| /* SPDX-License-Identifier: GPL-2.0-only */ |
| /* |
| * KVM L1 hypervisor optimizations on Hyper-V. |
| */ |
| |
| #ifndef __ARCH_X86_KVM_KVM_ONHYPERV_H__ |
| #define __ARCH_X86_KVM_KVM_ONHYPERV_H__ |
| |
| #if IS_ENABLED(CONFIG_HYPERV) |
| int hv_flush_remote_tlbs_range(struct kvm *kvm, gfn_t gfn, gfn_t nr_pages); |
| int hv_flush_remote_tlbs(struct kvm *kvm); |
| void hv_track_root_tdp(struct kvm_vcpu *vcpu, hpa_t root_tdp); |
| static inline hpa_t hv_get_partition_assist_page(struct kvm_vcpu *vcpu) |
| { |
| /* |
| * Partition assist page is something which Hyper-V running in L0 |
| * requires from KVM running in L1 before direct TLB flush for L2 |
| * guests can be enabled. KVM doesn't currently use the page but to |
| * comply with TLFS it still needs to be allocated. For now, this |
| * is a single page shared among all vCPUs. |
| */ |
| struct hv_partition_assist_pg **p_hv_pa_pg = |
| &vcpu->kvm->arch.hv_pa_pg; |
| |
| if (!*p_hv_pa_pg) |
| *p_hv_pa_pg = kzalloc(PAGE_SIZE, GFP_KERNEL_ACCOUNT); |
| |
| if (!*p_hv_pa_pg) |
| return INVALID_PAGE; |
| |
| return __pa(*p_hv_pa_pg); |
| } |
| #else /* !CONFIG_HYPERV */ |
| static inline int hv_flush_remote_tlbs(struct kvm *kvm) |
| { |
| return -EOPNOTSUPP; |
| } |
| |
| static inline void hv_track_root_tdp(struct kvm_vcpu *vcpu, hpa_t root_tdp) |
| { |
| } |
| #endif /* !CONFIG_HYPERV */ |
| |
| #endif |