mirror of
https://github.com/italicsjenga/rp-hal-boards.git
synced 2025-01-10 12:31:31 +11:00
Make Multicore
take SioFifo
rather than the whole Sio
& make the spawn
closure the last argument
This commit is contained in:
parent
b932663cc9
commit
c0fafc7694
|
@ -115,11 +115,11 @@ fn main() -> ! {
|
||||||
// The single-cycle I/O block controls our GPIO pins
|
// The single-cycle I/O block controls our GPIO pins
|
||||||
let mut sio = hal::sio::Sio::new(pac.SIO);
|
let mut sio = hal::sio::Sio::new(pac.SIO);
|
||||||
|
|
||||||
let mut mc = Multicore::new(&mut pac.PSM, &mut pac.PPB, &mut sio);
|
let mut mc = Multicore::new(&mut pac.PSM, &mut pac.PPB, &mut sio.fifo);
|
||||||
let cores = mc.cores();
|
let cores = mc.cores();
|
||||||
let core1 = &mut cores[1];
|
let core1 = &mut cores[1];
|
||||||
let _test = core1.spawn(move || core1_task(sys_freq), unsafe {
|
let _test = core1.spawn(unsafe { &mut CORE1_STACK.mem }, move || {
|
||||||
&mut CORE1_STACK.mem
|
core1_task(sys_freq)
|
||||||
});
|
});
|
||||||
|
|
||||||
/// How much we adjust the LED period every cycle
|
/// How much we adjust the LED period every cycle
|
||||||
|
|
|
@ -101,7 +101,11 @@ impl<const SIZE: usize> Stack<SIZE> {
|
||||||
|
|
||||||
impl<'p> Multicore<'p> {
|
impl<'p> Multicore<'p> {
|
||||||
/// Create a new |Multicore| instance.
|
/// Create a new |Multicore| instance.
|
||||||
pub fn new(psm: &'p mut pac::PSM, ppb: &'p mut pac::PPB, sio: &'p mut crate::Sio) -> Self {
|
pub fn new(
|
||||||
|
psm: &'p mut pac::PSM,
|
||||||
|
ppb: &'p mut pac::PPB,
|
||||||
|
sio: &'p mut crate::sio::SioFifo,
|
||||||
|
) -> Self {
|
||||||
Self {
|
Self {
|
||||||
cores: [
|
cores: [
|
||||||
Core { inner: None },
|
Core { inner: None },
|
||||||
|
@ -120,7 +124,11 @@ impl<'p> Multicore<'p> {
|
||||||
|
|
||||||
/// A handle for controlling a logical core.
|
/// A handle for controlling a logical core.
|
||||||
pub struct Core<'p> {
|
pub struct Core<'p> {
|
||||||
inner: Option<(&'p mut pac::PSM, &'p mut pac::PPB, &'p mut crate::Sio)>,
|
inner: Option<(
|
||||||
|
&'p mut pac::PSM,
|
||||||
|
&'p mut pac::PPB,
|
||||||
|
&'p mut crate::sio::SioFifo,
|
||||||
|
)>,
|
||||||
}
|
}
|
||||||
|
|
||||||
impl<'p> Core<'p> {
|
impl<'p> Core<'p> {
|
||||||
|
@ -133,11 +141,11 @@ impl<'p> Core<'p> {
|
||||||
}
|
}
|
||||||
|
|
||||||
/// Spawn a function on this core.
|
/// Spawn a function on this core.
|
||||||
pub fn spawn<F>(&mut self, entry: F, stack: &'static mut [usize]) -> Result<(), Error>
|
pub fn spawn<F>(&mut self, stack: &'static mut [usize], entry: F) -> Result<(), Error>
|
||||||
where
|
where
|
||||||
F: FnOnce() -> bad::Never + Send + 'static,
|
F: FnOnce() -> bad::Never + Send + 'static,
|
||||||
{
|
{
|
||||||
if let Some((psm, ppb, sio)) = self.inner.as_mut() {
|
if let Some((psm, ppb, fifo)) = self.inner.as_mut() {
|
||||||
// The first two ignored `u64` parameters are there to take up all of the registers,
|
// The first two ignored `u64` parameters are there to take up all of the registers,
|
||||||
// which means that the rest of the arguments are taken from the stack,
|
// which means that the rest of the arguments are taken from the stack,
|
||||||
// where we're able to put them from core 0.
|
// where we're able to put them from core 0.
|
||||||
|
@ -202,11 +210,11 @@ impl<'p> Core<'p> {
|
||||||
loop {
|
loop {
|
||||||
let cmd = cmd_seq[seq] as u32;
|
let cmd = cmd_seq[seq] as u32;
|
||||||
if cmd == 0 {
|
if cmd == 0 {
|
||||||
sio.fifo.drain();
|
fifo.drain();
|
||||||
cortex_m::asm::sev();
|
cortex_m::asm::sev();
|
||||||
}
|
}
|
||||||
sio.fifo.write_blocking(cmd);
|
fifo.write_blocking(cmd);
|
||||||
let response = sio.fifo.read_blocking();
|
let response = fifo.read_blocking();
|
||||||
if cmd == response {
|
if cmd == response {
|
||||||
seq += 1;
|
seq += 1;
|
||||||
} else {
|
} else {
|
||||||
|
@ -225,7 +233,7 @@ impl<'p> Core<'p> {
|
||||||
}
|
}
|
||||||
|
|
||||||
// Wait until the other core has copied `entry` before returning.
|
// Wait until the other core has copied `entry` before returning.
|
||||||
sio.fifo.read_blocking();
|
fifo.read_blocking();
|
||||||
|
|
||||||
Ok(())
|
Ok(())
|
||||||
} else {
|
} else {
|
||||||
|
|
Loading…
Reference in a new issue