diff options
author | Ming Qian <ming.qian@nxp.com> | 2020-03-16 10:02:08 +0800 |
---|---|---|
committer | Andriy Gelman <andriy.gelman@gmail.com> | 2020-04-29 21:55:35 -0400 |
commit | 7afd34050c1190e59e572a7882916a7dd4670d55 (patch) | |
tree | fe4f538f37bd7bdf33f63e218c27a36aa6156f65 | |
parent | e444e5bb1ad9434ab79790a5aececcd6b783360b (diff) | |
download | ffmpeg-7afd34050c1190e59e572a7882916a7dd4670d55.tar.gz |
avcodec/v4l2_buffers: don't prevent enqueue capture buffer to driver
Enqueue/dequeue of the capture buffers should continue while draining.
Reference: linux/Documentation/media/uapi/v4l/dev-decoder.rst
"The client must continue to handle both queues independently,
similarly to normal decode operation. This includes:
...
- queuing and dequeuing CAPTURE buffers, until a buffer marked with
the V4L2_BUF_FLAG_LAST flag is dequeued"
Signed-off-by: Ming Qian <ming.qian@nxp.com>
Signed-off-by: Andriy Gelman <andriy.gelman@gmail.com>
-rw-r--r-- | libavcodec/v4l2_buffers.c | 2 |
1 files changed, 1 insertions, 1 deletions
diff --git a/libavcodec/v4l2_buffers.c b/libavcodec/v4l2_buffers.c index dc1b9eaf24..02f23d954b 100644 --- a/libavcodec/v4l2_buffers.c +++ b/libavcodec/v4l2_buffers.c @@ -222,7 +222,7 @@ static void v4l2_free_buffer(void *opaque, uint8_t *unused) if (!atomic_load(&s->refcount)) sem_post(&s->refsync); } else { - if (s->draining) { + if (s->draining && V4L2_TYPE_IS_OUTPUT(avbuf->context->type)) { /* no need to queue more buffers to the driver */ avbuf->status = V4L2BUF_AVAILABLE; } |