| // SPDX-License-Identifier: GPL-2.0 |
| |
| #include "../perf_regs.h" |
| #include "../../arch/csky/include/uapi/asm/perf_regs.h" |
| |
| const char *__perf_reg_name_csky(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; |
| } |
| |
| uint64_t __perf_reg_ip_csky(void) |
| { |
| return PERF_REG_CSKY_PC; |
| } |
| |
| uint64_t __perf_reg_sp_csky(void) |
| { |
| return PERF_REG_CSKY_SP; |
| } |