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 */
|