mirror of
https://gitlab.freedesktop.org/gstreamer/gstreamer.git
synced 2025-02-03 13:02:29 +00:00
rtpmux: Free the pad private data on pad release
Free the pad private data on pad release instead of using a weak ref, which is not thread safe. Also, lock the content of the pad private using the element's object lock.
This commit is contained in:
parent
4be63c9add
commit
5e90a4e86b
1 changed files with 50 additions and 18 deletions
|
@ -87,6 +87,7 @@ static void gst_rtp_mux_finalize (GObject * object);
|
||||||
|
|
||||||
static GstPad *gst_rtp_mux_request_new_pad (GstElement * element,
|
static GstPad *gst_rtp_mux_request_new_pad (GstElement * element,
|
||||||
GstPadTemplate * templ, const gchar * name);
|
GstPadTemplate * templ, const gchar * name);
|
||||||
|
static void gst_rtp_mux_release_pad (GstElement * element, GstPad * pad);
|
||||||
static GstFlowReturn gst_rtp_mux_chain (GstPad * pad, GstBuffer * buffer);
|
static GstFlowReturn gst_rtp_mux_chain (GstPad * pad, GstBuffer * buffer);
|
||||||
static gboolean gst_rtp_mux_setcaps (GstPad * pad, GstCaps * caps);
|
static gboolean gst_rtp_mux_setcaps (GstPad * pad, GstCaps * caps);
|
||||||
static GstCaps *gst_rtp_mux_getcaps (GstPad * pad);
|
static GstCaps *gst_rtp_mux_getcaps (GstPad * pad);
|
||||||
|
@ -148,6 +149,7 @@ gst_rtp_mux_class_init (GstRTPMuxClass * klass)
|
||||||
|
|
||||||
gstelement_class->request_new_pad =
|
gstelement_class->request_new_pad =
|
||||||
GST_DEBUG_FUNCPTR (gst_rtp_mux_request_new_pad);
|
GST_DEBUG_FUNCPTR (gst_rtp_mux_request_new_pad);
|
||||||
|
gstelement_class->release_pad = GST_DEBUG_FUNCPTR (gst_rtp_mux_release_pad);
|
||||||
gstelement_class->change_state = GST_DEBUG_FUNCPTR (gst_rtp_mux_change_state);
|
gstelement_class->change_state = GST_DEBUG_FUNCPTR (gst_rtp_mux_change_state);
|
||||||
|
|
||||||
klass->chain_func = gst_rtp_mux_chain;
|
klass->chain_func = gst_rtp_mux_chain;
|
||||||
|
@ -245,15 +247,6 @@ gst_rtp_mux_create_sinkpad (GstRTPMux * rtp_mux, GstPadTemplate * templ)
|
||||||
return newpad;
|
return newpad;
|
||||||
}
|
}
|
||||||
|
|
||||||
static void
|
|
||||||
free_pad_private (gpointer data, GObject * where_the_object_was)
|
|
||||||
{
|
|
||||||
GstRTPMuxPadPrivate *padpriv = data;
|
|
||||||
|
|
||||||
gst_caps_replace (&padpriv->out_caps, NULL);
|
|
||||||
g_slice_free (GstRTPMuxPadPrivate, padpriv);
|
|
||||||
}
|
|
||||||
|
|
||||||
static void
|
static void
|
||||||
gst_rtp_mux_setup_sinkpad (GstRTPMux * rtp_mux, GstPad * sinkpad)
|
gst_rtp_mux_setup_sinkpad (GstRTPMux * rtp_mux, GstPad * sinkpad)
|
||||||
{
|
{
|
||||||
|
@ -274,7 +267,6 @@ gst_rtp_mux_setup_sinkpad (GstRTPMux * rtp_mux, GstPad * sinkpad)
|
||||||
gst_pad_set_active (sinkpad, TRUE);
|
gst_pad_set_active (sinkpad, TRUE);
|
||||||
|
|
||||||
gst_pad_set_element_private (sinkpad, padpriv);
|
gst_pad_set_element_private (sinkpad, padpriv);
|
||||||
g_object_weak_ref (G_OBJECT (sinkpad), free_pad_private, padpriv);
|
|
||||||
|
|
||||||
/* dd the pad to the element */
|
/* dd the pad to the element */
|
||||||
gst_element_add_pad (GST_ELEMENT (rtp_mux), sinkpad);
|
gst_element_add_pad (GST_ELEMENT (rtp_mux), sinkpad);
|
||||||
|
@ -306,6 +298,24 @@ gst_rtp_mux_request_new_pad (GstElement * element,
|
||||||
return newpad;
|
return newpad;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static void
|
||||||
|
gst_rtp_mux_release_pad (GstElement * element, GstPad * pad)
|
||||||
|
{
|
||||||
|
GstRTPMuxPadPrivate *padpriv;
|
||||||
|
|
||||||
|
GST_OBJECT_LOCK (element);
|
||||||
|
padpriv = gst_pad_get_element_private (pad);
|
||||||
|
gst_pad_set_element_private (pad, NULL);
|
||||||
|
GST_OBJECT_UNLOCK (element);
|
||||||
|
|
||||||
|
gst_element_remove_pad (element, pad);
|
||||||
|
|
||||||
|
if (padpriv) {
|
||||||
|
gst_caps_replace (&padpriv->out_caps, NULL);
|
||||||
|
g_slice_free (GstRTPMuxPadPrivate, padpriv);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
/* Put our own clock-base on the buffer */
|
/* Put our own clock-base on the buffer */
|
||||||
static void
|
static void
|
||||||
gst_rtp_mux_readjust_rtp_timestamp (GstRTPMux * rtp_mux, GstPad * pad,
|
gst_rtp_mux_readjust_rtp_timestamp (GstRTPMux * rtp_mux, GstPad * pad,
|
||||||
|
@ -313,10 +323,14 @@ gst_rtp_mux_readjust_rtp_timestamp (GstRTPMux * rtp_mux, GstPad * pad,
|
||||||
{
|
{
|
||||||
guint32 ts;
|
guint32 ts;
|
||||||
guint32 sink_ts_base = 0;
|
guint32 sink_ts_base = 0;
|
||||||
GstRTPMuxPadPrivate *padpriv = gst_pad_get_element_private (pad);
|
GstRTPMuxPadPrivate *padpriv;
|
||||||
|
|
||||||
if (padpriv->have_clock_base)
|
|
||||||
|
GST_OBJECT_LOCK (rtp_mux);
|
||||||
|
padpriv = gst_pad_get_element_private (pad);
|
||||||
|
if (padpriv && padpriv->have_clock_base)
|
||||||
sink_ts_base = padpriv->clock_base;
|
sink_ts_base = padpriv->clock_base;
|
||||||
|
GST_OBJECT_UNLOCK (rtp_mux);
|
||||||
|
|
||||||
ts = gst_rtp_buffer_get_timestamp (buffer) - sink_ts_base + rtp_mux->ts_base;
|
ts = gst_rtp_buffer_get_timestamp (buffer) - sink_ts_base + rtp_mux->ts_base;
|
||||||
GST_LOG_OBJECT (rtp_mux, "Re-adjusting RTP ts %u to %u",
|
GST_LOG_OBJECT (rtp_mux, "Re-adjusting RTP ts %u to %u",
|
||||||
|
@ -329,7 +343,7 @@ gst_rtp_mux_chain (GstPad * pad, GstBuffer * buffer)
|
||||||
{
|
{
|
||||||
GstRTPMux *rtp_mux;
|
GstRTPMux *rtp_mux;
|
||||||
GstFlowReturn ret;
|
GstFlowReturn ret;
|
||||||
GstRTPMuxPadPrivate *padpriv = gst_pad_get_element_private (pad);
|
GstRTPMuxPadPrivate *padpriv;
|
||||||
|
|
||||||
rtp_mux = GST_RTP_MUX (gst_pad_get_parent (pad));
|
rtp_mux = GST_RTP_MUX (gst_pad_get_parent (pad));
|
||||||
|
|
||||||
|
@ -344,6 +358,9 @@ gst_rtp_mux_chain (GstPad * pad, GstBuffer * buffer)
|
||||||
GST_OBJECT_LOCK (rtp_mux);
|
GST_OBJECT_LOCK (rtp_mux);
|
||||||
rtp_mux->seqnum++;
|
rtp_mux->seqnum++;
|
||||||
gst_rtp_buffer_set_seq (buffer, rtp_mux->seqnum);
|
gst_rtp_buffer_set_seq (buffer, rtp_mux->seqnum);
|
||||||
|
padpriv = gst_pad_get_element_private (pad);
|
||||||
|
if (padpriv)
|
||||||
|
gst_buffer_set_caps (buffer, padpriv->out_caps);
|
||||||
GST_OBJECT_UNLOCK (rtp_mux);
|
GST_OBJECT_UNLOCK (rtp_mux);
|
||||||
gst_rtp_buffer_set_ssrc (buffer, rtp_mux->current_ssrc);
|
gst_rtp_buffer_set_ssrc (buffer, rtp_mux->current_ssrc);
|
||||||
gst_rtp_mux_readjust_rtp_timestamp (rtp_mux, pad, buffer);
|
gst_rtp_mux_readjust_rtp_timestamp (rtp_mux, pad, buffer);
|
||||||
|
@ -351,10 +368,16 @@ gst_rtp_mux_chain (GstPad * pad, GstBuffer * buffer)
|
||||||
GST_BUFFER_SIZE (buffer), rtp_mux->seqnum,
|
GST_BUFFER_SIZE (buffer), rtp_mux->seqnum,
|
||||||
gst_rtp_buffer_get_timestamp (buffer));
|
gst_rtp_buffer_get_timestamp (buffer));
|
||||||
|
|
||||||
gst_buffer_set_caps (buffer, padpriv->out_caps);
|
if (!padpriv) {
|
||||||
|
ret = GST_FLOW_NOT_LINKED;
|
||||||
|
gst_buffer_unref (buffer);
|
||||||
|
goto out;
|
||||||
|
}
|
||||||
|
|
||||||
ret = gst_pad_push (rtp_mux->srcpad, buffer);
|
ret = gst_pad_push (rtp_mux->srcpad, buffer);
|
||||||
|
|
||||||
|
out:
|
||||||
|
|
||||||
gst_object_unref (rtp_mux);
|
gst_object_unref (rtp_mux);
|
||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
@ -365,7 +388,7 @@ gst_rtp_mux_setcaps (GstPad * pad, GstCaps * caps)
|
||||||
GstRTPMux *rtp_mux;
|
GstRTPMux *rtp_mux;
|
||||||
GstStructure *structure;
|
GstStructure *structure;
|
||||||
gboolean ret = FALSE;
|
gboolean ret = FALSE;
|
||||||
GstRTPMuxPadPrivate *padpriv = gst_pad_get_element_private (pad);
|
GstRTPMuxPadPrivate *padpriv;
|
||||||
|
|
||||||
rtp_mux = GST_RTP_MUX (gst_pad_get_parent (pad));
|
rtp_mux = GST_RTP_MUX (gst_pad_get_parent (pad));
|
||||||
|
|
||||||
|
@ -374,9 +397,13 @@ gst_rtp_mux_setcaps (GstPad * pad, GstCaps * caps)
|
||||||
if (!structure)
|
if (!structure)
|
||||||
goto out;
|
goto out;
|
||||||
|
|
||||||
if (gst_structure_get_uint (structure, "clock-base", &padpriv->clock_base)) {
|
GST_OBJECT_LOCK (rtp_mux);
|
||||||
|
padpriv = gst_pad_get_element_private (pad);
|
||||||
|
if (padpriv &&
|
||||||
|
gst_structure_get_uint (structure, "clock-base", &padpriv->clock_base)) {
|
||||||
padpriv->have_clock_base = TRUE;
|
padpriv->have_clock_base = TRUE;
|
||||||
}
|
}
|
||||||
|
GST_OBJECT_UNLOCK (rtp_mux);
|
||||||
|
|
||||||
caps = gst_caps_copy (caps);
|
caps = gst_caps_copy (caps);
|
||||||
|
|
||||||
|
@ -388,8 +415,13 @@ gst_rtp_mux_setcaps (GstPad * pad, GstCaps * caps)
|
||||||
"setting caps %" GST_PTR_FORMAT " on src pad..", caps);
|
"setting caps %" GST_PTR_FORMAT " on src pad..", caps);
|
||||||
ret = gst_pad_set_caps (rtp_mux->srcpad, caps);
|
ret = gst_pad_set_caps (rtp_mux->srcpad, caps);
|
||||||
|
|
||||||
if (ret)
|
if (ret) {
|
||||||
gst_caps_replace (&padpriv->out_caps, caps);
|
GST_OBJECT_LOCK (rtp_mux);
|
||||||
|
padpriv = gst_pad_get_element_private (pad);
|
||||||
|
if (padpriv)
|
||||||
|
gst_caps_replace (&padpriv->out_caps, caps);
|
||||||
|
GST_OBJECT_UNLOCK (rtp_mux);
|
||||||
|
}
|
||||||
gst_caps_unref (caps);
|
gst_caps_unref (caps);
|
||||||
|
|
||||||
out:
|
out:
|
||||||
|
|
Loading…
Reference in a new issue