aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorAndrew Morton <akpm@osdl.org>2006-09-26 04:52:36 -0400
committerAndi Kleen <andi@basil.nowhere.org>2006-09-26 04:52:36 -0400
commitabf0f10948b316b577851ef21c728341f1046552 (patch)
tree96cdb96a4e668fe3a3e9c88e8158bc371802f4d3
parente07e23e1fd3000289fc7ccc6c71879070d3b19e0 (diff)
[PATCH] wire up oops_enter()/oops_exit()
Implement pause_on_oops() on x86_64. AK: I redid the patch to do the oops_enter/exit in the existing oops_begin()/end(). This makes it much shorter. Signed-off-by: Andrew Morton <akpm@osdl.org> Signed-off-by: Andi Kleen <ak@suse.de>
-rw-r--r--arch/x86_64/kernel/traps.c3
1 files changed, 3 insertions, 0 deletions
diff --git a/arch/x86_64/kernel/traps.c b/arch/x86_64/kernel/traps.c
index ffc40cff1e07..34660b1e2720 100644
--- a/arch/x86_64/kernel/traps.c
+++ b/arch/x86_64/kernel/traps.c
@@ -561,6 +561,8 @@ unsigned __kprobes long oops_begin(void)
561 int cpu = safe_smp_processor_id(); 561 int cpu = safe_smp_processor_id();
562 unsigned long flags; 562 unsigned long flags;
563 563
564 oops_enter();
565
564 /* racy, but better than risking deadlock. */ 566 /* racy, but better than risking deadlock. */
565 local_irq_save(flags); 567 local_irq_save(flags);
566 if (!spin_trylock(&die_lock)) { 568 if (!spin_trylock(&die_lock)) {
@@ -589,6 +591,7 @@ void __kprobes oops_end(unsigned long flags)
589 spin_unlock_irqrestore(&die_lock, flags); 591 spin_unlock_irqrestore(&die_lock, flags);
590 if (panic_on_oops) 592 if (panic_on_oops)
591 panic("Fatal exception"); 593 panic("Fatal exception");
594 oops_exit();
592} 595}
593 596
594void __kprobes __die(const char * str, struct pt_regs * regs, long err) 597void __kprobes __die(const char * str, struct pt_regs * regs, long err)