Received: by 2002:a05:6a10:a0d1:0:0:0:0 with SMTP id j17csp200893pxa; Fri, 21 Aug 2020 05:12:07 -0700 (PDT) X-Google-Smtp-Source: ABdhPJxUIYtT/orejxv5ABgl8LX9N85XXb57ItOKOHLyZWPJ/BiqcRS+NEjG2eSbLGuVi8yyDTJl X-Received: by 2002:a17:907:40bf:: with SMTP id nu23mr2395575ejb.243.1598011927008; Fri, 21 Aug 2020 05:12:07 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1598011927; cv=none; d=google.com; s=arc-20160816; b=q0aq0EW2SWhvIJ6Cn26mwX6FoyrsIEQCZ5YBF4B3bdlabQfWTndqaihrGjjqL8FF1R 6TvDRgaLETeylVTKYDSLPsSqaBLyFvSDndhFBvqPpdCVpiqRCzqzxLb/eRiE5aJ7ZdDF n7+Xts63cFeoRr6O2bGgrQvDv5JoaypKaY1lyOEqJEJsv+G8/bHRXEOK3n1WfLszY1ji lsZyc2mZvioqLpaYGrw9VCJCgXT1tqN4dwugmaggvt2yfRwnpLwRQKr4EnBOBINJb8G1 I5EMW3ElmvKp8Lr6ZPIvy3n8A92EvQCBAJ6Zg64KQ7l1YDfTO6Jf3dM8k+5LrTgkxWoh dy6g== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:content-transfer-encoding :content-language:in-reply-to:mime-version:user-agent:date :message-id:from:references:cc:to:subject:dkim-signature; bh=Elz/9n2A7E9MeIn4e8Ei1rQfUn6BwgGav4oa/R3NlgY=; b=OUGPoyuywFB4F4dJx+HJurpkpC/XUsmkABuYiaj6lZ2y6FZX0/GTmLPWv4FVmX5R0I 8TfEL3swd8lAWl4Gfq9CowZKEmDV52HIZusXrNCj62eqkAfUn4fch8LiT+9aa3MYgjQ+ FkyxtaGL4kBQTrB3qQXvd0psEHmnKkIGjdisw+EYKELHIKQTBcK+2OS2vy3igFdfObhj 7furr72XLnRbmyRgdADKAks0v/hTrObyjzcrY8SIyNinGfXpxWVZdIsH2Rkx6bdnm3GE hNJCPzdt7ZVmVnP6C5RrnhagHiwsv4UJOXsp8+wGJkw/dqzoZ4huX0ixVOZGYM5bEd0K 3TNA== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@ti.com header.s=ti-com-17Q1 header.b=oBK7zLkd; 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=QUARANTINE sp=NONE dis=NONE) header.from=ti.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id f16si1042119edv.411.2020.08.21.05.11.43; Fri, 21 Aug 2020 05:12:06 -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=@ti.com header.s=ti-com-17Q1 header.b=oBK7zLkd; 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=QUARANTINE sp=NONE dis=NONE) header.from=ti.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1727125AbgHUMH7 (ORCPT + 99 others); Fri, 21 Aug 2020 08:07:59 -0400 Received: from lelv0143.ext.ti.com ([198.47.23.248]:46846 "EHLO lelv0143.ext.ti.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1728245AbgHUMHl (ORCPT ); Fri, 21 Aug 2020 08:07:41 -0400 Received: from lelv0266.itg.ti.com ([10.180.67.225]) by lelv0143.ext.ti.com (8.15.2/8.15.2) with ESMTP id 07LC73JE030109; Fri, 21 Aug 2020 07:07:03 -0500 DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=ti.com; s=ti-com-17Q1; t=1598011623; bh=Elz/9n2A7E9MeIn4e8Ei1rQfUn6BwgGav4oa/R3NlgY=; h=Subject:To:CC:References:From:Date:In-Reply-To; b=oBK7zLkdjltsOOeJe+AYO98TES7rye9lU54yuwIZH8hY0Xs4Ga1AfGvYkcJXuBaUC nlICVFizJ5QEdy0mQhackZOQZjMJVArHnZwwVon3MX7gWDAAT4CBxbO6B4hzGztdxW s5mvAMhM/DQGZ9By8k8zX/hrUt53oy2w8/O3S5hY= Received: from DLEE103.ent.ti.com (dlee103.ent.ti.com [157.170.170.33]) by lelv0266.itg.ti.com (8.15.2/8.15.2) with ESMTPS id 07LC72PV056631 (version=TLSv1.2 cipher=AES256-GCM-SHA384 bits=256 verify=FAIL); Fri, 21 Aug 2020 07:07:03 -0500 Received: from DLEE113.ent.ti.com (157.170.170.24) by DLEE103.ent.ti.com (157.170.170.33) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_128_CBC_SHA256_P256) id 15.1.1979.3; Fri, 21 Aug 2020 07:07:02 -0500 Received: from lelv0327.itg.ti.com (10.180.67.183) by DLEE113.ent.ti.com (157.170.170.24) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_128_CBC_SHA256_P256) id 15.1.1979.3 via Frontend Transport; Fri, 21 Aug 2020 07:07:02 -0500 Received: from [192.168.2.6] (ileax41-snat.itg.ti.com [10.172.224.153]) by lelv0327.itg.ti.com (8.15.2/8.15.2) with ESMTP id 07LC6x4O110362; Fri, 21 Aug 2020 07:07:00 -0500 Subject: Re: [PATCH] drm/omap: Fix runtime PM imbalance in dsi_runtime_get To: Dinghao Liu , CC: David Airlie , Daniel Vetter , Laurent Pinchart , Sebastian Reichel , Tony Lindgren , zhengbin , , References: <20200821074506.32359-1-dinghao.liu@zju.edu.cn> From: Tomi Valkeinen Message-ID: <5123d7ae-f491-d2d2-788d-b5250ae9e31d@ti.com> Date: Fri, 21 Aug 2020 15:06:59 +0300 User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:68.0) Gecko/20100101 Thunderbird/68.10.0 MIME-Version: 1.0 In-Reply-To: <20200821074506.32359-1-dinghao.liu@zju.edu.cn> Content-Type: text/plain; charset="utf-8" Content-Language: en-US Content-Transfer-Encoding: 7bit X-EXCLAIMER-MD-CONFIG: e1e8a2fd-e40a-4ac6-ac9b-f7e9cc9ee180 Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Hi, On 21/08/2020 10:45, Dinghao Liu wrote: > pm_runtime_get_sync() increments the runtime PM usage counter > even when it returns an error code. However, users of > dsi_runtime_get(), a direct wrapper of pm_runtime_get_sync(), > assume that PM usage counter will not change on error. Thus a > pairing decrement is needed on the error handling path to keep > the counter balanced. > > Fixes: 4fbafaf371be7 ("OMAP: DSS2: Use PM runtime & HWMOD support") > Signed-off-by: Dinghao Liu > --- > drivers/gpu/drm/omapdrm/dss/dsi.c | 7 +++++-- > 1 file changed, 5 insertions(+), 2 deletions(-) > > diff --git a/drivers/gpu/drm/omapdrm/dss/dsi.c b/drivers/gpu/drm/omapdrm/dss/dsi.c > index eeccf40bae41..973bfa14a104 100644 > --- a/drivers/gpu/drm/omapdrm/dss/dsi.c > +++ b/drivers/gpu/drm/omapdrm/dss/dsi.c > @@ -1112,8 +1112,11 @@ static int dsi_runtime_get(struct dsi_data *dsi) > DSSDBG("dsi_runtime_get\n"); > > r = pm_runtime_get_sync(dsi->dev); > - WARN_ON(r < 0); > - return r < 0 ? r : 0; > + if (WARN_ON(r < 0)) { > + pm_runtime_put_noidle(dsi->dev); > + return r; > + } > + return 0; > } Thanks! Good catch. I think this is broken in all the other modules in omapdrm too (e.g. dispc.c, venc.c, etc). Would you like to update the patch to cover the whole omapdrm? Tomi -- Texas Instruments Finland Oy, Porkkalankatu 22, 00180 Helsinki. Y-tunnus/Business ID: 0615521-4. Kotipaikka/Domicile: Helsinki