[gst-cvs] gst-plugins-base: rtpbasepayload: Store ptime from caps

Olivier Crête tester at kemper.freedesktop.org
Tue Jan 5 10:21:05 PST 2010


Module: gst-plugins-base
Branch: master
Commit: a4b0f2a1bd0fbea6b5ab4c6673f15fe37c824eb9
URL:    http://cgit.freedesktop.org/gstreamer/gst-plugins-base/commit/?id=a4b0f2a1bd0fbea6b5ab4c6673f15fe37c824eb9

Author: Olivier Crête <olivier.crete at collabora.co.uk>
Date:   Tue Dec 29 18:36:29 2009 -0500

rtpbasepayload: Store ptime from caps

https://bugzilla.gnome.org/show_bug.cgi?id=606050

---

 gst-libs/gst/rtp/gstbasertppayload.c |    8 ++++++--
 gst-libs/gst/rtp/gstbasertppayload.h |    7 ++++++-
 2 files changed, 12 insertions(+), 3 deletions(-)

diff --git a/gst-libs/gst/rtp/gstbasertppayload.c b/gst-libs/gst/rtp/gstbasertppayload.c
index 8b42c9e..a6d8eb3 100644
--- a/gst-libs/gst/rtp/gstbasertppayload.c
+++ b/gst-libs/gst/rtp/gstbasertppayload.c
@@ -530,6 +530,7 @@ gst_basertppayload_set_outcaps (GstBaseRTPPayload * payload, gchar * fieldname,
   }
 
   payload->priv->caps_max_ptime = DEFAULT_MAX_PTIME;
+  payload->abidata.ABI.ptime = 0;
 
   /* the peer caps can override some of the defaults */
   peercaps = gst_pad_peer_get_caps (payload->srcpad);
@@ -547,7 +548,7 @@ gst_basertppayload_set_outcaps (GstBaseRTPPayload * payload, gchar * fieldname,
     GstStructure *s, *d;
     const GValue *value;
     gint pt;
-    guint max_ptime;
+    gint max_ptime, ptime;
 
     /* peer provides caps we can use to fixate, intersect. This always returns a
      * writable caps. */
@@ -561,9 +562,12 @@ gst_basertppayload_set_outcaps (GstBaseRTPPayload * payload, gchar * fieldname,
     /* get first structure */
     s = gst_caps_get_structure (temp, 0);
 
-    if (gst_structure_get_uint (s, "maxptime", &max_ptime))
+    if (gst_structure_get_int (s, "maxptime", &max_ptime) && max_ptime > 0)
       payload->priv->caps_max_ptime = max_ptime * GST_MSECOND;
 
+    if (gst_structure_get_int (s, "ptime", &ptime) && ptime > 0)
+      payload->abidata.ABI.ptime = ptime;
+
     if (gst_structure_get_int (s, "payload", &pt)) {
       /* use peer pt */
       GST_BASE_RTP_PAYLOAD_PT (payload) = pt;
diff --git a/gst-libs/gst/rtp/gstbasertppayload.h b/gst-libs/gst/rtp/gstbasertppayload.h
index e57f74e..1591c10 100644
--- a/gst-libs/gst/rtp/gstbasertppayload.h
+++ b/gst-libs/gst/rtp/gstbasertppayload.h
@@ -111,7 +111,12 @@ struct _GstBaseRTPPayload
   /*< private >*/
   GstBaseRTPPayloadPrivate *priv;
 
-  gpointer _gst_reserved[GST_PADDING - (sizeof(guint64)/sizeof(gpointer)) - 1];
+  union  {
+    struct {
+      guint ptime; /* in ms */
+    } ABI;
+    gpointer _gst_reserved[GST_PADDING - (sizeof(guint64)/sizeof(gpointer)) - 1];
+  } abidata;
 };
 
 struct _GstBaseRTPPayloadClass





More information about the Gstreamer-commits mailing list