aboutsummaryrefslogtreecommitdiffstats
path: root/virt
diff options
context:
space:
mode:
authorPaolo Bonzini <pbonzini@redhat.com>2014-12-27 15:08:16 -0500
committerPaolo Bonzini <pbonzini@redhat.com>2014-12-28 04:01:25 -0500
commitdbaff30940d6ef9bfa5f1f0c819cf3344ed3129f (patch)
tree16bea1eb47bf7e59fc917e03390fc3d263614ccc /virt
parentefbeec7098eee2b3d2359d0cc24bbba0436e7f21 (diff)
kvm: warn on more invariant breakage
Modifying a non-existent slot is not allowed. Also check that the first loop doesn't move a deleted slot beyond the used part of the mslots array. Signed-off-by: Paolo Bonzini <pbonzini@redhat.com>
Diffstat (limited to 'virt')
-rw-r--r--virt/kvm/kvm_main.c4
1 files changed, 3 insertions, 1 deletions
diff --git a/virt/kvm/kvm_main.c b/virt/kvm/kvm_main.c
index 050974c051b5..1cc6e2e19982 100644
--- a/virt/kvm/kvm_main.c
+++ b/virt/kvm/kvm_main.c
@@ -671,6 +671,7 @@ static void update_memslots(struct kvm_memslots *slots,
671 671
672 WARN_ON(mslots[i].id != id); 672 WARN_ON(mslots[i].id != id);
673 if (!new->npages) { 673 if (!new->npages) {
674 WARN_ON(!mslots[i].npages);
674 new->base_gfn = 0; 675 new->base_gfn = 0;
675 if (mslots[i].npages) 676 if (mslots[i].npages)
676 slots->used_slots--; 677 slots->used_slots--;
@@ -704,7 +705,8 @@ static void update_memslots(struct kvm_memslots *slots,
704 slots->id_to_index[mslots[i].id] = i; 705 slots->id_to_index[mslots[i].id] = i;
705 i--; 706 i--;
706 } 707 }
707 } 708 } else
709 WARN_ON_ONCE(i != slots->used_slots);
708 710
709 mslots[i] = *new; 711 mslots[i] = *new;
710 slots->id_to_index[mslots[i].id] = i; 712 slots->id_to_index[mslots[i].id] = i;