blob: 7f6d538f8a8953e5a988730dfe7fff391c49f541 [file] [log] [blame]
Greg Kroah-Hartmanb2441312017-11-01 15:07:57 +01001/* SPDX-License-Identifier: GPL-2.0 */
Jiri Olsa2bcd3552012-08-07 15:20:43 +02002#ifndef ARCH_PERF_REGS_H
3#define ARCH_PERF_REGS_H
4
5#include <stdlib.h>
Borislav Petkovd944c4e2014-04-25 21:31:02 +02006#include <linux/types.h>
David Howellsd2709c72012-11-19 22:21:03 +00007#include <asm/perf_regs.h>
Jiri Olsa2bcd3552012-08-07 15:20:43 +02008
Jiri Olsa3c8b06f2014-01-07 13:47:21 +01009void perf_regs_load(u64 *regs);
10
Ingo Molnar89fe8082013-09-30 12:07:11 +020011#ifndef HAVE_ARCH_X86_64_SUPPORT
Jiri Olsa2bcd3552012-08-07 15:20:43 +020012#define PERF_REGS_MASK ((1ULL << PERF_REG_X86_32_MAX) - 1)
Jiri Olsaaa16b812014-01-07 13:47:22 +010013#define PERF_REGS_MAX PERF_REG_X86_32_MAX
14#define PERF_SAMPLE_REGS_ABI PERF_SAMPLE_REGS_ABI_32
Jiri Olsa2bcd3552012-08-07 15:20:43 +020015#else
16#define REG_NOSUPPORT ((1ULL << PERF_REG_X86_DS) | \
17 (1ULL << PERF_REG_X86_ES) | \
18 (1ULL << PERF_REG_X86_FS) | \
19 (1ULL << PERF_REG_X86_GS))
20#define PERF_REGS_MASK (((1ULL << PERF_REG_X86_64_MAX) - 1) & ~REG_NOSUPPORT)
Jiri Olsaaa16b812014-01-07 13:47:22 +010021#define PERF_REGS_MAX PERF_REG_X86_64_MAX
22#define PERF_SAMPLE_REGS_ABI PERF_SAMPLE_REGS_ABI_64
Jiri Olsa2bcd3552012-08-07 15:20:43 +020023#endif
24#define PERF_REG_IP PERF_REG_X86_IP
25#define PERF_REG_SP PERF_REG_X86_SP
26
27static inline const char *perf_reg_name(int id)
28{
29 switch (id) {
30 case PERF_REG_X86_AX:
31 return "AX";
32 case PERF_REG_X86_BX:
33 return "BX";
34 case PERF_REG_X86_CX:
35 return "CX";
36 case PERF_REG_X86_DX:
37 return "DX";
38 case PERF_REG_X86_SI:
39 return "SI";
40 case PERF_REG_X86_DI:
41 return "DI";
42 case PERF_REG_X86_BP:
43 return "BP";
44 case PERF_REG_X86_SP:
45 return "SP";
46 case PERF_REG_X86_IP:
47 return "IP";
48 case PERF_REG_X86_FLAGS:
49 return "FLAGS";
50 case PERF_REG_X86_CS:
51 return "CS";
52 case PERF_REG_X86_SS:
53 return "SS";
54 case PERF_REG_X86_DS:
55 return "DS";
56 case PERF_REG_X86_ES:
57 return "ES";
58 case PERF_REG_X86_FS:
59 return "FS";
60 case PERF_REG_X86_GS:
61 return "GS";
Ingo Molnar89fe8082013-09-30 12:07:11 +020062#ifdef HAVE_ARCH_X86_64_SUPPORT
Jiri Olsa2bcd3552012-08-07 15:20:43 +020063 case PERF_REG_X86_R8:
64 return "R8";
65 case PERF_REG_X86_R9:
66 return "R9";
67 case PERF_REG_X86_R10:
68 return "R10";
69 case PERF_REG_X86_R11:
70 return "R11";
71 case PERF_REG_X86_R12:
72 return "R12";
73 case PERF_REG_X86_R13:
74 return "R13";
75 case PERF_REG_X86_R14:
76 return "R14";
77 case PERF_REG_X86_R15:
78 return "R15";
Ingo Molnar89fe8082013-09-30 12:07:11 +020079#endif /* HAVE_ARCH_X86_64_SUPPORT */
Jiri Olsa2bcd3552012-08-07 15:20:43 +020080 default:
81 return NULL;
82 }
83
84 return NULL;
85}
86
87#endif /* ARCH_PERF_REGS_H */