dmaengine: moxart-dma: Fix memory leak when stopping a running transfer
The vd->node is removed from the lists when the transfer started so the vchan_get_all_descriptors() will not find it. This results memory leak. Signed-off-by: Peter Ujfalusi <peter.ujfalusi@ti.com> Signed-off-by: Vinod Koul <vinod.koul@intel.com>
This commit is contained in:
parent
f931782917
commit
fbef403aa7
1 changed files with 3 additions and 1 deletions
|
@ -193,8 +193,10 @@ static int moxart_terminate_all(struct dma_chan *chan)
|
||||||
|
|
||||||
spin_lock_irqsave(&ch->vc.lock, flags);
|
spin_lock_irqsave(&ch->vc.lock, flags);
|
||||||
|
|
||||||
if (ch->desc)
|
if (ch->desc) {
|
||||||
|
moxart_dma_desc_free(&ch->desc->vd);
|
||||||
ch->desc = NULL;
|
ch->desc = NULL;
|
||||||
|
}
|
||||||
|
|
||||||
ctrl = readl(ch->base + REG_OFF_CTRL);
|
ctrl = readl(ch->base + REG_OFF_CTRL);
|
||||||
ctrl &= ~(APB_DMA_ENABLE | APB_DMA_FIN_INT_EN | APB_DMA_ERR_INT_EN);
|
ctrl &= ~(APB_DMA_ENABLE | APB_DMA_FIN_INT_EN | APB_DMA_ERR_INT_EN);
|
||||||
|
|
Loading…
Add table
Reference in a new issue