]> git.proxmox.com Git - mirror_ubuntu-artful-kernel.git/commitdiff
UBUNTU: SAUCE: Fix spec_ctrl support in KVM
authorStefan Bader <stefan.bader@canonical.com>
Wed, 17 Jan 2018 14:31:00 +0000 (15:31 +0100)
committerKhalid Elmously <khalid.elmously@canonical.com>
Fri, 9 Feb 2018 20:14:47 +0000 (20:14 +0000)
CVE-2017-5715 (Spectre v2 Intel)

Initial change was missing code to correctly mask EDX bits of cpuid
level 7.0.

Fixes: 8339cae ("KVM: x86: Add speculative control CPUID support for guests")
Signed-off-by: Stefan Bader <stefan.bader@canonical.com>
Acked-by: Kleber Sacilotto de Souza <kleber.souza@canonical.com>
Acked-by: Khalid Elmously <khalid.elmously@canonical.com>
Signed-off-by: Kleber Sacilotto de Souza <kleber.souza@canonical.com>
Signed-off-by: Andy Whitcroft <apw@canonical.com>
Acked-by: Colin Ian King <colin.king@canonical.com>
Acked-by: Kamal Mostafa <kamal@canonical.com>
Signed-off-by: Khalid Elmously <khalid.elmously@canonical.com>
arch/x86/kvm/cpuid.c

index 44a990ce4f983bc0696c85cf4493e42aafc1161f..d192f150996f6e97f81090fd3d1b4481c2a19212 100644 (file)
@@ -361,6 +361,10 @@ static inline int __do_cpuid_ent(struct kvm_cpuid_entry2 *entry, u32 function,
                F(ADX) | F(SMAP) | F(AVX512F) | F(AVX512PF) | F(AVX512ER) |
                F(AVX512CD) | F(CLFLUSHOPT) | F(CLWB) | F(PCOMMIT);
 
+       /* cpuid 7.0.edx */
+       const u32 kvm_supported_7_0_edx_x86_features =
+               KF(SPEC_CTRL);
+
        /* cpuid 0xD.1.eax */
        const u32 kvm_supported_word10_x86_features =
                F(XSAVEOPT) | F(XSAVEC) | F(XGETBV1) | f_xsaves;
@@ -446,11 +450,14 @@ static inline int __do_cpuid_ent(struct kvm_cpuid_entry2 *entry, u32 function,
                        cpuid_mask(&entry->ebx, 9);
                        // TSC_ADJUST is emulated
                        entry->ebx |= F(TSC_ADJUST);
-               } else
+                       entry->edx &= kvm_supported_7_0_edx_x86_features;
+                       entry->edx &= get_scattered_cpuid_leaf(7, 0, 2);
+               } else {
                        entry->ebx = 0;
+                       entry->edx = 0;
+               }
                entry->eax = 0;
                entry->ecx = 0;
-               entry->edx = 0;
                break;
        }
        case 9: