diff options
author | Takuya Yoshikawa <yoshikawa.takuya@oss.ntt.co.jp> | 2012-07-02 04:57:17 -0400 |
---|---|---|
committer | Marcelo Tosatti <mtosatti@redhat.com> | 2012-07-18 15:55:04 -0400 |
commit | 77d11309b3a10e1ce112058ec2c9b7b979bcf311 (patch) | |
tree | 295d8d2adea1e2b68eac599263b963059fecf3a5 /arch/x86/kvm/x86.c | |
parent | b3ae2096974b12c3af2ad1a4e7716b084949867f (diff) |
KVM: Separate rmap_pde from kvm_lpage_info->write_count
This makes it possible to loop over rmap_pde arrays in the same way as
we do over rmap so that we can optimize kvm_handle_hva_range() easily in
the following patch.
Signed-off-by: Takuya Yoshikawa <yoshikawa.takuya@oss.ntt.co.jp>
Signed-off-by: Marcelo Tosatti <mtosatti@redhat.com>
Diffstat (limited to 'arch/x86/kvm/x86.c')
-rw-r--r-- | arch/x86/kvm/x86.c | 11 |
1 files changed, 11 insertions, 0 deletions
diff --git a/arch/x86/kvm/x86.c b/arch/x86/kvm/x86.c index 59b59508ff07..829b4e972558 100644 --- a/arch/x86/kvm/x86.c +++ b/arch/x86/kvm/x86.c | |||
@@ -6314,6 +6314,10 @@ void kvm_arch_free_memslot(struct kvm_memory_slot *free, | |||
6314 | int i; | 6314 | int i; |
6315 | 6315 | ||
6316 | for (i = 0; i < KVM_NR_PAGE_SIZES - 1; ++i) { | 6316 | for (i = 0; i < KVM_NR_PAGE_SIZES - 1; ++i) { |
6317 | if (!dont || free->arch.rmap_pde[i] != dont->arch.rmap_pde[i]) { | ||
6318 | kvm_kvfree(free->arch.rmap_pde[i]); | ||
6319 | free->arch.rmap_pde[i] = NULL; | ||
6320 | } | ||
6317 | if (!dont || free->arch.lpage_info[i] != dont->arch.lpage_info[i]) { | 6321 | if (!dont || free->arch.lpage_info[i] != dont->arch.lpage_info[i]) { |
6318 | kvm_kvfree(free->arch.lpage_info[i]); | 6322 | kvm_kvfree(free->arch.lpage_info[i]); |
6319 | free->arch.lpage_info[i] = NULL; | 6323 | free->arch.lpage_info[i] = NULL; |
@@ -6333,6 +6337,11 @@ int kvm_arch_create_memslot(struct kvm_memory_slot *slot, unsigned long npages) | |||
6333 | lpages = gfn_to_index(slot->base_gfn + npages - 1, | 6337 | lpages = gfn_to_index(slot->base_gfn + npages - 1, |
6334 | slot->base_gfn, level) + 1; | 6338 | slot->base_gfn, level) + 1; |
6335 | 6339 | ||
6340 | slot->arch.rmap_pde[i] = | ||
6341 | kvm_kvzalloc(lpages * sizeof(*slot->arch.rmap_pde[i])); | ||
6342 | if (!slot->arch.rmap_pde[i]) | ||
6343 | goto out_free; | ||
6344 | |||
6336 | slot->arch.lpage_info[i] = | 6345 | slot->arch.lpage_info[i] = |
6337 | kvm_kvzalloc(lpages * sizeof(*slot->arch.lpage_info[i])); | 6346 | kvm_kvzalloc(lpages * sizeof(*slot->arch.lpage_info[i])); |
6338 | if (!slot->arch.lpage_info[i]) | 6347 | if (!slot->arch.lpage_info[i]) |
@@ -6361,7 +6370,9 @@ int kvm_arch_create_memslot(struct kvm_memory_slot *slot, unsigned long npages) | |||
6361 | 6370 | ||
6362 | out_free: | 6371 | out_free: |
6363 | for (i = 0; i < KVM_NR_PAGE_SIZES - 1; ++i) { | 6372 | for (i = 0; i < KVM_NR_PAGE_SIZES - 1; ++i) { |
6373 | kvm_kvfree(slot->arch.rmap_pde[i]); | ||
6364 | kvm_kvfree(slot->arch.lpage_info[i]); | 6374 | kvm_kvfree(slot->arch.lpage_info[i]); |
6375 | slot->arch.rmap_pde[i] = NULL; | ||
6365 | slot->arch.lpage_info[i] = NULL; | 6376 | slot->arch.lpage_info[i] = NULL; |
6366 | } | 6377 | } |
6367 | return -ENOMEM; | 6378 | return -ENOMEM; |