| From: |
| Sean Christopherson <seanjc-AT-google.com> |
| To: |
| Thomas Gleixner <tglx-AT-linutronix.de>, Ingo Molnar <mingo-AT-redhat.com>, Borislav Petkov <bp-AT-alien8.de>, Dave Hansen <dave.hansen-AT-linux.intel.com>, x86-AT-kernel.org, Sean Christopherson <seanjc-AT-google.com>, Paolo Bonzini <pbonzini-AT-redhat.com> |
| Subject: |
| [PATCH 0/7] x86, KVM: Optimize SEV cache flushing |
| Date: |
| Wed, 26 Feb 2025 17:48:51 -0800 |
| Message-ID: |
| <20250227014858.3244505-1-seanjc@google.com> |
| Cc: |
| linux-kernel-AT-vger.kernel.org, kvm-AT-vger.kernel.org, Zheyun Shen <szy0127-AT-sjtu.edu.cn>, Tom Lendacky <thomas.lendacky-AT-amd.com>, Kevin Loughlin <kevinloughlin-AT-google.com>, Mingwei Zhang <mizhang-AT-google.com> |
| Archive-link: |
| Article |
This is the combination of Kevin's WBNOINVD series[1] with Zheyun's targeted
flushing series[2]. This is very, very lightly tested (emphasis on "very").
Note, I dropped Reviewed-by tags for patches to which I made non-trivial
modifications.
[1] https://lore.kernel.org/all/20250201000259.3289143-1-kevi...
[2] https://lore.kernel.org/all/20250128015345.7929-1-szy0127...
Relative to those series:
- Name the WBNOINVD opcode macro ASM_WBNOINVD to avoid a conflict with
KVM's CPUID stuff.
- Fix issues with SMP=n.
- Define all helpers in x86/lib.
- Don't return 0 from the helpers.
- Rename the CPU bitmap to avoid a naming collisions with KVM's existing
pCPU bitmap for WBINVD, and to not have WBINVD (versus WBNOINVD) in the
name.
- Fix builds where CPU bitmaps are off-stack.
- Massage comments.
- Mark a CPU as having done VMRUN in pre_sev_run(), but test to see if
the CPU already ran to avoid the locked RMW, i.e. to (hopefully) avoid
bouncing the cache line.
Kevin Loughlin (2):
x86, lib: Add WBNOINVD helper functions
KVM: SEV: Prefer WBNOINVD over WBINVD for cache maintenance efficiency
Sean Christopherson (2):
x86, lib: Drop the unused return value from wbinvd_on_all_cpus()
KVM: x86: Use wbinvd_on_cpu() instead of an open-coded equivalent
Zheyun Shen (3):
KVM: SVM: Remove wbinvd in sev_vm_destroy()
x86, lib: Add wbinvd and wbnoinvd helpers to target multiple CPUs
KVM: SVM: Flush cache only on CPUs running SEV guest
arch/x86/include/asm/smp.h | 23 ++++++--
arch/x86/include/asm/special_insns.h | 19 ++++++-
arch/x86/kvm/svm/sev.c | 79 +++++++++++++++++++---------
arch/x86/kvm/svm/svm.h | 1 +
arch/x86/kvm/x86.c | 11 +---
arch/x86/lib/cache-smp.c | 26 ++++++++-
6 files changed, 119 insertions(+), 40 deletions(-)
base-commit: fed48e2967f402f561d80075a20c5c9e16866e53
--
2.48.1.711.g2feabab25a-goog