Received: by 2002:a05:6a10:eb17:0:0:0:0 with SMTP id hx23csp2808895pxb; Mon, 6 Sep 2021 05:59:44 -0700 (PDT) X-Google-Smtp-Source: ABdhPJxO0mw963E4G6lx15TuHmavgK0IuzkCTT2n9gDdtjdVyYr4aPy5vOhD057lyHyWPas8hkD2 X-Received: by 2002:a50:eacc:: with SMTP id u12mr13101093edp.140.1630933184072; Mon, 06 Sep 2021 05:59:44 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1630933184; cv=none; d=google.com; s=arc-20160816; b=f67eNP8F3gRDqG7dk09FTLnUIhdzKDBjjX0qcLdGNdVbiJSVZgPszSotPcSdAa6XyC ye+XxGYBATuI4aRD/uRZncyngMYYJFOC4KHtHCL5WALUI/d4RlP2+Sbfqf5s4jCLX05d Hoxqh88oX9SYkvY52tdtoTeNHz0TXmjuS7Iomtcn6dAm88Qqge3vxXBN6zJK2zDPKtdh 7gWNugh7HUIH9vmFlp/1g3KalMKCqZOz/Sqikoyav+NABLoYscY8iC1zSjPd/O6UEzQN 21a4eirPUgYxh19o9WAdetzpATFFemefSlUt7zFg8rPI9B6Wa1TMd+ARNmraG5xgTWJU TQbw== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:mime-version :user-agent:references:in-reply-to:message-id:date:subject:cc:to :from:dkim-signature; bh=521Xoo8xgulzxtL6pkHKw+t0xr3xasaNsqmcELPTBY4=; b=uP/G29DXA2SjhRIjk46jFNPrV1Zk9wmWGe/OzHoiSPGZhPxSH4qFfWoULiUXKY0+CS /+C5oRlTroW0kA1hd0/b6Z/ajoZlI0R7bd827I4Bs0KXQaZj/73XSs3D8wL0UbEJWnuE YBTbjNbH9WngqwlonPYXQY427SHbb4qFVPnZjyZ6gPuouJdcYszdLNvS+r2U4y3XbO8L PlQweuUlNtTZFzsOc1egaKKDJY+X5wtIlL4HYWE1hR8IKfGwt9AxYZIJ376NrLo10j3L OfREFOOkfNeExfzzFDOTvUI1SkqzE6ruyoAFFmes+ip8HrfKYSLEX0x7AUw1GTGVYna9 Vbxw== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@linuxfoundation.org header.s=korg header.b=fTdTPRlD; 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; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=linuxfoundation.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id f11si8138095edr.52.2021.09.06.05.59.20; Mon, 06 Sep 2021 05:59:44 -0700 (PDT) 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 header.i=@linuxfoundation.org header.s=korg header.b=fTdTPRlD; 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; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=linuxfoundation.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S242598AbhIFM6Y (ORCPT + 99 others); Mon, 6 Sep 2021 08:58:24 -0400 Received: from mail.kernel.org ([198.145.29.99]:34270 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S242564AbhIFM6G (ORCPT ); Mon, 6 Sep 2021 08:58:06 -0400 Received: by mail.kernel.org (Postfix) with ESMTPSA id DB7116103D; Mon, 6 Sep 2021 12:57:00 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=linuxfoundation.org; s=korg; t=1630933021; bh=u9zluEWB18JkYxp3OuvxqEPeLfuUjRgiLvaU6qfkzmI=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=fTdTPRlDK75rld/e06aJAzIiJz5V3FYbV+8KyQ57odEESxEJDf6eBWCJPeD6ynbRr /m45FtDk6/l/zhmXMgaA/lFvSW6XVByiDaAsMAtxsRNxA9/wn4szMmqFQ6Z1GOsmlH mzCJWIhZjSZD1MEZKG3u3/R03lTdGpelqOD6Prhs= From: Greg Kroah-Hartman To: linux-kernel@vger.kernel.org Cc: Greg Kroah-Hartman , stable@vger.kernel.org, Pavel Skripkin , Hans Verkuil , Mauro Carvalho Chehab Subject: [PATCH 5.10 29/29] media: stkwebcam: fix memory leak in stk_camera_probe Date: Mon, 6 Sep 2021 14:55:44 +0200 Message-Id: <20210906125450.745519833@linuxfoundation.org> X-Mailer: git-send-email 2.33.0 In-Reply-To: <20210906125449.756437409@linuxfoundation.org> References: <20210906125449.756437409@linuxfoundation.org> User-Agent: quilt/0.66 MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org From: Pavel Skripkin commit 514e97674400462cc09c459a1ddfb9bf39017223 upstream. My local syzbot instance hit memory leak in usb_set_configuration(). The problem was in unputted usb interface. In case of errors after usb_get_intf() the reference should be putted to correclty free memory allocated for this interface. Fixes: ec16dae5453e ("V4L/DVB (7019): V4L: add support for Syntek DC1125 webcams") Cc: stable@vger.kernel.org Signed-off-by: Pavel Skripkin Signed-off-by: Hans Verkuil Signed-off-by: Mauro Carvalho Chehab Signed-off-by: Greg Kroah-Hartman --- drivers/media/usb/stkwebcam/stk-webcam.c | 6 ++++-- 1 file changed, 4 insertions(+), 2 deletions(-) --- a/drivers/media/usb/stkwebcam/stk-webcam.c +++ b/drivers/media/usb/stkwebcam/stk-webcam.c @@ -1346,7 +1346,7 @@ static int stk_camera_probe(struct usb_i if (!dev->isoc_ep) { pr_err("Could not find isoc-in endpoint\n"); err = -ENODEV; - goto error; + goto error_put; } dev->vsettings.palette = V4L2_PIX_FMT_RGB565; dev->vsettings.mode = MODE_VGA; @@ -1359,10 +1359,12 @@ static int stk_camera_probe(struct usb_i err = stk_register_video_device(dev); if (err) - goto error; + goto error_put; return 0; +error_put: + usb_put_intf(interface); error: v4l2_ctrl_handler_free(hdl); v4l2_device_unregister(&dev->v4l2_dev);