| <chapter id="chapter-data"> |
| <title>Buffers and Events</title> |
| <para> |
| The data flowing through a pipeline consists of a combination of |
| buffers and events. Buffers contain the actual media data. Events |
| contain control information, such as seeking information and |
| end-of-stream notifiers. All this will flow through the pipeline |
| automatically when it's running. This chapter is mostly meant to |
| explain the concept to you; you don't need to do anything for this. |
| </para> |
| |
| <sect1 id="section-buffers"> |
| <title>Buffers</title> |
| <para> |
| Buffers contain the data that will flow through the pipeline you have |
| created. A source element will typically create a new buffer and pass |
| it through a pad to the next element in the chain. When using the |
| GStreamer infrastructure to create a media pipeline you will not have |
| to deal with buffers yourself; the elements will do that for you. |
| </para> |
| <para> |
| A buffer consists, amongst others, of: |
| </para> |
| <itemizedlist> |
| <listitem> |
| <para> |
| A pointer to a piece of memory. |
| </para> |
| </listitem> |
| <listitem> |
| <para> |
| The size of the memory. |
| </para> |
| </listitem> |
| <listitem> |
| <para> |
| A timestamp for the buffer. |
| </para> |
| </listitem> |
| <listitem> |
| <para> |
| A refcount that indicates how many elements are using this |
| buffer. This refcount will be used to destroy the buffer when no |
| element has a reference to it. |
| </para> |
| </listitem> |
| <listitem> |
| <para> |
| Buffer flags. |
| </para> |
| </listitem> |
| </itemizedlist> |
| <para> |
| The simple case is that a buffer is created, memory allocated, data |
| put in it, and passed to the next element. That element reads the |
| data, does something (like creating a new buffer and decoding into |
| it), and unreferences the buffer. This causes the data to be free'ed |
| and the buffer to be destroyed. A typical video or audio decoder |
| works like this. |
| </para> |
| <para> |
| There are more complex scenarios, though. Elements can modify buffers |
| in-place, i.e. without allocating a new one. Elements can also write |
| to hardware memory (such as from video-capture sources) or memory |
| allocated from the X-server (using XShm). Buffers can be read-only, |
| and so on. |
| </para> |
| </sect1> |
| |
| <sect1 id="section-events"> |
| <title>Events</title> |
| <para> |
| Events are control particles that are sent both up- and downstream in |
| a pipeline along with buffers. Downstream events notify fellow elements |
| of stream states. Possible events include seeking, flushes, |
| end-of-stream notifications and so on. Upstream events are used both |
| in application-element interaction as well as element-element interaction |
| to request changes in stream state, such as seeks. For applications, |
| only upstream events are important. Downstream events are just |
| explained to get a more complete picture of the data concept. |
| </para> |
| <para> |
| Since most applications seek in time units, our example below does so |
| too: |
| </para> |
| <programlisting> |
| static void |
| seek_to_time (GstElement *element, |
| guint64 time_ns) |
| { |
| GstEvent *event; |
| |
| event = gst_event_new_seek (1.0, GST_FORMAT_TIME, |
| GST_SEEK_FLAG_NONE, |
| GST_SEEK_METHOD_SET, time_ns, |
| GST_SEEK_TYPE_NONE, G_GUINT64_CONSTANT (0)); |
| gst_element_send_event (element, event); |
| } |
| </programlisting> |
| <para> |
| The function <function>gst_element_seek ()</function> is a shortcut |
| for this. This is mostly just to show how it all works. |
| </para> |
| </sect1> |
| </chapter> |