media: cleanup media transport before freeing

Cleanup the media transport data before freeing. In particular, remove the qdata
from the rtpsource object.
This commit is contained in:
Wim Taymans 2010-08-24 16:47:30 +02:00
parent dc33070da3
commit 450b68252f
3 changed files with 18 additions and 2 deletions

View file

@ -171,6 +171,19 @@ free_destination (RTSPDestination *dest)
g_slice_free (RTSPDestination, dest); g_slice_free (RTSPDestination, dest);
} }
void
gst_rtsp_media_trans_cleanup (GstRTSPMediaTrans *trans)
{
if (trans->transport) {
gst_rtsp_transport_free (trans->transport);
trans->transport = NULL;
}
if (trans->rtpsource) {
g_object_set_qdata (trans->rtpsource, ssrc_stream_map_key, NULL);
trans->rtpsource = NULL;
}
}
static void static void
gst_rtsp_media_stream_free (GstRTSPMediaStream * stream) gst_rtsp_media_stream_free (GstRTSPMediaStream * stream)
{ {
@ -855,6 +868,7 @@ cleanup:
} }
} }
/* executed from streaming thread */
static void static void
caps_notify (GstPad * pad, GParamSpec * unused, GstRTSPMediaStream * stream) caps_notify (GstPad * pad, GParamSpec * unused, GstRTSPMediaStream * stream)
{ {
@ -1408,6 +1422,7 @@ bus_message (GstBus * bus, GstMessage * message, GstRTSPMedia * media)
return ret; return ret;
} }
/* called from streaming threads */
static void static void
pad_added_cb (GstElement * element, GstPad * pad, GstRTSPMedia * media) pad_added_cb (GstElement * element, GstPad * pad, GstRTSPMedia * media)
{ {

View file

@ -288,6 +288,8 @@ gboolean gst_rtsp_media_set_state (GstRTSPMedia *media, GstS
void gst_rtsp_media_remove_elements (GstRTSPMedia *media); void gst_rtsp_media_remove_elements (GstRTSPMedia *media);
void gst_rtsp_media_trans_cleanup (GstRTSPMediaTrans *trans);
G_END_DECLS G_END_DECLS
#endif /* __GST_RTSP_MEDIA_H__ */ #endif /* __GST_RTSP_MEDIA_H__ */

View file

@ -82,8 +82,7 @@ gst_rtsp_session_free_stream (GstRTSPSessionStream * stream)
gst_rtsp_session_stream_set_callbacks (stream, NULL, NULL, NULL, NULL); gst_rtsp_session_stream_set_callbacks (stream, NULL, NULL, NULL, NULL);
gst_rtsp_session_stream_set_keepalive (stream, NULL, NULL, NULL); gst_rtsp_session_stream_set_keepalive (stream, NULL, NULL, NULL);
if (stream->trans.transport) gst_rtsp_media_trans_cleanup (&stream->trans);
gst_rtsp_transport_free (stream->trans.transport);
g_free (stream); g_free (stream);
} }