mirror of
https://gitlab.freedesktop.org/gstreamer/gstreamer.git
synced 2025-01-26 09:08:14 +00:00
matroskademux: send gap events instead of segment tricks
This fixes missing frames from being time skipped. https://bugzilla.gnome.org/show_bug.cgi?id=732372
This commit is contained in:
parent
0e13172837
commit
5653b1a25a
1 changed files with 4 additions and 23 deletions
|
@ -3478,37 +3478,18 @@ gst_matroska_demux_parse_blockgroup_or_simpleblock (GstMatroskaDemux * demux,
|
||||||
&& lace_time > demux->common.segment.start
|
&& lace_time > demux->common.segment.start
|
||||||
&& (!GST_CLOCK_TIME_IS_VALID (demux->common.segment.stop)
|
&& (!GST_CLOCK_TIME_IS_VALID (demux->common.segment.stop)
|
||||||
|| lace_time < demux->common.segment.stop)) {
|
|| lace_time < demux->common.segment.stop)) {
|
||||||
GstSegment segment;
|
GstEvent *event;
|
||||||
GstEvent *event1, *event2;
|
|
||||||
GST_DEBUG_OBJECT (demux,
|
GST_DEBUG_OBJECT (demux,
|
||||||
"Gap of %" G_GINT64_FORMAT " ns detected in"
|
"Gap of %" G_GINT64_FORMAT " ns detected in"
|
||||||
"stream %d (%" GST_TIME_FORMAT " -> %" GST_TIME_FORMAT "). "
|
"stream %d (%" GST_TIME_FORMAT " -> %" GST_TIME_FORMAT "). "
|
||||||
"Sending updated SEGMENT events", diff,
|
"Sending updated SEGMENT events", diff,
|
||||||
stream->index, GST_TIME_ARGS (stream->pos),
|
stream->index, GST_TIME_ARGS (stream->pos),
|
||||||
GST_TIME_ARGS (lace_time));
|
GST_TIME_ARGS (lace_time));
|
||||||
/* send segment events such that the gap is not accounted in
|
|
||||||
* segment base time, hence running_time */
|
event = gst_event_new_gap (demux->last_stop_end, diff);
|
||||||
/* close ahead of gap */
|
|
||||||
segment = demux->common.segment;
|
|
||||||
segment.start = demux->last_stop_end;
|
|
||||||
segment.stop = demux->last_stop_end;
|
|
||||||
segment.position = demux->last_stop_end;
|
|
||||||
event1 = gst_event_new_segment (&segment);
|
|
||||||
/* skip gap */
|
|
||||||
segment.start = lace_time;
|
|
||||||
segment.stop = demux->common.segment.stop;
|
|
||||||
segment.position = lace_time;
|
|
||||||
event2 = gst_event_new_segment (&segment);
|
|
||||||
GST_OBJECT_UNLOCK (demux);
|
GST_OBJECT_UNLOCK (demux);
|
||||||
gst_matroska_demux_send_event (demux, event1);
|
gst_pad_push_event (stream->pad, event);
|
||||||
gst_matroska_demux_send_event (demux, event2);
|
|
||||||
GST_OBJECT_LOCK (demux);
|
GST_OBJECT_LOCK (demux);
|
||||||
/* align segment view with downstream,
|
|
||||||
* prevents double-counting base time when closing segment */
|
|
||||||
/* FIXME: in 0.10, the segment base/accum got updated here, but
|
|
||||||
* maybe we don't need that because of the double accounting
|
|
||||||
* mentioned above? */
|
|
||||||
demux->common.segment = segment;
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue