func-read.rst 4.7 KB
Newer Older
1 2 3 4 5 6 7 8
.. -*- coding: utf-8; mode: rst -*-

.. _func-read:

***********
V4L2 read()
***********

9
Name
10
====
11

12
v4l2-read - Read from a V4L2 device
13

14 15

Synopsis
16 17 18 19 20 21 22
========

.. code-block:: c

    #include <unistd.h>


23
.. cpp:function:: ssize_t read( int fd, void *buf, size_t count )
24

25

26
Arguments
27 28 29 30 31 32 33 34 35
=========

``fd``
    File descriptor returned by :ref:`open() <func-open>`.

``buf``
``count``


36
Description
37 38
===========

39
:ref:`read() <func-read>` attempts to read up to ``count`` bytes from file
40 41
descriptor ``fd`` into the buffer starting at ``buf``. The layout of the
data in the buffer is discussed in the respective device interface
42
section, see ##. If ``count`` is zero, :ref:`read() <func-read>` returns zero
43 44
and has no other results. If ``count`` is greater than ``SSIZE_MAX``,
the result is unspecified. Regardless of the ``count`` value each
45
:ref:`read() <func-read>` call will provide at most one frame (two fields)
46 47
worth of data.

48
By default :ref:`read() <func-read>` blocks until data becomes available. When
49
the ``O_NONBLOCK`` flag was given to the :ref:`open() <func-open>`
50
function it returns immediately with an ``EAGAIN`` error code when no data
51 52 53
is available. The :ref:`select() <func-select>` or
:ref:`poll() <func-poll>` functions can always be used to suspend
execution until data becomes available. All drivers supporting the
54 55
:ref:`read() <func-read>` function must also support :ref:`select() <func-select>` and
:ref:`poll() <func-poll>`.
56 57 58 59 60

Drivers can implement read functionality in different ways, using a
single or multiple buffers and discarding the oldest or newest frames
once the internal buffers are filled.

61
:ref:`read() <func-read>` never returns a "snapshot" of a buffer being filled.
62 63 64 65 66 67
Using a single buffer the driver will stop capturing when the
application starts reading the buffer until the read is finished. Thus
only the period of the vertical blanking interval is available for
reading, or the capture rate must fall below the nominal frame rate of
the video standard.

68
The behavior of :ref:`read() <func-read>` when called during the active picture
69 70 71 72
period or the vertical blanking separating the top and bottom field
depends on the discarding policy. A driver discarding the oldest frames
keeps capturing into an internal buffer, continuously overwriting the
previously, not read frame, and returns the frame being received at the
73
time of the :ref:`read() <func-read>` call as soon as it is complete.
74 75

A driver discarding the newest frames stops capturing until the next
76
:ref:`read() <func-read>` call. The frame being received at :ref:`read() <func-read>`
77 78 79
time is discarded, returning the following frame instead. Again this
implies a reduction of the capture rate to one half or less of the
nominal frame rate. An example of this model is the video read mode of
80
the bttv driver, initiating a DMA to user memory when :ref:`read() <func-read>`
81 82 83 84 85 86 87 88 89
is called and returning when the DMA finished.

In the multiple buffer model drivers maintain a ring of internal
buffers, automatically advancing to the next free buffer. This allows
continuous capturing when the application can empty the buffers fast
enough. Again, the behavior when the driver runs out of free buffers
depends on the discarding policy.

Applications can get and set the number of buffers used internally by
90
the driver with the :ref:`VIDIOC_G_PARM <VIDIOC_G_PARM>` and
91
:ref:`VIDIOC_S_PARM <VIDIOC_G_PARM>` ioctls. They are optional,
92 93 94 95
however. The discarding policy is not reported and cannot be changed.
For minimum requirements see :ref:`devices`.


96
Return Value
97 98 99 100 101
============

On success, the number of bytes read is returned. It is not an error if
this number is smaller than the number of bytes requested, or the amount
of data required for one frame. This may happen for example because
102
:ref:`read() <func-read>` was interrupted by a signal. On error, -1 is
103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129
returned, and the ``errno`` variable is set appropriately. In this case
the next read will start at the beginning of a new frame. Possible error
codes are:

EAGAIN
    Non-blocking I/O has been selected using O_NONBLOCK and no data was
    immediately available for reading.

EBADF
    ``fd`` is not a valid file descriptor or is not open for reading, or
    the process already has the maximum number of files open.

EBUSY
    The driver does not support multiple read streams and the device is
    already in use.

EFAULT
    ``buf`` references an inaccessible memory area.

EINTR
    The call was interrupted by a signal before any data was read.

EIO
    I/O error. This indicates some hardware problem or a failure to
    communicate with a remote device (USB camera etc.).

EINVAL
130
    The :ref:`read() <func-read>` function is not supported by this driver, not
131
    on this device, or generally not on this type of device.