Commit 66f469c1 authored by Laurent Pinchart's avatar Laurent Pinchart Committed by Mauro Carvalho Chehab

media: imx: imx7-media-csi: Validate capture format in .link_validate()

Move capture format validation from imx7_csi_configure() to
.link_validate(). This simplifies error handling at stream on time, as
imx7_csi_configure) now becomes a void function.
Signed-off-by: default avatarLaurent Pinchart <laurent.pinchart@ideasonboard.com>
Reviewed-by: default avatarRui Miguel Silva <rmfrfs@gmail.com>
Signed-off-by: default avatarHans Verkuil <hverkuil-cisco@xs4all.nl>
Signed-off-by: default avatarMauro Carvalho Chehab <mchehab+huawei@kernel.org>
parent db04bef6
...@@ -489,7 +489,7 @@ static void imx7_csi_dma_stop(struct imx7_csi *csi) ...@@ -489,7 +489,7 @@ static void imx7_csi_dma_stop(struct imx7_csi *csi)
imx_media_free_dma_buf(csi->dev, &csi->underrun_buf); imx_media_free_dma_buf(csi->dev, &csi->underrun_buf);
} }
static int imx7_csi_configure(struct imx7_csi *csi) static void imx7_csi_configure(struct imx7_csi *csi)
{ {
struct imx_media_video_dev *vdev = csi->vdev; struct imx_media_video_dev *vdev = csi->vdev;
struct v4l2_pix_format *out_pix = &vdev->fmt; struct v4l2_pix_format *out_pix = &vdev->fmt;
...@@ -518,7 +518,7 @@ static int imx7_csi_configure(struct imx7_csi *csi) ...@@ -518,7 +518,7 @@ static int imx7_csi_configure(struct imx7_csi *csi)
BIT_BASEADDR_CHG_ERR_EN); BIT_BASEADDR_CHG_ERR_EN);
imx7_csi_reg_write(csi, cr18, CSI_CSICR18); imx7_csi_reg_write(csi, cr18, CSI_CSICR18);
return 0; return;
} }
imx7_csi_set_imagpara(csi, width, out_pix->height); imx7_csi_set_imagpara(csi, width, out_pix->height);
...@@ -562,14 +562,10 @@ static int imx7_csi_configure(struct imx7_csi *csi) ...@@ -562,14 +562,10 @@ static int imx7_csi_configure(struct imx7_csi *csi)
cr18 |= BIT_MIPI_DATA_FORMAT_RAW14; cr18 |= BIT_MIPI_DATA_FORMAT_RAW14;
cr1 |= BIT_PIXEL_BIT; cr1 |= BIT_PIXEL_BIT;
break; break;
default:
return -EINVAL;
} }
imx7_csi_reg_write(csi, cr1, CSI_CSICR1); imx7_csi_reg_write(csi, cr1, CSI_CSICR1);
imx7_csi_reg_write(csi, cr18, CSI_CSICR18); imx7_csi_reg_write(csi, cr18, CSI_CSICR18);
return 0;
} }
static int imx7_csi_init(struct imx7_csi *csi) static int imx7_csi_init(struct imx7_csi *csi)
...@@ -622,18 +618,10 @@ static int imx7_csi_streaming_start(struct imx7_csi *csi) ...@@ -622,18 +618,10 @@ static int imx7_csi_streaming_start(struct imx7_csi *csi)
if (ret < 0) if (ret < 0)
return ret; return ret;
ret = imx7_csi_configure(csi); imx7_csi_configure(csi);
if (ret < 0)
goto dma_stop;
imx7_csi_enable(csi); imx7_csi_enable(csi);
return 0; return 0;
dma_stop:
imx7_csi_dma_stop(csi);
return ret;
} }
static int imx7_csi_streaming_stop(struct imx7_csi *csi) static int imx7_csi_streaming_stop(struct imx7_csi *csi)
...@@ -1010,10 +998,16 @@ static int imx7_csi_pad_link_validate(struct v4l2_subdev *sd, ...@@ -1010,10 +998,16 @@ static int imx7_csi_pad_link_validate(struct v4l2_subdev *sd,
struct v4l2_subdev_format *sink_fmt) struct v4l2_subdev_format *sink_fmt)
{ {
struct imx7_csi *csi = v4l2_get_subdevdata(sd); struct imx7_csi *csi = v4l2_get_subdevdata(sd);
struct imx_media_video_dev *vdev = csi->vdev;
const struct v4l2_pix_format *out_pix = &vdev->fmt;
struct media_entity *src; struct media_entity *src;
struct media_pad *pad; struct media_pad *pad;
int ret; int ret;
/*
* Validate the source link, and record whether the CSI mux selects the
* parallel input or the CSI-2 receiver.
*/
ret = v4l2_subdev_link_validate_default(sd, link, source_fmt, sink_fmt); ret = v4l2_subdev_link_validate_default(sd, link, source_fmt, sink_fmt);
if (ret) if (ret)
return ret; return ret;
...@@ -1031,10 +1025,6 @@ static int imx7_csi_pad_link_validate(struct v4l2_subdev *sd, ...@@ -1031,10 +1025,6 @@ static int imx7_csi_pad_link_validate(struct v4l2_subdev *sd,
src->function != MEDIA_ENT_F_VID_MUX) src->function != MEDIA_ENT_F_VID_MUX)
src = &csi->sd.entity; src = &csi->sd.entity;
/*
* find the entity that is selected by the source. This is needed
* to distinguish between a parallel or CSI-2 pipeline.
*/
pad = imx_media_pipeline_pad(src, 0, 0, true); pad = imx_media_pipeline_pad(src, 0, 0, true);
if (!pad) if (!pad)
return -ENODEV; return -ENODEV;
...@@ -1045,6 +1035,23 @@ static int imx7_csi_pad_link_validate(struct v4l2_subdev *sd, ...@@ -1045,6 +1035,23 @@ static int imx7_csi_pad_link_validate(struct v4l2_subdev *sd,
mutex_unlock(&csi->lock); mutex_unlock(&csi->lock);
/* Validate the sink link, ensure the pixel format is supported. */
switch (out_pix->pixelformat) {
case V4L2_PIX_FMT_UYVY:
case V4L2_PIX_FMT_YUYV:
case V4L2_PIX_FMT_GREY:
case V4L2_PIX_FMT_Y10:
case V4L2_PIX_FMT_Y12:
case V4L2_PIX_FMT_SBGGR8:
case V4L2_PIX_FMT_SBGGR16:
break;
default:
dev_dbg(csi->dev, "Invalid capture pixel format 0x%08x\n",
out_pix->pixelformat);
return -EINVAL;
}
return 0; return 0;
} }
......
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