mssdemux: add timescale to the caps
authorThiago Santos <thiago.sousa.santos@collabora.com>
Thu, 20 Dec 2012 18:30:06 +0000 (15:30 -0300)
committerThiago Santos <thiago.sousa.santos@collabora.com>
Wed, 8 May 2013 00:05:10 +0000 (21:05 -0300)
This is important for downstream to properly timestamp the samples

The default value is 10000000, but this can be set in the stream
or at the top-level manifest entry

ext/smoothstreaming/gstmssdemux.c
ext/smoothstreaming/gstmssmanifest.c
ext/smoothstreaming/gstmssmanifest.h

index a9a1b7266705073febb68e156a113e2a3a0f1285..243a40e97ca9e19c402cbbe7f65b7793ab574d23 100644 (file)
@@ -349,7 +349,9 @@ gst_mss_demux_expose_stream (GstMssDemux * mssdemux, GstMssDemuxStream * stream)
 
   media_caps = gst_mss_stream_get_caps (stream->manifest_stream);
   caps = gst_caps_new_simple ("video/quicktime", "variant", G_TYPE_STRING,
-      "mss-fragmented", "media-caps", GST_TYPE_CAPS, media_caps, NULL);
+      "mss-fragmented", "timescale", G_TYPE_UINT64,
+      gst_mss_stream_get_timescale (stream->manifest_stream), "media-caps",
+      GST_TYPE_CAPS, media_caps, NULL);
   gst_caps_unref (media_caps);
 
   if (caps) {
index d8923bc157fa19c940dbc392a3cec885b103c33b..8f20ab8025daf72a51afd56a414f8ddc21f2d019 100644 (file)
@@ -30,6 +30,8 @@
 
 #include "gstmssmanifest.h"
 
+#define DEFAULT_TIMESCALE             10000000
+
 #define MSS_NODE_STREAM_FRAGMENT      "c"
 #define MSS_NODE_STREAM_QUALITY       "QualityLevel"
 
@@ -37,6 +39,7 @@
 #define MSS_PROP_DURATION             "d"
 #define MSS_PROP_NUMBER               "n"
 #define MSS_PROP_TIME                 "t"
+#define MSS_PROP_TIMESCALE            "TimeScale"
 #define MSS_PROP_URL                  "Url"
 
 /* TODO check if atoi is successful? */
@@ -439,18 +442,40 @@ end:
   return caps;
 }
 
+guint64
+gst_mss_stream_get_timescale (GstMssStream * stream)
+{
+  gchar *timescale;
+  guint64 ts = DEFAULT_TIMESCALE;
+
+  timescale =
+      (gchar *) xmlGetProp (stream->xmlnode, (xmlChar *) MSS_PROP_TIMESCALE);
+  if (!timescale) {
+    timescale =
+        (gchar *) xmlGetProp (stream->xmlnode->parent,
+        (xmlChar *) MSS_PROP_TIMESCALE);
+  }
+
+  if (timescale) {
+    ts = strtoull (timescale, NULL, 10);
+    g_free (timescale);
+  }
+  return ts;
+}
+
 GstCaps *
 gst_mss_stream_get_caps (GstMssStream * stream)
 {
   GstMssStreamType streamtype = gst_mss_stream_get_type (stream);
   xmlNodePtr qualitylevel = stream->current_quality->data;
+  GstCaps *caps = NULL;
 
   if (streamtype == MSS_STREAM_TYPE_VIDEO)
-    return _gst_mss_stream_video_caps_from_qualitylevel_xml (qualitylevel);
+    caps = _gst_mss_stream_video_caps_from_qualitylevel_xml (qualitylevel);
   else if (streamtype == MSS_STREAM_TYPE_AUDIO)
-    return _gst_mss_stream_audio_caps_from_qualitylevel_xml (qualitylevel);
+    caps = _gst_mss_stream_audio_caps_from_qualitylevel_xml (qualitylevel);
 
-  return NULL;
+  return caps;
 }
 
 GstFlowReturn
index c2bf37ecd319a805e6a53034f9fe06038717b415..7b5f1f7af0d175ccce7ff7f8aa1f83f66e494301 100644 (file)
@@ -44,6 +44,7 @@ GSList * gst_mss_manifest_get_streams (GstMssManifest * manifest);
 
 GstMssStreamType gst_mss_stream_get_type (GstMssStream *stream);
 GstCaps * gst_mss_stream_get_caps (GstMssStream * stream);
+guint64 gst_mss_stream_get_timescale (GstMssStream * stream);
 GstFlowReturn gst_mss_stream_get_fragment_url (GstMssStream * stream, gchar ** url);
 GstFlowReturn gst_mss_stream_advance_fragment (GstMssStream * stream);