dmaengine: stm32-dma: check FIFO error interrupt enable
authorPierre-Yves MORDRET <pierre-yves.mordret@st.com>
Thu, 3 Jan 2019 10:17:29 +0000 (11:17 +0100)
committerVinod Koul <vkoul@kernel.org>
Mon, 7 Jan 2019 04:22:24 +0000 (09:52 +0530)
For avoiding false FIFO detection, check FIFO Error interrupt is
enabled prior raising any errors.
This will prevent having spurious FIFO error where it shouldn't.

Signed-off-by: Pierre-Yves MORDRET <pierre-yves.mordret@st.com>
Signed-off-by: Vinod Koul <vkoul@kernel.org>
drivers/dma/stm32-dma.c

index 4903a40..48f7c0f 100644 (file)
@@ -641,12 +641,13 @@ static irqreturn_t stm32_dma_chan_irq(int irq, void *devid)
 {
        struct stm32_dma_chan *chan = devid;
        struct stm32_dma_device *dmadev = stm32_dma_get_dev(chan);
-       u32 status, scr;
+       u32 status, scr, sfcr;
 
        spin_lock(&chan->vchan.lock);
 
        status = stm32_dma_irq_status(chan);
        scr = stm32_dma_read(dmadev, STM32_DMA_SCR(chan->id));
+       sfcr = stm32_dma_read(dmadev, STM32_DMA_SFCR(chan->id));
 
        if (status & STM32_DMA_TCI) {
                stm32_dma_irq_clear(chan, STM32_DMA_TCI);
@@ -661,10 +662,12 @@ static irqreturn_t stm32_dma_chan_irq(int irq, void *devid)
        if (status & STM32_DMA_FEI) {
                stm32_dma_irq_clear(chan, STM32_DMA_FEI);
                status &= ~STM32_DMA_FEI;
-               if (!(scr & STM32_DMA_SCR_EN))
-                       dev_err(chan2dev(chan), "FIFO Error\n");
-               else
-                       dev_dbg(chan2dev(chan), "FIFO over/underrun\n");
+               if (sfcr & STM32_DMA_SFCR_FEIE) {
+                       if (!(scr & STM32_DMA_SCR_EN))
+                               dev_err(chan2dev(chan), "FIFO Error\n");
+                       else
+                               dev_dbg(chan2dev(chan), "FIFO over/underrun\n");
+               }
        }
        if (status) {
                stm32_dma_irq_clear(chan, status);