[<prev] [next>] [thread-next>] [day] [month] [year] [list]
Message-ID: <e37e3f5e0146be65c60092a457ca5c82e25581a0.1545292748.git.yuanyuan.zhao@hxt-semitech.com>
Date: Wed, 9 Jan 2019 11:53:27 +0800
From: Zhao Yuanyuan <yuanyuan.zhao@...-semitech.com>
To: <marc.zyngier@....com>
CC: <tglx@...utronix.de>, <jason@...edaemon.net>,
<linux-kernel@...r.kernel.org>,
<linux-arm-kernel@...ts.infradead.org>,
<yu.zheng@...-semitech.com>, <dongsheng.wang@...-semitech.com>,
Zhao Yuanyuan <yuanyuan.zhao@...-semitech.com>
Subject: [RESEND 1/1] gic: its: Make sure a LPI is discarded before free.
Its device will be removed after all events be freed.
Undisarded events can lead to unpredictable behaviar.
Signed-off-by: Zhao Yuanyuan <yuanyuan.zhao@...-semitech.com>
---
drivers/irqchip/irq-gic-v3-its.c | 4 ++++
1 file changed, 4 insertions(+)
diff --git a/drivers/irqchip/irq-gic-v3-its.c b/drivers/irqchip/irq-gic-v3-its.c
index db20e99..4fee008 100644
--- a/drivers/irqchip/irq-gic-v3-its.c
+++ b/drivers/irqchip/irq-gic-v3-its.c
@@ -2572,6 +2572,10 @@ static void its_irq_domain_free(struct irq_domain *domain, unsigned int virq,
virq + i);
u32 event = its_get_event_id(data);
+ /* Discard irq before free */
+ if (irqd_is_activated(d))
+ its_send_discard(its_dev, event);
+
/* Mark interrupt index as unused */
clear_bit(event, its_dev->event_map.lpi_map);
--
1.8.3.1
Powered by blists - more mailing lists