diff options
-rw-r--r-- | arch/x86/kvm/mmu.c | 12 | ||||
-rw-r--r-- | virt/kvm/kvm_main.c | 7 |
2 files changed, 9 insertions, 10 deletions
diff --git a/arch/x86/kvm/mmu.c b/arch/x86/kvm/mmu.c index f02b8edc3d44..ccacf0b1b540 100644 --- a/arch/x86/kvm/mmu.c +++ b/arch/x86/kvm/mmu.c | |||
@@ -3538,14 +3538,18 @@ void kvm_mmu_slot_remove_write_access(struct kvm *kvm, int slot) | |||
3538 | if (!test_bit(slot, sp->slot_bitmap)) | 3538 | if (!test_bit(slot, sp->slot_bitmap)) |
3539 | continue; | 3539 | continue; |
3540 | 3540 | ||
3541 | if (sp->role.level != PT_PAGE_TABLE_LEVEL) | ||
3542 | continue; | ||
3543 | |||
3544 | pt = sp->spt; | 3541 | pt = sp->spt; |
3545 | for (i = 0; i < PT64_ENT_PER_PAGE; ++i) | 3542 | for (i = 0; i < PT64_ENT_PER_PAGE; ++i) { |
3543 | if (sp->role.level != PT_PAGE_TABLE_LEVEL | ||
3544 | && is_large_pte(pt[i])) { | ||
3545 | drop_spte(kvm, &pt[i], | ||
3546 | shadow_trap_nonpresent_pte); | ||
3547 | --kvm->stat.lpages; | ||
3548 | } | ||
3546 | /* avoid RMW */ | 3549 | /* avoid RMW */ |
3547 | if (is_writable_pte(pt[i])) | 3550 | if (is_writable_pte(pt[i])) |
3548 | update_spte(&pt[i], pt[i] & ~PT_WRITABLE_MASK); | 3551 | update_spte(&pt[i], pt[i] & ~PT_WRITABLE_MASK); |
3552 | } | ||
3549 | } | 3553 | } |
3550 | kvm_flush_remote_tlbs(kvm); | 3554 | kvm_flush_remote_tlbs(kvm); |
3551 | } | 3555 | } |
diff --git a/virt/kvm/kvm_main.c b/virt/kvm/kvm_main.c index f29abeb6a912..a3a8f5fb369e 100644 --- a/virt/kvm/kvm_main.c +++ b/virt/kvm/kvm_main.c | |||
@@ -621,7 +621,7 @@ int __kvm_set_memory_region(struct kvm *kvm, | |||
621 | struct kvm_userspace_memory_region *mem, | 621 | struct kvm_userspace_memory_region *mem, |
622 | int user_alloc) | 622 | int user_alloc) |
623 | { | 623 | { |
624 | int r, flush_shadow = 0; | 624 | int r; |
625 | gfn_t base_gfn; | 625 | gfn_t base_gfn; |
626 | unsigned long npages; | 626 | unsigned long npages; |
627 | unsigned long i; | 627 | unsigned long i; |
@@ -741,8 +741,6 @@ skip_lpage: | |||
741 | if (kvm_create_dirty_bitmap(&new) < 0) | 741 | if (kvm_create_dirty_bitmap(&new) < 0) |
742 | goto out_free; | 742 | goto out_free; |
743 | /* destroy any largepage mappings for dirty tracking */ | 743 | /* destroy any largepage mappings for dirty tracking */ |
744 | if (old.npages) | ||
745 | flush_shadow = 1; | ||
746 | } | 744 | } |
747 | #else /* not defined CONFIG_S390 */ | 745 | #else /* not defined CONFIG_S390 */ |
748 | new.user_alloc = user_alloc; | 746 | new.user_alloc = user_alloc; |
@@ -813,9 +811,6 @@ skip_lpage: | |||
813 | kvm_free_physmem_slot(&old, &new); | 811 | kvm_free_physmem_slot(&old, &new); |
814 | kfree(old_memslots); | 812 | kfree(old_memslots); |
815 | 813 | ||
816 | if (flush_shadow) | ||
817 | kvm_arch_flush_shadow(kvm); | ||
818 | |||
819 | return 0; | 814 | return 0; |
820 | 815 | ||
821 | out_free: | 816 | out_free: |