2005-09-04 06:56:11 +08:00
|
|
|
#include <linux/init.h>
|
|
|
|
#include <linux/linkage.h>
|
|
|
|
|
|
|
|
#include <asm/i8259.h>
|
2007-10-12 06:46:09 +08:00
|
|
|
#include <asm/irq_cpu.h>
|
2005-09-04 06:56:11 +08:00
|
|
|
#include <asm/mipsregs.h>
|
|
|
|
#include <asm/qemu.h>
|
|
|
|
#include <asm/system.h>
|
|
|
|
#include <asm/time.h>
|
|
|
|
|
2006-10-08 02:44:33 +08:00
|
|
|
asmlinkage void plat_irq_dispatch(void)
|
2005-09-04 06:56:11 +08:00
|
|
|
{
|
|
|
|
unsigned int pending = read_c0_status() & read_c0_cause();
|
|
|
|
|
|
|
|
if (pending & 0x8000) {
|
2007-10-12 06:46:09 +08:00
|
|
|
do_IRQ(Q_COUNT_COMPARE_IRQ);
|
2005-09-04 06:56:11 +08:00
|
|
|
return;
|
|
|
|
}
|
|
|
|
if (pending & 0x0400) {
|
|
|
|
int irq = i8259_irq();
|
|
|
|
|
|
|
|
if (likely(irq >= 0))
|
2006-10-08 02:44:33 +08:00
|
|
|
do_IRQ(irq);
|
2005-09-04 06:56:11 +08:00
|
|
|
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
void __init arch_init_irq(void)
|
|
|
|
{
|
|
|
|
mips_hpt_frequency = QEMU_C0_COUNTER_CLOCK; /* 100MHz */
|
|
|
|
|
2007-10-12 06:46:09 +08:00
|
|
|
mips_cpu_irq_init();
|
2005-09-04 06:56:11 +08:00
|
|
|
init_i8259_irqs();
|
|
|
|
set_c0_status(0x8400);
|
|
|
|
}
|