diff options
author | James Almer <jamrial@gmail.com> | 2022-03-16 23:58:40 -0300 |
---|---|---|
committer | James Almer <jamrial@gmail.com> | 2022-03-17 13:04:44 -0300 |
commit | 85b7be53e12478d54f8bd0da09a07f038a9892ac (patch) | |
tree | b89684a64661ab2d75ff61bdaf10d21673eba909 /libavcodec/setts_bsf.c | |
parent | c5628ae3476b9c3ee1c440db8756c7034c4440ce (diff) | |
download | ffmpeg-85b7be53e12478d54f8bd0da09a07f038a9892ac.tar.gz |
avcodec/setts_bsf: don't repeatedly set start pts and dts
Signed-off-by: James Almer <jamrial@gmail.com>
Diffstat (limited to 'libavcodec/setts_bsf.c')
-rw-r--r-- | libavcodec/setts_bsf.c | 17 |
1 files changed, 6 insertions, 11 deletions
diff --git a/libavcodec/setts_bsf.c b/libavcodec/setts_bsf.c index b7732214ee..3c666b5061 100644 --- a/libavcodec/setts_bsf.c +++ b/libavcodec/setts_bsf.c @@ -91,9 +91,6 @@ typedef struct SetTSContext { int64_t frame_number; - int64_t start_pts; - int64_t start_dts; - double var_values[VAR_VARS_NB]; AVExpr *ts_expr; @@ -149,8 +146,8 @@ static int setts_init(AVBSFContext *ctx) ctx->time_base_out = s->time_base; s->frame_number= 0; - s->start_pts = AV_NOPTS_VALUE; - s->start_dts = AV_NOPTS_VALUE; + s->var_values[VAR_STARTPTS] = AV_NOPTS_VALUE; + s->var_values[VAR_STARTDTS] = AV_NOPTS_VALUE; s->var_values[VAR_NOPTS] = AV_NOPTS_VALUE; s->var_values[VAR_TB] = ctx->time_base_in.den ? av_q2d(ctx->time_base_in) : 0; s->var_values[VAR_TB_OUT]= ctx->time_base_out.den ? av_q2d(ctx->time_base_out) : 0; @@ -174,11 +171,11 @@ static int setts_filter(AVBSFContext *ctx, AVPacket *pkt) return AVERROR(EAGAIN); } - if (s->start_pts == AV_NOPTS_VALUE) - s->start_pts = s->cur_pkt->pts; + if (s->var_values[VAR_STARTPTS] == AV_NOPTS_VALUE) + s->var_values[VAR_STARTPTS] = s->cur_pkt->pts; - if (s->start_dts == AV_NOPTS_VALUE) - s->start_dts = s->cur_pkt->dts; + if (s->var_values[VAR_STARTDTS] == AV_NOPTS_VALUE) + s->var_values[VAR_STARTDTS] = s->cur_pkt->dts; s->var_values[VAR_N] = s->frame_number++; s->var_values[VAR_TS] = s->cur_pkt->dts; @@ -195,8 +192,6 @@ static int setts_filter(AVBSFContext *ctx, AVPacket *pkt) s->var_values[VAR_NEXT_PTS] = pkt->pts; s->var_values[VAR_NEXT_DTS] = pkt->dts; s->var_values[VAR_NEXT_DUR] = pkt->duration; - s->var_values[VAR_STARTPTS] = s->start_pts; - s->var_values[VAR_STARTDTS] = s->start_dts; new_ts = llrint(av_expr_eval(s->ts_expr, s->var_values, NULL)); new_duration = llrint(av_expr_eval(s->duration_expr, s->var_values, NULL)); |