Commit 4ab4793c authored by Paul B Mahol's avatar Paul B Mahol

avfilter/avf_showfreqs: properly handle pts

Signed-off-by: 's avatarPaul B Mahol <onemda@gmail.com>
parent 58313f2d
...@@ -154,6 +154,15 @@ static int query_formats(AVFilterContext *ctx) ...@@ -154,6 +154,15 @@ static int query_formats(AVFilterContext *ctx)
return 0; return 0;
} }
static av_cold int init(AVFilterContext *ctx)
{
ShowFreqsContext *s = ctx->priv;
s->pts = AV_NOPTS_VALUE;
return 0;
}
static int config_output(AVFilterLink *outlink) static int config_output(AVFilterLink *outlink)
{ {
AVFilterContext *ctx = outlink->src; AVFilterContext *ctx = outlink->src;
...@@ -423,8 +432,12 @@ static int filter_frame(AVFilterLink *inlink, AVFrame *in) ...@@ -423,8 +432,12 @@ static int filter_frame(AVFilterLink *inlink, AVFrame *in)
AVFilterContext *ctx = inlink->dst; AVFilterContext *ctx = inlink->dst;
ShowFreqsContext *s = ctx->priv; ShowFreqsContext *s = ctx->priv;
AVFrame *fin = NULL; AVFrame *fin = NULL;
int consumed = 0;
int ret = 0; int ret = 0;
if (s->pts == AV_NOPTS_VALUE)
s->pts = in->pts - av_audio_fifo_size(s->fifo);
av_audio_fifo_write(s->fifo, (void **)in->extended_data, in->nb_samples); av_audio_fifo_write(s->fifo, (void **)in->extended_data, in->nb_samples);
while (av_audio_fifo_size(s->fifo) >= s->win_size) { while (av_audio_fifo_size(s->fifo) >= s->win_size) {
fin = ff_get_audio_buffer(inlink, s->win_size); fin = ff_get_audio_buffer(inlink, s->win_size);
...@@ -433,8 +446,8 @@ static int filter_frame(AVFilterLink *inlink, AVFrame *in) ...@@ -433,8 +446,8 @@ static int filter_frame(AVFilterLink *inlink, AVFrame *in)
goto fail; goto fail;
} }
fin->pts = s->pts; fin->pts = s->pts + consumed;
s->pts += s->hop_size; consumed += s->hop_size;
ret = av_audio_fifo_peek(s->fifo, (void **)fin->extended_data, s->win_size); ret = av_audio_fifo_peek(s->fifo, (void **)fin->extended_data, s->win_size);
if (ret < 0) if (ret < 0)
goto fail; goto fail;
...@@ -447,6 +460,7 @@ static int filter_frame(AVFilterLink *inlink, AVFrame *in) ...@@ -447,6 +460,7 @@ static int filter_frame(AVFilterLink *inlink, AVFrame *in)
} }
fail: fail:
s->pts = AV_NOPTS_VALUE;
av_frame_free(&fin); av_frame_free(&fin);
av_frame_free(&in); av_frame_free(&in);
return ret; return ret;
...@@ -491,6 +505,7 @@ static const AVFilterPad showfreqs_outputs[] = { ...@@ -491,6 +505,7 @@ static const AVFilterPad showfreqs_outputs[] = {
AVFilter ff_avf_showfreqs = { AVFilter ff_avf_showfreqs = {
.name = "showfreqs", .name = "showfreqs",
.description = NULL_IF_CONFIG_SMALL("Convert input audio to a frequencies video output."), .description = NULL_IF_CONFIG_SMALL("Convert input audio to a frequencies video output."),
.init = init,
.uninit = uninit, .uninit = uninit,
.query_formats = query_formats, .query_formats = query_formats,
.priv_size = sizeof(ShowFreqsContext), .priv_size = sizeof(ShowFreqsContext),
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment