media: coda: fix capture TRY_FMT for YUYV with non-MB-aligned widths
authorPhilipp Zabel <p.zabel@pengutronix.de>
Thu, 7 Dec 2017 11:11:11 +0000 (06:11 -0500)
committerMauro Carvalho Chehab <mchehab@s-opensource.com>
Mon, 18 Dec 2017 19:59:04 +0000 (14:59 -0500)
Since bytesperline always fulfills VDOA width requirements, detile the
whole buffer instead of limiting to visible width. This stops TRY_FMT
from returning -EINVAL for YUYV capture buffers that are not a multiple
of 16 wide.

An alternative would be to always round up width to stride, as we report
the valid image rectange via G_SELECTION (V4L2_SEL_TGT_COMPOSE_DEFAULT),
but that would require all applications to handle the compose default
rectangle properly.

Signed-off-by: Philipp Zabel <p.zabel@pengutronix.de>
Signed-off-by: Hans Verkuil <hans.verkuil@cisco.com>
Signed-off-by: Mauro Carvalho Chehab <mchehab@s-opensource.com>
drivers/media/platform/coda/coda-common.c

index 46a628a548d9f1afde9cee7b21ba7daea0efd02f..e8a7554a61d2400d5e58434b48c58088c7abf343 100644 (file)
@@ -486,8 +486,8 @@ static int coda_try_fmt_vdoa(struct coda_ctx *ctx, struct v4l2_format *f,
                return 0;
        }
 
-       err = vdoa_context_configure(NULL, f->fmt.pix.width, f->fmt.pix.height,
-                                    f->fmt.pix.pixelformat);
+       err = vdoa_context_configure(NULL, round_up(f->fmt.pix.width, 16),
+                                    f->fmt.pix.height, f->fmt.pix.pixelformat);
        if (err) {
                *use_vdoa = false;
                return 0;
@@ -730,7 +730,8 @@ static int coda_s_fmt(struct coda_ctx *ctx, struct v4l2_format *f,
        if (ctx->tiled_map_type == GDI_TILED_FRAME_MB_RASTER_MAP &&
            !coda_try_fmt_vdoa(ctx, f, &ctx->use_vdoa) &&
            ctx->use_vdoa)
-               vdoa_context_configure(ctx->vdoa, f->fmt.pix.width,
+               vdoa_context_configure(ctx->vdoa,
+                                      round_up(f->fmt.pix.width, 16),
                                       f->fmt.pix.height,
                                       f->fmt.pix.pixelformat);
        else