[FFmpeg-cvslog] r9496 - trunk/libavformat/v4l2.c
lucabe
subversion
Fri Jul 6 09:18:25 CEST 2007
Author: lucabe
Date: Fri Jul 6 09:18:25 2007
New Revision: 9496
Log:
Support for the AVFMT_FLAG_NONBLOCK flag (non-blocking input) in v4l2.c
Modified:
trunk/libavformat/v4l2.c
Modified: trunk/libavformat/v4l2.c
==============================================================================
--- trunk/libavformat/v4l2.c (original)
+++ trunk/libavformat/v4l2.c Fri Jul 6 09:18:25 2007
@@ -119,8 +119,12 @@ static int device_open(AVFormatContext *
struct v4l2_capability cap;
int fd;
int res;
+ int flags = O_RDWR;
- fd = open(ctx->filename, O_RDWR /*| O_NONBLOCK*/, 0);
+ if (ctx->flags & AVFMT_FLAG_NONBLOCK) {
+ flags |= O_NONBLOCK;
+ }
+ fd = open(ctx->filename, flags, 0);
if (fd < 0) {
av_log(ctx, AV_LOG_ERROR, "Cannot open video device %s : %s\n",
ctx->filename, strerror(errno));
@@ -331,9 +335,13 @@ static int mmap_read_frame(AVFormatConte
buf.memory = V4L2_MEMORY_MMAP;
/* FIXME: Some special treatment might be needed in case of loss of signal... */
- while ((res = ioctl(s->fd, VIDIOC_DQBUF, &buf)) < 0 &&
- ((errno == EAGAIN) || (errno == EINTR)));
+ while ((res = ioctl(s->fd, VIDIOC_DQBUF, &buf)) < 0 && (errno == EINTR));
if (res < 0) {
+ if (errno == EAGAIN) {
+ pkt->size = 0;
+
+ return AVERROR(EAGAIN);
+ }
av_log(ctx, AV_LOG_ERROR, "ioctl(VIDIOC_DQBUF): %s\n", strerror(errno));
return -1;
More information about the ffmpeg-cvslog
mailing list