media: atmel: atmel-isc-base: initialize the try_crop for the pads in try_fmt
When requesting format from sensor, some sensors call the subdev_get_try_crop which for ISC was not properly initialized, and this causes errors in determining proper image resolutions. To accommodate for this, when trying a format (in try_fmt), first attempt to obtain the framesize for this format from sensor. In case this fails, use the maximum ISC width/height as try_crop, otherwise provide the first size height/width from the sensor. Signed-off-by: Eugen Hristev <eugen.hristev@microchip.com> [hverkuil-cisco@xs4all.nl: changed {0} to {}] Signed-off-by: Hans Verkuil <hverkuil-cisco@xs4all.nl> Signed-off-by: Mauro Carvalho Chehab <mchehab+huawei@kernel.org>
This commit is contained in:
parent
da3a55b5a9
commit
374d968ac7
|
@ -1210,6 +1210,37 @@ static int isc_try_configure_pipeline(struct isc_device *isc)
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static void isc_try_fse(struct isc_device *isc,
|
||||||
|
struct v4l2_subdev_pad_config *pad_cfg)
|
||||||
|
{
|
||||||
|
int ret;
|
||||||
|
struct v4l2_subdev_frame_size_enum fse = {};
|
||||||
|
|
||||||
|
/*
|
||||||
|
* If we do not know yet which format the subdev is using, we cannot
|
||||||
|
* do anything.
|
||||||
|
*/
|
||||||
|
if (!isc->try_config.sd_format)
|
||||||
|
return;
|
||||||
|
|
||||||
|
fse.code = isc->try_config.sd_format->mbus_code;
|
||||||
|
fse.which = V4L2_SUBDEV_FORMAT_TRY;
|
||||||
|
|
||||||
|
ret = v4l2_subdev_call(isc->current_subdev->sd, pad, enum_frame_size,
|
||||||
|
pad_cfg, &fse);
|
||||||
|
/*
|
||||||
|
* Attempt to obtain format size from subdev. If not available,
|
||||||
|
* just use the maximum ISC can receive.
|
||||||
|
*/
|
||||||
|
if (ret) {
|
||||||
|
pad_cfg->try_crop.width = ISC_MAX_SUPPORT_WIDTH;
|
||||||
|
pad_cfg->try_crop.height = ISC_MAX_SUPPORT_HEIGHT;
|
||||||
|
} else {
|
||||||
|
pad_cfg->try_crop.width = fse.max_width;
|
||||||
|
pad_cfg->try_crop.height = fse.max_height;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
static int isc_try_fmt(struct isc_device *isc, struct v4l2_format *f,
|
static int isc_try_fmt(struct isc_device *isc, struct v4l2_format *f,
|
||||||
u32 *code)
|
u32 *code)
|
||||||
{
|
{
|
||||||
|
@ -1313,6 +1344,9 @@ static int isc_try_fmt(struct isc_device *isc, struct v4l2_format *f,
|
||||||
if (ret)
|
if (ret)
|
||||||
goto isc_try_fmt_err;
|
goto isc_try_fmt_err;
|
||||||
|
|
||||||
|
/* Obtain frame sizes if possible to have crop requirements ready */
|
||||||
|
isc_try_fse(isc, &pad_cfg);
|
||||||
|
|
||||||
v4l2_fill_mbus_format(&format.format, pixfmt, mbus_code);
|
v4l2_fill_mbus_format(&format.format, pixfmt, mbus_code);
|
||||||
ret = v4l2_subdev_call(isc->current_subdev->sd, pad, set_fmt,
|
ret = v4l2_subdev_call(isc->current_subdev->sd, pad, set_fmt,
|
||||||
&pad_cfg, &format);
|
&pad_cfg, &format);
|
||||||
|
|
Loading…
Reference in New Issue