xref: /openbmc/linux/tools/perf/tests/cpumap.c (revision c56c39276baa39ec3de40d618fd0e51ce34f850d)
1b2441318SGreg Kroah-Hartman // SPDX-License-Identifier: GPL-2.0
26c872901SJiri Olsa #include "tests.h"
33ac55b1dSArnaldo Carvalho de Melo #include <stdio.h>
46c872901SJiri Olsa #include "cpumap.h"
53ac55b1dSArnaldo Carvalho de Melo #include "event.h"
6ea49e01cSArnaldo Carvalho de Melo #include "util/synthetic-events.h"
73ac55b1dSArnaldo Carvalho de Melo #include <string.h>
83ac55b1dSArnaldo Carvalho de Melo #include <linux/bitops.h>
99c3516d1SJiri Olsa #include <perf/cpumap.h>
103ac55b1dSArnaldo Carvalho de Melo #include "debug.h"
113ac55b1dSArnaldo Carvalho de Melo 
123ac55b1dSArnaldo Carvalho de Melo struct machine;
136c872901SJiri Olsa 
146c872901SJiri Olsa static int process_event_mask(struct perf_tool *tool __maybe_unused,
156c872901SJiri Olsa 			 union perf_event *event,
166c872901SJiri Olsa 			 struct perf_sample *sample __maybe_unused,
176c872901SJiri Olsa 			 struct machine *machine __maybe_unused)
186c872901SJiri Olsa {
1972932371SJiri Olsa 	struct perf_record_cpu_map *map_event = &event->cpu_map;
2072932371SJiri Olsa 	struct perf_record_record_cpu_map *mask;
2172932371SJiri Olsa 	struct perf_record_cpu_map_data *data;
22f854839bSJiri Olsa 	struct perf_cpu_map *map;
236c872901SJiri Olsa 	int i;
246c872901SJiri Olsa 
25f77b57adSJiri Olsa 	data = &map_event->data;
266c872901SJiri Olsa 
276c872901SJiri Olsa 	TEST_ASSERT_VAL("wrong type", data->type == PERF_CPU_MAP__MASK);
286c872901SJiri Olsa 
2972932371SJiri Olsa 	mask = (struct perf_record_record_cpu_map *)data->data;
306c872901SJiri Olsa 
316c872901SJiri Olsa 	TEST_ASSERT_VAL("wrong nr",   mask->nr == 1);
326c872901SJiri Olsa 
336c872901SJiri Olsa 	for (i = 0; i < 20; i++) {
346c872901SJiri Olsa 		TEST_ASSERT_VAL("wrong cpu", test_bit(i, mask->mask));
356c872901SJiri Olsa 	}
366c872901SJiri Olsa 
37f77b57adSJiri Olsa 	map = cpu_map__new_data(data);
38*c56c3927SIan Rogers 	TEST_ASSERT_VAL("wrong nr",  perf_cpu_map__nr(map) == 20);
39f77b57adSJiri Olsa 
40f77b57adSJiri Olsa 	for (i = 0; i < 20; i++) {
41*c56c3927SIan Rogers 		TEST_ASSERT_VAL("wrong cpu", perf_cpu_map__cpu(map, i).cpu == i);
42f77b57adSJiri Olsa 	}
43f77b57adSJiri Olsa 
4438f01d8dSJiri Olsa 	perf_cpu_map__put(map);
456c872901SJiri Olsa 	return 0;
466c872901SJiri Olsa }
476c872901SJiri Olsa 
486c872901SJiri Olsa static int process_event_cpus(struct perf_tool *tool __maybe_unused,
496c872901SJiri Olsa 			 union perf_event *event,
506c872901SJiri Olsa 			 struct perf_sample *sample __maybe_unused,
516c872901SJiri Olsa 			 struct machine *machine __maybe_unused)
526c872901SJiri Olsa {
5372932371SJiri Olsa 	struct perf_record_cpu_map *map_event = &event->cpu_map;
546c872901SJiri Olsa 	struct cpu_map_entries *cpus;
5572932371SJiri Olsa 	struct perf_record_cpu_map_data *data;
56f854839bSJiri Olsa 	struct perf_cpu_map *map;
576c872901SJiri Olsa 
58f77b57adSJiri Olsa 	data = &map_event->data;
596c872901SJiri Olsa 
606c872901SJiri Olsa 	TEST_ASSERT_VAL("wrong type", data->type == PERF_CPU_MAP__CPUS);
616c872901SJiri Olsa 
626c872901SJiri Olsa 	cpus = (struct cpu_map_entries *)data->data;
636c872901SJiri Olsa 
646c872901SJiri Olsa 	TEST_ASSERT_VAL("wrong nr",   cpus->nr == 2);
656c872901SJiri Olsa 	TEST_ASSERT_VAL("wrong cpu",  cpus->cpu[0] == 1);
666c872901SJiri Olsa 	TEST_ASSERT_VAL("wrong cpu",  cpus->cpu[1] == 256);
67f77b57adSJiri Olsa 
68f77b57adSJiri Olsa 	map = cpu_map__new_data(data);
69*c56c3927SIan Rogers 	TEST_ASSERT_VAL("wrong nr",  perf_cpu_map__nr(map) == 2);
70*c56c3927SIan Rogers 	TEST_ASSERT_VAL("wrong cpu", perf_cpu_map__cpu(map, 0).cpu == 1);
71*c56c3927SIan Rogers 	TEST_ASSERT_VAL("wrong cpu", perf_cpu_map__cpu(map, 1).cpu == 256);
72ec09a42aSElena Reshetova 	TEST_ASSERT_VAL("wrong refcnt", refcount_read(&map->refcnt) == 1);
7338f01d8dSJiri Olsa 	perf_cpu_map__put(map);
746c872901SJiri Olsa 	return 0;
756c872901SJiri Olsa }
766c872901SJiri Olsa 
776c872901SJiri Olsa 
7833f44bfdSIan Rogers static int test__cpu_map_synthesize(struct test_suite *test __maybe_unused, int subtest __maybe_unused)
796c872901SJiri Olsa {
80f854839bSJiri Olsa 	struct perf_cpu_map *cpus;
816c872901SJiri Olsa 
826c872901SJiri Olsa 	/* This one is better stores in mask. */
839c3516d1SJiri Olsa 	cpus = perf_cpu_map__new("0,1,2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18,19");
846c872901SJiri Olsa 
856c872901SJiri Olsa 	TEST_ASSERT_VAL("failed to synthesize map",
866c872901SJiri Olsa 		!perf_event__synthesize_cpu_map(NULL, cpus, process_event_mask, NULL));
876c872901SJiri Olsa 
8838f01d8dSJiri Olsa 	perf_cpu_map__put(cpus);
896c872901SJiri Olsa 
906c872901SJiri Olsa 	/* This one is better stores in cpu values. */
919c3516d1SJiri Olsa 	cpus = perf_cpu_map__new("1,256");
926c872901SJiri Olsa 
936c872901SJiri Olsa 	TEST_ASSERT_VAL("failed to synthesize map",
946c872901SJiri Olsa 		!perf_event__synthesize_cpu_map(NULL, cpus, process_event_cpus, NULL));
956c872901SJiri Olsa 
9638f01d8dSJiri Olsa 	perf_cpu_map__put(cpus);
976c872901SJiri Olsa 	return 0;
986c872901SJiri Olsa }
99a24020e6SJiri Olsa 
100a24020e6SJiri Olsa static int cpu_map_print(const char *str)
101a24020e6SJiri Olsa {
1029c3516d1SJiri Olsa 	struct perf_cpu_map *map = perf_cpu_map__new(str);
103a24020e6SJiri Olsa 	char buf[100];
104a24020e6SJiri Olsa 
105a24020e6SJiri Olsa 	if (!map)
106a24020e6SJiri Olsa 		return -1;
107a24020e6SJiri Olsa 
108a24020e6SJiri Olsa 	cpu_map__snprint(map, buf, sizeof(buf));
109690d91f5SNamhyung Kim 	perf_cpu_map__put(map);
110690d91f5SNamhyung Kim 
111a24020e6SJiri Olsa 	return !strcmp(buf, str);
112a24020e6SJiri Olsa }
113a24020e6SJiri Olsa 
11433f44bfdSIan Rogers static int test__cpu_map_print(struct test_suite *test __maybe_unused, int subtest __maybe_unused)
115a24020e6SJiri Olsa {
116a24020e6SJiri Olsa 	TEST_ASSERT_VAL("failed to convert map", cpu_map_print("1"));
117a24020e6SJiri Olsa 	TEST_ASSERT_VAL("failed to convert map", cpu_map_print("1,5"));
118a24020e6SJiri Olsa 	TEST_ASSERT_VAL("failed to convert map", cpu_map_print("1,3,5,7,9,11,13,15,17,19,21-40"));
119a24020e6SJiri Olsa 	TEST_ASSERT_VAL("failed to convert map", cpu_map_print("2-5"));
120a24020e6SJiri Olsa 	TEST_ASSERT_VAL("failed to convert map", cpu_map_print("1,3-6,8-10,24,35-37"));
121a24020e6SJiri Olsa 	TEST_ASSERT_VAL("failed to convert map", cpu_map_print("1,3-6,8-10,24,35-37"));
122a24020e6SJiri Olsa 	TEST_ASSERT_VAL("failed to convert map", cpu_map_print("1-10,12-20,22-30,32-40"));
123a24020e6SJiri Olsa 	return 0;
124a24020e6SJiri Olsa }
125a2408a70SAndi Kleen 
12633f44bfdSIan Rogers static int test__cpu_map_merge(struct test_suite *test __maybe_unused, int subtest __maybe_unused)
127a2408a70SAndi Kleen {
128a2408a70SAndi Kleen 	struct perf_cpu_map *a = perf_cpu_map__new("4,2,1");
129a2408a70SAndi Kleen 	struct perf_cpu_map *b = perf_cpu_map__new("4,5,7");
130a2408a70SAndi Kleen 	struct perf_cpu_map *c = perf_cpu_map__merge(a, b);
131a2408a70SAndi Kleen 	char buf[100];
132a2408a70SAndi Kleen 
133*c56c3927SIan Rogers 	TEST_ASSERT_VAL("failed to merge map: bad nr", perf_cpu_map__nr(c) == 5);
134a2408a70SAndi Kleen 	cpu_map__snprint(c, buf, sizeof(buf));
135a2408a70SAndi Kleen 	TEST_ASSERT_VAL("failed to merge map: bad result", !strcmp(buf, "1-2,4-5,7"));
136a2408a70SAndi Kleen 	perf_cpu_map__put(b);
137a2408a70SAndi Kleen 	perf_cpu_map__put(c);
138a2408a70SAndi Kleen 	return 0;
139a2408a70SAndi Kleen }
140d68f0365SIan Rogers 
141d68f0365SIan Rogers DEFINE_SUITE("Synthesize cpu map", cpu_map_synthesize);
142d68f0365SIan Rogers DEFINE_SUITE("Print cpu map", cpu_map_print);
143d68f0365SIan Rogers DEFINE_SUITE("Merge cpu map", cpu_map_merge);
144