<html><head><meta name="color-scheme" content="light dark"></head><body><pre style="word-wrap: break-word; white-space: pre-wrap;">
From: Gerd Knorr &lt;kraxel@bytesex.org&gt;

Adapt saa7134 driver to video-buf changes.

Signed-off-by: Gerd Knorr &lt;kraxel@bytesex.org&gt;
Signed-off-by: Andrew Morton &lt;akpm@osdl.org&gt;
---

 25-akpm/drivers/media/common/saa7146_fops.c  |    4 +--
 25-akpm/drivers/media/common/saa7146_vbi.c   |   21 ++++++++--------
 25-akpm/drivers/media/common/saa7146_video.c |   34 ++++++++++++++-------------
 3 files changed, 31 insertions(+), 28 deletions(-)

diff -puN drivers/media/common/saa7146_fops.c~v4l-saa7146-update drivers/media/common/saa7146_fops.c
--- 25/drivers/media/common/saa7146_fops.c~v4l-saa7146-update	Mon Nov  8 13:51:50 2004
+++ 25-akpm/drivers/media/common/saa7146_fops.c	Mon Nov  8 13:51:50 2004
@@ -349,7 +349,7 @@ static int fops_mmap(struct file *file, 
 		BUG();
 		return 0;
 	}
-	return videobuf_mmap_mapper(vma,q);
+	return videobuf_mmap_mapper(q,vma);
 }
 
 static unsigned int fops_poll(struct file *file, struct poll_table_struct *wait)
@@ -362,7 +362,7 @@ static unsigned int fops_poll(struct fil
 
 	if (V4L2_BUF_TYPE_VBI_CAPTURE == fh-&gt;type) {
 		if( 0 == fh-&gt;vbi_q.streaming )
-			return videobuf_poll_stream(file, file-&gt;private_data, &amp;fh-&gt;vbi_q, wait);
+			return videobuf_poll_stream(file, &amp;fh-&gt;vbi_q, wait);
 		q = &amp;fh-&gt;vbi_q;
 	} else {
 		DEB_D(("using video queue.\n"));
diff -puN drivers/media/common/saa7146_vbi.c~v4l-saa7146-update drivers/media/common/saa7146_vbi.c
--- 25/drivers/media/common/saa7146_vbi.c~v4l-saa7146-update	Mon Nov  8 13:51:50 2004
+++ 25-akpm/drivers/media/common/saa7146_vbi.c	Mon Nov  8 13:51:50 2004
@@ -213,9 +213,9 @@ static int buffer_activate(struct saa714
 	return 0;
 }
 
-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-&gt;priv_data;
 	struct saa7146_fh *fh = file-&gt;private_data;
 	struct saa7146_dev *dev = fh-&gt;dev;
 	struct saa7146_buf *buf = (struct saa7146_buf *)vb;
@@ -265,7 +265,7 @@ static int buffer_prepare(void *priv, st
 	return err;
 }
 
-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)
 {
 	int llength,lines;
 	
@@ -280,9 +280,9 @@ static int buffer_setup(void *priv, unsi
 	return 0;
 }
 
-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-&gt;priv_data;
 	struct saa7146_fh *fh = file-&gt;private_data;
 	struct saa7146_dev *dev = fh-&gt;dev;
 	struct saa7146_vv *vv = dev-&gt;vv_data;
@@ -292,9 +292,9 @@ static void buffer_queue(void *priv, str
 	saa7146_buffer_queue(dev,&amp;vv-&gt;vbi_q,buf);
 }
 
-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-&gt;priv_data;
 	struct saa7146_fh *fh   = file-&gt;private_data;
 	struct saa7146_dev *dev = fh-&gt;dev;
 	struct saa7146_buf *buf = (struct saa7146_buf *)vb;
@@ -334,7 +334,7 @@ static void vbi_stop(struct saa7146_fh *
 		saa7146_buffer_finish(dev,&amp;vv-&gt;vbi_q,STATE_DONE);
 	}
 
-	videobuf_queue_cancel(file,&amp;fh-&gt;vbi_q);
+	videobuf_queue_cancel(&amp;fh-&gt;vbi_q);
 
 	vv-&gt;vbi_streaming = NULL;
 
@@ -407,7 +407,8 @@ static int vbi_open(struct saa7146_dev *
 			    dev-&gt;pci, &amp;dev-&gt;slock,
 			    V4L2_BUF_TYPE_VBI_CAPTURE,
 			    V4L2_FIELD_SEQ_TB, // FIXME: does this really work?
-			    sizeof(struct saa7146_buf));
+			    sizeof(struct saa7146_buf),
+			    file);
 	init_MUTEX(&amp;fh-&gt;vbi_q.lock);
 
 	init_timer(&amp;fh-&gt;vbi_read_timeout);
@@ -483,7 +484,7 @@ static ssize_t vbi_read(struct file *fil
 	}
 
 	mod_timer(&amp;fh-&gt;vbi_read_timeout, jiffies+BUFFER_TIMEOUT);
-	ret = videobuf_read_stream(file, &amp;fh-&gt;vbi_q, data, count, ppos, 1,
+	ret = videobuf_read_stream(&amp;fh-&gt;vbi_q, data, count, ppos, 1,
 				   file-&gt;f_flags &amp; O_NONBLOCK);
 /*
 	printk("BASE_ODD3:      0x%08x\n", saa7146_read(dev, BASE_ODD3));
diff -puN drivers/media/common/saa7146_video.c~v4l-saa7146-update drivers/media/common/saa7146_video.c
--- 25/drivers/media/common/saa7146_video.c~v4l-saa7146-update	Mon Nov  8 13:51:50 2004
+++ 25-akpm/drivers/media/common/saa7146_video.c	Mon Nov  8 13:51:50 2004
@@ -1137,7 +1137,7 @@ int saa7146_video_do_ioctl(struct inode 
 	case VIDIOC_REQBUFS: {
 		struct v4l2_requestbuffers *req = arg;
 		DEB_D(("VIDIOC_REQBUFS, type:%d\n",req-&gt;type));
-		return videobuf_reqbufs(file,q,req);
+		return videobuf_reqbufs(q,req);
 	}
 	case VIDIOC_QUERYBUF: {
 		struct v4l2_buffer *buf = arg;
@@ -1147,14 +1147,14 @@ int saa7146_video_do_ioctl(struct inode 
 	case VIDIOC_QBUF: {
 		struct v4l2_buffer *buf = arg;
 		int ret = 0;
-		ret = videobuf_qbuf(file,q,buf);
+		ret = videobuf_qbuf(q,buf);
 		DEB_D(("VIDIOC_QBUF: ret:%d, index:%d\n",ret,buf-&gt;index));
 		return ret;
 	}
 	case VIDIOC_DQBUF: {
 		struct v4l2_buffer *buf = arg;
 		int ret = 0;
-		ret = videobuf_dqbuf(file,q,buf,file-&gt;f_flags &amp; O_NONBLOCK);
+		ret = videobuf_dqbuf(q,buf,file-&gt;f_flags &amp; O_NONBLOCK);
 		DEB_D(("VIDIOC_DQBUF: ret:%d, index:%d\n",ret,buf-&gt;index));
 		return ret;
 	}
@@ -1166,7 +1166,7 @@ int saa7146_video_do_ioctl(struct inode 
 		if( 0 != err) {
 				return err;
 			}
-		err = videobuf_streamon(file,q);
+		err = videobuf_streamon(q);
 		return err;
 	}
 	case VIDIOC_STREAMOFF: {
@@ -1187,7 +1187,7 @@ int saa7146_video_do_ioctl(struct inode 
 			return -EBUSY;
 		}
 
-		err = videobuf_streamoff(file,q);
+		err = videobuf_streamoff(q);
 		if (0 != err) {
 			DEB_D(("warning: videobuf_streamoff() failed.\n"));
 		video_end(fh, file);
@@ -1210,7 +1210,7 @@ int saa7146_video_do_ioctl(struct inode 
 
 		q = &amp;fh-&gt;video_q;
 		down(&amp;q-&gt;lock);
-		err = videobuf_mmap_setup(file,q,gbuffers,gbufsize,
+		err = videobuf_mmap_setup(q,gbuffers,gbufsize,
 					  V4L2_MEMORY_MMAP);
 		if (err &lt; 0) {
 			up(&amp;q-&gt;lock);
@@ -1247,9 +1247,10 @@ static int buffer_activate (struct saa71
 	return 0;
 }
 
-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-&gt;priv_data;
 	struct saa7146_fh *fh = file-&gt;private_data;
 	struct saa7146_dev *dev = fh-&gt;dev;
 	struct saa7146_vv *vv = dev-&gt;vv_data;
@@ -1330,9 +1331,9 @@ static int buffer_prepare(void *priv, st
 	return err;
 }
 
-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)
 {
-	struct file *file = priv;
+	struct file *file = q-&gt;priv_data;
 	struct saa7146_fh *fh = file-&gt;private_data;
 
 	if (0 == *count || *count &gt; MAX_SAA7146_CAPTURE_BUFFERS)
@@ -1350,9 +1351,9 @@ static int buffer_setup(void *priv, unsi
 	return 0;
 }
 
-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-&gt;priv_data;
 	struct saa7146_fh *fh = file-&gt;private_data;
 	struct saa7146_dev *dev = fh-&gt;dev;
 	struct saa7146_vv *vv = dev-&gt;vv_data;
@@ -1363,9 +1364,9 @@ static void buffer_queue(void *priv, str
 }
 
 
-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-&gt;priv_data;
 	struct saa7146_fh *fh = file-&gt;private_data;
 	struct saa7146_dev *dev = fh-&gt;dev;
 	struct saa7146_buf *buf = (struct saa7146_buf *)vb;
@@ -1419,7 +1420,8 @@ static int video_open(struct saa7146_dev
 			    dev-&gt;pci, &amp;dev-&gt;slock,
 			    V4L2_BUF_TYPE_VIDEO_CAPTURE,
 			    V4L2_FIELD_INTERLACED,
-			    sizeof(struct saa7146_buf));
+			    sizeof(struct saa7146_buf),
+			    file);
 
 	init_MUTEX(&amp;fh-&gt;video_q.lock);
 
@@ -1485,7 +1487,7 @@ static ssize_t video_read(struct file *f
 		goto out;
 	}
 
-	ret = videobuf_read_one(file,&amp;fh-&gt;video_q , data, count, ppos,
+	ret = videobuf_read_one(&amp;fh-&gt;video_q, data, count, ppos,
 				file-&gt;f_flags &amp; O_NONBLOCK);
 	if (ret != 0) {
 	video_end(fh, file);
_
</pre></body></html>