diff options
author | 2018-05-12 16:01:33 +0000 | |
---|---|---|
committer | 2018-05-12 16:01:33 +0000 | |
commit | e047a5cfd6f569e101f12e5ed81ad882584b5610 (patch) | |
tree | 780583be0fbdcb7bb51189048ba92835dc391534 /cortex-m-rt/examples/device.rs | |
parent | 17b72ec698240ff70e6a4f64158eefdf58df598a (diff) | |
parent | 09013442e31a44634b44fa92c48f2134bf1388e9 (diff) | |
download | cortex-m-e047a5cfd6f569e101f12e5ed81ad882584b5610.tar.gz cortex-m-e047a5cfd6f569e101f12e5ed81ad882584b5610.tar.zst cortex-m-e047a5cfd6f569e101f12e5ed81ad882584b5610.zip |
Merge #69
69: compile on stable r=japaric a=japaric
with these changes this crate compiles on stable
Co-authored-by: Jorge Aparicio <jorge@japaric.io>
Diffstat (limited to 'cortex-m-rt/examples/device.rs')
-rw-r--r-- | cortex-m-rt/examples/device.rs | 50 |
1 files changed, 50 insertions, 0 deletions
diff --git a/cortex-m-rt/examples/device.rs b/cortex-m-rt/examples/device.rs new file mode 100644 index 0000000..cf91f21 --- /dev/null +++ b/cortex-m-rt/examples/device.rs @@ -0,0 +1,50 @@ +//! Manually create the interrupts portion of the vector table + +#![deny(unsafe_code)] +#![deny(warnings)] +#![no_main] +#![no_std] + +#[macro_use(entry, exception)] +extern crate cortex_m_rt as rt; +extern crate panic_semihosting; + +use rt::ExceptionFrame; + +// the program entry point +entry!(main); + +fn main() -> ! { + loop {} +} + +// the hard fault handler +exception!(HardFault, hard_fault); + +fn hard_fault(_ef: &ExceptionFrame) -> ! { + loop {} +} + +// the default exception handler +exception!(*, default_handler); + +fn default_handler(_irqn: i16) {} + +// interrupts portion of the vector table +pub union Vector { + handler: unsafe extern "C" fn(), + reserved: usize, +} + +extern "C" { + fn WWDG(); + fn PVD(); +} + +#[link_section = ".vector_table.interrupts"] +#[no_mangle] +pub static __INTERRUPTS: [Vector; 3] = [ + Vector { handler: WWDG }, + Vector { reserved: 0 }, + Vector { handler: PVD }, +]; |