aboutsummaryrefslogtreecommitdiff
path: root/arch/arm64
diff options
context:
space:
mode:
authorBehan Webster <behanw@converseincode.com>2014-02-12 12:16:37 -0800
committerBehan Webster <behanw@converseincode.com>2014-03-31 00:07:22 -0700
commitd21179c737aa69c33f69167f71d5eb831b6f52c1 (patch)
treec323fdc7b1608af7fc3e17d3b3e97260dddd0a80 /arch/arm64
parentb1e8d3e51984bed68e0fceeea75f60bb71d8cf39 (diff)
arm64: LLVMLinux: named_register-stacktrace-aarch64
The existing code uses named registers to get the value of the stack pointer. The new current_stack_pointer macro is more readable and allows for a central portable implementation of how to get the stack pointer with ASM. This change supports being able to compile the kernel with both gcc and Clang. Signed-off-by: Behan Webster <behanw@converseincode.com>
Diffstat (limited to 'arch/arm64')
-rw-r--r--arch/arm64/kernel/stacktrace.c3
1 files changed, 1 insertions, 2 deletions
diff --git a/arch/arm64/kernel/stacktrace.c b/arch/arm64/kernel/stacktrace.c
index 38f0558f0c0..6f44bf97e4c 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)
frame.sp = thread_saved_sp(tsk);
frame.pc = thread_saved_pc(tsk);
} else {
- register unsigned long current_sp asm("sp");
data.no_sched_functions = 0;
frame.fp = (unsigned long)__builtin_frame_address(0);
- frame.sp = current_sp;
+ frame.sp = current_stack_pointer;
frame.pc = (unsigned long)save_stack_trace_tsk;
}