Currently when DISPC is suspended, the driver stores all DISPC registers to memory, so that they can be restored on resume. This is a bad way to handle suspend/resume, as it's prone to failures and requires somewhat large amount of extra space to store the registers. A better approach is to program the DISPC from scratch when resuming. This can be easily accomplished in apply layer by setting the manager and overlay infos to dirty when the manager is to be enabled. Signed-off-by: Tomi Valkeinen <tomi.valkeinen@xxxxxx> --- drivers/video/omap2/dss/apply.c | 22 ++++++++++++++++++++++ 1 file changed, 22 insertions(+) diff --git a/drivers/video/omap2/dss/apply.c b/drivers/video/omap2/dss/apply.c index 60758db..6ab4cb6 100644 --- a/drivers/video/omap2/dss/apply.c +++ b/drivers/video/omap2/dss/apply.c @@ -1072,6 +1072,7 @@ static void dss_setup_fifos(void) static int dss_mgr_enable_compat(struct omap_overlay_manager *mgr) { struct mgr_priv_data *mp = get_mgr_priv(mgr); + struct omap_overlay *ovl; unsigned long flags; int r; @@ -1091,6 +1092,27 @@ static int dss_mgr_enable_compat(struct omap_overlay_manager *mgr) goto err; } + /* + * Mark the info & extra_info dirty for the manager and its enabled + * overlays to force register writes. This ensures that the relevant + * registers are set after DSS has been off and the registers have been + * reset. + */ + + mp->info_dirty = true; + mp->extra_info_dirty = true; + + list_for_each_entry(ovl, &mgr->overlays, list) { + struct ovl_priv_data *op = get_ovl_priv(ovl); + + if (!op->enabled) + continue; + + op->info_dirty = true; + op->extra_info_dirty = true; + dispc_ovl_set_channel_out(ovl->id, mgr->id); + } + dss_setup_fifos(); dss_write_regs(); -- 1.8.3.2 -- To unsubscribe from this list: send the line "unsubscribe linux-fbdev" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html