mirror of
https://mirrors.bfsu.edu.cn/git/linux.git
synced 2024-11-12 05:48:39 +08:00
32dcd021d0
Rename struct perf_evsel to struct evsel, so we don't have a name clash when we add struct perf_evsel in libperf. Committer notes: Added fixes for arm64, provided by Jiri. Signed-off-by: Jiri Olsa <jolsa@kernel.org> Cc: Alexander Shishkin <alexander.shishkin@linux.intel.com> Cc: Alexey Budankov <alexey.budankov@linux.intel.com> Cc: Andi Kleen <ak@linux.intel.com> Cc: Michael Petlan <mpetlan@redhat.com> Cc: Namhyung Kim <namhyung@kernel.org> Cc: Peter Zijlstra <peterz@infradead.org> Link: http://lkml.kernel.org/r/20190721112506.12306-5-jolsa@kernel.org Signed-off-by: Arnaldo Carvalho de Melo <acme@redhat.com>
67 lines
1.3 KiB
C
67 lines
1.3 KiB
C
// SPDX-License-Identifier: GPL-2.0
|
|
#include <errno.h>
|
|
#include <stdlib.h>
|
|
#include "evsel.h"
|
|
#include "counts.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);
|
|
}
|
|
}
|
|
|
|
static void perf_counts__reset(struct perf_counts *counts)
|
|
{
|
|
xyarray__reset(counts->loaded);
|
|
xyarray__reset(counts->values);
|
|
}
|
|
|
|
void perf_evsel__reset_counts(struct evsel *evsel)
|
|
{
|
|
perf_counts__reset(evsel->counts);
|
|
}
|
|
|
|
int perf_evsel__alloc_counts(struct evsel *evsel, int ncpus, int nthreads)
|
|
{
|
|
evsel->counts = perf_counts__new(ncpus, nthreads);
|
|
return evsel->counts != NULL ? 0 : -ENOMEM;
|
|
}
|
|
|
|
void perf_evsel__free_counts(struct evsel *evsel)
|
|
{
|
|
perf_counts__delete(evsel->counts);
|
|
evsel->counts = NULL;
|
|
}
|