|
@@ -114,18 +114,18 @@ static const struct v4l2_ctrl_config clu_mode_control = {
|
|
|
* V4L2 Subdevice Pad Operations
|
|
|
*/
|
|
|
|
|
|
+static const unsigned int clu_codes[] = {
|
|
|
+ MEDIA_BUS_FMT_ARGB8888_1X32,
|
|
|
+ MEDIA_BUS_FMT_AHSV8888_1X32,
|
|
|
+ MEDIA_BUS_FMT_AYUV8_1X32,
|
|
|
+};
|
|
|
+
|
|
|
static int clu_enum_mbus_code(struct v4l2_subdev *subdev,
|
|
|
struct v4l2_subdev_pad_config *cfg,
|
|
|
struct v4l2_subdev_mbus_code_enum *code)
|
|
|
{
|
|
|
- static const unsigned int codes[] = {
|
|
|
- MEDIA_BUS_FMT_ARGB8888_1X32,
|
|
|
- MEDIA_BUS_FMT_AHSV8888_1X32,
|
|
|
- MEDIA_BUS_FMT_AYUV8_1X32,
|
|
|
- };
|
|
|
-
|
|
|
- return vsp1_subdev_enum_mbus_code(subdev, cfg, code, codes,
|
|
|
- ARRAY_SIZE(codes));
|
|
|
+ return vsp1_subdev_enum_mbus_code(subdev, cfg, code, clu_codes,
|
|
|
+ ARRAY_SIZE(clu_codes));
|
|
|
}
|
|
|
|
|
|
static int clu_enum_frame_size(struct v4l2_subdev *subdev,
|
|
@@ -141,51 +141,10 @@ static int clu_set_format(struct v4l2_subdev *subdev,
|
|
|
struct v4l2_subdev_pad_config *cfg,
|
|
|
struct v4l2_subdev_format *fmt)
|
|
|
{
|
|
|
- struct vsp1_clu *clu = to_clu(subdev);
|
|
|
- struct v4l2_subdev_pad_config *config;
|
|
|
- struct v4l2_mbus_framefmt *format;
|
|
|
- int ret = 0;
|
|
|
-
|
|
|
- mutex_lock(&clu->entity.lock);
|
|
|
-
|
|
|
- config = vsp1_entity_get_pad_config(&clu->entity, cfg, fmt->which);
|
|
|
- if (!config) {
|
|
|
- ret = -EINVAL;
|
|
|
- goto done;
|
|
|
- }
|
|
|
-
|
|
|
- /* Default to YUV if the requested format is not supported. */
|
|
|
- if (fmt->format.code != MEDIA_BUS_FMT_ARGB8888_1X32 &&
|
|
|
- fmt->format.code != MEDIA_BUS_FMT_AHSV8888_1X32 &&
|
|
|
- fmt->format.code != MEDIA_BUS_FMT_AYUV8_1X32)
|
|
|
- fmt->format.code = MEDIA_BUS_FMT_AYUV8_1X32;
|
|
|
-
|
|
|
- format = vsp1_entity_get_pad_format(&clu->entity, config, fmt->pad);
|
|
|
-
|
|
|
- if (fmt->pad == CLU_PAD_SOURCE) {
|
|
|
- /* The CLU output format can't be modified. */
|
|
|
- fmt->format = *format;
|
|
|
- goto done;
|
|
|
- }
|
|
|
-
|
|
|
- format->code = fmt->format.code;
|
|
|
- format->width = clamp_t(unsigned int, fmt->format.width,
|
|
|
- CLU_MIN_SIZE, CLU_MAX_SIZE);
|
|
|
- format->height = clamp_t(unsigned int, fmt->format.height,
|
|
|
- CLU_MIN_SIZE, CLU_MAX_SIZE);
|
|
|
- format->field = V4L2_FIELD_NONE;
|
|
|
- format->colorspace = V4L2_COLORSPACE_SRGB;
|
|
|
-
|
|
|
- fmt->format = *format;
|
|
|
-
|
|
|
- /* Propagate the format to the source pad. */
|
|
|
- format = vsp1_entity_get_pad_format(&clu->entity, config,
|
|
|
- CLU_PAD_SOURCE);
|
|
|
- *format = fmt->format;
|
|
|
-
|
|
|
-done:
|
|
|
- mutex_unlock(&clu->entity.lock);
|
|
|
- return ret;
|
|
|
+ return vsp1_subdev_set_pad_format(subdev, cfg, fmt, clu_codes,
|
|
|
+ ARRAY_SIZE(clu_codes),
|
|
|
+ CLU_MIN_SIZE, CLU_MIN_SIZE,
|
|
|
+ CLU_MAX_SIZE, CLU_MAX_SIZE);
|
|
|
}
|
|
|
|
|
|
/* -----------------------------------------------------------------------------
|