diff options
author | Kenneth Aafloy <devnull@localhost> | 2004-11-16 14:23:36 +0000 |
---|---|---|
committer | Kenneth Aafloy <devnull@localhost> | 2004-11-16 14:23:36 +0000 |
commit | 070620158ef9755801329fc9b567070b8b19da38 (patch) | |
tree | af3e59882e4680cbe04d1520454b26ce445232a6 /linux/drivers/media/common | |
parent | 5c7692558a1136078b55837599894e816f2786e3 (diff) | |
download | mediapointer-dvb-s2-070620158ef9755801329fc9b567070b8b19da38.tar.gz mediapointer-dvb-s2-070620158ef9755801329fc9b567070b8b19da38.tar.bz2 |
- videobuf api changes in 2.6.10
Diffstat (limited to 'linux/drivers/media/common')
-rw-r--r-- | linux/drivers/media/common/saa7146_fops.c | 10 | ||||
-rw-r--r-- | linux/drivers/media/common/saa7146_vbi.c | 26 | ||||
-rw-r--r-- | linux/drivers/media/common/saa7146_video.c | 49 |
3 files changed, 60 insertions, 25 deletions
diff --git a/linux/drivers/media/common/saa7146_fops.c b/linux/drivers/media/common/saa7146_fops.c index 0fa03c3fa..dd92cebbd 100644 --- a/linux/drivers/media/common/saa7146_fops.c +++ b/linux/drivers/media/common/saa7146_fops.c @@ -1,4 +1,5 @@ #include <media/saa7146_vv.h> +#include <linux/version.h> #define BOARD_CAN_DO_VBI(dev) (dev->revision != 0 && dev->vv_data->vbi_minor != -1) @@ -344,7 +345,12 @@ static int fops_mmap(struct file *file, struct vm_area_struct * vma) BUG(); return 0; } + +#if LINUX_VERSION_CODE < KERNEL_VERSION(2,6,10) return videobuf_mmap_mapper(vma,q); +#else + return videobuf_mmap_mapper(q,vma); +#endif } static unsigned int fops_poll(struct file *file, struct poll_table_struct *wait) @@ -357,11 +363,7 @@ static unsigned int fops_poll(struct file *file, struct poll_table_struct *wait) if (V4L2_BUF_TYPE_VBI_CAPTURE == fh->type) { if( 0 == fh->vbi_q.streaming ) -#if (LINUX_VERSION_CODE < KERNEL_VERSION(2,6,10)) return videobuf_poll_stream(file, &fh->vbi_q, wait); -#else - return videobuf_poll_stream(file, file->private_data, &fh->vbi_q, wait); -#endif q = &fh->vbi_q; } else { DEB_D(("using video queue.\n")); 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 /* diff --git a/linux/drivers/media/common/saa7146_video.c b/linux/drivers/media/common/saa7146_video.c index 2f632b747..8cce44602 100644 --- a/linux/drivers/media/common/saa7146_video.c +++ b/linux/drivers/media/common/saa7146_video.c @@ -1137,7 +1137,11 @@ int saa7146_video_do_ioctl(struct inode *inode, struct file *file, unsigned int case VIDIOC_REQBUFS: { struct v4l2_requestbuffers *req = arg; DEB_D(("VIDIOC_REQBUFS, type:%d\n",req->type)); +#if (LINUX_VERSION_CODE < KERNEL_VERSION(2,6,10)) return videobuf_reqbufs(file,q,req); +#else + return videobuf_reqbufs(q,req); +#endif } case VIDIOC_QUERYBUF: { struct v4l2_buffer *buf = arg; @@ -1147,7 +1151,11 @@ int saa7146_video_do_ioctl(struct inode *inode, struct file *file, unsigned int case VIDIOC_QBUF: { struct v4l2_buffer *buf = arg; int ret = 0; +#if (LINUX_VERSION_CODE < KERNEL_VERSION(2,6,10)) ret = videobuf_qbuf(file,q,buf); +#else + ret = videobuf_qbuf(q,buf); +#endif DEB_D(("VIDIOC_QBUF: ret:%d, index:%d\n",ret,buf->index)); return ret; } @@ -1157,7 +1165,7 @@ int saa7146_video_do_ioctl(struct inode *inode, struct file *file, unsigned int #if (LINUX_VERSION_CODE < KERNEL_VERSION(2,6,10)) ret = videobuf_dqbuf(file,q,buf); #else - ret = videobuf_dqbuf(file,q,buf,file->f_flags & O_NONBLOCK); + ret = videobuf_dqbuf(q,buf,file->f_flags & O_NONBLOCK); #endif DEB_D(("VIDIOC_DQBUF: ret:%d, index:%d\n",ret,buf->index)); return ret; @@ -1170,7 +1178,11 @@ int saa7146_video_do_ioctl(struct inode *inode, struct file *file, unsigned int if( 0 != err) { return err; } +#if (LINUX_VERSION_CODE < KERNEL_VERSION(2,6,10)) err = videobuf_streamon(file,q); +#else + err = videobuf_streamon(q); +#endif return err; } case VIDIOC_STREAMOFF: { @@ -1191,7 +1203,11 @@ int saa7146_video_do_ioctl(struct inode *inode, struct file *file, unsigned int return -EBUSY; } +#if (LINUX_VERSION_CODE < KERNEL_VERSION(2,6,10)) err = videobuf_streamoff(file,q); +#else + err = videobuf_streamoff(q); +#endif if (0 != err) { DEB_D(("warning: videobuf_streamoff() failed.\n")); video_end(fh, file); @@ -1214,8 +1230,13 @@ int saa7146_video_do_ioctl(struct inode *inode, struct file *file, unsigned int q = &fh->video_q; down(&q->lock); +#if (LINUX_VERSION_CODE < KERNEL_VERSION(2,6,10)) err = videobuf_mmap_setup(file,q,gbuffers,gbufsize, V4L2_MEMORY_MMAP); +#else + err = videobuf_mmap_setup(q,gbuffers,gbufsize, + V4L2_MEMORY_MMAP); +#endif if (err < 0) { up(&q->lock); return err; @@ -1255,9 +1276,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; @@ -1343,9 +1364,9 @@ static int buffer_prepare(void *priv, struct videobuf_buffer *vb,enum v4l2_field 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) { - struct file *file = priv; + struct file *file = q->priv_data; #endif struct saa7146_fh *fh = file->private_data; @@ -1368,9 +1389,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; @@ -1385,9 +1406,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; @@ -1442,7 +1463,11 @@ static int video_open(struct saa7146_dev *dev, struct file *file) dev->pci, &dev->slock, V4L2_BUF_TYPE_VIDEO_CAPTURE, V4L2_FIELD_INTERLACED, - sizeof(struct saa7146_buf)); + sizeof(struct saa7146_buf) +#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2,6,10)) + ,file +#endif + ); init_MUTEX(&fh->video_q.lock); @@ -1509,9 +1534,9 @@ static ssize_t video_read(struct file *file, char __user *data, size_t count, lo } #if (LINUX_VERSION_CODE < KERNEL_VERSION(2,6,10)) - ret = videobuf_read_one(file,&fh->video_q , data, count, ppos); + ret = videobuf_read_one(file, &fh->video_q , data, count, ppos); #else - ret = videobuf_read_one(file,&fh->video_q , data, count, ppos, + ret = videobuf_read_one(&fh->video_q , data, count, ppos, file->f_flags & O_NONBLOCK); #endif if (ret != 0) { |