|
@@ -2863,13 +2863,16 @@ EXPORT_SYMBOL_GPL(kvm_mmu_unprotect_page_virt);
|
|
|
|
|
|
void __kvm_mmu_free_some_pages(struct kvm_vcpu *vcpu)
|
|
|
{
|
|
|
- while (vcpu->kvm->arch.n_free_mmu_pages < KVM_REFILL_PAGES &&
|
|
|
+ int free_pages;
|
|
|
+
|
|
|
+ free_pages = vcpu->kvm->arch.n_free_mmu_pages;
|
|
|
+ while (free_pages < KVM_REFILL_PAGES &&
|
|
|
!list_empty(&vcpu->kvm->arch.active_mmu_pages)) {
|
|
|
struct kvm_mmu_page *sp;
|
|
|
|
|
|
sp = container_of(vcpu->kvm->arch.active_mmu_pages.prev,
|
|
|
struct kvm_mmu_page, link);
|
|
|
- kvm_mmu_zap_page(vcpu->kvm, sp);
|
|
|
+ free_pages += kvm_mmu_zap_page(vcpu->kvm, sp);
|
|
|
++vcpu->kvm->stat.mmu_recycled;
|
|
|
}
|
|
|
}
|