aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/media/video/ivtv/ivtv-ioctl.c
diff options
context:
space:
mode:
Diffstat (limited to 'drivers/media/video/ivtv/ivtv-ioctl.c')
-rw-r--r--drivers/media/video/ivtv/ivtv-ioctl.c24
1 files changed, 21 insertions, 3 deletions
diff --git a/drivers/media/video/ivtv/ivtv-ioctl.c b/drivers/media/video/ivtv/ivtv-ioctl.c
index 6422cf8f189d..e95ebdeaa72f 100644
--- a/drivers/media/video/ivtv/ivtv-ioctl.c
+++ b/drivers/media/video/ivtv/ivtv-ioctl.c
@@ -35,6 +35,7 @@
35#include <media/saa7127.h> 35#include <media/saa7127.h>
36#include <media/tveeprom.h> 36#include <media/tveeprom.h>
37#include <media/v4l2-chip-ident.h> 37#include <media/v4l2-chip-ident.h>
38#include <media/v4l2-event.h>
38#include <linux/dvb/audio.h> 39#include <linux/dvb/audio.h>
39#include <linux/i2c-id.h> 40#include <linux/i2c-id.h>
40 41
@@ -1452,6 +1453,18 @@ static int ivtv_overlay(struct file *file, void *fh, unsigned int on)
1452 return 0; 1453 return 0;
1453} 1454}
1454 1455
1456static int ivtv_subscribe_event(struct v4l2_fh *fh, struct v4l2_event_subscription *sub)
1457{
1458 switch (sub->type) {
1459 case V4L2_EVENT_VSYNC:
1460 case V4L2_EVENT_EOS:
1461 break;
1462 default:
1463 return -EINVAL;
1464 }
1465 return v4l2_event_subscribe(fh, sub);
1466}
1467
1455static int ivtv_log_status(struct file *file, void *fh) 1468static int ivtv_log_status(struct file *file, void *fh)
1456{ 1469{
1457 struct ivtv *itv = ((struct ivtv_open_id *)fh)->itv; 1470 struct ivtv *itv = ((struct ivtv_open_id *)fh)->itv;
@@ -1560,7 +1573,7 @@ static int ivtv_log_status(struct file *file, void *fh)
1560 1573
1561static int ivtv_decoder_ioctls(struct file *filp, unsigned int cmd, void *arg) 1574static int ivtv_decoder_ioctls(struct file *filp, unsigned int cmd, void *arg)
1562{ 1575{
1563 struct ivtv_open_id *id = (struct ivtv_open_id *)filp->private_data; 1576 struct ivtv_open_id *id = fh2id(filp->private_data);
1564 struct ivtv *itv = id->itv; 1577 struct ivtv *itv = id->itv;
1565 int nonblocking = filp->f_flags & O_NONBLOCK; 1578 int nonblocking = filp->f_flags & O_NONBLOCK;
1566 struct ivtv_stream *s = &itv->streams[id->type]; 1579 struct ivtv_stream *s = &itv->streams[id->type];
@@ -1820,7 +1833,7 @@ static long ivtv_serialized_ioctl(struct ivtv *itv, struct file *filp,
1820 unsigned int cmd, unsigned long arg) 1833 unsigned int cmd, unsigned long arg)
1821{ 1834{
1822 struct video_device *vfd = video_devdata(filp); 1835 struct video_device *vfd = video_devdata(filp);
1823 struct ivtv_open_id *id = (struct ivtv_open_id *)filp->private_data; 1836 struct ivtv_open_id *id = fh2id(filp->private_data);
1824 long ret; 1837 long ret;
1825 1838
1826 /* check priority */ 1839 /* check priority */
@@ -1852,10 +1865,13 @@ static long ivtv_serialized_ioctl(struct ivtv *itv, struct file *filp,
1852 1865
1853long ivtv_v4l2_ioctl(struct file *filp, unsigned int cmd, unsigned long arg) 1866long ivtv_v4l2_ioctl(struct file *filp, unsigned int cmd, unsigned long arg)
1854{ 1867{
1855 struct ivtv_open_id *id = (struct ivtv_open_id *)filp->private_data; 1868 struct ivtv_open_id *id = fh2id(filp->private_data);
1856 struct ivtv *itv = id->itv; 1869 struct ivtv *itv = id->itv;
1857 long res; 1870 long res;
1858 1871
1872 /* DQEVENT can block, so this should not run with the serialize lock */
1873 if (cmd == VIDIOC_DQEVENT)
1874 return ivtv_serialized_ioctl(itv, filp, cmd, arg);
1859 mutex_lock(&itv->serialize_lock); 1875 mutex_lock(&itv->serialize_lock);
1860 res = ivtv_serialized_ioctl(itv, filp, cmd, arg); 1876 res = ivtv_serialized_ioctl(itv, filp, cmd, arg);
1861 mutex_unlock(&itv->serialize_lock); 1877 mutex_unlock(&itv->serialize_lock);
@@ -1926,6 +1942,8 @@ static const struct v4l2_ioctl_ops ivtv_ioctl_ops = {
1926 .vidioc_g_ext_ctrls = ivtv_g_ext_ctrls, 1942 .vidioc_g_ext_ctrls = ivtv_g_ext_ctrls,
1927 .vidioc_s_ext_ctrls = ivtv_s_ext_ctrls, 1943 .vidioc_s_ext_ctrls = ivtv_s_ext_ctrls,
1928 .vidioc_try_ext_ctrls = ivtv_try_ext_ctrls, 1944 .vidioc_try_ext_ctrls = ivtv_try_ext_ctrls,
1945 .vidioc_subscribe_event = ivtv_subscribe_event,
1946 .vidioc_unsubscribe_event = v4l2_event_unsubscribe,
1929}; 1947};
1930 1948
1931void ivtv_set_funcs(struct video_device *vdev) 1949void ivtv_set_funcs(struct video_device *vdev)