KVM: move postcommit flush to x86, as mmio sptes are x86 specific
authorMarcelo Tosatti <mtosatti@redhat.com>
Tue, 28 Aug 2012 20:43:26 +0000 (17:43 -0300)
committerAvi Kivity <avi@redhat.com>
Thu, 6 Sep 2012 13:37:30 +0000 (16:37 +0300)
Other arches do not need this.

Signed-off-by: Marcelo Tosatti <mtosatti@redhat.com>
v2: fix incorrect deletion of mmio sptes on gpa move (noticed by Takuya)
Signed-off-by: Avi Kivity <avi@redhat.com>
arch/x86/kvm/x86.c
virt/kvm/kvm_main.c

index 37797a0..6f6812e 100644 (file)
@@ -6445,6 +6445,14 @@ void kvm_arch_commit_memory_region(struct kvm *kvm,
                kvm_mmu_change_mmu_pages(kvm, nr_mmu_pages);
        kvm_mmu_slot_remove_write_access(kvm, mem->slot);
        spin_unlock(&kvm->mmu_lock);
+       /*
+        * If memory slot is created, or moved, we need to clear all
+        * mmio sptes.
+        */
+       if (npages && old.base_gfn != mem->guest_phys_addr >> PAGE_SHIFT) {
+               kvm_mmu_zap_all(kvm);
+               kvm_reload_remote_mmus(kvm);
+       }
 }
 
 void kvm_arch_flush_shadow_all(struct kvm *kvm)
index f41ea12..4fe02d9 100644 (file)
@@ -849,13 +849,6 @@ int __kvm_set_memory_region(struct kvm *kvm,
 
        kvm_arch_commit_memory_region(kvm, mem, old, user_alloc);
 
-       /*
-        * If the new memory slot is created, we need to clear all
-        * mmio sptes.
-        */
-       if (npages && old.base_gfn != mem->guest_phys_addr >> PAGE_SHIFT)
-               kvm_arch_flush_shadow_all(kvm);
-
        kvm_free_physmem_slot(&old, &new);
        kfree(old_memslots);