Doing modeset in .atomic_pre_enable callback instead of dedicated .mode_set
callback does not seem right. Undo this change, which was added as part of
commit 05aa61334592 ("drm: bridge: dw-mipi-dsi: Fix enable/disable of DSI
controller") as it breaks STM32MP15xx LTDC scanout (DSI)->TC358762 DSI-to-DPI
bridge->PT800480 DPI panel pipeline. The original fix for HX8394 panel likely
requires HX8394 panel side fix instead.

Fixes: 05aa61334592 ("drm: bridge: dw-mipi-dsi: Fix enable/disable of DSI 
controller")
Signed-off-by: Marek Vasut <ma...@denx.de>
---
Cc: Andrzej Hajda <andrzej.ha...@intel.com>
Cc: Biju Das <biju.das...@bp.renesas.com>
Cc: Daniel Vetter <dan...@ffwll.ch>
Cc: David Airlie <airl...@gmail.com>
Cc: Douglas Anderson <diand...@chromium.org>
Cc: Jernej Skrabec <jernej.skra...@gmail.com>
Cc: Jonas Karlman <jo...@kwiboo.se>
Cc: Laurent Pinchart <laurent.pinch...@ideasonboard.com>
Cc: Liu Ying <victor....@nxp.com>
Cc: Maarten Lankhorst <maarten.lankho...@linux.intel.com>
Cc: Maxime Ripard <mrip...@kernel.org>
Cc: Neil Armstrong <neil.armstr...@linaro.org>
Cc: Ondrej Jirman <m...@xff.cz>
Cc: Rob Herring <r...@kernel.org>
Cc: Robert Foss <rf...@kernel.org>
Cc: Sam Ravnborg <s...@ravnborg.org>
Cc: Thomas Zimmermann <tzimmerm...@suse.de>
Cc: dri-devel@lists.freedesktop.org
Cc: linux-ker...@vger.kernel.org
---
 drivers/gpu/drm/bridge/synopsys/dw-mipi-dsi.c | 18 +++---------------
 1 file changed, 3 insertions(+), 15 deletions(-)

diff --git a/drivers/gpu/drm/bridge/synopsys/dw-mipi-dsi.c 
b/drivers/gpu/drm/bridge/synopsys/dw-mipi-dsi.c
index 824fb3c65742e..ca5894393dba4 100644
--- a/drivers/gpu/drm/bridge/synopsys/dw-mipi-dsi.c
+++ b/drivers/gpu/drm/bridge/synopsys/dw-mipi-dsi.c
@@ -268,7 +268,6 @@ struct dw_mipi_dsi {
        struct dw_mipi_dsi *master; /* dual-dsi master ptr */
        struct dw_mipi_dsi *slave; /* dual-dsi slave ptr */
 
-       struct drm_display_mode mode;
        const struct dw_mipi_dsi_plat_data *plat_data;
 };
 
@@ -1016,25 +1015,15 @@ static void dw_mipi_dsi_mode_set(struct dw_mipi_dsi 
*dsi,
                phy_ops->power_on(dsi->plat_data->priv_data);
 }
 
-static void dw_mipi_dsi_bridge_atomic_pre_enable(struct drm_bridge *bridge,
-                                                struct drm_bridge_state 
*old_bridge_state)
-{
-       struct dw_mipi_dsi *dsi = bridge_to_dsi(bridge);
-
-       /* Power up the dsi ctl into a command mode */
-       dw_mipi_dsi_mode_set(dsi, &dsi->mode);
-       if (dsi->slave)
-               dw_mipi_dsi_mode_set(dsi->slave, &dsi->mode);
-}
-
 static void dw_mipi_dsi_bridge_mode_set(struct drm_bridge *bridge,
                                        const struct drm_display_mode *mode,
                                        const struct drm_display_mode 
*adjusted_mode)
 {
        struct dw_mipi_dsi *dsi = bridge_to_dsi(bridge);
 
-       /* Store the display mode for later use in pre_enable callback */
-       drm_mode_copy(&dsi->mode, adjusted_mode);
+       dw_mipi_dsi_mode_set(dsi, adjusted_mode);
+       if (dsi->slave)
+               dw_mipi_dsi_mode_set(dsi->slave, adjusted_mode);
 }
 
 static void dw_mipi_dsi_bridge_atomic_enable(struct drm_bridge *bridge,
@@ -1090,7 +1079,6 @@ static const struct drm_bridge_funcs 
dw_mipi_dsi_bridge_funcs = {
        .atomic_get_input_bus_fmts = 
dw_mipi_dsi_bridge_atomic_get_input_bus_fmts,
        .atomic_check           = dw_mipi_dsi_bridge_atomic_check,
        .atomic_reset           = drm_atomic_helper_bridge_reset,
-       .atomic_pre_enable      = dw_mipi_dsi_bridge_atomic_pre_enable,
        .atomic_enable          = dw_mipi_dsi_bridge_atomic_enable,
        .atomic_post_disable    = dw_mipi_dsi_bridge_post_atomic_disable,
        .mode_set               = dw_mipi_dsi_bridge_mode_set,
-- 
2.43.0

Reply via email to