c5ac25e0d7
The prolugue unwinder rely on symbol info. When PC is not in kernel text address, it cannot find relative symbol info and it will be broken. The guess unwinder will be used in this case. And the guess unwinder code in prolugue unwinder is redundant. Strip it out and set the unwinder type in unwind_state. Make guess_unwinder::unwind_next_frame() as default way when other unwinders cannot unwind in some extreme case. Signed-off-by: Jinyang He <hejinyang@loongson.cn> Signed-off-by: Huacai Chen <chenhuacai@loongson.cn>
33 lines
742 B
C
33 lines
742 B
C
// SPDX-License-Identifier: GPL-2.0
|
|
/*
|
|
* Copyright (C) 2022-2023 Loongson Technology Corporation Limited
|
|
*/
|
|
#include <linux/kernel.h>
|
|
#include <linux/ftrace.h>
|
|
|
|
#include <asm/unwind.h>
|
|
|
|
bool default_next_frame(struct unwind_state *state)
|
|
{
|
|
struct stack_info *info = &state->stack_info;
|
|
unsigned long addr;
|
|
|
|
if (unwind_done(state))
|
|
return false;
|
|
|
|
do {
|
|
for (state->sp += sizeof(unsigned long);
|
|
state->sp < info->end; state->sp += sizeof(unsigned long)) {
|
|
addr = *(unsigned long *)(state->sp);
|
|
state->pc = unwind_graph_addr(state, addr, state->sp + 8);
|
|
if (__kernel_text_address(state->pc))
|
|
return true;
|
|
}
|
|
|
|
state->sp = info->next_sp;
|
|
|
|
} while (!get_stack_info(state->sp, state->task, info));
|
|
|
|
return false;
|
|
}
|