]> git.proxmox.com Git - pve-kernel.git/blame - patches/kernel/0240-x86-cpu-x86-pti-Do-not-enable-PTI-on-AMD-processors.patch
build: reformat existing patches
[pve-kernel.git] / patches / kernel / 0240-x86-cpu-x86-pti-Do-not-enable-PTI-on-AMD-processors.patch
CommitLineData
59d5af67 1From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001
04f3b8be
FG
2From: Tom Lendacky <thomas.lendacky@amd.com>
3Date: Tue, 26 Dec 2017 23:43:54 -0600
59d5af67 4Subject: [PATCH] x86/cpu, x86/pti: Do not enable PTI on AMD processors
04f3b8be
FG
5MIME-Version: 1.0
6Content-Type: text/plain; charset=UTF-8
7Content-Transfer-Encoding: 8bit
8
9CVE-2017-5754
10
11AMD processors are not subject to the types of attacks that the kernel
12page table isolation feature protects against. The AMD microarchitecture
13does not allow memory references, including speculative references, that
14access higher privileged data when running in a lesser privileged mode
15when that access would result in a page fault.
16
17Disable page table isolation by default on AMD processors by not setting
18the X86_BUG_CPU_INSECURE feature, which controls whether X86_FEATURE_PTI
19is set.
20
21Signed-off-by: Tom Lendacky <thomas.lendacky@amd.com>
22Signed-off-by: Thomas Gleixner <tglx@linutronix.de>
23Reviewed-by: Borislav Petkov <bp@suse.de>
24Cc: Dave Hansen <dave.hansen@linux.intel.com>
25Cc: Andy Lutomirski <luto@kernel.org>
26Cc: stable@vger.kernel.org
27Link: https://lkml.kernel.org/r/20171227054354.20369.94587.stgit@tlendack-t1.amdoffice.net
28
29(cherry picked from commit 694d99d40972f12e59a3696effee8a376b79d7c8)
30Signed-off-by: Marcelo Henrique Cerri <marcelo.cerri@canonical.com>
31(cherry picked from commit 9d334f48f017b9c6457c6ba321e5a53a1cc6a5c7)
32Signed-off-by: Fabian Grünbichler <f.gruenbichler@proxmox.com>
33---
34 arch/x86/kernel/cpu/common.c | 4 ++--
35 1 file changed, 2 insertions(+), 2 deletions(-)
36
37diff --git a/arch/x86/kernel/cpu/common.c b/arch/x86/kernel/cpu/common.c
38index 99f37d1636ff..1854dd8071a6 100644
39--- a/arch/x86/kernel/cpu/common.c
40+++ b/arch/x86/kernel/cpu/common.c
41@@ -899,8 +899,8 @@ static void __init early_identify_cpu(struct cpuinfo_x86 *c)
42
43 setup_force_cpu_cap(X86_FEATURE_ALWAYS);
44
45- /* Assume for now that ALL x86 CPUs are insecure */
46- setup_force_cpu_bug(X86_BUG_CPU_INSECURE);
47+ if (c->x86_vendor != X86_VENDOR_AMD)
48+ setup_force_cpu_bug(X86_BUG_CPU_INSECURE);
49
50 fpu__init_system(c);
51 }
52--
532.14.2
54