On Fri, 5 Sep 2014, Andrew Bresticker wrote: > For platforms which boot with device-tree and use the MIPS CPU interrupt > controller binding, a generic plat_irq_dispatch() can be used since all > CPU interrupts should be mapped through the CPU IRQ domain. Implement a > plat_irq_dispatch() which simply handles the highest pending interrupt. > > Signed-off-by: Andrew Bresticker <abrestic@xxxxxxxxxxxx> > Tested-by: Jonas Gorski <jogo@xxxxxxxxxxx> > --- > No changes from v1. > --- > arch/mips/kernel/irq_cpu.c | 28 +++++++++++++++++++++++----- > 1 file changed, 23 insertions(+), 5 deletions(-) > > diff --git a/arch/mips/kernel/irq_cpu.c b/arch/mips/kernel/irq_cpu.c > index e498f2b..9cf8459 100644 > --- a/arch/mips/kernel/irq_cpu.c > +++ b/arch/mips/kernel/irq_cpu.c > @@ -116,6 +116,24 @@ void __init mips_cpu_irq_init(void) > } > > #ifdef CONFIG_IRQ_DOMAIN > +static struct irq_domain *mips_intc_domain; > + > +asmlinkage void __weak plat_irq_dispatch(void) > +{ > + unsigned int pending = read_c0_cause() & read_c0_status() & ST0_IM; > + unsigned int hw; > + int irq; > + > + if (!pending) { > + spurious_interrupt(); > + return; > + } > + > + hw = fls(pending) - CAUSEB_IP - 1; > + irq = irq_linear_revmap(mips_intc_domain, hw); > + do_IRQ(irq); Why are you not handling all pending interrupts in a loop? Thanks, tglx