summaryrefslogtreecommitdiff
path: root/tools/perf/arch/arm64/util/pmu.c
blob: 2a4eab2d160ee555312be2f16d04756a6034ed8d (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
// SPDX-License-Identifier: GPL-2.0

#include <internal/cpumap.h>
#include "../../../util/cpumap.h"
#include "../../../util/header.h"
#include "../../../util/pmu.h"
#include "../../../util/pmus.h"
#include <api/fs/fs.h>
#include <math.h>

const struct pmu_metrics_table *pmu_metrics_table__find(void)
{
	struct perf_pmu *pmu;

	/* Metrics aren't currently supported on heterogeneous Arm systems */
	if (perf_pmus__num_core_pmus() > 1)
		return NULL;

	/* Doesn't matter which one here because they'll all be the same */
	pmu = perf_pmus__find_core_pmu();
	if (pmu)
		return perf_pmu__find_metrics_table(pmu);

	return NULL;
}

double perf_pmu__cpu_slots_per_cycle(void)
{
	char path[PATH_MAX];
	unsigned long long slots = 0;
	struct perf_pmu *pmu = perf_pmus__find_core_pmu();

	if (pmu) {
		perf_pmu__pathname_scnprintf(path, sizeof(path),
					     pmu->name, "caps/slots");
		/*
		 * The value of slots is not greater than 32 bits, but
		 * filename__read_int can't read value with 0x prefix,
		 * so use filename__read_ull instead.
		 */
		filename__read_ull(path, &slots);
	}

	return slots ? (double)slots : NAN;
}