From mboxrd@z Thu Jan 1 00:00:00 1970 Received: from mailman by lists.gnu.org with tmda-scanned (Exim 4.43) id 1LtIxB-0000rn-Ib for qemu-devel@nongnu.org; Mon, 13 Apr 2009 05:59:49 -0400 Received: from exim by lists.gnu.org with spam-scanned (Exim 4.43) id 1LtIx6-0000r2-Jw for qemu-devel@nongnu.org; Mon, 13 Apr 2009 05:59:48 -0400 Received: from [199.232.76.173] (port=50296 helo=monty-python.gnu.org) by lists.gnu.org with esmtp (Exim 4.43) id 1LtIx6-0000qz-8S for qemu-devel@nongnu.org; Mon, 13 Apr 2009 05:59:44 -0400 Received: from fmmailgate03.web.de ([217.72.192.234]:36474) by monty-python.gnu.org with esmtp (Exim 4.60) (envelope-from ) id 1LtIx5-0002eW-KE for qemu-devel@nongnu.org; Mon, 13 Apr 2009 05:59:44 -0400 Message-ID: <49E30D04.3090903@web.de> Date: Mon, 13 Apr 2009 11:59:32 +0200 From: Jan Kiszka MIME-Version: 1.0 References: <49E06754.8050906@web.de> In-Reply-To: <49E06754.8050906@web.de> Content-Type: multipart/signed; micalg=pgp-sha1; protocol="application/pgp-signature"; boundary="------------enig5A003EEE3020DCE125FE2D99" Sender: jan.kiszka@web.de Subject: [Qemu-devel] [PATCH v2] kvm: Fix overlapping check for memory slots Reply-To: qemu-devel@nongnu.org List-Id: qemu-devel.nongnu.org List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , To: Avi Kivity Cc: Glauber Costa , qemu-devel , kvm-devel This is an OpenPGP/MIME signed message (RFC 2440 and 3156) --------------enig5A003EEE3020DCE125FE2D99 Content-Type: text/plain; charset=ISO-8859-15 Content-Transfer-Encoding: quoted-printable When checking for overlapping slots on registration of a new one, kvm currently also considers zero-length (ie. deleted) slots and rejects requests incorrectly. This finally denies user space from joining slots. Fix the check by skipping deleted slots and advertise this via a KVM_CAP_JOIN_MEMORY_REGIONS_WORKS. Signed-off-by: Jan Kiszka --- include/linux/kvm.h | 2 ++ virt/kvm/kvm_main.c | 3 ++- 2 files changed, 4 insertions(+), 1 deletions(-) diff --git a/include/linux/kvm.h b/include/linux/kvm.h index ee755e2..644e3a9 100644 --- a/include/linux/kvm.h +++ b/include/linux/kvm.h @@ -413,6 +413,8 @@ struct kvm_trace_rec { #define KVM_CAP_DEVICE_MSIX 28 #endif #define KVM_CAP_ASSIGN_DEV_IRQ 29 +/* Another bug in KVM_SET_USER_MEMORY_REGION fixed: */ +#define KVM_CAP_JOIN_MEMORY_REGIONS_WORKS 30 =20 #ifdef KVM_CAP_IRQ_ROUTING =20 diff --git a/virt/kvm/kvm_main.c b/virt/kvm/kvm_main.c index 363af32..3265566 100644 --- a/virt/kvm/kvm_main.c +++ b/virt/kvm/kvm_main.c @@ -1117,7 +1117,7 @@ int __kvm_set_memory_region(struct kvm *kvm, for (i =3D 0; i < KVM_MEMORY_SLOTS; ++i) { struct kvm_memory_slot *s =3D &kvm->memslots[i]; =20 - if (s =3D=3D memslot) + if (s =3D=3D memslot || !s->npages) continue; if (!((base_gfn + npages <=3D s->base_gfn) || (base_gfn >=3D s->base_gfn + s->npages))) @@ -2262,6 +2262,7 @@ static long kvm_dev_ioctl_check_extension_generic(l= ong arg) switch (arg) { case KVM_CAP_USER_MEMORY: case KVM_CAP_DESTROY_MEMORY_REGION_WORKS: + case KVM_CAP_JOIN_MEMORY_REGIONS_WORKS: return 1; #ifdef CONFIG_HAVE_KVM_IRQCHIP case KVM_CAP_IRQ_ROUTING: --------------enig5A003EEE3020DCE125FE2D99 Content-Type: application/pgp-signature; name="signature.asc" Content-Description: OpenPGP digital signature Content-Disposition: attachment; filename="signature.asc" -----BEGIN PGP SIGNATURE----- Version: GnuPG v2.0.9 (GNU/Linux) Comment: Using GnuPG with SUSE - http://enigmail.mozdev.org iEYEARECAAYFAknjDQ0ACgkQniDOoMHTA+mVrgCfUmiQT84DsdYeH0S3RZbWSFyb AuAAniOeK/ugXV1QUOmbKOVb7pkJR8fg =5pOb -----END PGP SIGNATURE----- --------------enig5A003EEE3020DCE125FE2D99--