• Tobias Schramm's avatar
    spi: sun6i: fix race between DMA RX transfer completion and RX FIFO drain · 1f11f420
    Tobias Schramm authored
    Previously the transfer complete IRQ immediately drained to RX FIFO to
    read any data remaining in FIFO to the RX buffer. This behaviour is
    correct when dealing with SPI in interrupt mode. However in DMA mode the
    transfer complete interrupt still fires as soon as all bytes to be
    transferred have been stored in the FIFO. At that point data in the FIFO
    still needs to be picked up by the DMA engine. Thus the drain procedure
    and DMA engine end up racing to read from RX FIFO, corrupting any data
    read. Additionally the RX buffer pointer is never adjusted according to
    DMA progress in DMA mode, thus calling the RX FIFO drain procedure in DMA
    mode is a bug.
    Fix corruptions in DMA RX mode by draining RX FIFO only in interrupt mode.
    Also wait for completion of RX DMA when in DMA mode before returning to
    ensure all data has been copied to the supplied memory buffer.
    Signed-off-by: default avatarTobias Schramm <t.schramm@manjaro.org>
    Link: https://lore.kernel.org/r/20230827152558.5368-3-t.schramm@manjaro.orgSigned-off-by: default avatarMark Brown <broonie@kernel.org>
    1f11f420
spi-sun6i.c 20.2 KB