diff options
| author | Ilpo Järvinen <[email protected]> | 2023-01-30 13:48:40 +0200 | 
|---|---|---|
| committer | Greg Kroah-Hartman <[email protected]> | 2023-01-31 11:15:16 +0100 | 
| commit | 31352811e13dc2313f101b890fd4b1ce760b5fe7 (patch) | |
| tree | c1ce607a9228b0e54e1c9b7c64e648b0a4ee90f6 /lib/zstd/common/zstd_common.c | |
| parent | 3f6c02fa712bd453871877fe1d1969625617471e (diff) | |
serial: 8250_dma: Fix DMA Rx completion race
__dma_rx_complete() is called from two places:
  - Through the DMA completion callback dma_rx_complete()
  - From serial8250_rx_dma_flush() after IIR_RLSI or IIR_RX_TIMEOUT
The former does not hold port's lock during __dma_rx_complete() which
allows these two to race and potentially insert the same data twice.
Extend port's lock coverage in dma_rx_complete() to prevent the race
and check if the DMA Rx is still pending completion before calling
into __dma_rx_complete().
Reported-by: Gilles BULOZ <[email protected]>
Tested-by: Gilles BULOZ <[email protected]>
Fixes: 9ee4b83e51f7 ("serial: 8250: Add support for dmaengine")
Cc: [email protected]
Signed-off-by: Ilpo Järvinen <[email protected]>
Link: https://lore.kernel.org/r/[email protected]
Signed-off-by: Greg Kroah-Hartman <[email protected]>
Diffstat (limited to 'lib/zstd/common/zstd_common.c')
0 files changed, 0 insertions, 0 deletions