spi/spi-xilinx: Fix mixed poll/irq mode
authorRicardo Ribalda Delgado <ricardo.ribalda@gmail.com>
Wed, 12 Aug 2015 16:04:04 +0000 (18:04 +0200)
committerMark Brown <broonie@kernel.org>
Thu, 13 Aug 2015 11:29:23 +0000 (12:29 +0100)
Once the module process a transfer in irq mode, the next poll transfer
will not work because the transmitter is left in inhibited state.

Fixes: 22417352f6b7f623 (Use polling mode on small transfers)
Reported-by: Edward Kigwana <ekigwana@scires.com>
Signed-off-by: Ricardo Ribalda Delgado <ricardo.ribalda@gmail.com>
Signed-off-by: Mark Brown <broonie@kernel.org>
Cc: stable@vger.kernel.org
drivers/spi/spi-xilinx.c

index 133f53a9c1d4eb9b5235b88de03dac9c5d2ea27e..7abf6792cc118bf696079a9ccacf8b33bb0270c5 100644 (file)
@@ -302,8 +302,10 @@ static int xilinx_spi_txrx_bufs(struct spi_device *spi, struct spi_transfer *t)
                remaining_words -= n_words;
        }
 
-       if (use_irq)
+       if (use_irq) {
                xspi->write_fn(0, xspi->regs + XIPIF_V123B_DGIER_OFFSET);
+               xspi->write_fn(cr, xspi->regs + XSPI_CR_OFFSET);
+       }
 
        return t->len;
 }