dmaengine: dw-axi-dmac: Increase polling time to DMA transmission completion status
authorWalker Chen <walker.chen@starfivetech.com>
Wed, 22 Mar 2023 09:48:19 +0000 (17:48 +0800)
committerVinod Koul <vkoul@kernel.org>
Wed, 12 Apr 2023 17:48:43 +0000 (23:18 +0530)
The bit DMAC_CHEN[0] is automatically cleared by hardware to disable the
channel after the last AMBA transfer of the DMA transfer to the
destination has completed. Software can therefore poll this bit to
determine when this channel is free for a new DMA transfer.
This time requires at least 40 milliseconds on JH7110 SoC, otherwise an
error message 'failed to stop' will be reported.

Signed-off-by: Walker Chen <walker.chen@starfivetech.com>
Link: https://lore.kernel.org/r/20230322094820.24738-4-walker.chen@starfivetech.com
Signed-off-by: Vinod Koul <vkoul@kernel.org>
drivers/dma/dw-axi-dmac/dw-axi-dmac-platform.c

index 6cfcb541d8c3f3815e12c3cc10abe1d7d6a32c3e..6937cc0c0b653bb60d6a2ecc1339a1026857ce96 100644 (file)
@@ -1147,7 +1147,7 @@ static int dma_chan_terminate_all(struct dma_chan *dchan)
        axi_chan_disable(chan);
 
        ret = readl_poll_timeout_atomic(chan->chip->regs + DMAC_CHEN, val,
-                                       !(val & chan_active), 1000, 10000);
+                                       !(val & chan_active), 1000, 50000);
        if (ret == -ETIMEDOUT)
                dev_warn(dchan2dev(dchan),
                         "%s failed to stop\n", axi_chan_name(chan));