aboutsummaryrefslogtreecommitdiff
path: root/examples/lock-free.no_rs
diff options
context:
space:
mode:
authorPer Lindgren <per.lindgren@ltu.se>2023-01-07 14:23:32 +0100
committerHenrik Tjäder <henrik@tjaders.com>2023-03-01 00:31:08 +0100
commitb054e871d486e8eb35e3c98a73652640238c5e7d (patch)
tree96f96f598b224d23011ef385c873ed45da558d8f /examples/lock-free.no_rs
parentbd20d0d89e3ea477c9970f06f0ec750cee71690b (diff)
examples/lock fixed
Diffstat (limited to 'examples/lock-free.no_rs')
-rw-r--r--examples/lock-free.no_rs50
1 files changed, 50 insertions, 0 deletions
diff --git a/examples/lock-free.no_rs b/examples/lock-free.no_rs
new file mode 100644
index 0000000..053307c
--- /dev/null
+++ b/examples/lock-free.no_rs
@@ -0,0 +1,50 @@
+//! examples/lock-free.rs
+
+#![deny(unsafe_code)]
+#![deny(warnings)]
+#![no_main]
+#![no_std]
+#![feature(type_alias_impl_trait)]
+
+use panic_semihosting as _;
+
+#[rtic::app(device = lm3s6965, dispatchers = [GPIOA])]
+mod app {
+ use cortex_m_semihosting::{debug, hprintln};
+
+ #[shared]
+ struct Shared {
+ #[lock_free] // <- lock-free shared resource
+ counter: u64,
+ }
+
+ #[local]
+ struct Local {}
+
+ #[init]
+ fn init(_: init::Context) -> (Shared, Local) {
+ foo::spawn().unwrap();
+
+ (Shared { counter: 0 }, Local {})
+ }
+
+ #[task(shared = [counter])] // <- same priority
+ async fn foo(c: foo::Context) {
+ bar::spawn().unwrap();
+
+ *c.shared.counter += 1; // <- no lock API required
+ let counter = *c.shared.counter;
+ hprintln!(" foo = {}", counter).unwrap();
+ }
+
+ #[task(shared = [counter])] // <- same priority
+ async fn bar(c: bar::Context) {
+ foo::spawn().unwrap();
+
+ *c.shared.counter += 1; // <- no lock API required
+ let counter = *c.shared.counter;
+ hprintln!(" bar = {}", counter).unwrap();
+
+ debug::exit(debug::EXIT_SUCCESS); // Exit QEMU simulator
+ }
+}