aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/irqchip
diff options
context:
space:
mode:
authorGrzegorz Jaszczyk <jaz@semihalf.com>2014-09-25 07:17:18 -0400
committerJason Cooper <jason@lakedaemon.net>2014-11-01 21:31:10 -0400
commit298dcb2dd0267d51e4f7c94a628cd0765a50ad75 (patch)
tree03a25cac6c5204d7b88aaf074e7eb744414856e5 /drivers/irqchip
parentf114040e3ea6e07372334ade75d1ee0775c355e1 (diff)
irqchip: armada-370-xp: Fix MSI interrupt handling
The MSI interrupts use the 16 high doorbells, which are notified by using IRQ1 of the main interrupt controller. The MSI interrupts were handled correctly for Armada-XP and Armada-370 but not for Armada-375 and Armada-38x, which use chained handler for the MPIC. This commit fixes that by checking proper interrupt number in chained handler for the MPIC. Signed-off-by: Grzegorz Jaszczyk <jaz@semihalf.com> Reviewed-by: Gregory CLEMENT <gregory.clement@free-electrons.com> Fixes: bc69b8adfe22 ("irqchip: armada-370-xp: Setup a chained handler for the MPIC") Cc: <stable@vger.kernel.org> # v3.15+ Acked-by: Ezequiel Garcia <ezequiel.garcia@free-electrons.com> Link: https://lkml.kernel.org/r/1411643839-64925-2-git-send-email-jaz@semihalf.com Signed-off-by: Jason Cooper <jason@lakedaemon.net>
Diffstat (limited to 'drivers/irqchip')
-rw-r--r--drivers/irqchip/irq-armada-370-xp.c4
1 files changed, 2 insertions, 2 deletions
diff --git a/drivers/irqchip/irq-armada-370-xp.c b/drivers/irqchip/irq-armada-370-xp.c
index 3e238cd049e6..2f01073d6201 100644
--- a/drivers/irqchip/irq-armada-370-xp.c
+++ b/drivers/irqchip/irq-armada-370-xp.c
@@ -413,9 +413,9 @@ static void armada_370_xp_mpic_handle_cascade_irq(unsigned int irq,
413 413
414 irqmap = readl_relaxed(per_cpu_int_base + ARMADA_375_PPI_CAUSE); 414 irqmap = readl_relaxed(per_cpu_int_base + ARMADA_375_PPI_CAUSE);
415 415
416 if (irqmap & BIT(0)) { 416 if (irqmap & BIT(1)) {
417 armada_370_xp_handle_msi_irq(NULL, true); 417 armada_370_xp_handle_msi_irq(NULL, true);
418 irqmap &= ~BIT(0); 418 irqmap &= ~BIT(1);
419 } 419 }
420 420
421 for_each_set_bit(irqn, &irqmap, BITS_PER_LONG) { 421 for_each_set_bit(irqn, &irqmap, BITS_PER_LONG) {