|  | .. SPDX-License-Identifier: GFDL-1.1-no-invariants-or-later | 
|  | .. c:namespace:: V4L | 
|  |  | 
|  | .. _VIDIOC_STREAMON: | 
|  |  | 
|  | *************************************** | 
|  | ioctl VIDIOC_STREAMON, VIDIOC_STREAMOFF | 
|  | *************************************** | 
|  |  | 
|  | Name | 
|  | ==== | 
|  |  | 
|  | VIDIOC_STREAMON - VIDIOC_STREAMOFF - Start or stop streaming I/O | 
|  |  | 
|  | Synopsis | 
|  | ======== | 
|  |  | 
|  | .. c:macro:: VIDIOC_STREAMON | 
|  |  | 
|  | ``int ioctl(int fd, VIDIOC_STREAMON, const int *argp)`` | 
|  |  | 
|  | .. c:macro:: VIDIOC_STREAMOFF | 
|  |  | 
|  | ``int ioctl(int fd, VIDIOC_STREAMOFF, const int *argp)`` | 
|  |  | 
|  | Arguments | 
|  | ========= | 
|  |  | 
|  | ``fd`` | 
|  | File descriptor returned by :c:func:`open()`. | 
|  |  | 
|  | ``argp`` | 
|  | Pointer to an integer. | 
|  |  | 
|  | Description | 
|  | =========== | 
|  |  | 
|  | The ``VIDIOC_STREAMON`` and ``VIDIOC_STREAMOFF`` ioctl start and stop | 
|  | the capture or output process during streaming | 
|  | (:ref:`memory mapping <mmap>`, :ref:`user pointer <userp>` or | 
|  | :ref:`DMABUF <dmabuf>`) I/O. | 
|  |  | 
|  | Capture hardware is disabled and no input buffers are filled (if there | 
|  | are any empty buffers in the incoming queue) until ``VIDIOC_STREAMON`` | 
|  | has been called. Output hardware is disabled and no video signal is | 
|  | produced until ``VIDIOC_STREAMON`` has been called. The ioctl will | 
|  | succeed when at least one output buffer is in the incoming queue. | 
|  |  | 
|  | Memory-to-memory devices will not start until ``VIDIOC_STREAMON`` has | 
|  | been called for both the capture and output stream types. | 
|  |  | 
|  | If ``VIDIOC_STREAMON`` fails then any already queued buffers will remain | 
|  | queued. | 
|  |  | 
|  | The ``VIDIOC_STREAMOFF`` ioctl, apart of aborting or finishing any DMA | 
|  | in progress, unlocks any user pointer buffers locked in physical memory, | 
|  | and it removes all buffers from the incoming and outgoing queues. That | 
|  | means all images captured but not dequeued yet will be lost, likewise | 
|  | all images enqueued for output but not transmitted yet. I/O returns to | 
|  | the same state as after calling | 
|  | :ref:`VIDIOC_REQBUFS` and can be restarted | 
|  | accordingly. | 
|  |  | 
|  | If buffers have been queued with :ref:`VIDIOC_QBUF` and | 
|  | ``VIDIOC_STREAMOFF`` is called without ever having called | 
|  | ``VIDIOC_STREAMON``, then those queued buffers will also be removed from | 
|  | the incoming queue and all are returned to the same state as after | 
|  | calling :ref:`VIDIOC_REQBUFS` and can be restarted | 
|  | accordingly. | 
|  |  | 
|  | Both ioctls take a pointer to an integer, the desired buffer or stream | 
|  | type. This is the same as struct | 
|  | :c:type:`v4l2_requestbuffers` ``type``. | 
|  |  | 
|  | If ``VIDIOC_STREAMON`` is called when streaming is already in progress, | 
|  | or if ``VIDIOC_STREAMOFF`` is called when streaming is already stopped, | 
|  | then 0 is returned. Nothing happens in the case of ``VIDIOC_STREAMON``, | 
|  | but ``VIDIOC_STREAMOFF`` will return queued buffers to their starting | 
|  | state as mentioned above. | 
|  |  | 
|  | .. note:: | 
|  |  | 
|  | Applications can be preempted for unknown periods right before | 
|  | or after the ``VIDIOC_STREAMON`` or ``VIDIOC_STREAMOFF`` calls, there is | 
|  | no notion of starting or stopping "now". Buffer timestamps can be used | 
|  | to synchronize with other events. | 
|  |  | 
|  | Return Value | 
|  | ============ | 
|  |  | 
|  | On success 0 is returned, on error -1 and the ``errno`` variable is set | 
|  | appropriately. The generic error codes are described at the | 
|  | :ref:`Generic Error Codes <gen-errors>` chapter. | 
|  |  | 
|  | EINVAL | 
|  | The buffer ``type`` is not supported, or no buffers have been | 
|  | allocated (memory mapping) or enqueued (output) yet. | 
|  |  | 
|  | EPIPE | 
|  | The driver implements | 
|  | :ref:`pad-level format configuration <pad-level-formats>` and the | 
|  | pipeline configuration is invalid. | 
|  |  | 
|  | ENOLINK | 
|  | The driver implements Media Controller interface and the pipeline | 
|  | link configuration is invalid. |