Commit ce62432c authored by Walker Chen's avatar Walker Chen Committed by Vinod Koul

dmaengine: dw-axi-dmac: Increase polling time to DMA transmission completion status

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: default avatarWalker Chen <walker.chen@starfivetech.com>
Link: https://lore.kernel.org/r/20230322094820.24738-4-walker.chen@starfivetech.comSigned-off-by: default avatarVinod Koul <vkoul@kernel.org>
parent 790f3c8b
...@@ -1147,7 +1147,7 @@ static int dma_chan_terminate_all(struct dma_chan *dchan) ...@@ -1147,7 +1147,7 @@ static int dma_chan_terminate_all(struct dma_chan *dchan)
axi_chan_disable(chan); axi_chan_disable(chan);
ret = readl_poll_timeout_atomic(chan->chip->regs + DMAC_CHEN, val, ret = readl_poll_timeout_atomic(chan->chip->regs + DMAC_CHEN, val,
!(val & chan_active), 1000, 10000); !(val & chan_active), 1000, 50000);
if (ret == -ETIMEDOUT) if (ret == -ETIMEDOUT)
dev_warn(dchan2dev(dchan), dev_warn(dchan2dev(dchan),
"%s failed to stop\n", axi_chan_name(chan)); "%s failed to stop\n", axi_chan_name(chan));
......
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