Re: [PATCH 0/2] CPPC: reduce FFH feedback-counter sampling skew on arm64

From: zhangpengjie (A)

Date: Thu Apr 30 2026 - 06:10:31 EST


Hi all,

Gentle ping on this thread. It has been a while since I posted it.

Could someone please take a look when you have time? If there is anything
I should revise or any additional information needed, I'd be happy to
update it.

Thanks!

On 4/10/2026 5:41 PM, Pengjie Zhang wrote:
The legacy CPPC feedback-counter path reads the delivered and reference
performance counters separately.

On arm64 systems using AMU-backed CPPC FFH counters, each FFH read is
served through a cross-CPU counter read helper. Reading the counters
separately therefore widens the sampling window between them and can
skew the delivered/reference ratio used by cpuinfo_cur_freq. Under heavy
load, the skew is observable as transient values that may exceed the
platform maximum, as discussed in [1] and [2].

This series adds a small generic hook for architectures that can obtain
both FFH feedback counters in one operation, while preserving the
existing per-register read path as the fallback.

Patch 1 adds the generic CPPC hook and uses it from cppc_get_perf_ctrs().
Patch 2 implements the hook on arm64 by sampling both AMU counters in a
single operation on the target CPU.

[1] https://lore.kernel.org/all/20231025093847.3740104-4-zengheng4@xxxxxxxxxx/
[2] https://lore.kernel.org/all/20231212072617.14756-1-lihuisong@xxxxxxxxxx/

Signed-off-by: Pengjie Zhang <zhangpengjie2@xxxxxxxxxx>

Pengjie Zhang (2):
ACPI: CPPC: add paired FFH feedback-counter read hook
arm64: topology: read CPPC FFH feedback counters in one operation

arch/arm64/kernel/topology.c | 75 ++++++++++++++++++++++++++++++++----
drivers/acpi/cppc_acpi.c | 58 +++++++++++++++++++++++++---
include/acpi/cppc_acpi.h | 7 ++++
3 files changed, 127 insertions(+), 13 deletions(-)