summaryrefslogtreecommitdiff
path: root/linux/drivers/media/common/saa7146_vbi.c
diff options
context:
space:
mode:
Diffstat (limited to 'linux/drivers/media/common/saa7146_vbi.c')
-rw-r--r--linux/drivers/media/common/saa7146_vbi.c26
1 files changed, 17 insertions, 9 deletions
diff --git a/linux/drivers/media/common/saa7146_vbi.c b/linux/drivers/media/common/saa7146_vbi.c
index 8a07e95df..ecbd93eee 100644
--- a/linux/drivers/media/common/saa7146_vbi.c
+++ b/linux/drivers/media/common/saa7146_vbi.c
@@ -218,9 +218,9 @@ static int buffer_activate(struct saa7146_dev *dev,
static int buffer_prepare(struct file *file, struct videobuf_buffer *vb,enum v4l2_field field)
{
#else
-static int buffer_prepare(void *priv, struct videobuf_buffer *vb,enum v4l2_field field)
+static int buffer_prepare(struct videobuf_queue *q, struct videobuf_buffer *vb,enum v4l2_field field)
{
- struct file *file = priv;
+ struct file *file = q->priv_data;
#endif
struct saa7146_fh *fh = file->private_data;
struct saa7146_dev *dev = fh->dev;
@@ -274,7 +274,7 @@ static int buffer_prepare(void *priv, struct videobuf_buffer *vb,enum v4l2_field
#if (LINUX_VERSION_CODE < KERNEL_VERSION(2,6,10))
static int buffer_setup(struct file *file, unsigned int *count, unsigned int *size)
#else
-static int buffer_setup(void *priv, unsigned int *count, unsigned int *size)
+static int buffer_setup(struct videobuf_queue *q, unsigned int *count, unsigned int *size)
#endif
{
int llength,lines;
@@ -294,9 +294,9 @@ static int buffer_setup(void *priv, unsigned int *count, unsigned int *size)
static void buffer_queue(struct file *file, struct videobuf_buffer *vb)
{
#else
-static void buffer_queue(void *priv, struct videobuf_buffer *vb)
+static void buffer_queue(struct videobuf_queue *q, struct videobuf_buffer *vb)
{
- struct file *file = priv;
+ struct file *file = q->priv_data;
#endif
struct saa7146_fh *fh = file->private_data;
struct saa7146_dev *dev = fh->dev;
@@ -311,9 +311,9 @@ static void buffer_queue(void *priv, struct videobuf_buffer *vb)
static void buffer_release(struct file *file, struct videobuf_buffer *vb)
{
#else
-static void buffer_release(void *priv, struct videobuf_buffer *vb)
+static void buffer_release(struct videobuf_queue *q, struct videobuf_buffer *vb)
{
- struct file *file = priv;
+ struct file *file = q->priv_data;
#endif
struct saa7146_fh *fh = file->private_data;
struct saa7146_dev *dev = fh->dev;
@@ -354,7 +354,11 @@ static void vbi_stop(struct saa7146_fh *fh, struct file *file)
saa7146_buffer_finish(dev,&vv->vbi_q,STATE_DONE);
}
+#if (LINUX_VERSION_CODE < KERNEL_VERSION(2,6,10))
videobuf_queue_cancel(file,&fh->vbi_q);
+#else
+ videobuf_queue_cancel(&fh->vbi_q);
+#endif
vv->vbi_streaming = NULL;
@@ -427,7 +431,11 @@ static int vbi_open(struct saa7146_dev *dev, struct file *file)
dev->pci, &dev->slock,
V4L2_BUF_TYPE_VBI_CAPTURE,
V4L2_FIELD_SEQ_TB, // FIXME: does this really work?
- sizeof(struct saa7146_buf));
+ sizeof(struct saa7146_buf)
+#if LINUX_VERSION_CODE >= KERNEL_VERSION(2,6,10)
+ ,file
+#endif
+ );
init_MUTEX(&fh->vbi_q.lock);
init_timer(&fh->vbi_read_timeout);
@@ -506,7 +514,7 @@ static ssize_t vbi_read(struct file *file, char __user *data, size_t count, loff
#if (LINUX_VERSION_CODE < KERNEL_VERSION(2,6,10))
ret = videobuf_read_stream(file, &fh->vbi_q, data, count, ppos, 1);
#else
- ret = videobuf_read_stream(file, &fh->vbi_q, data, count, ppos, 1,
+ ret = videobuf_read_stream(&fh->vbi_q, data, count, ppos, 1,
file->f_flags & O_NONBLOCK);
#endif
/*