Received: by 2002:a05:6a10:af89:0:0:0:0 with SMTP id iu9csp3589057pxb; Mon, 24 Jan 2022 12:57:50 -0800 (PST) X-Google-Smtp-Source: ABdhPJwxteWRKLrBgX4VyRgmgN58BY+Ibyu54hjRjUn+Jej0HiK19lIAmGSrVrZ6TKt0E6yX+JPH X-Received: by 2002:a17:90b:2245:: with SMTP id hk5mr139646pjb.75.1643057869817; Mon, 24 Jan 2022 12:57:49 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1643057869; cv=none; d=google.com; s=arc-20160816; b=RGsKMOfM37NUxG9cVzxUSPGHx02uSdZzmyUiGqzKJOm1PD1GyI/Z7uAGIh9d3ebpsZ /R3I7Almczo7XdoWd42PkUkoXt1aViH3ahn+KlyvyagZy7RWYwC0y3giFtPWWKGvlXpF uJWGjQeh+wfFkQF9rkgIAJVsfTIQMKhsEDDKoJj/FqRyw7qi5mU+QSIoloRszt1t2vza U7EAna72/T3tUhrH9RrUBKIOV33h4ZR8R1GX6vO+DQQRjiQiubscdR+JxxruXry45n3L RSirlGw5nsITUtM1+8fSZAAAtoLmkiaQE2/7Gno1OG+s/GOxToSAsJIg2KdR1Cj4vEZ7 eKaA== 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=6W4Pj8royA4ap8/3lIXVz1PSkZEIEajvlCoYnDUhBgI=; b=yM0JRs9q/vD3mdhyOiLCng+N+XLoJ67Dbew2QEm7vPzjerO1qD8NMKNlEqSJg1J13P KHSjUJsIXv5bMAps1kucQPjv/7Nz9MFy/7WcGAewCT+6FsaUyy4bO4T9ipsyvcMuO+Lk M3SMDry1R9hgqbXpr61uOrtrcwe2jOOgdgTdtquUf1K6/7LRyNXGqgtCvSxNeeYpqfcH u01eahpYwx/5VCi58JLjwwStM94BiDS/xheMnKp7mlkl7FULC5+YBLehmGyUdQMFGB+y rqU7XugaZUcddPPNg/QiuBCnu/6DzDsBfmMTjzpogQxglgt3pkr4OL4Dr2fOJGq04m/D bN3Q== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@linuxfoundation.org header.s=korg header.b=ncJBAo2P; 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 y13si14729424pgc.372.2022.01.24.12.57.31; Mon, 24 Jan 2022 12:57: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; dkim=pass header.i=@linuxfoundation.org header.s=korg header.b=ncJBAo2P; 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 S1348599AbiAXUSi (ORCPT + 99 others); Mon, 24 Jan 2022 15:18:38 -0500 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:59706 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1376372AbiAXUBc (ORCPT ); Mon, 24 Jan 2022 15:01:32 -0500 Received: from dfw.source.kernel.org (dfw.source.kernel.org [IPv6:2604:1380:4641:c500::1]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 1998CC055ABE; Mon, 24 Jan 2022 11:28:48 -0800 (PST) Received: from smtp.kernel.org (relay.kernel.org [52.25.139.140]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by dfw.source.kernel.org (Postfix) with ESMTPS id ADDA26148F; Mon, 24 Jan 2022 19:28:47 +0000 (UTC) Received: by smtp.kernel.org (Postfix) with ESMTPSA id 8B0F3C340E7; Mon, 24 Jan 2022 19:28:46 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=linuxfoundation.org; s=korg; t=1643052527; bh=jNhhpFP2tNg+Npy4Crv5614QHwFsd4ldaIklWzBWj20=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=ncJBAo2PsG3u4k3A+vimOP90FEwhtem6E3chxLDlnL3dH76p/96eFWNAqHumcEyNr ySRtEXFRcj4dZCvUaDhyOZnbr0zJTHhy0zhf0EFLDz7ZWL2QRSt5SUj5qZZPgamGwv KUJXgHEy90bQR3er/+ZdnDIjsfHfvqOs2sCMFf10= From: Greg Kroah-Hartman To: linux-kernel@vger.kernel.org Cc: Greg Kroah-Hartman , stable@vger.kernel.org, Jernej Skrabec , Andrzej Pietrasiewicz , Ezequiel Garcia , Hans Verkuil , Mauro Carvalho Chehab , Sasha Levin Subject: [PATCH 5.4 088/320] media: hantro: Fix probe func error path Date: Mon, 24 Jan 2022 19:41:12 +0100 Message-Id: <20220124183956.735090904@linuxfoundation.org> X-Mailer: git-send-email 2.34.1 In-Reply-To: <20220124183953.750177707@linuxfoundation.org> References: <20220124183953.750177707@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: Jernej Skrabec [ Upstream commit 37af43b250fda6162005d47bf7c959c70d52b107 ] If clocks for some reason couldn't be enabled, probe function returns immediately, without disabling PM. This obviously leaves PM ref counters unbalanced. Fix that by jumping to appropriate error path, so effects of PM functions are reversed. Fixes: 775fec69008d ("media: add Rockchip VPU JPEG encoder driver") Signed-off-by: Jernej Skrabec Acked-by: Andrzej Pietrasiewicz Reviewed-by: Ezequiel Garcia Signed-off-by: Hans Verkuil Signed-off-by: Mauro Carvalho Chehab Signed-off-by: Sasha Levin --- drivers/staging/media/hantro/hantro_drv.c | 3 ++- 1 file changed, 2 insertions(+), 1 deletion(-) diff --git a/drivers/staging/media/hantro/hantro_drv.c b/drivers/staging/media/hantro/hantro_drv.c index 32e5966ba5c5f..58cf44045b396 100644 --- a/drivers/staging/media/hantro/hantro_drv.c +++ b/drivers/staging/media/hantro/hantro_drv.c @@ -823,7 +823,7 @@ static int hantro_probe(struct platform_device *pdev) ret = clk_bulk_prepare(vpu->variant->num_clocks, vpu->clocks); if (ret) { dev_err(&pdev->dev, "Failed to prepare clocks\n"); - return ret; + goto err_pm_disable; } ret = v4l2_device_register(&pdev->dev, &vpu->v4l2_dev); @@ -879,6 +879,7 @@ err_v4l2_unreg: v4l2_device_unregister(&vpu->v4l2_dev); err_clk_unprepare: clk_bulk_unprepare(vpu->variant->num_clocks, vpu->clocks); +err_pm_disable: pm_runtime_dont_use_autosuspend(vpu->dev); pm_runtime_disable(vpu->dev); return ret; -- 2.34.1