perf auxtrace: Record whether an auxtrace mmap is needed
authorAdrian Hunter <adrian.hunter@intel.com>
Fri, 6 May 2022 12:25:47 +0000 (15:25 +0300)
committerArnaldo Carvalho de Melo <acme@redhat.com>
Tue, 10 May 2022 17:27:19 +0000 (14:27 -0300)
Add a flag needs_auxtrace_mmap to record whether an auxtrace mmap is
needed, in preparation for correctly determining whether or not an
auxtrace mmap is needed.

Signed-off-by: Adrian Hunter <adrian.hunter@intel.com>
Acked-by: Ian Rogers <irogers@google.com>
Cc: Alexey Bayduraev <alexey.v.bayduraev@linux.intel.com>
Cc: Jiri Olsa <jolsa@kernel.org>
Cc: Leo Yan <leo.yan@linaro.org>
Cc: Namhyung Kim <namhyung@kernel.org>
Link: http://lore.kernel.org/lkml/20220506122601.367589-10-adrian.hunter@intel.com
Signed-off-by: Arnaldo Carvalho de Melo <acme@redhat.com>
tools/perf/arch/arm/util/cs-etm.c
tools/perf/arch/arm64/util/arm-spe.c
tools/perf/arch/s390/util/auxtrace.c
tools/perf/arch/x86/util/intel-bts.c
tools/perf/arch/x86/util/intel-pt.c
tools/perf/util/evsel.h

index 11c71aa..1b54638 100644 (file)
@@ -319,6 +319,7 @@ static int cs_etm_recording_options(struct auxtrace_record *itr,
                        }
                        evsel->core.attr.freq = 0;
                        evsel->core.attr.sample_period = 1;
+                       evsel->needs_auxtrace_mmap = true;
                        cs_etm_evsel = evsel;
                        opts->full_auxtrace = true;
                }
index e8b577d..6f4db2a 100644 (file)
@@ -160,6 +160,7 @@ static int arm_spe_recording_options(struct auxtrace_record *itr,
                        }
                        evsel->core.attr.freq = 0;
                        evsel->core.attr.sample_period = arm_spe_pmu->default_config->sample_period;
+                       evsel->needs_auxtrace_mmap = true;
                        arm_spe_evsel = evsel;
                        opts->full_auxtrace = true;
                }
index 0db5c58..5068baa 100644 (file)
@@ -98,6 +98,7 @@ struct auxtrace_record *auxtrace_record__init(struct evlist *evlist,
        evlist__for_each_entry(evlist, pos) {
                if (pos->core.attr.config == PERF_EVENT_CPUM_SF_DIAG) {
                        diagnose = 1;
+                       pos->needs_auxtrace_mmap = true;
                        break;
                }
        }
index d68a0f4..bcccfba 100644 (file)
@@ -129,6 +129,7 @@ static int intel_bts_recording_options(struct auxtrace_record *itr,
                        }
                        evsel->core.attr.freq = 0;
                        evsel->core.attr.sample_period = 1;
+                       evsel->needs_auxtrace_mmap = true;
                        intel_bts_evsel = evsel;
                        opts->full_auxtrace = true;
                }
index 38ec266..2eaac46 100644 (file)
@@ -649,6 +649,7 @@ static int intel_pt_recording_options(struct auxtrace_record *itr,
                        evsel->core.attr.freq = 0;
                        evsel->core.attr.sample_period = 1;
                        evsel->no_aux_samples = true;
+                       evsel->needs_auxtrace_mmap = true;
                        intel_pt_evsel = evsel;
                        opts->full_auxtrace = true;
                }
index d4b0453..52dc5fd 100644 (file)
@@ -130,6 +130,7 @@ struct evsel {
        bool                    merged_stat;
        bool                    reset_group;
        bool                    errored;
+       bool                    needs_auxtrace_mmap;
        struct hashmap          *per_pkg_mask;
        int                     err;
        struct {