diff options
author | 2021-07-09 11:00:11 +0000 | |
---|---|---|
committer | 2021-07-09 11:00:11 +0000 | |
commit | e1a4d001f8e724596cd9de3e90698ce7de473b3f (patch) | |
tree | f7aac5eae4cc2e19cc06bfd6fa8dab843dcfb276 /examples/not-sync.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/not-sync.rs')
-rw-r--r-- | examples/not-sync.rs | 30 |
1 files changed, 20 insertions, 10 deletions
diff --git a/examples/not-sync.rs b/examples/not-sync.rs index f01d4043..1510e504 100644 --- a/examples/not-sync.rs +++ b/examples/not-sync.rs @@ -1,6 +1,6 @@ //! `examples/not-sync.rs` -#![deny(unsafe_code)] +// #![deny(unsafe_code)] #![deny(warnings)] #![no_main] #![no_std] @@ -12,32 +12,42 @@ pub struct NotSync { _0: PhantomData<*const ()>, } +unsafe impl Send for NotSync {} + #[rtic::app(device = lm3s6965, dispatchers = [SSI0])] mod app { use super::NotSync; use core::marker::PhantomData; use cortex_m_semihosting::debug; - #[resources] - struct Resources { - #[init(NotSync { _0: PhantomData })] + #[shared] + struct Shared { shared: NotSync, } + #[local] + struct Local {} + #[init] - fn init(_: init::Context) -> (init::LateResources, init::Monotonics) { + fn init(_: init::Context) -> (Shared, Local, init::Monotonics) { debug::exit(debug::EXIT_SUCCESS); - (init::LateResources {}, init::Monotonics()) + ( + Shared { + shared: NotSync { _0: PhantomData }, + }, + Local {}, + init::Monotonics(), + ) } - #[task(resources = [&shared])] + #[task(shared = [&shared])] fn foo(c: foo::Context) { - let _: &NotSync = c.resources.shared; + let _: &NotSync = c.shared.shared; } - #[task(resources = [&shared])] + #[task(shared = [&shared])] fn bar(c: bar::Context) { - let _: &NotSync = c.resources.shared; + let _: &NotSync = c.shared.shared; } } |