mirror of
https://gitlab.freedesktop.org/gstreamer/gstreamer.git
synced 2025-01-24 16:18:16 +00:00
splitmuxsink: Use GST_CLOCK_STIME_NONE instead of 0 to initialize max out running time
Otherwise streams with only DTS would misbehave while it is negative. For outputting everything immediately at EOS, use G_MAXINT64 instead which is bigger-or-equal to any other running time. Part-of: <https://gitlab.freedesktop.org/gstreamer/gstreamer/-/merge_requests/1005>
This commit is contained in:
parent
eed843eea0
commit
ed6823ad67
1 changed files with 5 additions and 7 deletions
|
@ -1239,10 +1239,8 @@ complete_or_wait_on_out (GstSplitMuxSink * splitmux, MqStreamCtx * ctx)
|
||||||
gboolean can_output = (ctx->is_reference || splitmux->ready_for_output);
|
gboolean can_output = (ctx->is_reference || splitmux->ready_for_output);
|
||||||
GstClockTimeDiff my_max_out_running_time = splitmux->max_out_running_time;
|
GstClockTimeDiff my_max_out_running_time = splitmux->max_out_running_time;
|
||||||
|
|
||||||
if (!(splitmux->max_out_running_time == 0 ||
|
if (my_max_out_running_time != GST_CLOCK_STIME_NONE
|
||||||
splitmux->max_out_running_time == GST_CLOCK_STIME_NONE ||
|
&& my_max_out_running_time != G_MAXINT64) {
|
||||||
splitmux->alignment_threshold == 0 ||
|
|
||||||
splitmux->max_out_running_time < splitmux->alignment_threshold)) {
|
|
||||||
my_max_out_running_time -= splitmux->alignment_threshold;
|
my_max_out_running_time -= splitmux->alignment_threshold;
|
||||||
GST_LOG_OBJECT (ctx->srcpad,
|
GST_LOG_OBJECT (ctx->srcpad,
|
||||||
"Max out running time currently %" GST_STIME_FORMAT
|
"Max out running time currently %" GST_STIME_FORMAT
|
||||||
|
@ -1261,7 +1259,7 @@ complete_or_wait_on_out (GstSplitMuxSink * splitmux, MqStreamCtx * ctx)
|
||||||
GST_STIME_ARGS (my_max_out_running_time));
|
GST_STIME_ARGS (my_max_out_running_time));
|
||||||
|
|
||||||
if (can_output) {
|
if (can_output) {
|
||||||
if (splitmux->max_out_running_time == GST_CLOCK_STIME_NONE ||
|
if (splitmux->max_out_running_time != GST_CLOCK_STIME_NONE &&
|
||||||
ctx->out_running_time < my_max_out_running_time) {
|
ctx->out_running_time < my_max_out_running_time) {
|
||||||
return GST_FLOW_OK;
|
return GST_FLOW_OK;
|
||||||
}
|
}
|
||||||
|
@ -2493,7 +2491,7 @@ handle_gathered_gop (GstSplitMuxSink * splitmux)
|
||||||
} else {
|
} else {
|
||||||
/* This is probably already the current state, but just in case: */
|
/* This is probably already the current state, but just in case: */
|
||||||
splitmux->input_state = SPLITMUX_INPUT_STATE_FINISHING_UP;
|
splitmux->input_state = SPLITMUX_INPUT_STATE_FINISHING_UP;
|
||||||
new_out_ts = GST_CLOCK_STIME_NONE; /* EOS runs until forever */
|
new_out_ts = G_MAXINT64; /* EOS runs until forever */
|
||||||
}
|
}
|
||||||
|
|
||||||
/* And wake all input contexts to send a wake-up event */
|
/* And wake all input contexts to send a wake-up event */
|
||||||
|
@ -3645,7 +3643,7 @@ gst_splitmux_sink_reset (GstSplitMuxSink * splitmux)
|
||||||
splitmux->max_in_running_time = GST_CLOCK_STIME_NONE;
|
splitmux->max_in_running_time = GST_CLOCK_STIME_NONE;
|
||||||
splitmux->gop_start_time = splitmux->fragment_start_time =
|
splitmux->gop_start_time = splitmux->fragment_start_time =
|
||||||
GST_CLOCK_STIME_NONE;
|
GST_CLOCK_STIME_NONE;
|
||||||
splitmux->max_out_running_time = 0;
|
splitmux->max_out_running_time = GST_CLOCK_STIME_NONE;
|
||||||
splitmux->fragment_total_bytes = 0;
|
splitmux->fragment_total_bytes = 0;
|
||||||
splitmux->fragment_reference_bytes = 0;
|
splitmux->fragment_reference_bytes = 0;
|
||||||
splitmux->gop_total_bytes = 0;
|
splitmux->gop_total_bytes = 0;
|
||||||
|
|
Loading…
Reference in a new issue