about summary refs log tree commit diff
path: root/tests/codegen
diff options
context:
space:
mode:
authorTaiki Endo <te316e89@gmail.com>2024-10-14 05:30:45 +0900
committerTaiki Endo <te316e89@gmail.com>2024-10-14 05:30:45 +0900
commitd858dfedbbde119f2ea707fea253e99c824ec252 (patch)
tree8297efb9c430d26187bbc45012d47f73f5dc9cc4 /tests/codegen
parent8f8bee4f60d9d3769f75c70d558c27a95761c554 (diff)
downloadrust-d858dfedbbde119f2ea707fea253e99c824ec252.tar.gz
rust-d858dfedbbde119f2ea707fea253e99c824ec252.zip
Fix clobber_abi and disallow SVE-related registers in Arm64EC inline assembly
Diffstat (limited to 'tests/codegen')
-rw-r--r--tests/codegen/asm-arm64ec-clobbers.rs36
1 files changed, 36 insertions, 0 deletions
diff --git a/tests/codegen/asm-arm64ec-clobbers.rs b/tests/codegen/asm-arm64ec-clobbers.rs
new file mode 100644
index 00000000000..2ec61907947
--- /dev/null
+++ b/tests/codegen/asm-arm64ec-clobbers.rs
@@ -0,0 +1,36 @@
+//@ assembly-output: emit-asm
+//@ compile-flags: --target arm64ec-pc-windows-msvc
+//@ needs-llvm-components: aarch64
+
+#![crate_type = "rlib"]
+#![feature(no_core, rustc_attrs, lang_items, asm_experimental_arch)]
+#![no_core]
+
+#[lang = "sized"]
+trait Sized {}
+
+#[rustc_builtin_macro]
+macro_rules! asm {
+    () => {};
+}
+
+// CHECK-LABEL: @cc_clobber
+// CHECK: call void asm sideeffect "", "~{cc}"()
+#[no_mangle]
+pub unsafe fn cc_clobber() {
+    asm!("", options(nostack, nomem));
+}
+
+// CHECK-LABEL: @no_clobber
+// CHECK: call void asm sideeffect "", ""()
+#[no_mangle]
+pub unsafe fn no_clobber() {
+    asm!("", options(nostack, nomem, preserves_flags));
+}
+
+// CHECK-LABEL: @clobber_abi
+// CHECK: asm sideeffect "", "={w0},={w1},={w2},={w3},={w4},={w5},={w6},={w7},={w8},={w9},={w10},={w11},={w12},={w15},={w16},={w17},={w30},={q0},={q1},={q2},={q3},={q4},={q5},={q6},={q7},={q8},={q9},={q10},={q11},={q12},={q13},={q14},={q15}"()
+#[no_mangle]
+pub unsafe fn clobber_abi() {
+    asm!("", clobber_abi("C"), options(nostack, nomem, preserves_flags));
+}