powerpc: Provide a way to defer perf counter work until interrupts are enabled
authorPaul Mackerras <paulus@samba.org>
Fri, 9 Jan 2009 05:52:19 +0000 (16:52 +1100)
committerPaul Mackerras <paulus@samba.org>
Fri, 9 Jan 2009 08:48:17 +0000 (19:48 +1100)
commit93a6d3ce6962044fe9badf528fed46b455d58292
treee3941058ddb4117b4598b8d94fb218cfeb9e2fa8
parentd662ed26734473d4cb5f3d78cebfec8f9126e97c
powerpc: Provide a way to defer perf counter work until interrupts are enabled

Because 64-bit powerpc uses lazy (soft) interrupt disabling, it is
possible for a performance monitor exception to come in when the
kernel thinks interrupts are disabled (i.e. when they are
soft-disabled but hard-enabled).  In such a situation the performance
monitor exception handler might have some processing to do (such as
process wakeups) which can't be done in what is effectively an NMI
handler.

This provides a way to defer that work until interrupts get enabled,
either in raw_local_irq_restore() or by returning from an interrupt
handler to code that had interrupts enabled.  We have a per-processor
flag that indicates that there is work pending to do when interrupts
subsequently get re-enabled.  This flag is checked in the interrupt
return path and in raw_local_irq_restore(), and if it is set,
perf_counter_do_pending() is called to do the pending work.

Signed-off-by: Paul Mackerras <paulus@samba.org>
arch/powerpc/include/asm/hw_irq.h
arch/powerpc/include/asm/paca.h
arch/powerpc/kernel/asm-offsets.c
arch/powerpc/kernel/entry_64.S
arch/powerpc/kernel/irq.c