aboutsummaryrefslogtreecommitdiff
path: root/cortex-m-rt/tests/compile-fail/unsafe-init-static.rs
diff options
context:
space:
mode:
authorGravatar bors[bot] <26634292+bors[bot]@users.noreply.github.com> 2019-11-24 14:20:30 +0000
committerGravatar GitHub <noreply@github.com> 2019-11-24 14:20:30 +0000
commit3445f11577d291195dee31e18cbfcb2a6982b124 (patch)
tree3f130e1d9b0699ed5c173fb1710744c245e0af5d /cortex-m-rt/tests/compile-fail/unsafe-init-static.rs
parent0457438264923a8c19016c25ae757b2dc9ee6d01 (diff)
parentee221ba79e050b35e3f756afbc798755012dccd1 (diff)
downloadcortex-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.rs45
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
+}