1 .. SPDX-License-Identifier: GFDL-1.1-no-invariants-or-later
6 ******************************************
7 ioctl VIDIOC_G_JPEGCOMP, VIDIOC_S_JPEGCOMP
8 ******************************************
13 VIDIOC_G_JPEGCOMP - VIDIOC_S_JPEGCOMP
18 .. c:macro:: VIDIOC_G_JPEGCOMP
20 ``int ioctl(int fd, VIDIOC_G_JPEGCOMP, v4l2_jpegcompression *argp)``
22 .. c:macro:: VIDIOC_S_JPEGCOMP
24 ``int ioctl(int fd, VIDIOC_S_JPEGCOMP, const v4l2_jpegcompression *argp)``
30 File descriptor returned by :c:func:`open()`.
33 Pointer to struct :c:type:`v4l2_jpegcompression`.
38 These ioctls are **deprecated**. New drivers and applications should use
39 :ref:`JPEG class controls <jpeg-controls>` for image quality and JPEG
44 Ronald Bultje elaborates:
46 APP is some application-specific information. The application can set it
47 itself, and it'll be stored in the JPEG-encoded fields (eg; interlacing
48 information for in an AVI or so). COM is the same, but it's comments,
49 like 'encoded by me' or so.
51 jpeg_markers describes whether the huffman tables, quantization tables
52 and the restart interval information (all JPEG-specific stuff) should be
53 stored in the JPEG-encoded fields. These define how the JPEG field is
54 encoded. If you omit them, applications assume you've used standard
55 encoding. You usually do want to add them.
57 .. tabularcolumns:: |p{1.2cm}|p{3.0cm}|p{13.3cm}|
59 .. c:type:: v4l2_jpegcompression
61 .. flat-table:: struct v4l2_jpegcompression
69 :ref:`V4L2_CID_JPEG_COMPRESSION_QUALITY <jpeg-quality-control>`
70 control is exposed by a driver applications should use it instead
71 and ignore this field.
89 - See :ref:`jpeg-markers`. Deprecated. If
90 :ref:`V4L2_CID_JPEG_ACTIVE_MARKER <jpeg-active-marker-control>`
91 control is exposed by a driver applications should use it instead
92 and ignore this field.
94 .. tabularcolumns:: |p{6.6cm}|p{2.2cm}|p{8.7cm}|
98 .. flat-table:: JPEG Markers Flags
103 * - ``V4L2_JPEG_MARKER_DHT``
105 - Define Huffman Tables
106 * - ``V4L2_JPEG_MARKER_DQT``
108 - Define Quantization Tables
109 * - ``V4L2_JPEG_MARKER_DRI``
111 - Define Restart Interval
112 * - ``V4L2_JPEG_MARKER_COM``
115 * - ``V4L2_JPEG_MARKER_APP``
117 - App segment, driver will always use APP0
122 On success 0 is returned, on error -1 and the ``errno`` variable is set
123 appropriately. The generic error codes are described at the
124 :ref:`Generic Error Codes <gen-errors>` chapter.