]> git.sesse.net Git - ffmpeg/commitdiff
lavfi/buffersink: loop over ff_request_frame().
authorNicolas George <george@nsup.org>
Tue, 25 Aug 2015 22:15:22 +0000 (00:15 +0200)
committerNicolas George <george@nsup.org>
Sun, 20 Sep 2015 16:50:00 +0000 (18:50 +0200)
Do not assume that ff_request_frame() returning success
implies a frame has arrived in the FIFO.
Instead, just loop until a frame is in the FIFO.
It does not change anything since the same loop is present
in ff_request_frame(), confirmed by an assertion.

libavfilter/buffersink.c

index e693161554caa24dfdd9dc7ec07c8de8801e4240..3206bd9dfe406141901e8f6a215d0655009d7fc5 100644 (file)
@@ -133,7 +133,7 @@ int attribute_align_arg av_buffersink_get_frame_flags(AVFilterContext *ctx, AVFr
     AVFrame *cur_frame;
 
     /* no picref available, fetch it from the filterchain */
-    if (!av_fifo_size(buf->fifo)) {
+    while (!av_fifo_size(buf->fifo)) {
         if (inlink->closed)
             return AVERROR_EOF;
         if (flags & AV_BUFFERSINK_FLAG_NO_REQUEST)
@@ -142,9 +142,6 @@ int attribute_align_arg av_buffersink_get_frame_flags(AVFilterContext *ctx, AVFr
             return ret;
     }
 
-    if (!av_fifo_size(buf->fifo))
-        return AVERROR(EINVAL);
-
     if (flags & AV_BUFFERSINK_FLAG_PEEK) {
         cur_frame = *((AVFrame **)av_fifo_peek2(buf->fifo, 0));
         if ((ret = av_frame_ref(frame, cur_frame)) < 0)