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