On Tue, 14 Aug 2007 13:52:42 +1000 (EST) David Gibson <[EMAIL PROTECTED]> wrote:
> At present the cascade interrupt handler for the UIC (interrupt > controller on 4xx embedded chips) will misbehave badly if it is called > spuriously - that is if the handler is invoked when no interrupts are > asserted in the child UIC. > > Although spurious interrupts shouldn't happen, it's good to behave > robustly if they do. This patch does so by checking for and ignoring > spurious interrupts. > > Signed-off-by: Valentine Barshak <[EMAIL PROTECTED]> > Signed-off-by: David Gibson <[EMAIL PROTECTED]> > > --- > arch/powerpc/sysdev/uic.c | 3 +++ > 1 file changed, 3 insertions(+) > > Index: working-2.6/arch/powerpc/sysdev/uic.c > =================================================================== > --- working-2.6.orig/arch/powerpc/sysdev/uic.c 2007-08-14 > 13:46:02.000000000 +1000 > +++ working-2.6/arch/powerpc/sysdev/uic.c 2007-08-14 13:46:02.000000000 > +1000 > @@ -266,6 +266,9 @@ irqreturn_t uic_cascade(int virq, void * > int subvirq; > > msr = mfdcr(uic->dcrbase + UIC_MSR); > + if (!msr) /* spurious interrupt */ > + return IRQ_HANDLED; Hm. Is there was a way we could have this case increment ppc_spurious_interrupts so that the BAD entry in /proc/interrupts would be updated with these? Not a huge deal, but it might be nice to have. Otherwise the patch looks fine. Acked-by: Josh Boyer <[EMAIL PROTECTED]> josh _______________________________________________ Linuxppc-dev mailing list Linuxppc-dev@ozlabs.org https://ozlabs.org/mailman/listinfo/linuxppc-dev