xref: /aosp_15_r20/external/mesa3d/src/panfrost/perf/quick.c (revision 6104692788411f58d303aa86923a9ff6ecaded22)
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