1 // SPDX-License-Identifier: GPL-2.0
5 #include "util/evlist.h"
6 #include "util/parse-events.h"
7 #include "util/event.h"
11 static int ___evlist__add_default_attrs(struct evlist *evlist,
12 struct perf_event_attr *attrs,
18 for (i = 0; i < nr_attrs; i++)
19 event_attr_init(attrs + i);
21 if (perf_pmus__num_core_pmus() == 1)
22 return evlist__add_attrs(evlist, attrs, nr_attrs);
24 for (i = 0; i < nr_attrs; i++) {
25 struct perf_pmu *pmu = NULL;
27 if (attrs[i].type == PERF_TYPE_SOFTWARE) {
28 struct evsel *evsel = evsel__new(attrs + i);
31 goto out_delete_partial_list;
32 list_add_tail(&evsel->core.node, &head);
36 while ((pmu = perf_pmus__scan_core(pmu)) != NULL) {
37 struct perf_cpu_map *cpus;
40 evsel = evsel__new(attrs + i);
42 goto out_delete_partial_list;
43 evsel->core.attr.config |= (__u64)pmu->type << PERF_PMU_TYPE_SHIFT;
44 cpus = perf_cpu_map__get(pmu->cpus);
45 evsel->core.cpus = cpus;
46 evsel->core.own_cpus = perf_cpu_map__get(cpus);
47 evsel->pmu_name = strdup(pmu->name);
48 list_add_tail(&evsel->core.node, &head);
52 evlist__splice_list_tail(evlist, &head);
56 out_delete_partial_list:
58 struct evsel *evsel, *n;
60 __evlist__for_each_entry_safe(&head, n, evsel)
66 int arch_evlist__add_default_attrs(struct evlist *evlist,
67 struct perf_event_attr *attrs,
73 return ___evlist__add_default_attrs(evlist, attrs, nr_attrs);
76 int arch_evlist__cmp(const struct evsel *lhs, const struct evsel *rhs)
78 if (topdown_sys_has_perf_metrics() &&
79 (arch_evsel__must_be_in_group(lhs) || arch_evsel__must_be_in_group(rhs))) {
80 /* Ensure the topdown slots comes first. */
81 if (strcasestr(lhs->name, "slots") && !strcasestr(lhs->name, "uops_retired.slots"))
83 if (strcasestr(rhs->name, "slots") && !strcasestr(rhs->name, "uops_retired.slots"))
85 /* Followed by topdown events. */
86 if (strcasestr(lhs->name, "topdown") && !strcasestr(rhs->name, "topdown"))
88 if (!strcasestr(lhs->name, "topdown") && strcasestr(rhs->name, "topdown"))
92 /* Default ordering by insertion index. */
93 return lhs->core.idx - rhs->core.idx;