Commit 7e47c384 authored by Philipp Zabel's avatar Philipp Zabel Committed by Mauro Carvalho Chehab

media: coda: fail S_SELECTION for read-only targets

v4l2-compliance complains if S_SELECTION returns 0 for read-only targets.
Signed-off-by: default avatarPhilipp Zabel <p.zabel@pengutronix.de>
Signed-off-by: default avatarHans Verkuil <hansverk@cisco.com>
Signed-off-by: default avatarMauro Carvalho Chehab <mchehab+samsung@kernel.org>
parent cf13135c
...@@ -939,32 +939,39 @@ static int coda_s_selection(struct file *file, void *fh, ...@@ -939,32 +939,39 @@ static int coda_s_selection(struct file *file, void *fh,
struct coda_ctx *ctx = fh_to_ctx(fh); struct coda_ctx *ctx = fh_to_ctx(fh);
struct coda_q_data *q_data; struct coda_q_data *q_data;
if (ctx->inst_type == CODA_INST_ENCODER && switch (s->target) {
s->type == V4L2_BUF_TYPE_VIDEO_OUTPUT && case V4L2_SEL_TGT_CROP:
s->target == V4L2_SEL_TGT_CROP) { if (ctx->inst_type == CODA_INST_ENCODER &&
q_data = get_q_data(ctx, s->type); s->type == V4L2_BUF_TYPE_VIDEO_OUTPUT) {
if (!q_data) q_data = get_q_data(ctx, s->type);
return -EINVAL; if (!q_data)
return -EINVAL;
s->r.left = 0;
s->r.top = 0;
s->r.width = clamp(s->r.width, 2U, q_data->width);
s->r.height = clamp(s->r.height, 2U, q_data->height);
if (s->flags & V4L2_SEL_FLAG_LE) { s->r.left = 0;
s->r.width = round_up(s->r.width, 2); s->r.top = 0;
s->r.height = round_up(s->r.height, 2); s->r.width = clamp(s->r.width, 2U, q_data->width);
} else { s->r.height = clamp(s->r.height, 2U, q_data->height);
s->r.width = round_down(s->r.width, 2);
s->r.height = round_down(s->r.height, 2); if (s->flags & V4L2_SEL_FLAG_LE) {
} s->r.width = round_up(s->r.width, 2);
s->r.height = round_up(s->r.height, 2);
} else {
s->r.width = round_down(s->r.width, 2);
s->r.height = round_down(s->r.height, 2);
}
q_data->rect = s->r; q_data->rect = s->r;
return 0; return 0;
}
/* else fall through */
case V4L2_SEL_TGT_NATIVE_SIZE:
case V4L2_SEL_TGT_COMPOSE:
return coda_g_selection(file, fh, s);
default:
/* v4l2-compliance expects this to fail for read-only targets */
return -EINVAL;
} }
return coda_g_selection(file, fh, s);
} }
static int coda_try_encoder_cmd(struct file *file, void *fh, static int coda_try_encoder_cmd(struct file *file, void *fh,
......
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