gstrtpsession: send custom upstream event "GstRTPCollision" on send_rtp_sink pad
authorJulien Isorce <julien.isorce@collabora.co.uk>
Fri, 1 Nov 2013 17:04:28 +0000 (17:04 +0000)
committerWim Taymans <wim.taymans@gmail.com>
Mon, 11 Nov 2013 14:25:52 +0000 (15:25 +0100)
See https://bugzilla.gnome.org/show_bug.cgi?id=711560

gst/rtpmanager/gstrtpsession.c

index 6ff65eb..4a33f69 100644 (file)
@@ -318,6 +318,7 @@ static void
 on_ssrc_collision (RTPSession * session, RTPSource * src, GstRtpSession * sess)
 {
   GstPad *recv_rtp_sink;
+  GstPad *send_rtp_sink;
 
   g_signal_emit (sess, gst_rtp_session_signals[SIGNAL_ON_SSRC_COLLISION], 0,
       src->ssrc);
@@ -325,12 +326,22 @@ on_ssrc_collision (RTPSession * session, RTPSource * src, GstRtpSession * sess)
   GST_RTP_SESSION_LOCK (sess);
   if ((recv_rtp_sink = sess->recv_rtp_sink))
     gst_object_ref (recv_rtp_sink);
+  if ((send_rtp_sink = sess->send_rtp_sink))
+    gst_object_ref (send_rtp_sink);
   GST_RTP_SESSION_UNLOCK (sess);
 
   if (recv_rtp_sink) {
     gst_pad_push_event (recv_rtp_sink, gst_event_new_reconfigure ());
     gst_object_unref (recv_rtp_sink);
   }
+
+  if (send_rtp_sink) {
+    GstEvent *event = gst_event_new_custom (GST_EVENT_CUSTOM_UPSTREAM,
+        gst_structure_new ("GstRTPCollision", "ssrc", G_TYPE_UINT,
+            (guint) src->ssrc, NULL));
+    gst_pad_push_event (send_rtp_sink, event);
+    gst_object_unref (send_rtp_sink);
+  }
 }
 
 static void