diff options
-rw-r--r-- | arch/i386/kernel/traps.c | 6 | ||||
-rw-r--r-- | arch/x86_64/kernel/traps.c | 6 | ||||
-rw-r--r-- | include/linux/kernel.h | 1 | ||||
-rw-r--r-- | include/linux/sysctl.h | 1 | ||||
-rw-r--r-- | kernel/panic.c | 1 | ||||
-rw-r--r-- | kernel/sysctl.c | 8 |
6 files changed, 23 insertions, 0 deletions
diff --git a/arch/i386/kernel/traps.c b/arch/i386/kernel/traps.c index 7db664d0b25..2f6cb827648 100644 --- a/arch/i386/kernel/traps.c +++ b/arch/i386/kernel/traps.c | |||
@@ -635,6 +635,8 @@ static void mem_parity_error(unsigned char reason, struct pt_regs * regs) | |||
635 | "to continue\n"); | 635 | "to continue\n"); |
636 | printk(KERN_EMERG "You probably have a hardware problem with your RAM " | 636 | printk(KERN_EMERG "You probably have a hardware problem with your RAM " |
637 | "chips\n"); | 637 | "chips\n"); |
638 | if (panic_on_unrecovered_nmi) | ||
639 | panic("NMI: Not continuing"); | ||
638 | 640 | ||
639 | /* Clear and disable the memory parity error line. */ | 641 | /* Clear and disable the memory parity error line. */ |
640 | clear_mem_error(reason); | 642 | clear_mem_error(reason); |
@@ -670,6 +672,10 @@ static void unknown_nmi_error(unsigned char reason, struct pt_regs * regs) | |||
670 | reason, smp_processor_id()); | 672 | reason, smp_processor_id()); |
671 | printk("Dazed and confused, but trying to continue\n"); | 673 | printk("Dazed and confused, but trying to continue\n"); |
672 | printk("Do you have a strange power saving mode enabled?\n"); | 674 | printk("Do you have a strange power saving mode enabled?\n"); |
675 | |||
676 | if (panic_on_unrecovered_nmi) | ||
677 | panic("NMI: Not continuing"); | ||
678 | |||
673 | } | 679 | } |
674 | 680 | ||
675 | static DEFINE_SPINLOCK(nmi_print_lock); | 681 | static DEFINE_SPINLOCK(nmi_print_lock); |
diff --git a/arch/x86_64/kernel/traps.c b/arch/x86_64/kernel/traps.c index 42bc070fdf1..b18829db2a6 100644 --- a/arch/x86_64/kernel/traps.c +++ b/arch/x86_64/kernel/traps.c | |||
@@ -732,6 +732,8 @@ mem_parity_error(unsigned char reason, struct pt_regs * regs) | |||
732 | { | 732 | { |
733 | printk("Uhhuh. NMI received. Dazed and confused, but trying to continue\n"); | 733 | printk("Uhhuh. NMI received. Dazed and confused, but trying to continue\n"); |
734 | printk("You probably have a hardware problem with your RAM chips\n"); | 734 | printk("You probably have a hardware problem with your RAM chips\n"); |
735 | if (panic_on_unrecovered_nmi) | ||
736 | panic("NMI: Not continuing"); | ||
735 | 737 | ||
736 | /* Clear and disable the memory parity error line. */ | 738 | /* Clear and disable the memory parity error line. */ |
737 | reason = (reason & 0xf) | 4; | 739 | reason = (reason & 0xf) | 4; |
@@ -757,6 +759,10 @@ unknown_nmi_error(unsigned char reason, struct pt_regs * regs) | |||
757 | { printk("Uhhuh. NMI received for unknown reason %02x.\n", reason); | 759 | { printk("Uhhuh. NMI received for unknown reason %02x.\n", reason); |
758 | printk("Dazed and confused, but trying to continue\n"); | 760 | printk("Dazed and confused, but trying to continue\n"); |
759 | printk("Do you have a strange power saving mode enabled?\n"); | 761 | printk("Do you have a strange power saving mode enabled?\n"); |
762 | |||
763 | if (panic_on_unrecovered_nmi) | ||
764 | panic("NMI: Not continuing"); | ||
765 | |||
760 | } | 766 | } |
761 | 767 | ||
762 | /* Runs on IST stack. This code must keep interrupts off all the time. | 768 | /* Runs on IST stack. This code must keep interrupts off all the time. |
diff --git a/include/linux/kernel.h b/include/linux/kernel.h index 2b2ae4fdce8..1ff9609300b 100644 --- a/include/linux/kernel.h +++ b/include/linux/kernel.h | |||
@@ -186,6 +186,7 @@ extern void bust_spinlocks(int yes); | |||
186 | extern int oops_in_progress; /* If set, an oops, panic(), BUG() or die() is in progress */ | 186 | extern int oops_in_progress; /* If set, an oops, panic(), BUG() or die() is in progress */ |
187 | extern int panic_timeout; | 187 | extern int panic_timeout; |
188 | extern int panic_on_oops; | 188 | extern int panic_on_oops; |
189 | extern int panic_on_unrecovered_nmi; | ||
189 | extern int tainted; | 190 | extern int tainted; |
190 | extern const char *print_tainted(void); | 191 | extern const char *print_tainted(void); |
191 | extern void add_taint(unsigned); | 192 | extern void add_taint(unsigned); |
diff --git a/include/linux/sysctl.h b/include/linux/sysctl.h index ecb79ba52ae..432778446ad 100644 --- a/include/linux/sysctl.h +++ b/include/linux/sysctl.h | |||
@@ -151,6 +151,7 @@ enum | |||
151 | KERN_COMPAT_LOG=73, /* int: print compat layer messages */ | 151 | KERN_COMPAT_LOG=73, /* int: print compat layer messages */ |
152 | KERN_MAX_LOCK_DEPTH=74, | 152 | KERN_MAX_LOCK_DEPTH=74, |
153 | KERN_NMI_WATCHDOG=75, /* int: enable/disable nmi watchdog */ | 153 | KERN_NMI_WATCHDOG=75, /* int: enable/disable nmi watchdog */ |
154 | KERN_PANIC_ON_NMI=76, /* int: whether we will panic on an unrecovered */ | ||
154 | }; | 155 | }; |
155 | 156 | ||
156 | 157 | ||
diff --git a/kernel/panic.c b/kernel/panic.c index 8010b9b17ac..d2db3e2209e 100644 --- a/kernel/panic.c +++ b/kernel/panic.c | |||
@@ -21,6 +21,7 @@ | |||
21 | #include <linux/debug_locks.h> | 21 | #include <linux/debug_locks.h> |
22 | 22 | ||
23 | int panic_on_oops; | 23 | int panic_on_oops; |
24 | int panic_on_unrecovered_nmi; | ||
24 | int tainted; | 25 | int tainted; |
25 | static int pause_on_oops; | 26 | static int pause_on_oops; |
26 | static int pause_on_oops_flag; | 27 | static int pause_on_oops_flag; |
diff --git a/kernel/sysctl.c b/kernel/sysctl.c index 040de6bd74d..220e2056412 100644 --- a/kernel/sysctl.c +++ b/kernel/sysctl.c | |||
@@ -642,6 +642,14 @@ static ctl_table kern_table[] = { | |||
642 | #endif | 642 | #endif |
643 | #if defined(CONFIG_X86) | 643 | #if defined(CONFIG_X86) |
644 | { | 644 | { |
645 | .ctl_name = KERN_PANIC_ON_NMI, | ||
646 | .procname = "panic_on_unrecovered_nmi", | ||
647 | .data = &panic_on_unrecovered_nmi, | ||
648 | .maxlen = sizeof(int), | ||
649 | .mode = 0644, | ||
650 | .proc_handler = &proc_dointvec, | ||
651 | }, | ||
652 | { | ||
645 | .ctl_name = KERN_BOOTLOADER_TYPE, | 653 | .ctl_name = KERN_BOOTLOADER_TYPE, |
646 | .procname = "bootloader_type", | 654 | .procname = "bootloader_type", |
647 | .data = &bootloader_type, | 655 | .data = &bootloader_type, |