Received: by 2002:ac0:a582:0:0:0:0:0 with SMTP id m2-v6csp3915720imm; Mon, 8 Oct 2018 11:37:45 -0700 (PDT) X-Google-Smtp-Source: ACcGV61xVUwBarrRJnrS7ZTW0uaRaKeYaem1ozKSK9KdQeSqzMGNhFftgNGm229WFv6n1ExF81CE X-Received: by 2002:a63:f110:: with SMTP id f16-v6mr22369314pgi.236.1539023865004; Mon, 08 Oct 2018 11:37:45 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1539023864; cv=none; d=google.com; s=arc-20160816; b=ds241+DPybcUTH5eNHph/MFB/LkQAvPZW+cj5rN2U7s6WUzgXiwijQXQWumDy/C8zV gEB44/eYYR7FFV29GeEOsgI1+697LnRc0yXHl7v8dSejXi13Lamn0IyKNPL2ZK1RBuqH I5ZP+wHF03QO0OxFiMIv9P2WXaMInvHL/t/ucZhFVqQo1TaryNKI4pORn20unKp5ngym JRqrtpduLhQQkyX2bS0WsnK/OIjb2derORDMR//dfLP/mCHDx0QM1wkSZxupDEfeoc5s RZWKSGKGWEMOFC85vevghrHX/p5aexRuYgn9UXF/p2DdBSfmgCWrNRVLFWsJ1WTkRrUD uUMQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:content-transfer-encoding:mime-version :user-agent:references:in-reply-to:message-id:date:subject:cc:to :from:dkim-signature; bh=HQzf9QW+hiNMWYgy7BKc+tppDd5r47qBE6Q07wn/nQY=; b=TEWCZMf4hx//FPqLYtfaUI+nKpJFGWNOGQrbKFQ+E/su/cQsA1IlAWrG+QXH96/Ac8 vFhKAhT9vlGgueS7PB4a+NHIbl4eXxnEPbP2imovNCc0xZl2IBI4nLbXgXjCe6gfiL8x 849a4dfuMF0IZZWMWxV0CY8XzTCdo/9c83apscyd2KpegXTVNfwRz00H64XjWpGxEZTs US0EqWOpvNGgpDQX1/BfzmPA4m1JVtBBCE9/fmClrniQ2WiB5JHIVaVaCUaI1fxsJZbV rdAmAhyWqryrMz43w3E3TSxD3flxmtKTILPtN33lZhlvNgGMbxCUGBmUvfJK2UsO+gPC qB7g== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@kernel.org header.s=default header.b=KmQ0gf11; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id x17-v6si17605138pgl.414.2018.10.08.11.37.30; Mon, 08 Oct 2018 11:37:44 -0700 (PDT) Received-SPF: pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) client-ip=209.132.180.67; Authentication-Results: mx.google.com; dkim=pass header.i=@kernel.org header.s=default header.b=KmQ0gf11; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1728729AbeJIBtx (ORCPT + 99 others); Mon, 8 Oct 2018 21:49:53 -0400 Received: from mail.kernel.org ([198.145.29.99]:35400 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1727261AbeJIBtx (ORCPT ); Mon, 8 Oct 2018 21:49:53 -0400 Received: from localhost (ip-213-127-77-176.ip.prioritytelecom.net [213.127.77.176]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by mail.kernel.org (Postfix) with ESMTPSA id 3A5662064A; Mon, 8 Oct 2018 18:36:49 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=default; t=1539023809; bh=cBTQKK1QkfL25pVPZrLUMxR2Dz65t/m2rQwJc6g1ZvM=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=KmQ0gf11AchWLpiihm+4pVbyvW16ELd/IbNu469teMYr/kfFAcPJ57lvevKBDx5W8 DW3DSlLko+jiHXotf0XYz5b3HgxB3hpXLkKfBixaaS5sNkGp8HFdg6BO1oPc/vJZin 4KDEPSu4Y8bXw08aGIPX8x0/lcC9ilBooYtJUL3I= From: Greg Kroah-Hartman To: linux-kernel@vger.kernel.org Cc: Greg Kroah-Hartman , stable@vger.kernel.org, Anton Vasilyev , Felipe Balbi , Sasha Levin Subject: [PATCH 4.4 092/113] usb: gadget: fotg210-udc: Fix memory leak of fotg210->ep[i] Date: Mon, 8 Oct 2018 20:31:33 +0200 Message-Id: <20181008175536.362057438@linuxfoundation.org> X-Mailer: git-send-email 2.19.0 In-Reply-To: <20181008175530.864641368@linuxfoundation.org> References: <20181008175530.864641368@linuxfoundation.org> User-Agent: quilt/0.65 X-stable: review MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org 4.4-stable review patch. If anyone has any objections, please let me know. ------------------ From: Anton Vasilyev [ Upstream commit c37bd52836296ecc9a0fc8060b819089aebdbcde ] There is no deallocation of fotg210->ep[i] elements, allocated at fotg210_udc_probe. The patch adds deallocation of fotg210->ep array elements and simplifies error path of fotg210_udc_probe(). Found by Linux Driver Verification project (linuxtesting.org). Signed-off-by: Anton Vasilyev Signed-off-by: Felipe Balbi Signed-off-by: Sasha Levin Signed-off-by: Greg Kroah-Hartman --- drivers/usb/gadget/udc/fotg210-udc.c | 15 ++++++++++----- 1 file changed, 10 insertions(+), 5 deletions(-) --- a/drivers/usb/gadget/udc/fotg210-udc.c +++ b/drivers/usb/gadget/udc/fotg210-udc.c @@ -1066,12 +1066,15 @@ static struct usb_gadget_ops fotg210_gad static int fotg210_udc_remove(struct platform_device *pdev) { struct fotg210_udc *fotg210 = platform_get_drvdata(pdev); + int i; usb_del_gadget_udc(&fotg210->gadget); iounmap(fotg210->reg); free_irq(platform_get_irq(pdev, 0), fotg210); fotg210_ep_free_request(&fotg210->ep[0]->ep, fotg210->ep0_req); + for (i = 0; i < FOTG210_MAX_NUM_EP; i++) + kfree(fotg210->ep[i]); kfree(fotg210); return 0; @@ -1102,7 +1105,7 @@ static int fotg210_udc_probe(struct plat /* initialize udc */ fotg210 = kzalloc(sizeof(struct fotg210_udc), GFP_KERNEL); if (fotg210 == NULL) - goto err_alloc; + goto err; for (i = 0; i < FOTG210_MAX_NUM_EP; i++) { _ep[i] = kzalloc(sizeof(struct fotg210_ep), GFP_KERNEL); @@ -1114,7 +1117,7 @@ static int fotg210_udc_probe(struct plat fotg210->reg = ioremap(res->start, resource_size(res)); if (fotg210->reg == NULL) { pr_err("ioremap error.\n"); - goto err_map; + goto err_alloc; } spin_lock_init(&fotg210->lock); @@ -1162,7 +1165,7 @@ static int fotg210_udc_probe(struct plat fotg210->ep0_req = fotg210_ep_alloc_request(&fotg210->ep[0]->ep, GFP_KERNEL); if (fotg210->ep0_req == NULL) - goto err_req; + goto err_map; fotg210_init(fotg210); @@ -1190,12 +1193,14 @@ err_req: fotg210_ep_free_request(&fotg210->ep[0]->ep, fotg210->ep0_req); err_map: - if (fotg210->reg) - iounmap(fotg210->reg); + iounmap(fotg210->reg); err_alloc: + for (i = 0; i < FOTG210_MAX_NUM_EP; i++) + kfree(fotg210->ep[i]); kfree(fotg210); +err: return ret; }