[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