projects
/
linux.git
/ commitdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
| commitdiff |
tree
raw
|
patch
| inline |
side by side
(parent:
da32b28
)
dmaengine: idxd: fix misc interrupt handler thread unmasking
author
Dave Jiang
<dave.jiang@intel.com>
Thu, 25 Jun 2020 19:16:54 +0000
(12:16 -0700)
committer
Vinod Koul
<vkoul@kernel.org>
Thu, 2 Jul 2020 13:32:20 +0000
(19:02 +0530)
Fix unmasking of misc interrupt handler when completing normal. It exits
early and skips the unmasking with the current implementation. Fix to
unmask interrupt when exiting normally.
Fixes: bfe1d56091c1 ("dmaengine: idxd: Init and probe for Intel data accelerators")
Signed-off-by: Dave Jiang <dave.jiang@intel.com>
Link:
https://lore.kernel.org/r/159311256528.855.11527922406329728512.stgit@djiang5-desk3.ch.intel.com
Signed-off-by: Vinod Koul <vkoul@kernel.org>
drivers/dma/idxd/irq.c
patch
|
blob
|
history
diff --git
a/drivers/dma/idxd/irq.c
b/drivers/dma/idxd/irq.c
index 6510791b9921b4dabc49a02e8a5423ce8b605a96..8a35f58da689092b8555aac1426b88a0ae02a637 100644
(file)
--- a/
drivers/dma/idxd/irq.c
+++ b/
drivers/dma/idxd/irq.c
@@
-141,7
+141,7
@@
irqreturn_t idxd_misc_thread(int vec, void *data)
iowrite32(cause, idxd->reg_base + IDXD_INTCAUSE_OFFSET);
if (!err)
-
return IRQ_HANDLED
;
+
goto out
;
gensts.bits = ioread32(idxd->reg_base + IDXD_GENSTATS_OFFSET);
if (gensts.state == IDXD_DEVICE_STATE_HALT) {
@@
-162,6
+162,7
@@
irqreturn_t idxd_misc_thread(int vec, void *data)
spin_unlock_bh(&idxd->dev_lock);
}
+ out:
idxd_unmask_msix_vector(idxd, irq_entry->id);
return IRQ_HANDLED;
}