xref: /openbmc/linux/tools/perf/tests/mem.c (revision 03ab8e6297acd1bc0eedaa050e2a1635c576fd11)
15875cf4cSArnaldo Carvalho de Melo // SPDX-License-Identifier: GPL-2.0
2d3300a3cSArnaldo Carvalho de Melo #include "util/map_symbol.h"
33067eaa7SAndi Kleen #include "util/mem-events.h"
43067eaa7SAndi Kleen #include "util/symbol.h"
53067eaa7SAndi Kleen #include "linux/perf_event.h"
63067eaa7SAndi Kleen #include "util/debug.h"
73067eaa7SAndi Kleen #include "tests.h"
83067eaa7SAndi Kleen #include <string.h>
93067eaa7SAndi Kleen 
check(union perf_mem_data_src data_src,const char * string)103067eaa7SAndi Kleen static int check(union perf_mem_data_src data_src,
113067eaa7SAndi Kleen 		  const char *string)
123067eaa7SAndi Kleen {
133067eaa7SAndi Kleen 	char out[100];
143067eaa7SAndi Kleen 	char failure[100];
153067eaa7SAndi Kleen 	struct mem_info mi = { .data_src = data_src };
163067eaa7SAndi Kleen 
173067eaa7SAndi Kleen 	int n;
183067eaa7SAndi Kleen 
193067eaa7SAndi Kleen 	n = perf_mem__snp_scnprintf(out, sizeof out, &mi);
203067eaa7SAndi Kleen 	n += perf_mem__lvl_scnprintf(out + n, sizeof out - n, &mi);
2177f18153SJiri Olsa 	scnprintf(failure, sizeof failure, "unexpected %s", out);
223067eaa7SAndi Kleen 	TEST_ASSERT_VAL(failure, !strcmp(string, out));
233067eaa7SAndi Kleen 	return 0;
243067eaa7SAndi Kleen }
253067eaa7SAndi Kleen 
test__mem(struct test_suite * text __maybe_unused,int subtest __maybe_unused)26*33f44bfdSIan Rogers static int test__mem(struct test_suite *text __maybe_unused, int subtest __maybe_unused)
273067eaa7SAndi Kleen {
283067eaa7SAndi Kleen 	int ret = 0;
293067eaa7SAndi Kleen 	union perf_mem_data_src src;
303067eaa7SAndi Kleen 
313067eaa7SAndi Kleen 	memset(&src, 0, sizeof(src));
323067eaa7SAndi Kleen 
333067eaa7SAndi Kleen 	src.mem_lvl = PERF_MEM_LVL_HIT;
343067eaa7SAndi Kleen 	src.mem_lvl_num = 4;
353067eaa7SAndi Kleen 
363067eaa7SAndi Kleen 	ret |= check(src, "N/AL4 hit");
373067eaa7SAndi Kleen 
383067eaa7SAndi Kleen 	src.mem_remote = 1;
393067eaa7SAndi Kleen 
403067eaa7SAndi Kleen 	ret |= check(src, "N/ARemote L4 hit");
413067eaa7SAndi Kleen 
423067eaa7SAndi Kleen 	src.mem_lvl = PERF_MEM_LVL_MISS;
433067eaa7SAndi Kleen 	src.mem_lvl_num = PERF_MEM_LVLNUM_PMEM;
443067eaa7SAndi Kleen 	src.mem_remote = 0;
453067eaa7SAndi Kleen 
463067eaa7SAndi Kleen 	ret |= check(src, "N/APMEM miss");
473067eaa7SAndi Kleen 
483067eaa7SAndi Kleen 	src.mem_remote = 1;
493067eaa7SAndi Kleen 
503067eaa7SAndi Kleen 	ret |= check(src, "N/ARemote PMEM miss");
513067eaa7SAndi Kleen 
523067eaa7SAndi Kleen 	src.mem_snoopx = PERF_MEM_SNOOPX_FWD;
533067eaa7SAndi Kleen 	src.mem_lvl_num = PERF_MEM_LVLNUM_RAM;
543067eaa7SAndi Kleen 
553067eaa7SAndi Kleen 	ret |= check(src , "FwdRemote RAM miss");
563067eaa7SAndi Kleen 
573067eaa7SAndi Kleen 	return ret;
583067eaa7SAndi Kleen }
59d68f0365SIan Rogers 
60d68f0365SIan Rogers DEFINE_SUITE("Test data source output", mem);
61