diff options
Diffstat (limited to 'tools/perf/util/stat.c')
| -rw-r--r-- | tools/perf/util/stat.c | 20 | 
1 files changed, 16 insertions, 4 deletions
| diff --git a/tools/perf/util/stat.c b/tools/perf/util/stat.c index ee6f03481215..c1af37e11f98 100644 --- a/tools/perf/util/stat.c +++ b/tools/perf/util/stat.c @@ -1,5 +1,6 @@  // SPDX-License-Identifier: GPL-2.0  #include <errno.h> +#include <linux/err.h>  #include <inttypes.h>  #include <math.h>  #include <string.h> @@ -311,7 +312,7 @@ static int check_per_pkg(struct evsel *counter, struct perf_counts_values *vals,  	if (!mask) {  		mask = hashmap__new(pkg_id_hash, pkg_id_equal, NULL); -		if (!mask) +		if (IS_ERR(mask))  			return -ENOMEM;  		counter->per_pkg_mask = mask; @@ -471,9 +472,10 @@ int perf_stat_process_counter(struct perf_stat_config *config,  int perf_event__process_stat_event(struct perf_session *session,  				   union perf_event *event)  { -	struct perf_counts_values count; +	struct perf_counts_values count, *ptr;  	struct perf_record_stat *st = &event->stat;  	struct evsel *counter; +	int cpu_map_idx;  	count.val = st->val;  	count.ena = st->ena; @@ -484,8 +486,18 @@ int perf_event__process_stat_event(struct perf_session *session,  		pr_err("Failed to resolve counter for stat event.\n");  		return -EINVAL;  	} - -	*perf_counts(counter->counts, st->cpu, st->thread) = count; +	cpu_map_idx = perf_cpu_map__idx(evsel__cpus(counter), (struct perf_cpu){.cpu = st->cpu}); +	if (cpu_map_idx == -1) { +		pr_err("Invalid CPU %d for event %s.\n", st->cpu, evsel__name(counter)); +		return -EINVAL; +	} +	ptr = perf_counts(counter->counts, cpu_map_idx, st->thread); +	if (ptr == NULL) { +		pr_err("Failed to find perf count for CPU %d thread %d on event %s.\n", +			st->cpu, st->thread, evsel__name(counter)); +		return -EINVAL; +	} +	*ptr = count;  	counter->supported = true;  	return 0;  } | 
