aboutsummaryrefslogtreecommitdiffstats
path: root/arch/s390/kernel
diff options
context:
space:
mode:
authorHeiko Carstens <heiko.carstens@de.ibm.com>2007-06-19 07:10:05 -0400
committerMartin Schwidefsky <schwidefsky@de.ibm.com>2007-06-19 07:10:20 -0400
commitbca0fb8683b7406d3056dc53a14b0a482c367e2b (patch)
tree9c42ec8d7c927766e2d7c6a74b6875f08156db5b /arch/s390/kernel
parent0fc9bbf771ce7d41ed33300e75e74e922dde1c38 (diff)
[S390] Add oops_enter()/oops_exit() calls to die().
This is mainly to switch off all potentially debugging stuff that won't report anything useful after an oops happened. Besided that setting pause_on_oops will work too, but doesn't make too much sense on s390. Signed-off-by: Heiko Carstens <heiko.carstens@de.ibm.com> Signed-off-by: Martin Schwidefsky <schwidefsky@de.ibm.com>
Diffstat (limited to 'arch/s390/kernel')
-rw-r--r--arch/s390/kernel/traps.c8
1 files changed, 5 insertions, 3 deletions
diff --git a/arch/s390/kernel/traps.c b/arch/s390/kernel/traps.c
index 1d8c92740ccd..ee9186f8fb08 100644
--- a/arch/s390/kernel/traps.c
+++ b/arch/s390/kernel/traps.c
@@ -253,20 +253,22 @@ void die(const char * str, struct pt_regs * regs, long err)
253{ 253{
254 static int die_counter; 254 static int die_counter;
255 255
256 oops_enter();
256 debug_stop_all(); 257 debug_stop_all();
257 console_verbose(); 258 console_verbose();
258 spin_lock_irq(&die_lock); 259 spin_lock_irq(&die_lock);
259 bust_spinlocks(1); 260 bust_spinlocks(1);
260 printk("%s: %04lx [#%d]\n", str, err & 0xffff, ++die_counter); 261 printk("%s: %04lx [#%d]\n", str, err & 0xffff, ++die_counter);
261 print_modules(); 262 print_modules();
262 show_regs(regs); 263 show_regs(regs);
263 bust_spinlocks(0); 264 bust_spinlocks(0);
264 spin_unlock_irq(&die_lock); 265 spin_unlock_irq(&die_lock);
265 if (in_interrupt()) 266 if (in_interrupt())
266 panic("Fatal exception in interrupt"); 267 panic("Fatal exception in interrupt");
267 if (panic_on_oops) 268 if (panic_on_oops)
268 panic("Fatal exception: panic_on_oops"); 269 panic("Fatal exception: panic_on_oops");
269 do_exit(SIGSEGV); 270 oops_exit();
271 do_exit(SIGSEGV);
270} 272}
271 273
272static void inline 274static void inline