1*5933f6d2SKuninori Morimoto // SPDX-License-Identifier: GPL-2.0
2830fafecSPaul Mundt /*
3830fafecSPaul Mundt * Performance event callchain support - SuperH architecture code
4830fafecSPaul Mundt *
5830fafecSPaul Mundt * Copyright (C) 2009 Paul Mundt
6830fafecSPaul Mundt */
7830fafecSPaul Mundt #include <linux/kernel.h>
8830fafecSPaul Mundt #include <linux/sched.h>
9830fafecSPaul Mundt #include <linux/perf_event.h>
10830fafecSPaul Mundt #include <linux/percpu.h>
11830fafecSPaul Mundt #include <asm/unwinder.h>
12830fafecSPaul Mundt #include <asm/ptrace.h>
13830fafecSPaul Mundt
callchain_address(void * data,unsigned long addr,int reliable)14830fafecSPaul Mundt static void callchain_address(void *data, unsigned long addr, int reliable)
15830fafecSPaul Mundt {
16cfbcf468SArnaldo Carvalho de Melo struct perf_callchain_entry_ctx *entry = data;
17830fafecSPaul Mundt
18830fafecSPaul Mundt if (reliable)
1970791ce9SFrederic Weisbecker perf_callchain_store(entry, addr);
20830fafecSPaul Mundt }
21830fafecSPaul Mundt
22830fafecSPaul Mundt static const struct stacktrace_ops callchain_ops = {
23830fafecSPaul Mundt .address = callchain_address,
24830fafecSPaul Mundt };
25830fafecSPaul Mundt
2656962b44SFrederic Weisbecker void
perf_callchain_kernel(struct perf_callchain_entry_ctx * entry,struct pt_regs * regs)27cfbcf468SArnaldo Carvalho de Melo perf_callchain_kernel(struct perf_callchain_entry_ctx *entry, struct pt_regs *regs)
28830fafecSPaul Mundt {
2970791ce9SFrederic Weisbecker perf_callchain_store(entry, regs->pc);
30830fafecSPaul Mundt
31830fafecSPaul Mundt unwind_stack(NULL, regs, NULL, &callchain_ops, entry);
32830fafecSPaul Mundt }
33