q-irq.c 665 B

12345678910111213141516171819202122232425262728293031323334353637
  1. #include <linux/init.h>
  2. #include <linux/interrupt.h>
  3. #include <linux/linkage.h>
  4. #include <asm/i8259.h>
  5. #include <asm/irq_cpu.h>
  6. #include <asm/mipsregs.h>
  7. #include <asm/qemu.h>
  8. #include <asm/system.h>
  9. #include <asm/time.h>
  10. asmlinkage void plat_irq_dispatch(void)
  11. {
  12. unsigned int pending = read_c0_status() & read_c0_cause();
  13. if (pending & 0x8000) {
  14. do_IRQ(Q_COUNT_COMPARE_IRQ);
  15. return;
  16. }
  17. if (pending & 0x0400) {
  18. int irq = i8259_irq();
  19. if (likely(irq >= 0))
  20. do_IRQ(irq);
  21. return;
  22. }
  23. }
  24. void __init arch_init_irq(void)
  25. {
  26. mips_hpt_frequency = QEMU_C0_COUNTER_CLOCK; /* 100MHz */
  27. mips_cpu_irq_init();
  28. init_i8259_irqs();
  29. set_c0_status(0x400);
  30. }