ARM: OMAP: Fix race in OMAP2/3 DMA IRQ handling
authorJuha Yrjola <juha.yrjola@solidboot.com>
Thu, 29 Jan 2009 16:57:12 +0000 (08:57 -0800)
committerGrazvydas Ignotas <notasas@gmail.com>
Thu, 10 Jun 2010 13:05:32 +0000 (16:05 +0300)
CSR must be cleared before invoking the callback.

If the callback function starts a new, fast DMA transfer on the same
channel, the completion status might lost if CSR is cleared after
the callback invocation.

Signed-off-by: Juha Yrjola <juha.yrjola@solidboot.com>
Signed-off-by: Tony Lindgren <tony@atomide.com>
arch/arm/plat-omap/dma.c

index 6ccafbc..ee77013 100755 (executable)
@@ -1913,11 +1913,11 @@ static int omap2_dma_handle_ch(int ch)
                status = dma_read(CSR(ch));
        }
 
+       dma_write(status, CSR(ch));
+
        if (likely(dma_chan[ch].callback != NULL))
                dma_chan[ch].callback(ch, status, dma_chan[ch].data);
 
-       dma_write(status, CSR(ch));
-
        return 0;
 }