diff options
author | Paul B Mahol <onemda@gmail.com> | 2019-07-14 17:53:35 +0200 |
---|---|---|
committer | Paul B Mahol <onemda@gmail.com> | 2019-07-14 18:20:18 +0200 |
commit | be822eb6f880543bf4c7f5094f7062f90c7c97c1 (patch) | |
tree | 1453fbfdd22b986feb0c082af0e0b7a39e07e54c /libavfilter | |
parent | 077bf9058f162414340b427dd467b7b8739874cd (diff) | |
download | ffmpeg-be822eb6f880543bf4c7f5094f7062f90c7c97c1.tar.gz |
avfilter/vf_remap: use time_base from framesync
Fixes non-monotonous timestamps.
Diffstat (limited to 'libavfilter')
-rw-r--r-- | libavfilter/vf_remap.c | 8 |
1 files changed, 5 insertions, 3 deletions
diff --git a/libavfilter/vf_remap.c b/libavfilter/vf_remap.c index 48ec38af7c..2603997a2b 100644 --- a/libavfilter/vf_remap.c +++ b/libavfilter/vf_remap.c @@ -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) |