drm/omap: fix WB height with interlace
authorTomi Valkeinen <tomi.valkeinen@ti.com>
Thu, 26 Oct 2017 11:40:13 +0000 (14:40 +0300)
committerTomi Valkeinen <tomi.valkeinen@ti.com>
Thu, 1 Mar 2018 07:18:18 +0000 (09:18 +0200)
When using WB capture from interlaced source, we need to halve the
picture heights correctly.

Unfortunately the current dispc_ovl_setup_common() doesn't deal with
interlace very neatly, so the end result is a bit messy.

Signed-off-by: Tomi Valkeinen <tomi.valkeinen@ti.com>
Acked-by: Benoit Parrot <bparrot@ti.com>
drivers/gpu/drm/omapdrm/dss/dispc.c

index 000a3d4a27bf8356aa302ac4b5c59281dc39026a..72f00e8a1329a17484aa4dfa96450f290c6994f2 100644 (file)
@@ -2597,18 +2597,19 @@ static int dispc_ovl_setup_common(struct dispc_device *dispc,
        out_width = out_width == 0 ? width : out_width;
        out_height = out_height == 0 ? height : out_height;
 
-       if (ilace && height == out_height)
-               fieldmode = true;
-
-       if (ilace) {
-               if (fieldmode)
-                       in_height /= 2;
-               pos_y /= 2;
-               out_height /= 2;
-
-               DSSDBG("adjusting for ilace: height %d, pos_y %d, "
-                       "out_height %d\n", in_height, pos_y,
-                       out_height);
+       if (plane != OMAP_DSS_WB) {
+               if (ilace && height == out_height)
+                       fieldmode = true;
+
+               if (ilace) {
+                       if (fieldmode)
+                               in_height /= 2;
+                       pos_y /= 2;
+                       out_height /= 2;
+
+                       DSSDBG("adjusting for ilace: height %d, pos_y %d, out_height %d\n",
+                               in_height, pos_y, out_height);
+               }
        }
 
        if (!dispc_ovl_color_mode_supported(dispc, plane, fourcc))
@@ -2771,6 +2772,9 @@ int dispc_wb_setup(struct dispc_device *dispc,
        enum omap_overlay_caps caps =
                OMAP_DSS_OVL_CAP_SCALE | OMAP_DSS_OVL_CAP_PRE_MULT_ALPHA;
 
+       if (vm->flags & DISPLAY_FLAGS_INTERLACED)
+               in_height /= 2;
+
        DSSDBG("dispc_wb_setup, pa %x, pa_uv %x, %d,%d -> %dx%d, cmode %x, "
                "rot %d\n", wi->paddr, wi->p_uv_addr, in_width,
                in_height, wi->width, wi->height, wi->fourcc, wi->rotation);