aboutsummaryrefslogtreecommitdiff
path: root/src/shared
diff options
context:
space:
mode:
authorGravatar John Ericson <Ericson2314@Yahoo.com> 2016-06-27 18:00:46 -0700
committerGravatar John Ericson <Ericson2314@Yahoo.com> 2016-06-29 22:48:09 -0700
commitdd3bb0fca40118e52c4584c11f0d010410da4a0c (patch)
tree5244ed55399dca02db1d7aa2bb84def26c84696c /src/shared
parentd322a4db5f84405d76c1498259ab3a59df51f265 (diff)
downloadrust-x86-dd3bb0fca40118e52c4584c11f0d010410da4a0c.tar.gz
rust-x86-dd3bb0fca40118e52c4584c11f0d010410da4a0c.tar.zst
rust-x86-dd3bb0fca40118e52c4584c11f0d010410da4a0c.zip
`dtables::*` is mode-portable
Diffstat (limited to 'src/shared')
-rw-r--r--src/shared/dtables.rs27
-rw-r--r--src/shared/mod.rs1
2 files changed, 28 insertions, 0 deletions
diff --git a/src/shared/dtables.rs b/src/shared/dtables.rs
new file mode 100644
index 0000000..d2e3413
--- /dev/null
+++ b/src/shared/dtables.rs
@@ -0,0 +1,27 @@
+//! Functions and data-structures to load descriptor tables.
+
+/// A struct describing a pointer to a descriptor table (GDT / IDT).
+/// This is in a format suitable for giving to 'lgdt' or 'lidt'.
+#[derive(Debug)]
+#[repr(C, packed)]
+pub struct DescriptorTablePointer {
+ /// Size of the DT.
+ pub limit: u16,
+ /// Pointer to the memory region containing the DT.
+ pub base: u64,
+}
+
+/// Load GDT table.
+pub unsafe fn lgdt(gdt: &DescriptorTablePointer) {
+ asm!("lgdt ($0)" :: "r" (gdt) : "memory");
+}
+
+/// Load LDT table.
+pub unsafe fn lldt(ldt: &DescriptorTablePointer) {
+ asm!("lldt ($0)" :: "r" (ldt) : "memory");
+}
+
+/// Load IDT table.
+pub unsafe fn lidt(idt: &DescriptorTablePointer) {
+ asm!("lidt ($0)" :: "r" (idt) : "memory");
+}
diff --git a/src/shared/mod.rs b/src/shared/mod.rs
index a461c08..977dcf4 100644
--- a/src/shared/mod.rs
+++ b/src/shared/mod.rs
@@ -2,6 +2,7 @@
pub mod control_regs;
pub mod descriptor;
+pub mod dtables;
pub mod io;
pub mod irq;
pub mod paging;