Commit 41ffc423 authored by Dmitry Osipenko's avatar Dmitry Osipenko Committed by Vinod Koul

dmaengine: tegra-apb: Clean up tasklet releasing

There is no need to kill tasklet when driver's probe fails because tasklet
can't be scheduled at this time. It is also cleaner to kill tasklet on
channel's freeing rather than to kill it on driver's removal, otherwise
tasklet could perform a dummy execution after channel's releasing, which
isn't very nice.
Signed-off-by: default avatarDmitry Osipenko <digetx@gmail.com>
Acked-by: default avatarJon Hunter <jonathanh@nvidia.com>
Link: https://lore.kernel.org/r/20200209163356.6439-6-digetx@gmail.comSigned-off-by: default avatarVinod Koul <vkoul@kernel.org>
parent 8e84172e
...@@ -1291,7 +1291,6 @@ static void tegra_dma_free_chan_resources(struct dma_chan *dc) ...@@ -1291,7 +1291,6 @@ static void tegra_dma_free_chan_resources(struct dma_chan *dc)
struct tegra_dma_sg_req *sg_req; struct tegra_dma_sg_req *sg_req;
struct list_head dma_desc_list; struct list_head dma_desc_list;
struct list_head sg_req_list; struct list_head sg_req_list;
unsigned long flags;
INIT_LIST_HEAD(&dma_desc_list); INIT_LIST_HEAD(&dma_desc_list);
INIT_LIST_HEAD(&sg_req_list); INIT_LIST_HEAD(&sg_req_list);
...@@ -1299,15 +1298,14 @@ static void tegra_dma_free_chan_resources(struct dma_chan *dc) ...@@ -1299,15 +1298,14 @@ static void tegra_dma_free_chan_resources(struct dma_chan *dc)
dev_dbg(tdc2dev(tdc), "Freeing channel %d\n", tdc->id); dev_dbg(tdc2dev(tdc), "Freeing channel %d\n", tdc->id);
tegra_dma_terminate_all(dc); tegra_dma_terminate_all(dc);
tasklet_kill(&tdc->tasklet);
spin_lock_irqsave(&tdc->lock, flags);
list_splice_init(&tdc->pending_sg_req, &sg_req_list); list_splice_init(&tdc->pending_sg_req, &sg_req_list);
list_splice_init(&tdc->free_sg_req, &sg_req_list); list_splice_init(&tdc->free_sg_req, &sg_req_list);
list_splice_init(&tdc->free_dma_desc, &dma_desc_list); list_splice_init(&tdc->free_dma_desc, &dma_desc_list);
INIT_LIST_HEAD(&tdc->cb_desc); INIT_LIST_HEAD(&tdc->cb_desc);
tdc->config_init = false; tdc->config_init = false;
tdc->isr_handler = NULL; tdc->isr_handler = NULL;
spin_unlock_irqrestore(&tdc->lock, flags);
while (!list_empty(&dma_desc_list)) { while (!list_empty(&dma_desc_list)) {
dma_desc = list_first_entry(&dma_desc_list, dma_desc = list_first_entry(&dma_desc_list,
...@@ -1546,7 +1544,6 @@ static int tegra_dma_probe(struct platform_device *pdev) ...@@ -1546,7 +1544,6 @@ static int tegra_dma_probe(struct platform_device *pdev)
struct tegra_dma_channel *tdc = &tdma->channels[i]; struct tegra_dma_channel *tdc = &tdma->channels[i];
free_irq(tdc->irq, tdc); free_irq(tdc->irq, tdc);
tasklet_kill(&tdc->tasklet);
} }
pm_runtime_disable(&pdev->dev); pm_runtime_disable(&pdev->dev);
...@@ -1566,7 +1563,6 @@ static int tegra_dma_remove(struct platform_device *pdev) ...@@ -1566,7 +1563,6 @@ static int tegra_dma_remove(struct platform_device *pdev)
for (i = 0; i < tdma->chip_data->nr_channels; ++i) { for (i = 0; i < tdma->chip_data->nr_channels; ++i) {
tdc = &tdma->channels[i]; tdc = &tdma->channels[i];
free_irq(tdc->irq, tdc); free_irq(tdc->irq, tdc);
tasklet_kill(&tdc->tasklet);
} }
pm_runtime_disable(&pdev->dev); pm_runtime_disable(&pdev->dev);
......
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