* [PATCH 1/1] drm: bridge: ldb: Warn if LDB clock does not match requested link frequency
@ 2022-12-08 6:55 Alexander Stein
2023-01-19 7:38 ` Alexander Stein
` (2 more replies)
0 siblings, 3 replies; 4+ messages in thread
From: Alexander Stein @ 2022-12-08 6:55 UTC (permalink / raw)
To: Andrzej Hajda, Neil Armstrong, Robert Foss, Laurent Pinchart,
Jonas Karlman, Jernej Skrabec, David Airlie, Daniel Vetter
Cc: Alexander Stein, dri-devel
The LDB clock needs to be exactly 7-times the pixel clock used by the
display.
Signed-off-by: Alexander Stein <alexander.stein@ew.tq-group.com>
---
i.MX8MP has a dedicated LDB clock which defines the actual LVDS link frequency.
This has to be (exactly) the 7-time of the pixel clock.
Although the clock min/max range is available, panel-simple does not (yet) use
the range to find a (perfect) frequency which can be used down the chain, which
is also in range.
Depending on the pixel clock the exact multiple might not be configured.
Raise a warning if there is a mismatch, which might cause an invalid display
image.
drivers/gpu/drm/bridge/fsl-ldb.c | 23 +++++++++++++++++++----
1 file changed, 19 insertions(+), 4 deletions(-)
diff --git a/drivers/gpu/drm/bridge/fsl-ldb.c b/drivers/gpu/drm/bridge/fsl-ldb.c
index f9e0f8d992680..9bcba8fc57e74 100644
--- a/drivers/gpu/drm/bridge/fsl-ldb.c
+++ b/drivers/gpu/drm/bridge/fsl-ldb.c
@@ -66,6 +66,14 @@ static inline struct fsl_ldb *to_fsl_ldb(struct drm_bridge *bridge)
return container_of(bridge, struct fsl_ldb, bridge);
}
+static unsigned long fsl_ldb_link_frequency(struct fsl_ldb *fsl_ldb, int clock)
+{
+ if (fsl_ldb->lvds_dual_link)
+ return clock * 3500;
+ else
+ return clock * 7000;
+}
+
static int fsl_ldb_attach(struct drm_bridge *bridge,
enum drm_bridge_attach_flags flags)
{
@@ -85,6 +93,8 @@ static void fsl_ldb_atomic_enable(struct drm_bridge *bridge,
const struct drm_display_mode *mode;
struct drm_connector *connector;
struct drm_crtc *crtc;
+ unsigned long configured_link_freq;
+ unsigned long requested_link_freq;
bool lvds_format_24bpp;
bool lvds_format_jeida;
u32 reg;
@@ -128,10 +138,15 @@ static void fsl_ldb_atomic_enable(struct drm_bridge *bridge,
crtc_state = drm_atomic_get_new_crtc_state(state, crtc);
mode = &crtc_state->adjusted_mode;
- if (fsl_ldb->lvds_dual_link)
- clk_set_rate(fsl_ldb->clk, mode->clock * 3500);
- else
- clk_set_rate(fsl_ldb->clk, mode->clock * 7000);
+ requested_link_freq = fsl_ldb_link_frequency(fsl_ldb, mode->clock);
+ clk_set_rate(fsl_ldb->clk, requested_link_freq);
+
+ configured_link_freq = clk_get_rate(fsl_ldb->clk);
+ if (configured_link_freq != requested_link_freq)
+ dev_warn(fsl_ldb->dev, "Configured LDB clock (%lu Hz) does not match requested LVDS clock: %lu Hz",
+ configured_link_freq,
+ requested_link_freq);
+
clk_prepare_enable(fsl_ldb->clk);
/* Program LDB_CTRL */
--
2.34.1
^ permalink raw reply related [flat|nested] 4+ messages in thread
* Re: [PATCH 1/1] drm: bridge: ldb: Warn if LDB clock does not match requested link frequency
2022-12-08 6:55 [PATCH 1/1] drm: bridge: ldb: Warn if LDB clock does not match requested link frequency Alexander Stein
@ 2023-01-19 7:38 ` Alexander Stein
2023-01-19 7:49 ` Neil Armstrong
2023-01-19 7:53 ` Neil Armstrong
2 siblings, 0 replies; 4+ messages in thread
From: Alexander Stein @ 2023-01-19 7:38 UTC (permalink / raw)
To: Andrzej Hajda, Neil Armstrong, Robert Foss, Laurent Pinchart,
Jonas Karlman, Jernej Skrabec, David Airlie, Daniel Vetter
Cc: dri-devel
Hi everyone,
Am Donnerstag, 8. Dezember 2022, 07:55:38 CET schrieb Alexander Stein:
> The LDB clock needs to be exactly 7-times the pixel clock used by the
> display.
Any feedback on this?
Thanks
Alexander
> Signed-off-by: Alexander Stein <alexander.stein@ew.tq-group.com>
> ---
> i.MX8MP has a dedicated LDB clock which defines the actual LVDS link
> frequency. This has to be (exactly) the 7-time of the pixel clock.
> Although the clock min/max range is available, panel-simple does not (yet)
> use the range to find a (perfect) frequency which can be used down the
> chain, which is also in range.
> Depending on the pixel clock the exact multiple might not be configured.
> Raise a warning if there is a mismatch, which might cause an invalid display
> image.
>
> drivers/gpu/drm/bridge/fsl-ldb.c | 23 +++++++++++++++++++----
> 1 file changed, 19 insertions(+), 4 deletions(-)
>
> diff --git a/drivers/gpu/drm/bridge/fsl-ldb.c
> b/drivers/gpu/drm/bridge/fsl-ldb.c index f9e0f8d992680..9bcba8fc57e74
> 100644
> --- a/drivers/gpu/drm/bridge/fsl-ldb.c
> +++ b/drivers/gpu/drm/bridge/fsl-ldb.c
> @@ -66,6 +66,14 @@ static inline struct fsl_ldb *to_fsl_ldb(struct
> drm_bridge *bridge) return container_of(bridge, struct fsl_ldb, bridge);
> }
>
> +static unsigned long fsl_ldb_link_frequency(struct fsl_ldb *fsl_ldb, int
> clock) +{
> + if (fsl_ldb->lvds_dual_link)
> + return clock * 3500;
> + else
> + return clock * 7000;
> +}
> +
> static int fsl_ldb_attach(struct drm_bridge *bridge,
> enum drm_bridge_attach_flags flags)
> {
> @@ -85,6 +93,8 @@ static void fsl_ldb_atomic_enable(struct drm_bridge
> *bridge, const struct drm_display_mode *mode;
> struct drm_connector *connector;
> struct drm_crtc *crtc;
> + unsigned long configured_link_freq;
> + unsigned long requested_link_freq;
> bool lvds_format_24bpp;
> bool lvds_format_jeida;
> u32 reg;
> @@ -128,10 +138,15 @@ static void fsl_ldb_atomic_enable(struct drm_bridge
> *bridge, crtc_state = drm_atomic_get_new_crtc_state(state, crtc);
> mode = &crtc_state->adjusted_mode;
>
> - if (fsl_ldb->lvds_dual_link)
> - clk_set_rate(fsl_ldb->clk, mode->clock * 3500);
> - else
> - clk_set_rate(fsl_ldb->clk, mode->clock * 7000);
> + requested_link_freq = fsl_ldb_link_frequency(fsl_ldb, mode->clock);
> + clk_set_rate(fsl_ldb->clk, requested_link_freq);
> +
> + configured_link_freq = clk_get_rate(fsl_ldb->clk);
> + if (configured_link_freq != requested_link_freq)
> + dev_warn(fsl_ldb->dev, "Configured LDB clock (%lu Hz) does
not match
> requested LVDS clock: %lu Hz", +
configured_link_freq,
> + requested_link_freq);
> +
> clk_prepare_enable(fsl_ldb->clk);
>
> /* Program LDB_CTRL */
^ permalink raw reply [flat|nested] 4+ messages in thread
* Re: [PATCH 1/1] drm: bridge: ldb: Warn if LDB clock does not match requested link frequency
2022-12-08 6:55 [PATCH 1/1] drm: bridge: ldb: Warn if LDB clock does not match requested link frequency Alexander Stein
2023-01-19 7:38 ` Alexander Stein
@ 2023-01-19 7:49 ` Neil Armstrong
2023-01-19 7:53 ` Neil Armstrong
2 siblings, 0 replies; 4+ messages in thread
From: Neil Armstrong @ 2023-01-19 7:49 UTC (permalink / raw)
To: Alexander Stein, Andrzej Hajda, Robert Foss, Laurent Pinchart,
Jonas Karlman, Jernej Skrabec, David Airlie, Daniel Vetter
Cc: dri-devel
On 08/12/2022 07:55, Alexander Stein wrote:
> The LDB clock needs to be exactly 7-times the pixel clock used by the
> display.
>
> Signed-off-by: Alexander Stein <alexander.stein@ew.tq-group.com>
> ---
> i.MX8MP has a dedicated LDB clock which defines the actual LVDS link frequency.
> This has to be (exactly) the 7-time of the pixel clock.
> Although the clock min/max range is available, panel-simple does not (yet) use
> the range to find a (perfect) frequency which can be used down the chain, which
> is also in range.
> Depending on the pixel clock the exact multiple might not be configured.
> Raise a warning if there is a mismatch, which might cause an invalid display
> image.
>
> drivers/gpu/drm/bridge/fsl-ldb.c | 23 +++++++++++++++++++----
> 1 file changed, 19 insertions(+), 4 deletions(-)
>
> diff --git a/drivers/gpu/drm/bridge/fsl-ldb.c b/drivers/gpu/drm/bridge/fsl-ldb.c
> index f9e0f8d992680..9bcba8fc57e74 100644
> --- a/drivers/gpu/drm/bridge/fsl-ldb.c
> +++ b/drivers/gpu/drm/bridge/fsl-ldb.c
> @@ -66,6 +66,14 @@ static inline struct fsl_ldb *to_fsl_ldb(struct drm_bridge *bridge)
> return container_of(bridge, struct fsl_ldb, bridge);
> }
>
> +static unsigned long fsl_ldb_link_frequency(struct fsl_ldb *fsl_ldb, int clock)
> +{
> + if (fsl_ldb->lvds_dual_link)
> + return clock * 3500;
> + else
> + return clock * 7000;
> +}
> +
> static int fsl_ldb_attach(struct drm_bridge *bridge,
> enum drm_bridge_attach_flags flags)
> {
> @@ -85,6 +93,8 @@ static void fsl_ldb_atomic_enable(struct drm_bridge *bridge,
> const struct drm_display_mode *mode;
> struct drm_connector *connector;
> struct drm_crtc *crtc;
> + unsigned long configured_link_freq;
> + unsigned long requested_link_freq;
> bool lvds_format_24bpp;
> bool lvds_format_jeida;
> u32 reg;
> @@ -128,10 +138,15 @@ static void fsl_ldb_atomic_enable(struct drm_bridge *bridge,
> crtc_state = drm_atomic_get_new_crtc_state(state, crtc);
> mode = &crtc_state->adjusted_mode;
>
> - if (fsl_ldb->lvds_dual_link)
> - clk_set_rate(fsl_ldb->clk, mode->clock * 3500);
> - else
> - clk_set_rate(fsl_ldb->clk, mode->clock * 7000);
> + requested_link_freq = fsl_ldb_link_frequency(fsl_ldb, mode->clock);
> + clk_set_rate(fsl_ldb->clk, requested_link_freq);
> +
> + configured_link_freq = clk_get_rate(fsl_ldb->clk);
> + if (configured_link_freq != requested_link_freq)
> + dev_warn(fsl_ldb->dev, "Configured LDB clock (%lu Hz) does not match requested LVDS clock: %lu Hz",
> + configured_link_freq,
> + requested_link_freq);
> +
> clk_prepare_enable(fsl_ldb->clk);
>
> /* Program LDB_CTRL */
Reviewed-by: Neil Armstrong <neil.armstrong@linaro.org>
^ permalink raw reply [flat|nested] 4+ messages in thread
* Re: [PATCH 1/1] drm: bridge: ldb: Warn if LDB clock does not match requested link frequency
2022-12-08 6:55 [PATCH 1/1] drm: bridge: ldb: Warn if LDB clock does not match requested link frequency Alexander Stein
2023-01-19 7:38 ` Alexander Stein
2023-01-19 7:49 ` Neil Armstrong
@ 2023-01-19 7:53 ` Neil Armstrong
2 siblings, 0 replies; 4+ messages in thread
From: Neil Armstrong @ 2023-01-19 7:53 UTC (permalink / raw)
To: Andrzej Hajda, Robert Foss, Laurent Pinchart, Jonas Karlman,
Jernej Skrabec, David Airlie, Daniel Vetter, Alexander Stein
Cc: dri-devel
Hi,
On Thu, 08 Dec 2022 07:55:38 +0100, Alexander Stein wrote:
> The LDB clock needs to be exactly 7-times the pixel clock used by the
> display.
>
>
Thanks, Applied to https://anongit.freedesktop.org/git/drm/drm-misc.git (drm-misc-next)
[1/1] drm: bridge: ldb: Warn if LDB clock does not match requested link frequency
https://cgit.freedesktop.org/drm/drm-misc/commit/?id=bd43a9844bc6f78e00fdc91db47f6969d10c5ac5
--
Neil
^ permalink raw reply [flat|nested] 4+ messages in thread
end of thread, other threads:[~2023-01-19 7:53 UTC | newest]
Thread overview: 4+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2022-12-08 6:55 [PATCH 1/1] drm: bridge: ldb: Warn if LDB clock does not match requested link frequency Alexander Stein
2023-01-19 7:38 ` Alexander Stein
2023-01-19 7:49 ` Neil Armstrong
2023-01-19 7:53 ` Neil Armstrong
This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.