diff options
author | Mauro Carvalho Chehab <mchehab@infradead.org> | 2006-12-01 15:33:55 -0200 |
---|---|---|
committer | Mauro Carvalho Chehab <mchehab@infradead.org> | 2006-12-01 15:33:55 -0200 |
commit | 655f032b6b86ac96cefcefe344e181d83d197c87 (patch) | |
tree | 379866364afce7b20f3cb6eb9cb0f472c09854ad | |
parent | b3ceea6006597e232746dc87188c71ba307cd681 (diff) | |
download | mediapointer-dvb-s2-655f032b6b86ac96cefcefe344e181d83d197c87.tar.gz mediapointer-dvb-s2-655f032b6b86ac96cefcefe344e181d83d197c87.tar.bz2 |
Fix free buffer handling
From: Mauro Carvalho Chehab <mchehab@infradead.org>
There is a non-compliance on video-buf implementation about calling REQBUFS
with count=0. According with API, this should free all buffers, but video-buf
returns, instead, -EINVAL.
Signed-off-by: Mauro Carvalho Chehab <mchehab@infradead.org>
-rw-r--r-- | v4l2-apps/lib/v4l2_driver.c | 17 |
1 files changed, 11 insertions, 6 deletions
diff --git a/v4l2-apps/lib/v4l2_driver.c b/v4l2-apps/lib/v4l2_driver.c index 3c156f459..a73d6a3f5 100644 --- a/v4l2-apps/lib/v4l2_driver.c +++ b/v4l2-apps/lib/v4l2_driver.c @@ -525,10 +525,21 @@ int v4l2_free_bufs(struct v4l2_driver *drv) drv->reqbuf.type = V4L2_BUF_TYPE_VIDEO_CAPTURE; drv->reqbuf.memory = V4L2_MEMORY_MMAP; + /* stop capture */ + if (xioctl(drv->fd,VIDIOC_STREAMOFF,&drv->reqbuf.type)<0) + return errno; + + sleep (1); // FIXME: Should check if all buffers are stopped + +/* V4L2 API says REQBUFS with count=0 should be used to release buffer. + However, video-buf.c doesn't implement it. + */ +#if 0 if (xioctl(drv->fd,VIDIOC_REQBUFS,&drv->reqbuf)<0) { perror("reqbufs while freeing buffers"); return errno; } +#endif if (drv->reqbuf.count != 0) { fprintf(stderr,"REQBUFS returned %d buffers while asking for freeing it!\n", @@ -693,12 +704,6 @@ prt_buf_info("***QBUF",drv->v4l2_bufs[i]); int v4l2_stop_streaming(struct v4l2_driver *drv) { - /* stop capture */ - if (xioctl(drv->fd,VIDIOC_STREAMOFF,&drv->reqbuf.type)<0) - return errno; - - sleep (1); // FIXME: Should check if all buffers are stopped - v4l2_free_bufs(drv); return 0; |