rtic/examples/not-send.rs
2021-03-03 11:04:02 +01:00

63 lines
1.5 KiB
Rust

//! `examples/not-send.rs`
#![deny(unsafe_code)]
#![deny(warnings)]
#![no_main]
#![no_std]
use core::marker::PhantomData;
use cortex_m_semihosting::debug;
use panic_semihosting as _;
use rtic::app;
pub struct NotSend {
_0: PhantomData<*const ()>,
}
#[app(device = lm3s6965)]
const APP: () = {
struct Resources {
#[init(None)]
shared: Option<NotSend>,
}
#[init(spawn = [baz, quux])]
fn init(c: init::Context) {
c.spawn.baz().unwrap();
c.spawn.quux().unwrap();
}
#[task(spawn = [bar])]
fn foo(c: foo::Context) {
// scenario 1: message passed to task that runs at the same priority
c.spawn.bar(NotSend { _0: PhantomData }).ok();
}
#[task]
fn bar(_: bar::Context, _x: NotSend) {
// scenario 1
}
#[task(priority = 2, resources = [shared])]
fn baz(c: baz::Context) {
// scenario 2: resource shared between tasks that run at the same priority
*c.resources.shared = Some(NotSend { _0: PhantomData });
}
#[task(priority = 2, resources = [shared])]
fn quux(c: quux::Context) {
// scenario 2
let _not_send = c.resources.shared.take().unwrap();
debug::exit(debug::EXIT_SUCCESS);
}
// RTIC requires that unused interrupts are declared in an extern block when
// using software tasks; these free interrupts will be used to dispatch the
// software tasks.
extern "C" {
fn SSI0();
fn QEI0();
}
};