]> www.infradead.org Git - users/jedix/linux-maple.git/commit
cpupower: fix TSC MHz calculation
authorHe Rongguang <herongguang@linux.alibaba.com>
Thu, 12 Dec 2024 02:14:59 +0000 (10:14 +0800)
committerShuah Khan <skhan@linuxfoundation.org>
Mon, 16 Dec 2024 20:57:12 +0000 (13:57 -0700)
commit9d6c0e58514f8b57cd9c2c755e41623d6a966025
treed41f46a59c3b97a826db98752040faccf8c8d3ed
parent46fd8c707b552c0a846917192f66e623bb03f976
cpupower: fix TSC MHz calculation

Commit 'cpupower: Make TSC read per CPU for Mperf monitor' (c2adb1877b7)
changes TSC counter reads per cpu, but left time diff global (from start
of all cpus to end of all cpus), thus diff(time) is too large for a
cpu's tsc counting, resulting in far less than acutal TSC_Mhz and thus
`cpupower monitor` showing far less than actual cpu realtime frequency.

/proc/cpuinfo shows frequency:
cat /proc/cpuinfo | egrep -e 'processor' -e 'MHz'
...
processor : 171
cpu MHz   : 4108.498
...

before fix (System 100% busy):
    | Mperf              || Idle_Stats
 CPU| C0   | Cx   | Freq  || POLL | C1   | C2
 171|  0.77| 99.23|  2279||  0.00|  0.00|  0.00

after fix (System 100% busy):
    | Mperf              || Idle_Stats
 CPU| C0   | Cx   | Freq  || POLL | C1   | C2
 171|  0.46| 99.54|  4095||  0.00|  0.00|  0.00

Fixes: c2adb1877b76 ("cpupower: Make TSC read per CPU for Mperf monitor")
Signed-off-by: He Rongguang <herongguang@linux.alibaba.com>
Signed-off-by: Shuah Khan <skhan@linuxfoundation.org>
tools/power/cpupower/utils/idle_monitor/mperf_monitor.c