aboutsummaryrefslogtreecommitdiff
path: root/cortex-m-rt/tests/compile-fail/exception-soundness.rs
diff options
context:
space:
mode:
authorGravatar Adam Greig <adam@adamgreig.com> 2022-01-12 00:48:56 +0000
committerGravatar Adam Greig <adam@adamgreig.com> 2022-01-12 00:48:56 +0000
commit0ffd08328a3ec20974d72ea87a2883d8c9135411 (patch)
tree17e1aebd54840ca3597f4e7722fba1d504220b38 /cortex-m-rt/tests/compile-fail/exception-soundness.rs
parent92552c73d3b56dc86007450633950d16ebe0e495 (diff)
parent5932aaa76bed539c1222e9592be12ca4d4bf5847 (diff)
downloadcortex-m-0ffd08328a3ec20974d72ea87a2883d8c9135411.tar.gz
cortex-m-0ffd08328a3ec20974d72ea87a2883d8c9135411.tar.zst
cortex-m-0ffd08328a3ec20974d72ea87a2883d8c9135411.zip
Merge cortex-m-rt repository into cortex-m.
Diffstat (limited to 'cortex-m-rt/tests/compile-fail/exception-soundness.rs')
-rw-r--r--cortex-m-rt/tests/compile-fail/exception-soundness.rs29
1 files changed, 29 insertions, 0 deletions
diff --git a/cortex-m-rt/tests/compile-fail/exception-soundness.rs b/cortex-m-rt/tests/compile-fail/exception-soundness.rs
new file mode 100644
index 0000000..9a1e10b
--- /dev/null
+++ b/cortex-m-rt/tests/compile-fail/exception-soundness.rs
@@ -0,0 +1,29 @@
+#![no_main]
+#![no_std]
+
+extern crate cortex_m_rt;
+extern crate panic_halt;
+
+use cortex_m_rt::{entry, exception};
+
+#[entry]
+fn foo() -> ! {
+ loop {}
+}
+
+#[exception]
+fn SysTick() {
+ static mut COUNT: u64 = 0;
+
+ if *COUNT % 2 == 0 {
+ *COUNT += 1;
+ } else {
+ *COUNT *= 2;
+ }
+}
+
+#[exception]
+fn SVCall() {
+ // If this was allowed it would lead to a data race as `SVCall` could preempt `SysTick`
+ SysTick(); //~ ERROR cannot find function, tuple struct or tuple variant `SysTick` in this scope [E0425]
+}