mirror of
https://github.com/italicsjenga/rp-hal-boards.git
synced 2025-01-26 03:06:32 +11:00
Add a fence after writing the arguments to the stack
Co-authored-by: Jan Niehusmann <jan@gondor.com>
This commit is contained in:
parent
9848f849bd
commit
e9534ace04
1 changed files with 11 additions and 0 deletions
|
@ -35,6 +35,8 @@
|
||||||
//! For a detailed example, see [examples/multicore_fifo_blink.rs](https://github.com/rp-rs/rp-hal/tree/main/rp2040-hal/examples/multicore_fifo_blink.rs)
|
//! For a detailed example, see [examples/multicore_fifo_blink.rs](https://github.com/rp-rs/rp-hal/tree/main/rp2040-hal/examples/multicore_fifo_blink.rs)
|
||||||
|
|
||||||
use core::mem::ManuallyDrop;
|
use core::mem::ManuallyDrop;
|
||||||
|
use core::sync::atomic::compiler_fence;
|
||||||
|
use core::sync::atomic::Ordering;
|
||||||
|
|
||||||
use crate::pac;
|
use crate::pac;
|
||||||
use crate::Sio;
|
use crate::Sio;
|
||||||
|
@ -194,6 +196,15 @@ impl<'p> Core<'p> {
|
||||||
stack_ptr.cast::<&mut ManuallyDrop<F>>().write(&mut entry);
|
stack_ptr.cast::<&mut ManuallyDrop<F>>().write(&mut entry);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Make sure the compiler does not reorder the stack writes after to after the
|
||||||
|
// below FIFO writes, which would result in them not being seen by the second
|
||||||
|
// core.
|
||||||
|
//
|
||||||
|
// From the compiler perspective, this doesn't guarantee that the second core
|
||||||
|
// actually sees those writes. However, we know that the RP2040 doesn't have
|
||||||
|
// memory caches, and writes happen in-order.
|
||||||
|
compiler_fence(Ordering::Release);
|
||||||
|
|
||||||
let vector_table = ppb.vtor.read().bits();
|
let vector_table = ppb.vtor.read().bits();
|
||||||
|
|
||||||
// After reset, core 1 is waiting to receive commands over FIFO.
|
// After reset, core 1 is waiting to receive commands over FIFO.
|
||||||
|
|
Loading…
Add table
Reference in a new issue