irq.h 1.2 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849
  1. /*
  2. * This file is subject to the terms and conditions of the GNU General Public
  3. * License. See the file "COPYING" in the main directory of this archive
  4. * for more details.
  5. *
  6. * Copyright (C) 1994 by Waldorf GMBH, written by Ralf Baechle
  7. * Copyright (C) 1995, 96, 97, 98, 99, 2000, 01, 02, 03 by Ralf Baechle
  8. */
  9. #ifndef _ASM_IRQ_H
  10. #define _ASM_IRQ_H
  11. #include <linux/linkage.h>
  12. #include <linux/smp.h>
  13. #include <linux/irqdomain.h>
  14. #include <asm/mipsmtregs.h>
  15. #include <irq.h>
  16. #ifdef CONFIG_I8259
  17. static inline int irq_canonicalize(int irq)
  18. {
  19. return ((irq == I8259A_IRQ_BASE + 2) ? I8259A_IRQ_BASE + 9 : irq);
  20. }
  21. #else
  22. #define irq_canonicalize(irq) (irq) /* Sane hardware, sane code ... */
  23. #endif
  24. extern void do_IRQ(unsigned int irq);
  25. extern void arch_init_irq(void);
  26. extern void spurious_interrupt(void);
  27. extern int allocate_irqno(void);
  28. extern void alloc_legacy_irqno(void);
  29. extern void free_irqno(unsigned int irq);
  30. /*
  31. * Before R2 the timer and performance counter interrupts were both fixed to
  32. * IE7. Since R2 their number has to be read from the c0_intctl register.
  33. */
  34. #define CP0_LEGACY_COMPARE_IRQ 7
  35. #define CP0_LEGACY_PERFCNT_IRQ 7
  36. extern int cp0_compare_irq;
  37. extern int cp0_compare_irq_shift;
  38. extern int cp0_perfcount_irq;
  39. #endif /* _ASM_IRQ_H */