Commit 571d29ba authored by James Clark's avatar James Clark Committed by Arnaldo Carvalho de Melo
Browse files

perf arm-spe: Don't hard code config attribute



Use the config attribute that's published by the driver instead of
hard coding "attr.config".

Reviewed-by: default avatarIan Rogers <irogers@google.com>
Signed-off-by: default avatarJames Clark <james.clark@linaro.org>
Cc: Adrian Hunter <adrian.hunter@intel.com>
Cc: Alexander Shishkin <alexander.shishkin@linux.intel.com>
Cc: Ingo Molnar <mingo@redhat.com>
Cc: Jiri Olsa <jolsa@kernel.org>
Cc: John Garry <john.g.garry@oracle.com>
Cc: Leo Yan <leo.yan@linux.dev>
Cc: Mark Rutland <mark.rutland@arm.com>
Cc: Mike Leach <mike.leach@linaro.org>
Cc: Namhyung Kim <namhyung@kernel.org>
Cc: Peter Zijlstra <peterz@infradead.org>
Cc: Suzuki Poulouse <suzuki.poulose@arm.com>
Cc: Will Deacon <will@kernel.org>
Signed-off-by: default avatarArnaldo Carvalho de Melo <acme@redhat.com>
parent 5e63706f
Loading
Loading
Loading
Loading
+8 −7
Original line number Diff line number Diff line
@@ -256,7 +256,7 @@ static __u64 arm_spe_pmu__sample_period(const struct perf_pmu *arm_spe_pmu)

static void arm_spe_setup_evsel(struct evsel *evsel, struct perf_cpu_map *cpus)
{
	u64 bit;
	u64 pa_enable_bit;

	evsel->core.attr.freq = 0;
	evsel->core.attr.sample_period = arm_spe_pmu__sample_period(evsel->pmu);
@@ -288,8 +288,9 @@ static void arm_spe_setup_evsel(struct evsel *evsel, struct perf_cpu_map *cpus)
	 * inform that the resulting output's SPE samples contain physical addresses
	 * where applicable.
	 */
	bit = perf_pmu__format_bits(evsel->pmu, "pa_enable");
	if (evsel->core.attr.config & bit)

	if (!evsel__get_config_val(evsel, "pa_enable", &pa_enable_bit))
		if (pa_enable_bit)
			evsel__set_sample_bit(evsel, PHYS_ADDR);
}

@@ -397,6 +398,7 @@ static int arm_spe_recording_options(struct auxtrace_record *itr,
	struct perf_cpu_map *cpus = evlist->core.user_requested_cpus;
	bool discard = false;
	int err;
	u64 discard_bit;

	sper->evlist = evlist;

@@ -425,9 +427,8 @@ static int arm_spe_recording_options(struct auxtrace_record *itr,
	evlist__for_each_entry_safe(evlist, tmp, evsel) {
		if (evsel__is_aux_event(evsel)) {
			arm_spe_setup_evsel(evsel, cpus);
			if (evsel->core.attr.config &
			    perf_pmu__format_bits(evsel->pmu, "discard"))
				discard = true;
			if (!evsel__get_config_val(evsel, "discard", &discard_bit))
				discard = !!discard_bit;
		}
	}