|
@@ -37,6 +37,13 @@ void v4l2_fh_init(struct v4l2_fh *fh, struct video_device *vdev)
|
|
fh->ctrl_handler = vdev->ctrl_handler;
|
|
fh->ctrl_handler = vdev->ctrl_handler;
|
|
INIT_LIST_HEAD(&fh->list);
|
|
INIT_LIST_HEAD(&fh->list);
|
|
set_bit(V4L2_FL_USES_V4L2_FH, &fh->vdev->flags);
|
|
set_bit(V4L2_FL_USES_V4L2_FH, &fh->vdev->flags);
|
|
|
|
+ /*
|
|
|
|
+ * determine_valid_ioctls() does not know if struct v4l2_fh
|
|
|
|
+ * is used by this driver, but here we do. So enable the
|
|
|
|
+ * prio ioctls here.
|
|
|
|
+ */
|
|
|
|
+ set_bit(_IOC_NR(VIDIOC_G_PRIORITY), vdev->valid_ioctls);
|
|
|
|
+ set_bit(_IOC_NR(VIDIOC_S_PRIORITY), vdev->valid_ioctls);
|
|
fh->prio = V4L2_PRIORITY_UNSET;
|
|
fh->prio = V4L2_PRIORITY_UNSET;
|
|
init_waitqueue_head(&fh->wait);
|
|
init_waitqueue_head(&fh->wait);
|
|
INIT_LIST_HEAD(&fh->available);
|
|
INIT_LIST_HEAD(&fh->available);
|
|
@@ -49,8 +56,7 @@ void v4l2_fh_add(struct v4l2_fh *fh)
|
|
{
|
|
{
|
|
unsigned long flags;
|
|
unsigned long flags;
|
|
|
|
|
|
- if (test_bit(V4L2_FL_USE_FH_PRIO, &fh->vdev->flags))
|
|
|
|
- v4l2_prio_open(fh->vdev->prio, &fh->prio);
|
|
|
|
|
|
+ v4l2_prio_open(fh->vdev->prio, &fh->prio);
|
|
spin_lock_irqsave(&fh->vdev->fh_lock, flags);
|
|
spin_lock_irqsave(&fh->vdev->fh_lock, flags);
|
|
list_add(&fh->list, &fh->vdev->fh_list);
|
|
list_add(&fh->list, &fh->vdev->fh_list);
|
|
spin_unlock_irqrestore(&fh->vdev->fh_lock, flags);
|
|
spin_unlock_irqrestore(&fh->vdev->fh_lock, flags);
|
|
@@ -78,8 +84,7 @@ void v4l2_fh_del(struct v4l2_fh *fh)
|
|
spin_lock_irqsave(&fh->vdev->fh_lock, flags);
|
|
spin_lock_irqsave(&fh->vdev->fh_lock, flags);
|
|
list_del_init(&fh->list);
|
|
list_del_init(&fh->list);
|
|
spin_unlock_irqrestore(&fh->vdev->fh_lock, flags);
|
|
spin_unlock_irqrestore(&fh->vdev->fh_lock, flags);
|
|
- if (test_bit(V4L2_FL_USE_FH_PRIO, &fh->vdev->flags))
|
|
|
|
- v4l2_prio_close(fh->vdev->prio, fh->prio);
|
|
|
|
|
|
+ v4l2_prio_close(fh->vdev->prio, fh->prio);
|
|
}
|
|
}
|
|
EXPORT_SYMBOL_GPL(v4l2_fh_del);
|
|
EXPORT_SYMBOL_GPL(v4l2_fh_del);
|
|
|
|
|