linux-zen-desktop/tools/perf/arch/arm64/util/pmu.c

66 lines
1.4 KiB
C
Raw Normal View History

2023-08-30 17:31:07 +02:00
// SPDX-License-Identifier: GPL-2.0
#include <internal/cpumap.h>
#include "../../../util/cpumap.h"
#include "../../../util/pmu.h"
2023-10-24 12:59:35 +02:00
#include "../../../util/pmus.h"
2023-08-30 17:31:07 +02:00
#include <api/fs/fs.h>
#include <math.h>
static struct perf_pmu *pmu__find_core_pmu(void)
{
struct perf_pmu *pmu = NULL;
2023-10-24 12:59:35 +02:00
while ((pmu = perf_pmus__scan_core(pmu))) {
2023-08-30 17:31:07 +02:00
/*
* The cpumap should cover all CPUs. Otherwise, some CPUs may
* not support some events or have different event IDs.
*/
2023-10-24 12:59:35 +02:00
if (RC_CHK_ACCESS(pmu->cpus)->nr != cpu__max_cpu().cpu)
2023-08-30 17:31:07 +02:00
return NULL;
return pmu;
}
return NULL;
}
const struct pmu_metrics_table *pmu_metrics_table__find(void)
{
struct perf_pmu *pmu = pmu__find_core_pmu();
if (pmu)
return perf_pmu__find_metrics_table(pmu);
return NULL;
}
const struct pmu_events_table *pmu_events_table__find(void)
{
struct perf_pmu *pmu = pmu__find_core_pmu();
if (pmu)
return perf_pmu__find_events_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 = pmu__find_core_pmu();
if (pmu) {
perf_pmu__pathname_scnprintf(path, sizeof(path),
pmu->name, "caps/slots");
/*
2023-10-24 12:59:35 +02:00
* 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.
2023-08-30 17:31:07 +02:00
*/
2023-10-24 12:59:35 +02:00
filename__read_ull(path, &slots);
2023-08-30 17:31:07 +02:00
}
return slots ? (double)slots : NAN;
}