crypto: api - Fix module load deadlock with fallback algorithms
[linux-2.6/linux-2.6-openrd.git] / include / linux / irqnr.h
blob86af92e9e84c0e3115845bcd3abbc125d28b5088
1 #ifndef _LINUX_IRQNR_H
2 #define _LINUX_IRQNR_H
4 /*
5 * Generic irq_desc iterators:
6 */
7 #ifdef __KERNEL__
9 #ifndef CONFIG_GENERIC_HARDIRQS
10 #include <asm/irq.h>
13 * Wrappers for non-genirq architectures:
15 #define nr_irqs NR_IRQS
16 #define irq_to_desc(irq) (&irq_desc[irq])
18 # define for_each_irq_desc(irq, desc) \
19 for (irq = 0; irq < nr_irqs; irq++)
21 # define for_each_irq_desc_reverse(irq, desc) \
22 for (irq = nr_irqs - 1; irq >= 0; irq--)
23 #else /* CONFIG_GENERIC_HARDIRQS */
25 extern int nr_irqs;
26 extern struct irq_desc *irq_to_desc(unsigned int irq);
28 # define for_each_irq_desc(irq, desc) \
29 for (irq = 0, desc = irq_to_desc(irq); irq < nr_irqs; \
30 irq++, desc = irq_to_desc(irq)) \
31 if (desc)
34 # define for_each_irq_desc_reverse(irq, desc) \
35 for (irq = nr_irqs - 1, desc = irq_to_desc(irq); irq >= 0; \
36 irq--, desc = irq_to_desc(irq)) \
37 if (desc)
39 #endif /* CONFIG_GENERIC_HARDIRQS */
41 #define for_each_irq_nr(irq) \
42 for (irq = 0; irq < nr_irqs; irq++)
44 #endif /* __KERNEL__ */
46 #endif