Merge tag 'staging-5.8-rc3' of git://git.kernel.org/pub/scm/linux/kernel/git/gregkh...
[linux/fpc-iii.git] / Documentation / userspace-api / media / v4l / mmap.rst
blob9c44d05ebc3f8f78cd74db0aa8e107cfc3235049
1 .. Permission is granted to copy, distribute and/or modify this
2 .. document under the terms of the GNU Free Documentation License,
3 .. Version 1.1 or any later version published by the Free Software
4 .. Foundation, with no Invariant Sections, no Front-Cover Texts
5 .. and no Back-Cover Texts. A copy of the license is included at
6 .. Documentation/userspace-api/media/fdl-appendix.rst.
7 ..
8 .. TODO: replace it to GFDL-1.1-or-later WITH no-invariant-sections
10 .. _mmap:
12 ******************************
13 Streaming I/O (Memory Mapping)
14 ******************************
16 Input and output devices support this I/O method when the
17 ``V4L2_CAP_STREAMING`` flag in the ``capabilities`` field of struct
18 :c:type:`v4l2_capability` returned by the
19 :ref:`VIDIOC_QUERYCAP` ioctl is set. There are two
20 streaming methods, to determine if the memory mapping flavor is
21 supported applications must call the :ref:`VIDIOC_REQBUFS` ioctl
22 with the memory type set to ``V4L2_MEMORY_MMAP``.
24 Streaming is an I/O method where only pointers to buffers are exchanged
25 between application and driver, the data itself is not copied. Memory
26 mapping is primarily intended to map buffers in device memory into the
27 application's address space. Device memory can be for example the video
28 memory on a graphics card with a video capture add-on. However, being
29 the most efficient I/O method available for a long time, many other
30 drivers support streaming as well, allocating buffers in DMA-able main
31 memory.
33 A driver can support many sets of buffers. Each set is identified by a
34 unique buffer type value. The sets are independent and each set can hold
35 a different type of data. To access different sets at the same time
36 different file descriptors must be used. [#f1]_
38 To allocate device buffers applications call the
39 :ref:`VIDIOC_REQBUFS` ioctl with the desired number
40 of buffers and buffer type, for example ``V4L2_BUF_TYPE_VIDEO_CAPTURE``.
41 This ioctl can also be used to change the number of buffers or to free
42 the allocated memory, provided none of the buffers are still mapped.
44 Before applications can access the buffers they must map them into their
45 address space with the :ref:`mmap() <func-mmap>` function. The
46 location of the buffers in device memory can be determined with the
47 :ref:`VIDIOC_QUERYBUF` ioctl. In the single-planar
48 API case, the ``m.offset`` and ``length`` returned in a struct
49 :c:type:`v4l2_buffer` are passed as sixth and second
50 parameter to the :ref:`mmap() <func-mmap>` function. When using the
51 multi-planar API, struct :c:type:`v4l2_buffer` contains an
52 array of struct :c:type:`v4l2_plane` structures, each
53 containing its own ``m.offset`` and ``length``. When using the
54 multi-planar API, every plane of every buffer has to be mapped
55 separately, so the number of calls to :ref:`mmap() <func-mmap>` should
56 be equal to number of buffers times number of planes in each buffer. The
57 offset and length values must not be modified. Remember, the buffers are
58 allocated in physical memory, as opposed to virtual memory, which can be
59 swapped out to disk. Applications should free the buffers as soon as
60 possible with the :ref:`munmap() <func-munmap>` function.
62 Example: Mapping buffers in the single-planar API
63 =================================================
65 .. code-block:: c
67     struct v4l2_requestbuffers reqbuf;
68     struct {
69         void *start;
70         size_t length;
71     } *buffers;
72     unsigned int i;
74     memset(&reqbuf, 0, sizeof(reqbuf));
75     reqbuf.type = V4L2_BUF_TYPE_VIDEO_CAPTURE;
76     reqbuf.memory = V4L2_MEMORY_MMAP;
77     reqbuf.count = 20;
79     if (-1 == ioctl (fd, VIDIOC_REQBUFS, &reqbuf)) {
80         if (errno == EINVAL)
81             printf("Video capturing or mmap-streaming is not supported\\n");
82         else
83             perror("VIDIOC_REQBUFS");
85         exit(EXIT_FAILURE);
86     }
88     /* We want at least five buffers. */
90     if (reqbuf.count < 5) {
91         /* You may need to free the buffers here. */
92         printf("Not enough buffer memory\\n");
93         exit(EXIT_FAILURE);
94     }
96     buffers = calloc(reqbuf.count, sizeof(*buffers));
97     assert(buffers != NULL);
99     for (i = 0; i < reqbuf.count; i++) {
100         struct v4l2_buffer buffer;
102         memset(&buffer, 0, sizeof(buffer));
103         buffer.type = reqbuf.type;
104         buffer.memory = V4L2_MEMORY_MMAP;
105         buffer.index = i;
107         if (-1 == ioctl (fd, VIDIOC_QUERYBUF, &buffer)) {
108             perror("VIDIOC_QUERYBUF");
109             exit(EXIT_FAILURE);
110         }
112         buffers[i].length = buffer.length; /* remember for munmap() */
114         buffers[i].start = mmap(NULL, buffer.length,
115                     PROT_READ | PROT_WRITE, /* recommended */
116                     MAP_SHARED,             /* recommended */
117                     fd, buffer.m.offset);
119         if (MAP_FAILED == buffers[i].start) {
120             /* If you do not exit here you should unmap() and free()
121                the buffers mapped so far. */
122             perror("mmap");
123             exit(EXIT_FAILURE);
124         }
125     }
127     /* Cleanup. */
129     for (i = 0; i < reqbuf.count; i++)
130         munmap(buffers[i].start, buffers[i].length);
133 Example: Mapping buffers in the multi-planar API
134 ================================================
136 .. code-block:: c
138     struct v4l2_requestbuffers reqbuf;
139     /* Our current format uses 3 planes per buffer */
140     #define FMT_NUM_PLANES = 3
142     struct {
143         void *start[FMT_NUM_PLANES];
144         size_t length[FMT_NUM_PLANES];
145     } *buffers;
146     unsigned int i, j;
148     memset(&reqbuf, 0, sizeof(reqbuf));
149     reqbuf.type = V4L2_BUF_TYPE_VIDEO_CAPTURE_MPLANE;
150     reqbuf.memory = V4L2_MEMORY_MMAP;
151     reqbuf.count = 20;
153     if (ioctl(fd, VIDIOC_REQBUFS, &reqbuf) < 0) {
154         if (errno == EINVAL)
155             printf("Video capturing or mmap-streaming is not supported\\n");
156         else
157             perror("VIDIOC_REQBUFS");
159         exit(EXIT_FAILURE);
160     }
162     /* We want at least five buffers. */
164     if (reqbuf.count < 5) {
165         /* You may need to free the buffers here. */
166         printf("Not enough buffer memory\\n");
167         exit(EXIT_FAILURE);
168     }
170     buffers = calloc(reqbuf.count, sizeof(*buffers));
171     assert(buffers != NULL);
173     for (i = 0; i < reqbuf.count; i++) {
174         struct v4l2_buffer buffer;
175         struct v4l2_plane planes[FMT_NUM_PLANES];
177         memset(&buffer, 0, sizeof(buffer));
178         buffer.type = reqbuf.type;
179         buffer.memory = V4L2_MEMORY_MMAP;
180         buffer.index = i;
181         /* length in struct v4l2_buffer in multi-planar API stores the size
182          * of planes array. */
183         buffer.length = FMT_NUM_PLANES;
184         buffer.m.planes = planes;
186         if (ioctl(fd, VIDIOC_QUERYBUF, &buffer) < 0) {
187             perror("VIDIOC_QUERYBUF");
188             exit(EXIT_FAILURE);
189         }
191         /* Every plane has to be mapped separately */
192         for (j = 0; j < FMT_NUM_PLANES; j++) {
193             buffers[i].length[j] = buffer.m.planes[j].length; /* remember for munmap() */
195             buffers[i].start[j] = mmap(NULL, buffer.m.planes[j].length,
196                      PROT_READ | PROT_WRITE, /* recommended */
197                      MAP_SHARED,             /* recommended */
198                      fd, buffer.m.planes[j].m.offset);
200             if (MAP_FAILED == buffers[i].start[j]) {
201                 /* If you do not exit here you should unmap() and free()
202                    the buffers and planes mapped so far. */
203                 perror("mmap");
204                 exit(EXIT_FAILURE);
205             }
206         }
207     }
209     /* Cleanup. */
211     for (i = 0; i < reqbuf.count; i++)
212         for (j = 0; j < FMT_NUM_PLANES; j++)
213             munmap(buffers[i].start[j], buffers[i].length[j]);
215 Conceptually streaming drivers maintain two buffer queues, an incoming
216 and an outgoing queue. They separate the synchronous capture or output
217 operation locked to a video clock from the application which is subject
218 to random disk or network delays and preemption by other processes,
219 thereby reducing the probability of data loss. The queues are organized
220 as FIFOs, buffers will be output in the order enqueued in the incoming
221 FIFO, and were captured in the order dequeued from the outgoing FIFO.
223 The driver may require a minimum number of buffers enqueued at all times
224 to function, apart of this no limit exists on the number of buffers
225 applications can enqueue in advance, or dequeue and process. They can
226 also enqueue in a different order than buffers have been dequeued, and
227 the driver can *fill* enqueued *empty* buffers in any order.  [#f2]_ The
228 index number of a buffer (struct :c:type:`v4l2_buffer`
229 ``index``) plays no role here, it only identifies the buffer.
231 Initially all mapped buffers are in dequeued state, inaccessible by the
232 driver. For capturing applications it is customary to first enqueue all
233 mapped buffers, then to start capturing and enter the read loop. Here
234 the application waits until a filled buffer can be dequeued, and
235 re-enqueues the buffer when the data is no longer needed. Output
236 applications fill and enqueue buffers, when enough buffers are stacked
237 up the output is started with :ref:`VIDIOC_STREAMON <VIDIOC_STREAMON>`.
238 In the write loop, when the application runs out of free buffers, it
239 must wait until an empty buffer can be dequeued and reused.
241 To enqueue and dequeue a buffer applications use the
242 :ref:`VIVIOC_QBUF <VIDIOC_QBUF>` and :ref:`VIDIOC_DQBUF <VIDIOC_QBUF>`
243 ioctl. The status of a buffer being mapped, enqueued, full or empty can
244 be determined at any time using the :ref:`VIDIOC_QUERYBUF` ioctl. Two
245 methods exist to suspend execution of the application until one or more
246 buffers can be dequeued.  By default :ref:`VIDIOC_DQBUF <VIDIOC_QBUF>`
247 blocks when no buffer is in the outgoing queue. When the ``O_NONBLOCK``
248 flag was given to the :ref:`open() <func-open>` function,
249 :ref:`VIDIOC_DQBUF <VIDIOC_QBUF>` returns immediately with an ``EAGAIN``
250 error code when no buffer is available. The :ref:`select() <func-select>`
251 or :ref:`poll() <func-poll>` functions are always available.
253 To start and stop capturing or output applications call the
254 :ref:`VIDIOC_STREAMON <VIDIOC_STREAMON>` and :ref:`VIDIOC_STREAMOFF
255 <VIDIOC_STREAMON>` ioctl.
257 .. note:::ref:`VIDIOC_STREAMOFF <VIDIOC_STREAMON>`
258    removes all buffers from both queues as a side effect. Since there is
259    no notion of doing anything "now" on a multitasking system, if an
260    application needs to synchronize with another event it should examine
261    the struct ::c:type:`v4l2_buffer` ``timestamp`` of captured
262    or outputted buffers.
264 Drivers implementing memory mapping I/O must support the
265 :ref:`VIDIOC_REQBUFS <VIDIOC_REQBUFS>`, :ref:`VIDIOC_QUERYBUF
266 <VIDIOC_QUERYBUF>`, :ref:`VIDIOC_QBUF <VIDIOC_QBUF>`, :ref:`VIDIOC_DQBUF
267 <VIDIOC_QBUF>`, :ref:`VIDIOC_STREAMON <VIDIOC_STREAMON>`
268 and :ref:`VIDIOC_STREAMOFF <VIDIOC_STREAMON>` ioctls, the :ref:`mmap()
269 <func-mmap>`, :ref:`munmap() <func-munmap>`, :ref:`select()
270 <func-select>` and :ref:`poll() <func-poll>` function. [#f3]_
272 [capture example]
274 .. [#f1]
275    One could use one file descriptor and set the buffer type field
276    accordingly when calling :ref:`VIDIOC_QBUF` etc.,
277    but it makes the :ref:`select() <func-select>` function ambiguous. We also
278    like the clean approach of one file descriptor per logical stream.
279    Video overlay for example is also a logical stream, although the CPU
280    is not needed for continuous operation.
282 .. [#f2]
283    Random enqueue order permits applications processing images out of
284    order (such as video codecs) to return buffers earlier, reducing the
285    probability of data loss. Random fill order allows drivers to reuse
286    buffers on a LIFO-basis, taking advantage of caches holding
287    scatter-gather lists and the like.
289 .. [#f3]
290    At the driver level :ref:`select() <func-select>` and :ref:`poll() <func-poll>` are
291    the same, and :ref:`select() <func-select>` is too important to be optional.
292    The rest should be evident.