[FFmpeg-cvslog] af_asyncts: fix request_frame() behavior.

Anton Khirnov git at videolan.org
Mon Jul 9 22:43:08 CEST 2012


ffmpeg | branch: master | Anton Khirnov <anton at khirnov.net> | Wed Jul  4 16:46:17 2012 +0200| [6f834293d3023153ec5d09c232ac49c3afc57baa] | committer: Anton Khirnov

af_asyncts: fix request_frame() behavior.

Make sure that an output frame has really been produced before returning
0.

> http://git.videolan.org/gitweb.cgi/ffmpeg.git/?a=commit;h=6f834293d3023153ec5d09c232ac49c3afc57baa
---

 libavfilter/af_asyncts.c |   10 +++++++++-
 1 file changed, 9 insertions(+), 1 deletion(-)

diff --git a/libavfilter/af_asyncts.c b/libavfilter/af_asyncts.c
index 8402b26..097bc60 100644
--- a/libavfilter/af_asyncts.c
+++ b/libavfilter/af_asyncts.c
@@ -37,6 +37,9 @@ typedef struct ASyncContext {
     int resample;
     float min_delta_sec;
     int max_comp;
+
+    /* set by filter_samples() to signal an output frame to request_frame() */
+    int got_output;
 } ASyncContext;
 
 #define OFFSET(x) offsetof(ASyncContext, x)
@@ -117,9 +120,13 @@ static int request_frame(AVFilterLink *link)
 {
     AVFilterContext *ctx = link->src;
     ASyncContext      *s = ctx->priv;
-    int ret = ff_request_frame(ctx->inputs[0]);
+    int ret = 0;
     int nb_samples;
 
+    s->got_output = 0;
+    while (ret >= 0 && !s->got_output)
+        ret = ff_request_frame(ctx->inputs[0]);
+
     /* flush the fifo */
     if (ret == AVERROR_EOF && (nb_samples = avresample_get_delay(s->avr))) {
         AVFilterBufferRef *buf = ff_get_audio_buffer(link, AV_PERM_WRITE,
@@ -206,6 +213,7 @@ static void filter_samples(AVFilterLink *inlink, AVFilterBufferRef *buf)
                                    delta, nb_channels, buf->format);
         }
         ff_filter_samples(outlink, buf_out);
+        s->got_output = 1;
     } else {
         av_log(ctx, AV_LOG_WARNING, "Non-monotonous timestamps, dropping "
                "whole buffer.\n");



More information about the ffmpeg-cvslog mailing list