On RZ/G2L SoCs switching from DMA to interrupt mode, causes timeout issue as we are not getting Rx interrupt even though SPRF bit is set in the status register. But there is no issue if we don't switch between interrupt to DMA mode or vice versa. Performance comparison between interrupt and DMA mode on RZ/Five SMARC platform connected to a display module shows that performance and CPU utilization is much better with DMA mode compared to interrupt mode (1->65 fps) and (98->8%). This patch introduces a variable force_dma to avoid switching between DMA to interrupt mode for RZ platforms. Signed-off-by: Biju Das <biju.das.jz@xxxxxxxxxxxxxx> --- drivers/spi/spi-rspi.c | 4 +++- 1 file changed, 3 insertions(+), 1 deletion(-) diff --git a/drivers/spi/spi-rspi.c b/drivers/spi/spi-rspi.c index 7a014eeec2d0..f86b7b53288f 100644 --- a/drivers/spi/spi-rspi.c +++ b/drivers/spi/spi-rspi.c @@ -249,6 +249,7 @@ struct spi_ops { u16 flags; u16 fifo_size; u8 num_hw_ss; + bool force_dma; }; static void rspi_set_rate(struct rspi_data *rspi) @@ -677,7 +678,7 @@ static void qspi_receive_init(const struct rspi_data *rspi) static bool __rspi_can_dma(const struct rspi_data *rspi, const struct spi_transfer *xfer) { - return xfer->len > rspi->ops->fifo_size; + return rspi->ops->force_dma || (xfer->len > rspi->ops->fifo_size); } static bool rspi_can_dma(struct spi_controller *ctlr, struct spi_device *spi, @@ -1196,6 +1197,7 @@ static const struct spi_ops rspi_rz_ops = { .flags = SPI_CONTROLLER_MUST_RX | SPI_CONTROLLER_MUST_TX, .fifo_size = 8, /* 8 for TX, 32 for RX */ .num_hw_ss = 1, + .force_dma = true, }; static const struct spi_ops qspi_ops = { -- 2.25.1