From mboxrd@z Thu Jan 1 00:00:00 1970 Received: from eggs.gnu.org ([208.118.235.92]:58949) by lists.gnu.org with esmtp (Exim 4.71) (envelope-from ) id 1UZag1-000870-Bn for qemu-devel@nongnu.org; Tue, 07 May 2013 01:43:02 -0400 Received: from Debian-exim by eggs.gnu.org with spam-scanned (Exim 4.71) (envelope-from ) id 1UZafz-0005jE-OQ for qemu-devel@nongnu.org; Tue, 07 May 2013 01:43:01 -0400 Received: from mx1.redhat.com ([209.132.183.28]:61321) by eggs.gnu.org with esmtp (Exim 4.71) (envelope-from ) id 1UZafz-0005iv-GX for qemu-devel@nongnu.org; Tue, 07 May 2013 01:42:59 -0400 Message-ID: <51889457.3090609@redhat.com> Date: Tue, 07 May 2013 13:42:47 +0800 From: Jason Wang MIME-Version: 1.0 References: <1366965244-20542-1-git-send-email-jasowang@redhat.com> <1366965244-20542-2-git-send-email-jasowang@redhat.com> <20130428083239.GD7106@redhat.com> <517CE073.1090506@redhat.com> In-Reply-To: <517CE073.1090506@redhat.com> Content-Type: text/plain; charset=ISO-8859-1 Content-Transfer-Encoding: 7bit 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: "Michael S. Tsirkin" Cc: aliguori@us.ibm.com, pmatouse@redhat.com, Alexander Graf , qemu-devel@nongnu.org, Cornelia Huck , Richard Henderson On 04/28/2013 04:40 PM, Jason Wang wrote: > On 04/28/2013 04:32 PM, Michael S. Tsirkin wrote: >> 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? > Ok, this looks more clear. Will do it in V2. Recheck the code, looks like {get|set}_config() has been validated in virtio_bus_get_vdev_config(). So the codes were ok here, will drop this patch also. >>> --- >>> 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 >