]> git.baikalelectronics.ru Git - kernel.git/commit
xen/setup: filter APERFMPERF cpuid feature out
authorAndre Przywara <andre.przywara@amd.com>
Tue, 29 May 2012 11:07:31 +0000 (13:07 +0200)
committerKonrad Rzeszutek Wilk <konrad.wilk@oracle.com>
Thu, 31 May 2012 16:16:52 +0000 (12:16 -0400)
commit6f0464da1ecb83c0a8854e74732baeff8cfac5ec
tree3518e8efbca67bcd44d922b7c3ef758ffee6fbd0
parentd1c87d9ab22d6e8cc12e2adcea522b7276be8bed
xen/setup: filter APERFMPERF cpuid feature out

Xen PV kernels allow access to the APERF/MPERF registers to read the
effective frequency. Access to the MSRs is however redirected to the
currently scheduled physical CPU, making consecutive read and
compares unreliable. In addition each rdmsr traps into the hypervisor.
So to avoid bogus readouts and expensive traps, disable the kernel
internal feature flag for APERF/MPERF if running under Xen.
This will
a) remove the aperfmperf flag from /proc/cpuinfo
b) not mislead the power scheduler (arch/x86/kernel/cpu/sched.c) to
   use the feature to improve scheduling (by default disabled)
c) not mislead the cpufreq driver to use the MSRs

This does not cover userland programs which access the MSRs via the
device file interface, but this will be addressed separately.

Signed-off-by: Andre Przywara <andre.przywara@amd.com>
Cc: stable@vger.kernel.org # v3.0+
Signed-off-by: Konrad Rzeszutek Wilk <konrad.wilk@oracle.com>
arch/x86/xen/enlighten.c