diff options
author | Anton Khirnov <anton@khirnov.net> | 2013-08-04 12:10:23 +0200 |
---|---|---|
committer | Anton Khirnov <anton@khirnov.net> | 2013-08-05 10:52:00 +0200 |
commit | 3799376dd3373ee255651ed542c75b15665801a8 (patch) | |
tree | cdba2d5a6a5a81119c62275efef28d00dc0fdcff /libavfilter | |
parent | 06cd4c5a68e23f5be199c0d2d563da80989f839f (diff) | |
download | ffmpeg-3799376dd3373ee255651ed542c75b15665801a8.tar.gz |
lavfi/fifo: fix flushing when using request_samples
If any samples are still buffered when request_frame returns EOF, they
won't be returned currently.
Diffstat (limited to 'libavfilter')
-rw-r--r-- | libavfilter/fifo.c | 11 |
1 files changed, 9 insertions, 2 deletions
diff --git a/libavfilter/fifo.c b/libavfilter/fifo.c index 8d981cef96..a58ce9f7ab 100644 --- a/libavfilter/fifo.c +++ b/libavfilter/fifo.c @@ -147,10 +147,14 @@ static int return_audio_frame(AVFilterContext *ctx) { AVFilterLink *link = ctx->outputs[0]; FifoContext *s = ctx->priv; - AVFrame *head = s->root.next->frame; + AVFrame *head = s->root.next ? s->root.next->frame : NULL; AVFrame *out; int ret; + /* if head is NULL then we're flushing the remaining samples in out */ + if (!head && !s->out) + return AVERROR_EOF; + if (!s->out && head->nb_samples >= link->request_samples && calc_ptr_alignment(head) >= 32) { @@ -227,8 +231,11 @@ static int request_frame(AVFilterLink *outlink) int ret = 0; if (!fifo->root.next) { - if ((ret = ff_request_frame(outlink->src->inputs[0])) < 0) + if ((ret = ff_request_frame(outlink->src->inputs[0])) < 0) { + if (ret == AVERROR_EOF && outlink->request_samples) + return return_audio_frame(outlink->src); return ret; + } } if (outlink->request_samples) { |