dashdemux: make timestamps start from 0
authorWim Taymans <wim.taymans@collabora.co.uk>
Fri, 8 Mar 2013 14:04:48 +0000 (15:04 +0100)
committerThiago Santos <thiago.sousa.santos@collabora.com>
Wed, 8 May 2013 21:14:45 +0000 (18:14 -0300)
Non-live streams should timestamp buffers with a running-time starting from
0. Since we already push a 0 -> -1 segment, bring the timestamps to 0
by subtracting the initial timestamp.

ext/dash/gstdashdemux.c
ext/dash/gstdashdemux.h

index 5847b981a52e9e5bd0c8d1a29d0b2ea60c7c516d..1f21fb962940ed16206328d07ea41108b46bf401 100644 (file)
@@ -1119,7 +1119,6 @@ gst_dash_demux_stream_loop (GstDashDemux * demux)
 
   if (selected_stream) {
     GstDataQueueItem *item;
-    GstBuffer *buffer;
 
     GST_DEBUG_OBJECT (demux, "Selected stream %p %d", selected_stream,
         selected_stream->index);
@@ -1128,11 +1127,19 @@ gst_dash_demux_stream_loop (GstDashDemux * demux)
       goto end;
 
     if (G_LIKELY (GST_IS_BUFFER (item->object))) {
+      GstBuffer *buffer;
+      GstClockTime timestamp;
+
       buffer = GST_BUFFER_CAST (item->object);
       active_stream =
           gst_mpdparser_get_active_stream_by_index (demux->client,
           selected_stream->index);
+
+      timestamp = GST_BUFFER_TIMESTAMP (buffer);
+
       if (demux->need_segment) {
+        demux->timestamp_offset = timestamp;
+
         /* And send a newsegment */
         for (iter = demux->streams; iter; iter = g_slist_next (iter)) {
           GstDashDemuxStream *stream = iter->data;
@@ -1143,11 +1150,14 @@ gst_dash_demux_stream_loop (GstDashDemux * demux)
         }
         demux->need_segment = FALSE;
       }
+      /* make timestamp start from 0 by subtracting the offset */
+      timestamp -= demux->timestamp_offset;
+
+      GST_BUFFER_TIMESTAMP (buffer) = timestamp;
 
       GST_DEBUG_OBJECT (demux,
           "Pushing fragment ts: %" GST_TIME_FORMAT " at pad %s",
-          GST_TIME_ARGS (GST_BUFFER_TIMESTAMP (buffer)),
-          GST_PAD_NAME (selected_stream->pad));
+          GST_TIME_ARGS (timestamp), GST_PAD_NAME (selected_stream->pad));
 #if 0
       GST_DEBUG_OBJECT (demux,
           "Pushing fragment %p #%d (stream %i) ts:%" GST_TIME_FORMAT " dur:%"
@@ -1157,8 +1167,8 @@ gst_dash_demux_stream_loop (GstDashDemux * demux)
           GST_DEBUG_PAD_NAME (selected_stream->pad));
 #endif
       ret = gst_pad_push (selected_stream->pad, gst_buffer_ref (buffer));
-      gst_segment_set_last_stop (&demux->segment, GST_FORMAT_TIME,
-          GST_BUFFER_TIMESTAMP (buffer));
+      gst_segment_set_last_stop (&demux->segment, GST_FORMAT_TIME, timestamp);
+
       item->destroy (item);
       if ((ret != GST_FLOW_OK) && (active_stream
               && active_stream->mimeType == GST_STREAM_VIDEO))
index f034b085ec61887ba8e0c4ac8f0fe9692e6815be..47fffc6a0b16a62f8ee11fc3c21ef85d4e709c29 100644 (file)
@@ -112,6 +112,7 @@ struct _GstDashDemux
 
   GstSegment segment;
   gboolean need_segment;
+  GstClockTime timestamp_offset;
 
   GstBuffer *manifest;
   GstUriDownloader *downloader;