summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorPhil Howard <phil@gadgetoid.com>2024-08-02 14:16:57 +0100
committerDamien George <damien@micropython.org>2024-08-07 12:01:34 +1000
commitd2e33fe3096eec60d7017b0f17c4ddb6910a4d0b (patch)
tree7158f86f9d2440374561ba9795a2910f132123f8
parentad3552ae2cb5be65a8d61dc1c3bb2014d7ef4cae (diff)
rp2/machine_i2s: Deinit all active I2S instances on soft reset.
Add `machine_i2s_deinit_all` to teardown any active I2S instances on soft reset. Prior to this fix, code using I2S required a try/finally in order to avoid a hard fault on soft reset. Fixes issue #14339. Signed-off-by: Phil Howard <phil@gadgetoid.com>
-rw-r--r--ports/rp2/machine_i2s.c9
-rw-r--r--ports/rp2/main.c1
-rw-r--r--ports/rp2/modmachine.h1
3 files changed, 11 insertions, 0 deletions
diff --git a/ports/rp2/machine_i2s.c b/ports/rp2/machine_i2s.c
index 47eb5350a..b17d38336 100644
--- a/ports/rp2/machine_i2s.c
+++ b/ports/rp2/machine_i2s.c
@@ -171,6 +171,15 @@ void machine_i2s_init0(void) {
}
}
+void machine_i2s_deinit_all(void) {
+ for (uint8_t i = 0; i < MAX_I2S_RP2; i++) {
+ machine_i2s_obj_t *i2s = MP_STATE_PORT(machine_i2s_obj[i]);
+ if (i2s) {
+ mp_machine_i2s_deinit(i2s);
+ }
+ }
+}
+
static int8_t get_frame_mapping_index(int8_t bits, format_t format) {
if (format == MONO) {
if (bits == 16) {
diff --git a/ports/rp2/main.c b/ports/rp2/main.c
index 3b4d351a7..0f2721f17 100644
--- a/ports/rp2/main.c
+++ b/ports/rp2/main.c
@@ -214,6 +214,7 @@ int main(int argc, char **argv) {
#if MICROPY_PY_NETWORK
mod_network_deinit();
#endif
+ machine_i2s_deinit_all();
rp2_dma_deinit();
rp2_pio_deinit();
#if MICROPY_PY_BLUETOOTH
diff --git a/ports/rp2/modmachine.h b/ports/rp2/modmachine.h
index 3d0c726cd..e17ad67b0 100644
--- a/ports/rp2/modmachine.h
+++ b/ports/rp2/modmachine.h
@@ -6,6 +6,7 @@
void machine_pin_init(void);
void machine_pin_deinit(void);
void machine_i2s_init0(void);
+void machine_i2s_deinit_all(void);
void machine_pwm_deinit_all(void);
struct _machine_spi_obj_t *spi_from_mp_obj(mp_obj_t o);