mirror of
https://mirrors.bfsu.edu.cn/git/linux.git
synced 2025-01-25 23:34:47 +08:00
3213486f2e
This patch add support for DWARF register mappings and libdw registers initialization, which is used by perf callchain analyzing, eg: perf record --call-graph=dwarf <COMMAND> Here is elfutils csky backend patch set: https://sourceware.org/ml/elfutils-devel/2019-q2/msg00007.html Signed-off-by: Mao Han <han_mao@c-sky.com> Signed-off-by: Guo Ren <ren_guo@c-sky.com> Cc: Peter Zijlstra <peterz@infradead.org> Cc: Ingo Molnar <mingo@redhat.com> Cc: Arnaldo Carvalho de Melo <acme@kernel.org> Cc: Alexander Shishkin <alexander.shishkin@linux.intel.com> Cc: Jiri Olsa <jolsa@redhat.com> Cc: Namhyung Kim <namhyung@kernel.org> Cc: Arnd Bergmann <arnd@arnd.de>
101 lines
2.2 KiB
C
101 lines
2.2 KiB
C
/* SPDX-License-Identifier: GPL-2.0 */
|
|
// Copyright (C) 2019 Hangzhou C-SKY Microsystems co.,ltd.
|
|
|
|
#ifndef ARCH_PERF_REGS_H
|
|
#define ARCH_PERF_REGS_H
|
|
|
|
#include <stdlib.h>
|
|
#include <linux/types.h>
|
|
#include <asm/perf_regs.h>
|
|
|
|
#define PERF_REGS_MASK ((1ULL << PERF_REG_CSKY_MAX) - 1)
|
|
#define PERF_REGS_MAX PERF_REG_CSKY_MAX
|
|
#define PERF_SAMPLE_REGS_ABI PERF_SAMPLE_REGS_ABI_32
|
|
|
|
#define PERF_REG_IP PERF_REG_CSKY_PC
|
|
#define PERF_REG_SP PERF_REG_CSKY_SP
|
|
|
|
static inline const char *perf_reg_name(int id)
|
|
{
|
|
switch (id) {
|
|
case PERF_REG_CSKY_A0:
|
|
return "a0";
|
|
case PERF_REG_CSKY_A1:
|
|
return "a1";
|
|
case PERF_REG_CSKY_A2:
|
|
return "a2";
|
|
case PERF_REG_CSKY_A3:
|
|
return "a3";
|
|
case PERF_REG_CSKY_REGS0:
|
|
return "regs0";
|
|
case PERF_REG_CSKY_REGS1:
|
|
return "regs1";
|
|
case PERF_REG_CSKY_REGS2:
|
|
return "regs2";
|
|
case PERF_REG_CSKY_REGS3:
|
|
return "regs3";
|
|
case PERF_REG_CSKY_REGS4:
|
|
return "regs4";
|
|
case PERF_REG_CSKY_REGS5:
|
|
return "regs5";
|
|
case PERF_REG_CSKY_REGS6:
|
|
return "regs6";
|
|
case PERF_REG_CSKY_REGS7:
|
|
return "regs7";
|
|
case PERF_REG_CSKY_REGS8:
|
|
return "regs8";
|
|
case PERF_REG_CSKY_REGS9:
|
|
return "regs9";
|
|
case PERF_REG_CSKY_SP:
|
|
return "sp";
|
|
case PERF_REG_CSKY_LR:
|
|
return "lr";
|
|
case PERF_REG_CSKY_PC:
|
|
return "pc";
|
|
#if defined(__CSKYABIV2__)
|
|
case PERF_REG_CSKY_EXREGS0:
|
|
return "exregs0";
|
|
case PERF_REG_CSKY_EXREGS1:
|
|
return "exregs1";
|
|
case PERF_REG_CSKY_EXREGS2:
|
|
return "exregs2";
|
|
case PERF_REG_CSKY_EXREGS3:
|
|
return "exregs3";
|
|
case PERF_REG_CSKY_EXREGS4:
|
|
return "exregs4";
|
|
case PERF_REG_CSKY_EXREGS5:
|
|
return "exregs5";
|
|
case PERF_REG_CSKY_EXREGS6:
|
|
return "exregs6";
|
|
case PERF_REG_CSKY_EXREGS7:
|
|
return "exregs7";
|
|
case PERF_REG_CSKY_EXREGS8:
|
|
return "exregs8";
|
|
case PERF_REG_CSKY_EXREGS9:
|
|
return "exregs9";
|
|
case PERF_REG_CSKY_EXREGS10:
|
|
return "exregs10";
|
|
case PERF_REG_CSKY_EXREGS11:
|
|
return "exregs11";
|
|
case PERF_REG_CSKY_EXREGS12:
|
|
return "exregs12";
|
|
case PERF_REG_CSKY_EXREGS13:
|
|
return "exregs13";
|
|
case PERF_REG_CSKY_EXREGS14:
|
|
return "exregs14";
|
|
case PERF_REG_CSKY_TLS:
|
|
return "tls";
|
|
case PERF_REG_CSKY_HI:
|
|
return "hi";
|
|
case PERF_REG_CSKY_LO:
|
|
return "lo";
|
|
#endif
|
|
default:
|
|
return NULL;
|
|
}
|
|
|
|
return NULL;
|
|
}
|
|
|
|
#endif /* ARCH_PERF_REGS_H */
|