18c2ecf20Sopenharmony_ci/* SPDX-License-Identifier: GPL-2.0 */
28c2ecf20Sopenharmony_ci#ifndef ARCH_PERF_REGS_H
38c2ecf20Sopenharmony_ci#define ARCH_PERF_REGS_H
48c2ecf20Sopenharmony_ci
58c2ecf20Sopenharmony_ci#include <stdlib.h>
68c2ecf20Sopenharmony_ci#include <linux/types.h>
78c2ecf20Sopenharmony_ci#include <asm/perf_regs.h>
88c2ecf20Sopenharmony_ci
98c2ecf20Sopenharmony_civoid perf_regs_load(u64 *regs);
108c2ecf20Sopenharmony_ci
118c2ecf20Sopenharmony_ci#define PERF_REGS_MAX PERF_REG_X86_XMM_MAX
128c2ecf20Sopenharmony_ci#ifndef HAVE_ARCH_X86_64_SUPPORT
138c2ecf20Sopenharmony_ci#define PERF_REGS_MASK ((1ULL << PERF_REG_X86_32_MAX) - 1)
148c2ecf20Sopenharmony_ci#define PERF_SAMPLE_REGS_ABI PERF_SAMPLE_REGS_ABI_32
158c2ecf20Sopenharmony_ci#else
168c2ecf20Sopenharmony_ci#define REG_NOSUPPORT ((1ULL << PERF_REG_X86_DS) | \
178c2ecf20Sopenharmony_ci		       (1ULL << PERF_REG_X86_ES) | \
188c2ecf20Sopenharmony_ci		       (1ULL << PERF_REG_X86_FS) | \
198c2ecf20Sopenharmony_ci		       (1ULL << PERF_REG_X86_GS))
208c2ecf20Sopenharmony_ci#define PERF_REGS_MASK (((1ULL << PERF_REG_X86_64_MAX) - 1) & ~REG_NOSUPPORT)
218c2ecf20Sopenharmony_ci#define PERF_SAMPLE_REGS_ABI PERF_SAMPLE_REGS_ABI_64
228c2ecf20Sopenharmony_ci#endif
238c2ecf20Sopenharmony_ci#define PERF_REG_IP PERF_REG_X86_IP
248c2ecf20Sopenharmony_ci#define PERF_REG_SP PERF_REG_X86_SP
258c2ecf20Sopenharmony_ci
268c2ecf20Sopenharmony_cistatic inline const char *__perf_reg_name(int id)
278c2ecf20Sopenharmony_ci{
288c2ecf20Sopenharmony_ci	switch (id) {
298c2ecf20Sopenharmony_ci	case PERF_REG_X86_AX:
308c2ecf20Sopenharmony_ci		return "AX";
318c2ecf20Sopenharmony_ci	case PERF_REG_X86_BX:
328c2ecf20Sopenharmony_ci		return "BX";
338c2ecf20Sopenharmony_ci	case PERF_REG_X86_CX:
348c2ecf20Sopenharmony_ci		return "CX";
358c2ecf20Sopenharmony_ci	case PERF_REG_X86_DX:
368c2ecf20Sopenharmony_ci		return "DX";
378c2ecf20Sopenharmony_ci	case PERF_REG_X86_SI:
388c2ecf20Sopenharmony_ci		return "SI";
398c2ecf20Sopenharmony_ci	case PERF_REG_X86_DI:
408c2ecf20Sopenharmony_ci		return "DI";
418c2ecf20Sopenharmony_ci	case PERF_REG_X86_BP:
428c2ecf20Sopenharmony_ci		return "BP";
438c2ecf20Sopenharmony_ci	case PERF_REG_X86_SP:
448c2ecf20Sopenharmony_ci		return "SP";
458c2ecf20Sopenharmony_ci	case PERF_REG_X86_IP:
468c2ecf20Sopenharmony_ci		return "IP";
478c2ecf20Sopenharmony_ci	case PERF_REG_X86_FLAGS:
488c2ecf20Sopenharmony_ci		return "FLAGS";
498c2ecf20Sopenharmony_ci	case PERF_REG_X86_CS:
508c2ecf20Sopenharmony_ci		return "CS";
518c2ecf20Sopenharmony_ci	case PERF_REG_X86_SS:
528c2ecf20Sopenharmony_ci		return "SS";
538c2ecf20Sopenharmony_ci	case PERF_REG_X86_DS:
548c2ecf20Sopenharmony_ci		return "DS";
558c2ecf20Sopenharmony_ci	case PERF_REG_X86_ES:
568c2ecf20Sopenharmony_ci		return "ES";
578c2ecf20Sopenharmony_ci	case PERF_REG_X86_FS:
588c2ecf20Sopenharmony_ci		return "FS";
598c2ecf20Sopenharmony_ci	case PERF_REG_X86_GS:
608c2ecf20Sopenharmony_ci		return "GS";
618c2ecf20Sopenharmony_ci#ifdef HAVE_ARCH_X86_64_SUPPORT
628c2ecf20Sopenharmony_ci	case PERF_REG_X86_R8:
638c2ecf20Sopenharmony_ci		return "R8";
648c2ecf20Sopenharmony_ci	case PERF_REG_X86_R9:
658c2ecf20Sopenharmony_ci		return "R9";
668c2ecf20Sopenharmony_ci	case PERF_REG_X86_R10:
678c2ecf20Sopenharmony_ci		return "R10";
688c2ecf20Sopenharmony_ci	case PERF_REG_X86_R11:
698c2ecf20Sopenharmony_ci		return "R11";
708c2ecf20Sopenharmony_ci	case PERF_REG_X86_R12:
718c2ecf20Sopenharmony_ci		return "R12";
728c2ecf20Sopenharmony_ci	case PERF_REG_X86_R13:
738c2ecf20Sopenharmony_ci		return "R13";
748c2ecf20Sopenharmony_ci	case PERF_REG_X86_R14:
758c2ecf20Sopenharmony_ci		return "R14";
768c2ecf20Sopenharmony_ci	case PERF_REG_X86_R15:
778c2ecf20Sopenharmony_ci		return "R15";
788c2ecf20Sopenharmony_ci#endif /* HAVE_ARCH_X86_64_SUPPORT */
798c2ecf20Sopenharmony_ci
808c2ecf20Sopenharmony_ci#define XMM(x) \
818c2ecf20Sopenharmony_ci	case PERF_REG_X86_XMM ## x:	\
828c2ecf20Sopenharmony_ci	case PERF_REG_X86_XMM ## x + 1:	\
838c2ecf20Sopenharmony_ci		return "XMM" #x;
848c2ecf20Sopenharmony_ci	XMM(0)
858c2ecf20Sopenharmony_ci	XMM(1)
868c2ecf20Sopenharmony_ci	XMM(2)
878c2ecf20Sopenharmony_ci	XMM(3)
888c2ecf20Sopenharmony_ci	XMM(4)
898c2ecf20Sopenharmony_ci	XMM(5)
908c2ecf20Sopenharmony_ci	XMM(6)
918c2ecf20Sopenharmony_ci	XMM(7)
928c2ecf20Sopenharmony_ci	XMM(8)
938c2ecf20Sopenharmony_ci	XMM(9)
948c2ecf20Sopenharmony_ci	XMM(10)
958c2ecf20Sopenharmony_ci	XMM(11)
968c2ecf20Sopenharmony_ci	XMM(12)
978c2ecf20Sopenharmony_ci	XMM(13)
988c2ecf20Sopenharmony_ci	XMM(14)
998c2ecf20Sopenharmony_ci	XMM(15)
1008c2ecf20Sopenharmony_ci#undef XMM
1018c2ecf20Sopenharmony_ci	default:
1028c2ecf20Sopenharmony_ci		return NULL;
1038c2ecf20Sopenharmony_ci	}
1048c2ecf20Sopenharmony_ci
1058c2ecf20Sopenharmony_ci	return NULL;
1068c2ecf20Sopenharmony_ci}
1078c2ecf20Sopenharmony_ci
1088c2ecf20Sopenharmony_ci#endif /* ARCH_PERF_REGS_H */
109