mirror of
https://mirrors.bfsu.edu.cn/git/linux.git
synced 2025-01-13 09:15:02 +08:00
8b76a3188b
The aggr field in the struct perf_counts is to keep the aggregated value in the AGGR_GLOBAL for the old code. But it's not used anymore. Signed-off-by: Namhyung Kim <namhyung@kernel.org> Acked-by: Ian Rogers <irogers@google.com> Cc: Adrian Hunter <adrian.hunter@intel.com> Cc: Andi Kleen <ak@linux.intel.com> Cc: Athira Jajeev <atrajeev@linux.vnet.ibm.com> Cc: Ingo Molnar <mingo@kernel.org> Cc: James Clark <james.clark@arm.com> Cc: Jiri Olsa <jolsa@kernel.org> Cc: Kan Liang <kan.liang@linux.intel.com> Cc: Leo Yan <leo.yan@linaro.org> Cc: Michael Petlan <mpetlan@redhat.com> Cc: Peter Zijlstra <peterz@infradead.org> Cc: Xing Zhengjun <zhengjun.xing@linux.intel.com> Link: https://lore.kernel.org/r/20221018020227.85905-21-namhyung@kernel.org Signed-off-by: Arnaldo Carvalho de Melo <acme@redhat.com>
72 lines
1.4 KiB
C
72 lines
1.4 KiB
C
// SPDX-License-Identifier: GPL-2.0
|
|
#include <errno.h>
|
|
#include <stdlib.h>
|
|
#include <string.h>
|
|
#include "evsel.h"
|
|
#include "counts.h"
|
|
#include <perf/threadmap.h>
|
|
#include <linux/zalloc.h>
|
|
|
|
struct perf_counts *perf_counts__new(int ncpus, int nthreads)
|
|
{
|
|
struct perf_counts *counts = zalloc(sizeof(*counts));
|
|
|
|
if (counts) {
|
|
struct xyarray *values;
|
|
|
|
values = xyarray__new(ncpus, nthreads, sizeof(struct perf_counts_values));
|
|
if (!values) {
|
|
free(counts);
|
|
return NULL;
|
|
}
|
|
|
|
counts->values = values;
|
|
|
|
values = xyarray__new(ncpus, nthreads, sizeof(bool));
|
|
if (!values) {
|
|
xyarray__delete(counts->values);
|
|
free(counts);
|
|
return NULL;
|
|
}
|
|
|
|
counts->loaded = values;
|
|
}
|
|
|
|
return counts;
|
|
}
|
|
|
|
void perf_counts__delete(struct perf_counts *counts)
|
|
{
|
|
if (counts) {
|
|
xyarray__delete(counts->loaded);
|
|
xyarray__delete(counts->values);
|
|
free(counts);
|
|
}
|
|
}
|
|
|
|
void perf_counts__reset(struct perf_counts *counts)
|
|
{
|
|
xyarray__reset(counts->loaded);
|
|
xyarray__reset(counts->values);
|
|
}
|
|
|
|
void evsel__reset_counts(struct evsel *evsel)
|
|
{
|
|
perf_counts__reset(evsel->counts);
|
|
}
|
|
|
|
int evsel__alloc_counts(struct evsel *evsel)
|
|
{
|
|
struct perf_cpu_map *cpus = evsel__cpus(evsel);
|
|
int nthreads = perf_thread_map__nr(evsel->core.threads);
|
|
|
|
evsel->counts = perf_counts__new(perf_cpu_map__nr(cpus), nthreads);
|
|
return evsel->counts != NULL ? 0 : -ENOMEM;
|
|
}
|
|
|
|
void evsel__free_counts(struct evsel *evsel)
|
|
{
|
|
perf_counts__delete(evsel->counts);
|
|
evsel->counts = NULL;
|
|
}
|