summaryrefslogtreecommitdiffstats
path: root/virt/kvm/kvm_main.c
diff options
context:
space:
mode:
authorMarcelo Tosatti <mtosatti@redhat.com>2009-05-12 18:55:44 -0300
committerAvi Kivity <avi@redhat.com>2009-06-10 11:48:54 +0300
commitb43b1901ad282aeb74161837fb403927102687a1 (patch)
tree43b1b4537e620ce5c148e739c7588a279e76d7a5 /virt/kvm/kvm_main.c
parent7c8a83b75a38a807d37f5a4398eca2a42c8cf513 (diff)
downloadlinux-b43b1901ad282aeb74161837fb403927102687a1.tar.gz
linux-b43b1901ad282aeb74161837fb403927102687a1.tar.bz2
linux-b43b1901ad282aeb74161837fb403927102687a1.zip
KVM: take mmu_lock when updating a deleted slot
kvm_handle_hva relies on mmu_lock protection to safely access the memslot structures. Signed-off-by: Marcelo Tosatti <mtosatti@redhat.com> Signed-off-by: Avi Kivity <avi@redhat.com>
Diffstat (limited to 'virt/kvm/kvm_main.c')
-rw-r--r--virt/kvm/kvm_main.c2
1 files changed, 2 insertions, 0 deletions
diff --git a/virt/kvm/kvm_main.c b/virt/kvm/kvm_main.c
index 687d113a3e5e..5fed9bfc3cf5 100644
--- a/virt/kvm/kvm_main.c
+++ b/virt/kvm/kvm_main.c
@@ -1210,8 +1210,10 @@ int __kvm_set_memory_region(struct kvm *kvm,
kvm_free_physmem_slot(&old, npages ? &new : NULL);
/* Slot deletion case: we have to update the current slot */
+ spin_lock(&kvm->mmu_lock);
if (!npages)
*memslot = old;
+ spin_unlock(&kvm->mmu_lock);
#ifdef CONFIG_DMAR
/* map the pages in iommu page table */
r = kvm_iommu_map_pages(kvm, base_gfn, npages);