spi: sh-msiof: Use DMA if possible
authorHoan Nguyen An <na-hoan@jinso.co.jp>
Fri, 18 Jan 2019 09:29:31 +0000 (18:29 +0900)
committerMark Brown <broonie@kernel.org>
Fri, 18 Jan 2019 18:20:52 +0000 (18:20 +0000)
Currently, this driver only supports feature for DMA 32-bits.
In this case, only if the data length is divisible by 4 to use
DMA, otherwise PIO will be used. This patch will suggest use
the DMA 32-bits with 4bytes of words, then the remaining data
will be transmitted by PIO mode.

Signed-off-by: Hoan Nguyen An <na-hoan@jinso.co.jp>
Reviewed-by: Geert Uytterhoeven <geert+renesas@glider.be>
Tested-by: Geert Uytterhoeven <geert+renesas@glider.be>
Signed-off-by: Mark Brown <broonie@kernel.org>
drivers/spi/spi-sh-msiof.c

index 351470bc020d668ae46ca35931e1687b31e33b74..617cdf3be0509938b387c62e2fbee022e4431876 100644 (file)
@@ -937,17 +937,13 @@ static int sh_msiof_transfer_one(struct spi_master *master,
                unsigned int l = 0;
 
                if (tx_buf)
-                       l = min(len, p->tx_fifo_size * 4);
+                       l = min(round_down(len, 4), p->tx_fifo_size * 4);
                if (rx_buf)
-                       l = min(len, p->rx_fifo_size * 4);
+                       l = min(round_down(len, 4), p->rx_fifo_size * 4);
 
                if (bits <= 8) {
-                       if (l & 3)
-                               break;
                        copy32 = copy_bswap32;
                } else if (bits <= 16) {
-                       if (l & 3)
-                               break;
                        copy32 = copy_wswap32;
                } else {
                        copy32 = copy_plain32;