Commit 28e4b459 authored by David Matlack's avatar David Matlack Committed by Sean Christopherson

KVM: x86/mmu: Collapse kvm_flush_remote_tlbs_with_{range,address}() together

Collapse kvm_flush_remote_tlbs_with_range() and
kvm_flush_remote_tlbs_with_address() into a single function. This
eliminates some lines of code and a useless NULL check on the range
struct.

Opportunistically switch from ENOTSUPP to EOPNOTSUPP to make checkpatch
happy.
Signed-off-by: default avatarDavid Matlack <dmatlack@google.com>
Link: https://lore.kernel.org/r/20230126184025.2294823-4-dmatlack@google.comSigned-off-by: default avatarSean Christopherson <seanjc@google.com>
parent 141705b7
...@@ -261,27 +261,20 @@ static inline bool kvm_available_flush_tlb_with_range(void) ...@@ -261,27 +261,20 @@ static inline bool kvm_available_flush_tlb_with_range(void)
return kvm_x86_ops.tlb_remote_flush_with_range; return kvm_x86_ops.tlb_remote_flush_with_range;
} }
static void kvm_flush_remote_tlbs_with_range(struct kvm *kvm,
struct kvm_tlb_range *range)
{
int ret = -ENOTSUPP;
if (range && kvm_x86_ops.tlb_remote_flush_with_range)
ret = static_call(kvm_x86_tlb_remote_flush_with_range)(kvm, range);
if (ret)
kvm_flush_remote_tlbs(kvm);
}
void kvm_flush_remote_tlbs_with_address(struct kvm *kvm, void kvm_flush_remote_tlbs_with_address(struct kvm *kvm,
u64 start_gfn, u64 pages) u64 start_gfn, u64 pages)
{ {
struct kvm_tlb_range range; struct kvm_tlb_range range;
int ret = -EOPNOTSUPP;
range.start_gfn = start_gfn; range.start_gfn = start_gfn;
range.pages = pages; range.pages = pages;
kvm_flush_remote_tlbs_with_range(kvm, &range); if (kvm_x86_ops.tlb_remote_flush_with_range)
ret = static_call(kvm_x86_tlb_remote_flush_with_range)(kvm, &range);
if (ret)
kvm_flush_remote_tlbs(kvm);
} }
static gfn_t kvm_mmu_page_get_gfn(struct kvm_mmu_page *sp, int index); static gfn_t kvm_mmu_page_get_gfn(struct kvm_mmu_page *sp, int index);
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment