irqnr.h 1.3 KB

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