xref: /openbmc/linux/tools/perf/tests/stat.c (revision 72932371e78012cea96edb9e833d81f1c32dd892)
1b2441318SGreg Kroah-Hartman // SPDX-License-Identifier: GPL-2.0
267424342SJiri Olsa #include <linux/compiler.h>
367424342SJiri Olsa #include "event.h"
467424342SJiri Olsa #include "tests.h"
567424342SJiri Olsa #include "stat.h"
65796f8f0SJiri Olsa #include "counts.h"
767424342SJiri Olsa #include "debug.h"
867424342SJiri Olsa 
9*72932371SJiri Olsa static bool has_term(struct perf_record_stat_config *config,
1067424342SJiri Olsa 		     u64 tag, u64 val)
1167424342SJiri Olsa {
1267424342SJiri Olsa 	unsigned i;
1367424342SJiri Olsa 
1467424342SJiri Olsa 	for (i = 0; i < config->nr; i++) {
1567424342SJiri Olsa 		if ((config->data[i].tag == tag) &&
1667424342SJiri Olsa 		    (config->data[i].val == val))
1767424342SJiri Olsa 			return true;
1867424342SJiri Olsa 	}
1967424342SJiri Olsa 
2067424342SJiri Olsa 	return false;
2167424342SJiri Olsa }
2267424342SJiri Olsa 
235796f8f0SJiri Olsa static int process_stat_config_event(struct perf_tool *tool __maybe_unused,
2467424342SJiri Olsa 				     union perf_event *event,
2567424342SJiri Olsa 				     struct perf_sample *sample __maybe_unused,
2667424342SJiri Olsa 				     struct machine *machine __maybe_unused)
2767424342SJiri Olsa {
28*72932371SJiri Olsa 	struct perf_record_stat_config *config = &event->stat_config;
298e381596SJiri Olsa 	struct perf_stat_config stat_config;
3067424342SJiri Olsa 
3167424342SJiri Olsa #define HAS(term, val) \
3267424342SJiri Olsa 	has_term(config, PERF_STAT_CONFIG_TERM__##term, val)
3367424342SJiri Olsa 
3467424342SJiri Olsa 	TEST_ASSERT_VAL("wrong nr",        config->nr == PERF_STAT_CONFIG_TERM__MAX);
3567424342SJiri Olsa 	TEST_ASSERT_VAL("wrong aggr_mode", HAS(AGGR_MODE, AGGR_CORE));
3667424342SJiri Olsa 	TEST_ASSERT_VAL("wrong scale",     HAS(SCALE, 1));
3767424342SJiri Olsa 	TEST_ASSERT_VAL("wrong interval",  HAS(INTERVAL, 1));
3867424342SJiri Olsa 
3967424342SJiri Olsa #undef HAS
4067424342SJiri Olsa 
418e381596SJiri Olsa 	perf_event__read_stat_config(&stat_config, config);
428e381596SJiri Olsa 
438e381596SJiri Olsa 	TEST_ASSERT_VAL("wrong aggr_mode", stat_config.aggr_mode == AGGR_CORE);
448e381596SJiri Olsa 	TEST_ASSERT_VAL("wrong scale",     stat_config.scale == 1);
458e381596SJiri Olsa 	TEST_ASSERT_VAL("wrong interval",  stat_config.interval == 1);
4667424342SJiri Olsa 	return 0;
4767424342SJiri Olsa }
4867424342SJiri Olsa 
4981f17c90SArnaldo Carvalho de Melo int test__synthesize_stat_config(struct test *test __maybe_unused, int subtest __maybe_unused)
5067424342SJiri Olsa {
5167424342SJiri Olsa 	struct perf_stat_config stat_config = {
5267424342SJiri Olsa 		.aggr_mode	= AGGR_CORE,
5367424342SJiri Olsa 		.scale		= 1,
5467424342SJiri Olsa 		.interval	= 1,
5567424342SJiri Olsa 	};
5667424342SJiri Olsa 
5767424342SJiri Olsa 	TEST_ASSERT_VAL("failed to synthesize stat_config",
585796f8f0SJiri Olsa 		!perf_event__synthesize_stat_config(NULL, &stat_config, process_stat_config_event, NULL));
595796f8f0SJiri Olsa 
605796f8f0SJiri Olsa 	return 0;
615796f8f0SJiri Olsa }
625796f8f0SJiri Olsa 
635796f8f0SJiri Olsa static int process_stat_event(struct perf_tool *tool __maybe_unused,
645796f8f0SJiri Olsa 			      union perf_event *event,
655796f8f0SJiri Olsa 			      struct perf_sample *sample __maybe_unused,
665796f8f0SJiri Olsa 			      struct machine *machine __maybe_unused)
675796f8f0SJiri Olsa {
68*72932371SJiri Olsa 	struct perf_record_stat *st = &event->stat;
695796f8f0SJiri Olsa 
705796f8f0SJiri Olsa 	TEST_ASSERT_VAL("wrong cpu",    st->cpu    == 1);
715796f8f0SJiri Olsa 	TEST_ASSERT_VAL("wrong thread", st->thread == 2);
725796f8f0SJiri Olsa 	TEST_ASSERT_VAL("wrong id",     st->id     == 3);
735796f8f0SJiri Olsa 	TEST_ASSERT_VAL("wrong val",    st->val    == 100);
745796f8f0SJiri Olsa 	TEST_ASSERT_VAL("wrong run",    st->ena    == 200);
755796f8f0SJiri Olsa 	TEST_ASSERT_VAL("wrong ena",    st->run    == 300);
765796f8f0SJiri Olsa 	return 0;
775796f8f0SJiri Olsa }
785796f8f0SJiri Olsa 
7981f17c90SArnaldo Carvalho de Melo int test__synthesize_stat(struct test *test __maybe_unused, int subtest __maybe_unused)
805796f8f0SJiri Olsa {
815796f8f0SJiri Olsa 	struct perf_counts_values count;
825796f8f0SJiri Olsa 
835796f8f0SJiri Olsa 	count.val = 100;
845796f8f0SJiri Olsa 	count.ena = 200;
855796f8f0SJiri Olsa 	count.run = 300;
865796f8f0SJiri Olsa 
875796f8f0SJiri Olsa 	TEST_ASSERT_VAL("failed to synthesize stat_config",
885796f8f0SJiri Olsa 		!perf_event__synthesize_stat(NULL, 1, 2, 3, &count, process_stat_event, NULL));
8967424342SJiri Olsa 
9067424342SJiri Olsa 	return 0;
9167424342SJiri Olsa }
92d4c22591SJiri Olsa 
93d4c22591SJiri Olsa static int process_stat_round_event(struct perf_tool *tool __maybe_unused,
94d4c22591SJiri Olsa 				    union perf_event *event,
95d4c22591SJiri Olsa 				    struct perf_sample *sample __maybe_unused,
96d4c22591SJiri Olsa 				    struct machine *machine __maybe_unused)
97d4c22591SJiri Olsa {
98*72932371SJiri Olsa 	struct perf_record_stat_round *stat_round = &event->stat_round;
99d4c22591SJiri Olsa 
100d4c22591SJiri Olsa 	TEST_ASSERT_VAL("wrong time", stat_round->time == 0xdeadbeef);
101d4c22591SJiri Olsa 	TEST_ASSERT_VAL("wrong type", stat_round->type == PERF_STAT_ROUND_TYPE__INTERVAL);
102d4c22591SJiri Olsa 	return 0;
103d4c22591SJiri Olsa }
104d4c22591SJiri Olsa 
10581f17c90SArnaldo Carvalho de Melo int test__synthesize_stat_round(struct test *test __maybe_unused, int subtest __maybe_unused)
106d4c22591SJiri Olsa {
107d4c22591SJiri Olsa 	TEST_ASSERT_VAL("failed to synthesize stat_config",
108d4c22591SJiri Olsa 		!perf_event__synthesize_stat_round(NULL, 0xdeadbeef, PERF_STAT_ROUND_TYPE__INTERVAL,
109d4c22591SJiri Olsa 						   process_stat_round_event, NULL));
110d4c22591SJiri Olsa 
111d4c22591SJiri Olsa 	return 0;
112d4c22591SJiri Olsa }
113