|
@@ -3480,11 +3480,11 @@ static void mmu_free_root_page(struct kvm *kvm, hpa_t *root_hpa,
|
|
|
}
|
|
|
|
|
|
/* roots_to_free must be some combination of the KVM_MMU_ROOT_* flags */
|
|
|
-void kvm_mmu_free_roots(struct kvm_vcpu *vcpu, ulong roots_to_free)
|
|
|
+void kvm_mmu_free_roots(struct kvm_vcpu *vcpu, struct kvm_mmu *mmu,
|
|
|
+ ulong roots_to_free)
|
|
|
{
|
|
|
int i;
|
|
|
LIST_HEAD(invalid_list);
|
|
|
- struct kvm_mmu *mmu = vcpu->arch.mmu;
|
|
|
bool free_active_root = roots_to_free & KVM_MMU_ROOT_CURRENT;
|
|
|
|
|
|
BUILD_BUG_ON(KVM_MMU_NUM_PREV_ROOTS >= BITS_PER_LONG);
|
|
@@ -4200,7 +4200,8 @@ static void __kvm_mmu_new_cr3(struct kvm_vcpu *vcpu, gpa_t new_cr3,
|
|
|
bool skip_tlb_flush)
|
|
|
{
|
|
|
if (!fast_cr3_switch(vcpu, new_cr3, new_role, skip_tlb_flush))
|
|
|
- kvm_mmu_free_roots(vcpu, KVM_MMU_ROOT_CURRENT);
|
|
|
+ kvm_mmu_free_roots(vcpu, vcpu->arch.mmu,
|
|
|
+ KVM_MMU_ROOT_CURRENT);
|
|
|
}
|
|
|
|
|
|
void kvm_mmu_new_cr3(struct kvm_vcpu *vcpu, gpa_t new_cr3, bool skip_tlb_flush)
|
|
@@ -4981,7 +4982,7 @@ EXPORT_SYMBOL_GPL(kvm_mmu_load);
|
|
|
|
|
|
void kvm_mmu_unload(struct kvm_vcpu *vcpu)
|
|
|
{
|
|
|
- kvm_mmu_free_roots(vcpu, KVM_MMU_ROOTS_ALL);
|
|
|
+ kvm_mmu_free_roots(vcpu, vcpu->arch.mmu, KVM_MMU_ROOTS_ALL);
|
|
|
WARN_ON(VALID_PAGE(vcpu->arch.mmu->root_hpa));
|
|
|
}
|
|
|
EXPORT_SYMBOL_GPL(kvm_mmu_unload);
|