Commit 75ae118a authored by Tomi Valkeinen's avatar Tomi Valkeinen

OMAPDSS: APPLY: add dss_setup_fifos

Currently fifo threshold configuration is done per overlay or per
manager. However, when a fifo size configuration is added, we need to
always configure the thresholds for all overlays.

This patch prepares for that by changing the fifo threshold
configuration to always handle all overlays.
Signed-off-by: default avatarTomi Valkeinen <tomi.valkeinen@ti.com>
parent a6b24f83
...@@ -960,6 +960,9 @@ static void dss_ovl_setup_fifo(struct omap_overlay *ovl) ...@@ -960,6 +960,9 @@ static void dss_ovl_setup_fifo(struct omap_overlay *ovl)
u32 size, burst_size; u32 size, burst_size;
u32 fifo_low, fifo_high; u32 fifo_low, fifo_high;
if (!op->enabled && !op->enabling)
return;
dssdev = ovl->manager->device; dssdev = ovl->manager->device;
size = dispc_ovl_get_fifo_size(ovl->id); size = dispc_ovl_get_fifo_size(ovl->id);
...@@ -993,7 +996,6 @@ static void dss_ovl_setup_fifo(struct omap_overlay *ovl) ...@@ -993,7 +996,6 @@ static void dss_ovl_setup_fifo(struct omap_overlay *ovl)
static void dss_mgr_setup_fifos(struct omap_overlay_manager *mgr) static void dss_mgr_setup_fifos(struct omap_overlay_manager *mgr)
{ {
struct omap_overlay *ovl; struct omap_overlay *ovl;
struct ovl_priv_data *op;
struct mgr_priv_data *mp; struct mgr_priv_data *mp;
mp = get_mgr_priv(mgr); mp = get_mgr_priv(mgr);
...@@ -1001,13 +1003,19 @@ static void dss_mgr_setup_fifos(struct omap_overlay_manager *mgr) ...@@ -1001,13 +1003,19 @@ static void dss_mgr_setup_fifos(struct omap_overlay_manager *mgr)
if (!mp->enabled) if (!mp->enabled)
return; return;
list_for_each_entry(ovl, &mgr->overlays, list) { list_for_each_entry(ovl, &mgr->overlays, list)
op = get_ovl_priv(ovl); dss_ovl_setup_fifo(ovl);
}
if (!op->enabled && !op->enabling) static void dss_setup_fifos(void)
continue; {
const int num_mgrs = omap_dss_get_num_overlay_managers();
struct omap_overlay_manager *mgr;
int i;
dss_ovl_setup_fifo(ovl); for (i = 0; i < num_mgrs; ++i) {
mgr = omap_dss_get_overlay_manager(i);
dss_mgr_setup_fifos(mgr);
} }
} }
...@@ -1033,7 +1041,7 @@ int dss_mgr_enable(struct omap_overlay_manager *mgr) ...@@ -1033,7 +1041,7 @@ int dss_mgr_enable(struct omap_overlay_manager *mgr)
goto err; goto err;
} }
dss_mgr_setup_fifos(mgr); dss_setup_fifos();
dss_write_regs(); dss_write_regs();
dss_set_go_bits(); dss_set_go_bits();
...@@ -1409,7 +1417,7 @@ int dss_ovl_enable(struct omap_overlay *ovl) ...@@ -1409,7 +1417,7 @@ int dss_ovl_enable(struct omap_overlay *ovl)
goto err2; goto err2;
} }
dss_ovl_setup_fifo(ovl); dss_setup_fifos();
op->enabling = false; op->enabling = false;
dss_apply_ovl_enable(ovl, true); dss_apply_ovl_enable(ovl, 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