mirror of
https://gitlab.freedesktop.org/gstreamer/gstreamer.git
synced 2025-01-12 10:25:33 +00:00
gst/asfdemux/: Make all timestamps start from zero in pull-mode too; some small clean-ups and FIXMEs here and there.
Original commit message from CVS: * gst/asfdemux/asfpacket.c: (gst_asf_payload_queue_for_stream): * gst/asfdemux/gstasfdemux.c: (gst_asf_demux_reset), (gst_asf_demux_init), (gst_asf_demux_push_complete_payloads), (gst_asf_demux_process_file): * gst/asfdemux/gstasfdemux.h: Make all timestamps start from zero in pull-mode too; some small clean-ups and FIXMEs here and there.
This commit is contained in:
parent
c2784b4ca8
commit
f7abd8bbc8
4 changed files with 41 additions and 12 deletions
10
ChangeLog
10
ChangeLog
|
@ -1,3 +1,13 @@
|
||||||
|
2007-05-04 Tim-Philipp Müller <tim at centricular dot net>
|
||||||
|
|
||||||
|
* gst/asfdemux/asfpacket.c: (gst_asf_payload_queue_for_stream):
|
||||||
|
* gst/asfdemux/gstasfdemux.c: (gst_asf_demux_reset),
|
||||||
|
(gst_asf_demux_init), (gst_asf_demux_push_complete_payloads),
|
||||||
|
(gst_asf_demux_process_file):
|
||||||
|
* gst/asfdemux/gstasfdemux.h:
|
||||||
|
Make all timestamps start from zero in pull-mode too; some small
|
||||||
|
clean-ups and FIXMEs here and there.
|
||||||
|
|
||||||
2007-05-01 Tim-Philipp Müller <tim at centricular dot net>
|
2007-05-01 Tim-Philipp Müller <tim at centricular dot net>
|
||||||
|
|
||||||
* gst/asfdemux/asfpacket.c: (gst_asf_demux_parse_payload),
|
* gst/asfdemux/asfpacket.c: (gst_asf_demux_parse_payload),
|
||||||
|
|
|
@ -121,6 +121,27 @@ static void
|
||||||
gst_asf_payload_queue_for_stream (GstASFDemux * demux, AsfPayload * payload,
|
gst_asf_payload_queue_for_stream (GstASFDemux * demux, AsfPayload * payload,
|
||||||
AsfStream * stream)
|
AsfStream * stream)
|
||||||
{
|
{
|
||||||
|
/* remember the first timestamp in the stream */
|
||||||
|
if (!GST_CLOCK_TIME_IS_VALID (demux->first_ts) &&
|
||||||
|
GST_CLOCK_TIME_IS_VALID (payload->ts)) {
|
||||||
|
GST_DEBUG_OBJECT (demux, "first ts: %" GST_TIME_FORMAT,
|
||||||
|
GST_TIME_ARGS (payload->ts));
|
||||||
|
demux->first_ts = payload->ts;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* better drop a few frames at the beginning than send bogus timestamps */
|
||||||
|
if (G_UNLIKELY (payload->ts < demux->first_ts)) {
|
||||||
|
GST_LOG_OBJECT (stream->pad, "Dropping payload with timestamp %"
|
||||||
|
GST_TIME_FORMAT " which is before the first timestamp %"
|
||||||
|
GST_TIME_FORMAT, GST_TIME_ARGS (payload->ts),
|
||||||
|
GST_TIME_ARGS (demux->first_ts));
|
||||||
|
gst_buffer_replace (&payload->buf, NULL);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* make timestamps start from 0 */
|
||||||
|
payload->ts -= demux->first_ts;
|
||||||
|
|
||||||
/* remove any incomplete payloads that will never be completed */
|
/* remove any incomplete payloads that will never be completed */
|
||||||
while (stream->payloads->len > 0) {
|
while (stream->payloads->len > 0) {
|
||||||
AsfPayload *prev;
|
AsfPayload *prev;
|
||||||
|
|
|
@ -205,6 +205,7 @@ gst_asf_demux_reset (GstASFDemux * demux)
|
||||||
demux->num_audio_streams = 0;
|
demux->num_audio_streams = 0;
|
||||||
demux->num_video_streams = 0;
|
demux->num_video_streams = 0;
|
||||||
demux->num_streams = 0;
|
demux->num_streams = 0;
|
||||||
|
demux->first_ts = GST_CLOCK_TIME_NONE;
|
||||||
demux->state = GST_ASF_DEMUX_STATE_HEADER;
|
demux->state = GST_ASF_DEMUX_STATE_HEADER;
|
||||||
demux->seekable = FALSE;
|
demux->seekable = FALSE;
|
||||||
demux->broadcast = FALSE;
|
demux->broadcast = FALSE;
|
||||||
|
@ -237,6 +238,7 @@ gst_asf_demux_init (GstASFDemux * demux, GstASFDemuxClass * klass)
|
||||||
demux->num_streams = 0;
|
demux->num_streams = 0;
|
||||||
|
|
||||||
demux->taglist = NULL;
|
demux->taglist = NULL;
|
||||||
|
demux->first_ts = GST_CLOCK_TIME_NONE;
|
||||||
demux->state = GST_ASF_DEMUX_STATE_HEADER;
|
demux->state = GST_ASF_DEMUX_STATE_HEADER;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1033,12 +1035,6 @@ gst_asf_demux_push_complete_payloads (GstASFDemux * demux)
|
||||||
GST_BUFFER_DURATION (payload->buf) = payload->duration;
|
GST_BUFFER_DURATION (payload->buf) = payload->duration;
|
||||||
|
|
||||||
/* FIXME: we should really set durations on buffers if we can */
|
/* FIXME: we should really set durations on buffers if we can */
|
||||||
/* (this is a hack, obviously)
|
|
||||||
if (strncmp (GST_PAD_NAME (stream->pad), "video", 5) == 0 &&
|
|
||||||
!GST_BUFFER_DURATION_IS_VALID (payload->buf)) {
|
|
||||||
GST_BUFFER_DURATION (payload->buf) = GST_SECOND / 30;
|
|
||||||
}
|
|
||||||
*/
|
|
||||||
|
|
||||||
GST_LOG_OBJECT (stream->pad, "pushing buffer, ts=%" GST_TIME_FORMAT
|
GST_LOG_OBJECT (stream->pad, "pushing buffer, ts=%" GST_TIME_FORMAT
|
||||||
", dur=%" GST_TIME_FORMAT " size=%u",
|
", dur=%" GST_TIME_FORMAT " size=%u",
|
||||||
|
@ -2047,14 +2043,14 @@ gst_asf_demux_process_file (GstASFDemux * demux, guint8 * data, guint64 size)
|
||||||
else
|
else
|
||||||
demux->play_time = 0;
|
demux->play_time = 0;
|
||||||
|
|
||||||
demux->preroll = preroll;
|
demux->preroll = preroll; /* FIXME: make GstClockTime */
|
||||||
|
|
||||||
if (demux->play_time == 0)
|
if (demux->play_time == 0)
|
||||||
demux->seekable = FALSE;
|
demux->seekable = FALSE;
|
||||||
|
|
||||||
GST_DEBUG_OBJECT (demux,
|
GST_DEBUG_OBJECT (demux, "play_time %" GST_TIME_FORMAT,
|
||||||
"play_time %" GST_TIME_FORMAT " preroll %" GST_TIME_FORMAT,
|
GST_TIME_ARGS (demux->play_time));
|
||||||
GST_TIME_ARGS (demux->play_time),
|
GST_DEBUG_OBJECT (demux, "preroll %" GST_TIME_FORMAT,
|
||||||
GST_TIME_ARGS (demux->preroll * GST_MSECOND));
|
GST_TIME_ARGS (demux->preroll * GST_MSECOND));
|
||||||
|
|
||||||
if (demux->play_time > 0) {
|
if (demux->play_time > 0) {
|
||||||
|
|
|
@ -87,7 +87,7 @@ typedef struct
|
||||||
guint32 sequence;
|
guint32 sequence;
|
||||||
guint64 delay;
|
guint64 delay;
|
||||||
guint64 first_pts;
|
guint64 first_pts;
|
||||||
guint64 last_pts;
|
guint64 last_pts; /* FIXME: remove, not actually evaluated */
|
||||||
GstBuffer *payload;
|
GstBuffer *payload;
|
||||||
|
|
||||||
/* video-only */
|
/* video-only */
|
||||||
|
@ -150,11 +150,13 @@ struct _GstASFDemux {
|
||||||
guint32 num_streams;
|
guint32 num_streams;
|
||||||
AsfStream stream[GST_ASF_DEMUX_NUM_STREAMS];
|
AsfStream stream[GST_ASF_DEMUX_NUM_STREAMS];
|
||||||
|
|
||||||
|
GstClockTime first_ts; /* first timestamp found */
|
||||||
|
|
||||||
guint32 packet_size;
|
guint32 packet_size;
|
||||||
guint32 timestamp; /* in milliseconds */
|
guint32 timestamp; /* in milliseconds */
|
||||||
guint64 play_time;
|
guint64 play_time;
|
||||||
|
|
||||||
guint64 preroll;
|
guint64 preroll; /* FIXME: make into GstClockTime */
|
||||||
guint64 pts;
|
guint64 pts;
|
||||||
|
|
||||||
gboolean seekable;
|
gboolean seekable;
|
||||||
|
|
Loading…
Reference in a new issue