diff options
author | Paul Mundt <lethal@linux-sh.org> | 2010-10-27 03:58:22 -0400 |
---|---|---|
committer | Paul Mundt <lethal@linux-sh.org> | 2010-10-27 03:58:22 -0400 |
commit | d1ba71f7645696020864fe3cea3049befbe50408 (patch) | |
tree | f870feb1903ed3c46ffe825c5a5b394175a757f9 /arch/sh | |
parent | 2e4f17d230d84579fef07836fb5f69bf1a0a47ad (diff) |
sh64: oprofile: Fix up kernel stack pointer size mismatch.
For the backtrace code its assumed that the stack pointer is 32-bits,
which is not the case with the sh64 registers. Use the shared
kernel_stack_pointer() helper to get at the actual register, which
already takes care of the necessary typecasting.
Signed-off-by: Paul Mundt <lethal@linux-sh.org>
Diffstat (limited to 'arch/sh')
-rw-r--r-- | arch/sh/oprofile/backtrace.c | 2 |
1 files changed, 1 insertions, 1 deletions
diff --git a/arch/sh/oprofile/backtrace.c b/arch/sh/oprofile/backtrace.c index 2bc74de23f08..37f3a75ea6cb 100644 --- a/arch/sh/oprofile/backtrace.c +++ b/arch/sh/oprofile/backtrace.c | |||
@@ -91,7 +91,7 @@ void sh_backtrace(struct pt_regs * const regs, unsigned int depth) | |||
91 | if (depth > backtrace_limit) | 91 | if (depth > backtrace_limit) |
92 | depth = backtrace_limit; | 92 | depth = backtrace_limit; |
93 | 93 | ||
94 | stackaddr = (unsigned long *)regs->regs[15]; | 94 | stackaddr = (unsigned long *)kernel_stack_pointer(regs); |
95 | if (!user_mode(regs)) { | 95 | if (!user_mode(regs)) { |
96 | if (depth) | 96 | if (depth) |
97 | unwind_stack(NULL, regs, stackaddr, | 97 | unwind_stack(NULL, regs, stackaddr, |