Hi,
I am currently trying to understand some internals of GStreamer. Assume I am using the following pipeline (executed via gst-launch-1.0, 1.11.91): gst-launch-1.0 videotestsrc num-buffers=100 ! xxx ! fakesink silent=false -v Videotestsrc is generating buffers, xxx (not relevant what it is, e.g. openh264enc) is forwarding buffers and fakesink is consuming the buffers. Looking into latest source code, function gst_fake_sink_render, I can't find where the buffers/memory is released. Is it done somewhere outside the fakesink source code? Where do I find this place, where fakesink render function is called and buffer/memory is released afterwards? (don't know if relevant: I have internal leak checking on and use also some GST_DEBUG options) Is there some documentation which explains such deep internals of Gstreamer? Many thanks! Best regards, Martin _______________________________________________ gstreamer-devel mailing list [hidden email] https://lists.freedesktop.org/mailman/listinfo/gstreamer-devel |
On Tue, 2017-05-02 at 23:59 +0200, Martin Maurer wrote:
Hi Martin, > gst-launch-1.0 videotestsrc num-buffers=100 ! xxx ! fakesink > silent=false -v > > Videotestsrc is generating buffers, xxx (not relevant what it is, > e.g. > openh264enc) is forwarding buffers > and fakesink is consuming the buffers. > Looking into latest source code, function gst_fake_sink_render, I > can't find where the buffers/memory is released. > Is it done somewhere outside the fakesink source code? > Where do I find this place, where fakesink render function is called > and buffer/memory is released afterwards? > (don't know if relevant: I have internal leak checking on and use > also some GST_DEBUG options) > Is there some documentation which explains such deep internals of > Gstreamer? The fakesink element takes ownership of the buffer pushed onto its sinkpad (like all elements), and the GstBaseSink class will take care of calling the fakesink element's render function and then later of releasing the buffer. The "enable-last-sample" property defaults to true, so basesink will hold onto the last buffer until the next buffer comes in, unless this is disabled. Cheers -Tim -- Tim Müller, Centricular Ltd - http://www.centricular.com _______________________________________________ gstreamer-devel mailing list [hidden email] https://lists.freedesktop.org/mailman/listinfo/gstreamer-devel |
Hello Tim many thanks for your helpful answer. I was able to continue my analysis. I have a leak in proprietary code, which I try to solve. It is leaking GstBuffers, GstMemory and a lot more. Here is an output (filtered by "2DE02E0" which is reported by leak tracer at end of
log):
Line 4879: 0:00:00.801076398 9452 0000000002C78F00 LOG GST_BUFFER gstbuffer.c:799:gst_buffer_new: new 0000000002DE02E0 Line 4880: 0:00:00.801194912 9452 0000000002C78F00 LOG GST_BUFFER gstbuffer.c:414:_memory_add: buffer 0000000002DE02E0, idx -1, mem 000000000DE70040 Line 4881: 0:00:00.801313790 9452 0000000002C78F00 LOG GST_BUFFER gstbuffer.c:855:gst_buffer_new_allocate: new buffer 0000000002DE02E0 of size 3156480 from allocator 0000000000000000 Line 4884: 0:00:00.801730595 9452 0000000002C78F00 LOG GST_BUFFER gstbuffer.c:1721:gst_buffer_map_range: buffer 0000000002DE02E0, idx 0, length 1, flags 0002 Line 4885: 0:00:00.801849473 9452 0000000002C78F00 LOG GST_BUFFER gstbuffer.c:213:_get_merged_memory: buffer 0000000002DE02E0, idx 0, length 1 Line 4887: 0:00:00.802088324 9452 0000000002C78F00 LOG GST_BUFFER gstbuffer.c:1721:gst_buffer_map_range: buffer 0000000002DE02E0, idx 0, length 1, flags 0002 Line 4888: 0:00:00.802232364 9452 0000000002C78F00 LOG GST_BUFFER gstbuffer.c:213:_get_merged_memory: buffer 0000000002DE02E0, idx 0, length 1 Line 4890: 0:00:00.802511693 9452 0000000002C78F00 TRACE GST_REFCOUNTING gstminiobject.c:351:gst_mini_object_ref: 0000000002DE02E0 ref 1->2 Line 4908: 0:00:00.806898166 9452 0000000002C78F00 TRACE GST_REFCOUNTING gstminiobject.c:431:gst_mini_object_unref: 0000000002DE02E0 unref 2->1 Line 4924: 0:00:00.811793338 9452 0000000002C78F00 LOG GST_BUFFER gstbuffer.c:1721:gst_buffer_map_range: buffer 0000000002DE02E0, idx 0, length 1, flags 0001 Line 4925: 0:00:00.812246973 9452 0000000002C78F00 LOG GST_BUFFER gstbuffer.c:213:_get_merged_memory: buffer 0000000002DE02E0, idx 0, length 1 Line 4927: 0:00:00.813025153 9452 0000000002C78F00 LOG GST_BUFFER gstbuffer.c:1721:gst_buffer_map_range: buffer 0000000002DE02E0, idx 0, length 1, flags 0001 Line 4928: 0:00:00.813394187 9452 0000000002C78F00 LOG GST_BUFFER gstbuffer.c:213:_get_merged_memory: buffer 0000000002DE02E0, idx 0, length 1 Line 4930: 0:00:00.814017753 9452 0000000002C78F00 TRACE GST_REFCOUNTING gstminiobject.c:351:gst_mini_object_ref: 0000000002DE02E0 ref 1->2 Line 4934: 0:00:00.817231850 9452 0000000002C78F00 TRACE GST_REFCOUNTING gstminiobject.c:431:gst_mini_object_unref: 0000000002DE02E0 unref 2->1 Line 21073: 0:00:04.460508975 9452 000000000032B030 TRACE GST_TRACER :0:: object-alive, type-name=(string)GstBuffer, address=(gpointer)0000000002DE02E0, description=(string)buffer: 0000000002DE02E0, pts 0:00:00.016666666, dts 99:99:99.999999999, dur 0:00:00.016666667, size 3156480, offset 1, offset_end 2, flags 0x0, ref-count=(uint)1, trace=(string); Inside GstBuffer there seems to be a GstMemory. So here is an output (filtered by "DE70040" which is also reported by leak tracer at end of log and added to the above GstBuffer, see first line): Line 4880: 0:00:00.801194912 9452 0000000002C78F00 LOG GST_BUFFER gstbuffer.c:414:_memory_add: buffer 0000000002DE02E0, idx -1, mem 000000000DE70040 Line 4886: 0:00:00.801968352 9452 0000000002C78F00 TRACE GST_REFCOUNTING gstminiobject.c:351:gst_mini_object_ref: 000000000DE70040 ref 1->2 Line 4889: 0:00:00.802365100 9452 0000000002C78F00 TRACE GST_REFCOUNTING gstminiobject.c:351:gst_mini_object_ref: 000000000DE70040 ref 2->3 Line 4906: 0:00:00.806293198 9452 0000000002C78F00 TRACE GST_REFCOUNTING gstminiobject.c:431:gst_mini_object_unref: 000000000DE70040 unref 3->2 Line 4907: 0:00:00.806549918 9452 0000000002C78F00 TRACE GST_REFCOUNTING gstminiobject.c:431:gst_mini_object_unref: 000000000DE70040 unref 2->1 Line 4926: 0:00:00.812676540 9452 0000000002C78F00 TRACE GST_REFCOUNTING gstminiobject.c:351:gst_mini_object_ref: 000000000DE70040 ref 1->2 Line 4929: 0:00:00.813721286 9452 0000000002C78F00 TRACE GST_REFCOUNTING gstminiobject.c:351:gst_mini_object_ref: 000000000DE70040 ref 2->3 Line 4932: 0:00:00.816408452 9452 0000000002C78F00 TRACE GST_REFCOUNTING gstminiobject.c:431:gst_mini_object_unref: 000000000DE70040 unref 3->2 Line 4933: 0:00:00.816641469 9452 0000000002C78F00 TRACE GST_REFCOUNTING gstminiobject.c:431:gst_mini_object_unref: 000000000DE70040 unref 2->1 Line 21087: 0:00:04.462267722 9452 000000000032B030 TRACE GST_TRACER :0:: object-alive, type-name=(string)GstMemory, address=(gpointer)000000000DE70040, description=(string)000000000DE70040, ref-count=(uint)1, trace=(string);
Pay attention, both times same run, only filtered differently. This are the only places, where the both addresses occur in memory. So buffer is not reused, but seems to remain
occupied. I see ref counts going up from 1 to x and back down to 1, which seems to be correct? What else could I trace or is attached to GstBuffer or GstMemory, which could prevent the GstBuffer and GstMemory from being reported as memory leaks? The number of leaked buffers looks like to be independently from the amount of buffers I am using in videotestsrc. I am seeing big buffers and small buffers (due
to I used a H.264 encoding element in the middle). Best regards, Martin Am 03.05.2017 um 00:30 schrieb Tim
Müller:
On Tue, 2017-05-02 at 23:59 +0200, Martin Maurer wrote: Hi Martin,gst-launch-1.0 videotestsrc num-buffers=100 ! xxx ! fakesink silent=false -v Videotestsrc is generating buffers, xxx (not relevant what it is, e.g. openh264enc) is forwarding buffers and fakesink is consuming the buffers. Looking into latest source code, function gst_fake_sink_render, I can't find where the buffers/memory is released. Is it done somewhere outside the fakesink source code? Where do I find this place, where fakesink render function is called and buffer/memory is released afterwards? (don't know if relevant: I have internal leak checking on and use also some GST_DEBUG options) Is there some documentation which explains such deep internals of Gstreamer?The fakesink element takes ownership of the buffer pushed onto its sinkpad (like all elements), and the GstBaseSink class will take care of calling the fakesink element's render function and then later of releasing the buffer. The "enable-last-sample" property defaults to true, so basesink will hold onto the last buffer until the next buffer comes in, unless this is disabled. Cheers -Tim _______________________________________________ gstreamer-devel mailing list [hidden email] https://lists.freedesktop.org/mailman/listinfo/gstreamer-devel |
Hi Martin,
On Wed, May 3, 2017 at 3:30 PM, Martin Maurer <[hidden email]> wrote: > I see ref counts going up from 1 to x and back down to 1, which seems to be > correct? What else could I trace or is attached to GstBuffer or GstMemory, it'd be better to use valgrind if you are trying to hunt down memory leaks. make sure to specify the suppression file from gstreamer common repo. -- yashi _______________________________________________ gstreamer-devel mailing list [hidden email] https://lists.freedesktop.org/mailman/listinfo/gstreamer-devel |
Free forum by Nabble | Edit this page |