Commit d05e3ead authored by Hoan Nguyen An's avatar Hoan Nguyen An Committed by Mark Brown

spi: sh-msiof: Use DMA if possible

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: default avatarHoan Nguyen An <na-hoan@jinso.co.jp>
Reviewed-by: default avatarGeert Uytterhoeven <geert+renesas@glider.be>
Tested-by: default avatarGeert Uytterhoeven <geert+renesas@glider.be>
Signed-off-by: default avatarMark Brown <broonie@kernel.org>
parent f70351ae
...@@ -937,17 +937,13 @@ static int sh_msiof_transfer_one(struct spi_master *master, ...@@ -937,17 +937,13 @@ static int sh_msiof_transfer_one(struct spi_master *master,
unsigned int l = 0; unsigned int l = 0;
if (tx_buf) 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) 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 (bits <= 8) {
if (l & 3)
break;
copy32 = copy_bswap32; copy32 = copy_bswap32;
} else if (bits <= 16) { } else if (bits <= 16) {
if (l & 3)
break;
copy32 = copy_wswap32; copy32 = copy_wswap32;
} else { } else {
copy32 = copy_plain32; copy32 = copy_plain32;
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment