media: ov7670: Add entity pads initialization
authorWenyou Yang <wenyou.yang@microchip.com>
Mon, 16 Oct 2017 03:14:25 +0000 (05:14 +0200)
committerMauro Carvalho Chehab <mchehab@osg.samsung.com>
Fri, 27 Oct 2017 13:53:10 +0000 (15:53 +0200)
Add the media entity pads initialization.

Signed-off-by: Wenyou Yang <wenyou.yang@microchip.com>
Signed-off-by: Sakari Ailus <sakari.ailus@linux.intel.com>
Signed-off-by: Mauro Carvalho Chehab <mchehab@osg.samsung.com>
drivers/media/i2c/ov7670.c

index e88549f0e70465dd78c5f78f1f2c62d8e5b296f7..553945d4ca283ce18f019fd62c027ae8e1dd4946 100644 (file)
@@ -213,6 +213,9 @@ struct ov7670_devtype {
 struct ov7670_format_struct;  /* coming later */
 struct ov7670_info {
        struct v4l2_subdev sd;
+#if defined(CONFIG_MEDIA_CONTROLLER)
+       struct media_pad pad;
+#endif
        struct v4l2_ctrl_handler hdl;
        struct {
                /* gain cluster */
@@ -1688,14 +1691,27 @@ static int ov7670_probe(struct i2c_client *client,
        v4l2_ctrl_auto_cluster(2, &info->auto_exposure,
                               V4L2_EXPOSURE_MANUAL, false);
        v4l2_ctrl_cluster(2, &info->saturation);
+
+#if defined(CONFIG_MEDIA_CONTROLLER)
+       info->pad.flags = MEDIA_PAD_FL_SOURCE;
+       info->sd.entity.function = MEDIA_ENT_F_CAM_SENSOR;
+       ret = media_entity_pads_init(&info->sd.entity, 1, &info->pad);
+       if (ret < 0)
+               goto hdl_free;
+#endif
+
        v4l2_ctrl_handler_setup(&info->hdl);
 
        ret = v4l2_async_register_subdev(&info->sd);
        if (ret < 0)
-               goto hdl_free;
+               goto entity_cleanup;
 
        return 0;
 
+entity_cleanup:
+#if defined(CONFIG_MEDIA_CONTROLLER)
+       media_entity_cleanup(&info->sd.entity);
+#endif
 hdl_free:
        v4l2_ctrl_handler_free(&info->hdl);
 clk_disable:
@@ -1712,6 +1728,9 @@ static int ov7670_remove(struct i2c_client *client)
        v4l2_device_unregister_subdev(sd);
        v4l2_ctrl_handler_free(&info->hdl);
        clk_disable_unprepare(info->clk);
+#if defined(CONFIG_MEDIA_CONTROLLER)
+       media_entity_cleanup(&info->sd.entity);
+#endif
        return 0;
 }