OSDN Git Service

lavfi/af_amerge: check for buffer queue overflows.
authorNicolas George <nicolas.george@normalesup.org>
Thu, 31 Jan 2013 13:24:57 +0000 (14:24 +0100)
committerNicolas George <nicolas.george@normalesup.org>
Thu, 31 Jan 2013 20:03:54 +0000 (21:03 +0100)
Without that test, ff_bufqueue_add silently discards the
oldest buffer, that leaves in[i].nb_samples inconsistent,
and causes later a segfault.

libavfilter/af_amerge.c

index 44b71e4..e552682 100644 (file)
@@ -231,6 +231,11 @@ static int filter_frame(AVFilterLink *inlink, AVFilterBufferRef *insamples)
         if (inlink == ctx->inputs[input_number])
             break;
     av_assert1(input_number < am->nb_inputs);
+    if (ff_bufqueue_is_full(&am->in[input_number].queue)) {
+        av_log(ctx, AV_LOG_ERROR, "Buffer queue overflow\n");
+        avfilter_unref_buffer(insamples);
+        return AVERROR(ENOMEM);
+    }
     ff_bufqueue_add(ctx, &am->in[input_number].queue, insamples);
     am->in[input_number].nb_samples += insamples->audio->nb_samples;
     nb_samples = am->in[0].nb_samples;