Commit b2fe7aee authored by Jacopo Mondi's avatar Jacopo Mondi Committed by Mauro Carvalho Chehab

media: i2c: imx219: Fix colorspace info

The IMX219 is a RAW sensor. Fix the colorspace configuration by
using V4L2_COLORSPACE_RAW and adjust the quantization and transfer
function values. Drop ycbcr_enc as it doesn't apply to RAW sensors.
Signed-off-by: default avatarJacopo Mondi <jacopo.mondi@ideasonboard.com>
Signed-off-by: default avatarSakari Ailus <sakari.ailus@linux.intel.com>
Signed-off-by: default avatarMauro Carvalho Chehab <mchehab@kernel.org>
parent a267c23a
...@@ -597,15 +597,12 @@ static void imx219_set_default_format(struct imx219 *imx219) ...@@ -597,15 +597,12 @@ static void imx219_set_default_format(struct imx219 *imx219)
fmt = &imx219->fmt; fmt = &imx219->fmt;
fmt->code = MEDIA_BUS_FMT_SRGGB10_1X10; fmt->code = MEDIA_BUS_FMT_SRGGB10_1X10;
fmt->colorspace = V4L2_COLORSPACE_SRGB; fmt->colorspace = V4L2_COLORSPACE_RAW;
fmt->ycbcr_enc = V4L2_MAP_YCBCR_ENC_DEFAULT(fmt->colorspace); fmt->quantization = V4L2_QUANTIZATION_FULL_RANGE;
fmt->quantization = V4L2_MAP_QUANTIZATION_DEFAULT(true,
fmt->colorspace,
fmt->ycbcr_enc);
fmt->xfer_func = V4L2_MAP_XFER_FUNC_DEFAULT(fmt->colorspace);
fmt->width = supported_modes[0].width; fmt->width = supported_modes[0].width;
fmt->height = supported_modes[0].height; fmt->height = supported_modes[0].height;
fmt->field = V4L2_FIELD_NONE; fmt->field = V4L2_FIELD_NONE;
fmt->xfer_func = V4L2_XFER_FUNC_NONE;
} }
static int imx219_set_ctrl(struct v4l2_ctrl *ctrl) static int imx219_set_ctrl(struct v4l2_ctrl *ctrl)
...@@ -714,12 +711,10 @@ static int imx219_init_cfg(struct v4l2_subdev *sd, ...@@ -714,12 +711,10 @@ static int imx219_init_cfg(struct v4l2_subdev *sd,
format->code = imx219_get_format_code(imx219, format->code = imx219_get_format_code(imx219,
MEDIA_BUS_FMT_SRGGB10_1X10); MEDIA_BUS_FMT_SRGGB10_1X10);
format->field = V4L2_FIELD_NONE; format->field = V4L2_FIELD_NONE;
format->colorspace = V4L2_COLORSPACE_SRGB; format->colorspace = V4L2_COLORSPACE_RAW;
format->ycbcr_enc = V4L2_MAP_YCBCR_ENC_DEFAULT(format->colorspace); format->ycbcr_enc = V4L2_MAP_YCBCR_ENC_DEFAULT(format->colorspace);
format->quantization = V4L2_MAP_QUANTIZATION_DEFAULT(true, format->quantization = V4L2_QUANTIZATION_FULL_RANGE;
format->colorspace, format->xfer_func = V4L2_XFER_FUNC_NONE;
format->ycbcr_enc);
format->xfer_func = V4L2_MAP_XFER_FUNC_DEFAULT(format->colorspace);
/* Initialize crop rectangle. */ /* Initialize crop rectangle. */
crop = v4l2_subdev_get_pad_crop(sd, state, 0); crop = v4l2_subdev_get_pad_crop(sd, state, 0);
...@@ -775,12 +770,9 @@ static int imx219_enum_frame_size(struct v4l2_subdev *sd, ...@@ -775,12 +770,9 @@ static int imx219_enum_frame_size(struct v4l2_subdev *sd,
static void imx219_reset_colorspace(struct v4l2_mbus_framefmt *fmt) static void imx219_reset_colorspace(struct v4l2_mbus_framefmt *fmt)
{ {
fmt->colorspace = V4L2_COLORSPACE_SRGB; fmt->colorspace = V4L2_COLORSPACE_RAW;
fmt->ycbcr_enc = V4L2_MAP_YCBCR_ENC_DEFAULT(fmt->colorspace); fmt->quantization = V4L2_QUANTIZATION_FULL_RANGE;
fmt->quantization = V4L2_MAP_QUANTIZATION_DEFAULT(true, fmt->xfer_func = V4L2_XFER_FUNC_NONE;
fmt->colorspace,
fmt->ycbcr_enc);
fmt->xfer_func = V4L2_MAP_XFER_FUNC_DEFAULT(fmt->colorspace);
} }
static void imx219_update_pad_format(struct imx219 *imx219, static void imx219_update_pad_format(struct imx219 *imx219,
......
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