drm: rcar-du: dsi: Properly stop video mode TX
The driver does not explicitly stop the video mode transmission when disabling the output. While this doesn't seem to be causing any issues, lets follow the steps described in the documentation and add a rcar_mipi_dsi_stop_video() which stop the video mode transmission. This function will also be used in later patches to stop the video transmission even if the DSI IP is not shut down. Signed-off-by: Tomi Valkeinen <tomi.valkeinen+renesas@ideasonboard.com> Reviewed-by: Laurent Pinchart <laurent.pinchart+renesas@ideasonboard.com> Signed-off-by: Laurent Pinchart <laurent.pinchart+renesas@ideasonboard.com>
This commit is contained in:
parent
cb90d90ca7
commit
dbf88d0331
@ -542,6 +542,34 @@ static int rcar_mipi_dsi_start_video(struct rcar_mipi_dsi *dsi)
|
||||
return 0;
|
||||
}
|
||||
|
||||
static void rcar_mipi_dsi_stop_video(struct rcar_mipi_dsi *dsi)
|
||||
{
|
||||
u32 status;
|
||||
int ret;
|
||||
|
||||
/* Disable transmission in video mode. */
|
||||
rcar_mipi_dsi_clr(dsi, TXVMCR, TXVMCR_EN_VIDEO);
|
||||
|
||||
ret = read_poll_timeout(rcar_mipi_dsi_read, status,
|
||||
!(status & TXVMSR_ACT),
|
||||
2000, 100000, false, dsi, TXVMSR);
|
||||
if (ret < 0) {
|
||||
dev_err(dsi->dev, "Failed to disable video transmission\n");
|
||||
return;
|
||||
}
|
||||
|
||||
/* Assert video FIFO clear. */
|
||||
rcar_mipi_dsi_set(dsi, TXVMCR, TXVMCR_VFCLR);
|
||||
|
||||
ret = read_poll_timeout(rcar_mipi_dsi_read, status,
|
||||
!(status & TXVMSR_VFRDY),
|
||||
2000, 100000, false, dsi, TXVMSR);
|
||||
if (ret < 0) {
|
||||
dev_err(dsi->dev, "Failed to assert video FIFO clear\n");
|
||||
return;
|
||||
}
|
||||
}
|
||||
|
||||
/* -----------------------------------------------------------------------------
|
||||
* Bridge
|
||||
*/
|
||||
@ -601,6 +629,7 @@ static void rcar_mipi_dsi_atomic_disable(struct drm_bridge *bridge,
|
||||
{
|
||||
struct rcar_mipi_dsi *dsi = bridge_to_rcar_mipi_dsi(bridge);
|
||||
|
||||
rcar_mipi_dsi_stop_video(dsi);
|
||||
rcar_mipi_dsi_shutdown(dsi);
|
||||
rcar_mipi_dsi_clk_disable(dsi);
|
||||
}
|
||||
|
Loading…
Reference in New Issue
Block a user