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