aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--arch/ia64/kvm/kvm-ia64.c6
-rw-r--r--arch/x86/kvm/mmu.c12
-rw-r--r--include/linux/kvm_host.h4
-rw-r--r--virt/kvm/iommu.c17
-rw-r--r--virt/kvm/kvm_main.c14
5 files changed, 27 insertions, 26 deletions
diff --git a/arch/ia64/kvm/kvm-ia64.c b/arch/ia64/kvm/kvm-ia64.c
index 43f4c92816ef..42ad1f9c9f01 100644
--- a/arch/ia64/kvm/kvm-ia64.c
+++ b/arch/ia64/kvm/kvm-ia64.c
@@ -1366,14 +1366,12 @@ static void kvm_release_vm_pages(struct kvm *kvm)
1366{ 1366{
1367 struct kvm_memslots *slots; 1367 struct kvm_memslots *slots;
1368 struct kvm_memory_slot *memslot; 1368 struct kvm_memory_slot *memslot;
1369 int i, j; 1369 int j;
1370 unsigned long base_gfn; 1370 unsigned long base_gfn;
1371 1371
1372 slots = kvm_memslots(kvm); 1372 slots = kvm_memslots(kvm);
1373 for (i = 0; i < slots->nmemslots; i++) { 1373 kvm_for_each_memslot(memslot, slots) {
1374 memslot = &slots->memslots[i];
1375 base_gfn = memslot->base_gfn; 1374 base_gfn = memslot->base_gfn;
1376
1377 for (j = 0; j < memslot->npages; j++) { 1375 for (j = 0; j < memslot->npages; j++) {
1378 if (memslot->rmap[j]) 1376 if (memslot->rmap[j])
1379 put_page((struct page *)memslot->rmap[j]); 1377 put_page((struct page *)memslot->rmap[j]);
diff --git a/arch/x86/kvm/mmu.c b/arch/x86/kvm/mmu.c
index 715dcb4fb798..d737443cdfdb 100644
--- a/arch/x86/kvm/mmu.c
+++ b/arch/x86/kvm/mmu.c
@@ -1128,15 +1128,15 @@ static int kvm_handle_hva(struct kvm *kvm, unsigned long hva,
1128 int (*handler)(struct kvm *kvm, unsigned long *rmapp, 1128 int (*handler)(struct kvm *kvm, unsigned long *rmapp,
1129 unsigned long data)) 1129 unsigned long data))
1130{ 1130{
1131 int i, j; 1131 int j;
1132 int ret; 1132 int ret;
1133 int retval = 0; 1133 int retval = 0;
1134 struct kvm_memslots *slots; 1134 struct kvm_memslots *slots;
1135 struct kvm_memory_slot *memslot;
1135 1136
1136 slots = kvm_memslots(kvm); 1137 slots = kvm_memslots(kvm);
1137 1138
1138 for (i = 0; i < slots->nmemslots; i++) { 1139 kvm_for_each_memslot(memslot, slots) {
1139 struct kvm_memory_slot *memslot = &slots->memslots[i];
1140 unsigned long start = memslot->userspace_addr; 1140 unsigned long start = memslot->userspace_addr;
1141 unsigned long end; 1141 unsigned long end;
1142 1142
@@ -3985,15 +3985,15 @@ nomem:
3985 */ 3985 */
3986unsigned int kvm_mmu_calculate_mmu_pages(struct kvm *kvm) 3986unsigned int kvm_mmu_calculate_mmu_pages(struct kvm *kvm)
3987{ 3987{
3988 int i;
3989 unsigned int nr_mmu_pages; 3988 unsigned int nr_mmu_pages;
3990 unsigned int nr_pages = 0; 3989 unsigned int nr_pages = 0;
3991 struct kvm_memslots *slots; 3990 struct kvm_memslots *slots;
3991 struct kvm_memory_slot *memslot;
3992 3992
3993 slots = kvm_memslots(kvm); 3993 slots = kvm_memslots(kvm);
3994 3994
3995 for (i = 0; i < slots->nmemslots; i++) 3995 kvm_for_each_memslot(memslot, slots)
3996 nr_pages += slots->memslots[i].npages; 3996 nr_pages += memslot->npages;
3997 3997
3998 nr_mmu_pages = nr_pages * KVM_PERMILLE_MMU_PAGES / 1000; 3998 nr_mmu_pages = nr_pages * KVM_PERMILLE_MMU_PAGES / 1000;
3999 nr_mmu_pages = max(nr_mmu_pages, 3999 nr_mmu_pages = max(nr_mmu_pages,
diff --git a/include/linux/kvm_host.h b/include/linux/kvm_host.h
index 23f795c66220..392af47a4353 100644
--- a/include/linux/kvm_host.h
+++ b/include/linux/kvm_host.h
@@ -308,6 +308,10 @@ static inline struct kvm_vcpu *kvm_get_vcpu(struct kvm *kvm, int i)
308 (vcpup = kvm_get_vcpu(kvm, idx)) != NULL; \ 308 (vcpup = kvm_get_vcpu(kvm, idx)) != NULL; \
309 idx++) 309 idx++)
310 310
311#define kvm_for_each_memslot(memslot, slots) \
312 for (memslot = &slots->memslots[0]; \
313 memslot < slots->memslots + (slots)->nmemslots; memslot++)
314
311int kvm_vcpu_init(struct kvm_vcpu *vcpu, struct kvm *kvm, unsigned id); 315int kvm_vcpu_init(struct kvm_vcpu *vcpu, struct kvm *kvm, unsigned id);
312void kvm_vcpu_uninit(struct kvm_vcpu *vcpu); 316void kvm_vcpu_uninit(struct kvm_vcpu *vcpu);
313 317
diff --git a/virt/kvm/iommu.c b/virt/kvm/iommu.c
index a195c07fa829..4e5f7b7f1d2b 100644
--- a/virt/kvm/iommu.c
+++ b/virt/kvm/iommu.c
@@ -134,14 +134,15 @@ unmap_pages:
134 134
135static int kvm_iommu_map_memslots(struct kvm *kvm) 135static int kvm_iommu_map_memslots(struct kvm *kvm)
136{ 136{
137 int i, idx, r = 0; 137 int idx, r = 0;
138 struct kvm_memslots *slots; 138 struct kvm_memslots *slots;
139 struct kvm_memory_slot *memslot;
139 140
140 idx = srcu_read_lock(&kvm->srcu); 141 idx = srcu_read_lock(&kvm->srcu);
141 slots = kvm_memslots(kvm); 142 slots = kvm_memslots(kvm);
142 143
143 for (i = 0; i < slots->nmemslots; i++) { 144 kvm_for_each_memslot(memslot, slots) {
144 r = kvm_iommu_map_pages(kvm, &slots->memslots[i]); 145 r = kvm_iommu_map_pages(kvm, memslot);
145 if (r) 146 if (r)
146 break; 147 break;
147 } 148 }
@@ -311,16 +312,16 @@ static void kvm_iommu_put_pages(struct kvm *kvm,
311 312
312static int kvm_iommu_unmap_memslots(struct kvm *kvm) 313static int kvm_iommu_unmap_memslots(struct kvm *kvm)
313{ 314{
314 int i, idx; 315 int idx;
315 struct kvm_memslots *slots; 316 struct kvm_memslots *slots;
317 struct kvm_memory_slot *memslot;
316 318
317 idx = srcu_read_lock(&kvm->srcu); 319 idx = srcu_read_lock(&kvm->srcu);
318 slots = kvm_memslots(kvm); 320 slots = kvm_memslots(kvm);
319 321
320 for (i = 0; i < slots->nmemslots; i++) { 322 kvm_for_each_memslot(memslot, slots)
321 kvm_iommu_put_pages(kvm, slots->memslots[i].base_gfn, 323 kvm_iommu_put_pages(kvm, memslot->base_gfn, memslot->npages);
322 slots->memslots[i].npages); 324
323 }
324 srcu_read_unlock(&kvm->srcu, idx); 325 srcu_read_unlock(&kvm->srcu, idx);
325 326
326 return 0; 327 return 0;
diff --git a/virt/kvm/kvm_main.c b/virt/kvm/kvm_main.c
index b5ed7770ced3..4c2900c5d81d 100644
--- a/virt/kvm/kvm_main.c
+++ b/virt/kvm/kvm_main.c
@@ -547,11 +547,11 @@ static void kvm_free_physmem_slot(struct kvm_memory_slot *free,
547 547
548void kvm_free_physmem(struct kvm *kvm) 548void kvm_free_physmem(struct kvm *kvm)
549{ 549{
550 int i;
551 struct kvm_memslots *slots = kvm->memslots; 550 struct kvm_memslots *slots = kvm->memslots;
551 struct kvm_memory_slot *memslot;
552 552
553 for (i = 0; i < slots->nmemslots; ++i) 553 kvm_for_each_memslot(memslot, slots)
554 kvm_free_physmem_slot(&slots->memslots[i], NULL); 554 kvm_free_physmem_slot(memslot, NULL);
555 555
556 kfree(kvm->memslots); 556 kfree(kvm->memslots);
557} 557}
@@ -975,15 +975,13 @@ EXPORT_SYMBOL_GPL(kvm_is_error_hva);
975static struct kvm_memory_slot *__gfn_to_memslot(struct kvm_memslots *slots, 975static struct kvm_memory_slot *__gfn_to_memslot(struct kvm_memslots *slots,
976 gfn_t gfn) 976 gfn_t gfn)
977{ 977{
978 int i; 978 struct kvm_memory_slot *memslot;
979
980 for (i = 0; i < slots->nmemslots; ++i) {
981 struct kvm_memory_slot *memslot = &slots->memslots[i];
982 979
980 kvm_for_each_memslot(memslot, slots)
983 if (gfn >= memslot->base_gfn 981 if (gfn >= memslot->base_gfn
984 && gfn < memslot->base_gfn + memslot->npages) 982 && gfn < memslot->base_gfn + memslot->npages)
985 return memslot; 983 return memslot;
986 } 984
987 return NULL; 985 return NULL;
988} 986}
989 987