Commit e27b1636 authored by Guenter Roeck's avatar Guenter Roeck Committed by Thomas Gleixner

genirq/PM: Always unlock IRQ descriptor in rearm_wake_irq()

rearm_wake_irq() does not unlock the irq descriptor if the interrupt
is not suspended or if wakeup is not enabled on it.

Restucture the exit conditions so the unlock is always ensured.

Fixes: 3a79bc63 ("PCI: irq: Introduce rearm_wake_irq()")
Signed-off-by: default avatarGuenter Roeck <linux@roeck-us.net>
Signed-off-by: default avatarThomas Gleixner <tglx@linutronix.de>
Acked-by: default avatarRafael J. Wysocki <rafael.j.wysocki@intel.com>
Cc: stable@vger.kernel.org
Link: https://lore.kernel.org/r/20200811180001.80203-1-linux@roeck-us.net
parent fb893de3
...@@ -185,14 +185,18 @@ void rearm_wake_irq(unsigned int irq) ...@@ -185,14 +185,18 @@ void rearm_wake_irq(unsigned int irq)
unsigned long flags; unsigned long flags;
struct irq_desc *desc = irq_get_desc_buslock(irq, &flags, IRQ_GET_DESC_CHECK_GLOBAL); struct irq_desc *desc = irq_get_desc_buslock(irq, &flags, IRQ_GET_DESC_CHECK_GLOBAL);
if (!desc || !(desc->istate & IRQS_SUSPENDED) || if (!desc)
!irqd_is_wakeup_set(&desc->irq_data))
return; return;
if (!(desc->istate & IRQS_SUSPENDED) ||
!irqd_is_wakeup_set(&desc->irq_data))
goto unlock;
desc->istate &= ~IRQS_SUSPENDED; desc->istate &= ~IRQS_SUSPENDED;
irqd_set(&desc->irq_data, IRQD_WAKEUP_ARMED); irqd_set(&desc->irq_data, IRQD_WAKEUP_ARMED);
__enable_irq(desc); __enable_irq(desc);
unlock:
irq_put_desc_busunlock(desc, flags); irq_put_desc_busunlock(desc, flags);
} }
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment