From 3fef8490698b9c6a78e34a535de81e8a5b53cc01 Mon Sep 17 00:00:00 2001 From: Sakari Ailus Date: Thu, 14 Feb 2008 21:47:22 +0200 Subject: [PATCH] ARM: OMAP 2: Camera: Don't return -EIO in VIDIOC_DQBUF vidioc_dqbuf returned -EIO in a number of cases which is probably a bit confusing for many programs. This patch changes behaviour so that the next intact frame is always returned (i.e. never -EIO anymore). -EAGAIN is returned in non-blocking mode. Signed-off-by: Sakari Ailus Signed-off-by: Tony Lindgren --- drivers/media/video/omap24xxcam.c | 17 +++++++++++++---- 1 file changed, 13 insertions(+), 4 deletions(-) diff --git a/drivers/media/video/omap24xxcam.c b/drivers/media/video/omap24xxcam.c index 96f488504ad..e540a8dbb90 100644 --- a/drivers/media/video/omap24xxcam.c +++ b/drivers/media/video/omap24xxcam.c @@ -1121,6 +1121,7 @@ static int vidioc_dqbuf(struct file *file, void *fh, struct v4l2_buffer *b) struct videobuf_buffer *vb; int rval; +videobuf_dqbuf_again: rval = videobuf_dqbuf(&ofh->vbq, b, file->f_flags & O_NONBLOCK); if (rval) goto out; @@ -1138,12 +1139,20 @@ static int vidioc_dqbuf(struct file *file, void *fh, struct v4l2_buffer *b) out: /* - * This is a hack. User space won't get the index of this - * buffer and does not want to requeue it so we requeue it - * here. + * This is a hack. We don't want to show -EIO to the user + * space. Requeue the buffer and try again if we're not doing + * this in non-blocking mode. */ - if (rval == -EIO) + if (rval == -EIO) { videobuf_qbuf(&ofh->vbq, b); + if (!(file->f_flags & O_NONBLOCK)) + goto videobuf_dqbuf_again; + /* + * We don't have a videobuf_buffer now --- maybe next + * time... + */ + rval = -EAGAIN; + } return rval; } -- 2.41.1