Received: by 2002:a05:6a10:f347:0:0:0:0 with SMTP id d7csp2300pxu; Tue, 1 Dec 2020 04:54:05 -0800 (PST) X-Google-Smtp-Source: ABdhPJwn3Q1ppngfA7Sv+ej9YQTFWbxSoGhYXJA3XWUegKcYi8XfG+xOCNKKzBq4F+CnDN5VEuq4 X-Received: by 2002:a50:fe02:: with SMTP id f2mr2859719edt.97.1606827245408; Tue, 01 Dec 2020 04:54:05 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1606827245; cv=none; d=google.com; s=arc-20160816; b=xl3JtgJATAZ3WgAMk2GLyLs+34xzXTG3jodVKrN9GIIPInled0d6WUbtIb7cFf5mQG EAMI54cGLccwl27z2SgH+DTUuLe7h0xpWbsPwXM8RCIAlx+f3pRjllOI8/VnyQKdXrUM ZFOEdfcnHceuwy03tocHTgnEEN3VxQvGAzLVo6rITfaflnbrr1Mp6s0lMSKzBPDoJB5/ TOXvJADNPMkNfo4X+mUfIc1X0jqwr+nJ0QWBFpEsEk1FHm9CDd1HXamQ1tEn0cC0CrLT 9+AGEaDGqpuUh9zbo7JQkpRJeMLNvMzkDnO6sb+7huFhxLp36UTmCgeugXzFXjPZVbSK kxxA== 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=J9CLFj5C9D/a4qU76S2IFFKPymjX4ezJIrZ/vnPO4KI=; b=rQZ9EfszrTHzS/gJsQmV1c3oOORP6gfNY96PNoYDUuz2GMAGXWXqgaljPHSHOy+rJ+ 6hrVK5ORKGyVu7Lzbur3GBS9g+tO0K2FoB1MnnETLRLbMhUusLh2bH2JB3FarKKr/Tcw 2HCIaAkZhrC9II3paHhrbetSH56RbSh76cBxxxNgHjROYax5JMEAk72FzIqU5KjL7KYD 6KvYRIJ51xINBRT7vhYl/rIutJoy3qQxqugcAes0ldZnaDPhOxzXNuWUU8khM6mfsojN bkWc2kAjKpSUVVfxcCZQ2On2mL1olFDG1x2xTmin58bY20zfCnasqTQEGbVmPv1gWttl nCgA== 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 t5si1054199edq.590.2020.12.01.04.53.40; Tue, 01 Dec 2020 04:54:05 -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 S2390931AbgLAMt0 (ORCPT + 99 others); Tue, 1 Dec 2020 07:49:26 -0500 Received: from szxga06-in.huawei.com ([45.249.212.32]:8482 "EHLO szxga06-in.huawei.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S2389617AbgLAMtY (ORCPT ); Tue, 1 Dec 2020 07:49:24 -0500 Received: from DGGEMS411-HUB.china.huawei.com (unknown [172.30.72.58]) by szxga06-in.huawei.com (SkyGuard) with ESMTP id 4ClhjL4PPyzhXlG; Tue, 1 Dec 2020 20:48:22 +0800 (CST) Received: from localhost.localdomain.localdomain (10.175.113.25) by DGGEMS411-HUB.china.huawei.com (10.3.19.211) with Microsoft SMTP Server id 14.3.487.0; Tue, 1 Dec 2020 20:48:33 +0800 From: Qinglang Miao To: Thierry Reding , David Airlie , Daniel Vetter , Jonathan Hunter CC: , , , Qinglang Miao Subject: [PATCH] drm/tegra: fix reference leak when pm_runtime_get_sync fails Date: Tue, 1 Dec 2020 20:56:31 +0800 Message-ID: <20201201125631.142590-1-miaoqinglang@huawei.com> X-Mailer: git-send-email 2.20.1 MIME-Version: 1.0 Content-Transfer-Encoding: 7BIT Content-Type: text/plain; charset=US-ASCII X-Originating-IP: [10.175.113.25] X-CFilter-Loop: Reflected Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org The PM reference count is not expected to be incremented on return in these tegra functions. However, pm_runtime_get_sync will increment the PM reference count even failed. Forgetting to putting operation will result in a reference leak here. Replace it with pm_runtime_resume_and_get to keep usage counter balanced. Fixes: fd67e9c6ed5a ("drm/tegra: Do not implement runtime PM") Reported-by: Hulk Robot Signed-off-by: Qinglang Miao --- drivers/gpu/drm/tegra/dc.c | 2 +- drivers/gpu/drm/tegra/dsi.c | 2 +- drivers/gpu/drm/tegra/hdmi.c | 2 +- drivers/gpu/drm/tegra/hub.c | 2 +- drivers/gpu/drm/tegra/sor.c | 2 +- drivers/gpu/drm/tegra/vic.c | 2 +- 6 files changed, 6 insertions(+), 6 deletions(-) diff --git a/drivers/gpu/drm/tegra/dc.c b/drivers/gpu/drm/tegra/dc.c index 424ad60b4..b2c8c68b7 100644 --- a/drivers/gpu/drm/tegra/dc.c +++ b/drivers/gpu/drm/tegra/dc.c @@ -2184,7 +2184,7 @@ static int tegra_dc_runtime_resume(struct host1x_client *client) struct device *dev = client->dev; int err; - err = pm_runtime_get_sync(dev); + err = pm_runtime_resume_and_get(dev); if (err < 0) { dev_err(dev, "failed to get runtime PM: %d\n", err); return err; diff --git a/drivers/gpu/drm/tegra/dsi.c b/drivers/gpu/drm/tegra/dsi.c index 5691ef1b0..f46d377f0 100644 --- a/drivers/gpu/drm/tegra/dsi.c +++ b/drivers/gpu/drm/tegra/dsi.c @@ -1111,7 +1111,7 @@ static int tegra_dsi_runtime_resume(struct host1x_client *client) struct device *dev = client->dev; int err; - err = pm_runtime_get_sync(dev); + err = pm_runtime_resume_and_get(dev); if (err < 0) { dev_err(dev, "failed to get runtime PM: %d\n", err); return err; diff --git a/drivers/gpu/drm/tegra/hdmi.c b/drivers/gpu/drm/tegra/hdmi.c index d09a24931..e5d2a4026 100644 --- a/drivers/gpu/drm/tegra/hdmi.c +++ b/drivers/gpu/drm/tegra/hdmi.c @@ -1510,7 +1510,7 @@ static int tegra_hdmi_runtime_resume(struct host1x_client *client) struct device *dev = client->dev; int err; - err = pm_runtime_get_sync(dev); + err = pm_runtime_resume_and_get(dev); if (err < 0) { dev_err(dev, "failed to get runtime PM: %d\n", err); return err; diff --git a/drivers/gpu/drm/tegra/hub.c b/drivers/gpu/drm/tegra/hub.c index 22a03f7ff..5ce771cba 100644 --- a/drivers/gpu/drm/tegra/hub.c +++ b/drivers/gpu/drm/tegra/hub.c @@ -789,7 +789,7 @@ static int tegra_display_hub_runtime_resume(struct host1x_client *client) unsigned int i; int err; - err = pm_runtime_get_sync(dev); + err = pm_runtime_resume_and_get(dev); if (err < 0) { dev_err(dev, "failed to get runtime PM: %d\n", err); return err; diff --git a/drivers/gpu/drm/tegra/sor.c b/drivers/gpu/drm/tegra/sor.c index e88a17c29..fa1272155 100644 --- a/drivers/gpu/drm/tegra/sor.c +++ b/drivers/gpu/drm/tegra/sor.c @@ -3214,7 +3214,7 @@ static int tegra_sor_runtime_resume(struct host1x_client *client) struct device *dev = client->dev; int err; - err = pm_runtime_get_sync(dev); + err = pm_runtime_resume_and_get(dev); if (err < 0) { dev_err(dev, "failed to get runtime PM: %d\n", err); return err; diff --git a/drivers/gpu/drm/tegra/vic.c b/drivers/gpu/drm/tegra/vic.c index ade56b860..b77f72630 100644 --- a/drivers/gpu/drm/tegra/vic.c +++ b/drivers/gpu/drm/tegra/vic.c @@ -314,7 +314,7 @@ static int vic_open_channel(struct tegra_drm_client *client, struct vic *vic = to_vic(client); int err; - err = pm_runtime_get_sync(vic->dev); + err = pm_runtime_resume_and_get(vic->dev); if (err < 0) return err; -- 2.23.0