mirror of
https://github.com/rust-lang/rust.git
synced 2024-11-22 06:44:35 +00:00
Rollup merge of #131310 - taiki-e:msp430-clobber-abi, r=Amanieu
Support clobber_abi in MSP430 inline assembly This supports `clobber_abi` which is one of the requirements of stabilization mentioned in #93335. Refs: Section 3.2 "Register Conventions" in [MSP430 Embedded Application Binary Interface](https://www.ti.com/lit/an/slaa534a/slaa534a.pdf) cc ``@cr1901`` r? ``@Amanieu`` ``@rustbot`` label +O-msp430
This commit is contained in:
commit
9e72070f77
@ -893,6 +893,7 @@ pub enum InlineAsmClobberAbi {
|
|||||||
RiscV,
|
RiscV,
|
||||||
LoongArch,
|
LoongArch,
|
||||||
S390x,
|
S390x,
|
||||||
|
Msp430,
|
||||||
}
|
}
|
||||||
|
|
||||||
impl InlineAsmClobberAbi {
|
impl InlineAsmClobberAbi {
|
||||||
@ -946,6 +947,10 @@ impl InlineAsmClobberAbi {
|
|||||||
"C" | "system" => Ok(InlineAsmClobberAbi::S390x),
|
"C" | "system" => Ok(InlineAsmClobberAbi::S390x),
|
||||||
_ => Err(&["C", "system"]),
|
_ => Err(&["C", "system"]),
|
||||||
},
|
},
|
||||||
|
InlineAsmArch::Msp430 => match name {
|
||||||
|
"C" | "system" => Ok(InlineAsmClobberAbi::Msp430),
|
||||||
|
_ => Err(&["C", "system"]),
|
||||||
|
},
|
||||||
_ => Err(&[]),
|
_ => Err(&[]),
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -1125,6 +1130,11 @@ impl InlineAsmClobberAbi {
|
|||||||
a8, a9, a10, a11, a12, a13, a14, a15,
|
a8, a9, a10, a11, a12, a13, a14, a15,
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
InlineAsmClobberAbi::Msp430 => clobbered_regs! {
|
||||||
|
Msp430 Msp430InlineAsmReg {
|
||||||
|
r11, r12, r13, r14, r15,
|
||||||
|
}
|
||||||
|
},
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
36
tests/codegen/asm-msp430-clobbers.rs
Normal file
36
tests/codegen/asm-msp430-clobbers.rs
Normal file
@ -0,0 +1,36 @@
|
|||||||
|
//@ assembly-output: emit-asm
|
||||||
|
//@ compile-flags: --target msp430-none-elf
|
||||||
|
//@ needs-llvm-components: msp430
|
||||||
|
|
||||||
|
#![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: @sr_clobber
|
||||||
|
// CHECK: call void asm sideeffect "", "~{sr}"()
|
||||||
|
#[no_mangle]
|
||||||
|
pub unsafe fn sr_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 "", "={r11},={r12},={r13},={r14},={r15}"()
|
||||||
|
#[no_mangle]
|
||||||
|
pub unsafe fn clobber_abi() {
|
||||||
|
asm!("", clobber_abi("C"), options(nostack, nomem, preserves_flags));
|
||||||
|
}
|
Loading…
Reference in New Issue
Block a user