Re: [sparc] BUG: NMI Watchdog detected LOCKUP on CPU0

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



From: Ben Hutchings <ben@xxxxxxxxxxxxxxx>
Date: Sat, 07 Apr 2012 18:21:38 +0100

> cheetah_xcall_deliver() does appear to be relevant to the problem and it
> looks like it could loop indefinitely - though presumably only if a
> processor is behaving strangely?

I can only loop indefinitely if one of the cpus is hung and
does not respond to the cross-call interrupt.

> It appears to periodically enable and disable interrupts, but then
> I'm not sure how the PSTATE.IE and PIL interrupt control fields
> interact and I don't think this will reset the NMI watchdog.

PSTATE.IE controls delivery of all interrupts, both PIL
based and vectored interrupts.

PIL only controls delivery of PIL interrupts.

The NMI watchdog interrupt is a special PIL interrupt, and
most of the standard local_irq_disable() et al. routines on
sparc will adjust the %pil such that NMI watchdog interrupts
are still delivered.

See include/asm/pil.h for details.

--
To unsubscribe from this list: send the line "unsubscribe sparclinux" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at  http://vger.kernel.org/majordomo-info.html


[Index of Archives]     [Kernel Development]     [DCCP]     [Linux ARM Development]     [Linux]     [Photo]     [Yosemite Help]     [Linux ARM Kernel]     [Linux SCSI]     [Linux x86_64]     [Linux Hams]

  Powered by Linux