mirror of
https://github.com/embassy-rs/embassy.git
synced 2025-09-27 04:10:25 +00:00
embassy-rp: add multicore test for SpinlockRawMutex
This commit is contained in:
parent
05a6f7a795
commit
313328c09a
1
ci.sh
1
ci.sh
@ -338,6 +338,7 @@ rm out/tests/stm32u5a5zj/usart
|
||||
# As of 2025-02-17 these tests work when run from flash
|
||||
rm out/tests/pimoroni-pico-plus-2/multicore
|
||||
rm out/tests/pimoroni-pico-plus-2/gpio_multicore
|
||||
rm out/tests/pimoroni-pico-plus-2/spinlock_mutex_multicore
|
||||
# Doesn't work when run from ram on the 2350
|
||||
rm out/tests/pimoroni-pico-plus-2/flash
|
||||
# This test passes locally but fails on the HIL, no idea why
|
||||
|
54
tests/rp/src/bin/spinlock_mutex_multicore.rs
Normal file
54
tests/rp/src/bin/spinlock_mutex_multicore.rs
Normal file
@ -0,0 +1,54 @@
|
||||
#![no_std]
|
||||
#![no_main]
|
||||
#[cfg(feature = "rp2040")]
|
||||
teleprobe_meta::target!(b"rpi-pico");
|
||||
#[cfg(feature = "rp235xb")]
|
||||
teleprobe_meta::target!(b"pimoroni-pico-plus-2");
|
||||
|
||||
use defmt::{info, unwrap};
|
||||
use embassy_executor::Executor;
|
||||
use embassy_rp::multicore::{spawn_core1, Stack};
|
||||
use embassy_rp::spinlock_mutex::SpinlockRawMutex;
|
||||
use embassy_sync::channel::Channel;
|
||||
use static_cell::StaticCell;
|
||||
use {defmt_rtt as _, panic_probe as _};
|
||||
|
||||
static mut CORE1_STACK: Stack<1024> = Stack::new();
|
||||
static EXECUTOR0: StaticCell<Executor> = StaticCell::new();
|
||||
static EXECUTOR1: StaticCell<Executor> = StaticCell::new();
|
||||
static CHANNEL0: Channel<SpinlockRawMutex<0>, bool, 1> = Channel::new();
|
||||
static CHANNEL1: Channel<SpinlockRawMutex<1>, bool, 1> = Channel::new();
|
||||
|
||||
#[cortex_m_rt::entry]
|
||||
fn main() -> ! {
|
||||
let p = embassy_rp::init(Default::default());
|
||||
spawn_core1(
|
||||
p.CORE1,
|
||||
unsafe { &mut *core::ptr::addr_of_mut!(CORE1_STACK) },
|
||||
move || {
|
||||
let executor1 = EXECUTOR1.init(Executor::new());
|
||||
executor1.run(|spawner| unwrap!(spawner.spawn(core1_task())));
|
||||
},
|
||||
);
|
||||
let executor0 = EXECUTOR0.init(Executor::new());
|
||||
executor0.run(|spawner| unwrap!(spawner.spawn(core0_task())));
|
||||
}
|
||||
|
||||
#[embassy_executor::task]
|
||||
async fn core0_task() {
|
||||
info!("CORE0 is running");
|
||||
let ping = true;
|
||||
CHANNEL0.send(ping).await;
|
||||
let pong = CHANNEL1.receive().await;
|
||||
assert_eq!(ping, pong);
|
||||
|
||||
info!("Test OK");
|
||||
cortex_m::asm::bkpt();
|
||||
}
|
||||
|
||||
#[embassy_executor::task]
|
||||
async fn core1_task() {
|
||||
info!("CORE1 is running");
|
||||
let ping = CHANNEL0.receive().await;
|
||||
CHANNEL1.send(ping).await;
|
||||
}
|
Loading…
x
Reference in New Issue
Block a user