diff options
author | Lubomir Rintel <lkundrak@v3.sk> | 2020-04-19 18:49:09 +0200 |
---|---|---|
committer | Vinod Koul <vkoul@kernel.org> | 2020-04-23 12:44:30 +0530 |
commit | 0c89446379218698189a47871336cb30286a7197 (patch) | |
tree | f6cd6a2abe86a49361824b07ee1ff646a1054d87 | |
parent | 363c32701c7fdc8265a84b21a6a4f45d1202b9ca (diff) | |
download | linux-stable-0c89446379218698189a47871336cb30286a7197.tar.gz linux-stable-0c89446379218698189a47871336cb30286a7197.tar.bz2 linux-stable-0c89446379218698189a47871336cb30286a7197.zip |
dmaengine: mmp_tdma: Reset channel error on release
When a channel configuration fails, the status of the channel is set to
DEV_ERROR so that an attempt to submit it fails. However, this status
sticks until the heat end of the universe, making it impossible to
recover from the error.
Let's reset it when the channel is released so that further use of the
channel with correct configuration is not impacted.
Signed-off-by: Lubomir Rintel <lkundrak@v3.sk>
Link: https://lore.kernel.org/r/20200419164912.670973-5-lkundrak@v3.sk
Signed-off-by: Vinod Koul <vkoul@kernel.org>
-rw-r--r-- | drivers/dma/mmp_tdma.c | 2 |
1 files changed, 2 insertions, 0 deletions
diff --git a/drivers/dma/mmp_tdma.c b/drivers/dma/mmp_tdma.c index 51e08c16756a..d683232d7fea 100644 --- a/drivers/dma/mmp_tdma.c +++ b/drivers/dma/mmp_tdma.c @@ -363,6 +363,8 @@ static void mmp_tdma_free_descriptor(struct mmp_tdma_chan *tdmac) gen_pool_free(gpool, (unsigned long)tdmac->desc_arr, size); tdmac->desc_arr = NULL; + if (tdmac->status == DMA_ERROR) + tdmac->status = DMA_COMPLETE; return; } |