blob: 4681757460a118e50192772b4218cb8407e1bbb0 [file] [log] [blame]
Ralf Baechle07119622005-09-03 15:56:11 -07001#include <linux/init.h>
2#include <linux/linkage.h>
3
4#include <asm/i8259.h>
Ralf Baechle7bcf7712007-10-11 23:46:09 +01005#include <asm/irq_cpu.h>
Ralf Baechle07119622005-09-03 15:56:11 -07006#include <asm/mipsregs.h>
7#include <asm/qemu.h>
8#include <asm/system.h>
9#include <asm/time.h>
10
Ralf Baechle937a8012006-10-07 19:44:33 +010011asmlinkage void plat_irq_dispatch(void)
Ralf Baechle07119622005-09-03 15:56:11 -070012{
13 unsigned int pending = read_c0_status() & read_c0_cause();
14
15 if (pending & 0x8000) {
Ralf Baechle7bcf7712007-10-11 23:46:09 +010016 do_IRQ(Q_COUNT_COMPARE_IRQ);
Ralf Baechle07119622005-09-03 15:56:11 -070017 return;
18 }
19 if (pending & 0x0400) {
20 int irq = i8259_irq();
21
22 if (likely(irq >= 0))
Ralf Baechle937a8012006-10-07 19:44:33 +010023 do_IRQ(irq);
Ralf Baechle07119622005-09-03 15:56:11 -070024
25 return;
26 }
27}
28
29void __init arch_init_irq(void)
30{
Ralf Baechle07119622005-09-03 15:56:11 -070031 mips_hpt_frequency = QEMU_C0_COUNTER_CLOCK; /* 100MHz */
32
Ralf Baechle7bcf7712007-10-11 23:46:09 +010033 mips_cpu_irq_init();
Ralf Baechle07119622005-09-03 15:56:11 -070034 init_i8259_irqs();
35 set_c0_status(0x8400);
36}