2008-10-16 16:20:58 +00:00
|
|
|
#ifndef _LINUX_IRQNR_H
|
|
|
|
#define _LINUX_IRQNR_H
|
|
|
|
|
2008-12-12 10:26:39 +00:00
|
|
|
/*
|
|
|
|
* Generic irq_desc iterators:
|
|
|
|
*/
|
|
|
|
#ifdef __KERNEL__
|
|
|
|
|
2008-10-16 16:20:58 +00:00
|
|
|
#ifndef CONFIG_GENERIC_HARDIRQS
|
|
|
|
#include <asm/irq.h>
|
2009-01-05 13:34:42 +00:00
|
|
|
|
|
|
|
/*
|
|
|
|
* Wrappers for non-genirq architectures:
|
|
|
|
*/
|
|
|
|
#define nr_irqs NR_IRQS
|
|
|
|
#define irq_to_desc(irq) (&irq_desc[irq])
|
2008-10-16 16:20:58 +00:00
|
|
|
|
|
|
|
# define for_each_irq_desc(irq, desc) \
|
|
|
|
for (irq = 0; irq < nr_irqs; irq++)
|
|
|
|
|
2008-12-08 22:06:17 +00:00
|
|
|
# define for_each_irq_desc_reverse(irq, desc) \
|
|
|
|
for (irq = nr_irqs - 1; irq >= 0; irq--)
|
2009-01-11 06:24:07 +00:00
|
|
|
|
2008-12-26 03:24:24 +00:00
|
|
|
#else /* CONFIG_GENERIC_HARDIRQS */
|
2008-12-12 10:26:39 +00:00
|
|
|
|
|
|
|
extern int nr_irqs;
|
2008-12-26 03:24:24 +00:00
|
|
|
extern struct irq_desc *irq_to_desc(unsigned int irq);
|
2010-09-30 08:45:07 +00:00
|
|
|
unsigned int irq_get_next_irq(unsigned int offset);
|
2008-12-12 10:26:39 +00:00
|
|
|
|
2008-12-26 03:24:24 +00:00
|
|
|
# define for_each_irq_desc(irq, desc) \
|
|
|
|
for (irq = 0, desc = irq_to_desc(irq); irq < nr_irqs; \
|
2008-12-26 03:29:48 +00:00
|
|
|
irq++, desc = irq_to_desc(irq)) \
|
2009-01-03 18:11:05 +00:00
|
|
|
if (!desc) \
|
|
|
|
; \
|
|
|
|
else
|
2008-12-26 03:29:48 +00:00
|
|
|
|
|
|
|
|
2008-12-26 03:24:24 +00:00
|
|
|
# define for_each_irq_desc_reverse(irq, desc) \
|
|
|
|
for (irq = nr_irqs - 1, desc = irq_to_desc(irq); irq >= 0; \
|
2008-12-26 03:29:48 +00:00
|
|
|
irq--, desc = irq_to_desc(irq)) \
|
2009-01-03 18:11:05 +00:00
|
|
|
if (!desc) \
|
|
|
|
; \
|
|
|
|
else
|
2008-12-08 22:06:17 +00:00
|
|
|
|
2009-08-26 23:20:48 +00:00
|
|
|
#ifdef CONFIG_SMP
|
2010-10-28 02:30:31 +00:00
|
|
|
#define irq_node(irq) (irq_get_irq_data(irq)->node)
|
2009-08-26 23:20:48 +00:00
|
|
|
#else
|
|
|
|
#define irq_node(irq) 0
|
|
|
|
#endif
|
|
|
|
|
2010-09-30 08:45:07 +00:00
|
|
|
# define for_each_active_irq(irq) \
|
|
|
|
for (irq = irq_get_next_irq(0); irq < nr_irqs; \
|
|
|
|
irq = irq_get_next_irq(irq + 1))
|
|
|
|
|
2008-12-26 03:24:24 +00:00
|
|
|
#endif /* CONFIG_GENERIC_HARDIRQS */
|
2008-12-08 22:06:17 +00:00
|
|
|
|
|
|
|
#define for_each_irq_nr(irq) \
|
|
|
|
for (irq = 0; irq < nr_irqs; irq++)
|
2008-10-16 16:20:58 +00:00
|
|
|
|
2008-12-12 10:26:39 +00:00
|
|
|
#endif /* __KERNEL__ */
|
|
|
|
|
2008-10-16 16:20:58 +00:00
|
|
|
#endif
|