1*61046927SAndroid Build Coastguard Worker #include <xf86drm.h>
2*61046927SAndroid Build Coastguard Worker #include <stdio.h>
3*61046927SAndroid Build Coastguard Worker #include <lib/kmod/pan_kmod.h>
4*61046927SAndroid Build Coastguard Worker #include <lib/pan_props.h>
5*61046927SAndroid Build Coastguard Worker #include "pan_perf.h"
6*61046927SAndroid Build Coastguard Worker
7*61046927SAndroid Build Coastguard Worker int
main(void)8*61046927SAndroid Build Coastguard Worker main(void)
9*61046927SAndroid Build Coastguard Worker {
10*61046927SAndroid Build Coastguard Worker int fd = drmOpenWithType("panfrost", NULL, DRM_NODE_RENDER);
11*61046927SAndroid Build Coastguard Worker
12*61046927SAndroid Build Coastguard Worker if (fd < 0) {
13*61046927SAndroid Build Coastguard Worker fprintf(stderr, "No panfrost device\n");
14*61046927SAndroid Build Coastguard Worker exit(1);
15*61046927SAndroid Build Coastguard Worker }
16*61046927SAndroid Build Coastguard Worker
17*61046927SAndroid Build Coastguard Worker void *ctx = ralloc_context(NULL);
18*61046927SAndroid Build Coastguard Worker struct panfrost_perf *perf = rzalloc(ctx, struct panfrost_perf);
19*61046927SAndroid Build Coastguard Worker
20*61046927SAndroid Build Coastguard Worker panfrost_perf_init(perf, fd);
21*61046927SAndroid Build Coastguard Worker
22*61046927SAndroid Build Coastguard Worker int ret = panfrost_perf_enable(perf);
23*61046927SAndroid Build Coastguard Worker
24*61046927SAndroid Build Coastguard Worker if (ret < 0) {
25*61046927SAndroid Build Coastguard Worker fprintf(stderr, "failed to enable counters (%d)\n", ret);
26*61046927SAndroid Build Coastguard Worker fprintf(
27*61046927SAndroid Build Coastguard Worker stderr,
28*61046927SAndroid Build Coastguard Worker "try `# echo Y > /sys/module/panfrost/parameters/unstable_ioctls`\n");
29*61046927SAndroid Build Coastguard Worker
30*61046927SAndroid Build Coastguard Worker exit(1);
31*61046927SAndroid Build Coastguard Worker }
32*61046927SAndroid Build Coastguard Worker
33*61046927SAndroid Build Coastguard Worker sleep(1);
34*61046927SAndroid Build Coastguard Worker
35*61046927SAndroid Build Coastguard Worker panfrost_perf_dump(perf);
36*61046927SAndroid Build Coastguard Worker
37*61046927SAndroid Build Coastguard Worker for (unsigned i = 0; i < perf->cfg->n_categories; ++i) {
38*61046927SAndroid Build Coastguard Worker const struct panfrost_perf_category *cat = &perf->cfg->categories[i];
39*61046927SAndroid Build Coastguard Worker printf("%s\n", cat->name);
40*61046927SAndroid Build Coastguard Worker
41*61046927SAndroid Build Coastguard Worker for (unsigned j = 0; j < cat->n_counters; ++j) {
42*61046927SAndroid Build Coastguard Worker const struct panfrost_perf_counter *ctr = &cat->counters[j];
43*61046927SAndroid Build Coastguard Worker uint32_t val = panfrost_perf_counter_read(ctr, perf);
44*61046927SAndroid Build Coastguard Worker printf("%s (%s): %u\n", ctr->name, ctr->symbol_name, val);
45*61046927SAndroid Build Coastguard Worker }
46*61046927SAndroid Build Coastguard Worker
47*61046927SAndroid Build Coastguard Worker printf("\n");
48*61046927SAndroid Build Coastguard Worker }
49*61046927SAndroid Build Coastguard Worker
50*61046927SAndroid Build Coastguard Worker if (panfrost_perf_disable(perf) < 0) {
51*61046927SAndroid Build Coastguard Worker fprintf(stderr, "failed to disable counters\n");
52*61046927SAndroid Build Coastguard Worker exit(1);
53*61046927SAndroid Build Coastguard Worker }
54*61046927SAndroid Build Coastguard Worker
55*61046927SAndroid Build Coastguard Worker return 0;
56*61046927SAndroid Build Coastguard Worker }
57