//! This shows how to spawn a task on the second core. //! The first core will print the value of a counter which is incremented by the //! second core. #![no_std] #![no_main] use core::cell::RefCell; use critical_section::Mutex; use esp32s3_hal::{ clock::ClockControl, cpu_control::CpuControl, peripherals::{Peripherals, TIMG1}, prelude::*, timer::{Timer, Timer0, TimerGroup}, Rtc, }; use esp_backtrace as _; use esp_println::println; use nb::block; #[entry] fn main() -> ! { let peripherals = Peripherals::take(); let mut system = peripherals.SYSTEM.split(); let clocks = ClockControl::boot_defaults(system.clock_control).freeze(); let timer_group0 = TimerGroup::new( peripherals.TIMG0, &clocks, &mut system.peripheral_clock_control, ); let mut timer0 = timer_group0.timer0; let mut wdt0 = timer_group0.wdt; let timer_group1 = TimerGroup::new( peripherals.TIMG1, &clocks, &mut system.peripheral_clock_control, ); let mut timer1 = timer_group1.timer0; let mut wdt1 = timer_group1.wdt; let mut rtc = Rtc::new(peripherals.RTC_CNTL); // Disable MWDT and RWDT (Watchdog) flash boot protection wdt0.disable(); wdt1.disable(); rtc.rwdt.disable(); timer0.start(1u64.secs()); timer1.start(500u64.millis()); let counter = Mutex::new(RefCell::new(0)); let mut cpu_control = CpuControl::new(system.cpu_control); let mut cpu1_fnctn = || { cpu1_task(&mut timer1, &counter); }; let _guard = cpu_control.start_app_core(&mut cpu1_fnctn).unwrap(); loop { block!(timer0.wait()).unwrap(); let count = critical_section::with(|cs| *counter.borrow_ref(cs)); println!("Hello World - Core 0! Counter is {}", count); } } fn cpu1_task( timer: &mut Timer>, counter: &critical_section::Mutex>, ) -> ! { println!("Hello World - Core 1!"); loop { block!(timer.wait()).unwrap(); critical_section::with(|cs| { let new_val = counter.borrow_ref_mut(cs).wrapping_add(1); *counter.borrow_ref_mut(cs) = new_val; }); } }