diff options
author | Wim Taymans <wim.taymans@gmail.com> | 2007-09-12 18:04:32 +0000 |
---|---|---|
committer | Wim Taymans <wim.taymans@gmail.com> | 2007-09-12 18:04:32 +0000 |
commit | 79800df8b6335e435e7e98c92784cdfe5f10d3c5 (patch) | |
tree | 739f0d57986b8a66ae01ce17948c9830860adb3d /gst/rtpmanager/gstrtpbin.c | |
parent | a698a439beb8a06dace3b5558b921ba2549699a1 (diff) | |
download | gst-plugins-bad-79800df8b6335e435e7e98c92784cdfe5f10d3c5.tar.gz gst-plugins-bad-79800df8b6335e435e7e98c92784cdfe5f10d3c5.tar.bz2 gst-plugins-bad-79800df8b6335e435e7e98c92784cdfe5f10d3c5.zip |
gst/rtpmanager/gstrtpbin.c: Calculate and configure the NTP base time so that we can generate better
Original commit message from CVS:
* gst/rtpmanager/gstrtpbin.c: (calc_ntp_ns_base),
(gst_rtp_bin_change_state), (new_payload_found), (create_send_rtp):
Calculate and configure the NTP base time so that we can generate better
NTP times in SR packets.
Set caps on new ghostpad.
* gst/rtpmanager/gstrtpjitterbuffer.c:
(gst_rtp_jitter_buffer_loop):
Clean debug statement.
* gst/rtpmanager/gstrtpsession.c: (gst_rtp_session_class_init),
(gst_rtp_session_init), (gst_rtp_session_set_property),
(gst_rtp_session_get_property), (get_current_ntp_ns_time),
(rtcp_thread), (gst_rtp_session_event_recv_rtp_sink),
(gst_rtp_session_internal_links), (gst_rtp_session_chain_recv_rtp),
(gst_rtp_session_event_send_rtp_sink),
(gst_rtp_session_chain_send_rtp), (create_recv_rtp_sink),
(create_send_rtp_sink):
* gst/rtpmanager/gstrtpsession.h:
Add ntp-ns-base property to convert running_time to NTP time.
Handle NEWSEGMENT events on send and recv RTP pads so that we can
calculate the running time and thus NTP time of the packets.
Simplify getting the current NTP time using the pipeline clock.
Implement internal links functions.
Use the buffer timestamp to calculate the NTP time instead of the clock.
* gst/rtpmanager/gstrtpssrcdemux.c: (create_demux_pad_for_ssrc),
(gst_rtp_ssrc_demux_init), (gst_rtp_ssrc_demux_sink_event),
(gst_rtp_ssrc_demux_chain), (gst_rtp_ssrc_demux_rtcp_chain),
(gst_rtp_ssrc_demux_internal_links),
(gst_rtp_ssrc_demux_src_query):
* gst/rtpmanager/gstrtpssrcdemux.h:
Implement internal links function.
Calculate the diff between different streams, this might be used later
to get the inter stream latency.
* gst/rtpmanager/rtpsession.c: (rtp_session_send_rtp):
Simple cleanup.
* gst/rtpmanager/rtpsource.c: (rtp_source_init),
(calculate_jitter), (rtp_source_send_rtp), (rtp_source_get_new_sr):
Make the clock skew window a little bigger.
Apply the clock skew to all buffers, not just one with a new timestamp.
Calculate and debug sender clock drift.
Use extended last timestamp to interpollate for SR reports.
Diffstat (limited to 'gst/rtpmanager/gstrtpbin.c')
-rw-r--r-- | gst/rtpmanager/gstrtpbin.c | 31 |
1 files changed, 28 insertions, 3 deletions
diff --git a/gst/rtpmanager/gstrtpbin.c b/gst/rtpmanager/gstrtpbin.c index a4ba67c3..7d5fb5d1 100644 --- a/gst/rtpmanager/gstrtpbin.c +++ b/gst/rtpmanager/gstrtpbin.c @@ -208,6 +208,8 @@ GST_STATIC_PAD_TEMPLATE ("sink_%d", struct _GstRtpBinPrivate { GMutex *bin_lock; + + GstClockTime ntp_ns_base; }; /* signals and args */ @@ -1142,6 +1144,30 @@ gst_rtp_bin_provide_clock (GstElement * element) return GST_CLOCK_CAST (gst_object_ref (rtpbin->provided_clock)); } +static void +calc_ntp_ns_base (GstRtpBin * bin) +{ + GstClockTime now; + GTimeVal current; + GSList *walk; + + /* get the current time and convert it to NTP time in nanoseconds */ + g_get_current_time (¤t); + now = GST_TIMEVAL_TO_TIME (current); + now += (2208988800LL * GST_SECOND); + + GST_RTP_BIN_LOCK (bin); + bin->priv->ntp_ns_base = now; + for (walk = bin->sessions; walk; walk = g_slist_next (walk)) { + GstRtpBinSession *session = (GstRtpBinSession *) walk->data; + + g_object_set (session->session, "ntp-ns-base", now, NULL); + } + GST_RTP_BIN_UNLOCK (bin); + + return; +} + static GstStateChangeReturn gst_rtp_bin_change_state (GstElement * element, GstStateChange transition) { @@ -1156,6 +1182,7 @@ gst_rtp_bin_change_state (GstElement * element, GstStateChange transition) case GST_STATE_CHANGE_READY_TO_PAUSED: break; case GST_STATE_CHANGE_PAUSED_TO_PLAYING: + calc_ntp_ns_base (rtpbin); break; default: break; @@ -1199,6 +1226,7 @@ new_payload_found (GstElement * element, guint pt, GstPad * pad, gpad = gst_ghost_pad_new_from_template (padname, pad, templ); g_free (padname); + gst_pad_set_caps (gpad, GST_PAD_CAPS (pad)); gst_pad_set_active (gpad, TRUE); gst_element_add_pad (GST_ELEMENT_CAST (rtpbin), gpad); } @@ -1553,9 +1581,6 @@ create_send_rtp (GstRtpBin * rtpbin, GstPadTemplate * templ, const gchar * name) if (session->send_rtp_sink == NULL) goto pad_failed; - g_signal_connect (session->send_rtp_sink, "notify::caps", - (GCallback) caps_changed, session); - result = gst_ghost_pad_new_from_template (name, session->send_rtp_sink, templ); gst_pad_set_active (result, TRUE); |