Received: by 2002:a05:6a10:8c0a:0:0:0:0 with SMTP id go10csp3950717pxb; Tue, 2 Mar 2021 02:50:40 -0800 (PST) X-Google-Smtp-Source: ABdhPJyILTvH5M6gGa/yxvmVIG19b9elWT39lPwg6XyEYJR3EwBqmhJ9po7Uodv0WeaczPCWX0ru X-Received: by 2002:a05:6402:6ca:: with SMTP id n10mr8100638edy.312.1614682240643; Tue, 02 Mar 2021 02:50:40 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1614682240; cv=none; d=google.com; s=arc-20160816; b=Adni8khtmn+Xwdg1VaLXPPA1jM89ED328FaHi6sfN9g50OAZdSJKAtruduADp6tpnd yJAtvHw0aIHwPgN0jkhj3Rxq2Ppg+JVWN2cOXbREnJ8uG2/wRlijOKA3EhYKr43hjNE6 35gmY+l6zxnubKESTshOwWRTCnh8M0NYZDlWguMQRqCD6GP0gXjbeQMPXku/3HCxA7OI QGQF0klfSsonSWEX119oT+lE+WjRoH7m/haafF0f3G+95cqgfzwJLo2rR22OLpNSV+2q 6ZeNorCcUEHgCzoOX5QMb+p+THhx2RZ69IEuBBSlNWqypJyVnGBWiWeI+ARfXFebCvYo xEMQ== 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=1Aeak7VcUiBibEtvDUF36iVTs1rktxnP6kOM0o86Px8=; b=w4NVEKP5MxwcBk8llx829N3RKblLaTNUUZqWOpj7Xx8Wea6uyxeUFx35tVGzVq7Dzh AIoj+Lr1ToqBpCFY6wLC3UzHU9h19OjZDJSaSSxwnHpKGhCurr3t89abewIjJaG2hTul /muzpxNvqj+BDXw8nH430i/ArN70ym+OzG4gtuKZwgk5IH6CYcMg8bAkzDj8iL4eOSDG 6HMxG+APGXuZDlkJ0yuk1MozInUaz3962NF1xjV/1UERh6ap3fw2uTvp4vL6O9ok9aMK iyvjhAqZA/kun138FfbTb9mIcuW8mE0opd0eojygKm9AgwYPo1RIdOm6yJRkkl3G7tvM +HLA== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@linuxfoundation.org header.s=korg header.b=FdRPeAbV; 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 q3si1265229edc.7.2021.03.02.02.50.17; Tue, 02 Mar 2021 02:50:40 -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 header.i=@linuxfoundation.org header.s=korg header.b=FdRPeAbV; 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 S1380150AbhCBBsh (ORCPT + 99 others); Mon, 1 Mar 2021 20:48:37 -0500 Received: from mail.kernel.org ([198.145.29.99]:48600 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S241515AbhCAT0p (ORCPT ); Mon, 1 Mar 2021 14:26:45 -0500 Received: by mail.kernel.org (Postfix) with ESMTPSA id 48CEC64E22; Mon, 1 Mar 2021 17:10:01 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=linuxfoundation.org; s=korg; t=1614618601; bh=HuvaGODZbp3hurLAhBmhqPUiJR9JIRrXi8xF1vFELTI=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=FdRPeAbVU66OgrSDf+zx2NQq39OpZhXyRuu2MHVmhtXDzE/WUs9E+cju2MyQjmvO1 qjjpCnY69wq+DBl5eHYfdjAcRH+6QL5HGXrcW5kADLOak036FNfTxQELJnQ1+187xe 3E5ebDl4S5PF1GXJ+fpchRu5iDAsbabWe/JR8Zyg= From: Greg Kroah-Hartman To: linux-kernel@vger.kernel.org Cc: Greg Kroah-Hartman , stable@vger.kernel.org, Christophe JAILLET , =?UTF-8?q?=E5=91=A8=E7=90=B0=E6=9D=B0=20 ?= , Herbert Xu , Sasha Levin Subject: [PATCH 5.10 147/663] hwrng: ingenic - Fix a resource leak in an error handling path Date: Mon, 1 Mar 2021 17:06:35 +0100 Message-Id: <20210301161149.044384121@linuxfoundation.org> X-Mailer: git-send-email 2.30.1 In-Reply-To: <20210301161141.760350206@linuxfoundation.org> References: <20210301161141.760350206@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 [ Upstream commit c4ff41b93d1f10d1b8be258c31a0436c5769fc00 ] In case of error, we should call 'clk_disable_unprepare()' to undo a previous 'clk_prepare_enable()' call, as already done in the remove function. Fixes: 406346d22278 ("hwrng: ingenic - Add hardware TRNG for Ingenic X1830") Signed-off-by: Christophe JAILLET Tested-by: 周琰杰 (Zhou Yanjie) Signed-off-by: Herbert Xu Signed-off-by: Sasha Levin --- drivers/char/hw_random/ingenic-trng.c | 6 +++++- 1 file changed, 5 insertions(+), 1 deletion(-) diff --git a/drivers/char/hw_random/ingenic-trng.c b/drivers/char/hw_random/ingenic-trng.c index 954a8411d67d2..0eb80f786f4dd 100644 --- a/drivers/char/hw_random/ingenic-trng.c +++ b/drivers/char/hw_random/ingenic-trng.c @@ -113,13 +113,17 @@ static int ingenic_trng_probe(struct platform_device *pdev) ret = hwrng_register(&trng->rng); if (ret) { dev_err(&pdev->dev, "Failed to register hwrng\n"); - return ret; + goto err_unprepare_clk; } platform_set_drvdata(pdev, trng); dev_info(&pdev->dev, "Ingenic DTRNG driver registered\n"); return 0; + +err_unprepare_clk: + clk_disable_unprepare(trng->clk); + return ret; } static int ingenic_trng_remove(struct platform_device *pdev) -- 2.27.0