Received: by 2002:a05:6a10:f347:0:0:0:0 with SMTP id d7csp1191616pxu; Fri, 27 Nov 2020 01:45:47 -0800 (PST) X-Google-Smtp-Source: ABdhPJypp44F+X8rQAYN9cimZ9pJtJSOsfFuGmxJJrEJEbTG7Ep7lXkv097whCApupvhlRucuBA2 X-Received: by 2002:a50:8a02:: with SMTP id i2mr1322572edi.222.1606470346966; Fri, 27 Nov 2020 01:45:46 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1606470346; cv=none; d=google.com; s=arc-20160816; b=lrgsZFoOEgdPzuoB5cyuaUtSQXz0jQAV6P/zO+V/PCw1GMCm+H2gs7dZx0Jd0rGALj ZOQptqx2q9tCaNhhKyijwmT9AN+nEBJg7bpXRq//Sm1lOnE6FdZbp2vEYWtdX7CG9U8z DovwxUA211qf8XKVst9QypbT2UNCwhycUTiOGRhhBtZ/bIqMeYaU1rOrlUc9hbg9bBtm Lvd62idIkHvPhImrLJAd8adnH/CnGeIJUBa/YNS9Pwvxr+fQsUZjHGuPIZr7Q1H+YkDx uFQQ/IhwSATtWxWbhe/N0jqHhBBF/W7WjSVovjWWdQNFmpg8dEfImLeH3DKyKZZeYx68 qUxQ== 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=/jOX8oCOQMGLt7JMcIiXYGT6EFhL6NhCQk/j8xHIrNo=; b=LELkpMW/5dj/rIWCxJy0zEMICrKlLboEOzKViTyj7K4fCKCGgBZwbBbWtdhwvc20Rz qY818QvvXE4tMkxrF93lY74DDpIz74acQnm2QlDQlRlotOBdFgao987H3XXygUmeMsUH IgpmN2WmwbZJ4qP8M0bTH9UdEfi6S6sJHHyrbYU2mF5zuic83iE7wb07m+YH8AeSQ5Ly GM/BkLNgqzKr15gcMY5ZUDFlBFCc1zKOCQI/Wiz0wTTJBA++B7Xmi1r/3n+JGge0rg9T 5r2QwR2FY0445Cwav/Ut1hZlp5ZPc0a/6bK9/C/1tWedl1U4EZnXyGFveUsjCvmx00V+ PPaw== 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 ce26si2775286edb.168.2020.11.27.01.45.24; Fri, 27 Nov 2020 01:45:46 -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 S1728983AbgK0JlK (ORCPT + 99 others); Fri, 27 Nov 2020 04:41:10 -0500 Received: from szxga04-in.huawei.com ([45.249.212.190]:7750 "EHLO szxga04-in.huawei.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1728177AbgK0Jkf (ORCPT ); Fri, 27 Nov 2020 04:40:35 -0500 Received: from DGGEMS409-HUB.china.huawei.com (unknown [172.30.72.60]) by szxga04-in.huawei.com (SkyGuard) with ESMTP id 4Cj8jq61XDzkdqx; Fri, 27 Nov 2020 17:39:59 +0800 (CST) Received: from localhost.localdomain.localdomain (10.175.113.25) by DGGEMS409-HUB.china.huawei.com (10.3.19.209) with Microsoft SMTP Server id 14.3.487.0; Fri, 27 Nov 2020 17:40:21 +0800 From: Qinglang Miao To: Qiang Yu , David Airlie , "Daniel Vetter" CC: , , , Qinglang Miao Subject: [PATCH] drm/lima: fix reference leak in lima_pm_busy Date: Fri, 27 Nov 2020 17:44:38 +0800 Message-ID: <20201127094438.121003-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 pm_runtime_get_sync will increment pm usage counter even it failed. Forgetting to putting operation will result in a reference leak here. A new function pm_runtime_resume_and_get is introduced in [0] to keep usage counter balanced. So We fix the reference leak by replacing it with new funtion. [0] dd8088d5a896 ("PM: runtime: Add pm_runtime_resume_and_get to deal with usage counter") Fixes: 50de2e9ebbc0 ("drm/lima: enable runtime pm") Reported-by: Hulk Robot Signed-off-by: Qinglang Miao --- drivers/gpu/drm/lima/lima_sched.c | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/drivers/gpu/drm/lima/lima_sched.c b/drivers/gpu/drm/lima/lima_sched.c index dc6df9e9a..f6e7a88a5 100644 --- a/drivers/gpu/drm/lima/lima_sched.c +++ b/drivers/gpu/drm/lima/lima_sched.c @@ -200,7 +200,7 @@ static int lima_pm_busy(struct lima_device *ldev) int ret; /* resume GPU if it has been suspended by runtime PM */ - ret = pm_runtime_get_sync(ldev->dev); + ret = pm_runtime_resume_and_get(ldev->dev); if (ret < 0) return ret; -- 2.23.0