Commit 9f808956 authored by Tomi Valkeinen's avatar Tomi Valkeinen

OMAPDSS: APPLY: fix need_isr

need_isr() should return true whenever there's work that needs to be
handled in the VSYNC/FRAMEDONE irq handler. However, need_isr() is
missing some cases where we need the irq handler.

This patch adds checks for shadow dirty flags, so that the irq handler
is started/kept running while shadow dirty flags are set.
Signed-off-by: default avatarTomi Valkeinen <tomi.valkeinen@ti.com>
parent cc372d84
...@@ -358,16 +358,38 @@ static bool need_isr(void) ...@@ -358,16 +358,38 @@ static bool need_isr(void)
if (mp->info_dirty) if (mp->info_dirty)
return true; return true;
/* to set GO bit */
if (mp->shadow_info_dirty)
return true;
list_for_each_entry(ovl, &mgr->overlays, list) { list_for_each_entry(ovl, &mgr->overlays, list) {
struct ovl_priv_data *op; struct ovl_priv_data *op;
op = get_ovl_priv(ovl); op = get_ovl_priv(ovl);
/*
* NOTE: we check extra_info flags even for
* disabled overlays, as extra_infos need to be
* always written.
*/
/* to write new values to registers */
if (op->extra_info_dirty)
return true;
/* to set GO bit */
if (op->shadow_extra_info_dirty)
return true;
if (!op->enabled) if (!op->enabled)
continue; continue;
/* to write new values to registers */ /* to write new values to registers */
if (op->info_dirty || op->extra_info_dirty) if (op->info_dirty)
return true;
/* to set GO bit */
if (op->shadow_info_dirty)
return true; return true;
} }
} }
......
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