aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/media
diff options
context:
space:
mode:
authorHans Verkuil <hverkuil@xs4all.nl>2011-03-22 09:14:07 -0400
committerMauro Carvalho Chehab <mchehab@redhat.com>2011-03-22 15:38:16 -0400
commitb1a873a37b6551a214ad37d1eee7654a9d65fd6e (patch)
tree3667a3d36c9f7c6ae73609004331f006751c44be /drivers/media
parent2f82441a8644287e5b647329cc30b590f6fd3714 (diff)
[media] v4l2: use new flag to enable core priority handling
Rather than guess which driver supports core priority handling, require drivers that do to explicitly set the V4L2_FL_USE_FH_PRIO flag in video_device. Updated the core prio handling accordingly and set the flag in the three drivers that do. Signed-off-by: Hans Verkuil <hverkuil@xs4all.nl> Signed-off-by: Mauro Carvalho Chehab <mchehab@redhat.com>
Diffstat (limited to 'drivers/media')
-rw-r--r--drivers/media/video/cx18/cx18-streams.c1
-rw-r--r--drivers/media/video/ivtv/ivtv-streams.c1
-rw-r--r--drivers/media/video/v4l2-dev.c8
-rw-r--r--drivers/media/video/v4l2-fh.c7
-rw-r--r--drivers/media/video/v4l2-ioctl.c13
-rw-r--r--drivers/media/video/vivi.c1
6 files changed, 18 insertions, 13 deletions
diff --git a/drivers/media/video/cx18/cx18-streams.c b/drivers/media/video/cx18/cx18-streams.c
index 2d248560770e..c6e2ca3b1149 100644
--- a/drivers/media/video/cx18/cx18-streams.c
+++ b/drivers/media/video/cx18/cx18-streams.c
@@ -207,6 +207,7 @@ static int cx18_prep_dev(struct cx18 *cx, int type)
207 s->video_dev->fops = &cx18_v4l2_enc_fops; 207 s->video_dev->fops = &cx18_v4l2_enc_fops;
208 s->video_dev->release = video_device_release; 208 s->video_dev->release = video_device_release;
209 s->video_dev->tvnorms = V4L2_STD_ALL; 209 s->video_dev->tvnorms = V4L2_STD_ALL;
210 set_bit(V4L2_FL_USE_FH_PRIO, &s->video_dev->flags);
210 cx18_set_funcs(s->video_dev); 211 cx18_set_funcs(s->video_dev);
211 return 0; 212 return 0;
212} 213}
diff --git a/drivers/media/video/ivtv/ivtv-streams.c b/drivers/media/video/ivtv/ivtv-streams.c
index 512607e0cda3..942683336555 100644
--- a/drivers/media/video/ivtv/ivtv-streams.c
+++ b/drivers/media/video/ivtv/ivtv-streams.c
@@ -214,6 +214,7 @@ static int ivtv_prep_dev(struct ivtv *itv, int type)
214 s->vdev->fops = ivtv_stream_info[type].fops; 214 s->vdev->fops = ivtv_stream_info[type].fops;
215 s->vdev->release = video_device_release; 215 s->vdev->release = video_device_release;
216 s->vdev->tvnorms = V4L2_STD_ALL; 216 s->vdev->tvnorms = V4L2_STD_ALL;
217 set_bit(V4L2_FL_USE_FH_PRIO, &s->vdev->flags);
217 ivtv_set_funcs(s->vdev); 218 ivtv_set_funcs(s->vdev);
218 return 0; 219 return 0;
219} 220}
diff --git a/drivers/media/video/v4l2-dev.c b/drivers/media/video/v4l2-dev.c
index 1898099ec65a..498e6742579e 100644
--- a/drivers/media/video/v4l2-dev.c
+++ b/drivers/media/video/v4l2-dev.c
@@ -578,11 +578,9 @@ int __video_register_device(struct video_device *vdev, int type, int nr,
578 vdev->parent = vdev->v4l2_dev->dev; 578 vdev->parent = vdev->v4l2_dev->dev;
579 if (vdev->ctrl_handler == NULL) 579 if (vdev->ctrl_handler == NULL)
580 vdev->ctrl_handler = vdev->v4l2_dev->ctrl_handler; 580 vdev->ctrl_handler = vdev->v4l2_dev->ctrl_handler;
581 /* If the prio state pointer is NULL, and if the driver doesn't 581 /* If the prio state pointer is NULL, then use the v4l2_device
582 handle priorities itself, then use the v4l2_device prio 582 prio state. */
583 state. */ 583 if (vdev->prio == NULL)
584 if (vdev->prio == NULL && vdev->ioctl_ops &&
585 vdev->ioctl_ops->vidioc_s_priority == NULL)
586 vdev->prio = &vdev->v4l2_dev->prio; 584 vdev->prio = &vdev->v4l2_dev->prio;
587 } 585 }
588 586
diff --git a/drivers/media/video/v4l2-fh.c b/drivers/media/video/v4l2-fh.c
index 543b3fe6784e..717f71e6370e 100644
--- a/drivers/media/video/v4l2-fh.c
+++ b/drivers/media/video/v4l2-fh.c
@@ -35,7 +35,6 @@ int v4l2_fh_init(struct v4l2_fh *fh, struct video_device *vdev)
35 INIT_LIST_HEAD(&fh->list); 35 INIT_LIST_HEAD(&fh->list);
36 set_bit(V4L2_FL_USES_V4L2_FH, &fh->vdev->flags); 36 set_bit(V4L2_FL_USES_V4L2_FH, &fh->vdev->flags);
37 fh->prio = V4L2_PRIORITY_UNSET; 37 fh->prio = V4L2_PRIORITY_UNSET;
38 BUG_ON(vdev->prio == NULL);
39 38
40 /* 39 /*
41 * fh->events only needs to be initialized if the driver 40 * fh->events only needs to be initialized if the driver
@@ -54,7 +53,8 @@ void v4l2_fh_add(struct v4l2_fh *fh)
54{ 53{
55 unsigned long flags; 54 unsigned long flags;
56 55
57 v4l2_prio_open(fh->vdev->prio, &fh->prio); 56 if (test_bit(V4L2_FL_USE_FH_PRIO, &fh->vdev->flags))
57 v4l2_prio_open(fh->vdev->prio, &fh->prio);
58 spin_lock_irqsave(&fh->vdev->fh_lock, flags); 58 spin_lock_irqsave(&fh->vdev->fh_lock, flags);
59 list_add(&fh->list, &fh->vdev->fh_list); 59 list_add(&fh->list, &fh->vdev->fh_list);
60 spin_unlock_irqrestore(&fh->vdev->fh_lock, flags); 60 spin_unlock_irqrestore(&fh->vdev->fh_lock, flags);
@@ -82,7 +82,8 @@ void v4l2_fh_del(struct v4l2_fh *fh)
82 spin_lock_irqsave(&fh->vdev->fh_lock, flags); 82 spin_lock_irqsave(&fh->vdev->fh_lock, flags);
83 list_del_init(&fh->list); 83 list_del_init(&fh->list);
84 spin_unlock_irqrestore(&fh->vdev->fh_lock, flags); 84 spin_unlock_irqrestore(&fh->vdev->fh_lock, flags);
85 v4l2_prio_close(fh->vdev->prio, fh->prio); 85 if (test_bit(V4L2_FL_USE_FH_PRIO, &fh->vdev->flags))
86 v4l2_prio_close(fh->vdev->prio, fh->prio);
86} 87}
87EXPORT_SYMBOL_GPL(v4l2_fh_del); 88EXPORT_SYMBOL_GPL(v4l2_fh_del);
88 89
diff --git a/drivers/media/video/v4l2-ioctl.c b/drivers/media/video/v4l2-ioctl.c
index 3e6b6fa5771a..a01ed39e6c16 100644
--- a/drivers/media/video/v4l2-ioctl.c
+++ b/drivers/media/video/v4l2-ioctl.c
@@ -541,6 +541,7 @@ static long __video_do_ioctl(struct file *file,
541 void *fh = file->private_data; 541 void *fh = file->private_data;
542 struct v4l2_fh *vfh = NULL; 542 struct v4l2_fh *vfh = NULL;
543 struct v4l2_format f_copy; 543 struct v4l2_format f_copy;
544 int use_fh_prio = 0;
544 long ret = -EINVAL; 545 long ret = -EINVAL;
545 546
546 if (ops == NULL) { 547 if (ops == NULL) {
@@ -555,10 +556,12 @@ static long __video_do_ioctl(struct file *file,
555 printk(KERN_CONT "\n"); 556 printk(KERN_CONT "\n");
556 } 557 }
557 558
558 if (test_bit(V4L2_FL_USES_V4L2_FH, &vfd->flags)) 559 if (test_bit(V4L2_FL_USES_V4L2_FH, &vfd->flags)) {
559 vfh = file->private_data; 560 vfh = file->private_data;
561 use_fh_prio = test_bit(V4L2_FL_USE_FH_PRIO, &vfd->flags);
562 }
560 563
561 if (vfh && !ops->vidioc_s_priority) { 564 if (use_fh_prio) {
562 switch (cmd) { 565 switch (cmd) {
563 case VIDIOC_S_CTRL: 566 case VIDIOC_S_CTRL:
564 case VIDIOC_S_STD: 567 case VIDIOC_S_STD:
@@ -620,7 +623,7 @@ static long __video_do_ioctl(struct file *file,
620 623
621 if (ops->vidioc_g_priority) { 624 if (ops->vidioc_g_priority) {
622 ret = ops->vidioc_g_priority(file, fh, p); 625 ret = ops->vidioc_g_priority(file, fh, p);
623 } else if (vfh) { 626 } else if (use_fh_prio) {
624 *p = v4l2_prio_max(&vfd->v4l2_dev->prio); 627 *p = v4l2_prio_max(&vfd->v4l2_dev->prio);
625 ret = 0; 628 ret = 0;
626 } 629 }
@@ -632,7 +635,7 @@ static long __video_do_ioctl(struct file *file,
632 { 635 {
633 enum v4l2_priority *p = arg; 636 enum v4l2_priority *p = arg;
634 637
635 if (!ops->vidioc_s_priority && vfh == NULL) 638 if (!ops->vidioc_s_priority && !use_fh_prio)
636 break; 639 break;
637 dbgarg(cmd, "setting priority to %d\n", *p); 640 dbgarg(cmd, "setting priority to %d\n", *p);
638 if (ops->vidioc_s_priority) 641 if (ops->vidioc_s_priority)
@@ -2187,7 +2190,7 @@ static long __video_do_ioctl(struct file *file,
2187 2190
2188 if (!ops->vidioc_default) 2191 if (!ops->vidioc_default)
2189 break; 2192 break;
2190 if (vfh && !ops->vidioc_s_priority) 2193 if (use_fh_prio)
2191 valid_prio = v4l2_prio_check(vfd->prio, vfh->prio) >= 0; 2194 valid_prio = v4l2_prio_check(vfd->prio, vfh->prio) >= 0;
2192 ret = ops->vidioc_default(file, fh, valid_prio, cmd, arg); 2195 ret = ops->vidioc_default(file, fh, valid_prio, cmd, arg);
2193 break; 2196 break;
diff --git a/drivers/media/video/vivi.c b/drivers/media/video/vivi.c
index 42500bf03a9c..2238a613d664 100644
--- a/drivers/media/video/vivi.c
+++ b/drivers/media/video/vivi.c
@@ -1254,6 +1254,7 @@ static int __init vivi_create_instance(int inst)
1254 *vfd = vivi_template; 1254 *vfd = vivi_template;
1255 vfd->debug = debug; 1255 vfd->debug = debug;
1256 vfd->v4l2_dev = &dev->v4l2_dev; 1256 vfd->v4l2_dev = &dev->v4l2_dev;
1257 set_bit(V4L2_FL_USE_FH_PRIO, &vfd->flags);
1257 1258
1258 /* 1259 /*
1259 * Provide a mutex to v4l2 core. It will be used to protect 1260 * Provide a mutex to v4l2 core. It will be used to protect