embedded-trainings-2020/advanced/firmware/src/bin/rtic-resource.rs

44 lines
1,011 B
Rust
Raw Normal View History

2020-06-09 09:52:27 +00:00
#![no_main]
#![no_std]
use cortex_m::asm;
use dk::peripheral::POWER;
2020-06-09 09:52:27 +00:00
use panic_log as _; // panic handler
#[rtic::app(device = dk)]
2020-06-09 09:52:27 +00:00
const APP: () = {
struct Resources {
power: POWER,
2020-06-09 09:52:27 +00:00
}
#[init]
fn init(_cx: init::Context) -> init::LateResources {
let board = dk::init().unwrap();
let power = board.power;
2020-06-09 09:52:27 +00:00
power.intenset.write(|w| w.usbdetected().set_bit());
2020-06-09 09:52:27 +00:00
log::info!("USBDETECTED interrupt enabled");
2020-06-09 09:52:27 +00:00
init::LateResources { power }
}
2020-06-09 09:52:27 +00:00
#[idle]
fn idle(_cx: idle::Context) -> ! {
loop {
log::info!("idle: going to sleep");
asm::wfi();
log::info!("idle: woke up");
}
}
2020-06-09 09:52:27 +00:00
#[task(binds = POWER_CLOCK, resources = [power])]
fn on_power_event(cx: on_power_event::Context) {
log::info!("POWER event occurred");
2020-06-09 09:52:27 +00:00
// clear the interrupt flag; otherwise this task will run again after it returns
cx.resources.power.events_usbdetected.reset();
2020-06-09 09:52:27 +00:00
}
};