mirror of
https://github.com/italicsjenga/rp-hal-boards.git
synced 2025-01-10 20:41:31 +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
|
@ -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)
|
||||
|
||||
use core::mem::ManuallyDrop;
|
||||
use core::sync::atomic::compiler_fence;
|
||||
use core::sync::atomic::Ordering;
|
||||
|
||||
use crate::pac;
|
||||
use crate::Sio;
|
||||
|
@ -194,6 +196,15 @@ impl<'p> Core<'p> {
|
|||
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();
|
||||
|
||||
// After reset, core 1 is waiting to receive commands over FIFO.
|
||||
|
|
Loading…
Reference in a new issue