f9af0e7091
Impact: cleanup before CONFIG_SPARSE_IRQ age, for_each_irq_desc() sat in irqnr.h and could be called from generic code. CONFIG_SPARSE_IRQ breaks this assumption, but SPARSE_IRQ version for_each_irq_desc() also can move into irqnr.h easily. Also, this patch unifies CONFIG_SPARSE_IRQ and !CONFIG_SPARSE_IRQ for_each_irq_desc(). Signed-off-by: KOSAKI Motohiro <kosaki.motohiro@jp.fujitsu.com> Signed-off-by: Ingo Molnar <mingo@elte.hu>
38 lines
946 B
C
38 lines
946 B
C
#ifndef _LINUX_IRQNR_H
|
|
#define _LINUX_IRQNR_H
|
|
|
|
/*
|
|
* Generic irq_desc iterators:
|
|
*/
|
|
#ifdef __KERNEL__
|
|
|
|
#ifndef CONFIG_GENERIC_HARDIRQS
|
|
#include <asm/irq.h>
|
|
# define nr_irqs NR_IRQS
|
|
|
|
# define for_each_irq_desc(irq, desc) \
|
|
for (irq = 0; irq < nr_irqs; irq++)
|
|
|
|
# define for_each_irq_desc_reverse(irq, desc) \
|
|
for (irq = nr_irqs - 1; irq >= 0; irq--)
|
|
#else /* CONFIG_GENERIC_HARDIRQS */
|
|
|
|
extern int nr_irqs;
|
|
extern struct irq_desc *irq_to_desc(unsigned int irq);
|
|
|
|
# define for_each_irq_desc(irq, desc) \
|
|
for (irq = 0, desc = irq_to_desc(irq); irq < nr_irqs; \
|
|
irq++, desc = irq_to_desc(irq))
|
|
# define for_each_irq_desc_reverse(irq, desc) \
|
|
for (irq = nr_irqs - 1, desc = irq_to_desc(irq); irq >= 0; \
|
|
irq--, desc = irq_to_desc(irq))
|
|
|
|
#endif /* CONFIG_GENERIC_HARDIRQS */
|
|
|
|
#define for_each_irq_nr(irq) \
|
|
for (irq = 0; irq < nr_irqs; irq++)
|
|
|
|
#endif /* __KERNEL__ */
|
|
|
|
#endif
|