Donate to e Foundation | Murena handsets with /e/OS | Own a part of Murena! Learn more

Commit 0eff9f66 authored by Matt Fleming's avatar Matt Fleming Committed by Paul Mundt
Browse files

sh: Use the new stack unwinder API



Instead of implementing our own stack unwinder via dump_trace() we
should use the new stack unwinder API because it is more modular. This
change allows us to decouple the interface for generating stacktraces
from the implementation of a stack unwinder.

Signed-off-by: default avatarMatt Fleming <matt@console-pimps.org>
Signed-off-by: default avatarPaul Mundt <lethal@linux-sh.org>
parent bf61ad1f
Loading
Loading
Loading
Loading
+6 −11
Original line number Diff line number Diff line
@@ -6,7 +6,7 @@
#include <linux/kallsyms.h>
#include <linux/ftrace.h>
#include <linux/debug_locks.h>

#include <asm/unwinder.h>
#include <asm/stacktrace.h>

void printk_address(unsigned long address, int reliable)
@@ -46,11 +46,8 @@ print_ftrace_graph_addr(unsigned long addr, void *data,
{ }
#endif

/*
 * Unwind the call stack and pass information to the stacktrace_ops
 * functions.
 */
void dump_trace(struct task_struct *task, struct pt_regs *regs,
void
stack_reader_dump(struct task_struct *task, struct pt_regs *regs,
		  unsigned long *sp, const struct stacktrace_ops *ops,
		  void *data)
{
@@ -71,8 +68,6 @@ void dump_trace(struct task_struct *task, struct pt_regs *regs,
		}
	}
}
EXPORT_SYMBOL(dump_trace);


static void
print_trace_warning_symbol(void *data, char *msg, unsigned long symbol)
@@ -117,7 +112,7 @@ void show_trace(struct task_struct *tsk, unsigned long *sp,

	printk("\nCall trace:\n");

	dump_trace(tsk, regs, sp, &print_trace_ops, "");
	unwind_stack(tsk, regs, sp, &print_trace_ops, "");

	printk("\n");

+3 −2
Original line number Diff line number Diff line
@@ -13,6 +13,7 @@
#include <linux/stacktrace.h>
#include <linux/thread_info.h>
#include <linux/module.h>
#include <asm/unwinder.h>
#include <asm/ptrace.h>
#include <asm/stacktrace.h>

@@ -57,7 +58,7 @@ void save_stack_trace(struct stack_trace *trace)
{
	unsigned long *sp = (unsigned long *)current_stack_pointer;

	dump_trace(current, NULL, sp,  &save_stack_ops, trace);
	unwind_stack(current, NULL, sp,  &save_stack_ops, trace);
}
EXPORT_SYMBOL_GPL(save_stack_trace);

@@ -89,6 +90,6 @@ void save_stack_trace_tsk(struct task_struct *tsk, struct stack_trace *trace)
{
	unsigned long *sp = (unsigned long *)tsk->thread.sp;

	dump_trace(current, NULL, sp,  &save_stack_ops_nosched, trace);
	unwind_stack(current, NULL, sp,  &save_stack_ops_nosched, trace);
}
EXPORT_SYMBOL_GPL(save_stack_trace_tsk);
+3 −2
Original line number Diff line number Diff line
@@ -17,6 +17,7 @@
#include <linux/sched.h>
#include <linux/kallsyms.h>
#include <linux/mm.h>
#include <asm/unwinder.h>
#include <asm/ptrace.h>
#include <asm/uaccess.h>
#include <asm/sections.h>
@@ -120,7 +121,7 @@ void sh_backtrace(struct pt_regs * const regs, unsigned int depth)
	stackaddr = (unsigned long *)regs->regs[15];
	if (!user_mode(regs)) {
		if (depth)
			dump_trace(NULL, regs, stackaddr,
			unwind_stack(NULL, regs, stackaddr,
				     &backtrace_ops, &depth);
		return;
	}