From 959aecf6aca7649fbca8e2025358819791d0c41d Mon Sep 17 00:00:00 2001 From: Bob McWhirter Date: Tue, 26 Oct 2021 14:01:39 -0400 Subject: [PATCH 1/3] Enable the DMAMUX clocks. --- embassy-stm32/src/dma/dmamux.rs | 10 +++++++++- 1 file changed, 9 insertions(+), 1 deletion(-) diff --git a/embassy-stm32/src/dma/dmamux.rs b/embassy-stm32/src/dma/dmamux.rs index 718859a44..ef84f1269 100644 --- a/embassy-stm32/src/dma/dmamux.rs +++ b/embassy-stm32/src/dma/dmamux.rs @@ -47,5 +47,13 @@ pac::dma_channels! { }; } +use crate::rcc::sealed::RccPeripheral; + /// safety: must be called only once -pub(crate) unsafe fn init() {} +pub(crate) unsafe fn init() { + pac::peripherals! { + (dmamux, $peri:ident) => { + crate::peripherals::$peri::enable(); + }; + } +} From a72816492ac09898fc7d72fe20cc0e025d5292a6 Mon Sep 17 00:00:00 2001 From: Bob McWhirter Date: Tue, 26 Oct 2021 14:19:03 -0400 Subject: [PATCH 2/3] Only attempt to enable the dmamux peri clock if it has an enable bit. --- embassy-stm32/src/dma/dmamux.rs | 6 +++++- 1 file changed, 5 insertions(+), 1 deletion(-) diff --git a/embassy-stm32/src/dma/dmamux.rs b/embassy-stm32/src/dma/dmamux.rs index ef84f1269..4ce65eb21 100644 --- a/embassy-stm32/src/dma/dmamux.rs +++ b/embassy-stm32/src/dma/dmamux.rs @@ -53,7 +53,11 @@ use crate::rcc::sealed::RccPeripheral; pub(crate) unsafe fn init() { pac::peripherals! { (dmamux, $peri:ident) => { - crate::peripherals::$peri::enable(); + pac::peripheral_rcc! { + ($peri, $clock:ident, $en_reg:ident, $rst_reg:ident, $en_fn:ident, $rst_fn:ident) => { + crate::peripherals::$peri::enable() + }; + } }; } } From bbff98ed0de2f37cc25f00b944bb0afb1bb85646 Mon Sep 17 00:00:00 2001 From: Bob McWhirter Date: Tue, 26 Oct 2021 14:34:03 -0400 Subject: [PATCH 3/3] Move the `use` inside the macro call, inside another set of braces in case it percolates up twice. --- embassy-stm32/src/dma/dmamux.rs | 13 +++++++------ 1 file changed, 7 insertions(+), 6 deletions(-) diff --git a/embassy-stm32/src/dma/dmamux.rs b/embassy-stm32/src/dma/dmamux.rs index 4ce65eb21..14218d56a 100644 --- a/embassy-stm32/src/dma/dmamux.rs +++ b/embassy-stm32/src/dma/dmamux.rs @@ -47,16 +47,17 @@ pac::dma_channels! { }; } -use crate::rcc::sealed::RccPeripheral; - /// safety: must be called only once pub(crate) unsafe fn init() { pac::peripherals! { (dmamux, $peri:ident) => { - pac::peripheral_rcc! { - ($peri, $clock:ident, $en_reg:ident, $rst_reg:ident, $en_fn:ident, $rst_fn:ident) => { - crate::peripherals::$peri::enable() - }; + { + pac::peripheral_rcc! { + ($peri, $clock:ident, $en_reg:ident, $rst_reg:ident, $en_fn:ident, $rst_fn:ident) => { + use crate::rcc::sealed::RccPeripheral; + crate::peripherals::$peri::enable() + }; + } } }; }