genirq: Avoid double loop on suspend
authorThomas Gleixner <tglx@linutronix.de>
Thu, 28 Aug 2014 20:50:43 +0000 (22:50 +0200)
committerRafael J. Wysocki <rafael.j.wysocki@intel.com>
Mon, 1 Sep 2014 11:48:29 +0000 (13:48 +0200)
We can synchronize the suspended interrupts right away. No need for an
extra loop.

Signed-off-by: Thomas Gleixner <tglx@linutronix.de>
Signed-off-by: Rafael J. Wysocki <rafael.j.wysocki@intel.com>
kernel/irq/pm.c

index a21b3dc9825a3f7a619f1bd91a8ec2a826673f93..cf0ce0163db90ed0a6e61e60d43085d21461d5a7 100644 (file)
@@ -49,10 +49,10 @@ void irq_pm_remove_action(struct irq_desc *desc, struct irqaction *action)
                desc->no_suspend_depth--;
 }
 
-static void suspend_device_irq(struct irq_desc *desc, int irq)
+static bool suspend_device_irq(struct irq_desc *desc, int irq)
 {
        if (!desc->action || desc->no_suspend_depth)
-               return;
+               return false;
 
        desc->istate |= IRQS_SUSPENDED;
        __disable_irq(desc, irq);
@@ -65,6 +65,7 @@ static void suspend_device_irq(struct irq_desc *desc, int irq)
         */
        if (irq_desc_get_chip(desc)->flags & IRQCHIP_MASK_ON_SUSPEND)
                mask_irq(desc);
+       return true;
 }
 
 /**
@@ -86,15 +87,15 @@ void suspend_device_irqs(void)
 
        for_each_irq_desc(irq, desc) {
                unsigned long flags;
+               bool sync;
 
                raw_spin_lock_irqsave(&desc->lock, flags);
-               suspend_device_irq(desc, irq);
+               sync = suspend_device_irq(desc, irq);
                raw_spin_unlock_irqrestore(&desc->lock, flags);
-       }
 
-       for_each_irq_desc(irq, desc)
-               if (desc->istate & IRQS_SUSPENDED)
+               if (sync)
                        synchronize_irq(irq);
+       }
 }
 EXPORT_SYMBOL_GPL(suspend_device_irqs);