Received: by 2002:a05:6a10:8c0a:0:0:0:0 with SMTP id go10csp786043pxb; Sat, 20 Feb 2021 23:47:49 -0800 (PST) X-Google-Smtp-Source: ABdhPJzt7MqBLkXgLoyVXHnqSwTFQygfBZDhVQaZUyeBonpdHS+KmuVIogdnDqxyIcwB/tTEQg8/ X-Received: by 2002:a17:906:4d99:: with SMTP id s25mr9442134eju.351.1613893669607; Sat, 20 Feb 2021 23:47:49 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1613893669; cv=none; d=google.com; s=arc-20160816; b=xTVeomQJwOZXJWP7GBae+upfVWWC0xoLp8pHcy9F5PpyYpH70hdXhWmLhNPcIxYrDr 6CU0j+YM/5lLOhT/PmzTPVnOfWPEieRXl2hUlwNl0LcIJVWwdiFh+pEmYC32B5JyJtI6 rb+ws7cNC/Pe0XgEG6vUTKotXuLVx5ibhYVZ+PP/P2QC5o5Pc3kMv7HjZA4s5igi9Gzr VvFp7z4KtrZXBTkK9nZ9Umr5kS2Ci7nWpXIu3OZvfW0e6QD9BsCp1V/11Ihu/7Qt9ecV qCvW0ZzqoNg3E/yziizY9rtnJhsUtZZ66FcHc02ZfGg406zrswbXMvJvGyN0kD1zx5Vp bD0Q== 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 :message-id:date:subject:cc:to:from; bh=PzK40OYeBNyfxS6A0hEKJSp6QtMI7Nw8/8w477kva3I=; b=aHvSzXJVn5WcBl2zkOt9M95OkMUwjSM9qEJisCp6kY85JVKhBgk6oC1E/nmXcUpYQo gTkzM4T2bLpHRgHpeUirwS0ZJuiZ6Ox2Ec/p0pihSyUago8TY3IVcK679E+Ce3q9lQFa SbA8PYXLE2ozOSjD43n4VcVBikMZjrtwLaWQ2ah59GEBdXfWZNBqhahlL71lgvLRgrS9 p/sSX/9CDjuuuBnJHcBfciZICBZTKX6p68p90Vx1Kde5nDddDvBHU62DfyghIay03o4l NAXUO80v+9PcOYE6aRO1CSC33VU4doNY/xymrwcdDAAjPaU6eevJzGs50HDyQ2KdnVbF 684A== ARC-Authentication-Results: i=1; mx.google.com; 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 x9si10616619ejc.196.2021.02.20.23.47.26; Sat, 20 Feb 2021 23:47:49 -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; 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 S229863AbhBUHnU (ORCPT + 99 others); Sun, 21 Feb 2021 02:43:20 -0500 Received: from smtp07.smtpout.orange.fr ([80.12.242.129]:27689 "EHLO smtp.smtpout.orange.fr" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S229661AbhBUHnS (ORCPT ); Sun, 21 Feb 2021 02:43:18 -0500 Received: from localhost.localdomain ([90.126.17.6]) by mwinf5d65 with ME id Xjhb2400607rLVE03jhbrF; Sun, 21 Feb 2021 08:41:36 +0100 X-ME-Helo: localhost.localdomain X-ME-Auth: Y2hyaXN0b3BoZS5qYWlsbGV0QHdhbmFkb28uZnI= X-ME-Date: Sun, 21 Feb 2021 08:41:36 +0100 X-ME-IP: 90.126.17.6 From: Christophe JAILLET To: balbi@kernel.org, gregkh@linuxfoundation.org, krzk@kernel.org, nathan@kernel.org, ndesaulniers@google.com, arnd@arndb.de, gustavoars@kernel.org, linux-arm-kernel@lists.infradead.org Cc: linux-usb@vger.kernel.org, linux-samsung-soc@vger.kernel.org, linux-kernel@vger.kernel.org, kernel-janitors@vger.kernel.org, Christophe JAILLET Subject: [PATCH 2/2] usb: gadget: s3c: Fix the error handling path in 's3c2410_udc_probe()' Date: Sun, 21 Feb 2021 08:41:33 +0100 Message-Id: <20210221074133.938017-1-christophe.jaillet@wanadoo.fr> X-Mailer: git-send-email 2.27.0 MIME-Version: 1.0 Content-Transfer-Encoding: 8bit Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Some 'clk_prepare_enable()' and 'clk_get()' must be undone in the error handling path of the probe function, as already done in the remove function. Fixes: 1c6d47aa4f4b ("USB Gadget driver for Samsung s3c2410 ARM SoC") Signed-off-by: Christophe JAILLET --- checkpatch reports: WARNING: Unknown commit id '1c6d47aa4f4b', maybe rebased or not pulled? According to https://git.kernel.org/pub/scm/linux/kernel/git/next/linux-next.git/commit/drivers/usb/gadget/s3c2410_udc.c?id=3fc154b6b8134b98bb94d60cad9a46ec1ffbe372 the commit ID looks correct to me. Maybe something should be tweaked somewhere before applying, but I don't know what! --- drivers/usb/gadget/udc/s3c2410_udc.c | 16 ++++++++++++---- 1 file changed, 12 insertions(+), 4 deletions(-) diff --git a/drivers/usb/gadget/udc/s3c2410_udc.c b/drivers/usb/gadget/udc/s3c2410_udc.c index 3fc436286bad..146250e93412 100644 --- a/drivers/usb/gadget/udc/s3c2410_udc.c +++ b/drivers/usb/gadget/udc/s3c2410_udc.c @@ -1750,7 +1750,8 @@ static int s3c2410_udc_probe(struct platform_device *pdev) udc_clock = clk_get(NULL, "usb-device"); if (IS_ERR(udc_clock)) { dev_err(dev, "failed to get udc clock source\n"); - return PTR_ERR(udc_clock); + retval = PTR_ERR(udc_clock); + goto err_usb_bus_clk; } clk_prepare_enable(udc_clock); @@ -1773,7 +1774,7 @@ static int s3c2410_udc_probe(struct platform_device *pdev) base_addr = devm_platform_ioremap_resource(pdev, 0); if (!base_addr) { retval = -ENOMEM; - goto err; + goto err_udc_clk; } the_controller = udc; @@ -1791,7 +1792,7 @@ static int s3c2410_udc_probe(struct platform_device *pdev) if (retval != 0) { dev_err(dev, "cannot get irq %i, err %d\n", irq_usbd, retval); retval = -EBUSY; - goto err; + goto err_udc_clk; } dev_dbg(dev, "got irq %i\n", irq_usbd); @@ -1862,7 +1863,14 @@ static int s3c2410_udc_probe(struct platform_device *pdev) gpio_free(udc_info->vbus_pin); err_int: free_irq(irq_usbd, udc); -err: +err_udc_clk: + clk_disable_unprepare(udc_clock); + clk_put(udc_clock); + udc_clock = NULL; +err_usb_bus_clk: + clk_disable_unprepare(usb_bus_clock); + clk_put(usb_bus_clock); + usb_bus_clock = NULL; return retval; } -- 2.27.0