diff options
author | Uri Lublin <uril@qumranet.com> | 2007-02-22 09:43:09 -0500 |
---|---|---|
committer | Avi Kivity <avi@qumranet.com> | 2007-03-04 04:12:42 -0500 |
commit | cd1a4a982a78e793125db2f386e91dc7c89c9ed1 (patch) | |
tree | 7e5e9dd9534feed9ecc83c147e2f6166a6edbc48 | |
parent | ab51a434c5816e1ca3f033791c1cc5c6594998ec (diff) |
KVM: Fix dirty page log bitmap size/access calculation
Since dirty_bitmap is an unsigned long array, the alignment and size need
to take that into account.
Signed-off-by: Uri Lublin <uril@qumranet.com>
Signed-off-by: Avi Kivity <avi@qumranet.com>
-rw-r--r-- | drivers/kvm/kvm_main.c | 4 |
1 files changed, 2 insertions, 2 deletions
diff --git a/drivers/kvm/kvm_main.c b/drivers/kvm/kvm_main.c index edff4055b32b..e7108105c50b 100644 --- a/drivers/kvm/kvm_main.c +++ b/drivers/kvm/kvm_main.c | |||
@@ -792,9 +792,9 @@ static int kvm_vm_ioctl_get_dirty_log(struct kvm *kvm, | |||
792 | if (!memslot->dirty_bitmap) | 792 | if (!memslot->dirty_bitmap) |
793 | goto out; | 793 | goto out; |
794 | 794 | ||
795 | n = ALIGN(memslot->npages, 8) / 8; | 795 | n = ALIGN(memslot->npages, BITS_PER_LONG) / 8; |
796 | 796 | ||
797 | for (i = 0; !any && i < n; ++i) | 797 | for (i = 0; !any && i < n/sizeof(long); ++i) |
798 | any = memslot->dirty_bitmap[i]; | 798 | any = memslot->dirty_bitmap[i]; |
799 | 799 | ||
800 | r = -EFAULT; | 800 | r = -EFAULT; |