diff options
| author | Steven Rostedt <srostedt@redhat.com> | 2009-05-14 23:19:09 -0400 | 
|---|---|---|
| committer | Steven Rostedt <rostedt@goodmis.org> | 2009-05-14 23:19:09 -0400 | 
| commit | 29a679754b1a2581ee456eada6c2de7ce95068bb (patch) | |
| tree | e647c89f3a293f4436ed285acc46180e6fe9a292 /arch/x86/kernel/stacktrace.c | |
| parent | 168b6b1d0594c7866caa73b12f3b8d91075695f2 (diff) | |
| download | olio-linux-3.10-29a679754b1a2581ee456eada6c2de7ce95068bb.tar.xz olio-linux-3.10-29a679754b1a2581ee456eada6c2de7ce95068bb.zip  | |
x86/stacktrace: return 0 instead of -1 for stack ops
If we return -1 in the ops->stack for the stacktrace saving, we end up
breaking out of the loop if the stack we are tracing is in the exception
stack. This causes traces like:
          <idle>-0     [002] 34263.745825: raise_softirq_irqoff <-__blk_complete_request
          <idle>-0     [002] 34263.745826:
 <= 0
 <= 0
 <= 0
 <= 0
 <= 0
 <= 0
 <= 0
By returning "0" instead, the irq stack is saved as well, and we see:
          <idle>-0     [003]   883.280992: raise_softirq_irqoff <-__hrtimer_star
t_range_ns
          <idle>-0     [003]   883.280992:
 <= hrtimer_start_range_ns
 <= tick_nohz_restart_sched_tick
 <= cpu_idle
 <= start_secondary
 <=
 <= 0
 <= 0
[ Impact: record stacks from interrupts ]
Signed-off-by: Steven Rostedt <rostedt@goodmis.org>
Diffstat (limited to 'arch/x86/kernel/stacktrace.c')
| -rw-r--r-- | arch/x86/kernel/stacktrace.c | 2 | 
1 files changed, 1 insertions, 1 deletions
diff --git a/arch/x86/kernel/stacktrace.c b/arch/x86/kernel/stacktrace.c index f7bddc2e37d..4aaf7e48394 100644 --- a/arch/x86/kernel/stacktrace.c +++ b/arch/x86/kernel/stacktrace.c @@ -20,7 +20,7 @@ save_stack_warning_symbol(void *data, char *msg, unsigned long symbol)  static int save_stack_stack(void *data, char *name)  { -	return -1; +	return 0;  }  static void save_stack_address(void *data, unsigned long addr, int reliable)  |