mirror of
https://git.ffmpeg.org/ffmpeg.git
synced 2025-02-18 04:47:12 +00:00
avfilter/af_anlmdn: drain samples at end
This commit is contained in:
parent
b5ae61d2c0
commit
c563513fdf
@ -57,6 +57,7 @@ typedef struct AudioNLMeansContext {
|
|||||||
int64_t pts;
|
int64_t pts;
|
||||||
|
|
||||||
AVAudioFifo *fifo;
|
AVAudioFifo *fifo;
|
||||||
|
int eof_left;
|
||||||
|
|
||||||
AudioNLMDNDSPContext dsp;
|
AudioNLMDNDSPContext dsp;
|
||||||
} AudioNLMeansContext;
|
} AudioNLMeansContext;
|
||||||
@ -140,6 +141,7 @@ static int config_output(AVFilterLink *outlink)
|
|||||||
s->K = av_rescale(s->pd, outlink->sample_rate, AV_TIME_BASE);
|
s->K = av_rescale(s->pd, outlink->sample_rate, AV_TIME_BASE);
|
||||||
s->S = av_rescale(s->rd, outlink->sample_rate, AV_TIME_BASE);
|
s->S = av_rescale(s->rd, outlink->sample_rate, AV_TIME_BASE);
|
||||||
|
|
||||||
|
s->eof_left = -1;
|
||||||
s->pts = AV_NOPTS_VALUE;
|
s->pts = AV_NOPTS_VALUE;
|
||||||
s->H = s->K * 2 + 1;
|
s->H = s->K * 2 + 1;
|
||||||
s->N = s->H + (s->K + s->S) * 2;
|
s->N = s->H + (s->K + s->S) * 2;
|
||||||
@ -276,6 +278,33 @@ static int filter_frame(AVFilterLink *inlink, AVFrame *in)
|
|||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static int request_frame(AVFilterLink *outlink)
|
||||||
|
{
|
||||||
|
AVFilterContext *ctx = outlink->src;
|
||||||
|
AudioNLMeansContext *s = ctx->priv;
|
||||||
|
int ret;
|
||||||
|
|
||||||
|
ret = ff_request_frame(ctx->inputs[0]);
|
||||||
|
|
||||||
|
if (ret == AVERROR_EOF && s->eof_left != 0) {
|
||||||
|
AVFrame *in;
|
||||||
|
|
||||||
|
if (s->eof_left < 0)
|
||||||
|
s->eof_left = av_audio_fifo_size(s->fifo);
|
||||||
|
in = ff_get_audio_buffer(outlink, FFMIN(s->H, s->N - s->eof_left));
|
||||||
|
if (!in)
|
||||||
|
return AVERROR(ENOMEM);
|
||||||
|
|
||||||
|
if (s->eof_left < s->H)
|
||||||
|
s->eof_left = 0;
|
||||||
|
else
|
||||||
|
s->eof_left -= s->H;
|
||||||
|
return filter_frame(ctx->inputs[0], in);
|
||||||
|
}
|
||||||
|
|
||||||
|
return ret;
|
||||||
|
}
|
||||||
|
|
||||||
static av_cold void uninit(AVFilterContext *ctx)
|
static av_cold void uninit(AVFilterContext *ctx)
|
||||||
{
|
{
|
||||||
AudioNLMeansContext *s = ctx->priv;
|
AudioNLMeansContext *s = ctx->priv;
|
||||||
@ -299,6 +328,7 @@ static const AVFilterPad outputs[] = {
|
|||||||
.name = "default",
|
.name = "default",
|
||||||
.type = AVMEDIA_TYPE_AUDIO,
|
.type = AVMEDIA_TYPE_AUDIO,
|
||||||
.config_props = config_output,
|
.config_props = config_output,
|
||||||
|
.request_frame = request_frame,
|
||||||
},
|
},
|
||||||
{ NULL }
|
{ NULL }
|
||||||
};
|
};
|
||||||
|
Loading…
Reference in New Issue
Block a user