]> git.hungrycats.org Git - linux/commitdiff
x86/KVM/VMX: Add L1D MSR based flush
authorPaolo Bonzini <pbonzini@redhat.com>
Mon, 2 Jul 2018 11:03:48 +0000 (13:03 +0200)
committerGreg Kroah-Hartman <gregkh@linuxfoundation.org>
Wed, 15 Aug 2018 16:11:03 +0000 (18:11 +0200)
commit 3fa045be4c720146b18a19cea7a767dc6ad5df94 upstream

336996-Speculative-Execution-Side-Channel-Mitigations.pdf defines a new MSR
(IA32_FLUSH_CMD aka 0x10B) which has similar write-only semantics to other
MSRs defined in the document.

The semantics of this MSR is to allow "finer granularity invalidation of
caching structures than existing mechanisms like WBINVD. It will writeback
and invalidate the L1 data cache, including all cachelines brought in by
preceding instructions, without invalidating all caches (eg. L2 or
LLC). Some processors may also invalidate the first level level instruction
cache on a L1D_FLUSH command. The L1 data and instruction caches may be
shared across the logical processors of a core."

Use it instead of the loop based L1 flush algorithm.

A copy of this document is available at
   https://bugzilla.kernel.org/show_bug.cgi?id=199511

[ tglx: Avoid allocating pages when the MSR is available ]

Signed-off-by: Paolo Bonzini <pbonzini@redhat.com>
Signed-off-by: Konrad Rzeszutek Wilk <konrad.wilk@oracle.com>
Signed-off-by: Thomas Gleixner <tglx@linutronix.de>
Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
arch/x86/include/asm/msr-index.h
arch/x86/kvm/vmx.c

index fda2114197b36935558f0a376644dcd0a0c268ce..c5bcac4a0585bd5164acc9bd119b25075972bf44 100644 (file)
                                                    * control required.
                                                    */
 
+#define MSR_IA32_FLUSH_CMD             0x0000010b
+#define L1D_FLUSH                      (1 << 0)   /*
+                                                   * Writeback and invalidate the
+                                                   * L1 data cache.
+                                                   */
+
 #define MSR_IA32_BBL_CR_CTL            0x00000119
 #define MSR_IA32_BBL_CR_CTL3           0x0000011e
 
index 62c782f39e286cba5600a67104bbe589815c4943..6e1ba9a585a76ae260661ea7470e7a7959fc95c9 100644 (file)
@@ -9350,6 +9350,11 @@ static void __maybe_unused vmx_l1d_flush(void)
 {
        int size = PAGE_SIZE << L1D_CACHE_ORDER;
 
+       if (static_cpu_has(X86_FEATURE_FLUSH_L1D)) {
+               wrmsrl(MSR_IA32_FLUSH_CMD, L1D_FLUSH);
+               return;
+       }
+
        asm volatile(
                /* First ensure the pages are in the TLB */
                "xorl   %%eax, %%eax\n"
@@ -12977,11 +12982,13 @@ static int __init vmx_setup_l1d_flush(void)
            !boot_cpu_has_bug(X86_BUG_L1TF))
                return 0;
 
-       page = alloc_pages(GFP_KERNEL, L1D_CACHE_ORDER);
-       if (!page)
-               return -ENOMEM;
+       if (!boot_cpu_has(X86_FEATURE_FLUSH_L1D)) {
+               page = alloc_pages(GFP_KERNEL, L1D_CACHE_ORDER);
+               if (!page)
+                       return -ENOMEM;
+               vmx_l1d_flush_pages = page_address(page);
+       }
 
-       vmx_l1d_flush_pages = page_address(page);
        static_branch_enable(&vmx_l1d_should_flush);
        return 0;
 }