• Sean Christopherson's avatar
    KVM: x86: Use __try_cmpxchg_user() to emulate atomic accesses · 1c2361f6
    Sean Christopherson authored
    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: 42e35f80 ("KVM/X86: Use kvm_vcpu_map in emulator_cmpxchg_emulated")
    Cc: stable@vger.kernel.org
    Signed-off-by: default avatarSean Christopherson <seanjc@google.com>
    Message-Id: <20220202004945.2540433-5-seanjc@google.com>
    Signed-off-by: default avatarPaolo Bonzini <pbonzini@redhat.com>
    1c2361f6
x86.c 341 KB