summaryrefslogtreecommitdiff
path: root/libavfilter/avf_showfreqs.c
diff options
context:
space:
mode:
authorPaul B Mahol <onemda@gmail.com>2016-01-31 21:38:49 +0100
committerPaul B Mahol <onemda@gmail.com>2016-01-31 22:18:12 +0100
commit4ab4793c155e66ce7845831a5761c2bc0d04b035 (patch)
tree7ff9045ec6e09840972c4ed7e8181c699cc584e7 /libavfilter/avf_showfreqs.c
parent58313f2dda0a01add2d3d3d33f0b9eadfee1ff05 (diff)
avfilter/avf_showfreqs: properly handle pts
Signed-off-by: Paul B Mahol <onemda@gmail.com>
Diffstat (limited to 'libavfilter/avf_showfreqs.c')
-rw-r--r--libavfilter/avf_showfreqs.c19
1 files changed, 17 insertions, 2 deletions
diff --git a/libavfilter/avf_showfreqs.c b/libavfilter/avf_showfreqs.c
index 632388753c..af6e4c2a53 100644
--- a/libavfilter/avf_showfreqs.c
+++ b/libavfilter/avf_showfreqs.c
@@ -154,6 +154,15 @@ static int query_formats(AVFilterContext *ctx)
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)
{
AVFilterContext *ctx = outlink->src;
@@ -423,8 +432,12 @@ static int filter_frame(AVFilterLink *inlink, AVFrame *in)
AVFilterContext *ctx = inlink->dst;
ShowFreqsContext *s = ctx->priv;
AVFrame *fin = NULL;
+ int consumed = 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);
while (av_audio_fifo_size(s->fifo) >= s->win_size) {
fin = ff_get_audio_buffer(inlink, s->win_size);
@@ -433,8 +446,8 @@ static int filter_frame(AVFilterLink *inlink, AVFrame *in)
goto fail;
}
- fin->pts = s->pts;
- s->pts += s->hop_size;
+ fin->pts = s->pts + consumed;
+ consumed += s->hop_size;
ret = av_audio_fifo_peek(s->fifo, (void **)fin->extended_data, s->win_size);
if (ret < 0)
goto fail;
@@ -447,6 +460,7 @@ static int filter_frame(AVFilterLink *inlink, AVFrame *in)
}
fail:
+ s->pts = AV_NOPTS_VALUE;
av_frame_free(&fin);
av_frame_free(&in);
return ret;
@@ -491,6 +505,7 @@ static const AVFilterPad showfreqs_outputs[] = {
AVFilter ff_avf_showfreqs = {
.name = "showfreqs",
.description = NULL_IF_CONFIG_SMALL("Convert input audio to a frequencies video output."),
+ .init = init,
.uninit = uninit,
.query_formats = query_formats,
.priv_size = sizeof(ShowFreqsContext),