diff --git a/libavfilter/af_amerge.c b/libavfilter/af_amerge.c index 44b71e4acb..e55268259e 100644 --- a/libavfilter/af_amerge.c +++ b/libavfilter/af_amerge.c @@ -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;