Linux 6.12-rc1
[linux-block.git] / tools / perf / tests / evsel-roundtrip-name.c
CommitLineData
b2441318 1// SPDX-License-Identifier: GPL-2.0
cfffae2e
JO
2#include "evlist.h"
3#include "evsel.h"
4#include "parse-events.h"
5#include "tests.h"
84f5d36f 6#include "debug.h"
877a7a11 7#include <linux/kernel.h>
cfffae2e
JO
8
9static int perf_evsel__roundtrip_cache_name_test(void)
10{
a8af6e48 11 int ret = TEST_OK;
cfffae2e 12
a8af6e48
IR
13 for (int type = 0; type < PERF_COUNT_HW_CACHE_MAX; type++) {
14 for (int op = 0; op < PERF_COUNT_HW_CACHE_OP_MAX; op++) {
cfffae2e 15 /* skip invalid cache type */
c754c382 16 if (!evsel__is_cache_op_valid(type, op))
cfffae2e
JO
17 continue;
18
a8af6e48
IR
19 for (int res = 0; res < PERF_COUNT_HW_CACHE_RESULT_MAX; res++) {
20 char name[128];
21 struct evlist *evlist = evlist__new();
22 struct evsel *evsel;
23 int err;
cfffae2e 24
a8af6e48
IR
25 if (evlist == NULL) {
26 pr_debug("Failed to alloc evlist");
27 return TEST_FAIL;
28 }
29 __evsel__hw_cache_type_op_res_name(type, op, res,
30 name, sizeof(name));
cfffae2e 31
a8af6e48
IR
32 err = parse_event(evlist, name);
33 if (err) {
34 pr_debug("Failure to parse cache event '%s' possibly as PMUs don't support it",
35 name);
36 evlist__delete(evlist);
cfffae2e 37 continue;
cfffae2e 38 }
a8af6e48 39 evlist__for_each_entry(evlist, evsel) {
09d2056e 40 if (!evsel__name_is(evsel, name)) {
a8af6e48
IR
41 pr_debug("%s != %s\n", evsel__name(evsel), name);
42 ret = TEST_FAIL;
43 }
44 }
45 evlist__delete(evlist);
cfffae2e
JO
46 }
47 }
48 }
cfffae2e
JO
49 return ret;
50}
51
a8af6e48 52static int perf_evsel__name_array_test(const char *const names[], int nr_names)
cfffae2e 53{
a8af6e48 54 int ret = TEST_OK;
cfffae2e 55
a8af6e48
IR
56 for (int i = 0; i < nr_names; ++i) {
57 struct evlist *evlist = evlist__new();
58 struct evsel *evsel;
59 int err;
cfffae2e 60
a8af6e48
IR
61 if (evlist == NULL) {
62 pr_debug("Failed to alloc evlist");
63 return TEST_FAIL;
64 }
806731a9 65 err = parse_event(evlist, names[i]);
cfffae2e
JO
66 if (err) {
67 pr_debug("failed to parse event '%s', err %d\n",
68 names[i], err);
a8af6e48
IR
69 evlist__delete(evlist);
70 ret = TEST_FAIL;
71 continue;
cfffae2e 72 }
a8af6e48 73 evlist__for_each_entry(evlist, evsel) {
09d2056e 74 if (!evsel__name_is(evsel, names[i])) {
a8af6e48
IR
75 pr_debug("%s != %s\n", evsel__name(evsel), names[i]);
76 ret = TEST_FAIL;
77 }
cfffae2e 78 }
a8af6e48 79 evlist__delete(evlist);
cfffae2e 80 }
a8af6e48 81 return ret;
cfffae2e
JO
82}
83
33f44bfd 84static int test__perf_evsel__roundtrip_name_test(struct test_suite *test __maybe_unused,
d68f0365 85 int subtest __maybe_unused)
cfffae2e 86{
a8af6e48 87 int err = 0, ret = TEST_OK;
afff9f31 88
a8af6e48 89 err = perf_evsel__name_array_test(evsel__hw_names, PERF_COUNT_HW_MAX);
cfffae2e
JO
90 if (err)
91 ret = err;
92
a8af6e48 93 err = perf_evsel__name_array_test(evsel__sw_names, PERF_COUNT_SW_DUMMY + 1);
cfffae2e
JO
94 if (err)
95 ret = err;
96
97 err = perf_evsel__roundtrip_cache_name_test();
98 if (err)
99 ret = err;
100
101 return ret;
102}
d68f0365
IR
103
104DEFINE_SUITE("Roundtrip evsel->name", perf_evsel__roundtrip_name_test);