media: Revert "media: staging/imx: add media device to capture register"
authorSteve Longerbeam <slongerbeam@gmail.com>
Fri, 10 May 2019 21:50:04 +0000 (17:50 -0400)
committerMauro Carvalho Chehab <mchehab+samsung@kernel.org>
Tue, 28 May 2019 17:55:10 +0000 (13:55 -0400)
The imx6-specific subdevs that register a capture device will no
longer hold a reference to the media device, so this commit must be
reverted.

This reverts commit 16204b8a1c1af77725533b77936e6c73953486ae.

Signed-off-by: Steve Longerbeam <slongerbeam@gmail.com>
Signed-off-by: Hans Verkuil <hverkuil-cisco@xs4all.nl>
Signed-off-by: Mauro Carvalho Chehab <mchehab+samsung@kernel.org>
drivers/staging/media/imx/imx-ic-prpencvf.c
drivers/staging/media/imx/imx-media-capture.c
drivers/staging/media/imx/imx-media-csi.c
drivers/staging/media/imx/imx-media.h
drivers/staging/media/imx/imx7-media-csi.c

index 64037b0a83877e15d2e6846e5abc662199335396..1ba4a5154fb5518e145f41ae579f42696067ae2e 100644 (file)
@@ -1266,7 +1266,7 @@ static int prp_registered(struct v4l2_subdev *sd)
        if (ret)
                return ret;
 
-       ret = imx_media_capture_device_register(priv->md, priv->vdev);
+       ret = imx_media_capture_device_register(priv->vdev);
        if (ret)
                return ret;
 
index b6788576e43b6c26d1f898ed43ff6e9e72efc24d..2e76c58c4d8778aac224d2efa21ed4099f3c3a1d 100644 (file)
@@ -700,8 +700,7 @@ void imx_media_capture_device_error(struct imx_media_video_dev *vdev)
 }
 EXPORT_SYMBOL_GPL(imx_media_capture_device_error);
 
-int imx_media_capture_device_register(struct imx_media_dev *md,
-                                     struct imx_media_video_dev *vdev)
+int imx_media_capture_device_register(struct imx_media_video_dev *vdev)
 {
        struct capture_priv *priv = to_capture_priv(vdev);
        struct v4l2_subdev *sd = priv->src_sd;
@@ -710,7 +709,8 @@ int imx_media_capture_device_register(struct imx_media_dev *md,
        struct v4l2_subdev_format fmt_src;
        int ret;
 
-       priv->md = md;
+       /* get media device */
+       priv->md = dev_get_drvdata(sd->v4l2_dev->dev);
 
        vfd->v4l2_dev = sd->v4l2_dev;
 
index 1d248aca40a9ec3795fcf27c70fb1fa81ce9a164..28fe66052cc7486622d79ac91e5f859aa3fb0932 100644 (file)
@@ -1812,7 +1812,7 @@ static int csi_registered(struct v4l2_subdev *sd)
        if (ret)
                goto free_fim;
 
-       ret = imx_media_capture_device_register(priv->md, priv->vdev);
+       ret = imx_media_capture_device_register(priv->vdev);
        if (ret)
                goto free_fim;
 
index 6587aa49e0051859b79076c515f9701a1876870d..eb59ba0c3b62bfbc270142513ceb27cccd275adf 100644 (file)
@@ -268,8 +268,7 @@ int imx_media_of_add_csi(struct imx_media_dev *imxmd,
 struct imx_media_video_dev *
 imx_media_capture_device_init(struct v4l2_subdev *src_sd, int pad);
 void imx_media_capture_device_remove(struct imx_media_video_dev *vdev);
-int imx_media_capture_device_register(struct imx_media_dev *md,
-                                     struct imx_media_video_dev *vdev);
+int imx_media_capture_device_register(struct imx_media_video_dev *vdev);
 void imx_media_capture_device_unregister(struct imx_media_video_dev *vdev);
 struct imx_media_buffer *
 imx_media_capture_device_next_buf(struct imx_media_video_dev *vdev);
index a708a0340eb18a0a0d5931870b946e13ba78181a..18eb5d3ecf102ad5bca3f84379f1c290d2929a92 100644 (file)
@@ -1126,7 +1126,7 @@ static int imx7_csi_registered(struct v4l2_subdev *sd)
        if (ret < 0)
                return ret;
 
-       ret = imx_media_capture_device_register(csi->imxmd, csi->vdev);
+       ret = imx_media_capture_device_register(csi->vdev);
        if (ret < 0)
                return ret;