From: Ognyan Tonchev Date: Thu, 11 Jun 2015 15:39:00 +0000 (+0200) Subject: rtsp-media: Always use real payloader when creating streams X-Git-Tag: 1.6.0~24 X-Git-Url: http://review.tizen.org/git/?a=commitdiff_plain;h=fb71b9c4e9bb66784491df81537d4865b99480f1;p=platform%2Fupstream%2Fgst-rtsp-server.git rtsp-media: Always use real payloader when creating streams A bin that contains the real payloader might be used as payloader. In this case we have to get the real payloader for the various properties it provides. Example use cases for this are bins that payload some media and then have additional elements that add metadata or RTP extension headers to the stream. https://bugzilla.gnome.org/show_bug.cgi?id=750800 --- diff --git a/gst/rtsp-server/rtsp-media.c b/gst/rtsp-server/rtsp-media.c index d4efd5f..53b2cc4 100644 --- a/gst/rtsp-server/rtsp-media.c +++ b/gst/rtsp-server/rtsp-media.c @@ -211,6 +211,8 @@ static gboolean default_handle_sdp (GstRTSPMedia * media, GstSDPMessage * sdp); static gboolean wait_preroll (GstRTSPMedia * media); +static GstElement * find_payload_element (GstElement * payloader); + static guint gst_rtsp_media_signals[SIGNAL_LAST] = { 0 }; #define C_ENUM(v) ((gint) v) @@ -1442,12 +1444,24 @@ gst_rtsp_media_collect_streams (GstRTSPMedia * media) name = g_strdup_printf ("pay%d", i); if ((elem = gst_bin_get_by_name (GST_BIN (element), name))) { + GstElement *pay; GST_INFO ("found stream %d with payloader %p", i, elem); /* take the pad of the payloader */ pad = gst_element_get_static_pad (elem, "src"); + + /* find the real payload element in case elem is a GstBin */ + pay = find_payload_element (elem); + /* create the stream */ - gst_rtsp_media_create_stream (media, elem, pad); + if (pay == NULL) { + GST_WARNING ("could not find real payloader, using bin"); + gst_rtsp_media_create_stream (media, elem, pad); + } else { + gst_rtsp_media_create_stream (media, pay, pad); + gst_object_unref (pay); + } + gst_object_unref (pad); gst_object_unref (elem);