diff options
| author | Matt Fleming <matt@console-pimps.org> | 2009-08-11 17:43:20 -0400 |
|---|---|---|
| committer | Paul Mundt <lethal@linux-sh.org> | 2009-08-13 06:52:53 -0400 |
| commit | 0eff9f66de79a0707a9c3a2f8528ccfd62100f0b (patch) | |
| tree | 72c2cdbda141faec9950438b7e7cd02ddcd59705 /arch/sh/kernel/stacktrace.c | |
| parent | bf61ad1f870be88676a07bfef69acd59ce10172e (diff) | |
sh: Use the new stack unwinder API
Instead of implementing our own stack unwinder via dump_trace() we
should use the new stack unwinder API because it is more modular. This
change allows us to decouple the interface for generating stacktraces
from the implementation of a stack unwinder.
Signed-off-by: Matt Fleming <matt@console-pimps.org>
Signed-off-by: Paul Mundt <lethal@linux-sh.org>
Diffstat (limited to 'arch/sh/kernel/stacktrace.c')
| -rw-r--r-- | arch/sh/kernel/stacktrace.c | 5 |
1 files changed, 3 insertions, 2 deletions
diff --git a/arch/sh/kernel/stacktrace.c b/arch/sh/kernel/stacktrace.c index 6c24a400b05e..45b1adde3abe 100644 --- a/arch/sh/kernel/stacktrace.c +++ b/arch/sh/kernel/stacktrace.c | |||
| @@ -13,6 +13,7 @@ | |||
| 13 | #include <linux/stacktrace.h> | 13 | #include <linux/stacktrace.h> |
| 14 | #include <linux/thread_info.h> | 14 | #include <linux/thread_info.h> |
| 15 | #include <linux/module.h> | 15 | #include <linux/module.h> |
| 16 | #include <asm/unwinder.h> | ||
| 16 | #include <asm/ptrace.h> | 17 | #include <asm/ptrace.h> |
| 17 | #include <asm/stacktrace.h> | 18 | #include <asm/stacktrace.h> |
| 18 | 19 | ||
| @@ -57,7 +58,7 @@ void save_stack_trace(struct stack_trace *trace) | |||
| 57 | { | 58 | { |
| 58 | unsigned long *sp = (unsigned long *)current_stack_pointer; | 59 | unsigned long *sp = (unsigned long *)current_stack_pointer; |
| 59 | 60 | ||
| 60 | dump_trace(current, NULL, sp, &save_stack_ops, trace); | 61 | unwind_stack(current, NULL, sp, &save_stack_ops, trace); |
| 61 | } | 62 | } |
| 62 | EXPORT_SYMBOL_GPL(save_stack_trace); | 63 | EXPORT_SYMBOL_GPL(save_stack_trace); |
| 63 | 64 | ||
| @@ -89,6 +90,6 @@ void save_stack_trace_tsk(struct task_struct *tsk, struct stack_trace *trace) | |||
| 89 | { | 90 | { |
| 90 | unsigned long *sp = (unsigned long *)tsk->thread.sp; | 91 | unsigned long *sp = (unsigned long *)tsk->thread.sp; |
| 91 | 92 | ||
| 92 | dump_trace(current, NULL, sp, &save_stack_ops_nosched, trace); | 93 | unwind_stack(current, NULL, sp, &save_stack_ops_nosched, trace); |
| 93 | } | 94 | } |
| 94 | EXPORT_SYMBOL_GPL(save_stack_trace_tsk); | 95 | EXPORT_SYMBOL_GPL(save_stack_trace_tsk); |
