From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: X-Spam-Checker-Version: SpamAssassin 3.4.0 (2014-02-07) on aws-us-west-2-korg-lkml-1.web.codeaurora.org X-Spam-Level: X-Spam-Status: No, score=-12.3 required=3.0 tests=BAYES_00,DKIM_SIGNED, DKIM_VALID,DKIM_VALID_AU,HEADER_FROM_DIFFERENT_DOMAINS,INCLUDES_PATCH, MAILING_LIST_MULTI,NICE_REPLY_A,SPF_HELO_NONE,SPF_PASS,USER_AGENT_SANE_1 autolearn=unavailable autolearn_force=no version=3.4.0 Received: from mail.kernel.org (mail.kernel.org [198.145.29.99]) by smtp.lore.kernel.org (Postfix) with ESMTP id ED5FFC11F68 for ; Fri, 2 Jul 2021 09:23:44 +0000 (UTC) Received: from vger.kernel.org (vger.kernel.org [23.128.96.18]) by mail.kernel.org (Postfix) with ESMTP id C1F37610CA for ; Fri, 2 Jul 2021 09:23:44 +0000 (UTC) Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S231176AbhGBJ0P (ORCPT ); Fri, 2 Jul 2021 05:26:15 -0400 Received: from mx07-00178001.pphosted.com ([185.132.182.106]:37072 "EHLO mx07-00178001.pphosted.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S230078AbhGBJ0O (ORCPT ); Fri, 2 Jul 2021 05:26:14 -0400 Received: from pps.filterd (m0241204.ppops.net [127.0.0.1]) by mx07-00178001.pphosted.com (8.16.0.43/8.16.0.43) with SMTP id 1629AxOI019441; Fri, 2 Jul 2021 11:23:25 +0200 DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=foss.st.com; h=subject : to : cc : references : from : message-id : date : mime-version : in-reply-to : content-type : content-transfer-encoding; s=selector1; bh=5ywvL4VVQ+2r/jhdIM14ypRiW/ywajQXfPzZ2maovTA=; b=LCFPp+Y/RgFx7ixHPOVRqbIYocI4RlvALr9i9XihsloC62P6IqcJYwyoVmO8ylFHUZ20 L8og9QpEFFl1aiSqTNk9cS9Z7SrCTiYbrmqAsWAxFMurq+NRNG26/Sl2q2j4+Kmtysz5 k0vqFhDN2uHI6j8gFBRBfBWOgFNkLlXVQGdpeN5Sxsf19WOtmvPibI9VciZUFYW9yYdL gc/Mewf4JRC9Ocf81Ywq18JbF7ik0ZCTLv5Bb7qoXfgJQ0Zjm56yfEe6pdpc4QASptl3 H9b5gRz0WrsJfQE7zpIvK19h/jh6l6GLIR4EuT5PLLUFMAC9x0eLi+cos7DiI+ViAvAo lg== Received: from beta.dmz-eu.st.com (beta.dmz-eu.st.com [164.129.1.35]) by mx07-00178001.pphosted.com with ESMTP id 39hw3cscpu-1 (version=TLSv1.2 cipher=ECDHE-RSA-AES256-GCM-SHA384 bits=256 verify=NOT); Fri, 02 Jul 2021 11:23:25 +0200 Received: from euls16034.sgp.st.com (euls16034.sgp.st.com [10.75.44.20]) by beta.dmz-eu.st.com (STMicroelectronics) with ESMTP id 317E610002A; Fri, 2 Jul 2021 11:23:23 +0200 (CEST) Received: from Webmail-eu.st.com (sfhdag2node3.st.com [10.75.127.6]) by euls16034.sgp.st.com (STMicroelectronics) with ESMTP id 8E2F8217B92; Fri, 2 Jul 2021 11:23:23 +0200 (CEST) Received: from lmecxl0557.lme.st.com (10.75.127.47) by SFHDAG2NODE3.st.com (10.75.127.6) with Microsoft SMTP Server (TLS) id 15.0.1497.2; Fri, 2 Jul 2021 11:23:22 +0200 Subject: Re: [PATCH] drm/stm: ltdc: improve pm_runtime to stop clocks To: Marek Vasut CC: Yannick FERTRE , Philippe CORNU , Raphael GALLAIS-POU , Yannick FERTRE - foss , Philippe CORNU - foss , Benjamin Gaignard , David Airlie , "Daniel Vetter" , Maxime Coquelin , Alexandre TORGUE - foss , "dri-devel@lists.freedesktop.org" , "linux-stm32@st-md-mailman.stormreply.com" , "linux-arm-kernel@lists.infradead.org" , "linux-kernel@vger.kernel.org" , Stephen Boyd References: <20210629115709.16145-1-raphael.gallais-pou@foss.st.com> <420e243d-7541-a07e-177b-d2db11c26aef@denx.de> From: Raphael Gallais-Pou Message-ID: <3bb823e4-4724-7072-fe9f-7b8a355c8e50@foss.st.com> Date: Fri, 2 Jul 2021 11:23:21 +0200 User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:78.0) Gecko/20100101 Thunderbird/78.8.1 MIME-Version: 1.0 In-Reply-To: <420e243d-7541-a07e-177b-d2db11c26aef@denx.de> Content-Type: text/plain; charset="utf-8"; format=flowed Content-Transfer-Encoding: 8bit Content-Language: en-US X-Originating-IP: [10.75.127.47] X-ClientProxiedBy: SFHDAG1NODE3.st.com (10.75.127.3) To SFHDAG2NODE3.st.com (10.75.127.6) X-Proofpoint-Virus-Version: vendor=fsecure engine=2.50.10434:6.0.391,18.0.790 definitions=2021-07-02_01:2021-07-02,2021-07-02 signatures=0 Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Hello Marek, Sorry for the late answer. On 6/30/21 2:35 AM, Marek Vasut wrote: > On 6/29/21 1:58 PM, Raphael GALLAIS-POU - foss wrote: > > [...] > >> +++ b/drivers/gpu/drm/stm/ltdc.c >> @@ -425,10 +425,17 @@ static void ltdc_crtc_atomic_enable(struct >> drm_crtc *crtc, >>   { >>       struct ltdc_device *ldev = crtc_to_ltdc(crtc); >>       struct drm_device *ddev = crtc->dev; >> +    int ret; >>         DRM_DEBUG_DRIVER("\n"); >>   -    pm_runtime_get_sync(ddev->dev); >> +    if (!pm_runtime_active(ddev->dev)) { >> +        ret = pm_runtime_get_sync(ddev->dev); > > All these if (!pm_runtime_active()) then pm_runtime_get_sync() calls > look like workaround for some larger issue. Shouldn't the pm_runtime > do some refcounting on its own , so this shouldn't be needed ? This problem purely comes from the driver internals, so I don't think it is a workaround. Because of the "ltdc_crtc_mode_set_nofb" function which does not have any "symmetrical" call, such as enable/disable functions, there was two calls to pm_runtime_get_sync against one call to pm_runtime_put_sync. This instability resulted in the LTDC clocks being always enabled, even when the peripheral was disabled. This could be seen in the clk_summary as explained in the patch summary among other things. By doing so, we first check if the clocks are not already activated, and in that case we call pm_runtime_get_sync. Regards, Raphaël G-P From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: X-Spam-Checker-Version: SpamAssassin 3.4.0 (2014-02-07) on aws-us-west-2-korg-lkml-1.web.codeaurora.org X-Spam-Level: X-Spam-Status: No, score=-10.6 required=3.0 tests=BAYES_00,DKIMWL_WL_HIGH, DKIM_SIGNED,DKIM_VALID,HEADER_FROM_DIFFERENT_DOMAINS,INCLUDES_PATCH, MAILING_LIST_MULTI,NICE_REPLY_A,SPF_HELO_NONE,SPF_PASS,URIBL_BLOCKED, USER_AGENT_SANE_1 autolearn=ham autolearn_force=no version=3.4.0 Received: from mail.kernel.org (mail.kernel.org [198.145.29.99]) by smtp.lore.kernel.org (Postfix) with ESMTP id CED43C11F68 for ; Fri, 2 Jul 2021 09:25:21 +0000 (UTC) Received: from bombadil.infradead.org (bombadil.infradead.org [198.137.202.133]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by mail.kernel.org (Postfix) with ESMTPS id 91C8F611C0 for ; Fri, 2 Jul 2021 09:25:21 +0000 (UTC) DMARC-Filter: OpenDMARC Filter v1.3.2 mail.kernel.org 91C8F611C0 Authentication-Results: mail.kernel.org; dmarc=fail (p=none dis=none) header.from=foss.st.com Authentication-Results: mail.kernel.org; spf=none smtp.mailfrom=linux-arm-kernel-bounces+linux-arm-kernel=archiver.kernel.org@lists.infradead.org DKIM-Signature: v=1; a=rsa-sha256; q=dns/txt; c=relaxed/relaxed; d=lists.infradead.org; s=bombadil.20210309; h=Sender:Content-Type: Content-Transfer-Encoding:List-Subscribe:List-Help:List-Post:List-Archive: List-Unsubscribe:List-Id:In-Reply-To:MIME-Version:Date:Message-ID:From: References:CC:To:Subject:Reply-To:Content-ID:Content-Description:Resent-Date: Resent-From:Resent-Sender:Resent-To:Resent-Cc:Resent-Message-ID:List-Owner; bh=t+MD1SQcWV2/LouuR9sP5WtfGd0Ks1in1V6v+ox6trI=; b=RYXePkNKAsRt545oFQlqSjoql+ vEYGTU6RvlHOfHP3WM4TQM4AF6T1Pf++NEtbrwtmjEjTMeUWo4VPciFUVdpsiI2cLawrV+1jWB8TB NWnu+2emmjm5ruOfER8U3KVTRlynAJ4oEjfIVwBK68lorE3xKb++Skn5HIHqvEN0KvA4o7LrbF1Hk 7/OvpfK4e8RDQ3OpBOnYFeH3+vw5h3tM5AEcQfxSaS7qJdbLpdZ/sZKuIBxOJcHd+cDLPqz0q1Lsw kbr5ceJZjrhFlvpmUWx+B9pzXwkAGZ9+KpZqf9dEcrH4DJ5RODDeL1KROtqG9kL/v03+cCv4edJZt I7r4eP0Q==; Received: from localhost ([::1] helo=bombadil.infradead.org) by bombadil.infradead.org with esmtp (Exim 4.94.2 #2 (Red Hat Linux)) id 1lzFOg-002c1Q-Mi; Fri, 02 Jul 2021 09:23:42 +0000 Received: from mx07-00178001.pphosted.com ([185.132.182.106]) by bombadil.infradead.org with esmtps (Exim 4.94.2 #2 (Red Hat Linux)) id 1lzFOc-002bzX-RW for linux-arm-kernel@lists.infradead.org; Fri, 02 Jul 2021 09:23:40 +0000 Received: from pps.filterd (m0241204.ppops.net [127.0.0.1]) by mx07-00178001.pphosted.com (8.16.0.43/8.16.0.43) with SMTP id 1629AxOI019441; Fri, 2 Jul 2021 11:23:25 +0200 DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=foss.st.com; h=subject : to : cc : references : from : message-id : date : mime-version : in-reply-to : content-type : content-transfer-encoding; s=selector1; bh=5ywvL4VVQ+2r/jhdIM14ypRiW/ywajQXfPzZ2maovTA=; b=LCFPp+Y/RgFx7ixHPOVRqbIYocI4RlvALr9i9XihsloC62P6IqcJYwyoVmO8ylFHUZ20 L8og9QpEFFl1aiSqTNk9cS9Z7SrCTiYbrmqAsWAxFMurq+NRNG26/Sl2q2j4+Kmtysz5 k0vqFhDN2uHI6j8gFBRBfBWOgFNkLlXVQGdpeN5Sxsf19WOtmvPibI9VciZUFYW9yYdL gc/Mewf4JRC9Ocf81Ywq18JbF7ik0ZCTLv5Bb7qoXfgJQ0Zjm56yfEe6pdpc4QASptl3 H9b5gRz0WrsJfQE7zpIvK19h/jh6l6GLIR4EuT5PLLUFMAC9x0eLi+cos7DiI+ViAvAo lg== Received: from beta.dmz-eu.st.com (beta.dmz-eu.st.com [164.129.1.35]) by mx07-00178001.pphosted.com with ESMTP id 39hw3cscpu-1 (version=TLSv1.2 cipher=ECDHE-RSA-AES256-GCM-SHA384 bits=256 verify=NOT); Fri, 02 Jul 2021 11:23:25 +0200 Received: from euls16034.sgp.st.com (euls16034.sgp.st.com [10.75.44.20]) by beta.dmz-eu.st.com (STMicroelectronics) with ESMTP id 317E610002A; Fri, 2 Jul 2021 11:23:23 +0200 (CEST) Received: from Webmail-eu.st.com (sfhdag2node3.st.com [10.75.127.6]) by euls16034.sgp.st.com (STMicroelectronics) with ESMTP id 8E2F8217B92; Fri, 2 Jul 2021 11:23:23 +0200 (CEST) Received: from lmecxl0557.lme.st.com (10.75.127.47) by SFHDAG2NODE3.st.com (10.75.127.6) with Microsoft SMTP Server (TLS) id 15.0.1497.2; Fri, 2 Jul 2021 11:23:22 +0200 Subject: Re: [PATCH] drm/stm: ltdc: improve pm_runtime to stop clocks To: Marek Vasut CC: Yannick FERTRE , Philippe CORNU , Raphael GALLAIS-POU , Yannick FERTRE - foss , Philippe CORNU - foss , Benjamin Gaignard , David Airlie , "Daniel Vetter" , Maxime Coquelin , Alexandre TORGUE - foss , "dri-devel@lists.freedesktop.org" , "linux-stm32@st-md-mailman.stormreply.com" , "linux-arm-kernel@lists.infradead.org" , "linux-kernel@vger.kernel.org" , Stephen Boyd References: <20210629115709.16145-1-raphael.gallais-pou@foss.st.com> <420e243d-7541-a07e-177b-d2db11c26aef@denx.de> From: Raphael Gallais-Pou Message-ID: <3bb823e4-4724-7072-fe9f-7b8a355c8e50@foss.st.com> Date: Fri, 2 Jul 2021 11:23:21 +0200 User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:78.0) Gecko/20100101 Thunderbird/78.8.1 MIME-Version: 1.0 In-Reply-To: <420e243d-7541-a07e-177b-d2db11c26aef@denx.de> Content-Language: en-US X-Originating-IP: [10.75.127.47] X-ClientProxiedBy: SFHDAG1NODE3.st.com (10.75.127.3) To SFHDAG2NODE3.st.com (10.75.127.6) X-Proofpoint-Virus-Version: vendor=fsecure engine=2.50.10434:6.0.391, 18.0.790 definitions=2021-07-02_01:2021-07-02, 2021-07-02 signatures=0 X-CRM114-Version: 20100106-BlameMichelson ( TRE 0.8.0 (BSD) ) MR-646709E3 X-CRM114-CacheID: sfid-20210702_022339_216983_96C81BAD X-CRM114-Status: GOOD ( 22.32 ) X-BeenThere: linux-arm-kernel@lists.infradead.org X-Mailman-Version: 2.1.34 Precedence: list List-Id: List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , Content-Transfer-Encoding: base64 Content-Type: text/plain; charset="utf-8"; Format="flowed" Sender: "linux-arm-kernel" Errors-To: linux-arm-kernel-bounces+linux-arm-kernel=archiver.kernel.org@lists.infradead.org SGVsbG8gTWFyZWssCgoKU29ycnkgZm9yIHRoZSBsYXRlIGFuc3dlci4KCgpPbiA2LzMwLzIxIDI6 MzUgQU0sIE1hcmVrIFZhc3V0IHdyb3RlOgo+IE9uIDYvMjkvMjEgMTo1OCBQTSwgUmFwaGFlbCBH QUxMQUlTLVBPVSAtIGZvc3Mgd3JvdGU6Cj4KPiBbLi4uXQo+Cj4+ICsrKyBiL2RyaXZlcnMvZ3B1 L2RybS9zdG0vbHRkYy5jCj4+IEBAIC00MjUsMTAgKzQyNSwxNyBAQCBzdGF0aWMgdm9pZCBsdGRj X2NydGNfYXRvbWljX2VuYWJsZShzdHJ1Y3QgCj4+IGRybV9jcnRjICpjcnRjLAo+PiDCoCB7Cj4+ IMKgwqDCoMKgwqAgc3RydWN0IGx0ZGNfZGV2aWNlICpsZGV2ID0gY3J0Y190b19sdGRjKGNydGMp Owo+PiDCoMKgwqDCoMKgIHN0cnVjdCBkcm1fZGV2aWNlICpkZGV2ID0gY3J0Yy0+ZGV2Owo+PiAr wqDCoMKgIGludCByZXQ7Cj4+IMKgIMKgwqDCoMKgwqAgRFJNX0RFQlVHX0RSSVZFUigiXG4iKTsK Pj4gwqAgLcKgwqDCoCBwbV9ydW50aW1lX2dldF9zeW5jKGRkZXYtPmRldik7Cj4+ICvCoMKgwqAg aWYgKCFwbV9ydW50aW1lX2FjdGl2ZShkZGV2LT5kZXYpKSB7Cj4+ICvCoMKgwqDCoMKgwqDCoCBy ZXQgPSBwbV9ydW50aW1lX2dldF9zeW5jKGRkZXYtPmRldik7Cj4KPiBBbGwgdGhlc2UgaWYgKCFw bV9ydW50aW1lX2FjdGl2ZSgpKSB0aGVuIHBtX3J1bnRpbWVfZ2V0X3N5bmMoKSBjYWxscyAKPiBs b29rIGxpa2Ugd29ya2Fyb3VuZCBmb3Igc29tZSBsYXJnZXIgaXNzdWUuIFNob3VsZG4ndCB0aGUg cG1fcnVudGltZSAKPiBkbyBzb21lIHJlZmNvdW50aW5nIG9uIGl0cyBvd24gLCBzbyB0aGlzIHNo b3VsZG4ndCBiZSBuZWVkZWQgPwoKClRoaXMgcHJvYmxlbSBwdXJlbHkgY29tZXMgZnJvbSB0aGUg ZHJpdmVyIGludGVybmFscywgc28gSSBkb24ndCB0aGluayBpdCAKaXMgYSB3b3JrYXJvdW5kLgoK QmVjYXVzZSBvZiB0aGUgImx0ZGNfY3J0Y19tb2RlX3NldF9ub2ZiIiBmdW5jdGlvbiB3aGljaCBk b2VzIG5vdCBoYXZlIAphbnkgInN5bW1ldHJpY2FsIiBjYWxsLCBzdWNoIGFzIGVuYWJsZS9kaXNh YmxlIGZ1bmN0aW9ucywgdGhlcmUgd2FzIHR3byAKY2FsbHMgdG8gcG1fcnVudGltZV9nZXRfc3lu YyBhZ2FpbnN0IG9uZSBjYWxsIHRvIHBtX3J1bnRpbWVfcHV0X3N5bmMuCgpUaGlzIGluc3RhYmls aXR5IHJlc3VsdGVkIGluIHRoZSBMVERDIGNsb2NrcyBiZWluZyBhbHdheXMgZW5hYmxlZCwgZXZl biAKd2hlbiB0aGUgcGVyaXBoZXJhbCB3YXMgZGlzYWJsZWQuIFRoaXMgY291bGQgYmUgc2VlbiBp biB0aGUgY2xrX3N1bW1hcnkgCmFzIGV4cGxhaW5lZCBpbiB0aGUgcGF0Y2ggc3VtbWFyeSBhbW9u ZyBvdGhlciB0aGluZ3MuCgpCeSBkb2luZyBzbywgd2UgZmlyc3QgY2hlY2sgaWYgdGhlIGNsb2Nr cyBhcmUgbm90IGFscmVhZHkgYWN0aXZhdGVkLCBhbmQgCmluIHRoYXQgY2FzZSB3ZSBjYWxsIHBt X3J1bnRpbWVfZ2V0X3N5bmMuCgoKClJlZ2FyZHMsCgpSYXBoYcOrbCBHLVAKCgpfX19fX19fX19f X19fX19fX19fX19fX19fX19fX19fX19fX19fX19fX19fX19fXwpsaW51eC1hcm0ta2VybmVsIG1h aWxpbmcgbGlzdApsaW51eC1hcm0ta2VybmVsQGxpc3RzLmluZnJhZGVhZC5vcmcKaHR0cDovL2xp c3RzLmluZnJhZGVhZC5vcmcvbWFpbG1hbi9saXN0aW5mby9saW51eC1hcm0ta2VybmVsCg== From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: X-Spam-Checker-Version: SpamAssassin 3.4.0 (2014-02-07) on aws-us-west-2-korg-lkml-1.web.codeaurora.org X-Spam-Level: X-Spam-Status: No, score=-10.1 required=3.0 tests=BAYES_00,DKIM_INVALID, DKIM_SIGNED,HEADER_FROM_DIFFERENT_DOMAINS,INCLUDES_PATCH,MAILING_LIST_MULTI, NICE_REPLY_A,SPF_HELO_NONE,SPF_PASS,USER_AGENT_SANE_1 autolearn=ham autolearn_force=no version=3.4.0 Received: from mail.kernel.org (mail.kernel.org [198.145.29.99]) by smtp.lore.kernel.org (Postfix) with ESMTP id 944BAC11F68 for ; Fri, 2 Jul 2021 09:23:33 +0000 (UTC) Received: from gabe.freedesktop.org (gabe.freedesktop.org [131.252.210.177]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by mail.kernel.org (Postfix) with ESMTPS id 4AB5461090 for ; Fri, 2 Jul 2021 09:23:33 +0000 (UTC) DMARC-Filter: OpenDMARC Filter v1.3.2 mail.kernel.org 4AB5461090 Authentication-Results: mail.kernel.org; dmarc=fail (p=none dis=none) header.from=foss.st.com Authentication-Results: mail.kernel.org; spf=none smtp.mailfrom=dri-devel-bounces@lists.freedesktop.org Received: from gabe.freedesktop.org (localhost [127.0.0.1]) by gabe.freedesktop.org (Postfix) with ESMTP id C683E89AB9; Fri, 2 Jul 2021 09:23:32 +0000 (UTC) Received: from mx07-00178001.pphosted.com (mx07-00178001.pphosted.com [185.132.182.106]) by gabe.freedesktop.org (Postfix) with ESMTPS id DF0F889A91 for ; Fri, 2 Jul 2021 09:23:31 +0000 (UTC) Received: from pps.filterd (m0241204.ppops.net [127.0.0.1]) by mx07-00178001.pphosted.com (8.16.0.43/8.16.0.43) with SMTP id 1629AxOI019441; Fri, 2 Jul 2021 11:23:25 +0200 DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=foss.st.com; h=subject : to : cc : references : from : message-id : date : mime-version : in-reply-to : content-type : content-transfer-encoding; s=selector1; bh=5ywvL4VVQ+2r/jhdIM14ypRiW/ywajQXfPzZ2maovTA=; b=LCFPp+Y/RgFx7ixHPOVRqbIYocI4RlvALr9i9XihsloC62P6IqcJYwyoVmO8ylFHUZ20 L8og9QpEFFl1aiSqTNk9cS9Z7SrCTiYbrmqAsWAxFMurq+NRNG26/Sl2q2j4+Kmtysz5 k0vqFhDN2uHI6j8gFBRBfBWOgFNkLlXVQGdpeN5Sxsf19WOtmvPibI9VciZUFYW9yYdL gc/Mewf4JRC9Ocf81Ywq18JbF7ik0ZCTLv5Bb7qoXfgJQ0Zjm56yfEe6pdpc4QASptl3 H9b5gRz0WrsJfQE7zpIvK19h/jh6l6GLIR4EuT5PLLUFMAC9x0eLi+cos7DiI+ViAvAo lg== Received: from beta.dmz-eu.st.com (beta.dmz-eu.st.com [164.129.1.35]) by mx07-00178001.pphosted.com with ESMTP id 39hw3cscpu-1 (version=TLSv1.2 cipher=ECDHE-RSA-AES256-GCM-SHA384 bits=256 verify=NOT); Fri, 02 Jul 2021 11:23:25 +0200 Received: from euls16034.sgp.st.com (euls16034.sgp.st.com [10.75.44.20]) by beta.dmz-eu.st.com (STMicroelectronics) with ESMTP id 317E610002A; Fri, 2 Jul 2021 11:23:23 +0200 (CEST) Received: from Webmail-eu.st.com (sfhdag2node3.st.com [10.75.127.6]) by euls16034.sgp.st.com (STMicroelectronics) with ESMTP id 8E2F8217B92; Fri, 2 Jul 2021 11:23:23 +0200 (CEST) Received: from lmecxl0557.lme.st.com (10.75.127.47) by SFHDAG2NODE3.st.com (10.75.127.6) with Microsoft SMTP Server (TLS) id 15.0.1497.2; Fri, 2 Jul 2021 11:23:22 +0200 Subject: Re: [PATCH] drm/stm: ltdc: improve pm_runtime to stop clocks To: Marek Vasut References: <20210629115709.16145-1-raphael.gallais-pou@foss.st.com> <420e243d-7541-a07e-177b-d2db11c26aef@denx.de> From: Raphael Gallais-Pou Message-ID: <3bb823e4-4724-7072-fe9f-7b8a355c8e50@foss.st.com> Date: Fri, 2 Jul 2021 11:23:21 +0200 User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:78.0) Gecko/20100101 Thunderbird/78.8.1 MIME-Version: 1.0 In-Reply-To: <420e243d-7541-a07e-177b-d2db11c26aef@denx.de> Content-Type: text/plain; charset="utf-8"; format=flowed Content-Transfer-Encoding: 8bit Content-Language: en-US X-Originating-IP: [10.75.127.47] X-ClientProxiedBy: SFHDAG1NODE3.st.com (10.75.127.3) To SFHDAG2NODE3.st.com (10.75.127.6) X-Proofpoint-Virus-Version: vendor=fsecure engine=2.50.10434:6.0.391, 18.0.790 definitions=2021-07-02_01:2021-07-02, 2021-07-02 signatures=0 X-BeenThere: dri-devel@lists.freedesktop.org X-Mailman-Version: 2.1.29 Precedence: list List-Id: Direct Rendering Infrastructure - Development List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , Cc: Maxime Coquelin , Raphael GALLAIS-POU , David Airlie , "linux-kernel@vger.kernel.org" , Yannick FERTRE - foss , Philippe CORNU , "dri-devel@lists.freedesktop.org" , Alexandre TORGUE - foss , Yannick FERTRE , Philippe CORNU - foss , Benjamin Gaignard , Stephen Boyd , "linux-stm32@st-md-mailman.stormreply.com" , "linux-arm-kernel@lists.infradead.org" Errors-To: dri-devel-bounces@lists.freedesktop.org Sender: "dri-devel" Hello Marek, Sorry for the late answer. On 6/30/21 2:35 AM, Marek Vasut wrote: > On 6/29/21 1:58 PM, Raphael GALLAIS-POU - foss wrote: > > [...] > >> +++ b/drivers/gpu/drm/stm/ltdc.c >> @@ -425,10 +425,17 @@ static void ltdc_crtc_atomic_enable(struct >> drm_crtc *crtc, >>   { >>       struct ltdc_device *ldev = crtc_to_ltdc(crtc); >>       struct drm_device *ddev = crtc->dev; >> +    int ret; >>         DRM_DEBUG_DRIVER("\n"); >>   -    pm_runtime_get_sync(ddev->dev); >> +    if (!pm_runtime_active(ddev->dev)) { >> +        ret = pm_runtime_get_sync(ddev->dev); > > All these if (!pm_runtime_active()) then pm_runtime_get_sync() calls > look like workaround for some larger issue. Shouldn't the pm_runtime > do some refcounting on its own , so this shouldn't be needed ? This problem purely comes from the driver internals, so I don't think it is a workaround. Because of the "ltdc_crtc_mode_set_nofb" function which does not have any "symmetrical" call, such as enable/disable functions, there was two calls to pm_runtime_get_sync against one call to pm_runtime_put_sync. This instability resulted in the LTDC clocks being always enabled, even when the peripheral was disabled. This could be seen in the clk_summary as explained in the patch summary among other things. By doing so, we first check if the clocks are not already activated, and in that case we call pm_runtime_get_sync. Regards, Raphaël G-P