diff options
author | 2021-11-02 13:41:12 +0100 | |
---|---|---|
committer | 2021-11-02 13:41:12 +0100 | |
commit | 8065d741aceb96ea06e70afce05408e334a977b5 (patch) | |
tree | bcba74ecf2bc4985a39cfdceee627b0742cb4820 /macros/src/codegen/dispatchers.rs | |
parent | b25d775771f7ecc4fdfc5a2faaeb52e63cc344c9 (diff) | |
download | rtic-8065d741aceb96ea06e70afce05408e334a977b5.tar.gz rtic-8065d741aceb96ea06e70afce05408e334a977b5.tar.zst rtic-8065d741aceb96ea06e70afce05408e334a977b5.zip |
Fixed aliasing issue due to RacyCell implementation
Diffstat (limited to 'macros/src/codegen/dispatchers.rs')
-rw-r--r-- | macros/src/codegen/dispatchers.rs | 8 |
1 files changed, 4 insertions, 4 deletions
diff --git a/macros/src/codegen/dispatchers.rs b/macros/src/codegen/dispatchers.rs index 57103acd..a90a97c7 100644 --- a/macros/src/codegen/dispatchers.rs +++ b/macros/src/codegen/dispatchers.rs @@ -78,12 +78,12 @@ pub fn codegen(app: &App, analysis: &Analysis, _extra: &Extra) -> Vec<TokenStrea #(#cfgs)* #t::#name => { let #tupled = - #inputs - .get_unchecked() + (&*#inputs + .get()) .get_unchecked(usize::from(index)) .as_ptr() .read(); - #fq.get_mut_unchecked().split().0.enqueue_unchecked(index); + (&mut *#fq.get_mut()).split().0.enqueue_unchecked(index); let priority = &rtic::export::Priority::new(PRIORITY); #name( #name::Context::new(priority) @@ -95,7 +95,7 @@ pub fn codegen(app: &App, analysis: &Analysis, _extra: &Extra) -> Vec<TokenStrea .collect::<Vec<_>>(); stmts.push(quote!( - while let Some((task, index)) = #rq.get_mut_unchecked().split().1.dequeue() { + while let Some((task, index)) = (&mut *#rq.get_mut()).split().1.dequeue() { match task { #(#arms)* } |