diff options
| author | Tommy Chiang (oToToT) <ty1208chiang@gmail.com> | 2022-11-29 02:48:33 +0800 |
|---|---|---|
| committer | Tommy Chiang (oToToT) <ty1208chiang@gmail.com> | 2022-11-29 14:25:46 +0800 |
| commit | 382dba52ee0c6142d9a3774d735962797c043fab (patch) | |
| tree | d26e8a584557c22f0482902e8ed253bf2b76eb1e /src/test | |
| parent | 8a09420ac48658cad726e0a6997687ceac4151e3 (diff) | |
| download | rust-382dba52ee0c6142d9a3774d735962797c043fab.tar.gz rust-382dba52ee0c6142d9a3774d735962797c043fab.zip | |
v8a as default aarch64 target
After https://github.com/llvm/llvm-project/commit/8689f5e landed, LLVM takes the intersection of v8a and v8r as default. This commit brings back v8a support by explicitly specifying v8a in the feature list. This should solve #97724.
Diffstat (limited to 'src/test')
| -rw-r--r-- | src/test/assembly/asm/aarch64-el2vmsa.rs | 37 |
1 files changed, 37 insertions, 0 deletions
diff --git a/src/test/assembly/asm/aarch64-el2vmsa.rs b/src/test/assembly/asm/aarch64-el2vmsa.rs new file mode 100644 index 00000000000..1908ffb8ff3 --- /dev/null +++ b/src/test/assembly/asm/aarch64-el2vmsa.rs @@ -0,0 +1,37 @@ +// assembly-output: emit-asm +// compile-flags: --target aarch64-unknown-linux-gnu +// needs-llvm-components: aarch64 + +#![feature(no_core, lang_items, rustc_attrs)] +#![crate_type = "rlib"] +#![no_core] + +#[rustc_builtin_macro] +macro_rules! asm { + () => {}; +} + +#[lang = "sized"] +trait Sized {} + +// CHECK-LABEL: ttbr0_el2: +#[no_mangle] +pub fn ttbr0_el2() { + // CHECK: //APP + // CHECK-NEXT: msr TTBR0_EL2, x0 + // CHECK-NEXT: //NO_APP + unsafe { + asm!("msr ttbr0_el2, x0"); + } +} + +// CHECK-LABEL: vttbr_el2: +#[no_mangle] +pub fn vttbr_el2() { + // CHECK: //APP + // CHECK-NEXT: msr VTTBR_EL2, x0 + // CHECK-NEXT: //NO_APP + unsafe { + asm!("msr vttbr_el2, x0"); + } +} |
