irq: initialize nr_irqs based on nr_cpu_ids
[safe/jmp/linux-2.6] / include / linux / irqnr.h
1 #ifndef _LINUX_IRQNR_H
2 #define _LINUX_IRQNR_H
3
4 /*
5  * Generic irq_desc iterators:
6  */
7 #ifdef __KERNEL__
8
9 #ifndef CONFIG_GENERIC_HARDIRQS
10 #include <asm/irq.h>
11
12 /*
13  * Wrappers for non-genirq architectures:
14  */
15 #define nr_irqs                 NR_IRQS
16 #define irq_to_desc(irq)        (&irq_desc[irq])
17
18 # define for_each_irq_desc(irq, desc)           \
19         for (irq = 0; irq < nr_irqs; irq++)
20
21 # define for_each_irq_desc_reverse(irq, desc)                          \
22         for (irq = nr_irqs - 1; irq >= 0; irq--)
23
24 #else /* CONFIG_GENERIC_HARDIRQS */
25
26 #include <asm/irq_vectors.h>    /* need possible max_nr_irqs() */
27
28 extern int nr_irqs;
29 extern struct irq_desc *irq_to_desc(unsigned int irq);
30
31 # ifndef max_nr_irqs
32 #  define max_nr_irqs(nr_cpus)  NR_IRQS
33 # endif
34
35 # define for_each_irq_desc(irq, desc)                                   \
36         for (irq = 0, desc = irq_to_desc(irq); irq < nr_irqs;           \
37              irq++, desc = irq_to_desc(irq))                            \
38                 if (desc)
39
40
41 # define for_each_irq_desc_reverse(irq, desc)                           \
42         for (irq = nr_irqs - 1, desc = irq_to_desc(irq); irq >= 0;      \
43              irq--, desc = irq_to_desc(irq))                            \
44                 if (desc)
45
46 #endif /* CONFIG_GENERIC_HARDIRQS */
47
48 #define for_each_irq_nr(irq)                   \
49        for (irq = 0; irq < nr_irqs; irq++)
50
51 #endif /* __KERNEL__ */
52
53 #endif