q-irq.c 649 B

123456789101112131415161718192021222324252627282930313233343536
  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. extern asmlinkage void qemu_handle_int(void);
  9. asmlinkage void plat_irq_dispatch(void)
  10. {
  11. unsigned int pending = read_c0_status() & read_c0_cause();
  12. if (pending & 0x8000) {
  13. ll_timer_interrupt(Q_COUNT_COMPARE_IRQ);
  14. return;
  15. }
  16. if (pending & 0x0400) {
  17. int irq = i8259_irq();
  18. if (likely(irq >= 0))
  19. do_IRQ(irq);
  20. return;
  21. }
  22. }
  23. void __init arch_init_irq(void)
  24. {
  25. mips_hpt_frequency = QEMU_C0_COUNTER_CLOCK; /* 100MHz */
  26. init_i8259_irqs();
  27. set_c0_status(0x8400);
  28. }