mirror of
https://gitlab.freedesktop.org/gstreamer/gstreamer.git
synced 2025-01-10 17:35:59 +00:00
docs/pwg/intro-basics.xml: rewrite bufferpool stuff.
Original commit message from CVS: * docs/pwg/intro-basics.xml: rewrite bufferpool stuff.
This commit is contained in:
parent
807937481e
commit
7a5223b57a
2 changed files with 50 additions and 27 deletions
|
@ -1,3 +1,7 @@
|
||||||
|
2004-01-28 David Schleef <ds@schleef.org>
|
||||||
|
|
||||||
|
* docs/pwg/intro-basics.xml: rewrite bufferpool stuff.
|
||||||
|
|
||||||
2004-01-29 Benjamin Otte <in7y118@public.uni-hamburg.de>
|
2004-01-29 Benjamin Otte <in7y118@public.uni-hamburg.de>
|
||||||
|
|
||||||
* docs/random/mimetypes:
|
* docs/random/mimetypes:
|
||||||
|
|
|
@ -192,38 +192,57 @@
|
||||||
url="../gstreamer/gstreamer-gstevent.html"><classname>GstEvent</classname></ulink>.
|
url="../gstreamer/gstreamer-gstevent.html"><classname>GstEvent</classname></ulink>.
|
||||||
</para>
|
</para>
|
||||||
|
|
||||||
<sect2 id="sect2-buffers-bufferpools" xreflabel="Buffer Allocation and
|
<sect2 id="sect2-buffer-allocation" xreflabel="Buffer Allocation">
|
||||||
Buffer Pools">
|
<title>Buffer Allocation</title>
|
||||||
<title>Buffer Allocation and Buffer Pools</title>
|
|
||||||
<para>
|
<para>
|
||||||
Buffers can be allocated using various schemes, and they may either be
|
Buffers are able to store chunks of memory of several different
|
||||||
passed on by an element or unreferenced, thus freeing the memory used by
|
types. The most generic type of buffer contains memory allocated
|
||||||
the buffer. Buffer allocation and unlinking are important concepts when
|
by malloc(). Such buffers, although convenient, are not always
|
||||||
dealing with real time media processing, since memory allocation is
|
very fast, since data often needs to be specifically copied into
|
||||||
relatively slow on most systems.
|
the buffer.
|
||||||
</para>
|
</para>
|
||||||
<para>
|
<para>
|
||||||
To improve the latency in a media pipeline, many &GStreamer; elements
|
Many specialized elements create buffers that point to special
|
||||||
use a <emphasis>buffer pool</emphasis> to handle buffer allocation and
|
memory. For example, the filesrc element usually
|
||||||
releasing. A buffer pool is a virtual representation of one or more
|
maps a file into the address space of the application (using mmap()),
|
||||||
buffers of which the data is not actually allocated by &GStreamer;
|
and creates buffers that point into that address range. These
|
||||||
itself. Examples of these include hardware framebuffer memory in video
|
buffers created by filesrc act exactly like generic buffers, except
|
||||||
output elements or kernel-allocated DMA memory for video capture. The
|
that they are read-only. The buffer freeing code automatically
|
||||||
huge advantage of using these buffers instead of creating our own is
|
determines the correct method of freeing the underlying memory.
|
||||||
that we do not have to copy memory from one place to another, thereby
|
Downstream elements that recieve these kinds of buffers do not
|
||||||
saving a noticeable number of CPU cycles. Elements should not provide
|
need to do anything special to handle or unreference it.
|
||||||
a bufferpool to decrease the number of memory allocations: the kernel
|
|
||||||
will generally take care of that - and will probably do that much more
|
|
||||||
efficiently than we ever could. Using bufferpools in this way is highly
|
|
||||||
discouraged.
|
|
||||||
</para>
|
</para>
|
||||||
<para>
|
<para>
|
||||||
Normally in a media pipeline, most filter elements in &GStreamer; deal
|
Another way an element might get specialized buffers is to
|
||||||
with a buffer in place, meaning that they do not create or destroy
|
request them from a downstream peer. These are called
|
||||||
buffers. Sometimes, however, elements might need to alter the reference
|
downstream-allocated buffers. Elements can ask a
|
||||||
count of a buffer, either by copying or destroying the buffer, or by
|
peer connected to a source pad to create an empty buffer of
|
||||||
creating a new buffer. These topics are generally reserved for
|
a given size. If a downstream element is able to create a
|
||||||
non-filter elements, so they will be addressed at that point.
|
special buffer of the correct size, it will do so. Otherwise
|
||||||
|
&GStreamer; will automatically create a generic buffer instead.
|
||||||
|
The element that requested the buffer can then copy data into
|
||||||
|
the buffer, and push the buffer to the source pad it was
|
||||||
|
allocated from.
|
||||||
|
</para>
|
||||||
|
<para>
|
||||||
|
Many sink elements have accelerated methods for copying data
|
||||||
|
to hardware, or have direct access to hardware. It is common
|
||||||
|
for these elements to be able to create downstream-allocated
|
||||||
|
buffers for their upstream peers. One such example is
|
||||||
|
ximagesink. It creates buffers that contain XImages. Thus,
|
||||||
|
when an upstream peer copies data into the buffer, it is copying
|
||||||
|
directly into the XImage, enabling ximagesink to draw the
|
||||||
|
image directly to the screen instead of having to copy data
|
||||||
|
into an XImage first.
|
||||||
|
</para>
|
||||||
|
<para>
|
||||||
|
Filter elements often have the opportunity to either work on
|
||||||
|
a buffer in-place, or work while copying from a source buffer
|
||||||
|
to a destination buffer. It is optimal to implement both
|
||||||
|
algorithms, since the &GStreamer; framework can choose the
|
||||||
|
fastest algorithm as appropriate. Naturally, this only makes
|
||||||
|
sense for strict filters -- elements that have exactly the
|
||||||
|
same format on source and sink pads.
|
||||||
</para>
|
</para>
|
||||||
</sect2>
|
</sect2>
|
||||||
</sect1>
|
</sect1>
|
||||||
|
|
Loading…
Reference in a new issue