Donate to e Foundation | Murena handsets with /e/OS | Own a part of Murena! Learn more

Commit fbb60fe3 authored by Jason Wang's avatar Jason Wang Committed by Dave Airlie
Browse files

drm/qxl: return IRQ_NONE if it was not our irq



Return IRQ_NONE if it was not our irq. This is necessary for the case
when qxl is sharing irq line with a device A in a crash kernel. If qxl
is initialized before A and A's irq was raised during this gap,
returning IRQ_HANDLED in this case will cause this irq to be raised
again after EOI since kernel think it was handled but in fact it was
not.

Cc: Gerd Hoffmann <kraxel@redhat.com>
Cc: stable@vger.kernel.org
Signed-off-by: default avatarJason Wang <jasowang@redhat.com>
Signed-off-by: default avatarDave Airlie <airlied@redhat.com>
parent 85d9e14c
Loading
Loading
Loading
Loading
+3 −0
Original line number Diff line number Diff line
@@ -33,6 +33,9 @@ irqreturn_t qxl_irq_handler(int irq, void *arg)

	pending = xchg(&qdev->ram_header->int_pending, 0);

	if (!pending)
		return IRQ_NONE;

	atomic_inc(&qdev->irq_received);

	if (pending & QXL_INTERRUPT_DISPLAY) {