2018-08-30 22:15:26 +08:00
|
|
|
.. Permission is granted to copy, distribute and/or modify this
|
|
|
|
.. document under the terms of the GNU Free Documentation License,
|
|
|
|
.. Version 1.1 or any later version published by the Free Software
|
|
|
|
.. Foundation, with no Invariant Sections, no Front-Cover Texts
|
|
|
|
.. and no Back-Cover Texts. A copy of the license is included at
|
2020-03-04 17:21:39 +08:00
|
|
|
.. Documentation/userspace-api/media/fdl-appendix.rst.
|
2018-08-30 22:15:26 +08:00
|
|
|
..
|
|
|
|
.. TODO: replace it to GFDL-1.1-or-later WITH no-invariant-sections
|
|
|
|
|
2019-01-23 16:07:20 +08:00
|
|
|
.. _mem2mem:
|
2016-06-30 21:18:56 +08:00
|
|
|
|
2019-01-23 16:07:20 +08:00
|
|
|
********************************
|
|
|
|
Video Memory-To-Memory Interface
|
|
|
|
********************************
|
2016-06-30 21:18:56 +08:00
|
|
|
|
2019-01-23 16:07:20 +08:00
|
|
|
A V4L2 memory-to-memory device can compress, decompress, transform, or
|
|
|
|
otherwise convert video data from one format into another format, in memory.
|
|
|
|
Such memory-to-memory devices set the ``V4L2_CAP_VIDEO_M2M`` or
|
|
|
|
``V4L2_CAP_VIDEO_M2M_MPLANE`` capability. Examples of memory-to-memory
|
|
|
|
devices are codecs, scalers, deinterlacers or format converters (i.e.
|
|
|
|
converting from YUV to RGB).
|
2016-06-30 21:18:56 +08:00
|
|
|
|
|
|
|
A memory-to-memory video node acts just like a normal video node, but it
|
2019-01-23 16:07:20 +08:00
|
|
|
supports both output (sending frames from memory to the hardware)
|
|
|
|
and capture (receiving the processed frames from the hardware into
|
2016-06-30 21:18:56 +08:00
|
|
|
memory) stream I/O. An application will have to setup the stream I/O for
|
2016-07-05 05:05:55 +08:00
|
|
|
both sides and finally call :ref:`VIDIOC_STREAMON <VIDIOC_STREAMON>`
|
2019-01-23 16:07:20 +08:00
|
|
|
for both capture and output to start the hardware.
|
2016-06-30 21:18:56 +08:00
|
|
|
|
2016-10-18 21:15:32 +08:00
|
|
|
Memory-to-memory devices function as a shared resource: you can
|
2016-06-30 21:18:56 +08:00
|
|
|
open the video node multiple times, each application setting up their
|
2019-01-23 16:07:20 +08:00
|
|
|
own properties that are local to the file handle, and each can use
|
2016-06-30 21:18:56 +08:00
|
|
|
it independently from the others. The driver will arbitrate access to
|
2019-01-23 16:07:20 +08:00
|
|
|
the hardware and reprogram it whenever another file handler gets access.
|
2016-06-30 21:18:56 +08:00
|
|
|
This is different from the usual video node behavior where the video
|
|
|
|
properties are global to the device (i.e. changing something through one
|
|
|
|
file handle is visible through another file handle).
|
2019-01-23 16:07:20 +08:00
|
|
|
|
|
|
|
One of the most common memory-to-memory device is the codec. Codecs
|
|
|
|
are more complicated than most and require additional setup for
|
|
|
|
their codec parameters. This is done through codec controls.
|
2019-08-15 22:44:51 +08:00
|
|
|
See :ref:`mpeg-controls`. More details on how to use codec memory-to-memory
|
|
|
|
devices are given in the following sections.
|
|
|
|
|
|
|
|
.. toctree::
|
|
|
|
:maxdepth: 1
|
|
|
|
|
|
|
|
dev-decoder
|
2019-11-19 19:34:57 +08:00
|
|
|
dev-encoder
|
2019-08-15 22:44:55 +08:00
|
|
|
dev-stateless-decoder
|