dmaengine: altera-msgdma: use irq variant of spin_lock/unlock while invoking callbacks
authorOlivier Dautricourt <olivierdautricourt@gmail.com>
Sat, 8 Jun 2024 21:31:46 +0000 (23:31 +0200)
committerVinod Koul <vkoul@kernel.org>
Tue, 11 Jun 2024 16:20:55 +0000 (21:50 +0530)
As we first take the lock with spin_lock_irqsave in msgdma_tasklet, Lockdep
might complain about this. Inspired by commit 9558cf4ad07e
("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>
drivers/dma/altera-msgdma.c

index a8e3615235b8edf6a63b19981579b2168ced0cab..160a465b06dd8f1e45c4c0f0b06fe28726415c2e 100644 (file)
@@ -583,6 +583,7 @@ static void msgdma_issue_pending(struct dma_chan *chan)
 static void msgdma_chan_desc_cleanup(struct msgdma_device *mdev)
 {
        struct msgdma_sw_desc *desc, *next;
+       unsigned long irqflags;
 
        list_for_each_entry_safe(desc, next, &mdev->done_list, node) {
                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);
                if (dmaengine_desc_callback_valid(&cb)) {
-                       spin_unlock(&mdev->lock);
+                       spin_unlock_irqrestore(&mdev->lock, irqflags);
                        dmaengine_desc_callback_invoke(&cb, NULL);
-                       spin_lock(&mdev->lock);
+                       spin_lock_irqsave(&mdev->lock, irqflags);
                }
 
                /* Run any dependencies, then free the descriptor */