aboutsummaryrefslogtreecommitdiff
path: root/macros/src/codegen/dispatchers.rs
diff options
context:
space:
mode:
authorGravatar Emil Fresk <emil.fresk@gmail.com> 2021-11-02 13:41:12 +0100
committerGravatar Emil Fresk <emil.fresk@gmail.com> 2021-11-02 13:41:12 +0100
commit8065d741aceb96ea06e70afce05408e334a977b5 (patch)
treebcba74ecf2bc4985a39cfdceee627b0742cb4820 /macros/src/codegen/dispatchers.rs
parentb25d775771f7ecc4fdfc5a2faaeb52e63cc344c9 (diff)
downloadrtic-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.rs8
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)*
}