Message ID | 20190516011417.10590-9-niklas.soderlund+renesas@ragnatech.se (mailing list archive) |
---|---|
State | Superseded |
Delegated to: | Kieran Bingham |
Headers | show |
Series | rcar-vin: Merge Gen2 and Gen3 file operations | expand |
Hi Niklas, Thank you for the patch. On Thu, May 16, 2019 at 03:14:17AM +0200, Niklas Söderlund wrote: > After the rework of the Gen2 file operations it's now trivial to merge > the Gen2 and Gen3 versions. > > Signed-off-by: Niklas Söderlund <niklas.soderlund+renesas@ragnatech.se> > Reviewed-by: Ulrich Hecht <uli+renesas@fpond.eu> > --- > drivers/media/platform/rcar-vin/rcar-v4l2.c | 96 ++++----------------- > 1 file changed, 16 insertions(+), 80 deletions(-) > > diff --git a/drivers/media/platform/rcar-vin/rcar-v4l2.c b/drivers/media/platform/rcar-vin/rcar-v4l2.c > index 169639416121f204..8e4afa4278fe9d30 100644 > --- a/drivers/media/platform/rcar-vin/rcar-v4l2.c > +++ b/drivers/media/platform/rcar-vin/rcar-v4l2.c > @@ -781,14 +781,19 @@ static int rvin_open(struct file *file) > if (ret) > goto err_pm; > > - if (v4l2_fh_is_singular_file(file)) { > - ret = rvin_power_parallel(vin, true); > + if (vin->info->use_mc) { > + ret = v4l2_pipeline_pm_use(&vin->vdev.entity, 1); > if (ret < 0) > goto err_open; > + } else { > + if (v4l2_fh_is_singular_file(file)) { > + ret = rvin_power_parallel(vin, true); > + if (ret < 0) > + goto err_open; > > - v4l2_ctrl_handler_setup(&vin->ctrl_handler); > + v4l2_ctrl_handler_setup(&vin->ctrl_handler); > + } > } I wonder if you shouldn't abstract the first open init and last close cleanup operations in separate functions, with MC and non-MC variants, as you will need to handle the v4l2_ctrl_handler_setup() failure here, making error handling more complex. > - > mutex_unlock(&vin->lock); > > return 0; > @@ -816,12 +821,12 @@ static int rvin_release(struct file *file) > /* the release helper will cleanup any on-going streaming */ > ret = _vb2_fop_release(file, NULL); > > - /* > - * If this was the last open file. > - * Then de-initialize hw module. > - */ > - if (fh_singular) > - rvin_power_parallel(vin, false); > + if (vin->info->use_mc) { > + v4l2_pipeline_pm_use(&vin->vdev.entity, 0); > + } else { > + if (fh_singular) > + rvin_power_parallel(vin, false); > + } > > pm_runtime_put(vin->dev); > > @@ -840,74 +845,6 @@ static const struct v4l2_file_operations rvin_fops = { > .read = vb2_fop_read, > }; > > -/* ----------------------------------------------------------------------------- > - * Media controller file operations > - */ > - > -static int rvin_mc_open(struct file *file) > -{ > - struct rvin_dev *vin = video_drvdata(file); > - int ret; > - > - ret = mutex_lock_interruptible(&vin->lock); > - if (ret) > - return ret; > - > - ret = pm_runtime_get_sync(vin->dev); > - if (ret < 0) > - goto err_unlock; > - > - ret = v4l2_pipeline_pm_use(&vin->vdev.entity, 1); > - if (ret < 0) > - goto err_pm; > - > - file->private_data = vin; > - > - ret = v4l2_fh_open(file); > - if (ret) > - goto err_v4l2pm; > - > - mutex_unlock(&vin->lock); > - > - return 0; > -err_v4l2pm: > - v4l2_pipeline_pm_use(&vin->vdev.entity, 0); > -err_pm: > - pm_runtime_put(vin->dev); > -err_unlock: > - mutex_unlock(&vin->lock); > - > - return ret; > -} > - > -static int rvin_mc_release(struct file *file) > -{ > - struct rvin_dev *vin = video_drvdata(file); > - int ret; > - > - mutex_lock(&vin->lock); > - > - /* the release helper will cleanup any on-going streaming. */ > - ret = _vb2_fop_release(file, NULL); > - > - v4l2_pipeline_pm_use(&vin->vdev.entity, 0); > - pm_runtime_put(vin->dev); > - > - mutex_unlock(&vin->lock); > - > - return ret; > -} > - > -static const struct v4l2_file_operations rvin_mc_fops = { > - .owner = THIS_MODULE, > - .unlocked_ioctl = video_ioctl2, > - .open = rvin_mc_open, > - .release = rvin_mc_release, > - .poll = vb2_fop_poll, > - .mmap = vb2_fop_mmap, > - .read = vb2_fop_read, > -}; > - > void rvin_v4l2_unregister(struct rvin_dev *vin) > { > if (!video_is_registered(&vin->vdev)) > @@ -948,6 +885,7 @@ int rvin_v4l2_register(struct rvin_dev *vin) > snprintf(vdev->name, sizeof(vdev->name), "VIN%u output", vin->id); > vdev->release = video_device_release_empty; > vdev->lock = &vin->lock; > + vdev->fops = &rvin_fops; > vdev->device_caps = V4L2_CAP_VIDEO_CAPTURE | V4L2_CAP_STREAMING | > V4L2_CAP_READWRITE; > > @@ -959,10 +897,8 @@ int rvin_v4l2_register(struct rvin_dev *vin) > vin->format.colorspace = RVIN_DEFAULT_COLORSPACE; > > if (vin->info->use_mc) { > - vdev->fops = &rvin_mc_fops; > vdev->ioctl_ops = &rvin_mc_ioctl_ops; > } else { > - vdev->fops = &rvin_fops; > vdev->ioctl_ops = &rvin_ioctl_ops; > rvin_reset_format(vin); > }
diff --git a/drivers/media/platform/rcar-vin/rcar-v4l2.c b/drivers/media/platform/rcar-vin/rcar-v4l2.c index 169639416121f204..8e4afa4278fe9d30 100644 --- a/drivers/media/platform/rcar-vin/rcar-v4l2.c +++ b/drivers/media/platform/rcar-vin/rcar-v4l2.c @@ -781,14 +781,19 @@ static int rvin_open(struct file *file) if (ret) goto err_pm; - if (v4l2_fh_is_singular_file(file)) { - ret = rvin_power_parallel(vin, true); + if (vin->info->use_mc) { + ret = v4l2_pipeline_pm_use(&vin->vdev.entity, 1); if (ret < 0) goto err_open; + } else { + if (v4l2_fh_is_singular_file(file)) { + ret = rvin_power_parallel(vin, true); + if (ret < 0) + goto err_open; - v4l2_ctrl_handler_setup(&vin->ctrl_handler); + v4l2_ctrl_handler_setup(&vin->ctrl_handler); + } } - mutex_unlock(&vin->lock); return 0; @@ -816,12 +821,12 @@ static int rvin_release(struct file *file) /* the release helper will cleanup any on-going streaming */ ret = _vb2_fop_release(file, NULL); - /* - * If this was the last open file. - * Then de-initialize hw module. - */ - if (fh_singular) - rvin_power_parallel(vin, false); + if (vin->info->use_mc) { + v4l2_pipeline_pm_use(&vin->vdev.entity, 0); + } else { + if (fh_singular) + rvin_power_parallel(vin, false); + } pm_runtime_put(vin->dev); @@ -840,74 +845,6 @@ static const struct v4l2_file_operations rvin_fops = { .read = vb2_fop_read, }; -/* ----------------------------------------------------------------------------- - * Media controller file operations - */ - -static int rvin_mc_open(struct file *file) -{ - struct rvin_dev *vin = video_drvdata(file); - int ret; - - ret = mutex_lock_interruptible(&vin->lock); - if (ret) - return ret; - - ret = pm_runtime_get_sync(vin->dev); - if (ret < 0) - goto err_unlock; - - ret = v4l2_pipeline_pm_use(&vin->vdev.entity, 1); - if (ret < 0) - goto err_pm; - - file->private_data = vin; - - ret = v4l2_fh_open(file); - if (ret) - goto err_v4l2pm; - - mutex_unlock(&vin->lock); - - return 0; -err_v4l2pm: - v4l2_pipeline_pm_use(&vin->vdev.entity, 0); -err_pm: - pm_runtime_put(vin->dev); -err_unlock: - mutex_unlock(&vin->lock); - - return ret; -} - -static int rvin_mc_release(struct file *file) -{ - struct rvin_dev *vin = video_drvdata(file); - int ret; - - mutex_lock(&vin->lock); - - /* the release helper will cleanup any on-going streaming. */ - ret = _vb2_fop_release(file, NULL); - - v4l2_pipeline_pm_use(&vin->vdev.entity, 0); - pm_runtime_put(vin->dev); - - mutex_unlock(&vin->lock); - - return ret; -} - -static const struct v4l2_file_operations rvin_mc_fops = { - .owner = THIS_MODULE, - .unlocked_ioctl = video_ioctl2, - .open = rvin_mc_open, - .release = rvin_mc_release, - .poll = vb2_fop_poll, - .mmap = vb2_fop_mmap, - .read = vb2_fop_read, -}; - void rvin_v4l2_unregister(struct rvin_dev *vin) { if (!video_is_registered(&vin->vdev)) @@ -948,6 +885,7 @@ int rvin_v4l2_register(struct rvin_dev *vin) snprintf(vdev->name, sizeof(vdev->name), "VIN%u output", vin->id); vdev->release = video_device_release_empty; vdev->lock = &vin->lock; + vdev->fops = &rvin_fops; vdev->device_caps = V4L2_CAP_VIDEO_CAPTURE | V4L2_CAP_STREAMING | V4L2_CAP_READWRITE; @@ -959,10 +897,8 @@ int rvin_v4l2_register(struct rvin_dev *vin) vin->format.colorspace = RVIN_DEFAULT_COLORSPACE; if (vin->info->use_mc) { - vdev->fops = &rvin_mc_fops; vdev->ioctl_ops = &rvin_mc_ioctl_ops; } else { - vdev->fops = &rvin_fops; vdev->ioctl_ops = &rvin_ioctl_ops; rvin_reset_format(vin); }