about summary refs log tree commit diff
path: root/src/test
diff options
context:
space:
mode:
authorTommy Chiang (oToToT) <ty1208chiang@gmail.com>2022-11-29 02:48:33 +0800
committerTommy Chiang (oToToT) <ty1208chiang@gmail.com>2022-11-29 14:25:46 +0800
commit382dba52ee0c6142d9a3774d735962797c043fab (patch)
treed26e8a584557c22f0482902e8ed253bf2b76eb1e /src/test
parent8a09420ac48658cad726e0a6997687ceac4151e3 (diff)
downloadrust-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.rs37
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");
+    }
+}