blob: 7df36dbe65c702b039ef4ff6908b821a85302023 [file] [log] [blame]
Ralf Baechle07119622005-09-03 15:56:11 -07001#include <linux/init.h>
Atsushi Nemotod9eec1a2007-10-31 01:21:03 +09002#include <linux/interrupt.h>
Ralf Baechle07119622005-09-03 15:56:11 -07003#include <linux/linkage.h>
4
5#include <asm/i8259.h>
Ralf Baechle7bcf7712007-10-11 23:46:09 +01006#include <asm/irq_cpu.h>
Ralf Baechle07119622005-09-03 15:56:11 -07007#include <asm/mipsregs.h>
8#include <asm/qemu.h>
9#include <asm/system.h>
10#include <asm/time.h>
11
Ralf Baechle937a8012006-10-07 19:44:33 +010012asmlinkage void plat_irq_dispatch(void)
Ralf Baechle07119622005-09-03 15:56:11 -070013{
14 unsigned int pending = read_c0_status() & read_c0_cause();
15
16 if (pending & 0x8000) {
Ralf Baechle7bcf7712007-10-11 23:46:09 +010017 do_IRQ(Q_COUNT_COMPARE_IRQ);
Ralf Baechle07119622005-09-03 15:56:11 -070018 return;
19 }
20 if (pending & 0x0400) {
21 int irq = i8259_irq();
22
23 if (likely(irq >= 0))
Ralf Baechle937a8012006-10-07 19:44:33 +010024 do_IRQ(irq);
Ralf Baechle07119622005-09-03 15:56:11 -070025
26 return;
27 }
28}
29
30void __init arch_init_irq(void)
31{
Ralf Baechle07119622005-09-03 15:56:11 -070032 mips_hpt_frequency = QEMU_C0_COUNTER_CLOCK; /* 100MHz */
33
Ralf Baechle7bcf7712007-10-11 23:46:09 +010034 mips_cpu_irq_init();
Ralf Baechle07119622005-09-03 15:56:11 -070035 init_i8259_irqs();
Atsushi Nemoto8f7e7d62007-11-23 00:44:06 +090036 set_c0_status(0x400);
Ralf Baechle07119622005-09-03 15:56:11 -070037}