media: coda: fix capture TRY_FMT for YUYV with non-MB-aligned widths
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>
This commit is contained in:
parent
e112146f3b
commit
1403bc4c0f
|
@ -486,8 +486,8 @@ static int coda_try_fmt_vdoa(struct coda_ctx *ctx, struct v4l2_format *f,
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
err = vdoa_context_configure(NULL, f->fmt.pix.width, f->fmt.pix.height,
|
err = vdoa_context_configure(NULL, round_up(f->fmt.pix.width, 16),
|
||||||
f->fmt.pix.pixelformat);
|
f->fmt.pix.height, f->fmt.pix.pixelformat);
|
||||||
if (err) {
|
if (err) {
|
||||||
*use_vdoa = false;
|
*use_vdoa = false;
|
||||||
return 0;
|
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 &&
|
if (ctx->tiled_map_type == GDI_TILED_FRAME_MB_RASTER_MAP &&
|
||||||
!coda_try_fmt_vdoa(ctx, f, &ctx->use_vdoa) &&
|
!coda_try_fmt_vdoa(ctx, f, &ctx->use_vdoa) &&
|
||||||
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.height,
|
||||||
f->fmt.pix.pixelformat);
|
f->fmt.pix.pixelformat);
|
||||||
else
|
else
|
||||||
|
|
Loading…
Reference in New Issue