]> git.baikalelectronics.ru Git - kernel.git/commit
x86, amd: Disable way access filter on Piledriver CPUs
authorAndre Przywara <andre.przywara@amd.com>
Wed, 31 Oct 2012 16:20:50 +0000 (17:20 +0100)
committerH. Peter Anvin <hpa@linux.intel.com>
Wed, 31 Oct 2012 20:06:55 +0000 (13:06 -0700)
commit68682e9e7dd2283c2579d5f1595a8a5a4665abb8
tree93ebbaf9397d1b78dfdf5db80e9ac3bf0ebb5bae
parentf63f584ef9896d11589b07433db09d0f261c9d3f
x86, amd: Disable way access filter on Piledriver CPUs

The Way Access Filter in recent AMD CPUs may hurt the performance of
some workloads, caused by aliasing issues in the L1 cache.
This patch disables it on the affected CPUs.

The issue is similar to that one of last year:
http://lkml.indiana.edu/hypermail/linux/kernel/1107.3/00041.html
This new patch does not replace the old one, we just need another
quirk for newer CPUs.

The performance penalty without the patch depends on the
circumstances, but is a bit less than the last year's 3%.

The workloads affected would be those that access code from the same
physical page under different virtual addresses, so different
processes using the same libraries with ASLR or multiple instances of
PIE-binaries. The code needs to be accessed simultaneously from both
cores of the same compute unit.

More details can be found here:
http://developer.amd.com/Assets/SharedL1InstructionCacheonAMD15hCPU.pdf

CPUs affected are anything with the core known as Piledriver.
That includes the new parts of the AMD A-Series (aka Trinity) and the
just released new CPUs of the FX-Series (aka Vishera).
The model numbering is a bit odd here: FX CPUs have model 2,
A-Series has model 10h, with possible extensions to 1Fh. Hence the
range of model ids.

Signed-off-by: Andre Przywara <osp@andrep.de>
Link: http://lkml.kernel.org/r/1351700450-9277-1-git-send-email-osp@andrep.de
Signed-off-by: H. Peter Anvin <hpa@linux.intel.com>
arch/x86/kernel/cpu/amd.c