summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorBenjamin Herrenschmidt <benh@kernel.crashing.org>2012-02-13 20:42:18 +0000
committerBenjamin Herrenschmidt <benh@kernel.crashing.org>2012-02-16 16:15:10 +1100
commit54321242afe6fcf8b7e589bc21ecf832bc5a206a (patch)
treedfc1d3bd73cd1c28421e27bbbbcad60368a69907
parenta1a1d1bfc9be2a5ea8cce78ebd0f17c79489f053 (diff)
downloadlinux-3.10-54321242afe6fcf8b7e589bc21ecf832bc5a206a.tar.gz
linux-3.10-54321242afe6fcf8b7e589bc21ecf832bc5a206a.tar.bz2
linux-3.10-54321242afe6fcf8b7e589bc21ecf832bc5a206a.zip
powerpc: Disable interrupts early in Program Check
Program Check exceptions are the result of WARNs, BUGs, some type of breakpoints, kprobe, and other illegal instructions. We want interrupts (and thus preemption) to remain disabled while doing the initial stage of testing the reason and branching off to a debugger or kprobe, so we are still on the original CPU which makes debugging easier in various cases. This is how the code was intended, hence the local_irq_enable() right in the middle of program_check_exception(). However, the assembly exception prologue for that exception was incorrectly marked as enabling interrupts, which defeats that (and records a redundant enable with lockdep). Signed-off-by: Benjamin Herrenschmidt <benh@kernel.crashing.org>
-rw-r--r--arch/powerpc/kernel/exceptions-64s.S2
1 files changed, 1 insertions, 1 deletions
diff --git a/arch/powerpc/kernel/exceptions-64s.S b/arch/powerpc/kernel/exceptions-64s.S
index d4be7bb3dbd..3844ca7c509 100644
--- a/arch/powerpc/kernel/exceptions-64s.S
+++ b/arch/powerpc/kernel/exceptions-64s.S
@@ -775,7 +775,7 @@ program_check_common:
EXCEPTION_PROLOG_COMMON(0x700, PACA_EXGEN)
bl .save_nvgprs
addi r3,r1,STACK_FRAME_OVERHEAD
- ENABLE_INTS
+ DISABLE_INTS
bl .program_check_exception
b .ret_from_except