perf test: Use macro for "suite" definitions
Add a macro to simplify later refactoring. No functional change. Signed-off-by: Ian Rogers <irogers@google.com> Tested-by: Sohaib Mohamed <sohaib.amhmd@gmail.com> Acked-by: Jiri Olsa <jolsa@redhat.com> Cc: Alexander Shishkin <alexander.shishkin@linux.intel.com> Cc: Brendan Higgins <brendanhiggins@google.com> Cc: Daniel Latypov <dlatypov@google.com> Cc: David Gow <davidgow@google.com> Cc: Ingo Molnar <mingo@redhat.com> Cc: Jin Yao <yao.jin@linux.intel.com> Cc: John Garry <john.garry@huawei.com> Cc: Mark Rutland <mark.rutland@arm.com> Cc: Namhyung Kim <namhyung@kernel.org> Cc: Paul Clarke <pc@us.ibm.com> Cc: Peter Zijlstra <peterz@infradead.org> Cc: Stephane Eranian <eranian@google.com> Link: https://lore.kernel.org/r/20211104064208.3156807-3-irogers@google.com Signed-off-by: Arnaldo Carvalho de Melo <acme@redhat.com>
This commit is contained in:
parent
fe90d37877
commit
54df5c8e01
|
@ -36,337 +36,156 @@ struct test __weak arch_tests[] = {
|
||||||
},
|
},
|
||||||
};
|
};
|
||||||
|
|
||||||
|
#define DEFINE_SUITE(description, name) \
|
||||||
|
{ \
|
||||||
|
.desc = description, \
|
||||||
|
.func = test__##name, \
|
||||||
|
}
|
||||||
|
|
||||||
static struct test generic_tests[] = {
|
static struct test generic_tests[] = {
|
||||||
{
|
DEFINE_SUITE("vmlinux symtab matches kallsyms", vmlinux_matches_kallsyms),
|
||||||
.desc = "vmlinux symtab matches kallsyms",
|
DEFINE_SUITE("Detect openat syscall event", openat_syscall_event),
|
||||||
.func = test__vmlinux_matches_kallsyms,
|
DEFINE_SUITE("Detect openat syscall event on all cpus", openat_syscall_event_on_all_cpus),
|
||||||
},
|
DEFINE_SUITE("Read samples using the mmap interface", basic_mmap),
|
||||||
{
|
DEFINE_SUITE("Test data source output", mem),
|
||||||
.desc = "Detect openat syscall event",
|
DEFINE_SUITE("Parse event definition strings", parse_events),
|
||||||
.func = test__openat_syscall_event,
|
DEFINE_SUITE("Simple expression parser", expr),
|
||||||
},
|
DEFINE_SUITE("PERF_RECORD_* events & perf_sample fields", PERF_RECORD),
|
||||||
{
|
DEFINE_SUITE("Parse perf pmu format", pmu),
|
||||||
.desc = "Detect openat syscall event on all cpus",
|
{
|
||||||
.func = test__openat_syscall_event_on_all_cpus,
|
.desc = "PMU events",
|
||||||
},
|
.func = test__pmu_events,
|
||||||
{
|
.subtest = {
|
||||||
.desc = "Read samples using the mmap interface",
|
.skip_if_fail = false,
|
||||||
.func = test__basic_mmap,
|
.get_nr = test__pmu_events_subtest_get_nr,
|
||||||
},
|
.get_desc = test__pmu_events_subtest_get_desc,
|
||||||
{
|
.skip_reason = test__pmu_events_subtest_skip_reason,
|
||||||
.desc = "Test data source output",
|
|
||||||
.func = test__mem,
|
|
||||||
},
|
|
||||||
{
|
|
||||||
.desc = "Parse event definition strings",
|
|
||||||
.func = test__parse_events,
|
|
||||||
},
|
|
||||||
{
|
|
||||||
.desc = "Simple expression parser",
|
|
||||||
.func = test__expr,
|
|
||||||
},
|
|
||||||
{
|
|
||||||
.desc = "PERF_RECORD_* events & perf_sample fields",
|
|
||||||
.func = test__PERF_RECORD,
|
|
||||||
},
|
|
||||||
{
|
|
||||||
.desc = "Parse perf pmu format",
|
|
||||||
.func = test__pmu,
|
|
||||||
},
|
|
||||||
{
|
|
||||||
.desc = "PMU events",
|
|
||||||
.func = test__pmu_events,
|
|
||||||
.subtest = {
|
|
||||||
.skip_if_fail = false,
|
|
||||||
.get_nr = test__pmu_events_subtest_get_nr,
|
|
||||||
.get_desc = test__pmu_events_subtest_get_desc,
|
|
||||||
.skip_reason = test__pmu_events_subtest_skip_reason,
|
|
||||||
},
|
|
||||||
|
|
||||||
},
|
|
||||||
{
|
|
||||||
.desc = "DSO data read",
|
|
||||||
.func = test__dso_data,
|
|
||||||
},
|
|
||||||
{
|
|
||||||
.desc = "DSO data cache",
|
|
||||||
.func = test__dso_data_cache,
|
|
||||||
},
|
|
||||||
{
|
|
||||||
.desc = "DSO data reopen",
|
|
||||||
.func = test__dso_data_reopen,
|
|
||||||
},
|
|
||||||
{
|
|
||||||
.desc = "Roundtrip evsel->name",
|
|
||||||
.func = test__perf_evsel__roundtrip_name_test,
|
|
||||||
},
|
|
||||||
{
|
|
||||||
.desc = "Parse sched tracepoints fields",
|
|
||||||
.func = test__perf_evsel__tp_sched_test,
|
|
||||||
},
|
|
||||||
{
|
|
||||||
.desc = "syscalls:sys_enter_openat event fields",
|
|
||||||
.func = test__syscall_openat_tp_fields,
|
|
||||||
},
|
|
||||||
{
|
|
||||||
.desc = "Setup struct perf_event_attr",
|
|
||||||
.func = test__attr,
|
|
||||||
},
|
|
||||||
{
|
|
||||||
.desc = "Match and link multiple hists",
|
|
||||||
.func = test__hists_link,
|
|
||||||
},
|
|
||||||
{
|
|
||||||
.desc = "'import perf' in python",
|
|
||||||
.func = test__python_use,
|
|
||||||
},
|
|
||||||
{
|
|
||||||
.desc = "Breakpoint overflow signal handler",
|
|
||||||
.func = test__bp_signal,
|
|
||||||
.is_supported = test__bp_signal_is_supported,
|
|
||||||
},
|
|
||||||
{
|
|
||||||
.desc = "Breakpoint overflow sampling",
|
|
||||||
.func = test__bp_signal_overflow,
|
|
||||||
.is_supported = test__bp_signal_is_supported,
|
|
||||||
},
|
|
||||||
{
|
|
||||||
.desc = "Breakpoint accounting",
|
|
||||||
.func = test__bp_accounting,
|
|
||||||
.is_supported = test__bp_account_is_supported,
|
|
||||||
},
|
|
||||||
{
|
|
||||||
.desc = "Watchpoint",
|
|
||||||
.func = test__wp,
|
|
||||||
.is_supported = test__wp_is_supported,
|
|
||||||
.subtest = {
|
|
||||||
.skip_if_fail = false,
|
|
||||||
.get_nr = test__wp_subtest_get_nr,
|
|
||||||
.get_desc = test__wp_subtest_get_desc,
|
|
||||||
.skip_reason = test__wp_subtest_skip_reason,
|
|
||||||
},
|
|
||||||
},
|
|
||||||
{
|
|
||||||
.desc = "Number of exit events of a simple workload",
|
|
||||||
.func = test__task_exit,
|
|
||||||
},
|
|
||||||
{
|
|
||||||
.desc = "Software clock events period values",
|
|
||||||
.func = test__sw_clock_freq,
|
|
||||||
},
|
|
||||||
{
|
|
||||||
.desc = "Object code reading",
|
|
||||||
.func = test__code_reading,
|
|
||||||
},
|
|
||||||
{
|
|
||||||
.desc = "Sample parsing",
|
|
||||||
.func = test__sample_parsing,
|
|
||||||
},
|
|
||||||
{
|
|
||||||
.desc = "Use a dummy software event to keep tracking",
|
|
||||||
.func = test__keep_tracking,
|
|
||||||
},
|
|
||||||
{
|
|
||||||
.desc = "Parse with no sample_id_all bit set",
|
|
||||||
.func = test__parse_no_sample_id_all,
|
|
||||||
},
|
|
||||||
{
|
|
||||||
.desc = "Filter hist entries",
|
|
||||||
.func = test__hists_filter,
|
|
||||||
},
|
|
||||||
{
|
|
||||||
.desc = "Lookup mmap thread",
|
|
||||||
.func = test__mmap_thread_lookup,
|
|
||||||
},
|
|
||||||
{
|
|
||||||
.desc = "Share thread maps",
|
|
||||||
.func = test__thread_maps_share,
|
|
||||||
},
|
|
||||||
{
|
|
||||||
.desc = "Sort output of hist entries",
|
|
||||||
.func = test__hists_output,
|
|
||||||
},
|
|
||||||
{
|
|
||||||
.desc = "Cumulate child hist entries",
|
|
||||||
.func = test__hists_cumulate,
|
|
||||||
},
|
|
||||||
{
|
|
||||||
.desc = "Track with sched_switch",
|
|
||||||
.func = test__switch_tracking,
|
|
||||||
},
|
|
||||||
{
|
|
||||||
.desc = "Filter fds with revents mask in a fdarray",
|
|
||||||
.func = test__fdarray__filter,
|
|
||||||
},
|
|
||||||
{
|
|
||||||
.desc = "Add fd to a fdarray, making it autogrow",
|
|
||||||
.func = test__fdarray__add,
|
|
||||||
},
|
|
||||||
{
|
|
||||||
.desc = "kmod_path__parse",
|
|
||||||
.func = test__kmod_path__parse,
|
|
||||||
},
|
|
||||||
{
|
|
||||||
.desc = "Thread map",
|
|
||||||
.func = test__thread_map,
|
|
||||||
},
|
|
||||||
{
|
|
||||||
.desc = "LLVM search and compile",
|
|
||||||
.func = test__llvm,
|
|
||||||
.subtest = {
|
|
||||||
.skip_if_fail = true,
|
|
||||||
.get_nr = test__llvm_subtest_get_nr,
|
|
||||||
.get_desc = test__llvm_subtest_get_desc,
|
|
||||||
},
|
|
||||||
},
|
|
||||||
{
|
|
||||||
.desc = "Session topology",
|
|
||||||
.func = test__session_topology,
|
|
||||||
},
|
|
||||||
{
|
|
||||||
.desc = "BPF filter",
|
|
||||||
.func = test__bpf,
|
|
||||||
.subtest = {
|
|
||||||
.skip_if_fail = true,
|
|
||||||
.get_nr = test__bpf_subtest_get_nr,
|
|
||||||
.get_desc = test__bpf_subtest_get_desc,
|
|
||||||
},
|
|
||||||
},
|
|
||||||
{
|
|
||||||
.desc = "Synthesize thread map",
|
|
||||||
.func = test__thread_map_synthesize,
|
|
||||||
},
|
|
||||||
{
|
|
||||||
.desc = "Remove thread map",
|
|
||||||
.func = test__thread_map_remove,
|
|
||||||
},
|
|
||||||
{
|
|
||||||
.desc = "Synthesize cpu map",
|
|
||||||
.func = test__cpu_map_synthesize,
|
|
||||||
},
|
|
||||||
{
|
|
||||||
.desc = "Synthesize stat config",
|
|
||||||
.func = test__synthesize_stat_config,
|
|
||||||
},
|
|
||||||
{
|
|
||||||
.desc = "Synthesize stat",
|
|
||||||
.func = test__synthesize_stat,
|
|
||||||
},
|
|
||||||
{
|
|
||||||
.desc = "Synthesize stat round",
|
|
||||||
.func = test__synthesize_stat_round,
|
|
||||||
},
|
|
||||||
{
|
|
||||||
.desc = "Synthesize attr update",
|
|
||||||
.func = test__event_update,
|
|
||||||
},
|
|
||||||
{
|
|
||||||
.desc = "Event times",
|
|
||||||
.func = test__event_times,
|
|
||||||
},
|
|
||||||
{
|
|
||||||
.desc = "Read backward ring buffer",
|
|
||||||
.func = test__backward_ring_buffer,
|
|
||||||
},
|
|
||||||
{
|
|
||||||
.desc = "Print cpu map",
|
|
||||||
.func = test__cpu_map_print,
|
|
||||||
},
|
|
||||||
{
|
|
||||||
.desc = "Merge cpu map",
|
|
||||||
.func = test__cpu_map_merge,
|
|
||||||
},
|
},
|
||||||
|
|
||||||
{
|
},
|
||||||
.desc = "Probe SDT events",
|
DEFINE_SUITE("DSO data read", dso_data),
|
||||||
.func = test__sdt_event,
|
DEFINE_SUITE("DSO data cache", dso_data_cache),
|
||||||
|
DEFINE_SUITE("DSO data reopen", dso_data_reopen),
|
||||||
|
DEFINE_SUITE("Roundtrip evsel->name", perf_evsel__roundtrip_name_test),
|
||||||
|
DEFINE_SUITE("Parse sched tracepoints fields", perf_evsel__tp_sched_test),
|
||||||
|
DEFINE_SUITE("syscalls:sys_enter_openat event fields", syscall_openat_tp_fields),
|
||||||
|
DEFINE_SUITE("Setup struct perf_event_attr", attr),
|
||||||
|
DEFINE_SUITE("Match and link multiple hists", hists_link),
|
||||||
|
DEFINE_SUITE("'import perf' in python", python_use),
|
||||||
|
{
|
||||||
|
.desc = "Breakpoint overflow signal handler",
|
||||||
|
.func = test__bp_signal,
|
||||||
|
.is_supported = test__bp_signal_is_supported,
|
||||||
|
},
|
||||||
|
{
|
||||||
|
.desc = "Breakpoint overflow sampling",
|
||||||
|
.func = test__bp_signal_overflow,
|
||||||
|
.is_supported = test__bp_signal_is_supported,
|
||||||
|
},
|
||||||
|
{
|
||||||
|
.desc = "Breakpoint accounting",
|
||||||
|
.func = test__bp_accounting,
|
||||||
|
.is_supported = test__bp_account_is_supported,
|
||||||
|
},
|
||||||
|
{
|
||||||
|
.desc = "Watchpoint",
|
||||||
|
.func = test__wp,
|
||||||
|
.is_supported = test__wp_is_supported,
|
||||||
|
.subtest = {
|
||||||
|
.skip_if_fail = false,
|
||||||
|
.get_nr = test__wp_subtest_get_nr,
|
||||||
|
.get_desc = test__wp_subtest_get_desc,
|
||||||
|
.skip_reason = test__wp_subtest_skip_reason,
|
||||||
},
|
},
|
||||||
{
|
},
|
||||||
.desc = "is_printable_array",
|
DEFINE_SUITE("Number of exit events of a simple workload", task_exit),
|
||||||
.func = test__is_printable_array,
|
DEFINE_SUITE("Software clock events period values", sw_clock_freq),
|
||||||
|
DEFINE_SUITE("Object code reading", code_reading),
|
||||||
|
DEFINE_SUITE("Sample parsing", sample_parsing),
|
||||||
|
DEFINE_SUITE("Use a dummy software event to keep tracking", keep_tracking),
|
||||||
|
DEFINE_SUITE("Parse with no sample_id_all bit set", parse_no_sample_id_all),
|
||||||
|
DEFINE_SUITE("Filter hist entries", hists_filter),
|
||||||
|
DEFINE_SUITE("Lookup mmap thread", mmap_thread_lookup),
|
||||||
|
DEFINE_SUITE("Share thread maps", thread_maps_share),
|
||||||
|
DEFINE_SUITE("Sort output of hist entries", hists_output),
|
||||||
|
DEFINE_SUITE("Cumulate child hist entries", hists_cumulate),
|
||||||
|
DEFINE_SUITE("Track with sched_switch", switch_tracking),
|
||||||
|
DEFINE_SUITE("Filter fds with revents mask in a fdarray", fdarray__filter),
|
||||||
|
DEFINE_SUITE("Add fd to a fdarray, making it autogrow", fdarray__add),
|
||||||
|
DEFINE_SUITE("kmod_path__parse", kmod_path__parse),
|
||||||
|
DEFINE_SUITE("Thread map", thread_map),
|
||||||
|
{
|
||||||
|
.desc = "LLVM search and compile",
|
||||||
|
.func = test__llvm,
|
||||||
|
.subtest = {
|
||||||
|
.skip_if_fail = true,
|
||||||
|
.get_nr = test__llvm_subtest_get_nr,
|
||||||
|
.get_desc = test__llvm_subtest_get_desc,
|
||||||
},
|
},
|
||||||
{
|
},
|
||||||
.desc = "Print bitmap",
|
DEFINE_SUITE("Session topology", session_topology),
|
||||||
.func = test__bitmap_print,
|
{
|
||||||
},
|
.desc = "BPF filter",
|
||||||
{
|
.func = test__bpf,
|
||||||
.desc = "perf hooks",
|
.subtest = {
|
||||||
.func = test__perf_hooks,
|
.skip_if_fail = true,
|
||||||
},
|
.get_nr = test__bpf_subtest_get_nr,
|
||||||
{
|
.get_desc = test__bpf_subtest_get_desc,
|
||||||
.desc = "builtin clang support",
|
|
||||||
.func = test__clang,
|
|
||||||
.subtest = {
|
|
||||||
.skip_if_fail = true,
|
|
||||||
.get_nr = test__clang_subtest_get_nr,
|
|
||||||
.get_desc = test__clang_subtest_get_desc,
|
|
||||||
}
|
|
||||||
},
|
|
||||||
{
|
|
||||||
.desc = "unit_number__scnprintf",
|
|
||||||
.func = test__unit_number__scnprint,
|
|
||||||
},
|
|
||||||
{
|
|
||||||
.desc = "mem2node",
|
|
||||||
.func = test__mem2node,
|
|
||||||
},
|
|
||||||
{
|
|
||||||
.desc = "time utils",
|
|
||||||
.func = test__time_utils,
|
|
||||||
},
|
|
||||||
{
|
|
||||||
.desc = "Test jit_write_elf",
|
|
||||||
.func = test__jit_write_elf,
|
|
||||||
},
|
|
||||||
{
|
|
||||||
.desc = "Test libpfm4 support",
|
|
||||||
.func = test__pfm,
|
|
||||||
.subtest = {
|
|
||||||
.skip_if_fail = true,
|
|
||||||
.get_nr = test__pfm_subtest_get_nr,
|
|
||||||
.get_desc = test__pfm_subtest_get_desc,
|
|
||||||
}
|
|
||||||
},
|
|
||||||
{
|
|
||||||
.desc = "Test api io",
|
|
||||||
.func = test__api_io,
|
|
||||||
},
|
|
||||||
{
|
|
||||||
.desc = "maps__merge_in",
|
|
||||||
.func = test__maps__merge_in,
|
|
||||||
},
|
|
||||||
{
|
|
||||||
.desc = "Demangle Java",
|
|
||||||
.func = test__demangle_java,
|
|
||||||
},
|
|
||||||
{
|
|
||||||
.desc = "Demangle OCaml",
|
|
||||||
.func = test__demangle_ocaml,
|
|
||||||
},
|
|
||||||
{
|
|
||||||
.desc = "Parse and process metrics",
|
|
||||||
.func = test__parse_metric,
|
|
||||||
},
|
|
||||||
{
|
|
||||||
.desc = "PE file support",
|
|
||||||
.func = test__pe_file_parsing,
|
|
||||||
},
|
|
||||||
{
|
|
||||||
.desc = "Event expansion for cgroups",
|
|
||||||
.func = test__expand_cgroup_events,
|
|
||||||
},
|
|
||||||
{
|
|
||||||
.desc = "Convert perf time to TSC",
|
|
||||||
.func = test__perf_time_to_tsc,
|
|
||||||
.is_supported = test__tsc_is_supported,
|
|
||||||
},
|
|
||||||
{
|
|
||||||
.desc = "dlfilter C API",
|
|
||||||
.func = test__dlfilter,
|
|
||||||
},
|
|
||||||
{
|
|
||||||
.func = NULL,
|
|
||||||
},
|
},
|
||||||
|
},
|
||||||
|
DEFINE_SUITE("Synthesize thread map", thread_map_synthesize),
|
||||||
|
DEFINE_SUITE("Remove thread map", thread_map_remove),
|
||||||
|
DEFINE_SUITE("Synthesize cpu map", cpu_map_synthesize),
|
||||||
|
DEFINE_SUITE("Synthesize stat config", synthesize_stat_config),
|
||||||
|
DEFINE_SUITE("Synthesize stat", synthesize_stat),
|
||||||
|
DEFINE_SUITE("Synthesize stat round", synthesize_stat_round),
|
||||||
|
DEFINE_SUITE("Synthesize attr update", event_update),
|
||||||
|
DEFINE_SUITE("Event times", event_times),
|
||||||
|
DEFINE_SUITE("Read backward ring buffer", backward_ring_buffer),
|
||||||
|
DEFINE_SUITE("Print cpu map", cpu_map_print),
|
||||||
|
DEFINE_SUITE("Merge cpu map", cpu_map_merge),
|
||||||
|
DEFINE_SUITE("Probe SDT events", sdt_event),
|
||||||
|
DEFINE_SUITE("is_printable_array", is_printable_array),
|
||||||
|
DEFINE_SUITE("Print bitmap", bitmap_print),
|
||||||
|
DEFINE_SUITE("perf hooks", perf_hooks),
|
||||||
|
{
|
||||||
|
.desc = "builtin clang support",
|
||||||
|
.func = test__clang,
|
||||||
|
.subtest = {
|
||||||
|
.skip_if_fail = true,
|
||||||
|
.get_nr = test__clang_subtest_get_nr,
|
||||||
|
.get_desc = test__clang_subtest_get_desc,
|
||||||
|
}
|
||||||
|
},
|
||||||
|
DEFINE_SUITE("unit_number__scnprintf", unit_number__scnprint),
|
||||||
|
DEFINE_SUITE("mem2node", mem2node),
|
||||||
|
DEFINE_SUITE("time utils", time_utils),
|
||||||
|
DEFINE_SUITE("Test jit_write_elf", jit_write_elf),
|
||||||
|
{
|
||||||
|
.desc = "Test libpfm4 support",
|
||||||
|
.func = test__pfm,
|
||||||
|
.subtest = {
|
||||||
|
.skip_if_fail = true,
|
||||||
|
.get_nr = test__pfm_subtest_get_nr,
|
||||||
|
.get_desc = test__pfm_subtest_get_desc,
|
||||||
|
}
|
||||||
|
},
|
||||||
|
DEFINE_SUITE("Test api io", api_io),
|
||||||
|
DEFINE_SUITE("maps__merge_in", maps__merge_in),
|
||||||
|
DEFINE_SUITE("Demangle Java", demangle_java),
|
||||||
|
DEFINE_SUITE("Demangle OCaml", demangle_ocaml),
|
||||||
|
DEFINE_SUITE("Parse and process metrics", parse_metric),
|
||||||
|
DEFINE_SUITE("PE file support", pe_file_parsing),
|
||||||
|
DEFINE_SUITE("Event expansion for cgroups", expand_cgroup_events),
|
||||||
|
{
|
||||||
|
.desc = "Convert perf time to TSC",
|
||||||
|
.func = test__perf_time_to_tsc,
|
||||||
|
.is_supported = test__tsc_is_supported,
|
||||||
|
},
|
||||||
|
DEFINE_SUITE("dlfilter C API", dlfilter),
|
||||||
|
{
|
||||||
|
.func = NULL,
|
||||||
|
},
|
||||||
};
|
};
|
||||||
|
|
||||||
static struct test *tests[] = {
|
static struct test *tests[] = {
|
||||||
|
|
Loading…
Reference in New Issue