summaryrefslogtreecommitdiff
path: root/arch/sparc
diff options
context:
space:
mode:
authorVignesh R <vigneshr@ti.com>2018-10-15 12:08:28 +0530
committerGreg Kroah-Hartman <gregkh@linuxfoundation.org>2019-11-28 18:25:47 +0100
commite53300c4bf3954d3bf8656b02321c620b0966c8b (patch)
tree31e0d457711d97bdedb9ef027c5d0be232bf5c82 /arch/sparc
parent8250c2a36a97f26ea5055cfb80b435d3330fab54 (diff)
spi: omap2-mcspi: Set FIFO DMA trigger level to word length
[ Upstream commit b682cffa3ac6d9d9e16e9b413c45caee3b391fab ] McSPI has 32 byte FIFO in Transmit-Receive mode. Current code tries to configuration FIFO watermark level for DMA trigger to be GCD of transfer length and max FIFO size which would mean trigger level may be set to 32 for transmit-receive mode if length is aligned. This does not work in case of SPI slave mode where FIFO always needs to have data ready whenever master starts the clock. With DMA trigger size of 32 there will be a small window during slave TX where DMA is still putting data into FIFO but master would have started clock for next byte, resulting in shifting out of stale data. Similarly, on Slave RX side there may be RX FIFO overflow Fix this by setting FIFO watermark for DMA trigger to word length. This means DMA is triggered as soon as FIFO has space for word length bytes and DMA would make sure FIFO is almost always full therefore improving FIFO occupancy in both master and slave mode. Signed-off-by: Vignesh R <vigneshr@ti.com> Signed-off-by: Mark Brown <broonie@kernel.org> Signed-off-by: Sasha Levin <sashal@kernel.org>
Diffstat (limited to 'arch/sparc')
0 files changed, 0 insertions, 0 deletions