mirror of
https://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git
synced 2025-01-22 16:06:04 -05:00
perf header: Refactor get_cpuid to take a CPU for ARM
ARM BIG.little has no notion of a constant CPUID for both core types. To reflect this reality, change the get_cpuid function to also pass in a possibly unused logical cpu. If the dummy value (-1) is passed in then ARM can, as currently happens, select the first logical CPU's "CPUID". The changes to ARM getcpuid happen in a follow up change. Reviewed-by: James Clark <james.clark@linaro.org> Signed-off-by: Ian Rogers <irogers@google.com> Tested-by: Xu Yang <xu.yang_2@nxp.com> Cc: Adrian Hunter <adrian.hunter@intel.com> Cc: Albert Ou <aou@eecs.berkeley.edu> Cc: Alexander Shishkin <alexander.shishkin@linux.intel.com> Cc: Alexandre Ghiti <alexghiti@rivosinc.com> Cc: Athira Rajeev <atrajeev@linux.vnet.ibm.com> Cc: Ben Zong-You Xie <ben717@andestech.com> Cc: Benjamin Gray <bgray@linux.ibm.com> Cc: Bibo Mao <maobibo@loongson.cn> Cc: Clément Le Goffic <clement.legoffic@foss.st.com> Cc: Dima Kogan <dima@secretsauce.net> Cc: Dr. David Alan Gilbert <linux@treblig.org> Cc: Huacai Chen <chenhuacai@kernel.org> Cc: Ingo Molnar <mingo@redhat.com> Cc: Jiri Olsa <jolsa@kernel.org> Cc: John Garry <john.g.garry@oracle.com> Cc: Kan Liang <kan.liang@linux.intel.com> Cc: Leo Yan <leo.yan@linux.dev> Cc: Mark Rutland <mark.rutland@arm.com> Cc: Masami Hiramatsu <mhiramat@kernel.org> Cc: Mike Leach <mike.leach@linaro.org> Cc: Namhyung Kim <namhyung@kernel.org> Cc: Palmer Dabbelt <palmer@dabbelt.com> Cc: Paul Walmsley <paul.walmsley@sifive.com> Cc: Peter Zijlstra <peterz@infradead.org> Cc: Ravi Bangoria <ravi.bangoria@amd.com> Cc: Sandipan Das <sandipan.das@amd.com> Cc: Will Deacon <will@kernel.org> Cc: Yicong Yang <yangyicong@hisilicon.com> Cc: linux-arm-kernel@lists.infradead.org Cc: linux-riscv@lists.infradead.org Link: https://lore.kernel.org/r/20241107162035.52206-4-irogers@google.com Signed-off-by: Arnaldo Carvalho de Melo <acme@redhat.com>
This commit is contained in:
parent
c6fafe36ba
commit
cec0d6572a
11 changed files with 19 additions and 14 deletions
|
@ -50,7 +50,7 @@ static int _get_cpuid(char *buf, size_t sz, struct perf_cpu_map *cpus)
|
||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
||||||
int get_cpuid(char *buf, size_t sz)
|
int get_cpuid(char *buf, size_t sz, struct perf_cpu cpu __maybe_unused)
|
||||||
{
|
{
|
||||||
struct perf_cpu_map *cpus = perf_cpu_map__new_online_cpus();
|
struct perf_cpu_map *cpus = perf_cpu_map__new_online_cpus();
|
||||||
int ret;
|
int ret;
|
||||||
|
|
|
@ -70,7 +70,7 @@ static char *_get_cpuid(void)
|
||||||
return cpuid;
|
return cpuid;
|
||||||
}
|
}
|
||||||
|
|
||||||
int get_cpuid(char *buffer, size_t sz)
|
int get_cpuid(char *buffer, size_t sz, struct perf_cpu cpu __maybe_unused)
|
||||||
{
|
{
|
||||||
int ret = 0;
|
int ret = 0;
|
||||||
char *cpuid = _get_cpuid();
|
char *cpuid = _get_cpuid();
|
||||||
|
|
|
@ -24,7 +24,7 @@ static bool is_compat_mode(void)
|
||||||
}
|
}
|
||||||
|
|
||||||
int
|
int
|
||||||
get_cpuid(char *buffer, size_t sz)
|
get_cpuid(char *buffer, size_t sz, struct perf_cpu cpu __maybe_unused)
|
||||||
{
|
{
|
||||||
unsigned long pvr;
|
unsigned long pvr;
|
||||||
int nb;
|
int nb;
|
||||||
|
|
|
@ -81,7 +81,7 @@ static char *_get_cpuid(void)
|
||||||
return cpuid;
|
return cpuid;
|
||||||
}
|
}
|
||||||
|
|
||||||
int get_cpuid(char *buffer, size_t sz)
|
int get_cpuid(char *buffer, size_t sz, struct perf_cpu cpu __maybe_unused)
|
||||||
{
|
{
|
||||||
char *cpuid = _get_cpuid();
|
char *cpuid = _get_cpuid();
|
||||||
int ret = 0;
|
int ret = 0;
|
||||||
|
|
|
@ -27,7 +27,7 @@
|
||||||
#define SYSINFO "/proc/sysinfo"
|
#define SYSINFO "/proc/sysinfo"
|
||||||
#define SRVLVL "/proc/service_levels"
|
#define SRVLVL "/proc/service_levels"
|
||||||
|
|
||||||
int get_cpuid(char *buffer, size_t sz)
|
int get_cpuid(char *buffer, size_t sz, struct perf_cpu cpu __maybe_unused)
|
||||||
{
|
{
|
||||||
char *cp, *line = NULL, *line2;
|
char *cp, *line = NULL, *line2;
|
||||||
char type[8], model[33], version[8], manufacturer[32], authorization[8];
|
char type[8], model[33], version[8], manufacturer[32], authorization[8];
|
||||||
|
|
|
@ -55,11 +55,12 @@ struct auxtrace_record *auxtrace_record__init(struct evlist *evlist,
|
||||||
int *err)
|
int *err)
|
||||||
{
|
{
|
||||||
char buffer[64];
|
char buffer[64];
|
||||||
|
struct perf_cpu cpu = perf_cpu_map__min(evlist->core.all_cpus);
|
||||||
int ret;
|
int ret;
|
||||||
|
|
||||||
*err = 0;
|
*err = 0;
|
||||||
|
|
||||||
ret = get_cpuid(buffer, sizeof(buffer));
|
ret = get_cpuid(buffer, sizeof(buffer), cpu);
|
||||||
if (ret) {
|
if (ret) {
|
||||||
*err = ret;
|
*err = ret;
|
||||||
return NULL;
|
return NULL;
|
||||||
|
|
|
@ -58,7 +58,7 @@ __get_cpuid(char *buffer, size_t sz, const char *fmt)
|
||||||
}
|
}
|
||||||
|
|
||||||
int
|
int
|
||||||
get_cpuid(char *buffer, size_t sz)
|
get_cpuid(char *buffer, size_t sz, struct perf_cpu cpu __maybe_unused)
|
||||||
{
|
{
|
||||||
return __get_cpuid(buffer, sz, "%s,%u,%u,%u$");
|
return __get_cpuid(buffer, sz, "%s,%u,%u,%u$");
|
||||||
}
|
}
|
||||||
|
|
|
@ -1226,7 +1226,9 @@ static int cpu_isa_config(struct perf_kvm_stat *kvm)
|
||||||
int err;
|
int err;
|
||||||
|
|
||||||
if (kvm->live) {
|
if (kvm->live) {
|
||||||
err = get_cpuid(buf, sizeof(buf));
|
struct perf_cpu cpu = {-1};
|
||||||
|
|
||||||
|
err = get_cpuid(buf, sizeof(buf), cpu);
|
||||||
if (err != 0) {
|
if (err != 0) {
|
||||||
pr_err("Failed to look up CPU type: %s\n",
|
pr_err("Failed to look up CPU type: %s\n",
|
||||||
str_error_r(err, buf, sizeof(buf)));
|
str_error_r(err, buf, sizeof(buf)));
|
||||||
|
|
|
@ -373,7 +373,8 @@ int perf_env__read_pmu_mappings(struct perf_env *env)
|
||||||
int perf_env__read_cpuid(struct perf_env *env)
|
int perf_env__read_cpuid(struct perf_env *env)
|
||||||
{
|
{
|
||||||
char cpuid[128];
|
char cpuid[128];
|
||||||
int err = get_cpuid(cpuid, sizeof(cpuid));
|
struct perf_cpu cpu = {-1};
|
||||||
|
int err = get_cpuid(cpuid, sizeof(cpuid), cpu);
|
||||||
|
|
||||||
if (err)
|
if (err)
|
||||||
return err;
|
return err;
|
||||||
|
|
|
@ -856,18 +856,19 @@ int __weak strcmp_cpuid_str(const char *mapcpuid, const char *cpuid)
|
||||||
* default get_cpuid(): nothing gets recorded
|
* default get_cpuid(): nothing gets recorded
|
||||||
* actual implementation must be in arch/$(SRCARCH)/util/header.c
|
* actual implementation must be in arch/$(SRCARCH)/util/header.c
|
||||||
*/
|
*/
|
||||||
int __weak get_cpuid(char *buffer __maybe_unused, size_t sz __maybe_unused)
|
int __weak get_cpuid(char *buffer __maybe_unused, size_t sz __maybe_unused,
|
||||||
|
struct perf_cpu cpu __maybe_unused)
|
||||||
{
|
{
|
||||||
return ENOSYS; /* Not implemented */
|
return ENOSYS; /* Not implemented */
|
||||||
}
|
}
|
||||||
|
|
||||||
static int write_cpuid(struct feat_fd *ff,
|
static int write_cpuid(struct feat_fd *ff, struct evlist *evlist)
|
||||||
struct evlist *evlist __maybe_unused)
|
|
||||||
{
|
{
|
||||||
|
struct perf_cpu cpu = perf_cpu_map__min(evlist->core.all_cpus);
|
||||||
char buffer[64];
|
char buffer[64];
|
||||||
int ret;
|
int ret;
|
||||||
|
|
||||||
ret = get_cpuid(buffer, sizeof(buffer));
|
ret = get_cpuid(buffer, sizeof(buffer), cpu);
|
||||||
if (ret)
|
if (ret)
|
||||||
return -1;
|
return -1;
|
||||||
|
|
||||||
|
|
|
@ -201,7 +201,7 @@ int build_caches_for_cpu(u32 cpu, struct cpu_cache_level caches[], u32 *cntp);
|
||||||
/*
|
/*
|
||||||
* arch specific callback
|
* arch specific callback
|
||||||
*/
|
*/
|
||||||
int get_cpuid(char *buffer, size_t sz);
|
int get_cpuid(char *buffer, size_t sz, struct perf_cpu cpu);
|
||||||
|
|
||||||
char *get_cpuid_str(struct perf_pmu *pmu __maybe_unused);
|
char *get_cpuid_str(struct perf_pmu *pmu __maybe_unused);
|
||||||
int strcmp_cpuid_str(const char *s1, const char *s2);
|
int strcmp_cpuid_str(const char *s1, const char *s2);
|
||||||
|
|
Loading…
Reference in a new issue