[<prev] [next>] [<thread-prev] [day] [month] [year] [list]
Message-ID: <20251118155813.533424-4-darcari@redhat.com>
Date: Tue, 18 Nov 2025 10:58:13 -0500
From: David Arcari <darcari@...hat.com>
To: lenb@...nel.org
Cc: linux-pm@...r.kernel.org,
linux-kernel@...r.kernel.org,
David Arcari <darcari@...hat.com>
Subject: [PATCH 3/3] tools/power turbostat: allow turbostat to work when aperf is not available
Currently when aperf is not available the function has_amperf() still
returns true. The end result is that the program gets an error in
delta_thread() which causes turbostat to restart. We can avoid this
by not setting msr_counter_arch_infos[MSR_ARCH_INFO_APERF_INDEX].present
when aperf is not available allowing turbostat to execute normally.
Signed-off-by: David Arcari <darcari@...hat.com>
Cc: Len Brown <lenb@...nel.org>
Cc: linux-kernel@...r.kernel.org
---
tools/power/x86/turbostat/turbostat.c | 4 ++++
1 file changed, 4 insertions(+)
diff --git a/tools/power/x86/turbostat/turbostat.c b/tools/power/x86/turbostat/turbostat.c
index 5567b9ecd516..b3f1e4ae5813 100644
--- a/tools/power/x86/turbostat/turbostat.c
+++ b/tools/power/x86/turbostat/turbostat.c
@@ -8592,6 +8592,10 @@ void msr_perf_init_(void)
continue;
if (cai->needed) {
+ /* check to see if APERF is available */
+ if (cidx == MSR_ARCH_INFO_APERF_INDEX && !has_aperf)
+ continue;
+
/* Use perf API for this counter */
if (add_msr_perf_counter(cpu, cci, cai) != -1) {
cci->source[cai->rci_index] = COUNTER_SOURCE_PERF;
--
2.51.0
Powered by blists - more mailing lists