From 51db37a4cb1522f28146ee1c8df82c4885ddc9bf Mon Sep 17 00:00:00 2001 From: Wilfried Chauveau <wilfried.chauveau@ithinuel.me> Date: Sun, 21 Aug 2022 19:00:57 +0100 Subject: [PATCH] replace cortex_m::interrupt::Mutex with critical_section::Mutex in examples (#422) --- boards/rp-pico/CHANGELOG.md | 1 + boards/rp-pico/Cargo.toml | 1 + boards/rp-pico/examples/pico_uart_irq_buffer.rs | 12 ++++++------ boards/rp-pico/examples/pico_uart_irq_echo.rs | 6 +++--- boards/rp-pico/examples/pico_usb_twitchy_mouse.rs | 2 +- rp2040-hal/examples/gpio_irq_example.rs | 6 +++--- rp2040-hal/examples/vector_table.rs | 10 +++++----- 7 files changed, 20 insertions(+), 18 deletions(-) diff --git a/boards/rp-pico/CHANGELOG.md b/boards/rp-pico/CHANGELOG.md index 30e5668..d98d693 100644 --- a/boards/rp-pico/CHANGELOG.md +++ b/boards/rp-pico/CHANGELOG.md @@ -10,6 +10,7 @@ and this project adheres to [Semantic Versioning](https://semver.org/spec/v2.0.0 ### Added - `rp2040-e5` feature enabling the workaround for errata 5 on the USB device peripheral. +- Support for critical-section 1.0.0 in the examples. ### Changed diff --git a/boards/rp-pico/Cargo.toml b/boards/rp-pico/Cargo.toml index 2ef6b88..3943368 100644 --- a/boards/rp-pico/Cargo.toml +++ b/boards/rp-pico/Cargo.toml @@ -37,6 +37,7 @@ embedded-graphics = "0.7.1" hd44780-driver = "0.4.0" pio = "0.2.0" pio-proc = "0.2.1" +critical-section = "1.0.0" defmt = "0.3.0" defmt-rtt = "0.3.0" diff --git a/boards/rp-pico/examples/pico_uart_irq_buffer.rs b/boards/rp-pico/examples/pico_uart_irq_buffer.rs index 9117662..6e78846 100644 --- a/boards/rp-pico/examples/pico_uart_irq_buffer.rs +++ b/boards/rp-pico/examples/pico_uart_irq_buffer.rs @@ -49,7 +49,7 @@ use pac::interrupt; // Some short-cuts to useful types use core::cell::RefCell; -use cortex_m::interrupt::Mutex; +use critical_section::Mutex; use heapless::spsc::Queue; /// Import the GPIO pins we use @@ -148,7 +148,7 @@ fn main() -> ! { // Now we give away the entire UART peripheral, via the variable // `GLOBAL_UART`. We can no longer access the UART from this main thread. - cortex_m::interrupt::free(|cs| { + critical_section::with(|cs| { GLOBAL_UART.borrow(cs).replace(Some(uart)); }); @@ -180,7 +180,7 @@ fn main() -> ! { impl UartQueue { /// Try and get some data out of the UART Queue. Returns None if queue empty. fn read_byte(&self) -> Option<u8> { - cortex_m::interrupt::free(|cs| { + critical_section::with(|cs| { let cell_queue = self.mutex_cell_queue.borrow(cs); let mut queue = cell_queue.borrow_mut(); queue.dequeue() @@ -189,7 +189,7 @@ impl UartQueue { /// Peek at the next byte in the queue without removing it. fn peek_byte(&self) -> Option<u8> { - cortex_m::interrupt::free(|cs| { + critical_section::with(|cs| { let cell_queue = self.mutex_cell_queue.borrow(cs); let queue = cell_queue.borrow_mut(); queue.peek().cloned() @@ -208,7 +208,7 @@ impl UartQueue { // Grab the mutex, by turning interrupts off. NOTE: This // doesn't work if you are using Core 1 as we only turn // interrupts off on one core. - cortex_m::interrupt::free(|cs| { + critical_section::with(|cs| { // Grab the mutex contents. let cell_queue = self.mutex_cell_queue.borrow(cs); // Grab mutable access to the queue. This can't fail @@ -262,7 +262,7 @@ fn UART0_IRQ() { // This is one-time lazy initialisation. We steal the variable given to us // via `GLOBAL_UART`. if UART.is_none() { - cortex_m::interrupt::free(|cs| { + critical_section::with(|cs| { *UART = GLOBAL_UART.borrow(cs).take(); }); } diff --git a/boards/rp-pico/examples/pico_uart_irq_echo.rs b/boards/rp-pico/examples/pico_uart_irq_echo.rs index 5002e6e..e1ee12b 100644 --- a/boards/rp-pico/examples/pico_uart_irq_echo.rs +++ b/boards/rp-pico/examples/pico_uart_irq_echo.rs @@ -47,7 +47,7 @@ use hal::pac::interrupt; // Some short-cuts to useful types use core::cell::RefCell; -use cortex_m::interrupt::Mutex; +use critical_section::Mutex; /// Import the GPIO pins we use use hal::gpio::pin::bank0::{Gpio0, Gpio1}; @@ -142,7 +142,7 @@ fn main() -> ! { // Now we give away the entire UART peripheral, via the variable // `GLOBAL_UART`. We can no longer access the UART from this main thread. - cortex_m::interrupt::free(|cs| { + critical_section::with(|cs| { GLOBAL_UART.borrow(cs).replace(Some(uart)); }); @@ -177,7 +177,7 @@ fn UART0_IRQ() { // This is one-time lazy initialisation. We steal the variable given to us // via `GLOBAL_UART`. if UART.is_none() { - cortex_m::interrupt::free(|cs| { + critical_section::with(|cs| { *UART = GLOBAL_UART.borrow(cs).take(); }); } diff --git a/boards/rp-pico/examples/pico_usb_twitchy_mouse.rs b/boards/rp-pico/examples/pico_usb_twitchy_mouse.rs index 56de286..f139d3b 100644 --- a/boards/rp-pico/examples/pico_usb_twitchy_mouse.rs +++ b/boards/rp-pico/examples/pico_usb_twitchy_mouse.rs @@ -168,7 +168,7 @@ fn main() -> ! { /// /// We do this with interrupts disabled, to avoid a race hazard with the USB IRQ. fn push_mouse_movement(report: MouseReport) -> Result<usize, usb_device::UsbError> { - cortex_m::interrupt::free(|_| unsafe { + critical_section::with(|_| unsafe { // Now interrupts are disabled, grab the global variable and, if // available, send it a HID report USB_HID.as_mut().map(|hid| hid.push_input(&report)) diff --git a/rp2040-hal/examples/gpio_irq_example.rs b/rp2040-hal/examples/gpio_irq_example.rs index d374590..91d440f 100644 --- a/rp2040-hal/examples/gpio_irq_example.rs +++ b/rp2040-hal/examples/gpio_irq_example.rs @@ -44,7 +44,7 @@ use hal::pac::interrupt; // Some short-cuts to useful types use core::cell::RefCell; -use cortex_m::interrupt::Mutex; +use critical_section::Mutex; use rp2040_hal::gpio; // The GPIO interrupt type we're going to generate @@ -133,7 +133,7 @@ fn main() -> ! { // Give away our pins by moving them into the `GLOBAL_PINS` variable. // We won't need to access them in the main thread again - cortex_m::interrupt::free(|cs| { + critical_section::with(|cs| { GLOBAL_PINS.borrow(cs).replace(Some((led, in_pin))); }); @@ -159,7 +159,7 @@ fn IO_IRQ_BANK0() { // This is one-time lazy initialisation. We steal the variables given to us // via `GLOBAL_PINS`. if LED_AND_BUTTON.is_none() { - cortex_m::interrupt::free(|cs| { + critical_section::with(|cs| { *LED_AND_BUTTON = GLOBAL_PINS.borrow(cs).take(); }); } diff --git a/rp2040-hal/examples/vector_table.rs b/rp2040-hal/examples/vector_table.rs index b8eee08..dfac446 100644 --- a/rp2040-hal/examples/vector_table.rs +++ b/rp2040-hal/examples/vector_table.rs @@ -23,7 +23,7 @@ use hal::pac; // Some traits we need use core::cell::RefCell; -use cortex_m::interrupt::Mutex; +use critical_section::Mutex; use embedded_hal::digital::v2::ToggleableOutputPin; use embedded_time::duration::Microseconds; use embedded_time::fixed_point::FixedPoint; @@ -113,7 +113,7 @@ fn main() -> ! { let led_pin = pins.gpio25.into_push_pull_output(); let mut timer = hal::Timer::new(pac.TIMER, &mut pac.RESETS); - cortex_m::interrupt::free(|cs| { + critical_section::with(|cs| { let mut alarm = timer.alarm_0().unwrap(); // Schedule an alarm in 1 second let _ = alarm.schedule(Microseconds(SLOW_BLINK_INTERVAL_US)); @@ -132,7 +132,7 @@ fn main() -> ! { // After 5 seconds, switch to our modified vector rable delay.delay_ms(5000); unsafe { - cortex_m::interrupt::free(|_| { + critical_section::with(|_| { RAM_VTABLE.activate(ppb); }); } @@ -147,7 +147,7 @@ fn main() -> ! { // that this interrupt entry ends up in the vector table. #[interrupt] fn TIMER_IRQ_0() { - cortex_m::interrupt::free(|cs| { + critical_section::with(|cs| { // Temporarily take our LED_AND_ALARM let ledalarm = unsafe { LED_AND_ALARM.borrow(cs).take() }; if let Some((mut led, mut alarm)) = ledalarm { @@ -169,7 +169,7 @@ fn TIMER_IRQ_0() { // This is the function we will use to replace TIMER_IRQ_0 in our RAM Vector Table extern "C" fn timer_irq0_replacement() { - cortex_m::interrupt::free(|cs| { + critical_section::with(|cs| { let ledalarm = unsafe { LED_AND_ALARM.borrow(cs).take() }; if let Some((mut led, mut alarm)) = ledalarm { // Clear the alarm interrupt or this interrupt service routine will keep firing