1 .. -*- coding: utf-8; mode: rst -*-
3 .. _VIDIOC_SUBDEV_ENUM_FRAME_SIZE:
5 ***********************************
6 ioctl VIDIOC_SUBDEV_ENUM_FRAME_SIZE
7 ***********************************
12 VIDIOC_SUBDEV_ENUM_FRAME_SIZE - Enumerate media bus frame sizes
18 .. cpp:function:: int ioctl( int fd, int request, struct v4l2_subdev_frame_size_enum * argp )
25 File descriptor returned by :ref:`open() <func-open>`.
28 VIDIOC_SUBDEV_ENUM_FRAME_SIZE
36 This ioctl allows applications to enumerate all frame sizes supported by
37 a sub-device on the given pad for the given media bus format. Supported
38 formats can be retrieved with the
39 :ref:`VIDIOC_SUBDEV_ENUM_MBUS_CODE`
42 To enumerate frame sizes applications initialize the ``pad``, ``which``
43 , ``code`` and ``index`` fields of the struct
44 :ref:`v4l2_subdev_mbus_code_enum <v4l2-subdev-mbus-code-enum>` and
45 call the :ref:`VIDIOC_SUBDEV_ENUM_FRAME_SIZE` ioctl with a pointer to the
46 structure. Drivers fill the minimum and maximum frame sizes or return an
47 EINVAL error code if one of the input parameters is invalid.
49 Sub-devices that only support discrete frame sizes (such as most
50 sensors) will return one or more frame sizes with identical minimum and
53 Not all possible sizes in given [minimum, maximum] ranges need to be
54 supported. For instance, a scaler that uses a fixed-point scaling ratio
55 might not be able to produce every frame size between the minimum and
56 maximum values. Applications must use the
57 :ref:`VIDIOC_SUBDEV_S_FMT <VIDIOC_SUBDEV_G_FMT>` ioctl to try the
58 sub-device for an exact supported frame size.
60 Available frame sizes may depend on the current 'try' formats at other
61 pads of the sub-device, as well as on the current active links and the
62 current values of V4L2 controls. See
63 :ref:`VIDIOC_SUBDEV_G_FMT` for more
64 information about try formats.
67 .. _v4l2-subdev-frame-size-enum:
69 .. flat-table:: struct v4l2_subdev_frame_size_enum
81 - Number of the format in the enumeration, set by the application.
89 - Pad number as reported by the media controller API.
97 - The media bus format code, as defined in
98 :ref:`v4l2-mbus-format`.
106 - Minimum frame width, in pixels.
114 - Maximum frame width, in pixels.
122 - Minimum frame height, in pixels.
130 - Maximum frame height, in pixels.
138 - Frame sizes to be enumerated, from enum
139 :ref:`v4l2_subdev_format_whence <v4l2-subdev-format-whence>`.
147 - Reserved for future extensions. Applications and drivers must set
154 On success 0 is returned, on error -1 and the ``errno`` variable is set
155 appropriately. The generic error codes are described at the
156 :ref:`Generic Error Codes <gen-errors>` chapter.
160 :ref:`v4l2_subdev_frame_size_enum <v4l2-subdev-frame-size-enum>`
161 ``pad`` references a non-existing pad, the ``code`` is invalid for
162 the given pad or the ``index`` field is out of bounds.