]> git.ipfire.org Git - thirdparty/kernel/stable-queue.git/commitdiff
3.18-stable patches
authorGreg Kroah-Hartman <gregkh@linuxfoundation.org>
Mon, 6 Nov 2017 08:50:16 +0000 (09:50 +0100)
committerGreg Kroah-Hartman <gregkh@linuxfoundation.org>
Mon, 6 Nov 2017 08:50:16 +0000 (09:50 +0100)
added patches:
x86-microcode-intel-disable-late-loading-on-model-79.patch

queue-3.18/series
queue-3.18/x86-microcode-intel-disable-late-loading-on-model-79.patch [new file with mode: 0644]

index e0ca7258b996116f573c8eb042aeaac9d0551175..250f5f7535cf1bb11ee9b2b8811ef66a584fc743 100644 (file)
@@ -10,3 +10,4 @@ arm-8715-1-add-a-private-asm-unaligned.h.patch
 ocfs2-fstrim-fix-start-offset-of-first-cluster-group-during-fstrim.patch
 drm-msm-fix-potential-buffer-overflow-issue.patch
 drm-msm-fix-an-integer-overflow-test.patch
+x86-microcode-intel-disable-late-loading-on-model-79.patch
diff --git a/queue-3.18/x86-microcode-intel-disable-late-loading-on-model-79.patch b/queue-3.18/x86-microcode-intel-disable-late-loading-on-model-79.patch
new file mode 100644 (file)
index 0000000..1d9a9f0
--- /dev/null
@@ -0,0 +1,66 @@
+From 723f2828a98c8ca19842042f418fb30dd8cfc0f7 Mon Sep 17 00:00:00 2001
+From: Borislav Petkov <bp@suse.de>
+Date: Wed, 18 Oct 2017 13:12:25 +0200
+Subject: x86/microcode/intel: Disable late loading on model 79
+
+From: Borislav Petkov <bp@suse.de>
+
+commit 723f2828a98c8ca19842042f418fb30dd8cfc0f7 upstream.
+
+Blacklist Broadwell X model 79 for late loading due to an erratum.
+
+Signed-off-by: Borislav Petkov <bp@suse.de>
+Acked-by: Tony Luck <tony.luck@intel.com>
+Cc: Linus Torvalds <torvalds@linux-foundation.org>
+Cc: Peter Zijlstra <peterz@infradead.org>
+Cc: Thomas Gleixner <tglx@linutronix.de>
+Link: http://lkml.kernel.org/r/20171018111225.25635-1-bp@alien8.de
+Signed-off-by: Ingo Molnar <mingo@kernel.org>
+Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
+
+
+---
+ arch/x86/kernel/cpu/microcode/intel.c |   18 ++++++++++++++++++
+ 1 file changed, 18 insertions(+)
+
+--- a/arch/x86/kernel/cpu/microcode/intel.c
++++ b/arch/x86/kernel/cpu/microcode/intel.c
+@@ -267,6 +267,18 @@ static int get_ucode_fw(void *to, const
+       return 0;
+ }
++static bool is_blacklisted(unsigned int cpu)
++{
++      struct cpuinfo_x86 *c = &cpu_data(cpu);
++
++      if (c->x86 == 6 && c->x86_model == 79) {
++              pr_err_once("late loading on model 79 is disabled.\n");
++              return true;
++      }
++
++      return false;
++}
++
+ static enum ucode_state request_microcode_fw(int cpu, struct device *device,
+                                            bool refresh_fw)
+ {
+@@ -275,6 +287,9 @@ static enum ucode_state request_microcod
+       const struct firmware *firmware;
+       enum ucode_state ret;
++      if (is_blacklisted(cpu))
++              return UCODE_NFOUND;
++
+       sprintf(name, "intel-ucode/%02x-%02x-%02x",
+               c->x86, c->x86_model, c->x86_mask);
+@@ -299,6 +314,9 @@ static int get_ucode_user(void *to, cons
+ static enum ucode_state
+ request_microcode_user(int cpu, const void __user *buf, size_t size)
+ {
++      if (is_blacklisted(cpu))
++              return UCODE_NFOUND;
++
+       return generic_load_microcode(cpu, (void *)buf, size, &get_ucode_user);
+ }