diff options
| author | Dmitry Torokhov <[email protected]> | 2011-05-24 00:06:26 -0700 | 
|---|---|---|
| committer | Dmitry Torokhov <[email protected]> | 2011-05-24 00:06:26 -0700 | 
| commit | b73077eb03f510a84b102fb97640e595a958403c (patch) | |
| tree | 8b639000418e2756bf6baece4e00e07d2534bccc /arch/x86/kernel/dumpstack.c | |
| parent | 28350e330cfab46b60a1dbf763b678d859f9f3d9 (diff) | |
| parent | 9d2e173644bb5c42ff1b280fbdda3f195a7cf1f7 (diff) | |
Merge branch 'next' into for-linus
Diffstat (limited to 'arch/x86/kernel/dumpstack.c')
| -rw-r--r-- | arch/x86/kernel/dumpstack.c | 51 | 
1 files changed, 9 insertions, 42 deletions
| diff --git a/arch/x86/kernel/dumpstack.c b/arch/x86/kernel/dumpstack.c index df20723a6a1b..e2a3f0606da4 100644 --- a/arch/x86/kernel/dumpstack.c +++ b/arch/x86/kernel/dumpstack.c @@ -27,7 +27,7 @@ static int die_counter;  void printk_address(unsigned long address, int reliable)  { -	printk(" [<%p>] %s%pS\n", (void *) address, +	printk(" [<%p>] %s%pB\n", (void *) address,  			reliable ? "" : "? ", (void *) address);  } @@ -175,21 +175,21 @@ static const struct stacktrace_ops print_trace_ops = {  void  show_trace_log_lvl(struct task_struct *task, struct pt_regs *regs, -		unsigned long *stack, char *log_lvl) +		unsigned long *stack, unsigned long bp, char *log_lvl)  {  	printk("%sCall Trace:\n", log_lvl); -	dump_trace(task, regs, stack, &print_trace_ops, log_lvl); +	dump_trace(task, regs, stack, bp, &print_trace_ops, log_lvl);  }  void show_trace(struct task_struct *task, struct pt_regs *regs, -		unsigned long *stack) +		unsigned long *stack, unsigned long bp)  { -	show_trace_log_lvl(task, regs, stack, ""); +	show_trace_log_lvl(task, regs, stack, bp, "");  }  void show_stack(struct task_struct *task, unsigned long *sp)  { -	show_stack_log_lvl(task, NULL, sp, ""); +	show_stack_log_lvl(task, NULL, sp, 0, "");  }  /* @@ -197,14 +197,16 @@ void show_stack(struct task_struct *task, unsigned long *sp)   */  void dump_stack(void)  { +	unsigned long bp;  	unsigned long stack; +	bp = stack_frame(current, NULL);  	printk("Pid: %d, comm: %.20s %s %s %.*s\n",  		current->pid, current->comm, print_tainted(),  		init_utsname()->release,  		(int)strcspn(init_utsname()->version, " "),  		init_utsname()->version); -	show_trace(NULL, NULL, &stack); +	show_trace(NULL, NULL, &stack, bp);  }  EXPORT_SYMBOL(dump_stack); @@ -320,41 +322,6 @@ void die(const char *str, struct pt_regs *regs, long err)  	oops_end(flags, regs, sig);  } -void notrace __kprobes -die_nmi(char *str, struct pt_regs *regs, int do_panic) -{ -	unsigned long flags; - -	if (notify_die(DIE_NMIWATCHDOG, str, regs, 0, 2, SIGINT) == NOTIFY_STOP) -		return; - -	/* -	 * We are in trouble anyway, lets at least try -	 * to get a message out. -	 */ -	flags = oops_begin(); -	printk(KERN_EMERG "%s", str); -	printk(" on CPU%d, ip %08lx, registers:\n", -		smp_processor_id(), regs->ip); -	show_registers(regs); -	oops_end(flags, regs, 0); -	if (do_panic || panic_on_oops) -		panic("Non maskable interrupt"); -	nmi_exit(); -	local_irq_enable(); -	do_exit(SIGBUS); -} - -static int __init oops_setup(char *s) -{ -	if (!s) -		return -EINVAL; -	if (!strcmp(s, "panic")) -		panic_on_oops = 1; -	return 0; -} -early_param("oops", oops_setup); -  static int __init kstack_setup(char *s)  {  	if (!s) |