diff options
author | 2021-07-09 11:00:11 +0000 | |
---|---|---|
committer | 2021-07-09 11:00:11 +0000 | |
commit | e1a4d001f8e724596cd9de3e90698ce7de473b3f (patch) | |
tree | f7aac5eae4cc2e19cc06bfd6fa8dab843dcfb276 /examples/shared.rs | |
parent | 13dc3992e616d817e38c167c4b47db816855f18b (diff) | |
parent | f3d9fd9b638a25b497e1ca02e7ce5de86c9fc1c9 (diff) | |
download | rtic-e1a4d001f8e724596cd9de3e90698ce7de473b3f.tar.gz rtic-e1a4d001f8e724596cd9de3e90698ce7de473b3f.tar.zst rtic-e1a4d001f8e724596cd9de3e90698ce7de473b3f.zip |
Merge #494
494: Resoures take 2 r=korken89 a=korken89
Co-authored-by: Emil Fresk <emil.fresk@gmail.com>
Diffstat (limited to 'examples/shared.rs')
-rw-r--r-- | examples/shared.rs | 54 |
1 files changed, 54 insertions, 0 deletions
diff --git a/examples/shared.rs b/examples/shared.rs new file mode 100644 index 00000000..c3fa07b9 --- /dev/null +++ b/examples/shared.rs @@ -0,0 +1,54 @@ +//! examples/late.rs + +#![deny(unsafe_code)] +#![deny(warnings)] +#![no_main] +#![no_std] + +use panic_semihosting as _; + +#[rtic::app(device = lm3s6965)] +mod app { + use cortex_m_semihosting::{debug, hprintln}; + use heapless::{ + consts::*, + i, + spsc::{Consumer, Producer, Queue}, + }; + use lm3s6965::Interrupt; + + #[shared] + struct Shared { + p: Producer<'static, u32, U4>, + c: Consumer<'static, u32, U4>, + } + + #[local] + struct Local {} + + #[init(local = [q: Queue<u32, U4> = Queue(i::Queue::new())])] + fn init(cx: init::Context) -> (Shared, Local, init::Monotonics) { + let (p, c) = cx.local.q.split(); + + // Initialization of shared resources + (Shared { p, c }, Local {}, init::Monotonics()) + } + + #[idle(shared = [c])] + fn idle(mut c: idle::Context) -> ! { + loop { + if let Some(byte) = c.shared.c.lock(|c| c.dequeue()) { + hprintln!("received message: {}", byte).unwrap(); + + debug::exit(debug::EXIT_SUCCESS); + } else { + rtic::pend(Interrupt::UART0); + } + } + } + + #[task(binds = UART0, shared = [p])] + fn uart0(mut c: uart0::Context) { + c.shared.p.lock(|p| p.enqueue(42).unwrap()); + } +} |