diff options
author | 2019-11-24 14:20:30 +0000 | |
---|---|---|
committer | 2019-11-24 14:20:30 +0000 | |
commit | 3445f11577d291195dee31e18cbfcb2a6982b124 (patch) | |
tree | 3f130e1d9b0699ed5c173fb1710744c245e0af5d /cortex-m-rt/tests/compile-fail/unsafe-init-static.rs | |
parent | 0457438264923a8c19016c25ae757b2dc9ee6d01 (diff) | |
parent | ee221ba79e050b35e3f756afbc798755012dccd1 (diff) | |
download | cortex-m-3445f11577d291195dee31e18cbfcb2a6982b124.tar.gz cortex-m-3445f11577d291195dee31e18cbfcb2a6982b124.tar.zst cortex-m-3445f11577d291195dee31e18cbfcb2a6982b124.zip |
Merge #205
205: Stop using randomized symbol names r=therealprof a=jonas-schievink
It isn't possible to do this by incrementing a global counter, since the expansion order of macros isn't guaranteed and might change between compiler invocations.
Fixes #212
Closes https://github.com/rust-embedded/cortex-m-rt/pull/196
Closes https://github.com/rust-embedded/cortex-m-rt/pull/195
Co-authored-by: Jonas Schievink <jonasschievink@gmail.com>
Diffstat (limited to 'cortex-m-rt/tests/compile-fail/unsafe-init-static.rs')
-rw-r--r-- | cortex-m-rt/tests/compile-fail/unsafe-init-static.rs | 45 |
1 files changed, 45 insertions, 0 deletions
diff --git a/cortex-m-rt/tests/compile-fail/unsafe-init-static.rs b/cortex-m-rt/tests/compile-fail/unsafe-init-static.rs new file mode 100644 index 0000000..c040173 --- /dev/null +++ b/cortex-m-rt/tests/compile-fail/unsafe-init-static.rs @@ -0,0 +1,45 @@ +//! Makes sure that the expansion of the attributes doesn't put the resource initializer in an +//! implicit `unsafe` block. + +#![no_main] +#![no_std] + +extern crate cortex_m_rt; +extern crate panic_halt; + +use cortex_m_rt::{entry, exception, interrupt}; + +#[allow(non_camel_case_types)] +enum interrupt { + UART0, +} + +const unsafe fn init() -> u32 { 0 } + +#[entry] +fn foo() -> ! { + static mut X: u32 = init(); //~ ERROR requires unsafe + + loop {} +} + +#[exception] +fn SVCall() { + static mut X: u32 = init(); //~ ERROR requires unsafe +} + +#[exception] +fn DefaultHandler(_irq: i16) { + static mut X: u32 = init(); //~ ERROR requires unsafe +} + +#[exception] +fn HardFault(_frame: &cortex_m_rt::ExceptionFrame) -> ! { + static mut X: u32 = init(); //~ ERROR requires unsafe + loop {} +} + +#[interrupt] +fn UART0() { + static mut X: u32 = init(); //~ ERROR requires unsafe +} |