Skip to content

Commit 7239ed7

Browse files
committed
KVM: remove kvm_arch_gmem_prepare_needed()
It is enough to return 0 if a guest need not do any preparation. This is in fact how sev_gmem_prepare() works for non-SNP guests, and it extends naturally to Intel hosts: the x86 callback for gmem_prepare is optional and returns 0 if not defined. Reviewed-by: Michael Roth <[email protected]> Signed-off-by: Paolo Bonzini <[email protected]>
1 parent 6dd761d commit 7239ed7

File tree

3 files changed

+3
-16
lines changed

3 files changed

+3
-16
lines changed

arch/x86/kvm/x86.c

Lines changed: 0 additions & 5 deletions
Original file line numberDiff line numberDiff line change
@@ -13645,11 +13645,6 @@ bool kvm_arch_no_poll(struct kvm_vcpu *vcpu)
1364513645
EXPORT_SYMBOL_GPL(kvm_arch_no_poll);
1364613646

1364713647
#ifdef CONFIG_HAVE_KVM_ARCH_GMEM_PREPARE
13648-
bool kvm_arch_gmem_prepare_needed(struct kvm *kvm)
13649-
{
13650-
return kvm->arch.vm_type == KVM_X86_SNP_VM;
13651-
}
13652-
1365313648
int kvm_arch_gmem_prepare(struct kvm *kvm, gfn_t gfn, kvm_pfn_t pfn, int max_order)
1365413649
{
1365513650
return kvm_x86_call(gmem_prepare)(kvm, pfn, gfn, max_order);

include/linux/kvm_host.h

Lines changed: 0 additions & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -2447,7 +2447,6 @@ static inline int kvm_gmem_get_pfn(struct kvm *kvm,
24472447

24482448
#ifdef CONFIG_HAVE_KVM_ARCH_GMEM_PREPARE
24492449
int kvm_arch_gmem_prepare(struct kvm *kvm, gfn_t gfn, kvm_pfn_t pfn, int max_order);
2450-
bool kvm_arch_gmem_prepare_needed(struct kvm *kvm);
24512450
#endif
24522451

24532452
/**

virt/kvm/guest_memfd.c

Lines changed: 3 additions & 10 deletions
Original file line numberDiff line numberDiff line change
@@ -29,16 +29,9 @@ static int __kvm_gmem_prepare_folio(struct kvm *kvm, struct kvm_memory_slot *slo
2929
pgoff_t index, struct folio *folio)
3030
{
3131
#ifdef CONFIG_HAVE_KVM_ARCH_GMEM_PREPARE
32-
kvm_pfn_t pfn;
33-
gfn_t gfn;
34-
int rc;
35-
36-
if (!kvm_arch_gmem_prepare_needed(kvm))
37-
return 0;
38-
39-
pfn = folio_file_pfn(folio, index);
40-
gfn = slot->base_gfn + index - slot->gmem.pgoff;
41-
rc = kvm_arch_gmem_prepare(kvm, gfn, pfn, folio_order(folio));
32+
kvm_pfn_t pfn = folio_file_pfn(folio, index);
33+
gfn_t gfn = slot->base_gfn + index - slot->gmem.pgoff;
34+
int rc = kvm_arch_gmem_prepare(kvm, gfn, pfn, folio_order(folio));
4235
if (rc) {
4336
pr_warn_ratelimited("gmem: Failed to prepare folio for index %lx GFN %llx PFN %llx error %d.\n",
4437
index, gfn, pfn, rc);

0 commit comments

Comments
 (0)