summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorMauro Carvalho Chehab <mchehab@infradead.org>2007-09-27 18:25:44 -0300
committerMauro Carvalho Chehab <mchehab@infradead.org>2007-09-27 18:25:44 -0300
commit89f22d9227d65dad3df4ad8fcf333a288016cdc8 (patch)
treebb73b6b7843e1b31be3bf721e4a0d8ccef0b0a25
parentc594848c181742c41a59366a72b70cea997446fd (diff)
downloadmediapointer-dvb-s2-89f22d9227d65dad3df4ad8fcf333a288016cdc8.tar.gz
mediapointer-dvb-s2-89f22d9227d65dad3df4ad8fcf333a288016cdc8.tar.bz2
videobuf cleanup: mmap check is common to all videobuf. Make it at core
Signed-off-by: Mauro Carvalho Chehab <mchehab@infradead.org> http://thread.gmane.org/gmane.comp.video.video4linux/34978/focus=34981 Reviewed-by: Ricardo Cerqueira <v4l@cerqueira.org>
-rw-r--r--linux/drivers/media/video/videobuf-core.c4
-rw-r--r--linux/drivers/media/video/videobuf-dma-sg.c24
-rw-r--r--linux/drivers/media/video/videobuf-vmalloc.c36
-rw-r--r--linux/include/media/videobuf-core.h4
-rw-r--r--linux/include/media/videobuf-dma-sg.h1
-rw-r--r--linux/include/media/videobuf-vmalloc.h3
6 files changed, 20 insertions, 52 deletions
diff --git a/linux/drivers/media/video/videobuf-core.c b/linux/drivers/media/video/videobuf-core.c
index a446067fd..3c402060d 100644
--- a/linux/drivers/media/video/videobuf-core.c
+++ b/linux/drivers/media/video/videobuf-core.c
@@ -150,7 +150,7 @@ int videobuf_queue_is_busy(struct videobuf_queue *q)
for (i = 0; i < VIDEO_MAX_FRAME; i++) {
if (NULL == q->bufs[i])
continue;
- if (CALL(q,is_mmapped,q->bufs[i])) {
+ if (q->bufs[i]->map) {
dprintk(1,"busy: buffer #%d mapped\n",i);
return 1;
}
@@ -239,7 +239,7 @@ static void videobuf_status(struct videobuf_queue *q, struct v4l2_buffer *b,
}
b->flags = 0;
- if (CALL(q,is_mmapped,vb))
+ if (vb->map)
b->flags |= V4L2_BUF_FLAG_MAPPED;
switch (vb->state) {
diff --git a/linux/drivers/media/video/videobuf-dma-sg.c b/linux/drivers/media/video/videobuf-dma-sg.c
index 8043a544a..e808008b3 100644
--- a/linux/drivers/media/video/videobuf-dma-sg.c
+++ b/linux/drivers/media/video/videobuf-dma-sg.c
@@ -380,9 +380,9 @@ videobuf_vm_close(struct vm_area_struct *vma)
MAGIC_CHECK(mem->magic,MAGIC_SG_MEM);
- if (mem->map != map)
+ if (q->bufs[i]->map != map)
continue;
- mem->map = NULL;
+ q->bufs[i]->map = NULL;
q->bufs[i]->baddr = 0;
q->ops->buf_release(q,q->bufs[i]);
}
@@ -537,8 +537,7 @@ static int __videobuf_mmap_free(struct videobuf_queue *q)
for (i = 0; i < VIDEO_MAX_FRAME; i++) {
if (q->bufs[i]) {
- struct videbuf_pci_sg_memory *mem=q->bufs[i]->priv;
- if (mem && mem->map)
+ if (q->bufs[i]->map)
return -EBUSY;
}
}
@@ -589,8 +588,7 @@ static int __videobuf_mmap_mapper(struct videobuf_queue *q,
continue;
if (V4L2_MEMORY_MMAP != q->bufs[last]->memory)
continue;
- mem=q->bufs[last]->priv;
- if (mem->map) {
+ if (q->bufs[last]->map) {
retval = -EBUSY;
goto done;
}
@@ -610,8 +608,7 @@ static int __videobuf_mmap_mapper(struct videobuf_queue *q,
if (NULL == map)
goto done;
for (size = 0, i = first; i <= last; size += q->bufs[i++]->bsize) {
- mem=q->bufs[i]->priv;
- mem->map = map;
+ q->bufs[i]->map = map;
q->bufs[i]->baddr = vma->vm_start + size;
}
map->count = 1;
@@ -630,16 +627,6 @@ static int __videobuf_mmap_mapper(struct videobuf_queue *q,
return retval;
}
-static int __videobuf_is_mmapped (struct videobuf_buffer *buf)
-{
- struct videbuf_pci_sg_memory *mem=buf->priv;
-
- BUG_ON (!mem);
- MAGIC_CHECK(mem->magic,MAGIC_SG_MEM);
-
- return (mem->map)?1:0;
-}
-
static int __videobuf_copy_to_user ( struct videobuf_queue *q,
char __user *data, size_t count,
int nonblocking )
@@ -695,7 +682,6 @@ static struct videobuf_qtype_ops pci_ops = {
.sync = __videobuf_sync,
.mmap_free = __videobuf_mmap_free,
.mmap_mapper = __videobuf_mmap_mapper,
- .is_mmapped = __videobuf_is_mmapped,
.copy_to_user = __videobuf_copy_to_user,
.copy_stream = __videobuf_copy_stream,
};
diff --git a/linux/drivers/media/video/videobuf-vmalloc.c b/linux/drivers/media/video/videobuf-vmalloc.c
index 83aa3eda9..49b6a3336 100644
--- a/linux/drivers/media/video/videobuf-vmalloc.c
+++ b/linux/drivers/media/video/videobuf-vmalloc.c
@@ -63,7 +63,6 @@ videobuf_vm_close(struct vm_area_struct *vma)
{
struct videobuf_mapping *map = vma->vm_private_data;
struct videobuf_queue *q = map->q;
- struct videbuf_vmalloc_memory *mem;
int i;
dprintk(2,"vm_close %p [count=%d,vma=%08lx-%08lx]\n",map,
@@ -76,19 +75,13 @@ videobuf_vm_close(struct vm_area_struct *vma)
for (i = 0; i < VIDEO_MAX_FRAME; i++) {
if (NULL == q->bufs[i])
continue;
- mem=q->bufs[i]->priv;
- if (!mem)
- continue;
-
- MAGIC_CHECK(mem->magic,MAGIC_VMAL_MEM);
-
- if (mem->map != map)
+ if (q->bufs[i]->map != map)
continue;
q->ops->buf_release(q,q->bufs[i]);
- mem->map = NULL;
+ q->bufs[i]->map = NULL;
q->bufs[i]->baddr = 0;
}
mutex_unlock(&q->lock);
@@ -192,8 +185,7 @@ static int __videobuf_mmap_free(struct videobuf_queue *q)
for (i = 0; i < VIDEO_MAX_FRAME; i++) {
if (q->bufs[i]) {
- struct videbuf_vmalloc_memory *mem=q->bufs[i]->priv;
- if (mem && mem->map)
+ if (q->bufs[i]->map)
return -EBUSY;
}
}
@@ -228,12 +220,9 @@ static int __videobuf_mmap_mapper(struct videobuf_queue *q,
(vma->vm_pgoff << PAGE_SHIFT));
return -EINVAL;
}
- mem=q->bufs[first]->priv;
- BUG_ON (!mem);
- MAGIC_CHECK(mem->magic,MAGIC_VMAL_MEM);
/* create mapping + update buffer list */
- map = mem->map = kmalloc(sizeof(struct videobuf_mapping),GFP_KERNEL);
+ map = q->bufs[first]->map = kmalloc(sizeof(struct videobuf_mapping),GFP_KERNEL);
if (NULL == map)
return -ENOMEM;
@@ -247,14 +236,19 @@ static int __videobuf_mmap_mapper(struct videobuf_queue *q,
vma->vm_flags |= VM_DONTEXPAND | VM_RESERVED;
vma->vm_private_data = map;
+ mem=q->bufs[first]->priv;
+ BUG_ON (!mem);
+ MAGIC_CHECK(mem->magic,MAGIC_VMAL_MEM);
+
/* Try to remap memory */
retval=remap_vmalloc_range(vma, mem->vmalloc,0);
if (retval<0) {
dprintk(1,"mmap: postponing remap_vmalloc_range\n");
+
mem->vma=kmalloc(sizeof(*vma),GFP_KERNEL);
if (!mem->vma) {
kfree(map);
- mem->map=NULL;
+ q->bufs[first]->map=NULL;
return -ENOMEM;
}
memcpy(mem->vma,vma,sizeof(*vma));
@@ -270,15 +264,6 @@ static int __videobuf_mmap_mapper(struct videobuf_queue *q,
return (0);
}
-static int __videobuf_is_mmapped (struct videobuf_buffer *buf)
-{
- struct videbuf_vmalloc_memory *mem=buf->priv;
- BUG_ON (!mem);
- MAGIC_CHECK(mem->magic,MAGIC_VMAL_MEM);
-
- return (mem->map)?1:0;
-}
-
static int __videobuf_copy_to_user ( struct videobuf_queue *q,
char __user *data, size_t count,
int nonblocking )
@@ -336,7 +321,6 @@ static struct videobuf_qtype_ops qops = {
.sync = __videobuf_sync,
.mmap_free = __videobuf_mmap_free,
.mmap_mapper = __videobuf_mmap_mapper,
- .is_mmapped = __videobuf_is_mmapped,
.copy_to_user = __videobuf_copy_to_user,
.copy_stream = __videobuf_copy_stream,
};
diff --git a/linux/include/media/videobuf-core.h b/linux/include/media/videobuf-core.h
index 30bdc2dd1..cf0759cb2 100644
--- a/linux/include/media/videobuf-core.h
+++ b/linux/include/media/videobuf-core.h
@@ -97,6 +97,9 @@ struct videobuf_buffer {
/* buffer addr (userland ptr!) */
unsigned long baddr;
+ /* for mmap'ed buffers */
+ struct videobuf_mapping *map;
+
/* Private pointer to allow specific methods to store their data */
int privsize;
void *priv;
@@ -143,7 +146,6 @@ struct videobuf_qtype_ops {
int (*mmap_free) (struct videobuf_queue *q);
int (*mmap_mapper) (struct videobuf_queue *q,
struct vm_area_struct *vma);
- int (*is_mmapped) (struct videobuf_buffer *buf);
};
struct videobuf_queue {
diff --git a/linux/include/media/videobuf-dma-sg.h b/linux/include/media/videobuf-dma-sg.h
index 62a370990..206d9027b 100644
--- a/linux/include/media/videobuf-dma-sg.h
+++ b/linux/include/media/videobuf-dma-sg.h
@@ -86,7 +86,6 @@ struct videbuf_pci_sg_memory
u32 magic;
/* for mmap'ed buffers */
- struct videobuf_mapping *map;
struct videobuf_dmabuf dma;
};
diff --git a/linux/include/media/videobuf-vmalloc.h b/linux/include/media/videobuf-vmalloc.h
index 5fff68df6..26a8958d2 100644
--- a/linux/include/media/videobuf-vmalloc.h
+++ b/linux/include/media/videobuf-vmalloc.h
@@ -21,9 +21,6 @@ struct videbuf_vmalloc_memory
{
u32 magic;
- /* for mmap'ed buffers */
- struct videobuf_mapping *map;
-
void *vmalloc;
/* remap_vmalloc_range seems to need to run after mmap() on some cases */