]> git.sesse.net Git - ffmpeg/commitdiff
avfilter/vf_remap: use time_base from framesync
authorPaul B Mahol <onemda@gmail.com>
Sun, 14 Jul 2019 15:53:35 +0000 (17:53 +0200)
committerPaul B Mahol <onemda@gmail.com>
Sun, 14 Jul 2019 16:20:18 +0000 (18:20 +0200)
Fixes non-monotonous timestamps.

libavfilter/vf_remap.c

index 48ec38af7c889b4981d33b14e5403e7c5a73aead..2603997a2b5ca7d66efc6015f40176ed1ed74382 100644 (file)
@@ -279,7 +279,7 @@ static int process_frame(FFFrameSync *fs)
         td.step = s->step;
         ctx->internal->execute(ctx, s->remap_slice, &td, NULL, FFMIN(outlink->h, ff_filter_get_nb_threads(ctx)));
     }
-    out->pts = av_rescale_q(in->pts, s->fs.time_base, outlink->time_base);
+    out->pts = av_rescale_q(s->fs.pts, s->fs.time_base, outlink->time_base);
 
     return ff_filter_frame(outlink, out);
 }
@@ -305,7 +305,6 @@ static int config_output(AVFilterLink *outlink)
 
     outlink->w = xlink->w;
     outlink->h = xlink->h;
-    outlink->time_base = srclink->time_base;
     outlink->sample_aspect_ratio = srclink->sample_aspect_ratio;
     outlink->frame_rate = srclink->frame_rate;
 
@@ -329,7 +328,10 @@ static int config_output(AVFilterLink *outlink)
     s->fs.opaque   = s;
     s->fs.on_event = process_frame;
 
-    return ff_framesync_configure(&s->fs);
+    ret = ff_framesync_configure(&s->fs);
+    outlink->time_base = s->fs.time_base;
+
+    return ret;
 }
 
 static int activate(AVFilterContext *ctx)