drm: bridge: ldb: Warn if LDB clock does not match requested link frequency
authorAlexander Stein <alexander.stein@ew.tq-group.com>
Thu, 8 Dec 2022 06:55:38 +0000 (07:55 +0100)
committerNeil Armstrong <neil.armstrong@linaro.org>
Thu, 19 Jan 2023 07:50:50 +0000 (08:50 +0100)
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>
Reviewed-by: Neil Armstrong <neil.armstrong@linaro.org>
Signed-off-by: Neil Armstrong <neil.armstrong@linaro.org>
Link: https://patchwork.freedesktop.org/patch/msgid/20221208065538.1753666-1-alexander.stein@ew.tq-group.com
drivers/gpu/drm/bridge/fsl-ldb.c

index f9e0f8d99268073a70681478e6777e5e632b59be..9bcba8fc57e74d31d3cf9de6d8f23cd1b5c2838a 100644 (file)
@@ -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 */