diff options
author | 2022-01-12 00:48:56 +0000 | |
---|---|---|
committer | 2022-01-12 00:48:56 +0000 | |
commit | 0ffd08328a3ec20974d72ea87a2883d8c9135411 (patch) | |
tree | 17e1aebd54840ca3597f4e7722fba1d504220b38 /cortex-m-rt/tests/compile-fail/exception-soundness.rs | |
parent | 92552c73d3b56dc86007450633950d16ebe0e495 (diff) | |
parent | 5932aaa76bed539c1222e9592be12ca4d4bf5847 (diff) | |
download | cortex-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.rs | 29 |
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] +} |