Skip to content

Commit 8dbbaa4

Browse files
geertubroonie
authored andcommitted
spi: rspi: Fix interrupted DMA transfers
When interrupted, wait_event_interruptible_timeout() returns -ERESTARTSYS, and the SPI transfer in progress will fail, as expected: m25p80 spi0.0: SPI transfer failed: -512 spi_master spi0: failed to transfer one message from queue However, as the underlying DMA transfers may not have completed, all subsequent SPI transfers may start to fail: spi_master spi0: receive timeout qspi_transfer_out_in() returned -110 m25p80 spi0.0: SPI transfer failed: -110 spi_master spi0: failed to transfer one message from queue Fix this by calling dmaengine_terminate_all() not only for timeouts, but also for errors. This can be reproduced on r8a7991/koelsch, using "hd /dev/mtd0" followed by CTRL-C. Signed-off-by: Geert Uytterhoeven <geert+renesas@glider.be> Signed-off-by: Mark Brown <broonie@kernel.org> Cc: stable@vger.kernel.org
1 parent c1ca59c commit 8dbbaa4

File tree

1 file changed

+6
-4
lines changed

1 file changed

+6
-4
lines changed

drivers/spi/spi-rspi.c

Lines changed: 6 additions & 4 deletions
Original file line numberDiff line numberDiff line change
@@ -598,11 +598,13 @@ static int rspi_dma_transfer(struct rspi_data *rspi, struct sg_table *tx,
598598

599599
ret = wait_event_interruptible_timeout(rspi->wait,
600600
rspi->dma_callbacked, HZ);
601-
if (ret > 0 && rspi->dma_callbacked)
601+
if (ret > 0 && rspi->dma_callbacked) {
602602
ret = 0;
603-
else if (!ret) {
604-
dev_err(&rspi->master->dev, "DMA timeout\n");
605-
ret = -ETIMEDOUT;
603+
} else {
604+
if (!ret) {
605+
dev_err(&rspi->master->dev, "DMA timeout\n");
606+
ret = -ETIMEDOUT;
607+
}
606608
if (tx)
607609
dmaengine_terminate_all(rspi->master->dma_tx);
608610
if (rx)

0 commit comments

Comments
 (0)