|
@@ -630,6 +630,19 @@ static int kvm_create_dirty_bitmap(struct kvm_memory_slot *memslot)
|
|
}
|
|
}
|
|
#endif /* !CONFIG_S390 */
|
|
#endif /* !CONFIG_S390 */
|
|
|
|
|
|
|
|
+void update_memslots(struct kvm_memslots *slots, struct kvm_memory_slot *new)
|
|
|
|
+{
|
|
|
|
+ if (new) {
|
|
|
|
+ int id = new->id;
|
|
|
|
+
|
|
|
|
+ slots->memslots[id] = *new;
|
|
|
|
+ if (id >= slots->nmemslots)
|
|
|
|
+ slots->nmemslots = id + 1;
|
|
|
|
+ }
|
|
|
|
+
|
|
|
|
+ slots->generation++;
|
|
|
|
+}
|
|
|
|
+
|
|
/*
|
|
/*
|
|
* Allocate some memory and give it an address in the guest physical address
|
|
* Allocate some memory and give it an address in the guest physical address
|
|
* space.
|
|
* space.
|
|
@@ -780,10 +793,8 @@ skip_lpage:
|
|
GFP_KERNEL);
|
|
GFP_KERNEL);
|
|
if (!slots)
|
|
if (!slots)
|
|
goto out_free;
|
|
goto out_free;
|
|
- if (mem->slot >= slots->nmemslots)
|
|
|
|
- slots->nmemslots = mem->slot + 1;
|
|
|
|
- slots->generation++;
|
|
|
|
slots->memslots[mem->slot].flags |= KVM_MEMSLOT_INVALID;
|
|
slots->memslots[mem->slot].flags |= KVM_MEMSLOT_INVALID;
|
|
|
|
+ update_memslots(slots, NULL);
|
|
|
|
|
|
old_memslots = kvm->memslots;
|
|
old_memslots = kvm->memslots;
|
|
rcu_assign_pointer(kvm->memslots, slots);
|
|
rcu_assign_pointer(kvm->memslots, slots);
|
|
@@ -815,9 +826,6 @@ skip_lpage:
|
|
GFP_KERNEL);
|
|
GFP_KERNEL);
|
|
if (!slots)
|
|
if (!slots)
|
|
goto out_free;
|
|
goto out_free;
|
|
- if (mem->slot >= slots->nmemslots)
|
|
|
|
- slots->nmemslots = mem->slot + 1;
|
|
|
|
- slots->generation++;
|
|
|
|
|
|
|
|
/* actual memory is freed via old in kvm_free_physmem_slot below */
|
|
/* actual memory is freed via old in kvm_free_physmem_slot below */
|
|
if (!npages) {
|
|
if (!npages) {
|
|
@@ -827,7 +835,7 @@ skip_lpage:
|
|
new.lpage_info[i] = NULL;
|
|
new.lpage_info[i] = NULL;
|
|
}
|
|
}
|
|
|
|
|
|
- slots->memslots[mem->slot] = new;
|
|
|
|
|
|
+ update_memslots(slots, &new);
|
|
old_memslots = kvm->memslots;
|
|
old_memslots = kvm->memslots;
|
|
rcu_assign_pointer(kvm->memslots, slots);
|
|
rcu_assign_pointer(kvm->memslots, slots);
|
|
synchronize_srcu_expedited(&kvm->srcu);
|
|
synchronize_srcu_expedited(&kvm->srcu);
|