mirror of
https://gitlab.freedesktop.org/gstreamer/gstreamer.git
synced 2024-12-04 15:36:35 +00:00
av1enc: Fix last timestamp tracking so it actually works
This behaves exactly the same as in vp8enc / vp9enc now. Fixes https://gitlab.freedesktop.org/gstreamer/gstreamer/-/issues/3546 Part-of: <https://gitlab.freedesktop.org/gstreamer/gstreamer/-/merge_requests/6922>
This commit is contained in:
parent
14713c9964
commit
8db6f1c929
2 changed files with 22 additions and 15 deletions
|
@ -870,6 +870,8 @@ gst_av1_enc_set_format (GstVideoEncoder * encoder, GstVideoCodecState * state)
|
|||
return FALSE;
|
||||
}
|
||||
av1enc->encoder_inited = TRUE;
|
||||
av1enc->last_pts = GST_CLOCK_TIME_NONE;
|
||||
av1enc->last_input_duration = GST_CLOCK_TIME_NONE;
|
||||
|
||||
GST_AV1_ENC_APPLY_CODEC_CONTROL (av1enc, AOME_SET_CPUUSED, av1enc->cpu_used);
|
||||
#ifdef AOM_CTRL_AV1E_SET_ROW_MT
|
||||
|
@ -968,30 +970,31 @@ gst_av1_enc_handle_frame (GstVideoEncoder * encoder, GstVideoCodecFrame * frame)
|
|||
gst_segment_to_running_time (&encoder->input_segment,
|
||||
GST_FORMAT_TIME, frame->pts);
|
||||
|
||||
if (GST_CLOCK_TIME_IS_VALID (av1enc->next_pts)
|
||||
&& pts_rt <= av1enc->next_pts) {
|
||||
if (GST_CLOCK_TIME_IS_VALID (av1enc->last_pts)
|
||||
&& pts_rt <= av1enc->last_pts) {
|
||||
GST_WARNING_OBJECT (av1enc,
|
||||
"decreasing pts %" GST_TIME_FORMAT " previous buffer was %"
|
||||
GST_TIME_FORMAT " enforce increasing pts", GST_TIME_ARGS (pts_rt),
|
||||
GST_TIME_ARGS (av1enc->next_pts));
|
||||
pts_rt = av1enc->next_pts + 1;
|
||||
GST_TIME_ARGS (av1enc->last_pts));
|
||||
pts_rt = av1enc->last_pts + 1;
|
||||
}
|
||||
|
||||
av1enc->next_pts = pts_rt;
|
||||
av1enc->last_pts = pts_rt;
|
||||
|
||||
// Convert the pts from nanoseconds to timebase units
|
||||
scaled_pts =
|
||||
gst_util_uint64_scale_int (pts_rt,
|
||||
gst_util_uint64_scale (pts_rt,
|
||||
av1enc->aom_cfg.g_timebase.den,
|
||||
av1enc->aom_cfg.g_timebase.num * (GstClockTime) GST_SECOND);
|
||||
|
||||
if (frame->duration != GST_CLOCK_TIME_NONE) {
|
||||
duration =
|
||||
gst_util_uint64_scale (frame->duration, av1enc->aom_cfg.g_timebase.den,
|
||||
gst_util_uint64_scale_round (frame->duration,
|
||||
av1enc->aom_cfg.g_timebase.den,
|
||||
av1enc->aom_cfg.g_timebase.num * (GstClockTime) GST_SECOND);
|
||||
|
||||
if (duration > 0) {
|
||||
av1enc->next_pts += frame->duration;
|
||||
av1enc->last_input_duration = frame->duration;
|
||||
} else {
|
||||
/* We force the path ignoring the duration if we end up with a zero
|
||||
* value for duration after scaling (e.g. duration value too small) */
|
||||
|
@ -999,11 +1002,9 @@ gst_av1_enc_handle_frame (GstVideoEncoder * encoder, GstVideoCodecFrame * frame)
|
|||
"Ignoring too small frame duration %" GST_TIME_FORMAT,
|
||||
GST_TIME_ARGS (frame->duration));
|
||||
duration = 1;
|
||||
av1enc->next_pts += 1;
|
||||
}
|
||||
} else {
|
||||
duration = 1;
|
||||
av1enc->next_pts += 1;
|
||||
}
|
||||
|
||||
if (aom_codec_encode (&av1enc->encoder, &raw, scaled_pts, duration, flags)
|
||||
|
@ -1038,8 +1039,11 @@ gst_av1_enc_finish (GstVideoEncoder * encoder)
|
|||
GST_DEBUG_OBJECT (encoder, "Calling finish");
|
||||
g_mutex_lock (&av1enc->encoder_lock);
|
||||
|
||||
if (GST_CLOCK_TIME_IS_VALID (av1enc->next_pts))
|
||||
pts = av1enc->next_pts;
|
||||
if (GST_CLOCK_TIME_IS_VALID (av1enc->last_pts))
|
||||
pts = av1enc->last_pts;
|
||||
if (GST_CLOCK_TIME_IS_VALID (av1enc->last_input_duration))
|
||||
pts += av1enc->last_input_duration;
|
||||
|
||||
scaled_pts =
|
||||
gst_util_uint64_scale (pts,
|
||||
av1enc->aom_cfg.g_timebase.den,
|
||||
|
@ -1071,7 +1075,8 @@ gst_av1_enc_destroy_encoder (GstAV1Enc * av1enc)
|
|||
av1enc->encoder_inited = FALSE;
|
||||
}
|
||||
|
||||
av1enc->next_pts = GST_CLOCK_TIME_NONE;
|
||||
av1enc->last_pts = GST_CLOCK_TIME_NONE;
|
||||
av1enc->last_input_duration = GST_CLOCK_TIME_NONE;
|
||||
|
||||
g_mutex_unlock (&av1enc->encoder_lock);
|
||||
}
|
||||
|
|
|
@ -172,8 +172,10 @@ struct _GstAV1Enc
|
|||
aom_img_fmt_t format;
|
||||
GMutex encoder_lock;
|
||||
|
||||
/* next pts, in running time */
|
||||
GstClockTime next_pts;
|
||||
/* Last inputi pts, in running time */
|
||||
GstClockTime last_pts;
|
||||
/* duration of the last input buffer */
|
||||
GstClockTime last_input_duration;
|
||||
|
||||
gboolean target_bitrate_set;
|
||||
};
|
||||
|
|
Loading…
Reference in a new issue