summaryrefslogtreecommitdiff
path: root/arch/arm64/include/asm/stacktrace/common.h
diff options
context:
space:
mode:
authorMark Rutland <mark.rutland@arm.com>2022-09-01 14:06:39 +0100
committerCatalin Marinas <catalin.marinas@arm.com>2022-09-09 12:30:07 +0100
commitbc8d75212d735ac9624c1d3532ad371ec9e570ae (patch)
tree042cfde0da8c95c66dc5bea3f2c7046419ee60cc /arch/arm64/include/asm/stacktrace/common.h
parent16283c54a6c79b589001763421738db96de3ae4e (diff)
arm64: stacktrace: simplify unwind_next_common()
Currently unwind_next_common() takes a pointer to a stack_info which is only ever used within unwind_next_common(). Make it a local variable and simplify callers. There should be no functional change as a result of this patch. Signed-off-by: Mark Rutland <mark.rutland@arm.com> Reviewed-by: Kalesh Singh <kaleshsingh@google.com> Reviewed-by: Madhavan T. Venkataraman <madvenka@linux.microsoft.com> Reviewed-by: Mark Brown <broonie@kernel.org> Cc: Fuad Tabba <tabba@google.com> Cc: Marc Zyngier <maz@kernel.org> Cc: Will Deacon <will@kernel.org> Link: https://lore.kernel.org/r/20220901130646.1316937-3-mark.rutland@arm.com Signed-off-by: Catalin Marinas <catalin.marinas@arm.com>
Diffstat (limited to 'arch/arm64/include/asm/stacktrace/common.h')
-rw-r--r--arch/arm64/include/asm/stacktrace/common.h12
1 files changed, 6 insertions, 6 deletions
diff --git a/arch/arm64/include/asm/stacktrace/common.h b/arch/arm64/include/asm/stacktrace/common.h
index b8b20ef5aa5d..0fbae7c78b70 100644
--- a/arch/arm64/include/asm/stacktrace/common.h
+++ b/arch/arm64/include/asm/stacktrace/common.h
@@ -146,27 +146,27 @@ typedef bool (*on_accessible_stack_fn)(const struct task_struct *tsk,
struct stack_info *info);
static inline int unwind_next_common(struct unwind_state *state,
- struct stack_info *info,
on_accessible_stack_fn accessible,
stack_trace_translate_fp_fn translate_fp)
{
+ struct stack_info info;
unsigned long fp = state->fp, kern_fp = fp;
struct task_struct *tsk = state->task;
if (fp & 0x7)
return -EINVAL;
- if (!accessible(tsk, fp, 16, info))
+ if (!accessible(tsk, fp, 16, &info))
return -EINVAL;
- if (test_bit(info->type, state->stacks_done))
+ if (test_bit(info.type, state->stacks_done))
return -EINVAL;
/*
* If fp is not from the current address space perform the necessary
* translation before dereferencing it to get the next fp.
*/
- if (translate_fp && !translate_fp(&kern_fp, info->type))
+ if (translate_fp && !translate_fp(&kern_fp, info.type))
return -EINVAL;
/*
@@ -183,7 +183,7 @@ static inline int unwind_next_common(struct unwind_state *state,
* stack to another, it's never valid to unwind back to that first
* stack.
*/
- if (info->type == state->prev_type) {
+ if (info.type == state->prev_type) {
if (fp <= state->prev_fp)
return -EINVAL;
} else {
@@ -197,7 +197,7 @@ static inline int unwind_next_common(struct unwind_state *state,
state->fp = READ_ONCE(*(unsigned long *)(kern_fp));
state->pc = READ_ONCE(*(unsigned long *)(kern_fp + 8));
state->prev_fp = fp;
- state->prev_type = info->type;
+ state->prev_type = info.type;
return 0;
}