aboutsummaryrefslogtreecommitdiff
path: root/src/bits64/controlregs.rs
diff options
context:
space:
mode:
authorGravatar John Ericson <Ericson2314@Yahoo.com> 2016-06-29 15:49:33 -0700
committerGravatar John Ericson <Ericson2314@Yahoo.com> 2016-06-29 15:49:33 -0700
commitfffa3ae71951c3b8f4b2a441764a44ab8e55416e (patch)
tree9a9897b863c845d7679bebeb3c46a774ecb5e33c /src/bits64/controlregs.rs
parentaaf26598addf1ef47fd8422d688965f89302d21b (diff)
downloadrust-x86-fffa3ae71951c3b8f4b2a441764a44ab8e55416e.tar.gz
rust-x86-fffa3ae71951c3b8f4b2a441764a44ab8e55416e.tar.zst
rust-x86-fffa3ae71951c3b8f4b2a441764a44ab8e55416e.zip
Crudely throw everything together
Diffstat (limited to 'src/bits64/controlregs.rs')
-rw-r--r--src/bits64/controlregs.rs43
1 files changed, 43 insertions, 0 deletions
diff --git a/src/bits64/controlregs.rs b/src/bits64/controlregs.rs
new file mode 100644
index 0000000..c243caf
--- /dev/null
+++ b/src/bits64/controlregs.rs
@@ -0,0 +1,43 @@
+//! Functions to read and write control registers.
+
+pub unsafe fn cr0() -> u64 {
+ let ret: u64;
+ asm!("mov %cr0, $0" : "=r" (ret));
+ ret
+}
+
+/// Write cr0.
+pub unsafe fn cr0_write(val: u64) {
+ asm!("mov $0, %cr0" :: "r" (val) : "memory");
+}
+
+/// Contains page-fault linear address.
+pub unsafe fn cr2() -> u64 {
+ let ret: u64;
+ asm!("mov %cr2, $0" : "=r" (ret));
+ ret
+}
+
+/// Contains page-table root pointer.
+pub unsafe fn cr3() -> u64 {
+ let ret: u64;
+ asm!("mov %cr3, $0" : "=r" (ret));
+ ret
+}
+
+/// Switch page-table PML4 pointer.
+pub unsafe fn cr3_write(val: u64) {
+ asm!("mov $0, %cr3" :: "r" (val) : "memory");
+}
+
+/// Contains various flags to control operations in protected mode.
+pub unsafe fn cr4() -> u64 {
+ let ret: u64;
+ asm!("mov %cr4, $0" : "=r" (ret));
+ ret
+}
+
+/// Write cr4.
+pub unsafe fn cr4_write(val: u64) {
+ asm!("mov $0, %cr4" :: "r" (val) : "memory");
+}