diff options
-rw-r--r-- | arch/ia64/kvm/kvm-ia64.c | 6 | ||||
-rw-r--r-- | arch/x86/kvm/mmu.c | 12 | ||||
-rw-r--r-- | include/linux/kvm_host.h | 4 | ||||
-rw-r--r-- | virt/kvm/iommu.c | 17 | ||||
-rw-r--r-- | virt/kvm/kvm_main.c | 14 |
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 | */ |
3986 | unsigned int kvm_mmu_calculate_mmu_pages(struct kvm *kvm) | 3986 | unsigned 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 | |||
311 | int kvm_vcpu_init(struct kvm_vcpu *vcpu, struct kvm *kvm, unsigned id); | 315 | int kvm_vcpu_init(struct kvm_vcpu *vcpu, struct kvm *kvm, unsigned id); |
312 | void kvm_vcpu_uninit(struct kvm_vcpu *vcpu); | 316 | void 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 | ||
135 | static int kvm_iommu_map_memslots(struct kvm *kvm) | 135 | static 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 | ||
312 | static int kvm_iommu_unmap_memslots(struct kvm *kvm) | 313 | static 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 | ||
548 | void kvm_free_physmem(struct kvm *kvm) | 548 | void 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); | |||
975 | static struct kvm_memory_slot *__gfn_to_memslot(struct kvm_memslots *slots, | 975 | static 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 | ||