From mboxrd@z Thu Jan 1 00:00:00 1970 Received: from eggs.gnu.org ([208.118.235.92]:48435) by lists.gnu.org with esmtp (Exim 4.71) (envelope-from ) id 1UWN2W-0004EZ-FF for qemu-devel@nongnu.org; Sun, 28 Apr 2013 04:33:00 -0400 Received: from Debian-exim by eggs.gnu.org with spam-scanned (Exim 4.71) (envelope-from ) id 1UWN2T-0006sX-Vn for qemu-devel@nongnu.org; Sun, 28 Apr 2013 04:32:56 -0400 Received: from mx1.redhat.com ([209.132.183.28]:54662) by eggs.gnu.org with esmtp (Exim 4.71) (envelope-from ) id 1UWN2T-0006sQ-Mr for qemu-devel@nongnu.org; Sun, 28 Apr 2013 04:32:53 -0400 Date: Sun, 28 Apr 2013 11:32:39 +0300 From: "Michael S. Tsirkin" Message-ID: <20130428083239.GD7106@redhat.com> References: <1366965244-20542-1-git-send-email-jasowang@redhat.com> <1366965244-20542-2-git-send-email-jasowang@redhat.com> MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: <1366965244-20542-2-git-send-email-jasowang@redhat.com> Subject: Re: [Qemu-devel] [PATCH 2/3] virtio-ccw: check config length before accessing it List-Id: List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , To: Jason Wang Cc: aliguori@us.ibm.com, pmatouse@redhat.com, Alexander Graf , qemu-devel@nongnu.org, Cornelia Huck , Richard Henderson On Fri, Apr 26, 2013 at 04:34:03PM +0800, Jason Wang wrote: > virtio-rng-ccw has zero config length, so we need validate the config length > before trying to access it. Otherwise we may crash since vdev->config is NULL. > > Cc: Cornelia Huck > Cc: Richard Henderson > Cc: Alexander Graf > Signed-off-by: Jason Wang The real problem is dev->vdev->get_config being NULL, isn't it? So why not validate it and be done with it? > --- > hw/s390x/virtio-ccw.c | 4 ++-- > 1 files changed, 2 insertions(+), 2 deletions(-) > > diff --git a/hw/s390x/virtio-ccw.c b/hw/s390x/virtio-ccw.c > index 56539d3..8d0dff5 100644 > --- a/hw/s390x/virtio-ccw.c > +++ b/hw/s390x/virtio-ccw.c > @@ -260,7 +260,7 @@ static int virtio_ccw_cb(SubchDev *sch, CCW1 ccw) > } > } > len = MIN(ccw.count, dev->vdev->config_len); > - if (!ccw.cda) { > + if (!ccw.cda || !len) { > ret = -EFAULT; > } else { > dev->vdev->get_config(dev->vdev, dev->vdev->config); > @@ -279,7 +279,7 @@ static int virtio_ccw_cb(SubchDev *sch, CCW1 ccw) > } > len = MIN(ccw.count, dev->vdev->config_len); > hw_len = len; > - if (!ccw.cda) { > + if (!ccw.cda || !len) { > ret = -EFAULT; > } else { > config = cpu_physical_memory_map(ccw.cda, &hw_len, 0); > -- > 1.7.1