From ee84bf3af80f9012bf1c09e00b0c9d4284feb977 Mon Sep 17 00:00:00 2001 From: Pedro Videgain Barranco Date: Wed, 27 Dec 2023 13:04:03 +0100 Subject: [PATCH] Updated non-blocking display documenation and added Changelog entry --- CHANGELOG.md | 2 ++ .../src/display/nonblocking/mod.rs | 20 +++++++++++++++---- 2 files changed, 18 insertions(+), 4 deletions(-) diff --git a/CHANGELOG.md b/CHANGELOG.md index beb854d..b0ce621 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -7,6 +7,8 @@ and this project adheres to [Semantic Versioning](http://semver.org/). ## [Unreleased] +- Update the non-blocking display documentation to better explain when methods + should be called from within a critical section - Bump example dependencies to latest versions to fix build - Update examples to use RTIC 1.0 - Add ADC for micro:bit V1 diff --git a/microbit-common/src/display/nonblocking/mod.rs b/microbit-common/src/display/nonblocking/mod.rs index 2ac40f7..ea96a0f 100644 --- a/microbit-common/src/display/nonblocking/mod.rs +++ b/microbit-common/src/display/nonblocking/mod.rs @@ -211,7 +211,10 @@ impl Display { /// Call this in an interrupt handler for the timer you're using. This method /// takes care of updating the LED display and clearing the timer's event registers /// - /// This must be called from within a [critical + /// This may be called at any time, so long as the code calling it is not interrupting, or + /// interruptable by `tiny_led_matrix::Display::handle_event()`. Within safe code, the borrow + /// checker ensures that this requirement is fulfilled. When writing unsafe code, this method + /// should be called from within a [critical /// section](https://docs.rs/cortex-m/0.7.2/cortex_m/interrupt/fn.free.html). pub fn handle_display_event(&mut self) { self.display @@ -220,7 +223,10 @@ impl Display { /// Show a new image /// - /// This must be called from within a [critical + /// This may be called at any time, so long as the code calling it is not interrupting, or + /// interruptable by `tiny_led_matrix::Display::handle_event()`. Within safe code, the borrow + /// checker ensures that this requirement is fulfilled. When writing unsafe code, this method + /// should be called from within a [critical /// section](https://docs.rs/cortex-m/0.7.2/cortex_m/interrupt/fn.free.html). /// /// ## Example @@ -241,7 +247,10 @@ impl Display { /// Clear the display /// - /// This must be called from within a [critical + /// This may be called at any time, so long as the code calling it is not interrupting, or + /// interruptable by `tiny_led_matrix::Display::handle_event()`. Within safe code, the borrow + /// checker ensures that this requirement is fulfilled. When writing unsafe code, this method + /// should be called from within a [critical /// section](https://docs.rs/cortex-m/0.7.2/cortex_m/interrupt/fn.free.html). pub fn clear(&mut self) { self.display.set_frame(&MicrobitFrame::default()); @@ -253,7 +262,10 @@ impl Display { /// This may be useful if performance is a concern as calling `set` on the frame /// can be done outside the critical section. /// - /// This must be called from within a [critical + /// This may be called at any time, so long as the code calling it is not interrupting, or + /// interruptable by `tiny_led_matrix::Display::handle_event()`. Within safe code, the borrow + /// checker ensures that this requirement is fulfilled. When writing unsafe code, this method + /// should be called from within a [critical /// section](https://docs.rs/cortex-m/0.7.2/cortex_m/interrupt/fn.free.html). /// /// ## Example