x86/aperfmperf: Make parts of the frequency invariance code unconditional
authorThomas Gleixner <tglx@linutronix.de>
Fri, 15 Apr 2022 19:19:59 +0000 (21:19 +0200)
committerThomas Gleixner <tglx@linutronix.de>
Wed, 27 Apr 2022 18:22:19 +0000 (20:22 +0200)
commitbb6e89df9028b2fab0ce6ac71cd9ef25b6ada32d
tree5440e10c14c8d2f32939a982f348ae83564b7b19
parent73a5fa7d51366a549a9f2e3ee875ae51aa0b5580
x86/aperfmperf: Make parts of the frequency invariance code unconditional

The frequency invariance support is currently limited to x86/64 and SMP,
which is the vast majority of machines.

arch_scale_freq_tick() is called every tick on all CPUs and reads the APERF
and MPERF MSRs. The CPU frequency getters function do the same via dedicated
IPIs.

While it could be argued that on systems where frequency invariance support
is disabled (32bit, !SMP) the per tick read of the APERF and MPERF MSRs can
be avoided, it does not make sense to keep the extra code and the resulting
runtime issues of mass IPIs around.

As a first step split out the non frequency invariance specific
initialization code and the read MSR portion of arch_scale_freq_tick(). The
rest of the code is still conditional and guarded with a static key.

Signed-off-by: Thomas Gleixner <tglx@linutronix.de>
Reviewed-by: Rafael J. Wysocki <rafael.j.wysocki@intel.com>
Acked-by: Peter Zijlstra (Intel) <peterz@infradead.org>
Acked-by: Paul E. McKenney <paulmck@kernel.org>
Link: https://lore.kernel.org/r/20220415161206.761988704@linutronix.de
arch/x86/include/asm/cpu.h
arch/x86/include/asm/topology.h
arch/x86/kernel/cpu/aperfmperf.c
arch/x86/kernel/smpboot.c