- while((cause = (read_c0_cause()& CAUSEF_IP))) {
- if (cause & CAUSEF_IP7)
- do_IRQ(MIPS_TIMER_INT, regs);
- else if (cause & CAUSEF_IP2)
- irq_dispatch_int(regs);
- else if (cause & CAUSEF_IP3)
- irq_dispatch_ext(INTERRUPT_ID_EXTERNAL_0, regs);
- else if (cause & CAUSEF_IP4)
- irq_dispatch_ext(INTERRUPT_ID_EXTERNAL_1, regs);
- else if (cause & CAUSEF_IP5)
- irq_dispatch_ext(INTERRUPT_ID_EXTERNAL_2, regs);
- else if (cause & CAUSEF_IP6)
- irq_dispatch_ext(INTERRUPT_ID_EXTERNAL_3, regs);
- cli();
+ while((cause = (read_c0_cause() & read_c0_status() & CAUSEF_IP))) {
+ if (cause & CAUSEF_IP7)
+ do_IRQ(MIPS_TIMER_INT, regs);
+ else if (cause & CAUSEF_IP2)
+ irq_dispatch_int(regs);
+#if defined(CONFIG_BCM96338) || defined(CONFIG_BCM96348)
+ else if (cause & CAUSEF_IP3)
+ irq_dispatch_ext(INTERRUPT_ID_EXTERNAL_0, regs);
+ else if (cause & CAUSEF_IP4)
+ irq_dispatch_ext(INTERRUPT_ID_EXTERNAL_1, regs);
+ else if (cause & CAUSEF_IP5)
+ irq_dispatch_ext(INTERRUPT_ID_EXTERNAL_2, regs);
+ else if (cause & CAUSEF_IP6)
+ irq_dispatch_ext(INTERRUPT_ID_EXTERNAL_3, regs);
+#endif
+ else if (cause & CAUSEF_IP0)
+ irq_dispatch_sw(INTERRUPT_ID_SOFTWARE_0, regs);
+ else if (cause & CAUSEF_IP1)
+ irq_dispatch_sw(INTERRUPT_ID_SOFTWARE_1, regs);
+ cli();