[media] cx231xx: initialize video/vbi pads
authorMauro Carvalho Chehab <mchehab@osg.samsung.com>
Sat, 3 Jan 2015 19:08:07 +0000 (16:08 -0300)
committerMauro Carvalho Chehab <mchehab@osg.samsung.com>
Fri, 13 Feb 2015 23:10:14 +0000 (21:10 -0200)
Both video and vbi are sink pads. Initialize them as such.

Signed-off-by: Mauro Carvalho Chehab <mchehab@osg.samsung.com>
drivers/media/usb/cx231xx/cx231xx-video.c
drivers/media/usb/cx231xx/cx231xx.h

index ecea76fe07f6121c8a44fbdc7b34d9456d0a400f..f3d1a488dfa7b951acbcee3067d959564ba55b89 100644 (file)
@@ -2121,7 +2121,12 @@ int cx231xx_register_analog_devices(struct cx231xx *dev)
                dev_err(dev->dev, "cannot allocate video_device.\n");
                return -ENODEV;
        }
-
+#if defined(CONFIG_MEDIA_CONTROLLER)
+       dev->video_pad.flags = MEDIA_PAD_FL_SINK;
+       ret = media_entity_init(&dev->vdev->entity, 1, &dev->video_pad, 0);
+       if (ret < 0)
+               dev_err(dev->dev, "failed to initialize video media entity!\n");
+#endif
        dev->vdev->ctrl_handler = &dev->ctrl_handler;
        /* register v4l2 video video_device */
        ret = video_register_device(dev->vdev, VFL_TYPE_GRABBER,
@@ -2147,6 +2152,12 @@ int cx231xx_register_analog_devices(struct cx231xx *dev)
                dev_err(dev->dev, "cannot allocate video_device.\n");
                return -ENODEV;
        }
+#if defined(CONFIG_MEDIA_CONTROLLER)
+       dev->vbi_pad.flags = MEDIA_PAD_FL_SINK;
+       ret = media_entity_init(&dev->vbi_dev->entity, 1, &dev->vbi_pad, 0);
+       if (ret < 0)
+               dev_err(dev->dev, "failed to initialize vbi media entity!\n");
+#endif
        dev->vbi_dev->ctrl_handler = &dev->ctrl_handler;
        /* register v4l2 vbi video_device */
        ret = video_register_device(dev->vbi_dev, VFL_TYPE_VBI,
index af9d6c4041dcaaa0f4ee2bf3ae684b3b61896ff9..e0d3106f6b443ab05ef1cb4b3f7d8eaa87863bde 100644 (file)
@@ -660,6 +660,7 @@ struct cx231xx {
 
 #if defined(CONFIG_MEDIA_CONTROLLER)
        struct media_device *media_dev;
+       struct media_pad video_pad, vbi_pad;
 #endif
 
        unsigned char eedata[256];