summaryrefslogtreecommitdiff
path: root/drivers
diff options
context:
space:
mode:
authorStafford Horne <shorne@gmail.com>2022-06-15 08:54:26 +0900
committerGreg Kroah-Hartman <gregkh@linuxfoundation.org>2022-07-21 21:24:40 +0200
commitee1da3d59674a1f6134fbe3dea7070e32f161083 (patch)
treea2f1153db64e29a507193ebf38da7fd34c196547 /drivers
parent9c9869c308a311ba7b5a48e6cdb3df22d63d088a (diff)
downloadlinux-ee1da3d59674a1f6134fbe3dea7070e32f161083.tar.gz
linux-ee1da3d59674a1f6134fbe3dea7070e32f161083.tar.bz2
linux-ee1da3d59674a1f6134fbe3dea7070e32f161083.zip
irqchip: or1k-pic: Undefine mask_ack for level triggered hardware
[ Upstream commit 8520501346ed8d1c4a6dfa751cb57328a9c843f1 ] The mask_ack operation clears the interrupt by writing to the PICSR register. This we don't want for level triggered interrupt because it does not actually clear the interrupt on the source hardware. This was causing issues in qemu with multi core setups where interrupts would continue to fire even though they had been cleared in PICSR. Just remove the mask_ack operation. Acked-by: Marc Zyngier <maz@kernel.org> Signed-off-by: Stafford Horne <shorne@gmail.com> Signed-off-by: Sasha Levin <sashal@kernel.org>
Diffstat (limited to 'drivers')
-rw-r--r--drivers/irqchip/irq-or1k-pic.c1
1 files changed, 0 insertions, 1 deletions
diff --git a/drivers/irqchip/irq-or1k-pic.c b/drivers/irqchip/irq-or1k-pic.c
index 03d2366118dd..d5f1fabc45d7 100644
--- a/drivers/irqchip/irq-or1k-pic.c
+++ b/drivers/irqchip/irq-or1k-pic.c
@@ -66,7 +66,6 @@ static struct or1k_pic_dev or1k_pic_level = {
.name = "or1k-PIC-level",
.irq_unmask = or1k_pic_unmask,
.irq_mask = or1k_pic_mask,
- .irq_mask_ack = or1k_pic_mask_ack,
},
.handle = handle_level_irq,
.flags = IRQ_LEVEL | IRQ_NOPROBE,