q-irq.c 602 B

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