Browse Source

avfilter/asrc_anullsrc: make number of output samples match duration

tags/n4.4
Paul B Mahol 4 years ago
parent
commit
0a17a4891d
1 changed files with 13 additions and 3 deletions
  1. +13
    -3
      libavfilter/asrc_anullsrc.c

+ 13
- 3
libavfilter/asrc_anullsrc.c View File

@@ -93,19 +93,28 @@ static int query_formats(AVFilterContext *ctx)
return ff_set_common_channel_layouts(ctx, ff_make_format64_list(chlayouts)); return ff_set_common_channel_layouts(ctx, ff_make_format64_list(chlayouts));
} }


static av_cold int config_props(AVFilterLink *outlink)
{
ANullContext *null = outlink->src->priv;

if (null->duration >= 0)
null->duration = av_rescale(null->duration, null->sample_rate, AV_TIME_BASE);

return 0;
}

static int activate(AVFilterContext *ctx) static int activate(AVFilterContext *ctx)
{ {
ANullContext *null = ctx->priv; ANullContext *null = ctx->priv;
AVFilterLink *outlink = ctx->outputs[0]; AVFilterLink *outlink = ctx->outputs[0];


if (null->duration >= 0 &&
av_rescale_q(null->pts, outlink->time_base, AV_TIME_BASE_Q) >= null->duration) {
if (null->duration >= 0 && null->pts >= null->duration) {
ff_outlink_set_status(outlink, AVERROR_EOF, null->pts); ff_outlink_set_status(outlink, AVERROR_EOF, null->pts);
return 0; return 0;
} }


if (ff_outlink_frame_wanted(outlink)) { if (ff_outlink_frame_wanted(outlink)) {
AVFrame *samplesref = ff_get_audio_buffer(outlink, null->nb_samples);
AVFrame *samplesref = ff_get_audio_buffer(outlink, null->duration >= 0 ? FFMIN(null->nb_samples, null->duration - null->pts) : null->nb_samples);
int ret; int ret;


if (!samplesref) if (!samplesref)
@@ -128,6 +137,7 @@ static const AVFilterPad avfilter_asrc_anullsrc_outputs[] = {
{ {
.name = "default", .name = "default",
.type = AVMEDIA_TYPE_AUDIO, .type = AVMEDIA_TYPE_AUDIO,
.config_props = config_props,
}, },
{ NULL } { NULL }
}; };


Loading…
Cancel
Save