diff options
author | Sean Christopherson <sean.j.christopherson@intel.com> | 2020-09-23 11:37:28 -0700 |
---|---|---|
committer | Paolo Bonzini <pbonzini@redhat.com> | 2020-09-28 07:57:39 -0400 |
commit | e89505698c9f70125651060547da4ff5046124fc (patch) | |
tree | bd0f93bb678fa4edf6700244a5f7180094642440 /arch/x86/oprofile | |
parent | 5a085326d51d0c92bc5c1f62d60dcf3db450af69 (diff) | |
download | lwn-e89505698c9f70125651060547da4ff5046124fc.tar.gz lwn-e89505698c9f70125651060547da4ff5046124fc.zip |
KVM: x86/mmu: Commit zap of remaining invalid pages when recovering lpages
Call kvm_mmu_commit_zap_page() after exiting the "prepare zap" loop in
kvm_recover_nx_lpages() to finish zapping pages in the unlikely event
that the loop exited due to lpage_disallowed_mmu_pages being empty.
Because the recovery thread drops mmu_lock() when rescheduling, it's
possible that lpage_disallowed_mmu_pages could be emptied by a different
thread without to_zap reaching zero despite to_zap being derived from
the number of disallowed lpages.
Fixes: 1aa9b9572b105 ("kvm: x86: mmu: Recovery of shattered NX large pages")
Cc: Junaid Shahid <junaids@google.com>
Cc: stable@vger.kernel.org
Signed-off-by: Sean Christopherson <sean.j.christopherson@intel.com>
Message-Id: <20200923183735.584-2-sean.j.christopherson@intel.com>
Signed-off-by: Paolo Bonzini <pbonzini@redhat.com>
Diffstat (limited to 'arch/x86/oprofile')
0 files changed, 0 insertions, 0 deletions