mirror of
https://gitlab.freedesktop.org/gstreamer/gstreamer.git
synced 2025-01-25 16:48:11 +00:00
gst/gstpad.c: Don't leak buffers, caps and pads on negotiation errors.
Original commit message from CVS: * gst/gstpad.c: (gst_pad_accept_caps), (gst_pad_alloc_buffer_full), (gst_pad_push): Don't leak buffers, caps and pads on negotiation errors.
This commit is contained in:
parent
0dbc4f8321
commit
c815b879fe
2 changed files with 15 additions and 2 deletions
|
@ -1,3 +1,9 @@
|
||||||
|
2006-03-17 Wim Taymans <wim@fluendo.com>
|
||||||
|
|
||||||
|
* gst/gstpad.c: (gst_pad_accept_caps), (gst_pad_alloc_buffer_full),
|
||||||
|
(gst_pad_push):
|
||||||
|
Don't leak buffers, caps and pads on negotiation errors.
|
||||||
|
|
||||||
2006-03-16 Stefan Kost <ensonic@users.sf.net>
|
2006-03-16 Stefan Kost <ensonic@users.sf.net>
|
||||||
|
|
||||||
* docs/faq/cvs.xml:
|
* docs/faq/cvs.xml:
|
||||||
|
|
11
gst/gstpad.c
11
gst/gstpad.c
|
@ -2113,8 +2113,11 @@ gst_pad_accept_caps (GstPad * pad, GstCaps * caps)
|
||||||
GST_OBJECT_UNLOCK (pad);
|
GST_OBJECT_UNLOCK (pad);
|
||||||
|
|
||||||
/* The current caps on a pad are trivially acceptable */
|
/* The current caps on a pad are trivially acceptable */
|
||||||
if (existing && (caps == existing || gst_caps_is_equal (caps, existing)))
|
if (existing) {
|
||||||
goto is_same_caps;
|
if (caps == existing || gst_caps_is_equal (caps, existing))
|
||||||
|
goto is_same_caps;
|
||||||
|
gst_caps_unref (existing);
|
||||||
|
}
|
||||||
|
|
||||||
if (G_LIKELY (acceptfunc)) {
|
if (G_LIKELY (acceptfunc)) {
|
||||||
/* we can call the function */
|
/* we can call the function */
|
||||||
|
@ -2582,6 +2585,8 @@ fallback:
|
||||||
}
|
}
|
||||||
not_negotiated:
|
not_negotiated:
|
||||||
{
|
{
|
||||||
|
gst_buffer_unref (*buf);
|
||||||
|
*buf = NULL;
|
||||||
GST_CAT_LOG_OBJECT (GST_CAT_SCHEDULING, pad,
|
GST_CAT_LOG_OBJECT (GST_CAT_SCHEDULING, pad,
|
||||||
"alloc function returned unacceptable buffer");
|
"alloc function returned unacceptable buffer");
|
||||||
return GST_FLOW_NOT_NEGOTIATED;
|
return GST_FLOW_NOT_NEGOTIATED;
|
||||||
|
@ -3351,6 +3356,8 @@ not_linked:
|
||||||
}
|
}
|
||||||
not_negotiated:
|
not_negotiated:
|
||||||
{
|
{
|
||||||
|
gst_buffer_unref (buffer);
|
||||||
|
gst_object_unref (peer);
|
||||||
GST_CAT_DEBUG_OBJECT (GST_CAT_SCHEDULING, pad,
|
GST_CAT_DEBUG_OBJECT (GST_CAT_SCHEDULING, pad,
|
||||||
"element pushed buffer then refused to accept the caps");
|
"element pushed buffer then refused to accept the caps");
|
||||||
return GST_FLOW_NOT_NEGOTIATED;
|
return GST_FLOW_NOT_NEGOTIATED;
|
||||||
|
|
Loading…
Reference in a new issue