Commit 7afd3405 authored by Ming Qian's avatar Ming Qian Committed by Andriy Gelman

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: 's avatarMing Qian <ming.qian@nxp.com>
Signed-off-by: 's avatarAndriy Gelman <andriy.gelman@gmail.com>
parent e444e5bb
...@@ -222,7 +222,7 @@ static void v4l2_free_buffer(void *opaque, uint8_t *unused) ...@@ -222,7 +222,7 @@ static void v4l2_free_buffer(void *opaque, uint8_t *unused)
if (!atomic_load(&s->refcount)) if (!atomic_load(&s->refcount))
sem_post(&s->refsync); sem_post(&s->refsync);
} else { } else {
if (s->draining) { if (s->draining && V4L2_TYPE_IS_OUTPUT(avbuf->context->type)) {
/* no need to queue more buffers to the driver */ /* no need to queue more buffers to the driver */
avbuf->status = V4L2BUF_AVAILABLE; avbuf->status = V4L2BUF_AVAILABLE;
} }
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment