irqnr.h 1.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263
  1. #ifndef _LINUX_IRQNR_H
  2. #define _LINUX_IRQNR_H
  3. /*
  4. * Generic irq_desc iterators:
  5. */
  6. #ifdef __KERNEL__
  7. #ifndef CONFIG_GENERIC_HARDIRQS
  8. #include <asm/irq.h>
  9. /*
  10. * Wrappers for non-genirq architectures:
  11. */
  12. #define nr_irqs NR_IRQS
  13. #define irq_to_desc(irq) (&irq_desc[irq])
  14. # define for_each_irq_desc(irq, desc) \
  15. for (irq = 0; irq < nr_irqs; irq++)
  16. # define for_each_irq_desc_reverse(irq, desc) \
  17. for (irq = nr_irqs - 1; irq >= 0; irq--)
  18. #else /* CONFIG_GENERIC_HARDIRQS */
  19. extern int nr_irqs;
  20. extern struct irq_desc *irq_to_desc(unsigned int irq);
  21. unsigned int irq_get_next_irq(unsigned int offset);
  22. # define for_each_irq_desc(irq, desc) \
  23. for (irq = 0, desc = irq_to_desc(irq); irq < nr_irqs; \
  24. irq++, desc = irq_to_desc(irq)) \
  25. if (!desc) \
  26. ; \
  27. else
  28. # define for_each_irq_desc_reverse(irq, desc) \
  29. for (irq = nr_irqs - 1, desc = irq_to_desc(irq); irq >= 0; \
  30. irq--, desc = irq_to_desc(irq)) \
  31. if (!desc) \
  32. ; \
  33. else
  34. #ifdef CONFIG_SMP
  35. #define irq_node(irq) (irq_get_irq_data(irq)->node)
  36. #else
  37. #define irq_node(irq) 0
  38. #endif
  39. # define for_each_active_irq(irq) \
  40. for (irq = irq_get_next_irq(0); irq < nr_irqs; \
  41. irq = irq_get_next_irq(irq + 1))
  42. #endif /* CONFIG_GENERIC_HARDIRQS */
  43. #define for_each_irq_nr(irq) \
  44. for (irq = 0; irq < nr_irqs; irq++)
  45. #endif /* __KERNEL__ */
  46. #endif