Received: by 2002:a05:6a10:9848:0:0:0:0 with SMTP id x8csp71448pxf; Wed, 10 Mar 2021 00:14:49 -0800 (PST) X-Google-Smtp-Source: ABdhPJzPs1ew2Bu7EY1OqbQ2Vv7/uV9FsrjMXJ9UcMdYrjfpGg6m05XOm2f6Vz2Ag3lRkHEBnJY/ X-Received: by 2002:a17:906:405b:: with SMTP id y27mr2442731ejj.332.1615364088971; Wed, 10 Mar 2021 00:14:48 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1615364088; cv=none; d=google.com; s=arc-20160816; b=m7oGkc9f5mjqqTXAocriu7FZY0FPeb3wd/1vmOHGwzRg25K9N7MTVBwYvybkPRvTIv BvcJTv5uH98PN5yax6tp4rzNj8j57ilKV9nVhui7pmJZgopLeHm8yPGlWGhixEEJUGLZ E23yfh9PbBuOjReeZwS/rYltkDye+chd24SIpFhVj4GyDZaLNvddRQyEOd11MTaIrE+o OOg0XM6lE4PWP8PJrDNv0SLtLKN+6PYmUApGg5IOlKJYB9193IJSfd8tWRzURrB/fQoh 6KZ6fIgKqYUp1YNzQ1v9T2FO3h3HLBXY9zQDbJ9SPk2zzCIJi8X0ZUMhbmIws0YNjU3Y KI3A== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:in-reply-to:content-disposition:mime-version :references:message-id:subject:cc:to:from:date:dkim-signature; bh=CQyiBZipeF5xIaqUtv6lhT05YSMvs6cnrxD/Jyuc3sU=; b=o9ADZDrBWg7AtZ06mAqUa6qmoj4dCD2+l7EiBrgw2rCafjSvkI3eUskCkOu2Sm/tJK unTBzgPQiaekRMQV6ZSnYoGfuygKD69aZ2XGyumpYNfQjSusLx8qoMcC8mMRaTz2GnbR vdMgejI+RMQeeFnx9XHFqsU5RgNCIJrrnp64bWBUvBrmmame8ETGR+CjK3nEj38SzuTY iKDVnXN+Gp4Ltnhtrbv/yMsaZpOU76qXXw3jtgRgp8dTxNksKIFXY2jL27F3NPmGuDZV D7aeHon/95xSA377TrM8ga3GtOOtpLVOD1GMGWO8wDvEUHoj/fq3Qr1I2kBz1EeILZaE Rj/A== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass (test mode) header.i=@ideasonboard.com header.s=mail header.b=TpnC23Mx; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id a15si9935650edr.346.2021.03.10.00.14.25; Wed, 10 Mar 2021 00:14:48 -0800 (PST) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) client-ip=23.128.96.18; Authentication-Results: mx.google.com; dkim=pass (test mode) header.i=@ideasonboard.com header.s=mail header.b=TpnC23Mx; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S229516AbhCJINR (ORCPT + 99 others); Wed, 10 Mar 2021 03:13:17 -0500 Received: from perceval.ideasonboard.com ([213.167.242.64]:59210 "EHLO perceval.ideasonboard.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S231152AbhCJIM4 (ORCPT ); Wed, 10 Mar 2021 03:12:56 -0500 Received: from pendragon.ideasonboard.com (62-78-145-57.bb.dnainternet.fi [62.78.145.57]) by perceval.ideasonboard.com (Postfix) with ESMTPSA id A9743F3; Wed, 10 Mar 2021 09:12:54 +0100 (CET) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=ideasonboard.com; s=mail; t=1615363974; bh=p4o+P+DQ74y4yqjC73QioWWOWOlWjgSrnbi5iNTpD28=; h=Date:From:To:Cc:Subject:References:In-Reply-To:From; b=TpnC23MxTmNMaLkZ3tij641VlgTTGnCgUNjbOiCc7L+sNkIAPGVxUwhGTFkIdyN8Q Rw0Dow8jOSx0h9HL3nSrHhnF1a/AGlvn4plGxD+9n0tj6htyFIQQktnOy1GcfTj9zV vTEwR7Ezm/GZKPYRYr+SidWcBQ5ATtOSmVkhPPZ4= Date: Wed, 10 Mar 2021 10:12:22 +0200 From: Laurent Pinchart To: Ricardo Ribalda Cc: Tomasz Figa , Marek Szyprowski , Mauro Carvalho Chehab , Linux Media Mailing List , Linux Kernel Mailing List , stable@vger.kernel.org Subject: Re: [PATCH] media: videobuf2: Fix integer overrun in allocation Message-ID: References: <20210309234317.1021588-1-ribalda@chromium.org> MIME-Version: 1.0 Content-Type: text/plain; charset=utf-8 Content-Disposition: inline In-Reply-To: Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Hi Ricardo, On Wed, Mar 10, 2021 at 08:58:39AM +0100, Ricardo Ribalda wrote: > On Wed, Mar 10, 2021 at 8:49 AM Laurent Pinchart wrote: > > On Wed, Mar 10, 2021 at 12:43:17AM +0100, Ricardo Ribalda wrote: > > > The plane_length is an unsigned integer. So, if we have a size of > > > 0xffffffff bytes we incorrectly allocate 0 bytes instead of 1 << 32. > > > > > > Cc: stable@vger.kernel.org > > > Fixes: 7f8414594e47 ("[media] media: videobuf2: fix the length check for mmap") > > > Signed-off-by: Ricardo Ribalda > > > --- > > > drivers/media/common/videobuf2/videobuf2-core.c | 4 +++- > > > 1 file changed, 3 insertions(+), 1 deletion(-) > > > > > > diff --git a/drivers/media/common/videobuf2/videobuf2-core.c b/drivers/media/common/videobuf2/videobuf2-core.c > > > index 02281d13505f..543da515c761 100644 > > > --- a/drivers/media/common/videobuf2/videobuf2-core.c > > > +++ b/drivers/media/common/videobuf2/videobuf2-core.c > > > @@ -223,8 +223,10 @@ static int __vb2_buf_mem_alloc(struct vb2_buffer *vb) > > > * NOTE: mmapped areas should be page aligned > > > */ > > > for (plane = 0; plane < vb->num_planes; ++plane) { > > > + unsigned long size = vb->planes[plane].length; > > > > unsigned long is still 32-bit on 32-bit platforms. > > > > > + > > > /* Memops alloc requires size to be page aligned. */ > > > - unsigned long size = PAGE_ALIGN(vb->planes[plane].length); > > > + size = PAGE_ALIGN(size); > > > > > > /* Did it wrap around? */ > > > if (size < vb->planes[plane].length) > > > > Doesn't this address the issue already ? > > Yes and no. If you need to allocate 0xffffffff you are still affected > by the underrun. The core will return an error instead of doing the > allocation. > > (yes, I know it is a lot of memory for a buffer) That's my point, I don't think there's a need for this :-) Especially with v4l2_buffer.m.offset being a __u32, we are limited to 4GB for *all* buffers. -- Regards, Laurent Pinchart