Commit b8320917 authored by Tomi Valkeinen's avatar Tomi Valkeinen Committed by Mauro Carvalho Chehab

media: ti-vpe: cal: fix subdev mbus_code enumeration

The cal_ctx_v4l2_init_formats() function does not handle error values
correctly when calling enum_mbus_code in subdevs, causing an infinite
loop if the subdev's enum_mbus_code returns some other error than EINVAL.

Fix the error handling.
Signed-off-by: default avatarTomi Valkeinen <tomi.valkeinen@ideasonboard.com>
Signed-off-by: default avatarHans Verkuil <hverkuil-cisco@xs4all.nl>
Signed-off-by: default avatarMauro Carvalho Chehab <mchehab+huawei@kernel.org>
parent f9426edd
...@@ -591,15 +591,21 @@ static int cal_ctx_v4l2_init_formats(struct cal_ctx *ctx) ...@@ -591,15 +591,21 @@ static int cal_ctx_v4l2_init_formats(struct cal_ctx *ctx)
sizeof(*ctx->active_fmt), GFP_KERNEL); sizeof(*ctx->active_fmt), GFP_KERNEL);
ctx->num_active_fmt = 0; ctx->num_active_fmt = 0;
for (j = 0, i = 0; ret != -EINVAL; ++j) { for (j = 0, i = 0; ; ++j) {
memset(&mbus_code, 0, sizeof(mbus_code)); memset(&mbus_code, 0, sizeof(mbus_code));
mbus_code.index = j; mbus_code.index = j;
mbus_code.which = V4L2_SUBDEV_FORMAT_ACTIVE; mbus_code.which = V4L2_SUBDEV_FORMAT_ACTIVE;
ret = v4l2_subdev_call(ctx->phy->sensor, pad, enum_mbus_code, ret = v4l2_subdev_call(ctx->phy->sensor, pad, enum_mbus_code,
NULL, &mbus_code); NULL, &mbus_code);
if (ret) if (ret == -EINVAL)
continue; break;
if (ret) {
ctx_err(ctx, "Error enumerating mbus codes in subdev %s: %d\n",
ctx->phy->sensor->name, ret);
return ret;
}
ctx_dbg(2, ctx, ctx_dbg(2, ctx,
"subdev %s: code: %04x idx: %u\n", "subdev %s: code: %04x idx: %u\n",
......
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