From 26fc8871db28d12ac5269e8297baf7d43a8c59d4 Mon Sep 17 00:00:00 2001 From: Dominic Fischer <14130965+Dominaezzz@users.noreply.github.com> Date: Mon, 23 Sep 2024 17:55:54 +0100 Subject: [PATCH] Simplify DMA interrupt handlers (#2215) Co-authored-by: Dominic Fischer --- esp-hal/src/dma/mod.rs | 88 ++++++++++++++---------------------------- 1 file changed, 30 insertions(+), 58 deletions(-) diff --git a/esp-hal/src/dma/mod.rs b/esp-hal/src/dma/mod.rs index ceb148ece1f..f000c46f49f 100644 --- a/esp-hal/src/dma/mod.rs +++ b/esp-hal/src/dma/mod.rs @@ -3070,49 +3070,49 @@ pub(crate) mod asynch { } } - fn handle_interrupt, Tx: TxChannel>() { - if Channel::pending_in_interrupts().is_disjoint( + fn handle_interrupt() { + if CH::Channel::pending_in_interrupts().is_disjoint( DmaRxInterrupt::DescriptorError | DmaRxInterrupt::DescriptorEmpty | DmaRxInterrupt::ErrorEof, ) { - Channel::unlisten_in( + CH::Channel::unlisten_in( DmaRxInterrupt::DescriptorError | DmaRxInterrupt::DescriptorEmpty | DmaRxInterrupt::ErrorEof | DmaRxInterrupt::SuccessfulEof | DmaRxInterrupt::Done, ); - Rx::waker().wake() + CH::Rx::waker().wake() } - if Channel::pending_out_interrupts().contains(DmaTxInterrupt::DescriptorError) { - Channel::unlisten_out( + if CH::Channel::pending_out_interrupts().contains(DmaTxInterrupt::DescriptorError) { + CH::Channel::unlisten_out( DmaTxInterrupt::DescriptorError | DmaTxInterrupt::TotalEof | DmaTxInterrupt::Done, ); - Tx::waker().wake() + CH::Tx::waker().wake() } - if Channel::pending_in_interrupts().contains(DmaRxInterrupt::SuccessfulEof) { - Channel::unlisten_in(DmaRxInterrupt::SuccessfulEof); - Rx::waker().wake() + if CH::Channel::pending_in_interrupts().contains(DmaRxInterrupt::SuccessfulEof) { + CH::Channel::unlisten_in(DmaRxInterrupt::SuccessfulEof); + CH::Rx::waker().wake() } - if Channel::pending_in_interrupts().contains(DmaRxInterrupt::Done) { - Channel::unlisten_in(DmaRxInterrupt::Done); - Rx::waker().wake() + if CH::Channel::pending_in_interrupts().contains(DmaRxInterrupt::Done) { + CH::Channel::unlisten_in(DmaRxInterrupt::Done); + CH::Rx::waker().wake() } - if Channel::pending_out_interrupts().contains(DmaTxInterrupt::TotalEof) - && Channel::is_listening_out().contains(DmaTxInterrupt::TotalEof) + if CH::Channel::pending_out_interrupts().contains(DmaTxInterrupt::TotalEof) + && CH::Channel::is_listening_out().contains(DmaTxInterrupt::TotalEof) { - Channel::unlisten_out(DmaTxInterrupt::TotalEof); - Tx::waker().wake() + CH::Channel::unlisten_out(DmaTxInterrupt::TotalEof); + CH::Tx::waker().wake() } - if Channel::pending_out_interrupts().contains(DmaTxInterrupt::Done) { - Channel::unlisten_out(DmaTxInterrupt::Done); - Tx::waker().wake() + if CH::Channel::pending_out_interrupts().contains(DmaTxInterrupt::Done) { + CH::Channel::unlisten_out(DmaTxInterrupt::Done); + CH::Tx::waker().wake() } } @@ -3120,39 +3120,35 @@ pub(crate) mod asynch { pub(crate) mod interrupt { use procmacros::handler; - pub(crate) fn interrupt_handler_ch() { - use crate::dma::gdma::{Channel, ChannelRxImpl, ChannelTxImpl}; - - super::handle_interrupt::, ChannelRxImpl, ChannelTxImpl>(); - } + use super::*; #[handler(priority = crate::interrupt::Priority::max())] pub(crate) fn interrupt_handler_ch0() { - interrupt_handler_ch::<0>(); + handle_interrupt::(); } #[cfg(not(esp32c2))] #[handler(priority = crate::interrupt::Priority::max())] pub(crate) fn interrupt_handler_ch1() { - interrupt_handler_ch::<1>(); + handle_interrupt::(); } #[cfg(not(esp32c2))] #[handler(priority = crate::interrupt::Priority::max())] pub(crate) fn interrupt_handler_ch2() { - interrupt_handler_ch::<2>(); + handle_interrupt::(); } #[cfg(esp32s3)] #[handler(priority = crate::interrupt::Priority::max())] pub(crate) fn interrupt_handler_ch3() { - interrupt_handler_ch::<3>(); + handle_interrupt::(); } #[cfg(esp32s3)] #[handler(priority = crate::interrupt::Priority::max())] pub(crate) fn interrupt_handler_ch4() { - interrupt_handler_ch::<4>(); + handle_interrupt::(); } } @@ -3164,49 +3160,25 @@ pub(crate) mod asynch { #[handler(priority = crate::interrupt::Priority::max())] pub(crate) fn interrupt_handler_spi2_dma() { - use crate::dma::pdma::{ - Spi2DmaChannel as Channel, - Spi2DmaChannelRxImpl as ChannelRxImpl, - Spi2DmaChannelTxImpl as ChannelTxImpl, - }; - - handle_interrupt::(); + handle_interrupt::(); } #[cfg(spi3)] #[handler(priority = crate::interrupt::Priority::max())] pub(crate) fn interrupt_handler_spi3_dma() { - use crate::dma::pdma::{ - Spi3DmaChannel as Channel, - Spi3DmaChannelRxImpl as ChannelRxImpl, - Spi3DmaChannelTxImpl as ChannelTxImpl, - }; - - handle_interrupt::(); + handle_interrupt::(); } #[cfg(i2s0)] #[handler(priority = crate::interrupt::Priority::max())] pub(crate) fn interrupt_handler_i2s0() { - use crate::dma::pdma::{ - I2s0DmaChannel as Channel, - I2s0DmaChannelRxImpl as ChannelRxImpl, - I2s0DmaChannelTxImpl as ChannelTxImpl, - }; - - handle_interrupt::(); + handle_interrupt::(); } #[cfg(i2s1)] #[handler(priority = crate::interrupt::Priority::max())] pub(crate) fn interrupt_handler_i2s1() { - use crate::dma::pdma::{ - I2s1DmaChannel as Channel, - I2s1DmaChannelRxImpl as ChannelRxImpl, - I2s1DmaChannelTxImpl as ChannelTxImpl, - }; - - handle_interrupt::(); + handle_interrupt::(); } } }