diff options
author | 2021-07-09 11:00:11 +0000 | |
---|---|---|
committer | 2021-07-09 11:00:11 +0000 | |
commit | e1a4d001f8e724596cd9de3e90698ce7de473b3f (patch) | |
tree | f7aac5eae4cc2e19cc06bfd6fa8dab843dcfb276 /examples/big-struct-opt.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/big-struct-opt.rs')
-rw-r--r-- | examples/big-struct-opt.rs | 23 |
1 files changed, 14 insertions, 9 deletions
diff --git a/examples/big-struct-opt.rs b/examples/big-struct-opt.rs index e6a5c172..2d0cc83d 100644 --- a/examples/big-struct-opt.rs +++ b/examples/big-struct-opt.rs @@ -25,27 +25,32 @@ mod app { use super::BigStruct; use core::mem::MaybeUninit; - #[resources] - struct Resources { + #[shared] + struct Shared { big_struct: &'static mut BigStruct, } - #[init] - fn init(_: init::Context) -> (init::LateResources, init::Monotonics) { - let big_struct = unsafe { - static mut BIG_STRUCT: MaybeUninit<BigStruct> = MaybeUninit::uninit(); + #[local] + struct Local {} + #[init(local = [bs: MaybeUninit<BigStruct> = MaybeUninit::uninit()])] + fn init(cx: init::Context) -> (Shared, Local, init::Monotonics) { + let big_struct = unsafe { // write directly into the static storage - BIG_STRUCT.as_mut_ptr().write(BigStruct::new()); - &mut *BIG_STRUCT.as_mut_ptr() + cx.local.bs.as_mut_ptr().write(BigStruct::new()); + &mut *cx.local.bs.as_mut_ptr() }; ( - init::LateResources { + Shared { // assign the reference so we can use the resource big_struct, }, + Local {}, init::Monotonics(), ) } + + #[task(binds = UART0, shared = [big_struct])] + fn task(_: task::Context) {} } |