genirq: Provide irq_desc_has_action
authorThomas Gleixner <tglx@linutronix.de>
Sun, 2 Aug 2015 20:38:26 +0000 (20:38 +0000)
committerThomas Gleixner <tglx@linutronix.de>
Wed, 5 Aug 2015 22:14:59 +0000 (00:14 +0200)
If we have a reference to irq_desc already, there is no point to do
another lookup.

Signed-off-by: Thomas Gleixner <tglx@linutronix.de>
Cc: Jiang Liu <jiang.liu@linux.intel.com>
Cc: Peter Zijlstra <peterz@infradead.org>
Cc: Rusty Russell <rusty@rustcorp.com.au>
Cc: Bjorn Helgaas <bhelgaas@google.com>
Link: http://lkml.kernel.org/r/20150802203609.638130301@linutronix.de
Signed-off-by: Thomas Gleixner <tglx@linutronix.de>
include/linux/irqdesc.h

index fcea4e48e21f5d7060b2451673abf9a8f47d0001..5acfa26602e1b5839a1916e5f9da8e947a605271 100644 (file)
@@ -166,12 +166,16 @@ static inline int handle_domain_irq(struct irq_domain *domain,
 #endif
 
 /* Test to see if a driver has successfully requested an irq */
-static inline int irq_has_action(unsigned int irq)
+static inline int irq_desc_has_action(struct irq_desc *desc)
 {
-       struct irq_desc *desc = irq_to_desc(irq);
        return desc->action != NULL;
 }
 
+static inline int irq_has_action(unsigned int irq)
+{
+       return irq_desc_has_action(irq_to_desc(irq));
+}
+
 /* caller has locked the irq_desc and both params are valid */
 static inline void __irq_set_handler_locked(unsigned int irq,
                                            irq_flow_handler_t handler)