spi: stm32: make spurious and overrun interrupts visible
authorAlain Volmat <alain.volmat@foss.st.com>
Fri, 5 Feb 2021 18:59:32 +0000 (19:59 +0100)
committerMark Brown <broonie@kernel.org>
Fri, 5 Feb 2021 19:17:01 +0000 (19:17 +0000)
We do not expect to receive spurious interrupts so rise a warning
if it happens.

RX overrun is an error condition that signals a corrupted RX
stream both in dma and in irq modes. Report the error and
abort the transfer in either cases.

Signed-off-by: Alain Volmat <alain.volmat@foss.st.com>
Link: https://lore.kernel.org/r/1612551572-495-9-git-send-email-alain.volmat@foss.st.com
Signed-off-by: Mark Brown <broonie@kernel.org>
drivers/spi/spi-stm32.c

index f3a4ff60ac4b9ad8fd563b235deeeedb8c233fc6..25c0764610119050093027e822bd97bbdfef69aa 100644 (file)
@@ -895,8 +895,8 @@ static irqreturn_t stm32h7_spi_irq_thread(int irq, void *dev_id)
                mask |= STM32H7_SPI_SR_RXP;
 
        if (!(sr & mask)) {
-               dev_dbg(spi->dev, "spurious IT (sr=0x%08x, ier=0x%08x)\n",
-                       sr, ier);
+               dev_warn(spi->dev, "spurious IT (sr=0x%08x, ier=0x%08x)\n",
+                        sr, ier);
                spin_unlock_irqrestore(&spi->lock, flags);
                return IRQ_NONE;
        }
@@ -923,15 +923,8 @@ static irqreturn_t stm32h7_spi_irq_thread(int irq, void *dev_id)
        }
 
        if (sr & STM32H7_SPI_SR_OVR) {
-               dev_warn(spi->dev, "Overrun: received value discarded\n");
-               if (!spi->cur_usedma && (spi->rx_buf && (spi->rx_len > 0)))
-                       stm32h7_spi_read_rxfifo(spi, false);
-               /*
-                * If overrun is detected while using DMA, it means that
-                * something went wrong, so stop the current transfer
-                */
-               if (spi->cur_usedma)
-                       end = true;
+               dev_err(spi->dev, "Overrun: RX data lost\n");
+               end = true;
        }
 
        if (sr & STM32H7_SPI_SR_EOT) {