Received: by 2002:a05:6a10:8c0a:0:0:0:0 with SMTP id go10csp1782819pxb; Mon, 22 Feb 2021 10:42:42 -0800 (PST) X-Google-Smtp-Source: ABdhPJzba30wex8xUkEaGMrWRRfqTXJjrXLjRn6kTQfEah5DsQ545ZjQk8kUZoT/7BB7CZ6ykQ70 X-Received: by 2002:a50:d9cc:: with SMTP id x12mr24491697edj.68.1614019362144; Mon, 22 Feb 2021 10:42:42 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1614019362; cv=none; d=google.com; s=arc-20160816; b=o4N+FqP2fQIuOnZP7Tc6FRLC0ju1TbXpSrlW2IPf4vaNV47m5dtHwAJ7I8l8ZV+kgV jodh9t8lqb9tKlr2DdiAYXtXfqYxrCA0cXvDzdtM5NzY1UvtzPXRBmajLPoZk7/mRDi3 D11ZO+npwj9Q7oZuvOrPFdjJgUVXNNy8yjTWkUrYFyL+bj8MB7pKU/xxPQPmOtx7XzoJ XdzqXc91LTFDMsqPChU6urFiOyJ9y1QNoBsgWqQF3Peatm6uvrtY8YFoM+Lp7yar7Ucu 91go4EuCHa6WND7PAvcxdye2WtlvUznoOT3hgwTNGEaT9HK+3T9qvLig4poTrJ1aNykR 89vw== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:in-reply-to:content-transfer-encoding :content-disposition:mime-version:references:message-id:subject:cc :to:from:date; bh=xO6dXhcIk1fwLWNAxyfUyTNdYW+2dI64M3Bq/Rtggkk=; b=UV+/bUIeuub1xwP6iQJzM5QabsEnnmtmFI7E5cgOzfdazqCYzapdacr2sfDf2MkZts FpdveCWYhi8/uuVwrrYhk+BGkPzSepHqcbBqyewELTIwVoy3+aEXT65a2Y0Dj3V6rfG0 yTjPLX5TeAUCqnE35QZTomoFJnDHVB3ClDmdYZ5/nm/wMXdKOMHKocUcO06qXGqalnjE apv7IN7P1lETuXmMRmpp/6MtY7rRnX2jrr5SMlOzG70N5165b4FFhadBjqoDbCzxqb33 Khp5MdFWeHvwBScSHydCNoHEAXp7rIE0KenhpMQZQUJmZ+d5fvhsFpzXVrE8zCUdfySm ADog== 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 j21si12248254edh.58.2021.02.22.10.42.19; Mon, 22 Feb 2021 10:42:42 -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 S231195AbhBVSkp (ORCPT + 99 others); Mon, 22 Feb 2021 13:40:45 -0500 Received: from honk.sigxcpu.org ([24.134.29.49]:55080 "EHLO honk.sigxcpu.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S230433AbhBVSjy (ORCPT ); Mon, 22 Feb 2021 13:39:54 -0500 Received: from localhost (localhost [127.0.0.1]) by honk.sigxcpu.org (Postfix) with ESMTP id 9D595FB05; Mon, 22 Feb 2021 19:39:09 +0100 (CET) X-Virus-Scanned: Debian amavisd-new at honk.sigxcpu.org Received: from honk.sigxcpu.org ([127.0.0.1]) by localhost (honk.sigxcpu.org [127.0.0.1]) (amavisd-new, port 10024) with ESMTP id KYsFArh9S4Nr; Mon, 22 Feb 2021 19:39:07 +0100 (CET) Date: Mon, 22 Feb 2021 19:39:06 +0100 From: Guido =?iso-8859-1?Q?G=FCnther?= To: Liu Ying Cc: Kishon Vijay Abraham I , Shawn Guo , Sascha Hauer , Pengutronix Kernel Team , Fabio Estevam , NXP Linux Team , Robert Chiras , Sam Ravnborg , linux-kernel@vger.kernel.org, linux-arm-kernel@lists.infradead.org Subject: Re: [PATCH v2 1/1] phy: fsl-imx8-mipi-dphy: Hook into runtime pm Message-ID: References: <424af315b677934fe6a91cee5a0a7aee058245a9.camel@nxp.com> MIME-Version: 1.0 Content-Type: text/plain; charset=iso-8859-1 Content-Disposition: inline Content-Transfer-Encoding: 8bit In-Reply-To: <424af315b677934fe6a91cee5a0a7aee058245a9.camel@nxp.com> Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Hi Liu, On Sat, Feb 20, 2021 at 01:37:29PM +0800, Liu Ying wrote: > Hi Guido, > > On Wed, 2020-12-16 at 12:27 +0100, Guido G?nther wrote: > > This allows us to shut down the mipi power domain on the imx8. The > > alternative would be to drop the dphy from the mipi power domain in the > > SOCs device tree and only have the DSI host controller visible there but > > since the PD is mostly about the PHY that would defeat it's purpose. > > > > This allows to shut off the power domain hen blanking the LCD panel: > > > > pm_genpd_summary before: > > > > domain status slaves > > /device runtime status > > ---------------------------------------------------------------------- > > mipi on > > /devices/platform/soc@0/soc@0:bus@30800000/30a00300.dphy unsupported > > /devices/platform/soc@0/soc@0:bus@30800000/30a00000.mipi_dsi suspended > > > > after: > > > > mipi off-0 > > /devices/platform/soc@0/soc@0:bus@30800000/30a00300.dphy suspended > > /devices/platform/soc@0/soc@0:bus@30800000/30a00000.mipi_dsi suspended > > > > Signed-off-by: Guido G?nther > > --- > > .../phy/freescale/phy-fsl-imx8-mipi-dphy.c | 22 ++++++++++++++++++- > > 1 file changed, 21 insertions(+), 1 deletion(-) > > > > diff --git a/drivers/phy/freescale/phy-fsl-imx8-mipi-dphy.c b/drivers/phy/freescale/phy-fsl-imx8-mipi-dphy.c > > index a95572b397ca..34e2d801e520 100644 > > --- a/drivers/phy/freescale/phy-fsl-imx8-mipi-dphy.c > > +++ b/drivers/phy/freescale/phy-fsl-imx8-mipi-dphy.c > > @@ -14,6 +14,7 @@ > > #include > > #include > > #include > > +#include > > #include > > > > /* DPHY registers */ > > @@ -93,6 +94,7 @@ struct mixel_dphy_cfg { > > }; > > > > struct mixel_dphy_priv { > > + struct device *dev; > > struct mixel_dphy_cfg cfg; > > struct regmap *regmap; > > struct clk *phy_ref_clk; > > @@ -382,6 +384,7 @@ static int mixel_dphy_power_on(struct phy *phy) > > ret = clk_prepare_enable(priv->phy_ref_clk); > > if (ret < 0) > > return ret; > > + pm_runtime_get_sync(priv->dev); > > > > phy_write(phy, PWR_ON, DPHY_PD_PLL); > > ret = regmap_read_poll_timeout(priv->regmap, DPHY_LOCK, locked, > > @@ -395,6 +398,7 @@ static int mixel_dphy_power_on(struct phy *phy) > > > > return 0; > > clock_disable: > > + pm_runtime_put(priv->dev); > > clk_disable_unprepare(priv->phy_ref_clk); > > return ret; > > } > > @@ -406,6 +410,7 @@ static int mixel_dphy_power_off(struct phy *phy) > > phy_write(phy, PWR_OFF, DPHY_PD_PLL); > > phy_write(phy, PWR_OFF, DPHY_PD_DPHY); > > > > + pm_runtime_put(priv->dev); > > clk_disable_unprepare(priv->phy_ref_clk); > > > > return 0; > > @@ -467,6 +472,7 @@ static int mixel_dphy_probe(struct platform_device *pdev) > > dev_dbg(dev, "phy_ref clock rate: %lu\n", > > clk_get_rate(priv->phy_ref_clk)); > > > > + priv->dev = dev; > > dev_set_drvdata(dev, priv); > > > > phy = devm_phy_create(dev, np, &mixel_dphy_phy_ops); > > @@ -477,12 +483,26 @@ static int mixel_dphy_probe(struct platform_device *pdev) > > phy_set_drvdata(phy, priv); > > > > phy_provider = devm_of_phy_provider_register(dev, of_phy_simple_xlate); > > + if (IS_ERR(phy_provider)) > > + return PTR_ERR(phy_provider); > > > > - return PTR_ERR_OR_ZERO(phy_provider); > > + pm_runtime_enable(dev); > > If this enablement is done prior to devm_phy_create(), then the > phy-core will manage runtime PM for this device. This way, this driver > doesn't have to manage it by itself. That makes things simpler indeed. Fixed in v4 together with your other comment. Thanks! -- Guido > > Regards, > Liu Ying > > > + > > + return 0; > > +} > > + > > +static int mixel_dphy_remove(struct platform_device *pdev) > > +{ > > + struct mixel_dphy_priv *priv = platform_get_drvdata(pdev); > > + > > + pm_runtime_disable(priv->dev); > > + > > + return 0; > > } > > > > static struct platform_driver mixel_dphy_driver = { > > .probe = mixel_dphy_probe, > > + .remove = mixel_dphy_remove, > > .driver = { > > .name = "mixel-mipi-dphy", > > .of_match_table = mixel_dphy_of_match, >