x86: Make X86_BUG_FXSAVE_LEAK detectable in CPUID on AMD
authorRudolf Marek <r.marek@assembler.cz>
Tue, 28 Nov 2017 21:01:06 +0000 (22:01 +0100)
committerIngo Molnar <mingo@kernel.org>
Sun, 17 Dec 2017 12:55:02 +0000 (13:55 +0100)
commitf2dbad36c55e5d3a91dccbde6e8cae345fe5632f
treed66f74d28d8c2ebe4dac3a57bf4e11ca3fbe8ca1
parenta8b4db562e7283a1520f9e9730297ecaab7622ea
x86: Make X86_BUG_FXSAVE_LEAK detectable in CPUID on AMD

[ Note, this is a Git cherry-pick of the following commit:

    2b67799bdf25 ("x86: Make X86_BUG_FXSAVE_LEAK detectable in CPUID on AMD")

  ... for easier x86 PTI code testing and back-porting. ]

The latest AMD AMD64 Architecture Programmer's Manual
adds a CPUID feature XSaveErPtr (CPUID_Fn80000008_EBX[2]).

If this feature is set, the FXSAVE, XSAVE, FXSAVEOPT, XSAVEC, XSAVES
/ FXRSTOR, XRSTOR, XRSTORS always save/restore error pointers,
thus making the X86_BUG_FXSAVE_LEAK workaround obsolete on such CPUs.

Signed-Off-By: Rudolf Marek <r.marek@assembler.cz>
Signed-off-by: Thomas Gleixner <tglx@linutronix.de>
Reviewed-by: Borislav Petkov <bp@suse.de>
Tested-by: Borislav Petkov <bp@suse.de>
Cc: Andy Lutomirski <luto@amacapital.net>
Link: https://lkml.kernel.org/r/bdcebe90-62c5-1f05-083c-eba7f08b2540@assembler.cz
Signed-off-by: Ingo Molnar <mingo@kernel.org>
arch/x86/include/asm/cpufeatures.h
arch/x86/kernel/cpu/amd.c