aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorUri Lublin <uril@qumranet.com>2007-02-22 09:43:09 -0500
committerAvi Kivity <avi@qumranet.com>2007-03-04 04:12:42 -0500
commitcd1a4a982a78e793125db2f386e91dc7c89c9ed1 (patch)
tree7e5e9dd9534feed9ecc83c147e2f6166a6edbc48
parentab51a434c5816e1ca3f033791c1cc5c6594998ec (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.c4
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;