diff options
author | Behan Webster <behanw@converseincode.com> | 2014-08-27 00:29:30 -0400 |
---|---|---|
committer | Will Deacon <will.deacon@arm.com> | 2014-09-08 09:39:19 -0400 |
commit | bb28cec4ea2f5151c08e061c6de825a8c853bbd6 (patch) | |
tree | 00f61fa4bd8e39db4394c3fc4f88672769e7f566 | |
parent | 3337a10e0d0cbc9225cefc23aa7a604b698367ed (diff) |
arm64: LLVMLinux: Use current_stack_pointer in save_stack_trace_tsk
Use the global current_stack_pointer to get the value of the stack pointer.
This change supports being able to compile the kernel with both gcc and clang.
Signed-off-by: Behan Webster <behanw@converseincode.com>
Signed-off-by: Mark Charlebois <charlebm@gmail.com>
Reviewed-by: Jan-Simon Möller <dl9pf@gmx.de>
Reviewed-by: Olof Johansson <olof@lixom.net>
Acked-by: Will Deacon <will.deacon@arm.com>
Signed-off-by: Will Deacon <will.deacon@arm.com>
-rw-r--r-- | arch/arm64/kernel/stacktrace.c | 3 |
1 files changed, 1 insertions, 2 deletions
diff --git a/arch/arm64/kernel/stacktrace.c b/arch/arm64/kernel/stacktrace.c index 55437ba1f5a4..407991bf79f5 100644 --- a/arch/arm64/kernel/stacktrace.c +++ b/arch/arm64/kernel/stacktrace.c | |||
@@ -111,10 +111,9 @@ void save_stack_trace_tsk(struct task_struct *tsk, struct stack_trace *trace) | |||
111 | frame.sp = thread_saved_sp(tsk); | 111 | frame.sp = thread_saved_sp(tsk); |
112 | frame.pc = thread_saved_pc(tsk); | 112 | frame.pc = thread_saved_pc(tsk); |
113 | } else { | 113 | } else { |
114 | register unsigned long current_sp asm("sp"); | ||
115 | data.no_sched_functions = 0; | 114 | data.no_sched_functions = 0; |
116 | frame.fp = (unsigned long)__builtin_frame_address(0); | 115 | frame.fp = (unsigned long)__builtin_frame_address(0); |
117 | frame.sp = current_sp; | 116 | frame.sp = current_stack_pointer; |
118 | frame.pc = (unsigned long)save_stack_trace_tsk; | 117 | frame.pc = (unsigned long)save_stack_trace_tsk; |
119 | } | 118 | } |
120 | 119 | ||