]> git.baikalelectronics.ru Git - kernel.git/commit
KVM: x86: Use __try_cmpxchg_user() to emulate atomic accesses
authorSean Christopherson <seanjc@google.com>
Wed, 2 Feb 2022 00:49:44 +0000 (00:49 +0000)
committerPaolo Bonzini <pbonzini@redhat.com>
Wed, 13 Apr 2022 17:37:48 +0000 (13:37 -0400)
commit88de71c2a24754be213b526482be3fb831d600c9
treee8871f26641bb43d6070002f354b0e1fcd2eeea2
parentfcd8882c35349ea82a9bd6c1295ed17bccb270e6
KVM: x86: Use __try_cmpxchg_user() to emulate atomic accesses

Use the recently introduce __try_cmpxchg_user() to emulate atomic guest
accesses via the associated userspace address instead of mapping the
backing pfn into kernel address space.  Using kvm_vcpu_map() is unsafe as
it does not coordinate with KVM's mmu_notifier to ensure the hva=>pfn
translation isn't changed/unmapped in the memremap() path, i.e. when
there's no struct page and thus no elevated refcount.

Fixes: 11102148530d ("KVM/X86: Use kvm_vcpu_map in emulator_cmpxchg_emulated")
Cc: stable@vger.kernel.org
Signed-off-by: Sean Christopherson <seanjc@google.com>
Message-Id: <20220202004945.2540433-5-seanjc@google.com>
Signed-off-by: Paolo Bonzini <pbonzini@redhat.com>
arch/x86/kvm/x86.c