diff options
Diffstat (limited to 'kernel/debug/kdb')
| -rw-r--r-- | kernel/debug/kdb/kdb_bt.c | 2 | ||||
| -rw-r--r-- | kernel/debug/kdb/kdb_debugger.c | 5 | ||||
| -rw-r--r-- | kernel/debug/kdb/kdb_io.c | 2 | ||||
| -rw-r--r-- | kernel/debug/kdb/kdb_main.c | 5 | 
4 files changed, 10 insertions, 4 deletions
diff --git a/kernel/debug/kdb/kdb_bt.c b/kernel/debug/kdb/kdb_bt.c index b03e0e814e4..fe15fff5df5 100644 --- a/kernel/debug/kdb/kdb_bt.c +++ b/kernel/debug/kdb/kdb_bt.c @@ -21,7 +21,7 @@  static void kdb_show_stack(struct task_struct *p, void *addr)  {  	int old_lvl = console_loglevel; -	console_loglevel = 15; +	console_loglevel = CONSOLE_LOGLEVEL_MOTORMOUTH;  	kdb_trap_printk++;  	kdb_set_current_task(p);  	if (addr) { diff --git a/kernel/debug/kdb/kdb_debugger.c b/kernel/debug/kdb/kdb_debugger.c index 328d18ef31e..8859ca34dcf 100644 --- a/kernel/debug/kdb/kdb_debugger.c +++ b/kernel/debug/kdb/kdb_debugger.c @@ -69,7 +69,10 @@ int kdb_stub(struct kgdb_state *ks)  	if (atomic_read(&kgdb_setting_breakpoint))  		reason = KDB_REASON_KEYBOARD; -	if (in_nmi()) +	if (ks->err_code == KDB_REASON_SYSTEM_NMI && ks->signo == SIGTRAP) +		reason = KDB_REASON_SYSTEM_NMI; + +	else if (in_nmi())  		reason = KDB_REASON_NMI;  	for (i = 0, bp = kdb_breakpoints; i < KDB_MAXBPT; i++, bp++) { diff --git a/kernel/debug/kdb/kdb_io.c b/kernel/debug/kdb/kdb_io.c index 14ff4849262..7c70812caea 100644 --- a/kernel/debug/kdb/kdb_io.c +++ b/kernel/debug/kdb/kdb_io.c @@ -710,7 +710,7 @@ kdb_printit:  	}  	if (logging) {  		saved_loglevel = console_loglevel; -		console_loglevel = 0; +		console_loglevel = CONSOLE_LOGLEVEL_SILENT;  		printk(KERN_INFO "%s", kdb_buffer);  	} diff --git a/kernel/debug/kdb/kdb_main.c b/kernel/debug/kdb/kdb_main.c index 00eb8f7fbf4..2f7c760305c 100644 --- a/kernel/debug/kdb/kdb_main.c +++ b/kernel/debug/kdb/kdb_main.c @@ -1091,7 +1091,7 @@ static int kdb_reboot(int argc, const char **argv)  static void kdb_dumpregs(struct pt_regs *regs)  {  	int old_lvl = console_loglevel; -	console_loglevel = 15; +	console_loglevel = CONSOLE_LOGLEVEL_MOTORMOUTH;  	kdb_trap_printk++;  	show_regs(regs);  	kdb_trap_printk--; @@ -1200,6 +1200,9 @@ static int kdb_local(kdb_reason_t reason, int error, struct pt_regs *regs,  			   instruction_pointer(regs));  		kdb_dumpregs(regs);  		break; +	case KDB_REASON_SYSTEM_NMI: +		kdb_printf("due to System NonMaskable Interrupt\n"); +		break;  	case KDB_REASON_NMI:  		kdb_printf("due to NonMaskable Interrupt @ "  			   kdb_machreg_fmt "\n",  | 
