Expand description
Multicore support
This module handles setup of the 2nd cpu core on the rp2040, which we refer to as core1. It provides functionality for setting up the stack, and starting core1.
The entrypoint for core1 can be any function that never returns, including closures.
Enable the critical-section-impl feature in embassy-rp when sharing data across cores using
the embassy-sync primitives and CriticalSectionRawMutex.
§Usage
use embassy_rp::multicore::Stack;
use static_cell::StaticCell;
use embassy_executor::Executor;
use core::ptr::addr_of_mut;
static mut CORE1_STACK: Stack<4096> = Stack::new();
static EXECUTOR0: StaticCell<Executor> = StaticCell::new();
static EXECUTOR1: StaticCell<Executor> = StaticCell::new();
#[embassy_executor::task]
async fn core0_task() {
    // ...
}
#[embassy_executor::task]
async fn core1_task() {
    // ...
}
#[cortex_m_rt::entry]
fn main() -> ! {
    let p = embassy_rp::init(Default::default());
    embassy_rp::multicore::spawn_core1(p.CORE1, unsafe { &mut *addr_of_mut!(CORE1_STACK) }, move || {
        let executor1 = EXECUTOR1.init(Executor::new());
        executor1.run(|spawner| spawner.spawn(core1_task().unwrap()));
    });
    let executor0 = EXECUTOR0.init(Executor::new());
    executor0.run(|spawner| spawner.spawn(core0_task().unwrap()))
}Structs§
- Stack
- Data type for a properly aligned stack of N bytes
Enums§
- CoreId
- Represents a partiticular CPU core (SIO_CPUID)
Functions§
- current_core 
- Gets which core we are currently executing from
- pause_core1 
- Pause execution on CORE1.
- resume_core1 
- Resume CORE1 execution.
- spawn_core1 
- Spawn a function on this core