diff options
author | 2022-03-04 13:26:33 +0100 | |
---|---|---|
committer | 2022-03-05 11:14:36 +0100 | |
commit | ca2577e3b8b5e05923f0d0d9deba6990940869e5 (patch) | |
tree | 237aed39ae4f1da4a197a5c9d374c19ea9ef2f31 /examples-runner/src/bin/message_passing.rs | |
parent | a765f3fffac95f270ce416dc15acd063b215f027 (diff) | |
download | rtic-ca2577e3b8b5e05923f0d0d9deba6990940869e5.tar.gz rtic-ca2577e3b8b5e05923f0d0d9deba6990940869e5.tar.zst rtic-ca2577e3b8b5e05923f0d0d9deba6990940869e5.zip |
Embedded ci works
Diffstat (limited to 'examples-runner/src/bin/message_passing.rs')
-rw-r--r-- | examples-runner/src/bin/message_passing.rs | 37 |
1 files changed, 37 insertions, 0 deletions
diff --git a/examples-runner/src/bin/message_passing.rs b/examples-runner/src/bin/message_passing.rs new file mode 100644 index 00000000..106c8e5a --- /dev/null +++ b/examples-runner/src/bin/message_passing.rs @@ -0,0 +1,37 @@ +//! examples/message_passing.rs + +#![deny(unsafe_code)] +#![deny(warnings)] +#![no_main] +#![no_std] + +use examples_runner as _; + +#[rtic::app(device = examples_runner::pac, dispatchers = [SSI0])] +mod app { + use examples_runner::{println, exit}; + + #[shared] + struct Shared {} + + #[local] + struct Local {} + + #[init] + fn init(_: init::Context) -> (Shared, Local, init::Monotonics) { + foo::spawn(1, 1).unwrap(); + foo::spawn(1, 2).unwrap(); + foo::spawn(2, 3).unwrap(); + assert!(foo::spawn(1, 4).is_err()); // The capacity of `foo` is reached + + (Shared {}, Local {}, init::Monotonics()) + } + + #[task(capacity = 3)] + fn foo(_c: foo::Context, x: i32, y: u32) { + println!("foo {}, {}", x, y); + if x == 2 { + exit(); + } + } +} |