mirror of
https://github.com/nxp-imx/linux-imx.git
synced 2025-07-07 18:05:21 +02:00
dmaengine: altera-msgdma: use irq variant of spin_lock/unlock while invoking callbacks
[ Upstream commit261d3a85d9
] As we first take the lock with spin_lock_irqsave in msgdma_tasklet, Lockdep might complain about this. Inspired by commit9558cf4ad0
("dmaengine: zynqmp_dma: fix lockdep warning in tasklet") Signed-off-by: Olivier Dautricourt <olivierdautricourt@gmail.com> Tested-by: Olivier Dautricourt <olivierdautricourt@gmail.com> Suggested-by: Eric Schwarz <eas@sw-optimization.com> Link: https://lore.kernel.org/r/20240608213216.25087-1-olivierdautricourt@gmail.com Signed-off-by: Vinod Koul <vkoul@kernel.org> Signed-off-by: Sasha Levin <sashal@kernel.org>
This commit is contained in:
parent
9d56712647
commit
cd3851ef3f
|
@ -583,6 +583,7 @@ static void msgdma_issue_pending(struct dma_chan *chan)
|
||||||
static void msgdma_chan_desc_cleanup(struct msgdma_device *mdev)
|
static void msgdma_chan_desc_cleanup(struct msgdma_device *mdev)
|
||||||
{
|
{
|
||||||
struct msgdma_sw_desc *desc, *next;
|
struct msgdma_sw_desc *desc, *next;
|
||||||
|
unsigned long irqflags;
|
||||||
|
|
||||||
list_for_each_entry_safe(desc, next, &mdev->done_list, node) {
|
list_for_each_entry_safe(desc, next, &mdev->done_list, node) {
|
||||||
struct dmaengine_desc_callback cb;
|
struct dmaengine_desc_callback cb;
|
||||||
|
@ -591,9 +592,9 @@ static void msgdma_chan_desc_cleanup(struct msgdma_device *mdev)
|
||||||
|
|
||||||
dmaengine_desc_get_callback(&desc->async_tx, &cb);
|
dmaengine_desc_get_callback(&desc->async_tx, &cb);
|
||||||
if (dmaengine_desc_callback_valid(&cb)) {
|
if (dmaengine_desc_callback_valid(&cb)) {
|
||||||
spin_unlock(&mdev->lock);
|
spin_unlock_irqrestore(&mdev->lock, irqflags);
|
||||||
dmaengine_desc_callback_invoke(&cb, NULL);
|
dmaengine_desc_callback_invoke(&cb, NULL);
|
||||||
spin_lock(&mdev->lock);
|
spin_lock_irqsave(&mdev->lock, irqflags);
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Run any dependencies, then free the descriptor */
|
/* Run any dependencies, then free the descriptor */
|
||||||
|
|
Loading…
Reference in New Issue
Block a user