Received: by 2002:a05:6a10:206:0:0:0:0 with SMTP id 6csp2659720pxj; Mon, 14 Jun 2021 04:16:03 -0700 (PDT) X-Google-Smtp-Source: ABdhPJwHrk73AULo5QYTiwxYeBlkQZ+uXN5tm20H762h3DbS3GbBR06e7CrOV4TOdFGg0kgn2SlG X-Received: by 2002:a17:907:6ef:: with SMTP id yh15mr14576731ejb.151.1623669363613; Mon, 14 Jun 2021 04:16:03 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1623669363; cv=none; d=google.com; s=arc-20160816; b=hKSnjIC1+d+g+pGpIcB0tuWpqELDtB6+Pbh1FO813eHlESU954qy1Au5/HX1qVEdFI hIRfAopSWRJ+soq0fpHcB/PsqGgmr418ceSGG0eR1o2GAF0vlt1yWr4FsIO2TJ979KMO OtwZAhWnzvGBoisxM5c2EG7Dpxh8jVsTKydlvfJVCsgFFvsRorsqATr3+t8CvQq5vkPU BWrnXPzO9kGR6GGYMAW9ii4zhuFohuS8V1mJIHz+4DRETDzaGv/DY/ETs2hrDd4uIZb4 58QsivUhF0bfSup49ZvrRpsWGeTLvC6YoGCHhNllJbCRug6kpqMh3bXkduLTAKp87OD/ yX5Q== 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=erYQ4o035feOmJy/skj/6MTjszvfHJzLN0JUgdS0sOw=; b=w+Ff6u6YVmIuTnxMAY86YXRSRkKYQIFoKsK+E7sOWA9lwcx+J37WOMxn/4FUHTL4Yl kX9YVuGQErbeVtJFnuvtB7TA5VxPaDiSIRD6hQBc6u0uLNPTqXAXw3Oafc82ef3eTG// ka+DP3yRWiwFxkIhF8/QIWbUIFxw8JT+78SPxoNFzJwQeEj/0A8m19XRh/LrT86RxSEC 0rlOVuMRsDeK9uSFTFBCNmmt3PaeuwU65f8BvZJSbriLXpgBpg/kIAkT6imz3NjHl8bq LNOzUpgQUObBYhzrFSQ1PoAgRzd+akfO/LF5n0QY5we0Sd+nE53qUMgrejyQIR5IR2VJ ESdw== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@linuxfoundation.org header.s=korg header.b=SRsX3YPU; 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 z22si8987715edb.151.2021.06.14.04.15.41; Mon, 14 Jun 2021 04:16:03 -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=SRsX3YPU; 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 S235795AbhFNLOz (ORCPT + 99 others); Mon, 14 Jun 2021 07:14:55 -0400 Received: from mail.kernel.org ([198.145.29.99]:36694 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S234686AbhFNLCu (ORCPT ); Mon, 14 Jun 2021 07:02:50 -0400 Received: by mail.kernel.org (Postfix) with ESMTPSA id BBCC0613FF; Mon, 14 Jun 2021 10:44:00 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=linuxfoundation.org; s=korg; t=1623667441; bh=nzAyjLyV03WC2pA/xt/1Q15MP5i9n0ZYniC4TeU6imA=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=SRsX3YPUHg+yUDthfXZH6aW6sUB7IHLeYqEJTH2PDdLBZ5EU8SyK+obxOZYEUq/RG 9gxRs0vUUyfvWZK6280NqccHbVOPjraMGPChUf3RoOVwywh8k2sx/yNqazEZG0bbc5 WL+Fnip1Ti3gxucX5TqARmrbJYwhu3BWyimLclFc= From: Greg Kroah-Hartman To: linux-kernel@vger.kernel.org Cc: Greg Kroah-Hartman , stable@vger.kernel.org, Martin Blumenstingl , Neil Armstrong , Christophe JAILLET Subject: [PATCH 5.10 071/131] usb: dwc3: meson-g12a: Disable the regulator in the error handling path of the probe Date: Mon, 14 Jun 2021 12:27:12 +0200 Message-Id: <20210614102655.451106856@linuxfoundation.org> X-Mailer: git-send-email 2.32.0 In-Reply-To: <20210614102652.964395392@linuxfoundation.org> References: <20210614102652.964395392@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: Christophe JAILLET commit 1d0d3d818eafe1963ec1eaf302175cd14938188e upstream. If an error occurs after a successful 'regulator_enable()' call, 'regulator_disable()' must be called. Fix the error handling path of the probe accordingly. The remove function doesn't need to be fixed, because the 'regulator_disable()' call is already hidden in 'dwc3_meson_g12a_suspend()' which is called via 'pm_runtime_set_suspended()' in the remove function. Fixes: c99993376f72 ("usb: dwc3: Add Amlogic G12A DWC3 glue") Reviewed-by: Martin Blumenstingl Acked-by: Neil Armstrong Signed-off-by: Christophe JAILLET Link: https://lore.kernel.org/r/79df054046224bbb0716a8c5c2082650290eec86.1621616013.git.christophe.jaillet@wanadoo.fr Cc: stable Signed-off-by: Greg Kroah-Hartman --- drivers/usb/dwc3/dwc3-meson-g12a.c | 8 ++++++-- 1 file changed, 6 insertions(+), 2 deletions(-) --- a/drivers/usb/dwc3/dwc3-meson-g12a.c +++ b/drivers/usb/dwc3/dwc3-meson-g12a.c @@ -775,13 +775,13 @@ static int dwc3_meson_g12a_probe(struct ret = priv->drvdata->usb_init(priv); if (ret) - goto err_disable_clks; + goto err_disable_regulator; /* Init PHYs */ for (i = 0 ; i < PHY_COUNT ; ++i) { ret = phy_init(priv->phys[i]); if (ret) - goto err_disable_clks; + goto err_disable_regulator; } /* Set PHY Power */ @@ -819,6 +819,10 @@ err_phys_exit: for (i = 0 ; i < PHY_COUNT ; ++i) phy_exit(priv->phys[i]); +err_disable_regulator: + if (priv->vbus) + regulator_disable(priv->vbus); + err_disable_clks: clk_bulk_disable_unprepare(priv->drvdata->num_clks, priv->drvdata->clks);