linux-spi.vger.kernel.org archive mirror
 help / color / mirror / Atom feed
From: Dmitry Osipenko <digetx@gmail.com>
To: "Thierry Reding" <thierry.reding@gmail.com>,
	"Jonathan Hunter" <jonathanh@nvidia.com>,
	"Ulf Hansson" <ulf.hansson@linaro.org>,
	"Viresh Kumar" <vireshk@kernel.org>,
	"Stephen Boyd" <sboyd@kernel.org>,
	"Peter De Schrijver" <pdeschrijver@nvidia.com>,
	"Mikko Perttunen" <mperttunen@nvidia.com>,
	"Peter Chen" <peter.chen@kernel.org>,
	"Mark Brown" <broonie@kernel.org>,
	"Lee Jones" <lee.jones@linaro.org>,
	"Uwe Kleine-König" <u.kleine-koenig@pengutronix.de>,
	"Nishanth Menon" <nm@ti.com>,
	"Vignesh Raghavendra" <vigneshr@ti.com>,
	"Richard Weinberger" <richard@nod.at>,
	"Miquel Raynal" <miquel.raynal@bootlin.com>,
	"Lucas Stach" <dev@lynxeye.de>, "Stefan Agner" <stefan@agner.ch>,
	"Adrian Hunter" <adrian.hunter@intel.com>,
	"Mauro Carvalho Chehab" <mchehab@kernel.org>,
	"Rob Herring" <robh+dt@kernel.org>,
	"Michael Turquette" <mturquette@baylibre.com>
Cc: linux-kernel@vger.kernel.org, linux-tegra@vger.kernel.org,
	linux-pm@vger.kernel.org, linux-usb@vger.kernel.org,
	linux-staging@lists.linux.dev, linux-spi@vger.kernel.org,
	linux-pwm@vger.kernel.org, linux-mtd@lists.infradead.org,
	linux-mmc@vger.kernel.org, linux-media@vger.kernel.org,
	dri-devel@lists.freedesktop.org, devicetree@vger.kernel.org,
	linux-clk@vger.kernel.org
Subject: [PATCH v11 12/34] drm/tegra: hdmi: Add OPP support
Date: Sun, 12 Sep 2021 23:08:10 +0300	[thread overview]
Message-ID: <20210912200832.12312-13-digetx@gmail.com> (raw)
In-Reply-To: <20210912200832.12312-1-digetx@gmail.com>

The HDMI on Tegra belongs to the core power domain and we're going to
enable GENPD support for the core domain. Now HDMI driver must use
OPP API for driving the controller's clock rate because OPP API takes
care of reconfiguring the domain's performance state based on HDMI clock
rate. Add OPP support to the HDMI driver.

Signed-off-by: Dmitry Osipenko <digetx@gmail.com>
---
 drivers/gpu/drm/tegra/hdmi.c | 16 ++++++++++++----
 1 file changed, 12 insertions(+), 4 deletions(-)

diff --git a/drivers/gpu/drm/tegra/hdmi.c b/drivers/gpu/drm/tegra/hdmi.c
index e5d2a4026028..9a87d351a828 100644
--- a/drivers/gpu/drm/tegra/hdmi.c
+++ b/drivers/gpu/drm/tegra/hdmi.c
@@ -11,10 +11,13 @@
 #include <linux/math64.h>
 #include <linux/module.h>
 #include <linux/of_device.h>
+#include <linux/pm_opp.h>
 #include <linux/pm_runtime.h>
 #include <linux/regulator/consumer.h>
 #include <linux/reset.h>
 
+#include <soc/tegra/common.h>
+
 #include <drm/drm_atomic_helper.h>
 #include <drm/drm_crtc.h>
 #include <drm/drm_debugfs.h>
@@ -1195,7 +1198,7 @@ static void tegra_hdmi_encoder_enable(struct drm_encoder *encoder)
 	h_back_porch = mode->htotal - mode->hsync_end;
 	h_front_porch = mode->hsync_start - mode->hdisplay;
 
-	err = clk_set_rate(hdmi->clk, hdmi->pixel_clock);
+	err = dev_pm_opp_set_rate(hdmi->dev, hdmi->pixel_clock);
 	if (err < 0) {
 		dev_err(hdmi->dev, "failed to set HDMI clock frequency: %d\n",
 			err);
@@ -1732,7 +1735,14 @@ static int tegra_hdmi_probe(struct platform_device *pdev)
 	}
 
 	platform_set_drvdata(pdev, hdmi);
-	pm_runtime_enable(&pdev->dev);
+
+	err = devm_pm_runtime_enable(&pdev->dev);
+	if (err)
+		return err;
+
+	err = devm_tegra_core_dev_init_opp_table_common(&pdev->dev);
+	if (err)
+		return err;
 
 	INIT_LIST_HEAD(&hdmi->client.list);
 	hdmi->client.ops = &hdmi_client_ops;
@@ -1753,8 +1763,6 @@ static int tegra_hdmi_remove(struct platform_device *pdev)
 	struct tegra_hdmi *hdmi = platform_get_drvdata(pdev);
 	int err;
 
-	pm_runtime_disable(&pdev->dev);
-
 	err = host1x_client_unregister(&hdmi->client);
 	if (err < 0) {
 		dev_err(&pdev->dev, "failed to unregister host1x client: %d\n",
-- 
2.32.0


  parent reply	other threads:[~2021-09-12 20:10 UTC|newest]

Thread overview: 39+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2021-09-12 20:07 [PATCH v11 00/34] NVIDIA Tegra power management patches for 5.16 Dmitry Osipenko
2021-09-12 20:07 ` [PATCH v11 01/34] opp: Change type of dev_pm_opp_attach_genpd(names) argument Dmitry Osipenko
2021-09-12 20:08 ` [PATCH v11 02/34] soc/tegra: Add devm_tegra_core_dev_init_opp_table_common() Dmitry Osipenko
2021-09-12 20:08 ` [PATCH v11 03/34] soc/tegra: pmc: Disable PMC state syncing Dmitry Osipenko
2021-09-12 20:08 ` [PATCH v11 04/34] soc/tegra: Don't print error message when OPPs not available Dmitry Osipenko
2021-09-12 20:08 ` [PATCH v11 05/34] dt-bindings: clock: tegra-car: Document new clock sub-nodes Dmitry Osipenko
2021-09-12 20:08 ` [PATCH v11 06/34] clk: tegra: Support runtime PM and power domain Dmitry Osipenko
2021-09-12 20:08 ` [PATCH v11 07/34] dt-bindings: host1x: Document OPP and power domain properties Dmitry Osipenko
2021-09-12 20:08 ` [PATCH v11 08/34] dt-bindings: host1x: Document Memory Client resets of Host1x, GR2D and GR3D Dmitry Osipenko
2021-09-16 19:49   ` Rob Herring
2021-09-12 20:08 ` [PATCH v11 09/34] gpu: host1x: Add runtime PM and OPP support Dmitry Osipenko
2021-09-12 20:08 ` [PATCH v11 10/34] gpu: host1x: Add host1x_channel_stop() Dmitry Osipenko
2021-09-12 20:08 ` [PATCH v11 11/34] drm/tegra: dc: Support OPP and SoC core voltage scaling Dmitry Osipenko
2021-09-12 20:08 ` Dmitry Osipenko [this message]
2021-09-12 20:08 ` [PATCH v11 13/34] drm/tegra: gr2d: Support generic power domain and runtime PM Dmitry Osipenko
2021-09-12 20:08 ` [PATCH v11 14/34] drm/tegra: gr3d: " Dmitry Osipenko
2021-09-12 20:08 ` [PATCH v11 15/34] drm/tegra: vic: Support system suspend Dmitry Osipenko
2021-09-12 20:08 ` [PATCH v11 16/34] usb: chipidea: tegra: Add runtime PM and OPP support Dmitry Osipenko
2021-09-12 20:08 ` [PATCH v11 17/34] bus: tegra-gmi: " Dmitry Osipenko
2021-09-12 20:08 ` [PATCH v11 18/34] pwm: tegra: " Dmitry Osipenko
2021-09-12 20:08 ` [PATCH v11 19/34] mmc: sdhci-tegra: " Dmitry Osipenko
2021-09-12 20:08 ` [PATCH v11 20/34] mtd: rawnand: tegra: " Dmitry Osipenko
2021-09-12 20:08 ` [PATCH v11 21/34] spi: tegra20-slink: Add " Dmitry Osipenko
2021-09-12 20:08 ` [PATCH v11 22/34] media: dt: bindings: tegra-vde: Convert to schema Dmitry Osipenko
2021-09-13 10:36   ` Hans Verkuil
2021-09-12 20:08 ` [PATCH v11 23/34] media: dt: bindings: tegra-vde: Document OPP and power domain Dmitry Osipenko
2021-09-13 10:36   ` Hans Verkuil
2021-09-12 20:08 ` [PATCH v11 24/34] media: staging: tegra-vde: Support generic " Dmitry Osipenko
2021-09-13 10:37   ` Hans Verkuil
2021-09-12 20:08 ` [PATCH v11 25/34] soc/tegra: fuse: Reset hardware Dmitry Osipenko
2021-09-12 20:08 ` [PATCH v11 26/34] soc/tegra: fuse: Use resource-managed helpers Dmitry Osipenko
2021-09-12 20:08 ` [PATCH v11 27/34] soc/tegra: regulators: Prepare for suspend Dmitry Osipenko
2021-09-12 20:08 ` [PATCH v11 28/34] soc/tegra: pmc: Change name of core power domain Dmitry Osipenko
2021-09-12 20:08 ` [PATCH v11 29/34] soc/tegra: pmc: Enable core domain support for Tegra20 and Tegra30 Dmitry Osipenko
2021-09-12 20:08 ` [PATCH v11 30/34] ARM: tegra: Add OPP tables and power domains to Tegra20 device-trees Dmitry Osipenko
2021-09-12 20:08 ` [PATCH v11 31/34] ARM: tegra: Add OPP tables and power domains to Tegra30 device-trees Dmitry Osipenko
2021-09-12 20:08 ` [PATCH v11 32/34] ARM: tegra: Add Memory Client resets to Tegra20 GR2D, GR3D and Host1x Dmitry Osipenko
2021-09-12 20:08 ` [PATCH v11 33/34] ARM: tegra: Add Memory Client resets to Tegra30 " Dmitry Osipenko
2021-09-12 20:08 ` [PATCH v11 34/34] ARM: tegra20/30: Disable unused host1x hardware Dmitry Osipenko

Reply instructions:

You may reply publicly to this message via plain-text email
using any one of the following methods:

* Save the following mbox file, import it into your mail client,
  and reply-to-all from there: mbox

  Avoid top-posting and favor interleaved quoting:
  https://en.wikipedia.org/wiki/Posting_style#Interleaved_style

* Reply using the --to, --cc, and --in-reply-to
  switches of git-send-email(1):

  git send-email \
    --in-reply-to=20210912200832.12312-13-digetx@gmail.com \
    --to=digetx@gmail.com \
    --cc=adrian.hunter@intel.com \
    --cc=broonie@kernel.org \
    --cc=dev@lynxeye.de \
    --cc=devicetree@vger.kernel.org \
    --cc=dri-devel@lists.freedesktop.org \
    --cc=jonathanh@nvidia.com \
    --cc=lee.jones@linaro.org \
    --cc=linux-clk@vger.kernel.org \
    --cc=linux-kernel@vger.kernel.org \
    --cc=linux-media@vger.kernel.org \
    --cc=linux-mmc@vger.kernel.org \
    --cc=linux-mtd@lists.infradead.org \
    --cc=linux-pm@vger.kernel.org \
    --cc=linux-pwm@vger.kernel.org \
    --cc=linux-spi@vger.kernel.org \
    --cc=linux-staging@lists.linux.dev \
    --cc=linux-tegra@vger.kernel.org \
    --cc=linux-usb@vger.kernel.org \
    --cc=mchehab@kernel.org \
    --cc=miquel.raynal@bootlin.com \
    --cc=mperttunen@nvidia.com \
    --cc=mturquette@baylibre.com \
    --cc=nm@ti.com \
    --cc=pdeschrijver@nvidia.com \
    --cc=peter.chen@kernel.org \
    --cc=richard@nod.at \
    --cc=robh+dt@kernel.org \
    --cc=sboyd@kernel.org \
    --cc=stefan@agner.ch \
    --cc=thierry.reding@gmail.com \
    --cc=u.kleine-koenig@pengutronix.de \
    --cc=ulf.hansson@linaro.org \
    --cc=vigneshr@ti.com \
    --cc=vireshk@kernel.org \
    /path/to/YOUR_REPLY

  https://kernel.org/pub/software/scm/git/docs/git-send-email.html

* If your mail client supports setting the In-Reply-To header
  via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).