Login  Register

gst_element_get_request_pad usage question

classic Classic list List threaded Threaded
2 messages Options Options
Embed post
Permalink
Reply | Threaded
Open this post in threaded view
| More
Print post
Permalink

gst_element_get_request_pad usage question

William Salibrici
46 posts

Hello,

The GStreamer Application Development Manual (1.8.3) page 32 shows a simple usage example for gst_element_get_request_pad. The example uses gst_object_unref (GST_OBJECT (pad)) when you are finished with the pad object. I found the same kind of usage in some of your test examples. I have also used it this way in my application C code and it appears to work ok.

However, I noticed that your core reference [direct from your documentation website] for GstElement, gst_element_get_request_pad, states that ‘The pad should be released with gst_element_release_request_pad().’ It doesn’t say anything about using gst_object_unref.

So my question is which one is correct – the manual or your core reference, or maybe both somehow? Will I end up with resource leaks if I don’t exactly follow the core reference?

Thank you for your clarification on this.

Regards,

Bill

 


_______________________________________________
gstreamer-devel mailing list
[hidden email]
https://lists.freedesktop.org/mailman/listinfo/gstreamer-devel
Reply | Threaded
Open this post in threaded view
| More
Print post
Permalink

Re: gst_element_get_request_pad usage question

Sebastian Dröge-3
2904 posts
On Mon, 2016-10-03 at 21:28 +0000, William Salibrici wrote:

> Hello,
>
> The GStreamer Application Development Manual (1.8.3) page 32 shows a
> simple usage example for gst_element_get_request_pad. The example
> uses gst_object_unref (GST_OBJECT (pad)) when you are finished with
> the pad object. I found the same kind of usage in some of your test
> examples. I have also used it this way in my application C code and
> it appears to work ok.
>
> However, I noticed that your core reference [direct from your
> documentation website] for GstElement, gst_element_get_request_pad,
> states that ‘The pad should be released with
> gst_element_release_request_pad().’ It doesn’t say anything about
> using gst_object_unref.
>
> So my question is which one is correct – the manual or your core
> reference, or maybe both somehow? Will I end up with resource leaks
> if I don’t exactly follow the core reference?
There are two parts to this.

First of all, pads like all GObjects are reference counted and you have
to handle this correctly with the right amount of g_object_ref() and
g_object_unref() calls in the right places. Details depend on your code
and what exactly you call, see the documentation and what it says about
ownership transfer in the function documentation.


Then for request pads there's another aspect. If you request a pad from
an element, the element will give you a reference to a new pad but it
will also internally keep another reference of the pad (in the end, it
would be useless if only your code had a reference to the pad, what/how
would the element be supposed to do something with it?).
So you unref your reference when you don't need it anymore, but you
also should release the pad from the element when the element should
not have the pad at all anymore.
When the element is destroyed, it will automatically remove all
remaining pads from itself though.

--
Sebastian Dröge, Centricular Ltd · http://www.centricular.com
_______________________________________________
gstreamer-devel mailing list
[hidden email]
https://lists.freedesktop.org/mailman/listinfo/gstreamer-devel

signature.asc (949 bytes) Download Attachment