Blame view
include/linux/irqnr.h
1.38 KB
dd3a1db90
|
1 2 |
#ifndef _LINUX_IRQNR_H #define _LINUX_IRQNR_H |
0ebb26e7a
|
3 4 5 6 |
/* * Generic irq_desc iterators: */ #ifdef __KERNEL__ |
dd3a1db90
|
7 8 |
#ifndef CONFIG_GENERIC_HARDIRQS #include <asm/irq.h> |
be92d7af3
|
9 10 11 12 13 14 |
/* * Wrappers for non-genirq architectures: */ #define nr_irqs NR_IRQS #define irq_to_desc(irq) (&irq_desc[irq]) |
dd3a1db90
|
15 16 17 |
# define for_each_irq_desc(irq, desc) \ for (irq = 0; irq < nr_irqs; irq++) |
dd3a1db90
|
18 |
|
240d367b4
|
19 20 |
# define for_each_irq_desc_reverse(irq, desc) \ for (irq = nr_irqs - 1; irq >= 0; irq--) |
9332fccde
|
21 |
|
f9af0e709
|
22 |
#else /* CONFIG_GENERIC_HARDIRQS */ |
0ebb26e7a
|
23 24 |
extern int nr_irqs; |
f9af0e709
|
25 |
extern struct irq_desc *irq_to_desc(unsigned int irq); |
a98d24b71
|
26 |
unsigned int irq_get_next_irq(unsigned int offset); |
0ebb26e7a
|
27 |
|
f9af0e709
|
28 29 |
# define for_each_irq_desc(irq, desc) \ for (irq = 0, desc = irq_to_desc(irq); irq < nr_irqs; \ |
18eefedfe
|
30 |
irq++, desc = irq_to_desc(irq)) \ |
01d07820a
|
31 32 33 |
if (!desc) \ ; \ else |
18eefedfe
|
34 |
|
f9af0e709
|
35 36 |
# define for_each_irq_desc_reverse(irq, desc) \ for (irq = nr_irqs - 1, desc = irq_to_desc(irq); irq >= 0; \ |
18eefedfe
|
37 |
irq--, desc = irq_to_desc(irq)) \ |
01d07820a
|
38 39 40 |
if (!desc) \ ; \ else |
240d367b4
|
41 |
|
5bfb5b513
|
42 |
#ifdef CONFIG_SMP |
4600d7c49
|
43 |
#define irq_node(irq) (irq_get_irq_data(irq)->node) |
5bfb5b513
|
44 45 46 |
#else #define irq_node(irq) 0 #endif |
a98d24b71
|
47 48 49 |
# define for_each_active_irq(irq) \ for (irq = irq_get_next_irq(0); irq < nr_irqs; \ irq = irq_get_next_irq(irq + 1)) |
f9af0e709
|
50 |
#endif /* CONFIG_GENERIC_HARDIRQS */ |
240d367b4
|
51 52 53 |
#define for_each_irq_nr(irq) \ for (irq = 0; irq < nr_irqs; irq++) |
dd3a1db90
|
54 |
|
0ebb26e7a
|
55 |
#endif /* __KERNEL__ */ |
dd3a1db90
|
56 |
#endif |