diff options
author | 2022-01-21 17:46:29 +0000 | |
---|---|---|
committer | 2022-01-25 09:11:49 -0800 | |
commit | 5d96aedd1403ad2ec6cfd3d5d2d043476d45645f (patch) | |
tree | 881771b058fe8e4a76a1a1935da7b7191dd30a7c /src/bits64/segmentation.rs | |
parent | 7c788ce1dc6d04dee68baa0ceddaf62b032953bb (diff) | |
download | rust-x86-5d96aedd1403ad2ec6cfd3d5d2d043476d45645f.tar.gz rust-x86-5d96aedd1403ad2ec6cfd3d5d2d043476d45645f.tar.zst rust-x86-5d96aedd1403ad2ec6cfd3d5d2d043476d45645f.zip |
Finish converting to new asm!() syntax.
I got a number of compile failures with `llvm_asm`
with the latest nightly. Instead of figuring out
how to fix that, I just went ahead and finished
converting everything to use `asm`, which has the
added bonus of being stable, anyway!
I'm not entirely sure this is all correct;
`cargo test` seems to drag in an explicit
dependency on x86-0.44.0, which still fails.
Note also that the SGX modifications are a bit
more elaborate than what had been there; apparently
LLVM uses the %rbx internally, even though the
instructions exposed in that module use that
register. I worked around that by pushing %rbx
and then copying the leaf operand from %rsi to
%rbx and copying %rbx _back_ to %rsi for output
and popping the original value of %rbx. The
input/output operands are then writen in terms
of %rsi.
Signed-off-by: Dan Cross <cross@gajendra.net>
Diffstat (limited to 'src/bits64/segmentation.rs')
-rw-r--r-- | src/bits64/segmentation.rs | 21 |
1 files changed, 12 insertions, 9 deletions
diff --git a/src/bits64/segmentation.rs b/src/bits64/segmentation.rs index c4420d8..36e3171 100644 --- a/src/bits64/segmentation.rs +++ b/src/bits64/segmentation.rs @@ -5,6 +5,9 @@ use crate::segmentation::{ LdtDescriptorBuilder, SystemDescriptorTypes64, }; +#[cfg(target_arch = "x86_64")] +use core::arch::asm; + /// Entry for IDT, GDT or LDT. /// /// See Intel 3a, Section 3.4.5 "Segment Descriptors", and Section 3.5.2 @@ -141,11 +144,11 @@ impl BuildDescriptor<Descriptor64> for DescriptorBuilder { /// Can cause a GP-fault with a bad `sel` value. #[cfg(target_arch = "x86_64")] pub unsafe fn load_cs(sel: SegmentSelector) { - llvm_asm!("pushq $0; \ + asm!("pushq {0}; \ leaq 1f(%rip), %rax; \ pushq %rax; \ lretq; \ - 1:" :: "ri" (sel.bits() as usize) : "rax" "memory"); + 1:", in(reg) sel.bits() as usize, out("rax") _, options(att_syntax)); } /// Write GS Segment Base @@ -154,7 +157,7 @@ pub unsafe fn load_cs(sel: SegmentSelector) { /// Needs FSGSBASE-Enable Bit (bit 16 of CR4) set. #[cfg(target_arch = "x86_64")] pub unsafe fn wrgsbase(base: u64) { - llvm_asm!("wrgsbase $0" :: "r" (base) : "memory"); + asm!("wrgsbase {0}", in(reg) base, options(att_syntax)); } /// Write FS Segment Base @@ -163,7 +166,7 @@ pub unsafe fn wrgsbase(base: u64) { /// Needs FSGSBASE-Enable Bit (bit 16 of CR4) set. #[cfg(target_arch = "x86_64")] pub unsafe fn wrfsbase(base: u64) { - llvm_asm!("wrfsbase $0" :: "r" (base) : "memory"); + asm!("wrfsbase {0}", in(reg) base, options(att_syntax)); } /// Read GS Segment Base @@ -173,7 +176,7 @@ pub unsafe fn wrfsbase(base: u64) { #[cfg(target_arch = "x86_64")] pub unsafe fn rdgsbase() -> u64 { let gs_base: u64; - llvm_asm!("rdgsbase $0" : "=r" (gs_base) ); + asm!("rdgsbase {0}", out(reg) gs_base, options(att_syntax)); gs_base } @@ -184,7 +187,7 @@ pub unsafe fn rdgsbase() -> u64 { #[cfg(target_arch = "x86_64")] pub unsafe fn rdfsbase() -> u64 { let fs_base: u64; - llvm_asm!("rdfsbase $0" : "=r" (fs_base) ); + asm!("rdfsbase {0}", out(reg) fs_base, options(att_syntax)); fs_base } @@ -195,7 +198,7 @@ pub unsafe fn rdfsbase() -> u64 { #[cfg(target_arch = "x86_64")] pub unsafe fn fs_deref() -> u64 { let fs: u64; - llvm_asm!("movq %fs:0x0, $0" : "=r" (fs) ); + asm!("movq %fs:0x0, {0}", out(reg) fs, options(att_syntax)); fs } @@ -206,7 +209,7 @@ pub unsafe fn fs_deref() -> u64 { #[cfg(target_arch = "x86_64")] pub unsafe fn gs_deref() -> u64 { let gs: u64; - llvm_asm!("movq %gs:0x0, $0" : "=r" (gs) ); + asm!("movq %gs:0x0, {0}", out(reg) gs, options(att_syntax)); gs } @@ -221,5 +224,5 @@ pub unsafe fn gs_deref() -> u64 { /// The SWAPGS instruction is a privileged instruction intended for use by system software. #[cfg(target_arch = "x86_64")] pub unsafe fn swapgs() { - llvm_asm!("swapgs" ::: "gs"); + asm!("swapgs"); } |