diff --git a/examples/lock2.rs b/examples/lock2.rs index 809d4dcc66..b505bf3b9f 100644 --- a/examples/lock2.rs +++ b/examples/lock2.rs @@ -25,7 +25,7 @@ const APP: () = { // when omitted priority is assumed to be `1` #[task(binds = GPIOA, resources = [shared, shared2])] - fn gpioa(mut c: gpioa::Context) { + fn gpioa(c: gpioa::Context) { c.resources.shared.lock(|shared| { *shared += 1; rtic::pend(Interrupt::GPIOB); diff --git a/examples/lock2_minimal.rs b/examples/lock2_minimal.rs new file mode 100644 index 0000000000..c1c6cccf81 --- /dev/null +++ b/examples/lock2_minimal.rs @@ -0,0 +1,39 @@ +//! examples/lock2.rs + +#![deny(unsafe_code)] +#![deny(warnings)] +#![no_main] +#![no_std] + +use cortex_m_semihosting::debug; +use lm3s6965::Interrupt; +use panic_semihosting as _; + +#[rtic::app(device = lm3s6965)] +const APP: () = { + struct Resources { + #[init(0)] + shared: u32, + #[init(0)] + shared2: u32, + } + + #[init] + fn init(_: init::Context) { + rtic::pend(Interrupt::GPIOA); + debug::exit(debug::EXIT_SUCCESS); + } + + // when omitted priority is assumed to be `1` + #[task(binds = GPIOA, resources = [shared, shared2])] + fn gpioa(c: gpioa::Context) { + c.resources.shared.lock(|shared| { + *shared += 1; + }); + } + + #[task(binds = GPIOB, priority = 2, resources = [shared, shared2])] + fn gpiob(c: gpiob::Context) { + *c.resources.shared += 1; + } +};