mirror of
https://github.com/rust-lang/rust-analyzer
synced 2025-01-14 14:13:58 +00:00
Rollup merge of #127766 - folkertdev:c-cmse-nonsecure-entry, r=jackh726
add `extern "C-cmse-nonsecure-entry" fn` tracking issue #75835 in https://github.com/rust-lang/rust/issues/75835#issuecomment-1183517255 it was decided that using an abi, rather than an attribute, was the right way to go for this feature. This PR adds that ABI and removes the `#[cmse_nonsecure_entry]` attribute. All relevant tests have been updated, some are now obsolete and have been removed. Error 0775 is no longer generated. It contains the list of targets that support the CMSE feature, and maybe we want to still use this? right now a generic "this abi is not supported on this platform" error is returned when this abi is used on an unsupported platform. On the other hand, users of this abi are likely to be experienced rust users, so maybe the generic error is good enough.
This commit is contained in:
commit
c1520a1263
3 changed files with 5 additions and 0 deletions
|
@ -377,6 +377,7 @@ pub enum FnAbi {
|
||||||
AvrNonBlockingInterrupt,
|
AvrNonBlockingInterrupt,
|
||||||
C,
|
C,
|
||||||
CCmseNonsecureCall,
|
CCmseNonsecureCall,
|
||||||
|
CCmseNonsecureEntry,
|
||||||
CDecl,
|
CDecl,
|
||||||
CDeclUnwind,
|
CDeclUnwind,
|
||||||
CUnwind,
|
CUnwind,
|
||||||
|
@ -434,6 +435,7 @@ impl FnAbi {
|
||||||
s if *s == sym::avr_dash_interrupt => FnAbi::AvrInterrupt,
|
s if *s == sym::avr_dash_interrupt => FnAbi::AvrInterrupt,
|
||||||
s if *s == sym::avr_dash_non_dash_blocking_dash_interrupt => FnAbi::AvrNonBlockingInterrupt,
|
s if *s == sym::avr_dash_non_dash_blocking_dash_interrupt => FnAbi::AvrNonBlockingInterrupt,
|
||||||
s if *s == sym::C_dash_cmse_dash_nonsecure_dash_call => FnAbi::CCmseNonsecureCall,
|
s if *s == sym::C_dash_cmse_dash_nonsecure_dash_call => FnAbi::CCmseNonsecureCall,
|
||||||
|
s if *s == sym::C_dash_cmse_dash_nonsecure_dash_entry => FnAbi::CCmseNonsecureEntry,
|
||||||
s if *s == sym::C_dash_unwind => FnAbi::CUnwind,
|
s if *s == sym::C_dash_unwind => FnAbi::CUnwind,
|
||||||
s if *s == sym::C => FnAbi::C,
|
s if *s == sym::C => FnAbi::C,
|
||||||
s if *s == sym::cdecl_dash_unwind => FnAbi::CDeclUnwind,
|
s if *s == sym::cdecl_dash_unwind => FnAbi::CDeclUnwind,
|
||||||
|
@ -477,6 +479,7 @@ impl FnAbi {
|
||||||
FnAbi::AvrNonBlockingInterrupt => "avr-non-blocking-interrupt",
|
FnAbi::AvrNonBlockingInterrupt => "avr-non-blocking-interrupt",
|
||||||
FnAbi::C => "C",
|
FnAbi::C => "C",
|
||||||
FnAbi::CCmseNonsecureCall => "C-cmse-nonsecure-call",
|
FnAbi::CCmseNonsecureCall => "C-cmse-nonsecure-call",
|
||||||
|
FnAbi::CCmseNonsecureEntry => "C-cmse-nonsecure-entry",
|
||||||
FnAbi::CDecl => "C-decl",
|
FnAbi::CDecl => "C-decl",
|
||||||
FnAbi::CDeclUnwind => "cdecl-unwind",
|
FnAbi::CDeclUnwind => "cdecl-unwind",
|
||||||
FnAbi::CUnwind => "C-unwind",
|
FnAbi::CUnwind => "C-unwind",
|
||||||
|
|
|
@ -32,6 +32,7 @@ const SUPPORTED_CALLING_CONVENTIONS: &[&str] = &[
|
||||||
"riscv-interrupt-m",
|
"riscv-interrupt-m",
|
||||||
"riscv-interrupt-s",
|
"riscv-interrupt-s",
|
||||||
"C-cmse-nonsecure-call",
|
"C-cmse-nonsecure-call",
|
||||||
|
"C-cmse-nonsecure-entry",
|
||||||
"wasm",
|
"wasm",
|
||||||
"system",
|
"system",
|
||||||
"system-unwind",
|
"system-unwind",
|
||||||
|
|
|
@ -94,6 +94,7 @@ define_symbols! {
|
||||||
avr_dash_interrupt = "avr-interrupt",
|
avr_dash_interrupt = "avr-interrupt",
|
||||||
avr_dash_non_dash_blocking_dash_interrupt = "avr-non-blocking-interrupt",
|
avr_dash_non_dash_blocking_dash_interrupt = "avr-non-blocking-interrupt",
|
||||||
C_dash_cmse_dash_nonsecure_dash_call = "C-cmse-nonsecure-call",
|
C_dash_cmse_dash_nonsecure_dash_call = "C-cmse-nonsecure-call",
|
||||||
|
C_dash_cmse_dash_nonsecure_dash_entry = "C-cmse-nonsecure-entry",
|
||||||
C_dash_unwind = "C-unwind",
|
C_dash_unwind = "C-unwind",
|
||||||
cdecl_dash_unwind = "cdecl-unwind",
|
cdecl_dash_unwind = "cdecl-unwind",
|
||||||
fastcall_dash_unwind = "fastcall-unwind",
|
fastcall_dash_unwind = "fastcall-unwind",
|
||||||
|
|
Loading…
Reference in a new issue