xref: /aosp_15_r20/external/igt-gpu-tools/lib/igt_perf.c (revision d83cc019efdc2edc6c4b16e9034a3ceb8d35d77c)
1*d83cc019SAndroid Build Coastguard Worker #include <stdint.h>
2*d83cc019SAndroid Build Coastguard Worker #include <fcntl.h>
3*d83cc019SAndroid Build Coastguard Worker #include <unistd.h>
4*d83cc019SAndroid Build Coastguard Worker #include <stdlib.h>
5*d83cc019SAndroid Build Coastguard Worker #include <string.h>
6*d83cc019SAndroid Build Coastguard Worker #include <errno.h>
7*d83cc019SAndroid Build Coastguard Worker #include <sys/sysinfo.h>
8*d83cc019SAndroid Build Coastguard Worker 
9*d83cc019SAndroid Build Coastguard Worker #include "igt_perf.h"
10*d83cc019SAndroid Build Coastguard Worker 
i915_type_id(void)11*d83cc019SAndroid Build Coastguard Worker uint64_t i915_type_id(void)
12*d83cc019SAndroid Build Coastguard Worker {
13*d83cc019SAndroid Build Coastguard Worker 	char buf[64];
14*d83cc019SAndroid Build Coastguard Worker 	ssize_t ret;
15*d83cc019SAndroid Build Coastguard Worker 	int fd;
16*d83cc019SAndroid Build Coastguard Worker 
17*d83cc019SAndroid Build Coastguard Worker 	fd = open("/sys/bus/event_source/devices/i915/type", O_RDONLY);
18*d83cc019SAndroid Build Coastguard Worker 	if (fd < 0)
19*d83cc019SAndroid Build Coastguard Worker 		return 0;
20*d83cc019SAndroid Build Coastguard Worker 
21*d83cc019SAndroid Build Coastguard Worker 	ret = read(fd, buf, sizeof(buf) - 1);
22*d83cc019SAndroid Build Coastguard Worker 	close(fd);
23*d83cc019SAndroid Build Coastguard Worker 	if (ret < 1)
24*d83cc019SAndroid Build Coastguard Worker 		return 0;
25*d83cc019SAndroid Build Coastguard Worker 
26*d83cc019SAndroid Build Coastguard Worker 	buf[ret] = '\0';
27*d83cc019SAndroid Build Coastguard Worker 
28*d83cc019SAndroid Build Coastguard Worker 	return strtoull(buf, NULL, 0);
29*d83cc019SAndroid Build Coastguard Worker }
30*d83cc019SAndroid Build Coastguard Worker 
31*d83cc019SAndroid Build Coastguard Worker static int
_perf_open(uint64_t type,uint64_t config,int group,uint64_t format)32*d83cc019SAndroid Build Coastguard Worker _perf_open(uint64_t type, uint64_t config, int group, uint64_t format)
33*d83cc019SAndroid Build Coastguard Worker {
34*d83cc019SAndroid Build Coastguard Worker 	struct perf_event_attr attr = { };
35*d83cc019SAndroid Build Coastguard Worker 	int nr_cpus = get_nprocs_conf();
36*d83cc019SAndroid Build Coastguard Worker 	int cpu = 0, ret;
37*d83cc019SAndroid Build Coastguard Worker 
38*d83cc019SAndroid Build Coastguard Worker 	attr.type = type;
39*d83cc019SAndroid Build Coastguard Worker 	if (attr.type == 0)
40*d83cc019SAndroid Build Coastguard Worker 		return -ENOENT;
41*d83cc019SAndroid Build Coastguard Worker 
42*d83cc019SAndroid Build Coastguard Worker 	if (group >= 0)
43*d83cc019SAndroid Build Coastguard Worker 		format &= ~PERF_FORMAT_GROUP;
44*d83cc019SAndroid Build Coastguard Worker 
45*d83cc019SAndroid Build Coastguard Worker 	attr.read_format = format;
46*d83cc019SAndroid Build Coastguard Worker 	attr.config = config;
47*d83cc019SAndroid Build Coastguard Worker 
48*d83cc019SAndroid Build Coastguard Worker 	do {
49*d83cc019SAndroid Build Coastguard Worker 		ret = perf_event_open(&attr, -1, cpu++, group, 0);
50*d83cc019SAndroid Build Coastguard Worker 	} while ((ret < 0 && errno == EINVAL) && (cpu < nr_cpus));
51*d83cc019SAndroid Build Coastguard Worker 
52*d83cc019SAndroid Build Coastguard Worker 	return ret;
53*d83cc019SAndroid Build Coastguard Worker }
54*d83cc019SAndroid Build Coastguard Worker 
perf_i915_open(uint64_t config)55*d83cc019SAndroid Build Coastguard Worker int perf_i915_open(uint64_t config)
56*d83cc019SAndroid Build Coastguard Worker {
57*d83cc019SAndroid Build Coastguard Worker 	return _perf_open(i915_type_id(), config, -1,
58*d83cc019SAndroid Build Coastguard Worker 			  PERF_FORMAT_TOTAL_TIME_ENABLED);
59*d83cc019SAndroid Build Coastguard Worker }
60*d83cc019SAndroid Build Coastguard Worker 
perf_i915_open_group(uint64_t config,int group)61*d83cc019SAndroid Build Coastguard Worker int perf_i915_open_group(uint64_t config, int group)
62*d83cc019SAndroid Build Coastguard Worker {
63*d83cc019SAndroid Build Coastguard Worker 	return _perf_open(i915_type_id(), config, group,
64*d83cc019SAndroid Build Coastguard Worker 			  PERF_FORMAT_TOTAL_TIME_ENABLED | PERF_FORMAT_GROUP);
65*d83cc019SAndroid Build Coastguard Worker }
66*d83cc019SAndroid Build Coastguard Worker 
igt_perf_open(uint64_t type,uint64_t config)67*d83cc019SAndroid Build Coastguard Worker int igt_perf_open(uint64_t type, uint64_t config)
68*d83cc019SAndroid Build Coastguard Worker {
69*d83cc019SAndroid Build Coastguard Worker 	return _perf_open(type, config, -1,
70*d83cc019SAndroid Build Coastguard Worker 			  PERF_FORMAT_TOTAL_TIME_ENABLED);
71*d83cc019SAndroid Build Coastguard Worker }
72*d83cc019SAndroid Build Coastguard Worker 
igt_perf_open_group(uint64_t type,uint64_t config,int group)73*d83cc019SAndroid Build Coastguard Worker int igt_perf_open_group(uint64_t type, uint64_t config, int group)
74*d83cc019SAndroid Build Coastguard Worker {
75*d83cc019SAndroid Build Coastguard Worker 	return _perf_open(type, config, group,
76*d83cc019SAndroid Build Coastguard Worker 			  PERF_FORMAT_TOTAL_TIME_ENABLED | PERF_FORMAT_GROUP);
77*d83cc019SAndroid Build Coastguard Worker }
78