diff options
author | 2018-08-11 20:41:46 -0500 | |
---|---|---|
committer | 2018-08-11 20:41:46 -0500 | |
commit | 3b25e71a78c6ac8514f3d59dc6e124a57439dcb6 (patch) | |
tree | 12630e79c3f08c358fccfe680813b159576fea21 /cortex-m-rt/examples/override-exception.rs | |
parent | 230d42233d35f13de82c1c7cb893352512ed3794 (diff) | |
download | cortex-m-3b25e71a78c6ac8514f3d59dc6e124a57439dcb6.tar.gz cortex-m-3b25e71a78c6ac8514f3d59dc6e124a57439dcb6.tar.zst cortex-m-3b25e71a78c6ac8514f3d59dc6e124a57439dcb6.zip |
v0.5.2
Diffstat (limited to 'cortex-m-rt/examples/override-exception.rs')
-rw-r--r-- | cortex-m-rt/examples/override-exception.rs | 35 |
1 files changed, 35 insertions, 0 deletions
diff --git a/cortex-m-rt/examples/override-exception.rs b/cortex-m-rt/examples/override-exception.rs new file mode 100644 index 0000000..2f100a2 --- /dev/null +++ b/cortex-m-rt/examples/override-exception.rs @@ -0,0 +1,35 @@ +//! How to override the hard fault exception handler and the default exception handler + +#![deny(unsafe_code)] +#![deny(warnings)] +#![no_main] +#![no_std] + +extern crate cortex_m; +#[macro_use(entry, exception)] +extern crate cortex_m_rt as rt; +extern crate panic_semihosting; + +use cortex_m::asm; +use rt::ExceptionFrame; + +// the program entry point +entry!(main); + +fn main() -> ! { + loop {} +} + +exception!(*, default_handler); + +fn default_handler(_irqn: i16) { + asm::bkpt(); +} + +exception!(HardFault, hard_fault); + +fn hard_fault(_ef: &ExceptionFrame) -> ! { + asm::bkpt(); + + loop {} +} |