ARM: 9258/1: stacktrace: Make stack walk callback consistent with generic code

As with the generic arch_stack_walk() code the ARM stack walk code takes
a callback that is called per stack frame. Currently the ARM code always
passes a struct stackframe to the callback and the generic code just
passes the pc, however none of the users ever reference anything in the
struct other than the pc value. The ARM code also uses a return type of
int while the generic code uses a return type of bool though in both
cases the return value is a boolean value and the sense is inverted
between the two.

In order to reduce code duplication when ARM is converted to use
arch_stack_walk() change the signature and return sense of the ARM
specific callback to match that of the generic code.

Signed-off-by: Li Huafei <lihuafei1@huawei.com>
Reviewed-by: Mark Brown <broonie@kernel.org>
Reviewed-by: Linus Waleij <linus.walleij@linaro.org>
Signed-off-by: Russell King (Oracle) <rmk+kernel@armlinux.org.uk>
This commit is contained in:
Li Huafei 2022-10-18 13:57:02 +01:00 committed by Russell King (Oracle)
parent 1d2e9b67b0
commit 70ccc7c066
4 changed files with 15 additions and 17 deletions

View File

@ -44,7 +44,7 @@ void arm_get_current_stackframe(struct pt_regs *regs, struct stackframe *frame)
extern int unwind_frame(struct stackframe *frame); extern int unwind_frame(struct stackframe *frame);
extern void walk_stackframe(struct stackframe *frame, extern void walk_stackframe(struct stackframe *frame,
int (*fn)(struct stackframe *, void *), void *data); bool (*fn)(void *, unsigned long), void *data);
extern void dump_mem(const char *lvl, const char *str, unsigned long bottom, extern void dump_mem(const char *lvl, const char *str, unsigned long bottom,
unsigned long top); unsigned long top);
extern void dump_backtrace(struct pt_regs *regs, struct task_struct *tsk, extern void dump_backtrace(struct pt_regs *regs, struct task_struct *tsk,

View File

@ -81,13 +81,12 @@ perf_callchain_user(struct perf_callchain_entry_ctx *entry, struct pt_regs *regs
* whist unwinding the stackframe and is like a subroutine return so we use * whist unwinding the stackframe and is like a subroutine return so we use
* the PC. * the PC.
*/ */
static int static bool
callchain_trace(struct stackframe *fr, callchain_trace(void *data, unsigned long pc)
void *data)
{ {
struct perf_callchain_entry_ctx *entry = data; struct perf_callchain_entry_ctx *entry = data;
perf_callchain_store(entry, fr->pc); perf_callchain_store(entry, pc);
return 0; return true;
} }
void void

View File

@ -16,17 +16,17 @@ struct return_address_data {
void *addr; void *addr;
}; };
static int save_return_addr(struct stackframe *frame, void *d) static bool save_return_addr(void *d, unsigned long pc)
{ {
struct return_address_data *data = d; struct return_address_data *data = d;
if (!data->level) { if (!data->level) {
data->addr = (void *)frame->pc; data->addr = (void *)pc;
return 1; return false;
} else { } else {
--data->level; --data->level;
return 0; return true;
} }
} }

View File

@ -127,12 +127,12 @@ int notrace unwind_frame(struct stackframe *frame)
#endif #endif
void notrace walk_stackframe(struct stackframe *frame, void notrace walk_stackframe(struct stackframe *frame,
int (*fn)(struct stackframe *, void *), void *data) bool (*fn)(void *, unsigned long), void *data)
{ {
while (1) { while (1) {
int ret; int ret;
if (fn(frame, data)) if (!fn(data, frame->pc))
break; break;
ret = unwind_frame(frame); ret = unwind_frame(frame);
if (ret < 0) if (ret < 0)
@ -148,21 +148,20 @@ struct stack_trace_data {
unsigned int skip; unsigned int skip;
}; };
static int save_trace(struct stackframe *frame, void *d) static bool save_trace(void *d, unsigned long addr)
{ {
struct stack_trace_data *data = d; struct stack_trace_data *data = d;
struct stack_trace *trace = data->trace; struct stack_trace *trace = data->trace;
unsigned long addr = frame->pc;
if (data->no_sched_functions && in_sched_functions(addr)) if (data->no_sched_functions && in_sched_functions(addr))
return 0; return true;
if (data->skip) { if (data->skip) {
data->skip--; data->skip--;
return 0; return true;
} }
trace->entries[trace->nr_entries++] = addr; trace->entries[trace->nr_entries++] = addr;
return trace->nr_entries >= trace->max_entries; return trace->nr_entries < trace->max_entries;
} }
/* This must be noinline to so that our skip calculation works correctly */ /* This must be noinline to so that our skip calculation works correctly */