1 /* SPDX-License-Identifier: GPL-2.0 */
2 #ifndef _PERF_SYS_H
3 #define _PERF_SYS_H
4 
5 #include <unistd.h>
6 #include <sys/types.h>
7 #include <sys/syscall.h>
8 #include <linux/types.h>
9 #include <linux/compiler.h>
10 #include <linux/perf_event.h>
11 #include <asm/barrier.h>
12 
13 #ifdef __powerpc__
14 #define CPUINFO_PROC	{"cpu"}
15 #endif
16 
17 #ifdef __s390__
18 #define CPUINFO_PROC	{"vendor_id"}
19 #endif
20 
21 #ifdef __sh__
22 #define CPUINFO_PROC	{"cpu type"}
23 #endif
24 
25 #ifdef __hppa__
26 #define CPUINFO_PROC	{"cpu"}
27 #endif
28 
29 #ifdef __sparc__
30 #define CPUINFO_PROC	{"cpu"}
31 #endif
32 
33 #ifdef __alpha__
34 #define CPUINFO_PROC	{"cpu model"}
35 #endif
36 
37 #ifdef __arm__
38 #define CPUINFO_PROC	{"model name", "Processor"}
39 #endif
40 
41 #ifdef __mips__
42 #define CPUINFO_PROC	{"cpu model"}
43 #endif
44 
45 #ifdef __arc__
46 #define CPUINFO_PROC	{"Processor"}
47 #endif
48 
49 #ifdef __xtensa__
50 #define CPUINFO_PROC	{"core ID"}
51 #endif
52 
53 #ifndef CPUINFO_PROC
54 #define CPUINFO_PROC	{ "model name", }
55 #endif
56 
57 static inline int
sys_perf_event_open(struct perf_event_attr * attr,pid_t pid,int cpu,int group_fd,unsigned long flags)58 sys_perf_event_open(struct perf_event_attr *attr,
59 		      pid_t pid, int cpu, int group_fd,
60 		      unsigned long flags)
61 {
62 	int fd;
63 
64 	fd = syscall(__NR_perf_event_open, attr, pid, cpu,
65 		     group_fd, flags);
66 
67 #ifdef HAVE_ATTR_TEST
68 	if (unlikely(test_attr__enabled))
69 		test_attr__open(attr, pid, cpu, fd, group_fd, flags);
70 #endif
71 	return fd;
72 }
73 
74 #endif /* _PERF_SYS_H */
75