]> git.ipfire.org Git - people/arne_f/kernel.git/commitdiff
arm/arm64: KVM: Take mmap_sem in stage2_unmap_vm
authorMarc Zyngier <marc.zyngier@arm.com>
Thu, 16 Mar 2017 18:20:49 +0000 (18:20 +0000)
committerMarc Zyngier <marc.zyngier@arm.com>
Mon, 20 Mar 2017 10:48:32 +0000 (10:48 +0000)
We don't hold the mmap_sem while searching for the VMAs when
we try to unmap each memslot for a VM. Fix this properly to
avoid unexpected results.

Fixes: commit 957db105c997 ("arm/arm64: KVM: Introduce stage2_unmap_vm")
Cc: stable@vger.kernel.org # v3.19+
Reviewed-by: Christoffer Dall <cdall@linaro.org>
Signed-off-by: Suzuki K Poulose <suzuki.poulose@arm.com>
Signed-off-by: Marc Zyngier <marc.zyngier@arm.com>
arch/arm/kvm/mmu.c

index 962616fd4ddd633289e98b99d99dea9fb758b820..f2e2e0c6d6fdfcc0d0926134f19d32826efe3b60 100644 (file)
@@ -803,6 +803,7 @@ void stage2_unmap_vm(struct kvm *kvm)
        int idx;
 
        idx = srcu_read_lock(&kvm->srcu);
+       down_read(&current->mm->mmap_sem);
        spin_lock(&kvm->mmu_lock);
 
        slots = kvm_memslots(kvm);
@@ -810,6 +811,7 @@ void stage2_unmap_vm(struct kvm *kvm)
                stage2_unmap_memslot(kvm, memslot);
 
        spin_unlock(&kvm->mmu_lock);
+       up_read(&current->mm->mmap_sem);
        srcu_read_unlock(&kvm->srcu, idx);
 }