After an evaluation, GNOME has moved from Bugzilla to GitLab. Learn more about GitLab.
No new issues can be reported in GNOME Bugzilla anymore.
To report an issue in a GNOME project, go to GNOME GitLab.
Do not go to GNOME Gitlab for: Bluefish, Doxygen, GnuCash, GStreamer, java-gnome, LDTP, NetworkManager, Tomboy.
Bug 572285 - Buffer Lists
Buffer Lists
Status: RESOLVED FIXED
Product: GStreamer
Classification: Platform
Component: gstreamer (core)
git master
Other All
: Normal enhancement
: 0.10.24
Assigned To: GStreamer Maintainers
GStreamer Maintainers
Depends on:
Blocks:
 
 
Reported: 2009-02-18 15:42 UTC by Jonas Holmberg
Modified: 2009-05-12 13:34 UTC
See Also:
GNOME target: ---
GNOME version: ---


Attachments
buffer arrays in core (41.84 KB, patch)
2009-02-18 15:52 UTC, Jonas Holmberg
none Details | Review
updated patch (44.43 KB, patch)
2009-02-19 15:32 UTC, Wim Taymans
none Details | Review
updated patch with _make_data_writable() (58.00 KB, patch)
2009-02-27 14:57 UTC, Jonas Holmberg
none Details | Review
Updated patch using mini object (61.76 KB, patch)
2009-03-02 21:42 UTC, Jonas Holmberg
none Details | Review
rtph264 payloader with buffer arrays and unit tests (21.45 KB, patch)
2009-03-10 09:21 UTC, Ognyan Tonchev (redstar_)
none Details | Review
basertp payloader and gstrtpbuffer with buffer arrays including unit tests (27.26 KB, patch)
2009-03-10 09:25 UTC, Ognyan Tonchev (redstar_)
none Details | Review
basesink with buffer arrays (11.94 KB, patch)
2009-03-10 09:27 UTC, Ognyan Tonchev (redstar_)
none Details | Review
multiudpsink with buffer arrays, unit tests also included (12.25 KB, patch)
2009-03-10 13:48 UTC, Ognyan Tonchev (redstar_)
none Details | Review
buffer list in core (61.01 KB, patch)
2009-04-21 08:51 UTC, Jonas Holmberg
none Details | Review
updated buffer list in core (83.76 KB, patch)
2009-04-27 21:40 UTC, Jonas Holmberg
committed Details | Review

Description Jonas Holmberg 2009-02-18 15:42:36 UTC
Please describe the problem:
1) Be able to push many buffers in one go in elements that spilt one buffer to many
2) Avoid memcpy of original buffer when inserting headers between chunks of payload data

Steps to reproduce:
1. 
2. 
3. 


Actual results:


Expected results:


Does this happen every time?


Other information:
Comment 1 Jonas Holmberg 2009-02-18 15:52:28 UTC
Created attachment 128990 [details] [review]
buffer arrays in core

Adds GstBufferArray type and support for pushing arrays in GstPad.
Comment 2 Jonas Holmberg 2009-02-18 16:10:43 UTC
Missing feature: gst_buffer_array_make_writeable()
How can we implement it?
Comment 3 Sebastian Dröge (slomo) 2009-02-18 16:36:08 UTC
<slomo> jij: looks like it could cause alignment problems... you store the length as guint before the array of GstBufferArrayData, if sizeof(guint)!=sizeof(gpointer) you store a pointer (data field of GstBufferArrayData) not pointer aligned
<jij> slomo, darn, I knew that would cause some problem
<slomo> jij: look at libgstfft and grep for STRUCT_ALIGN or ALIGN_STRUCT
<jij> slomo, why didn't someone add a size field for the free func in GstBuffer :)
<jij> slomo, thx
<slomo> jij: essentially you have to allocate 2*sizeof(size_t) for the size field and put the array afterwards
<jij> slomo, ok




Also it would make sense to use GstMiniObject as base class here, it would give you refcounting and all that.
Comment 4 Wim Taymans 2009-02-19 15:32:48 UTC
Created attachment 129072 [details] [review]
updated patch

Updated patch:

 - fix docs
 - clean up weird pointer math
 - clean up method names
 - clean up pad code
Comment 5 Sebastian Dröge (slomo) 2009-02-19 16:19:38 UTC
It's still no GstMiniObject though ;)
Comment 6 Jonas Holmberg 2009-02-20 15:52:50 UTC
The problem with gst_buffer_array_make_writeable() is that if the buffer array contain pointers into a "parent buffer" (e.g. array with RTP payloaded H.264 points into a H.264 buffer), the only way to check if that data is writeable is to check that refcount of the parent buffer equals the number of refs the array has to that parent buffer.

Another problem is that calling gst_buffer_make_writeable() on a group buffer will return the same buffer if refcount is 1 on the group buffer even if the group data points to data in a parent buffer with refcount >1.
Comment 7 David Schleef 2009-02-20 17:47:37 UTC
I've been meaning to add disjoint buffers to GStreamer for years.  Thank you for actually moving on the issue.

My plan was to split GstBuffer into 2 layers, the lower layer being a simple wrapper of a contiguous memory region into a GstMiniObject, with reference counting but no metadata.  The upper layer would contain the metadata and point to one or more MemoryRegions to hold the data, including an offset and size to specify a subregion of the MemoryRegion.

This rearrangement would subsume subbuffers and most buffer subclasses.  It might even take over GstAdapter, since adapters are an attempt to get around the disjoint buffer limitation.  It would allow buffers to share underlying data while having different (writeable) metadata.

Obviously, all this requires an ABI change, so would be for 0.11 at least, assuming someone does it.  I wouldn't be opposed to having something like this in 0.10.

An actual comment on the patch:  Couldn't this be better solved by extending (ahem, hacking to death) GstBuffer in a compatible way?
Comment 8 Wim Taymans 2009-02-23 14:08:46 UTC
Maybe we still need a subclass of the buffers in the array so that we can, for example, implement a working copy function. If that's the case we could expose the group methods on this new type. 

It all seems a bit too much for what we can reasonably implement right now. If you want to transfer some GstBufferArrayData element to another buffer, there is not really a way to increment the refcount of whatever object actually owns that data pointer unless you also add a _ref method to the Data structure.

I would think that for 0.10 we want to create the buffer array with its special buffers inside but that's it. Modifications to these arrays seems too much to handle without doing some serious GstBuffer redesigns. 
Comment 9 Jonas Holmberg 2009-02-27 14:57:38 UTC
Created attachment 129655 [details] [review]
updated patch with _make_data_writable()

Added gst_buffer_array_make_data_writable() and a debug category for buffer array.
Comment 10 Jonas Holmberg 2009-03-02 21:42:18 UTC
Created attachment 129892 [details] [review]
Updated patch using mini object

* GstBufferArray extends GstMiniObject
* Added copy-function (mini objects need it)
* Updated docs sections
Comment 11 Ognyan Tonchev (redstar_) 2009-03-10 09:21:52 UTC
Created attachment 130390 [details] [review]
rtph264 payloader with buffer arrays and unit tests
Comment 12 Ognyan Tonchev (redstar_) 2009-03-10 09:25:16 UTC
Created attachment 130391 [details] [review]
basertp payloader and gstrtpbuffer with buffer arrays including unit tests
Comment 13 Ognyan Tonchev (redstar_) 2009-03-10 09:27:46 UTC
Created attachment 130392 [details] [review]
basesink with buffer arrays
Comment 14 Ognyan Tonchev (redstar_) 2009-03-10 13:48:32 UTC
Created attachment 130398 [details] [review]
multiudpsink with buffer arrays, unit tests also included
Comment 15 Jonas Holmberg 2009-04-21 08:51:23 UTC
Created attachment 133027 [details] [review]
buffer list in core

Updated core patch using linked list and iterator instead of array.
Comment 16 Wim Taymans 2009-04-21 21:04:24 UTC
ah, looks neater indeed. 

I'm wondering if the copy function should really do a deep copy instead of a shallow one. The make writable on the list could mean that it's ok to change the list. But to actually change the buffer contents one would explicitly make the buffer writable first.

Is there a function to replace a buffer too?
Comment 17 Jonas Holmberg 2009-04-27 21:40:45 UTC
Created attachment 133453 [details] [review]
updated buffer list in core

Made copy function shallow and added functions for removing and replacing buffers.
Comment 18 Wim Taymans 2009-04-28 15:51:36 UTC
How does one append a buffer to a group?
Comment 19 Jonas Holmberg 2009-04-28 16:32:41 UTC
With the current API one would find the correct position using _next_group() and _next() (returns NULL at the end of the group) and then _add().
Comment 20 Wim Taymans 2009-05-12 13:34:43 UTC
Commited into git.