Commit 15ffa1da authored by Tomi Valkeinen's avatar Tomi Valkeinen

OMAP: DSS2: DSI: sync when disabling a display

When the panel driver calls omapdss_dsi_display_disable() it is possible
that there are still some unsent packets in the TX fifo.

Add dsi_sync_vc() calls in the beginning of
omapdss_dsi_display_disable() to make sure the TX fifos are empty.

This allows us to remove the msleep(10) hack from panel-taal.c
Signed-off-by: default avatarTomi Valkeinen <tomi.valkeinen@ti.com>
parent 3c07cae2
...@@ -1247,11 +1247,8 @@ static void taal_power_off(struct omap_dss_device *dssdev) ...@@ -1247,11 +1247,8 @@ static void taal_power_off(struct omap_dss_device *dssdev)
int r; int r;
r = taal_dcs_write_0(td, DCS_DISPLAY_OFF); r = taal_dcs_write_0(td, DCS_DISPLAY_OFF);
if (!r) { if (!r)
r = taal_sleep_in(td); r = taal_sleep_in(td);
/* HACK: wait a bit so that the message goes through */
msleep(10);
}
if (r) { if (r) {
dev_err(&dssdev->dev, dev_err(&dssdev->dev,
......
...@@ -4291,6 +4291,11 @@ void omapdss_dsi_display_disable(struct omap_dss_device *dssdev, ...@@ -4291,6 +4291,11 @@ void omapdss_dsi_display_disable(struct omap_dss_device *dssdev,
mutex_lock(&dsi->lock); mutex_lock(&dsi->lock);
dsi_sync_vc(dsidev, 0);
dsi_sync_vc(dsidev, 1);
dsi_sync_vc(dsidev, 2);
dsi_sync_vc(dsidev, 3);
dsi_display_uninit_dispc(dssdev); dsi_display_uninit_dispc(dssdev);
dsi_display_uninit_dsi(dssdev, disconnect_lanes, enter_ulps); dsi_display_uninit_dsi(dssdev, disconnect_lanes, enter_ulps);
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment