diff options
| author | Taiki Endo <te316e89@gmail.com> | 2024-10-14 05:30:45 +0900 |
|---|---|---|
| committer | Taiki Endo <te316e89@gmail.com> | 2024-10-14 05:30:45 +0900 |
| commit | d858dfedbbde119f2ea707fea253e99c824ec252 (patch) | |
| tree | 8297efb9c430d26187bbc45012d47f73f5dc9cc4 /tests/codegen | |
| parent | 8f8bee4f60d9d3769f75c70d558c27a95761c554 (diff) | |
| download | rust-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.rs | 36 |
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)); +} |
