aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorTomi Valkeinen <tomi.valkeinen@ti.com>2014-10-03 11:14:08 -0400
committerTomi Valkeinen <tomi.valkeinen@ti.com>2015-03-24 07:50:55 -0400
commit2dd3887b503c1cc8a61ef4a4f24462ce03f3ada5 (patch)
treeb338e7e2c1f2250ce9c3e421b142436d2129aaee
parent7cb0d6c17b96b8bf3c25de2dfde4fdeb9191f4c3 (diff)
drm/omap: fix plane's channel selection
omap_plane_pre_apply() sets the plane's output channel too late, only after the plane has already been otherwise configured and enabled. This causes problems, as at the configuration stage we need to make decisions based on the output channel. This may lead to bad plane settings or failing to setup the plane. Signed-off-by: Tomi Valkeinen <tomi.valkeinen@ti.com>
-rw-r--r--drivers/gpu/drm/omapdrm/omap_plane.c3
1 files changed, 2 insertions, 1 deletions
diff --git a/drivers/gpu/drm/omapdrm/omap_plane.c b/drivers/gpu/drm/omapdrm/omap_plane.c
index 6eedca107376..d52ff0455673 100644
--- a/drivers/gpu/drm/omapdrm/omap_plane.c
+++ b/drivers/gpu/drm/omapdrm/omap_plane.c
@@ -149,6 +149,8 @@ static void omap_plane_pre_apply(struct omap_drm_apply *apply)
149 DBG("%d,%d %pad %pad", info->pos_x, info->pos_y, 149 DBG("%d,%d %pad %pad", info->pos_x, info->pos_y,
150 &info->paddr, &info->p_uv_addr); 150 &info->paddr, &info->p_uv_addr);
151 151
152 dispc_ovl_set_channel_out(omap_plane->id, channel);
153
152 /* and finally, update omapdss: */ 154 /* and finally, update omapdss: */
153 ret = dispc_ovl_setup(omap_plane->id, info, false, 155 ret = dispc_ovl_setup(omap_plane->id, info, false,
154 omap_crtc_timings(crtc), false); 156 omap_crtc_timings(crtc), false);
@@ -158,7 +160,6 @@ static void omap_plane_pre_apply(struct omap_drm_apply *apply)
158 } 160 }
159 161
160 dispc_ovl_enable(omap_plane->id, true); 162 dispc_ovl_enable(omap_plane->id, true);
161 dispc_ovl_set_channel_out(omap_plane->id, channel);
162} 163}
163 164
164static void omap_plane_post_apply(struct omap_drm_apply *apply) 165static void omap_plane_post_apply(struct omap_drm_apply *apply)