]> pilppa.com Git - linux-2.6-omap-h63xx.git/commitdiff
KVM: ensure that memslot userspace addresses are page-aligned
authorHollis Blanchard <hollisb@us.ibm.com>
Fri, 7 Nov 2008 19:32:12 +0000 (13:32 -0600)
committerAvi Kivity <avi@redhat.com>
Wed, 31 Dec 2008 14:52:24 +0000 (16:52 +0200)
Bad page translation and silent guest failure ensue if the userspace address is
not page-aligned.  I hit this problem using large (host) pages with qemu,
because qemu currently has a hardcoded 4096-byte alignment for guest memory
allocations.

Signed-off-by: Hollis Blanchard <hollisb@us.ibm.com>
Signed-off-by: Avi Kivity <avi@redhat.com>
virt/kvm/kvm_main.c

index a65baa9039d5a8f3fb38741b78a35e6328cb9a08..0a0a9595ba3b2bb73c1774deca11ee138ec5ee6f 100644 (file)
@@ -715,6 +715,8 @@ int __kvm_set_memory_region(struct kvm *kvm,
                goto out;
        if (mem->guest_phys_addr & (PAGE_SIZE - 1))
                goto out;
+       if (mem->userspace_addr & (PAGE_SIZE - 1))
+               goto out;
        if (mem->slot >= KVM_MEMORY_SLOTS + KVM_PRIVATE_MEM_SLOTS)
                goto out;
        if (mem->guest_phys_addr + mem->memory_size < mem->guest_phys_addr)