aboutsummaryrefslogtreecommitdiffstats
path: root/os/hal/ports
diff options
context:
space:
mode:
authorisiora <isiora@35acf78f-673a-0410-8e92-d51de3d6d3f4>2018-02-20 18:20:16 +0000
committerisiora <isiora@35acf78f-673a-0410-8e92-d51de3d6d3f4>2018-02-20 18:20:16 +0000
commita6d67787e4730a1d925524494d5a0c1b580cc7be (patch)
tree78f7d4870206d6e38c1d128b42050139c7304161 /os/hal/ports
parent6497cd272ac8f7b6e4dfd67c44ac8790e4092526 (diff)
downloadChibiOS-a6d67787e4730a1d925524494d5a0c1b580cc7be.tar.gz
ChibiOS-a6d67787e4730a1d925524494d5a0c1b580cc7be.tar.bz2
ChibiOS-a6d67787e4730a1d925524494d5a0c1b580cc7be.zip
Cleanup ISR.
git-svn-id: svn://svn.code.sf.net/p/chibios/svn/trunk@11519 35acf78f-673a-0410-8e92-d51de3d6d3f4
Diffstat (limited to 'os/hal/ports')
-rw-r--r--os/hal/ports/SAMA/LLD/DMAv1/sama_xdmac.c46
1 files changed, 18 insertions, 28 deletions
diff --git a/os/hal/ports/SAMA/LLD/DMAv1/sama_xdmac.c b/os/hal/ports/SAMA/LLD/DMAv1/sama_xdmac.c
index 64a70edda..92b5367e3 100644
--- a/os/hal/ports/SAMA/LLD/DMAv1/sama_xdmac.c
+++ b/os/hal/ports/SAMA/LLD/DMAv1/sama_xdmac.c
@@ -105,32 +105,22 @@ OSAL_IRQ_HANDLER(dmaHandler) {
/* Read Global Interrupt Status Register */
gis = dmaGetGlobalInt(xdmac);
- for (chan = 0; chan < XDMAC_CHANNELS; chan++) {
+ for (chan = 0; gis && (chan < XDMAC_CHANNELS); chan++) {
sama_dma_channel_t *channel = &_sama_dma_channel_t[chan];
- bool pendingInt = FALSE;
if (!(gis & (0x1 << chan)))
- /* There is no pending interrupt for this channel */
- continue;
-
- if (channel->state == SAMA_DMA_FREE)
- /* Channel is free */
+ /* There is no pending interrupt for this channel */
continue;
-
- uint32_t cis = (dmaGetChannelInt(channel)) & ~(dmaGetChannelIntMask(channel));
-
- if (cis) {
- pendingInt = TRUE;
- }
-
- if (cis & (XDMAC_CIS_LIS|XDMAC_CIS_DIS)) {
- pendingInt = TRUE;
- }
-
- /* Executes callback */
- if (pendingInt && channel->dma_func) {
- channel->dma_func(channel->dma_param,cis);
- }
+ gis &= ~(0x1 << chan);
+
+ /**
+ * if channel interrupt is enabled and pending, and a callback exists,
+ * execute it
+ */
+ uint32_t cis = dmaGetChannelInt(channel) &~ dmaGetChannelIntMask(channel);
+ if (cis & (XDMAC_CIS_BIS|XDMAC_CIS_LIS|XDMAC_CIS_DIS))
+ if (channel->dma_func)
+ channel->dma_func(channel->dma_param, cis);
}
aicAckInt();
OSAL_IRQ_EPILOGUE();
@@ -258,13 +248,13 @@ sama_dma_channel_t* dmaChannelAllocate(uint32_t priority,
/* Setting AIC and enabling DMA clocks required by the current channel set.*/
#if SAMA_HAL_IS_SECURE
- aicSetSourcePriority(ID_XDMAC0, priority);
- aicEnableInt(ID_XDMAC0);
- pmcEnableXDMAC0();
+ aicSetSourcePriority(ID_XDMAC0, priority);
+ aicEnableInt(ID_XDMAC0);
+ pmcEnableXDMAC0();
#else
- aicSetSourcePriority(ID_XDMAC1, priority);
- aicEnableInt(ID_XDMAC1);
- pmcEnableXDMAC1();
+ aicSetSourcePriority(ID_XDMAC1, priority);
+ aicEnableInt(ID_XDMAC1);
+ pmcEnableXDMAC1();
#endif /* SAMA_HAL_IS_SECURE */
/* Enabling channel's interrupt */