summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--v4l/API/V4L1_API.html399
-rw-r--r--v4l/API/V4L2_API.html39683
-rw-r--r--v4l/ChangeLog9
3 files changed, 40090 insertions, 1 deletions
diff --git a/v4l/API/V4L1_API.html b/v4l/API/V4L1_API.html
new file mode 100644
index 000000000..4b3d8f640
--- /dev/null
+++ b/v4l/API/V4L1_API.html
@@ -0,0 +1,399 @@
+<HTML><HEAD>
+<TITLE>Video4Linux Kernel API Reference v0.1:19990430</TITLE>
+</HEAD>
+<! Revision History: >
+<! 4/30/1999 - Fred Gleason (fredg@wava.com)>
+<! Documented extensions for the Radio Data System (RDS) extensions >
+<BODY bgcolor="#ffffff">
+<H3>Devices</H3>
+Video4Linux provides the following sets of device files. These live on the
+character device formerly known as "/dev/bttv". /dev/bttv should be a
+symlink to /dev/video0 for most people.
+<P>
+<TABLE>
+<TR><TH>Device Name</TH><TH>Minor Range</TH><TH>Function</TH>
+<TR><TD>/dev/video</TD><TD>0-63</TD><TD>Video Capture Interface</TD>
+<TR><TD>/dev/radio</TD><TD>64-127</TD><TD>AM/FM Radio Devices</TD>
+<TR><TD>/dev/vtx</TD><TD>192-223</TD><TD>Teletext Interface Chips</TD>
+<TR><TD>/dev/vbi</TD><TD>224-239</TD><TD>Raw VBI Data (Intercast/teletext)</TD>
+</TABLE>
+<P>
+Video4Linux programs open and scan the devices to find what they are looking
+for. Capability queries define what each interface supports. The
+described API is only defined for video capture cards. The relevant subset
+applies to radio cards. Teletext interfaces talk the existing VTX API.
+<P>
+<H3>Capability Query Ioctl</H3>
+The <B>VIDIOCGCAP</B> ioctl call is used to obtain the capability
+information for a video device. The <b>struct video_capability</b> object
+passed to the ioctl is completed and returned. It contains the following
+information
+<P>
+<TABLE>
+<TR><TD><b>name[32]</b><TD>Canonical name for this interface</TD>
+<TR><TD><b>type</b><TD>Type of interface</TD>
+<TR><TD><b>channels</b><TD>Number of radio/tv channels if appropriate</TD>
+<TR><TD><b>audios</b><TD>Number of audio devices if appropriate</TD>
+<TR><TD><b>maxwidth</b><TD>Maximum capture width in pixels</TD>
+<TR><TD><b>maxheight</b><TD>Maximum capture height in pixels</TD>
+<TR><TD><b>minwidth</b><TD>Minimum capture width in pixels</TD>
+<TR><TD><b>minheight</b><TD>Minimum capture height in pixels</TD>
+</TABLE>
+<P>
+The type field lists the capability flags for the device. These are
+as follows
+<P>
+<TABLE>
+<TR><TH>Name</TH><TH>Description</TH>
+<TR><TD><b>VID_TYPE_CAPTURE</b><TD>Can capture to memory</TD>
+<TR><TD><b>VID_TYPE_TUNER</b><TD>Has a tuner of some form</TD>
+<TR><TD><b>VID_TYPE_TELETEXT</b><TD>Has teletext capability</TD>
+<TR><TD><b>VID_TYPE_OVERLAY</b><TD>Can overlay its image onto the frame buffer</TD>
+<TR><TD><b>VID_TYPE_CHROMAKEY</b><TD>Overlay is Chromakeyed</TD>
+<TR><TD><b>VID_TYPE_CLIPPING</b><TD>Overlay clipping is supported</TD>
+<TR><TD><b>VID_TYPE_FRAMERAM</b><TD>Overlay overwrites frame buffer memory</TD>
+<TR><TD><b>VID_TYPE_SCALES</b><TD>The hardware supports image scaling</TD>
+<TR><TD><b>VID_TYPE_MONOCHROME</b><TD>Image capture is grey scale only</TD>
+<TR><TD><b>VID_TYPE_SUBCAPTURE</b><TD>Capture can be of only part of the image</TD>
+</TABLE>
+<P>
+The minimum and maximum sizes listed for a capture device do not imply all
+that all height/width ratios or sizes within the range are possible. A
+request to set a size will be honoured by the largest available capture
+size whose capture is no large than the requested rectangle in either
+direction. For example the quickcam has 3 fixed settings.
+<P>
+<H3>Frame Buffer</H3>
+Capture cards that drop data directly onto the frame buffer must be told the
+base address of the frame buffer, its size and organisation. This is a
+privileged ioctl and one that eventually X itself should set.
+<P>
+The <b>VIDIOCSFBUF</b> ioctl sets the frame buffer parameters for a capture
+card. If the card does not do direct writes to the frame buffer then this
+ioctl will be unsupported. The <b>VIDIOCGFBUF</b> ioctl returns the
+currently used parameters. The structure used in both cases is a
+<b>struct video_buffer</b>.
+<P>
+<TABLE>
+<TR><TD><b>void *base</b></TD><TD>Base physical address of the buffer</TD>
+<TR><TD><b>int height</b></TD><TD>Height of the frame buffer</TD>
+<TR><TD><b>int width</b></TD><TD>Width of the frame buffer</TD>
+<TR><TD><b>int depth</b></TD><TD>Depth of the frame buffer</TD>
+<TR><TD><b>int bytesperline</b></TD><TD>Number of bytes of memory between the start of two adjacent lines</TD>
+</TABLE>
+<P>
+Note that these values reflect the physical layout of the frame buffer.
+The visible area may be smaller. In fact under XFree86 this is commonly the
+case. XFree86 DGA can provide the parameters required to set up this ioctl.
+Setting the base address to NULL indicates there is no physical frame buffer
+access.
+<P>
+<H3>Capture Windows</H3>
+The capture area is described by a <b>struct video_window</b>. This defines
+a capture area and the clipping information if relevant. The
+<b>VIDIOCGWIN</b> ioctl recovers the current settings and the
+<b>VIDIOCSWIN</b> sets new values. A successful call to <b>VIDIOCSWIN</b>
+indicates that a suitable set of parameters have been chosen. They do not
+indicate that exactly what was requested was granted. The program should
+call <b>VIDIOCGWIN</b> to check if the nearest match was suitable. The
+<b>struct video_window</b> contains the following fields.
+<P>
+<TABLE>
+<TR><TD><b>x</b><TD>The X co-ordinate specified in X windows format.</TD>
+<TR><TD><b>y</b><TD>The Y co-ordinate specified in X windows format.</TD>
+<TR><TD><b>width</b><TD>The width of the image capture.</TD>
+<TR><TD><b>height</b><TD>The height of the image capture.</TD>
+<TR><TD><b>chromakey</b><TD>A host order RGB32 value for the chroma key.</TD>
+<TR><TD><b>flags</b><TD>Additional capture flags.</TD>
+<TR><TD><b>clips</b><TD>A list of clipping rectangles. <em>(Set only)</em></TD>
+<TR><TD><b>clipcount</b><TD>The number of clipping rectangles. <em>(Set only)</em></TD>
+</TABLE>
+<P>
+Clipping rectangles are passed as an array. Each clip consists of the following
+fields available to the user.
+<P>
+<TABLE>
+<TR><TD><b>x</b></TD><TD>X co-ordinate of rectangle to skip</TD>
+<TR><TD><b>y</b></TD><TD>Y co-ordinate of rectangle to skip</TD>
+<TR><TD><b>width</b></TD><TD>Width of rectangle to skip</TD>
+<TR><TD><b>height</b></TD><TD>Height of rectangle to skip</TD>
+</TABLE>
+<P>
+Merely setting the window does not enable capturing. Overlay capturing
+(i.e. PCI-PCI transfer to the frame buffer of the video card)
+is activated by passing the <b>VIDIOCCAPTURE</b> ioctl a value of 1, and
+disabled by passing it a value of 0.
+<P>
+Some capture devices can capture a subfield of the image they actually see.
+This is indicated when VIDEO_TYPE_SUBCAPTURE is defined.
+The video_capture describes the time and special subfields to capture.
+The video_capture structure contains the following fields.
+<P>
+<TABLE>
+<TR><TD><b>x</b></TD><TD>X co-ordinate of source rectangle to grab</TD>
+<TR><TD><b>y</b></TD><TD>Y co-ordinate of source rectangle to grab</TD>
+<TR><TD><b>width</b></TD><TD>Width of source rectangle to grab</TD>
+<TR><TD><b>height</b></TD><TD>Height of source rectangle to grab</TD>
+<TR><TD><b>decimation</b></TD><TD>Decimation to apply</TD>
+<TR><TD><b>flags</b></TD><TD>Flag settings for grabbing</TD>
+</TABLE>
+The available flags are
+<P>
+<TABLE>
+<TR><TH>Name</TH><TH>Description</TH>
+<TR><TD><b>VIDEO_CAPTURE_ODD</b><TD>Capture only odd frames</TD>
+<TR><TD><b>VIDEO_CAPTURE_EVEN</b><TD>Capture only even frames</TD>
+</TABLE>
+<P>
+<H3>Video Sources</H3>
+Each video4linux video or audio device captures from one or more
+source <b>channels</b>. Each channel can be queries with the
+<b>VDIOCGCHAN</b> ioctl call. Before invoking this function the caller
+must set the channel field to the channel that is being queried. On return
+the <b>struct video_channel</b> is filled in with information about the
+nature of the channel itself.
+<P>
+The <b>VIDIOCSCHAN</b> ioctl takes an integer argument and switches the
+capture to this input. It is not defined whether parameters such as colour
+settings or tuning are maintained across a channel switch. The caller should
+maintain settings as desired for each channel. (This is reasonable as
+different video inputs may have different properties).
+<P>
+The <b>struct video_channel</b> consists of the following
+<P>
+<TABLE>
+<TR><TD><b>channel</b></TD><TD>The channel number</TD>
+<TR><TD><b>name</b></TD><TD>The input name - preferably reflecting the label
+on the card input itself</TD>
+<TR><TD><b>tuners</b></TD><TD>Number of tuners for this input</TD>
+<TR><TD><b>flags</b></TD><TD>Properties the tuner has</TD>
+<TR><TD><b>type</b></TD><TD>Input type (if known)</TD>
+<TR><TD><b>norm</b><TD>The norm for this channel</TD>
+</TABLE>
+<P>
+The flags defined are
+<P>
+<TABLE>
+<TR><TD><b>VIDEO_VC_TUNER</b><TD>Channel has tuners.</TD>
+<TR><TD><b>VIDEO_VC_AUDIO</b><TD>Channel has audio.</TD>
+<TR><TD><b>VIDEO_VC_NORM</b><TD>Channel has norm setting.</TD>
+</TABLE>
+<P>
+The types defined are
+<P>
+<TABLE>
+<TR><TD><b>VIDEO_TYPE_TV</b><TD>The input is a TV input.</TD>
+<TR><TD><b>VIDEO_TYPE_CAMERA</b><TD>The input is a camera.</TD>
+</TABLE>
+<P>
+<H3>Image Properties</H3>
+The image properties of the picture can be queried with the <b>VIDIOCGPICT</b>
+ioctl which fills in a <b>struct video_picture</b>. The <b>VIDIOCSPICT</b>
+ioctl allows values to be changed. All values except for the palette type
+are scaled between 0-65535.
+<P>
+The <b>struct video_picture</b> consists of the following fields
+<P>
+<TABLE>
+<TR><TD><b>brightness</b><TD>Picture brightness</TD>
+<TR><TD><b>hue</b><TD>Picture hue (colour only)</TD>
+<TR><TD><b>colour</b><TD>Picture colour (colour only)</TD>
+<TR><TD><b>contrast</b><TD>Picture contrast</TD>
+<TR><TD><b>whiteness</b><TD>The whiteness (greyscale only)</TD>
+<TR><TD><b>depth</b><TD>The capture depth (may need to match the frame buffer depth)</TD>
+<TR><TD><b>palette</b><TD>Reports the palette that should be used for this image</TD>
+</TABLE>
+<P>
+The following palettes are defined
+<P>
+<TABLE>
+<TR><TD><b>VIDEO_PALETTE_GREY</b><TD>Linear intensity grey scale (255 is brightest).</TD>
+<TR><TD><b>VIDEO_PALETTE_HI240</b><TD>The BT848 8bit colour cube.</TD>
+<TR><TD><b>VIDEO_PALETTE_RGB565</b><TD>RGB565 packed into 16 bit words.</TD>
+<TR><TD><b>VIDEO_PALETTE_RGB555</b><TD>RGV555 packed into 16 bit words, top bit undefined.</TD>
+<TR><TD><b>VIDEO_PALETTE_RGB24</b><TD>RGB888 packed into 24bit words.</TD>
+<TR><TD><b>VIDEO_PALETTE_RGB32</b><TD>RGB888 packed into the low 3 bytes of 32bit words. The top 8bits are undefined.</TD>
+<TR><TD><b>VIDEO_PALETTE_YUV422</b><TD>Video style YUV422 - 8bits packed 4bits Y 2bits U 2bits V</TD>
+<TR><TD><b>VIDEO_PALETTE_YUYV</b><TD>Describe me</TD>
+<TR><TD><b>VIDEO_PALETTE_UYVY</b><TD>Describe me</TD>
+<TR><TD><b>VIDEO_PALETTE_YUV420</b><TD>YUV420 capture</TD>
+<TR><TD><b>VIDEO_PALETTE_YUV411</b><TD>YUV411 capture</TD>
+<TR><TD><b>VIDEO_PALETTE_RAW</b><TD>RAW capture (BT848)</TD>
+<TR><TD><b>VIDEO_PALETTE_YUV422P</b><TD>YUV 4:2:2 Planar</TD>
+<TR><TD><b>VIDEO_PALETTE_YUV411P</b><TD>YUV 4:1:1 Planar</TD>
+</TABLE>
+<P>
+<H3>Tuning</H3>
+Each video input channel can have one or more tuners associated with it. Many
+devices will not have tuners. TV cards and radio cards will have one or more
+tuners attached.
+<P>
+Tuners are described by a <b>struct video_tuner</b> which can be obtained by
+the <b>VIDIOCGTUNER</b> ioctl. Fill in the tuner number in the structure
+then pass the structure to the ioctl to have the data filled in. The
+tuner can be switched using <b>VIDIOCSTUNER</b> which takes an integer argument
+giving the tuner to use. A struct tuner has the following fields
+<P>
+<TABLE>
+<TR><TD><b>tuner</b><TD>Number of the tuner</TD>
+<TR><TD><b>name</b><TD>Canonical name for this tuner (eg FM/AM/TV)</TD>
+<TR><TD><b>rangelow</b><TD>Lowest tunable frequency</TD>
+<TR><TD><b>rangehigh</b><TD>Highest tunable frequency</TD>
+<TR><TD><b>flags</b><TD>Flags describing the tuner</TD>
+<TR><TD><b>mode</b><TD>The video signal mode if relevant</TD>
+<TR><TD><b>signal</b><TD>Signal strength if known - between 0-65535</TD>
+</TABLE>
+<P>
+The following flags exist
+<P>
+<TABLE>
+<TR><TD><b>VIDEO_TUNER_PAL</b><TD>PAL tuning is supported</TD>
+<TR><TD><b>VIDEO_TUNER_NTSC</b><TD>NTSC tuning is supported</TD>
+<TR><TD><b>VIDEO_TUNER_SECAM</b><TD>SECAM tuning is supported</TD>
+<TR><TD><b>VIDEO_TUNER_LOW</b><TD>Frequency is in a lower range</TD>
+<TR><TD><b>VIDEO_TUNER_NORM</b><TD>The norm for this tuner is settable</TD>
+<TR><TD><b>VIDEO_TUNER_STEREO_ON</b><TD>The tuner is seeing stereo audio</TD>
+<TR><TD><b>VIDEO_TUNER_RDS_ON</b><TD>The tuner is seeing a RDS datastream</TD>
+<TR><TD><b>VIDEO_TUNER_MBS_ON</b><TD>The tuner is seeing a MBS datastream</TD>
+</TABLE>
+<P>
+The following modes are defined
+<P>
+<TABLE>
+<TR><TD><b>VIDEO_MODE_PAL</b><TD>The tuner is in PAL mode</TD>
+<TR><TD><b>VIDEO_MODE_NTSC</b><TD>The tuner is in NTSC mode</TD>
+<TR><TD><b>VIDEO_MODE_SECAM</b><TD>The tuner is in SECAM mode</TD>
+<TR><TD><b>VIDEO_MODE_AUTO</b><TD>The tuner auto switches, or mode does not apply</TD>
+</TABLE>
+<P>
+Tuning frequencies are an unsigned 32bit value in 1/16th MHz or if the
+<b>VIDEO_TUNER_LOW</b> flag is set they are in 1/16th KHz. The current
+frequency is obtained as an unsigned long via the <b>VIDIOCGFREQ</b> ioctl and
+set by the <b>VIDIOCSFREQ</b> ioctl.
+<P>
+<H3>Audio</H3>
+TV and Radio devices have one or more audio inputs that may be selected.
+The audio properties are queried by passing a <b>struct video_audio</b> to <b>VIDIOCGAUDIO</b> ioctl. The
+<b>VIDIOCSAUDIO</b> ioctl sets audio properties.
+<P>
+The structure contains the following fields
+<P>
+<TABLE>
+<TR><TD><b>audio</b><TD>The channel number</TD>
+<TR><TD><b>volume</b><TD>The volume level</TD>
+<TR><TD><b>bass</b><TD>The bass level</TD>
+<TR><TD><b>treble</b><TD>The treble level</TD>
+<TR><TD><b>flags</b><TD>Flags describing the audio channel</TD>
+<TR><TD><b>name</b><TD>Canonical name for the audio input</TD>
+<TR><TD><b>mode</b><TD>The mode the audio input is in</TD>
+<TR><TD><b>balance</b><TD>The left/right balance</TD>
+<TR><TD><b>step</b><TD>Actual step used by the hardware</TD>
+</TABLE>
+<P>
+The following flags are defined
+<P>
+<TABLE>
+<TR><TD><b>VIDEO_AUDIO_MUTE</b><TD>The audio is muted</TD>
+<TR><TD><b>VIDEO_AUDIO_MUTABLE</b><TD>Audio muting is supported</TD>
+<TR><TD><b>VIDEO_AUDIO_VOLUME</b><TD>The volume is controllable</TD>
+<TR><TD><b>VIDEO_AUDIO_BASS</b><TD>The bass is controllable</TD>
+<TR><TD><b>VIDEO_AUDIO_TREBLE</b><TD>The treble is controllable</TD>
+<TR><TD><b>VIDEO_AUDIO_BALANCE</b><TD>The balance is controllable</TD>
+</TABLE>
+<P>
+The following decoding modes are defined
+<P>
+<TABLE>
+<TR><TD><b>VIDEO_SOUND_MONO</b><TD>Mono signal</TD>
+<TR><TD><b>VIDEO_SOUND_STEREO</b><TD>Stereo signal (NICAM for TV)</TD>
+<TR><TD><b>VIDEO_SOUND_LANG1</b><TD>European TV alternate language 1</TD>
+<TR><TD><b>VIDEO_SOUND_LANG2</b><TD>European TV alternate language 2</TD>
+</TABLE>
+<P>
+<H3>Reading Images</H3>
+Each call to the <b>read</b> syscall returns the next available image
+from the device. It is up to the caller to set format and size (using
+the VIDIOCSPICT and VIDIOCSWIN ioctls) and then to pass a suitable
+size buffer and length to the function. Not all devices will support
+read operations.
+<P>
+A second way to handle image capture is via the mmap interface if supported.
+To use the mmap interface a user first sets the desired image size and depth
+properties. Next the VIDIOCGMBUF ioctl is issued. This reports the size
+of buffer to mmap and the offset within the buffer for each frame. The
+number of frames supported is device dependent and may only be one.
+<P>
+The video_mbuf structure contains the following fields
+<P>
+<TABLE>
+<TR><TD><b>size</b><TD>The number of bytes to map</TD>
+<TR><TD><b>frames</b><TD>The number of frames</TD>
+<TR><TD><b>offsets</b><TD>The offset of each frame</TD>
+</TABLE>
+<P>
+Once the mmap has been made the VIDIOCMCAPTURE ioctl starts the
+capture to a frame using the format and image size specified in the
+video_mmap (which should match or be below the initial query size).
+When the VIDIOCMCAPTURE ioctl returns the frame is <em>not</em>
+captured yet, the driver just instructed the hardware to start the
+capture. The application has to use the VIDIOCSYNC ioctl to wait
+until the capture of a frame is finished. VIDIOCSYNC takes the frame
+number you want to wait for as argument.
+<p>
+It is allowed to call VIDIOCMCAPTURE multiple times (with different
+frame numbers in video_mmap->frame of course) and thus have multiple
+outstanding capture requests. A simple way do to double-buffering
+using this feature looks like this:
+<pre>
+/* setup everything */
+VIDIOCMCAPTURE(0)
+while (whatever) {
+ VIDIOCMCAPTURE(1)
+ VIDIOCSYNC(0)
+ /* process frame 0 while the hardware captures frame 1 */
+ VIDIOCMCAPTURE(0)
+ VIDIOCSYNC(1)
+ /* process frame 1 while the hardware captures frame 0 */
+}
+</pre>
+Note that you are <em>not</em> limited to only two frames. The API
+allows up to 32 frames, the VIDIOCGMBUF ioctl returns the number of
+frames the driver granted. Thus it is possible to build deeper queues
+to avoid loosing frames on load peaks.
+<p>
+While capturing to memory the driver will make a "best effort" attempt
+to capture to screen as well if requested. This normally means all
+frames that "miss" memory mapped capture will go to the display.
+<P>
+A final ioctl exists to allow a device to obtain related devices if a
+driver has multiple components (for example video0 may not be associated
+with vbi0 which would cause an intercast display program to make a bad
+mistake). The VIDIOCGUNIT ioctl reports the unit numbers of the associated
+devices if any exist. The video_unit structure has the following fields.
+<P>
+<TABLE>
+<TR><TD><b>video</b><TD>Video capture device</TD>
+<TR><TD><b>vbi</b><TD>VBI capture device</TD>
+<TR><TD><b>radio</b><TD>Radio device</TD>
+<TR><TD><b>audio</b><TD>Audio mixer</TD>
+<TR><TD><b>teletext</b><TD>Teletext device</TD>
+</TABLE>
+<P>
+<H3>RDS Datastreams</H3>
+For radio devices that support it, it is possible to receive Radio Data
+System (RDS) data by means of a read() on the device. The data is packed in
+groups of three, as follows:
+<TABLE>
+<TR><TD>First Octet</TD><TD>Least Significant Byte of RDS Block</TD></TR>
+<TR><TD>Second Octet</TD><TD>Most Significant Byte of RDS Block
+<TR><TD>Third Octet</TD><TD>Bit 7:</TD><TD>Error bit. Indicates that
+an uncorrectable error occurred during reception of this block.</TD></TR>
+<TR><TD>&nbsp;</TD><TD>Bit 6:</TD><TD>Corrected bit. Indicates that
+an error was corrected for this data block.</TD></TR>
+<TR><TD>&nbsp;</TD><TD>Bits 5-3:</TD><TD>Received Offset. Indicates the
+offset received by the sync system.</TD></TR>
+<TR><TD>&nbsp;</TD><TD>Bits 2-0:</TD><TD>Offset Name. Indicates the
+offset applied to this data.</TD></TR>
+</TABLE>
+</BODY>
+</HTML>
diff --git a/v4l/API/V4L2_API.html b/v4l/API/V4L2_API.html
new file mode 100644
index 000000000..f1ef6aed3
--- /dev/null
+++ b/v4l/API/V4L2_API.html
@@ -0,0 +1,39683 @@
+<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
+<HTML
+><HEAD
+><TITLE
+>Video for Linux Two API Specification</TITLE
+><META
+NAME="GENERATOR"
+CONTENT="Modular DocBook HTML Stylesheet Version 1.7"></HEAD
+><BODY
+CLASS="BOOK"
+BGCOLOR="#FFFFFF"
+TEXT="#000000"
+LINK="#0000FF"
+VLINK="#840084"
+ALINK="#0000FF"
+><DIV
+CLASS="BOOK"
+><A
+NAME="INDEX"
+></A
+><DIV
+CLASS="TITLEPAGE"
+><H1
+CLASS="TITLE"
+><A
+NAME="AEN2"
+>Video for Linux Two API Specification</A
+></H1
+><H2
+CLASS="SUBTITLE"
+>Draft 0.8</H2
+><H3
+CLASS="AUTHOR"
+><A
+NAME="AEN6"
+></A
+>Michael H Schimek</H3
+><DIV
+CLASS="AFFILIATION"
+><DIV
+CLASS="ADDRESS"
+><P
+CLASS="ADDRESS"
+>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;<CODE
+CLASS="EMAIL"
+>&#60;<A
+HREF="mailto:mschimek@gmx.at"
+>mschimek@gmx.at</A
+>&#62;</CODE
+><br>
+&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;</P
+></DIV
+></DIV
+><H3
+CLASS="AUTHOR"
+><A
+NAME="AEN13"
+></A
+>Bill Dirks</H3
+><P
+CLASS="COPYRIGHT"
+>Copyright &copy; 1999, 2000, 2001, 2002, 2003, 2004 Bill Dirks, Michael H. Schimek</P
+><DIV
+CLASS="LEGALNOTICE"
+><P
+></P
+><A
+NAME="AEN25"
+></A
+><P
+>This document is copyrighted &copy; 1999-2004 by Bill
+Dirks and Michael H. Schimek.</P
+><P
+>Permission is granted to copy, distribute and/or modify
+this document under the terms of the GNU Free Documentation License,
+Version 1.1 or any later version published by the Free Software
+Foundation; with no Invariant Sections, with no Front-Cover Texts, and
+with no Back-Cover Texts. A copy of the license is included in the
+appendix entitled "GNU Free Documentation License".</P
+><P
+>Programming examples can be used without
+restriction.</P
+><P
+></P
+></DIV
+><HR></DIV
+><DIV
+CLASS="TOC"
+><DL
+><DT
+><B
+>Table of Contents</B
+></DT
+><DT
+><A
+HREF="#AEN71"
+>Introduction</A
+></DT
+><DT
+>1. <A
+HREF="#COMMON"
+>Common API Elements</A
+></DT
+><DD
+><DL
+><DT
+>1.1. <A
+HREF="#OPEN"
+>Opening and Closing Devices</A
+></DT
+><DD
+><DL
+><DT
+>1.1.1. <A
+HREF="#AEN100"
+>Device Naming</A
+></DT
+><DT
+>1.1.2. <A
+HREF="#RELATED"
+>Related Devices</A
+></DT
+><DT
+>1.1.3. <A
+HREF="#AEN153"
+>Multiple Opens</A
+></DT
+><DT
+>1.1.4. <A
+HREF="#AEN170"
+>Shared Data Streams</A
+></DT
+><DT
+>1.1.5. <A
+HREF="#AEN173"
+>Functions</A
+></DT
+></DL
+></DD
+><DT
+>1.2. <A
+HREF="#QUERYCAP"
+>Querying Capabilities</A
+></DT
+><DT
+>1.3. <A
+HREF="#APP-PRI"
+>Application Priority</A
+></DT
+><DT
+>1.4. <A
+HREF="#VIDEO"
+>Video Inputs and Outputs</A
+></DT
+><DT
+>1.5. <A
+HREF="#AUDIO"
+>Audio Inputs and Outputs</A
+></DT
+><DT
+>1.6. <A
+HREF="#TUNER"
+>Tuners and Modulators</A
+></DT
+><DD
+><DL
+><DT
+>1.6.1. <A
+HREF="#AEN296"
+>Tuners</A
+></DT
+><DT
+>1.6.2. <A
+HREF="#AEN318"
+>Modulators</A
+></DT
+><DT
+>1.6.3. <A
+HREF="#AEN337"
+>Radio Frequency</A
+></DT
+><DT
+>1.6.4. <A
+HREF="#AEN345"
+>Satellite Receivers</A
+></DT
+></DL
+></DD
+><DT
+>1.7. <A
+HREF="#STANDARD"
+>Video Standards</A
+></DT
+><DT
+>1.8. <A
+HREF="#CONTROL"
+>Controls</A
+></DT
+><DT
+>1.9. <A
+HREF="#FORMAT"
+>Data Formats</A
+></DT
+><DD
+><DL
+><DT
+>1.9.1. <A
+HREF="#AEN656"
+>Data Format Negotiation</A
+></DT
+><DT
+>1.9.2. <A
+HREF="#AEN689"
+>Image Format Enumeration</A
+></DT
+></DL
+></DD
+><DT
+>1.10. <A
+HREF="#CROP"
+>Cropping and Scaling</A
+></DT
+><DT
+>1.11. <A
+HREF="#STREAMING-PAR"
+>Streaming Parameters</A
+></DT
+></DL
+></DD
+><DT
+>2. <A
+HREF="#PIXFMT"
+>Image Formats</A
+></DT
+><DD
+><DL
+><DT
+>2.1. <A
+HREF="#AEN880"
+>Standard Image Formats</A
+></DT
+><DT
+>2.2. <A
+HREF="#COLORSPACES"
+>Colorspaces</A
+></DT
+><DT
+>2.3. <A
+HREF="#PIXFMT-RGB"
+>RGB Formats</A
+></DT
+><DT
+>2.4. <A
+HREF="#YUV-FORMATS"
+>YUV Formats</A
+></DT
+><DD
+><DL
+><DT
+><A
+HREF="#PIXFMT-GREY"
+><CODE
+CLASS="CONSTANT"
+>V4L2_PIX_FMT_GREY</CODE
+></A
+>&nbsp;--&nbsp;Grey-scale image.</DT
+><DT
+><A
+HREF="#PIXFMT-YUYV"
+><CODE
+CLASS="CONSTANT"
+>V4L2_PIX_FMT_YUYV</CODE
+></A
+>&nbsp;--&nbsp;Packed format with &frac12; horizontal chroma
+resolution, also known as YUV 4:2:2.</DT
+><DT
+><A
+HREF="#PIXFMT-UYVY"
+><CODE
+CLASS="CONSTANT"
+>V4L2_PIX_FMT_UYVY</CODE
+></A
+>&nbsp;--&nbsp;Variation of
+<CODE
+CLASS="CONSTANT"
+>V4L2_PIX_FMT_YUYV</CODE
+> with different order of samples
+in memory.</DT
+><DT
+><A
+HREF="#PIXFMT-Y41P"
+><CODE
+CLASS="CONSTANT"
+>V4L2_PIX_FMT_Y41P</CODE
+></A
+>&nbsp;--&nbsp;Packed format with &frac14; horizontal chroma
+resolution, also known as YUV 4:1:1.</DT
+><DT
+><A
+HREF="#PIXFMT-YVU420"
+><CODE
+CLASS="CONSTANT"
+>V4L2_PIX_FMT_YVU420</CODE
+>,
+<CODE
+CLASS="CONSTANT"
+>V4L2_PIX_FMT_YUV420</CODE
+></A
+>&nbsp;--&nbsp;Planar formats with &frac12; horizontal and
+vertical chroma resolution, also known as YUV 4:2:0.</DT
+><DT
+><A
+HREF="#PIXFMT-YVU410"
+><CODE
+CLASS="CONSTANT"
+>V4L2_PIX_FMT_YVU410</CODE
+>,
+<CODE
+CLASS="CONSTANT"
+>V4L2_PIX_FMT_YUV410</CODE
+></A
+>&nbsp;--&nbsp;Planar formats with &frac14; horizontal and
+vertical chroma resolution, also known as YUV 4:1:0.</DT
+><DT
+><A
+HREF="#PIXFMT-YUV422P"
+><CODE
+CLASS="CONSTANT"
+>V4L2_PIX_FMT_YUV422P</CODE
+></A
+>&nbsp;--&nbsp;Format with &frac12; horizontal chroma resolution,
+also known as YUV 4:2:2. Planar layout as opposed to
+<CODE
+CLASS="CONSTANT"
+>V4L2_PIX_FMT_YUYV</CODE
+>.</DT
+><DT
+><A
+HREF="#PIXFMT-YUV411P"
+><CODE
+CLASS="CONSTANT"
+>V4L2_PIX_FMT_YUV411P</CODE
+></A
+>&nbsp;--&nbsp;Format with &frac14; horizontal chroma resolution,
+also known as YUV 4:1:1. Planar layout as opposed to
+<CODE
+CLASS="CONSTANT"
+>V4L2_PIX_FMT_Y41P</CODE
+>.</DT
+><DT
+><A
+HREF="#AEN3002"
+><CODE
+CLASS="CONSTANT"
+>V4L2_PIX_FMT_NV12</CODE
+>,
+<CODE
+CLASS="CONSTANT"
+>V4L2_PIX_FMT_NV21</CODE
+></A
+>&nbsp;--&nbsp;Formats with &frac12; horizontal and vertical
+chroma resolution, also known as YUV 4:2:0. One luminance and one
+chrominance plane with alternating chroma samples as opposed to
+<CODE
+CLASS="CONSTANT"
+>V4L2_PIX_FMT_YVU420</CODE
+>.</DT
+></DL
+></DD
+><DT
+>2.5. <A
+HREF="#AEN3167"
+>Compressed Formats</A
+></DT
+><DT
+>2.6. <A
+HREF="#PIXFMT-RESERVED"
+>Reserved Format Identifiers</A
+></DT
+></DL
+></DD
+><DT
+>3. <A
+HREF="#IO"
+>Input/Output</A
+></DT
+><DD
+><DL
+><DT
+>3.1. <A
+HREF="#RW"
+>Read/Write</A
+></DT
+><DT
+>3.2. <A
+HREF="#MMAP"
+>Streaming I/O (Memory Mapping)</A
+></DT
+><DT
+>3.3. <A
+HREF="#USERP"
+>Streaming I/O (User Pointers)</A
+></DT
+><DT
+>3.4. <A
+HREF="#ASYNC"
+>Asynchronous I/O</A
+></DT
+><DT
+>3.5. <A
+HREF="#BUFFER"
+>Buffers</A
+></DT
+><DD
+><DL
+><DT
+>3.5.1. <A
+HREF="#AEN3738"
+>Timecodes</A
+></DT
+></DL
+></DD
+><DT
+>3.6. <A
+HREF="#FIELD-ORDER"
+>Field Order</A
+></DT
+></DL
+></DD
+><DT
+>4. <A
+HREF="#DEVICES"
+>Device Types</A
+></DT
+><DD
+><DL
+><DT
+>4.1. <A
+HREF="#CAPTURE"
+>Video Capture Interface</A
+></DT
+><DD
+><DL
+><DT
+>4.1.1. <A
+HREF="#AEN3960"
+>Querying Capabilities</A
+></DT
+><DT
+>4.1.2. <A
+HREF="#AEN3972"
+>Supplemental Functions</A
+></DT
+><DT
+>4.1.3. <A
+HREF="#AEN3982"
+>Image Format Negotiation</A
+></DT
+><DT
+>4.1.4. <A
+HREF="#AEN4024"
+>Reading Images</A
+></DT
+></DL
+></DD
+><DT
+>4.2. <A
+HREF="#OVERLAY"
+>Video Overlay Interface</A
+></DT
+><DD
+><DL
+><DT
+>4.2.1. <A
+HREF="#AEN4048"
+>Querying Capabilities</A
+></DT
+><DT
+>4.2.2. <A
+HREF="#AEN4056"
+>Supplemental Functions</A
+></DT
+><DT
+>4.2.3. <A
+HREF="#AEN4066"
+>Setup</A
+></DT
+><DT
+>4.2.4. <A
+HREF="#AEN4092"
+>Overlay Window</A
+></DT
+><DT
+>4.2.5. <A
+HREF="#AEN4266"
+>Enabling Overlay</A
+></DT
+></DL
+></DD
+><DT
+>4.3. <A
+HREF="#OUTPUT"
+>Video Output Interface</A
+></DT
+><DD
+><DL
+><DT
+>4.3.1. <A
+HREF="#AEN4279"
+>Querying Capabilities</A
+></DT
+><DT
+>4.3.2. <A
+HREF="#AEN4289"
+>Supplemental Functions</A
+></DT
+><DT
+>4.3.3. <A
+HREF="#AEN4299"
+>Image Format Negotiation</A
+></DT
+><DT
+>4.3.4. <A
+HREF="#AEN4341"
+>Writing Images</A
+></DT
+></DL
+></DD
+><DT
+>4.4. <A
+HREF="#CODEC"
+>Codec Interface</A
+></DT
+><DT
+>4.5. <A
+HREF="#EFFECT"
+>Effect Devices Interface</A
+></DT
+><DT
+>4.6. <A
+HREF="#RAW-VBI"
+>Raw VBI Data Interface</A
+></DT
+><DD
+><DL
+><DT
+>4.6.1. <A
+HREF="#AEN4383"
+>Querying Capabilities</A
+></DT
+><DT
+>4.6.2. <A
+HREF="#AEN4392"
+>Supplemental Functions</A
+></DT
+><DT
+>4.6.3. <A
+HREF="#AEN4399"
+>Raw VBI Format Negotiation</A
+></DT
+><DT
+>4.6.4. <A
+HREF="#AEN4571"
+>Reading and writing VBI images</A
+></DT
+></DL
+></DD
+><DT
+>4.7. <A
+HREF="#SLICED"
+>Sliced VBI Data Interface</A
+></DT
+><DD
+><DL
+><DT
+>4.7.1. <A
+HREF="#AEN4599"
+>Querying Capabilities</A
+></DT
+><DT
+>4.7.2. <A
+HREF="#AEN4608"
+>Supplemental Functions</A
+></DT
+><DT
+>4.7.3. <A
+HREF="#AEN4615"
+>Sliced VBI Format Negotiation</A
+></DT
+><DT
+>4.7.4. <A
+HREF="#AEN4760"
+>Reading and writing sliced VBI data</A
+></DT
+></DL
+></DD
+><DT
+>4.8. <A
+HREF="#TTX"
+>Teletext Interface</A
+></DT
+><DT
+>4.9. <A
+HREF="#RADIO"
+>Radio Interface</A
+></DT
+><DD
+><DL
+><DT
+>4.9.1. <A
+HREF="#AEN4799"
+>Querying Capabilities</A
+></DT
+><DT
+>4.9.2. <A
+HREF="#AEN4808"
+>Supplemental Functions</A
+></DT
+><DT
+>4.9.3. <A
+HREF="#AEN4814"
+>Programming</A
+></DT
+></DL
+></DD
+><DT
+>4.10. <A
+HREF="#RDS"
+>RDS Interface</A
+></DT
+></DL
+></DD
+><DT
+>I. <A
+HREF="#USER-FUNC"
+>Function Reference</A
+></DT
+><DD
+><DL
+><DT
+><A
+HREF="#FUNC-CLOSE"
+>close</A
+>&nbsp;--&nbsp;Close a V4L2 device</DT
+><DT
+><A
+HREF="#FUNC-IOCTL"
+>ioctl</A
+>&nbsp;--&nbsp;Program a V4L2 device</DT
+><DT
+><A
+HREF="#VIDIOC-CROPCAP"
+>ioctl VIDIOC_CROPCAP</A
+>&nbsp;--&nbsp;Information about the video cropping and scaling abilities.</DT
+><DT
+><A
+HREF="#VIDIOC-ENUMAUDIO"
+>ioctl VIDIOC_ENUMAUDIO</A
+>&nbsp;--&nbsp;Enumerate audio inputs</DT
+><DT
+><A
+HREF="#VIDIOC-ENUMAUDIOOUT"
+>ioctl VIDIOC_ENUMAUDOUT</A
+>&nbsp;--&nbsp;Enumerate audio outputs</DT
+><DT
+><A
+HREF="#VIDIOC-ENUM-FMT"
+>ioctl VIDIOC_ENUM_FMT</A
+>&nbsp;--&nbsp;Enumerate image formats</DT
+><DT
+><A
+HREF="#VIDIOC-ENUMINPUT"
+>ioctl VIDIOC_ENUMINPUT</A
+>&nbsp;--&nbsp;Enumerate video inputs</DT
+><DT
+><A
+HREF="#VIDIOC-ENUMOUTPUT"
+>ioctl VIDIOC_ENUMOUTPUT</A
+>&nbsp;--&nbsp;Enumerate video outputs</DT
+><DT
+><A
+HREF="#VIDIOC-ENUMSTD"
+>ioctl VIDIOC_ENUMSTD</A
+>&nbsp;--&nbsp;Enumerate supported video standards</DT
+><DT
+><A
+HREF="#VIDIOC-G-AUDIO"
+>ioctl VIDIOC_G_AUDIO, VIDIOC_S_AUDIO</A
+>&nbsp;--&nbsp;Query or select the current audio input and its
+attributes</DT
+><DT
+><A
+HREF="#VIDIOC-G-AUDIOOUT"
+>ioctl VIDIOC_G_AUDOUT, VIDIOC_S_AUDOUT</A
+>&nbsp;--&nbsp;Query or select the current audio output</DT
+><DT
+><A
+HREF="#VIDIOC-G-COMP"
+>ioctl VIDIOC_G_COMP, VIDIOC_S_COMP</A
+>&nbsp;--&nbsp;Get or set compression parameters</DT
+><DT
+><A
+HREF="#VIDIOC-G-CROP"
+>ioctl VIDIOC_G_CROP, VIDIOC_S_CROP</A
+>&nbsp;--&nbsp;Get or set the current cropping rectangle</DT
+><DT
+><A
+HREF="#VIDIOC-G-CTRL"
+>ioctl VIDIOC_G_CTRL, VIDIOC_S_CTRL</A
+>&nbsp;--&nbsp;Get or set the value of a control</DT
+><DT
+><A
+HREF="#VIDIOC-G-FBUF"
+>ioctl VIDIOC_G_FBUF, VIDIOC_S_FBUF</A
+>&nbsp;--&nbsp;Get or set frame buffer overlay parameters.</DT
+><DT
+><A
+HREF="#VIDIOC-G-FMT"
+>ioctl VIDIOC_G_FMT, VIDIOC_S_FMT, VIDIOC_TRY_FMT</A
+>&nbsp;--&nbsp;Get or set the data format, try a format.</DT
+><DT
+><A
+HREF="#VIDIOC-G-FREQUENCY"
+>ioctl VIDIOC_G_FREQUENCY, VIDIOC_S_FREQUENCY</A
+>&nbsp;--&nbsp;Get or set tuner or modulator radio
+frequency</DT
+><DT
+><A
+HREF="#VIDIOC-G-INPUT"
+>ioctl VIDIOC_G_INPUT, VIDIOC_S_INPUT</A
+>&nbsp;--&nbsp;Query or select the current video input</DT
+><DT
+><A
+HREF="#VIDIOC-G-JPEGCOMP"
+>ioctl VIDIOC_G_JPEGCOMP, VIDIOC_S_JPEGCOMP</A
+>&nbsp;--&nbsp;</DT
+><DT
+><A
+HREF="#VIDIOC-G-MODULATOR"
+>ioctl VIDIOC_G_MODULATOR, VIDIOC_S_MODULATOR</A
+>&nbsp;--&nbsp;Get or set modulator attributes</DT
+><DT
+><A
+HREF="#VIDIOC-G-OUTPUT"
+>ioctl VIDIOC_G_OUTPUT, VIDIOC_S_OUTPUT</A
+>&nbsp;--&nbsp;Query or select the current video output</DT
+><DT
+><A
+HREF="#VIDIOC-G-PARM"
+>ioctl VIDIOC_G_PARM, VIDIOC_S_PARM</A
+>&nbsp;--&nbsp;Get or set streaming parameters</DT
+><DT
+><A
+HREF="#VIDIOC-G-PRIORITY"
+>ioctl VIDIOC_G_PRIORITY, VIDIOC_S_PRIORITY</A
+>&nbsp;--&nbsp;Query or request the access priority associated with a
+file descriptor</DT
+><DT
+><A
+HREF="#VIDIOC-G-STD"
+>ioctl VIDIOC_G_STD, VIDIOC_S_STD</A
+>&nbsp;--&nbsp;Query or select the video standard of the current input</DT
+><DT
+><A
+HREF="#VIDIOC-G-TUNER"
+>ioctl VIDIOC_G_TUNER, VIDIOC_S_TUNER</A
+>&nbsp;--&nbsp;Get or set tuner attributes</DT
+><DT
+><A
+HREF="#VIDIOC-OVERLAY"
+>ioctl VIDIOC_OVERLAY</A
+>&nbsp;--&nbsp;Start or stop video overlay</DT
+><DT
+><A
+HREF="#VIDIOC-QBUF"
+>ioctl VIDIOC_QBUF, VIDIOC_DQBUF</A
+>&nbsp;--&nbsp;Exchange a buffer with the driver</DT
+><DT
+><A
+HREF="#VIDIOC-QUERYBUF"
+>ioctl VIDIOC_QUERYBUF</A
+>&nbsp;--&nbsp;Query the status of a buffer</DT
+><DT
+><A
+HREF="#VIDIOC-QUERYCAP"
+>ioctl VIDIOC_QUERYCAP</A
+>&nbsp;--&nbsp;Query device capabilities</DT
+><DT
+><A
+HREF="#VIDIOC-QUERYCTRL"
+>ioctl VIDIOC_QUERYCTRL, VIDIOC_QUERYMENU</A
+>&nbsp;--&nbsp;Enumerate controls and menu control items</DT
+><DT
+><A
+HREF="#VIDIOC-QUERYSTD"
+>ioctl VIDIOC_QUERYSTD</A
+>&nbsp;--&nbsp;Sense the video standard received by the current input</DT
+><DT
+><A
+HREF="#VIDIOC-REQBUFS"
+>ioctl VIDIOC_REQBUFS</A
+>&nbsp;--&nbsp;Initiate Memory Mapping or User Pointer I/O</DT
+><DT
+><A
+HREF="#VIDIOC-STREAMON"
+>ioctl VIDIOC_STREAMON, VIDIOC_STREAMOFF</A
+>&nbsp;--&nbsp;Start or stop streaming I/O.</DT
+><DT
+><A
+HREF="#FUNC-MMAP"
+>mmap</A
+>&nbsp;--&nbsp;Map device memory into application address space</DT
+><DT
+><A
+HREF="#FUNC-MUNMAP"
+>munmap</A
+>&nbsp;--&nbsp;Unmap device memory</DT
+><DT
+><A
+HREF="#FUNC-OPEN"
+>open</A
+>&nbsp;--&nbsp;Open a V4L2 device</DT
+><DT
+><A
+HREF="#FUNC-POLL"
+>poll</A
+>&nbsp;--&nbsp;Wait for some event on a file descriptor</DT
+><DT
+><A
+HREF="#FUNC-READ"
+>read</A
+>&nbsp;--&nbsp;Read from a V4L2 device</DT
+><DT
+><A
+HREF="#FUNC-SELECT"
+>select</A
+>&nbsp;--&nbsp;Synchronous I/O multiplexing</DT
+><DT
+><A
+HREF="#FUNC-WRITE"
+>write</A
+>&nbsp;--&nbsp;Write to a V4L2 device</DT
+></DL
+></DD
+><DT
+>5. <A
+HREF="#DRIVER"
+>Driver Interface</A
+></DT
+><DD
+><DL
+><DT
+>5.1. <A
+HREF="#FOO"
+>to do</A
+></DT
+><DD
+><DL
+><DT
+>5.1.1. <A
+HREF="#AEN9774"
+>to do</A
+></DT
+></DL
+></DD
+></DL
+></DD
+><DT
+>6. <A
+HREF="#COMPAT"
+>History</A
+></DT
+><DD
+><DL
+><DT
+>6.1. <A
+HREF="#DIFF-V4L"
+>Differences between V4L and V4L2</A
+></DT
+><DD
+><DL
+><DT
+>6.1.1. <A
+HREF="#AEN9783"
+>Opening and Closing Devices</A
+></DT
+><DT
+>6.1.2. <A
+HREF="#AEN9847"
+>Querying Capabilities</A
+></DT
+><DT
+>6.1.3. <A
+HREF="#AEN9977"
+>Video Sources</A
+></DT
+><DT
+>6.1.4. <A
+HREF="#AEN10033"
+>Tuning</A
+></DT
+><DT
+>6.1.5. <A
+HREF="#V4L-IMAGE-PROPERTIES"
+>Image Properties</A
+></DT
+><DT
+>6.1.6. <A
+HREF="#AEN10276"
+>Audio</A
+></DT
+><DT
+>6.1.7. <A
+HREF="#AEN10361"
+>Frame Buffer Overlay</A
+></DT
+><DT
+>6.1.8. <A
+HREF="#AEN10425"
+>Cropping</A
+></DT
+><DT
+>6.1.9. <A
+HREF="#AEN10458"
+>Reading Images, Memory Mapping</A
+></DT
+><DT
+>6.1.10. <A
+HREF="#AEN10541"
+>Reading Raw VBI Data</A
+></DT
+><DT
+>6.1.11. <A
+HREF="#AEN10594"
+>Miscellaneous</A
+></DT
+></DL
+></DD
+><DT
+>6.2. <A
+HREF="#HIST-V4L2"
+>History of the V4L2 API</A
+></DT
+><DD
+><DL
+><DT
+>6.2.1. <A
+HREF="#AEN10604"
+>Early Versions</A
+></DT
+><DT
+>6.2.2. <A
+HREF="#AEN10618"
+>V4L2 Version 0.16 1999-01-31</A
+></DT
+><DT
+>6.2.3. <A
+HREF="#AEN10621"
+>V4L2 Version 0.18 1999-03-16</A
+></DT
+><DT
+>6.2.4. <A
+HREF="#AEN10624"
+>V4L2 Version 0.19 1999-06-05</A
+></DT
+><DT
+>6.2.5. <A
+HREF="#AEN10633"
+>V4L2 Version 0.20 1999-09-10</A
+></DT
+><DT
+>6.2.6. <A
+HREF="#AEN10672"
+>V4L2 Version 0.20 incremental changes</A
+></DT
+><DT
+>6.2.7. <A
+HREF="#AEN10694"
+>V4L2 Version 0.20 2000-11-23</A
+></DT
+><DT
+>6.2.8. <A
+HREF="#AEN10709"
+>V4L2 Version 0.20 2002-07-25</A
+></DT
+><DT
+>6.2.9. <A
+HREF="#AEN10712"
+>V4L2 in Linux 2.5.46, 2002-10</A
+></DT
+><DT
+>6.2.10. <A
+HREF="#AEN11094"
+>V4L2 2003-06-19</A
+></DT
+><DT
+>6.2.11. <A
+HREF="#AEN11136"
+>V4L2 2003-11-05</A
+></DT
+><DT
+>6.2.12. <A
+HREF="#AEN11178"
+>V4L2 in Linux 2.6.6, 2004-05-09</A
+></DT
+><DT
+>6.2.13. <A
+HREF="#AEN11186"
+>V4L2 in Linux 2.6.8</A
+></DT
+><DT
+>6.2.14. <A
+HREF="#AEN11196"
+>V4L2 spec erratum 2004-08-01</A
+></DT
+></DL
+></DD
+><DT
+>6.3. <A
+HREF="#OTHER"
+>Relation of V4L2 to other Linux multimedia APIs</A
+></DT
+><DD
+><DL
+><DT
+>6.3.1. <A
+HREF="#XVIDEO"
+>X Video Extension</A
+></DT
+><DT
+>6.3.2. <A
+HREF="#AEN11233"
+>Digital Video</A
+></DT
+><DT
+>6.3.3. <A
+HREF="#AEN11237"
+>Audio Interfaces</A
+></DT
+></DL
+></DD
+></DL
+></DD
+><DT
+>A. <A
+HREF="#VIDEODEV"
+>Video For Linux Two Header File</A
+></DT
+><DT
+>B. <A
+HREF="#CAPTURE-EXAMPLE"
+>Video Capture Example</A
+></DT
+><DT
+>C. <A
+HREF="#FDL"
+>GNU Free Documentation License</A
+></DT
+><DD
+><DL
+><DT
+>C.1. <A
+HREF="#FDL-PREAMBLE"
+>0. PREAMBLE</A
+></DT
+><DT
+>C.2. <A
+HREF="#FDL-SECTION1"
+>1. APPLICABILITY AND DEFINITIONS</A
+></DT
+><DT
+>C.3. <A
+HREF="#FDL-SECTION2"
+>2. VERBATIM COPYING</A
+></DT
+><DT
+>C.4. <A
+HREF="#FDL-SECTION3"
+>3. COPYING IN QUANTITY</A
+></DT
+><DT
+>C.5. <A
+HREF="#FDL-SECTION4"
+>4. MODIFICATIONS</A
+></DT
+><DT
+>C.6. <A
+HREF="#FDL-SECTION5"
+>5. COMBINING DOCUMENTS</A
+></DT
+><DT
+>C.7. <A
+HREF="#FDL-SECTION6"
+>6. COLLECTIONS OF DOCUMENTS</A
+></DT
+><DT
+>C.8. <A
+HREF="#FDL-SECTION7"
+>7. AGGREGATION WITH INDEPENDENT WORKS</A
+></DT
+><DT
+>C.9. <A
+HREF="#FDL-SECTION8"
+>8. TRANSLATION</A
+></DT
+><DT
+>C.10. <A
+HREF="#FDL-SECTION9"
+>9. TERMINATION</A
+></DT
+><DT
+>C.11. <A
+HREF="#FDL-SECTION10"
+>10. FUTURE REVISIONS OF THIS LICENSE</A
+></DT
+><DT
+>C.12. <A
+HREF="#FDL-USING"
+>Addendum</A
+></DT
+></DL
+></DD
+><DT
+><A
+HREF="#AEN11623"
+>Bibliography</A
+></DT
+></DL
+></DIV
+><DIV
+CLASS="LOT"
+><DL
+CLASS="LOT"
+><DT
+><B
+>List of Tables</B
+></DT
+><DT
+>1-1. <A
+HREF="#CONTROL-ID"
+>Control IDs</A
+></DT
+><DT
+>2-1. <A
+HREF="#V4L2-PIX-FORMAT"
+>struct <CODE
+CLASS="STRUCTNAME"
+>v4l2_pix_format</CODE
+></A
+></DT
+><DT
+>2-2. <A
+HREF="#V4L2-COLORSPACE"
+>enum v4l2_colorspace</A
+></DT
+><DT
+>2-3. <A
+HREF="#RGB-FORMATS"
+>Packed RGB Image Formats</A
+></DT
+><DT
+>2-4. <A
+HREF="#RESERVED-FORMATS"
+>Reserved Image Formats</A
+></DT
+><DT
+>3-1. <A
+HREF="#V4L2-BUFFER"
+>struct <CODE
+CLASS="STRUCTNAME"
+>v4l2_buffer</CODE
+></A
+></DT
+><DT
+>3-2. <A
+HREF="#V4L2-BUF-TYPE"
+>enum v4l2_buf_type</A
+></DT
+><DT
+>3-3. <A
+HREF="#BUFFER-FLAGS"
+>Buffer Flags</A
+></DT
+><DT
+>3-4. <A
+HREF="#V4L2-MEMORY"
+>enum v4l2_memory</A
+></DT
+><DT
+>3-5. <A
+HREF="#V4L2-TIMECODE"
+>struct <CODE
+CLASS="STRUCTNAME"
+>v4l2_timecode</CODE
+></A
+></DT
+><DT
+>3-6. <A
+HREF="#TIMECODE-TYPE"
+>Timecode Types</A
+></DT
+><DT
+>3-7. <A
+HREF="#TIMECODE-FLAGS"
+>Timecode Flags</A
+></DT
+><DT
+>3-8. <A
+HREF="#V4L2-FIELD"
+>enum v4l2_field</A
+></DT
+><DT
+>4-1. <A
+HREF="#V4L2-WINDOW"
+>struct <CODE
+CLASS="STRUCTNAME"
+>v4l2_window</CODE
+></A
+></DT
+><DT
+>4-2. <A
+HREF="#V4L2-CLIP"
+>struct <CODE
+CLASS="STRUCTNAME"
+>v4l2_clip</CODE
+><A
+NAME="AEN4216"
+HREF="#FTN.AEN4216"
+><SPAN
+CLASS="footnote"
+>[22]</SPAN
+></A
+></A
+></DT
+><DT
+>4-3. <A
+HREF="#V4L2-RECT"
+>struct <CODE
+CLASS="STRUCTNAME"
+>v4l2_rect</CODE
+></A
+></DT
+><DT
+>4-4. <A
+HREF="#V4L2-VBI-FORMAT"
+>struct <CODE
+CLASS="STRUCTNAME"
+>v4l2_vbi_format</CODE
+></A
+></DT
+><DT
+>4-5. <A
+HREF="#VBIFMT-FLAGS"
+>Raw VBI Format Flags</A
+></DT
+><DT
+>4-6. <A
+HREF="#V4L2-SLICED-VBI-FORMAT"
+>struct <CODE
+CLASS="STRUCTNAME"
+>v4l2_sliced_vbi_format</CODE
+></A
+></DT
+><DT
+>4-7. <A
+HREF="#V4L2-SLICED-DATA"
+>struct <CODE
+CLASS="STRUCTNAME"
+>v4l2_sliced_data</CODE
+></A
+></DT
+><DT
+>4-8. <A
+HREF="#SLICED-VBI-TYPES"
+>Sliced VBI data formats</A
+></DT
+><DT
+>1. <A
+HREF="#V4L2-CROPCAP"
+>struct <CODE
+CLASS="STRUCTNAME"
+>v4l2_cropcap</CODE
+></A
+></DT
+><DT
+>2. <A
+HREF="#V4L2-RECT-CROP"
+>struct <CODE
+CLASS="STRUCTNAME"
+>v4l2_rect</CODE
+></A
+></DT
+><DT
+>1. <A
+HREF="#V4L2-FMTDESC"
+>struct <CODE
+CLASS="STRUCTNAME"
+>v4l2_fmtdesc</CODE
+></A
+></DT
+><DT
+>2. <A
+HREF="#FMTDESC-FLAGS"
+>Image Format Description Flags</A
+></DT
+><DT
+>1. <A
+HREF="#V4L2-INPUT"
+>struct <CODE
+CLASS="STRUCTNAME"
+>v4l2_input</CODE
+></A
+></DT
+><DT
+>2. <A
+HREF="#INPUT-TYPE"
+>Input Types</A
+></DT
+><DT
+>3. <A
+HREF="#INPUT-STATUS"
+>Input Status Flags</A
+></DT
+><DT
+>1. <A
+HREF="#V4L2-OUTPUT"
+>struct <CODE
+CLASS="STRUCTNAME"
+>v4l2_output</CODE
+></A
+></DT
+><DT
+>2. <A
+HREF="#OUTPUT-TYPE"
+>Output Type</A
+></DT
+><DT
+>1. <A
+HREF="#V4L2-STANDARD"
+>struct <CODE
+CLASS="STRUCTNAME"
+>v4l2_standard</CODE
+></A
+></DT
+><DT
+>2. <A
+HREF="#V4L2-FRACT"
+>struct <CODE
+CLASS="STRUCTNAME"
+>v4l2_fract</CODE
+></A
+></DT
+><DT
+>3. <A
+HREF="#V4L2-STD-ID"
+>typedef <CODE
+CLASS="STRUCTNAME"
+>v4l2_std_id</CODE
+></A
+></DT
+><DT
+>4. <A
+HREF="#VIDEO-STANDARDS"
+>Video Standards (based on [<A
+HREF="#ITU470"
+><ABBR
+CLASS="ABBREV"
+>ITU470</ABBR
+></A
+>])</A
+></DT
+><DT
+>1. <A
+HREF="#V4L2-AUDIO"
+>struct <CODE
+CLASS="STRUCTNAME"
+>v4l2_audio</CODE
+></A
+></DT
+><DT
+>2. <A
+HREF="#AUDIO-CAPABILITY"
+>Audio Capability Flags</A
+></DT
+><DT
+>3. <A
+HREF="#AUDIO-MODE"
+>Audio Modes</A
+></DT
+><DT
+>1. <A
+HREF="#V4L2-AUDIOOUT"
+>struct <CODE
+CLASS="STRUCTNAME"
+>v4l2_audioout</CODE
+></A
+></DT
+><DT
+>1. <A
+HREF="#V4L2-COMPRESSION"
+>struct <CODE
+CLASS="STRUCTNAME"
+>v4l2_compression</CODE
+></A
+></DT
+><DT
+>1. <A
+HREF="#V4L2-CROP"
+>struct <CODE
+CLASS="STRUCTNAME"
+>v4l2_crop</CODE
+></A
+></DT
+><DT
+>1. <A
+HREF="#V4L2-CONTROL"
+>struct <CODE
+CLASS="STRUCTNAME"
+>v4l2_control</CODE
+></A
+></DT
+><DT
+>1. <A
+HREF="#V4L2-FRAMEBUFFER"
+>struct <CODE
+CLASS="STRUCTNAME"
+>v4l2_framebuffer</CODE
+></A
+></DT
+><DT
+>2. <A
+HREF="#FRAMEBUFFER-CAP"
+>Frame Buffer Capability Flags</A
+></DT
+><DT
+>3. <A
+HREF="#FRAMEBUFFER-FLAGS"
+>Frame Buffer Flags</A
+></DT
+><DT
+>1. <A
+HREF="#V4L2-FORMAT"
+>struct <CODE
+CLASS="STRUCTNAME"
+>v4l2_format</CODE
+></A
+></DT
+><DT
+>1. <A
+HREF="#V4L2-FREQUENCY"
+>struct <CODE
+CLASS="STRUCTNAME"
+>v4l2_frequency</CODE
+></A
+></DT
+><DT
+>1. <A
+HREF="#V4L2-JPEGCOMPRESSION"
+>struct <CODE
+CLASS="STRUCTNAME"
+>v4l2_jpegcompression</CODE
+></A
+></DT
+><DT
+>2. <A
+HREF="#JPEG-MARKERS"
+>JPEG Markers Flags</A
+></DT
+><DT
+>1. <A
+HREF="#V4L2-MODULATOR"
+>struct <CODE
+CLASS="STRUCTNAME"
+>v4l2_modulator</CODE
+></A
+></DT
+><DT
+>2. <A
+HREF="#MODULATOR-TXSUBCHANS"
+>Modulator Audio Transmission Flags</A
+></DT
+><DT
+>1. <A
+HREF="#V4L2-STREAMPARM"
+>struct <CODE
+CLASS="STRUCTNAME"
+>v4l2_streamparm</CODE
+></A
+></DT
+><DT
+>2. <A
+HREF="#V4L2-CAPTUREPARM"
+>struct <CODE
+CLASS="STRUCTNAME"
+>v4l2_captureparm</CODE
+></A
+></DT
+><DT
+>3. <A
+HREF="#V4L2-OUTPUTPARM"
+>struct <CODE
+CLASS="STRUCTNAME"
+>v4l2_outputparm</CODE
+></A
+></DT
+><DT
+>4. <A
+HREF="#PARM-CAPS"
+>Streaming Parameters Capabilites</A
+></DT
+><DT
+>5. <A
+HREF="#PARM-FLAGS"
+>Capture Parameters Flags</A
+></DT
+><DT
+>1. <A
+HREF="#V4L2-PRIORITY"
+>enum v4l2_priority</A
+></DT
+><DT
+>1. <A
+HREF="#V4L2-TUNER"
+>struct <CODE
+CLASS="STRUCTNAME"
+>v4l2_tuner</CODE
+></A
+></DT
+><DT
+>2. <A
+HREF="#V4L2-TUNER-TYPE"
+>enum v4l2_tuner_type</A
+></DT
+><DT
+>3. <A
+HREF="#TUNER-CAPABILITY"
+>Tuner and Modulator Capability Flags</A
+></DT
+><DT
+>4. <A
+HREF="#TUNER-RXSUBCHANS"
+>Tuner Audio Reception Flags</A
+></DT
+><DT
+>5. <A
+HREF="#TUNER-AUDMODE"
+>Tuner Audio Modes</A
+></DT
+><DT
+>6. <A
+HREF="#TUNER-MATRIX"
+>Tuner Audio Matrix</A
+></DT
+><DT
+>1. <A
+HREF="#V4L2-CAPABILITY"
+>struct <CODE
+CLASS="STRUCTNAME"
+>v4l2_capability</CODE
+></A
+></DT
+><DT
+>2. <A
+HREF="#DEVICE-CAPABILITIES"
+>Device Capabilities Flags</A
+></DT
+><DT
+>1. <A
+HREF="#V4L2-QUERYCTRL"
+>struct <CODE
+CLASS="STRUCTNAME"
+>v4l2_queryctrl</CODE
+></A
+></DT
+><DT
+>2. <A
+HREF="#V4L2-QUERYMENU"
+>struct <CODE
+CLASS="STRUCTNAME"
+>v4l2_querymenu</CODE
+></A
+></DT
+><DT
+>3. <A
+HREF="#V4L2-CTRL-TYPE"
+>enum v4l2_ctrl_type</A
+></DT
+><DT
+>4. <A
+HREF="#CONTROL-FLAGS"
+>Control Flags</A
+></DT
+><DT
+>1. <A
+HREF="#V4L2-REQUESTBUFFERS"
+>struct <CODE
+CLASS="STRUCTNAME"
+>v4l2_requestbuffers</CODE
+></A
+></DT
+><DT
+>6-1. <A
+HREF="#V4L-DEV"
+>V4L Device Types, Names and Numbers</A
+></DT
+></DL
+></DIV
+><DIV
+CLASS="LOT"
+><DL
+CLASS="LOT"
+><DT
+><B
+>List of Figures</B
+></DT
+><DT
+>1-1. <A
+HREF="#CROP-SCALE"
+>Cropping and Scaling</A
+></DT
+><DT
+>3-1. <A
+HREF="#FIELDSEQ-TB"
+>Field Order, Top Field First Transmitted</A
+></DT
+><DT
+>3-2. <A
+HREF="#FIELDSEQ-BT"
+>Field Order, Bottom Field First Transmitted</A
+></DT
+><DT
+>4-1. <A
+HREF="#VBI-HSYNC"
+>Line synchronization</A
+></DT
+><DT
+>4-2. <A
+HREF="#VBI-525"
+>ITU-R 525 line numbering (M/NTSC and M/PAL)</A
+></DT
+><DT
+>4-3. <A
+HREF="#VBI-625"
+>ITU-R 625 line numbering</A
+></DT
+></DL
+></DIV
+><DIV
+CLASS="LOT"
+><DL
+CLASS="LOT"
+><DT
+><B
+>List of Examples</B
+></DT
+><DT
+>1-1. <A
+HREF="#AEN228"
+>Information about the current video input</A
+></DT
+><DT
+>1-2. <A
+HREF="#AEN236"
+>Switching to the first video input</A
+></DT
+><DT
+>1-3. <A
+HREF="#AEN282"
+>Information about the current audio input</A
+></DT
+><DT
+>1-4. <A
+HREF="#AEN288"
+>Switching to the first audio input</A
+></DT
+><DT
+>1-5. <A
+HREF="#AEN410"
+>Information about the current video standard</A
+></DT
+><DT
+>1-6. <A
+HREF="#AEN419"
+>Listing the video standards supported by the current
+input</A
+></DT
+><DT
+>1-7. <A
+HREF="#AEN430"
+>Selecting a new video standard</A
+></DT
+><DT
+>1-8. <A
+HREF="#AEN630"
+>Enumerating all controls</A
+></DT
+><DT
+>1-9. <A
+HREF="#AEN641"
+>Changing controls</A
+></DT
+><DT
+>1-10. <A
+HREF="#AEN747"
+>Resetting the cropping parameters</A
+></DT
+><DT
+>1-11. <A
+HREF="#AEN757"
+>Simple downscaling</A
+></DT
+><DT
+>1-12. <A
+HREF="#AEN765"
+>Current scaling factor and pixel aspect</A
+></DT
+><DT
+>2-1. <A
+HREF="#AEN984"
+>ITU-R Rec. BT.601 color conversion</A
+></DT
+><DT
+>2-2. <A
+HREF="#AEN1675"
+><CODE
+CLASS="CONSTANT"
+>V4L2_PIX_FMT_BGR24</CODE
+> 4 &times; 4 pixel
+image</A
+></DT
+><DT
+>2-1. <A
+HREF="#AEN1819"
+><CODE
+CLASS="CONSTANT"
+>V4L2_PIX_FMT_GREY</CODE
+> 4 &times; 4
+pixel image</A
+></DT
+><DT
+>2-1. <A
+HREF="#AEN1881"
+><CODE
+CLASS="CONSTANT"
+>V4L2_PIX_FMT_YUYV</CODE
+> 4 &times; 4
+pixel image</A
+></DT
+><DT
+>2-1. <A
+HREF="#AEN2026"
+><CODE
+CLASS="CONSTANT"
+>V4L2_PIX_FMT_UYVY</CODE
+> 4 &times; 4
+pixel image</A
+></DT
+><DT
+>2-1. <A
+HREF="#AEN2175"
+><CODE
+CLASS="CONSTANT"
+>V4L2_PIX_FMT_Y41P</CODE
+> 8 &times; 4
+pixel image</A
+></DT
+><DT
+>2-1. <A
+HREF="#AEN2402"
+><CODE
+CLASS="CONSTANT"
+>V4L2_PIX_FMT_YVU420</CODE
+> 4 &times; 4
+pixel image</A
+></DT
+><DT
+>2-1. <A
+HREF="#AEN2564"
+><CODE
+CLASS="CONSTANT"
+>V4L2_PIX_FMT_YVU410</CODE
+> 4 &times; 4
+pixel image</A
+></DT
+><DT
+>2-1. <A
+HREF="#AEN2702"
+><CODE
+CLASS="CONSTANT"
+>V4L2_PIX_FMT_YUV422P</CODE
+> 4 &times; 4
+pixel image</A
+></DT
+><DT
+>2-1. <A
+HREF="#AEN2869"
+><CODE
+CLASS="CONSTANT"
+>V4L2_PIX_FMT_YUV411P</CODE
+> 4 &times; 4
+pixel image</A
+></DT
+><DT
+>2-1. <A
+HREF="#AEN3026"
+><CODE
+CLASS="CONSTANT"
+>V4L2_PIX_FMT_NV12</CODE
+> 4 &times; 4
+pixel image</A
+></DT
+><DT
+>3-1. <A
+HREF="#AEN3316"
+>Mapping buffers</A
+></DT
+><DT
+>3-2. <A
+HREF="#AEN3392"
+>Initiating streaming I/O with user pointers</A
+></DT
+></DL
+></DIV
+><DIV
+CLASS="PREFACE"
+><HR><H1
+><A
+NAME="AEN71"
+></A
+>Introduction</H1
+><P
+>[to do]</P
+><P
+>If you have questions or ideas regarding the API, please try
+the Video4Linux mailing list: <A
+HREF="https://listman.redhat.com/mailman/listinfo/video4linux-list"
+TARGET="_top"
+>https://listman.redhat.com/mailman/listinfo/video4linux-list</A
+></P
+><P
+>For documentation related requests contact the maintainer at
+<A
+HREF="mailto:mschimek@gmx.at"
+TARGET="_top"
+>mschimek@gmx.at</A
+>.</P
+><P
+>The latest version of this document and the DocBook SGML
+sources is currently hosted at <A
+HREF="http://bytesex.org"
+TARGET="_top"
+>http://bytesex.org</A
+>, site of the V4L
+and V4L2 source code maintainer Gerd Knorr.</P
+></DIV
+><DIV
+CLASS="CHAPTER"
+><HR><H1
+><A
+NAME="COMMON"
+></A
+>Chapter 1. Common API Elements</H1
+><P
+>Programming a V4L2 device consists of these
+steps:</P
+><P
+></P
+><UL
+><LI
+><P
+>Opening the device</P
+></LI
+><LI
+><P
+>Changing device properties, selecting a video and audio
+input, video standard, picture brightness a.&nbsp;o.</P
+></LI
+><LI
+><P
+>Negotiating a data format</P
+></LI
+><LI
+><P
+>Negotiating an input/output method</P
+></LI
+><LI
+><P
+>The actual input/output loop</P
+></LI
+><LI
+><P
+>Closing the device</P
+></LI
+></UL
+><P
+>In practice most steps are optional and can be executed out of
+order. It depends on the V4L2 device type, you can read about the
+details in <A
+HREF="#DEVICES"
+>Chapter 4</A
+>. In this chapter we will discuss
+the basic concepts applicable to all devices.</P
+><DIV
+CLASS="SECTION"
+><HR><H2
+CLASS="SECTION"
+><A
+NAME="OPEN"
+>1.1. Opening and Closing Devices</A
+></H2
+><DIV
+CLASS="SECTION"
+><H3
+CLASS="SECTION"
+><A
+NAME="AEN100"
+>1.1.1. Device Naming</A
+></H3
+><P
+>V4L2 drivers are implemented as kernel modules, loaded
+manually by the system administrator or automatically when a device is
+first opened. The driver modules plug into the "videodev" kernel
+module. It provides helper functions and a common application
+interface as specified in this document.</P
+><P
+>Each driver thus loaded registers one or more device nodes
+with major number 81 and a minor number between 0 and 255. Assigning
+minor numbers to V4L2 devices is entirely up to the system administrator,
+this is primarily intended to solve conflicts between devices.<A
+NAME="AEN104"
+HREF="#FTN.AEN104"
+><SPAN
+CLASS="footnote"
+>[1]</SPAN
+></A
+> The module options to select minor numbers are named
+after the device special file with a "_nr" suffix. For example "video_nr"
+for <TT
+CLASS="FILENAME"
+>/dev/video</TT
+> video capture devices. The number is
+an offset to the base minor number associated with the device type.
+<A
+NAME="AEN107"
+HREF="#FTN.AEN107"
+><SPAN
+CLASS="footnote"
+>[2]</SPAN
+></A
+> When the driver supports multiple devices of the same
+type more than one minor number can be assigned, separated by commas:
+<DIV
+CLASS="INFORMALEXAMPLE"
+><P
+></P
+><A
+NAME="AEN109"
+></A
+><PRE
+CLASS="SCREEN"
+>&gt; insmod mydriver.o video_nr=0,1 radio_nr=0,1</PRE
+><P
+></P
+></DIV
+></P
+><P
+>In <TT
+CLASS="FILENAME"
+>/etc/modules.conf</TT
+> this may be
+written as: <DIV
+CLASS="INFORMALEXAMPLE"
+><P
+></P
+><A
+NAME="AEN113"
+></A
+><PRE
+CLASS="SCREEN"
+>alias char-major-81-0 mydriver
+alias char-major-81-1 mydriver
+alias char-major-81-64 mydriver <A
+NAME="ALIAS"
+><IMG
+SRC="/usr/share/sgml/docbook/stylesheet/dsssl/modular/images/callouts1.gif"
+HSPACE="0"
+VSPACE="0"
+BORDER="0"
+ALT="(1)"></A
+>
+options mydriver video_nr=0,1 radio_nr=0,1 <A
+NAME="OPTIONS"
+><IMG
+SRC="/usr/share/sgml/docbook/stylesheet/dsssl/modular/images/callouts2.gif"
+HSPACE="0"
+VSPACE="0"
+BORDER="0"
+ALT="(2)"></A
+>
+ </PRE
+><DIV
+CLASS="CALLOUTLIST"
+><DL
+COMPACT="COMPACT"
+><DT
+><A
+HREF="#ALIAS"
+><IMG
+SRC="/usr/share/sgml/docbook/stylesheet/dsssl/modular/images/callouts1.gif"
+HSPACE="0"
+VSPACE="0"
+BORDER="0"
+ALT="(1)"></A
+></DT
+><DD
+>When an application attempts to open a device
+special file with major number 81 and minor number 0, 1, or 64, load
+"mydriver" (and the "videodev" module it depends upon).</DD
+><DT
+><A
+HREF="#OPTIONS"
+><IMG
+SRC="/usr/share/sgml/docbook/stylesheet/dsssl/modular/images/callouts2.gif"
+HSPACE="0"
+VSPACE="0"
+BORDER="0"
+ALT="(2)"></A
+></DT
+><DD
+>Register the first two video capture devices with
+minor number 0 and 1 (base number is 0), the first two radio device
+with minor number 64 and 65 (base 64).</DD
+></DL
+></DIV
+><P
+></P
+></DIV
+> When no minor number is given as module
+option the driver supplies a default. <A
+HREF="#DEVICES"
+>Chapter 4</A
+>
+recommends the base minor numbers to be used for the various device
+types. Obviously minor numbers must be unique. When the number is
+already in use the <SPAN
+CLASS="emphasis"
+><I
+CLASS="EMPHASIS"
+>offending device</I
+></SPAN
+> will not be
+registered. </P
+><P
+>By convention system administrators create various
+character device special files with these major and minor numbers in
+the <TT
+CLASS="FILENAME"
+>/dev</TT
+> directory. The names recomended for the
+different V4L2 device types are listed in <A
+HREF="#DEVICES"
+>Chapter 4</A
+>.</P
+><P
+>The creation of character special files (with
+<SPAN
+CLASS="APPLICATION"
+>mknod</SPAN
+>) is a privileged operation and
+devices cannot be opened by major and minor number. That means
+applications cannot <SPAN
+CLASS="emphasis"
+><I
+CLASS="EMPHASIS"
+>reliable</I
+></SPAN
+> scan for loaded or
+installed drivers. The user must enter a device name, or the
+application can try the conventional device names.</P
+><P
+>Under the device filesystem (devfs) the minor number
+options are ignored. V4L2 drivers (or by proxy the "videodev" module)
+automatically create the required device files in the
+<TT
+CLASS="FILENAME"
+>/dev/v4l</TT
+> directory using the conventional device
+names above.</P
+></DIV
+><DIV
+CLASS="SECTION"
+><HR><H3
+CLASS="SECTION"
+><A
+NAME="RELATED"
+>1.1.2. Related Devices</A
+></H3
+><P
+>Devices can support several related functions. For example
+video capturing, video overlay and VBI capturing are related because
+these functions share, amongst other, the same video input and tuner
+frequency. V4L and earlier versions of V4L2 used the same device name
+and minor number for video capturing and overlay, but different ones
+for VBI. Experience showed this approach has several problems<A
+NAME="AEN135"
+HREF="#FTN.AEN135"
+><SPAN
+CLASS="footnote"
+>[3]</SPAN
+></A
+>, and to make things worse the V4L videodev module
+used to prohibit multiple opens of a device.</P
+><P
+>As a remedy the present version of the V4L2 API relaxed the
+concept of device types with specific names and minor numbers. For
+compatibility with old applications drivers must still register different
+minor numbers to assign a default function to the device. But if related
+functions are supported by the driver they must be available under all
+registered minor numbers. The desired function can be selected after
+opening the device as described in <A
+HREF="#DEVICES"
+>Chapter 4</A
+>.</P
+><P
+>Imagine a driver supporting video capturing, video
+overlay, raw VBI capturing, and FM radio reception. It registers three
+devices with minor number 0, 64 and 224 (this numbering scheme is
+inherited from the V4L API). Regardless if
+<TT
+CLASS="FILENAME"
+>/dev/video</TT
+> (81, 0) or
+<TT
+CLASS="FILENAME"
+>/dev/vbi</TT
+> (81, 224) is opened the application can
+select any one of the video capturing, overlay or VBI capturing
+functions. Without programming (e.&nbsp;g. reading from the device
+with <SPAN
+CLASS="APPLICATION"
+>dd</SPAN
+> or <SPAN
+CLASS="APPLICATION"
+>cat</SPAN
+>)
+<TT
+CLASS="FILENAME"
+>/dev/video</TT
+> captures video images, while
+<TT
+CLASS="FILENAME"
+>/dev/vbi</TT
+> captures raw VBI data.
+<TT
+CLASS="FILENAME"
+>/dev/radio</TT
+> (81, 64) is invariable a radio device,
+unrelated to the video functions. Being unrelated does not imply the
+devices can be used at the same time, however. The
+<CODE
+CLASS="FUNCTION"
+>open()</CODE
+> function may very well return an
+<SPAN
+CLASS="ERRORCODE"
+>EBUSY</SPAN
+> error code.</P
+><P
+>Besides video input or output the hardware may also
+support audio sampling or playback. If so, these functions are
+implemented as OSS or ALSA PCM devices and eventually OSS or ALSA
+audio mixer. The V4L2 API makes no provisions yet to find these
+related devices. If you have an idea please write to the Video4Linux
+mailing list: <A
+HREF="https://listman.redhat.com/mailman/listinfo/video4linux-list"
+TARGET="_top"
+>https://listman.redhat.com/mailman/listinfo/video4linux-list</A
+>.</P
+></DIV
+><DIV
+CLASS="SECTION"
+><HR><H3
+CLASS="SECTION"
+><A
+NAME="AEN153"
+>1.1.3. Multiple Opens</A
+></H3
+><P
+>In general, V4L2 devices can be opened more than once.
+When this is supported by the driver, users can for example start a
+"panel" application to change controls like brightness or audio
+volume, while another application captures video and audio. In other words, panel
+applications are comparable to an OSS or ALSA audio mixer application.
+When a device supports multiple functions like capturing and overlay
+<SPAN
+CLASS="emphasis"
+><I
+CLASS="EMPHASIS"
+>simultaneously</I
+></SPAN
+>, multiple opens allow concurrent
+use of the device by forked processes or specialized applications.</P
+><P
+>Multiple opens are optional, although drivers should
+permit at least concurrent accesses without data exchange, i.&nbsp;e.
+panel applications. This implies <CODE
+CLASS="FUNCTION"
+>open()</CODE
+> can
+return an <SPAN
+CLASS="ERRORCODE"
+>EBUSY</SPAN
+> error code when the device is already in use, as well as
+<CODE
+CLASS="FUNCTION"
+>ioctl()</CODE
+> functions initiating data exchange
+(namely the <A
+HREF="#VIDIOC-G-FMT"
+><CODE
+CLASS="CONSTANT"
+>VIDIOC_S_FMT</CODE
+></A
+> ioctl), and the <CODE
+CLASS="FUNCTION"
+>read()</CODE
+>
+and <CODE
+CLASS="FUNCTION"
+>write()</CODE
+> functions.</P
+><P
+>Mere opening a V4L2 device does not grant exclusive
+access.<A
+NAME="AEN166"
+HREF="#FTN.AEN166"
+><SPAN
+CLASS="footnote"
+>[4]</SPAN
+></A
+> Initiating data exchange however assigns the right
+to read or write the requested type of data, and to change related
+properties, to this file descriptor. Applications can request
+additional access privileges using the priority mechanism described in
+<A
+HREF="#APP-PRI"
+>Section 1.3</A
+>.</P
+></DIV
+><DIV
+CLASS="SECTION"
+><HR><H3
+CLASS="SECTION"
+><A
+NAME="AEN170"
+>1.1.4. Shared Data Streams</A
+></H3
+><P
+>V4L2 drivers should not support multiple applications
+reading or writing the same data stream on a device by copying
+buffers, time multiplexing or similar means. This is better handled by
+a proxy application in user space. When the driver supports stream
+sharing anyway it must be implemented transparently. The V4L2 API does
+not specify how conflicts are solved. </P
+></DIV
+><DIV
+CLASS="SECTION"
+><HR><H3
+CLASS="SECTION"
+><A
+NAME="AEN173"
+>1.1.5. Functions</A
+></H3
+><P
+>To open and close V4L2 devices applications use the <A
+HREF="#FUNC-OPEN"
+><CODE
+CLASS="FUNCTION"
+>open()</CODE
+></A
+> and <A
+HREF="#FUNC-CLOSE"
+><CODE
+CLASS="FUNCTION"
+>close()</CODE
+></A
+> function,
+respectively. Devices are programmed using the <A
+HREF="#FUNC-IOCTL"
+><CODE
+CLASS="FUNCTION"
+>ioctl()</CODE
+></A
+> function as
+explained in the following sections.</P
+></DIV
+></DIV
+><DIV
+CLASS="SECTION"
+><HR><H2
+CLASS="SECTION"
+><A
+NAME="QUERYCAP"
+>1.2. Querying Capabilities</A
+></H2
+><P
+>Because V4L2 covers a wide variety of devices not all
+aspects of the API are equally applicable to all types of devices.
+Furthermore devices of the same type have different capabilities and
+this specification permits the omission of a few complicated and less
+important parts of the API.</P
+><P
+>The <A
+HREF="#VIDIOC-QUERYCAP"
+><CODE
+CLASS="CONSTANT"
+>VIDIOC_QUERYCAP</CODE
+></A
+> ioctl is available to check if the kernel
+device is compatible with this specification, and to query the <A
+HREF="#DEVICES"
+>functions</A
+> and <A
+HREF="#IO"
+>I/O
+methods</A
+> supported by the device. Other features can be queried
+by calling the respective ioctl, for example <A
+HREF="#VIDIOC-ENUMINPUT"
+><CODE
+CLASS="CONSTANT"
+>VIDIOC_ENUMINPUT</CODE
+></A
+>
+to learn about the number, types and names of video connectors on the
+device. Although abstraction is a major objective of this API, the
+ioctl also allows driver specific applications to reliable identify
+the driver.</P
+><P
+>All V4L2 drivers must support
+<CODE
+CLASS="CONSTANT"
+>VIDIOC_QUERYCAP</CODE
+>. Applications should always call
+this ioctl after opening the device.</P
+></DIV
+><DIV
+CLASS="SECTION"
+><HR><H2
+CLASS="SECTION"
+><A
+NAME="APP-PRI"
+>1.3. Application Priority</A
+></H2
+><P
+>When multiple applications share a device it may be
+desirable to assign them different priorities. Contrary to the
+traditional "rm -rf /" school of thought a video recording application
+could for example block other applications from changing video
+controls or switching the current TV channel. Another objective is to
+permit low priority applications working in background, which can be
+preempted by user controlled applications and automatically regain
+control of the device at a later time.</P
+><P
+>Since these features cannot be implemented entirely in user
+space V4L2 defines the <A
+HREF="#VIDIOC-G-PRIORITY"
+><CODE
+CLASS="CONSTANT"
+>VIDIOC_G_PRIORITY</CODE
+></A
+> and <A
+HREF="#VIDIOC-G-PRIORITY"
+><CODE
+CLASS="CONSTANT"
+>VIDIOC_S_PRIORITY</CODE
+></A
+>
+ioctls to request and query the access priority associate with a file
+descriptor. Opening a device assigns a medium priority, compatible
+with earlier versions of V4L2 and drivers not supporting these ioctls.
+Applications requiring a different priority will usually call
+<CODE
+CLASS="CONSTANT"
+>VIDIOC_S_PRIORITY</CODE
+> after verifying the device with
+the <A
+HREF="#VIDIOC-QUERYCAP"
+><CODE
+CLASS="CONSTANT"
+>VIDIOC_QUERYCAP</CODE
+></A
+> ioctl.</P
+><P
+>Ioctls changing driver properties, such as <A
+HREF="#VIDIOC-G-INPUT"
+><CODE
+CLASS="CONSTANT"
+>VIDIOC_S_INPUT</CODE
+></A
+>,
+return an <SPAN
+CLASS="ERRORCODE"
+>EBUSY</SPAN
+> error code after another application obtained higher priority.
+An event mechanism to notify applications about asynchronous property
+changes has been proposed but not added yet.</P
+></DIV
+><DIV
+CLASS="SECTION"
+><HR><H2
+CLASS="SECTION"
+><A
+NAME="VIDEO"
+>1.4. Video Inputs and Outputs</A
+></H2
+><P
+>Video inputs and outputs are physical connectors of a
+device. These can be for example RF connectors (antenna/cable), CVBS
+a.k.a. Composite Video, S-Video or RGB connectors. Only video and VBI
+capture devices have inputs, output devices have outputs, at least one
+each. Radio devices have no video inputs or outputs.</P
+><P
+>To learn about the number and attributes of the
+available inputs and outputs applications can enumerate them with the
+<A
+HREF="#VIDIOC-ENUMINPUT"
+><CODE
+CLASS="CONSTANT"
+>VIDIOC_ENUMINPUT</CODE
+></A
+> and <A
+HREF="#VIDIOC-ENUMOUTPUT"
+><CODE
+CLASS="CONSTANT"
+>VIDIOC_ENUMOUTPUT</CODE
+></A
+> ioctl, respectively. The
+struct&nbsp;<A
+HREF="#V4L2-INPUT"
+>v4l2_input</A
+> returned by the <CODE
+CLASS="CONSTANT"
+>VIDIOC_ENUMINPUT</CODE
+>
+ioctl also contains signal status information applicable when the
+current video input is queried.</P
+><P
+>The <A
+HREF="#VIDIOC-G-INPUT"
+><CODE
+CLASS="CONSTANT"
+>VIDIOC_G_INPUT</CODE
+></A
+> and <A
+HREF="#VIDIOC-G-OUTPUT"
+><CODE
+CLASS="CONSTANT"
+>VIDIOC_G_OUTPUT</CODE
+></A
+> ioctl return the
+index of the current video input or output. To select a different
+input or output applications call the <A
+HREF="#VIDIOC-G-INPUT"
+><CODE
+CLASS="CONSTANT"
+>VIDIOC_S_INPUT</CODE
+></A
+> and
+<A
+HREF="#VIDIOC-G-OUTPUT"
+><CODE
+CLASS="CONSTANT"
+>VIDIOC_S_OUTPUT</CODE
+></A
+> ioctl. Drivers must implement all the input ioctls
+when the device has one or more inputs, all the output ioctls when the
+device has one or more outputs.</P
+><DIV
+CLASS="EXAMPLE"
+><A
+NAME="AEN228"
+></A
+><P
+><B
+>Example 1-1. Information about the current video input</B
+></P
+><PRE
+CLASS="PROGRAMLISTING"
+>struct&nbsp;<A
+HREF="#V4L2-INPUT"
+>v4l2_input</A
+> input;
+int index;
+
+if (-1 == ioctl (fd, <A
+HREF="#VIDIOC-G-INPUT"
+><CODE
+CLASS="CONSTANT"
+>VIDIOC_G_INPUT</CODE
+></A
+>, &amp;index)) {
+ perror ("VIDIOC_G_INPUT");
+ exit (EXIT_FAILURE);
+}
+
+memset (&amp;input, 0, sizeof (input));
+input.index = index;
+
+if (-1 == ioctl (fd, <A
+HREF="#VIDIOC-ENUMINPUT"
+><CODE
+CLASS="CONSTANT"
+>VIDIOC_ENUMINPUT</CODE
+></A
+>, &amp;input)) {
+ perror ("VIDIOC_ENUMINPUT");
+ exit (EXIT_FAILURE);
+}
+
+printf ("Current input: %s\n", input.name);
+ </PRE
+></DIV
+><DIV
+CLASS="EXAMPLE"
+><A
+NAME="AEN236"
+></A
+><P
+><B
+>Example 1-2. Switching to the first video input</B
+></P
+><PRE
+CLASS="PROGRAMLISTING"
+>int index;
+
+index = 0;
+
+if (-1 == ioctl (fd, <A
+HREF="#VIDIOC-G-INPUT"
+><CODE
+CLASS="CONSTANT"
+>VIDIOC_S_INPUT</CODE
+></A
+>, &amp;index)) {
+ perror ("VIDIOC_S_INPUT");
+ exit (EXIT_FAILURE);
+}
+ </PRE
+></DIV
+></DIV
+><DIV
+CLASS="SECTION"
+><HR><H2
+CLASS="SECTION"
+><A
+NAME="AUDIO"
+>1.5. Audio Inputs and Outputs</A
+></H2
+><P
+>Audio inputs and outputs are physical connectors of a
+device. Video capture devices have inputs, output devices have
+outputs, zero or more each. Radio devices have no audio inputs or
+outputs. They have exactly one tuner which in fact
+<SPAN
+CLASS="emphasis"
+><I
+CLASS="EMPHASIS"
+>is</I
+></SPAN
+> an audio source, but this API associates
+tuners with video inputs or outputs only, and radio devices have
+none of these.<A
+NAME="AEN245"
+HREF="#FTN.AEN245"
+><SPAN
+CLASS="footnote"
+>[5]</SPAN
+></A
+> A connector on a TV card to loop back the received
+audio signal to a sound card is not considered an audio output.</P
+><P
+>Audio and video inputs and outputs are associated. Selecting
+a video source also selects an audio source. This is most evident when
+the video and audio source is a tuner. Further audio connectors can
+combine with more than one video input or output. Assumed two
+composite video inputs and two audio inputs exist, there may be up to
+four valid combinations. The relation of video and audio connectors
+is defined in the <CODE
+CLASS="STRUCTFIELD"
+>audioset</CODE
+> field of the
+respective struct&nbsp;<A
+HREF="#V4L2-INPUT"
+>v4l2_input</A
+> or struct&nbsp;<A
+HREF="#V4L2-OUTPUT"
+>v4l2_output</A
+>, where each bit represents
+the index number, starting at zero, of one audio input or output.</P
+><P
+>To learn about the number and attributes of the
+available inputs and outputs applications can enumerate them with the
+<A
+HREF="#VIDIOC-ENUMAUDIO"
+><CODE
+CLASS="CONSTANT"
+>VIDIOC_ENUMAUDIO</CODE
+></A
+> and <A
+HREF="#VIDIOC-ENUMAUDIOOUT"
+><CODE
+CLASS="CONSTANT"
+>VIDIOC_ENUMAUDOUT</CODE
+></A
+> ioctl, respectively. The
+struct&nbsp;<A
+HREF="#V4L2-AUDIO"
+>v4l2_audio</A
+> returned by the <CODE
+CLASS="CONSTANT"
+>VIDIOC_ENUMAUDIO</CODE
+> ioctl
+also contains signal status information applicable when the current
+audio input is queried.</P
+><P
+>The <A
+HREF="#VIDIOC-G-AUDIO"
+><CODE
+CLASS="CONSTANT"
+>VIDIOC_G_AUDIO</CODE
+></A
+> and <A
+HREF="#VIDIOC-G-AUDIOOUT"
+><CODE
+CLASS="CONSTANT"
+>VIDIOC_G_AUDOUT</CODE
+></A
+> ioctl report
+the current audio input and output, respectively. Note that, unlike
+<A
+HREF="#VIDIOC-G-INPUT"
+><CODE
+CLASS="CONSTANT"
+>VIDIOC_G_INPUT</CODE
+></A
+> and <A
+HREF="#VIDIOC-G-OUTPUT"
+><CODE
+CLASS="CONSTANT"
+>VIDIOC_G_OUTPUT</CODE
+></A
+> these ioctls return a structure
+as <CODE
+CLASS="CONSTANT"
+>VIDIOC_ENUMAUDIO</CODE
+> and
+<CODE
+CLASS="CONSTANT"
+>VIDIOC_ENUMAUDOUT</CODE
+> do, not just an index.</P
+><P
+>To select an audio input and change its properties
+applications call the <A
+HREF="#VIDIOC-G-AUDIO"
+><CODE
+CLASS="CONSTANT"
+>VIDIOC_S_AUDIO</CODE
+></A
+> ioctl. To select an audio
+output (which presently has no changeable properties) applications
+call the <A
+HREF="#VIDIOC-G-AUDIOOUT"
+><CODE
+CLASS="CONSTANT"
+>VIDIOC_S_AUDOUT</CODE
+></A
+> ioctl.</P
+><P
+>Drivers must implement all input ioctls when the device
+has one or more inputs, all output ioctls when the device has one
+or more outputs. When the device has any audio inputs or outputs the
+driver must set the <CODE
+CLASS="CONSTANT"
+>V4L2_CAP_AUDIO</CODE
+> flag in the
+struct&nbsp;<A
+HREF="#V4L2-CAPABILITY"
+>v4l2_capability</A
+> returned by the <A
+HREF="#VIDIOC-QUERYCAP"
+><CODE
+CLASS="CONSTANT"
+>VIDIOC_QUERYCAP</CODE
+></A
+> ioctl.</P
+><DIV
+CLASS="EXAMPLE"
+><A
+NAME="AEN282"
+></A
+><P
+><B
+>Example 1-3. Information about the current audio input</B
+></P
+><PRE
+CLASS="PROGRAMLISTING"
+>struct&nbsp;<A
+HREF="#V4L2-AUDIO"
+>v4l2_audio</A
+> audio;
+
+memset (&amp;audio, 0, sizeof (audio));
+
+if (-1 == ioctl (fd, <A
+HREF="#VIDIOC-G-AUDIO"
+><CODE
+CLASS="CONSTANT"
+>VIDIOC_G_AUDIO</CODE
+></A
+>, &amp;audio)) {
+ perror ("VIDIOC_G_AUDIO");
+ exit (EXIT_FAILURE);
+}
+
+printf ("Current input: %s\n", audio.name);
+ </PRE
+></DIV
+><DIV
+CLASS="EXAMPLE"
+><A
+NAME="AEN288"
+></A
+><P
+><B
+>Example 1-4. Switching to the first audio input</B
+></P
+><PRE
+CLASS="PROGRAMLISTING"
+>struct&nbsp;<A
+HREF="#V4L2-AUDIO"
+>v4l2_audio</A
+> audio;
+
+memset (&amp;audio, 0, sizeof (audio)); /* clear audio.mode, audio.reserved */
+
+audio.index = 0;
+
+if (-1 == ioctl (fd, <A
+HREF="#VIDIOC-G-AUDIO"
+><CODE
+CLASS="CONSTANT"
+>VIDIOC_S_AUDIO</CODE
+></A
+>, &amp;audio)) {
+ perror ("VIDIOC_S_AUDIO");
+ exit (EXIT_FAILURE);
+}
+ </PRE
+></DIV
+></DIV
+><DIV
+CLASS="SECTION"
+><HR><H2
+CLASS="SECTION"
+><A
+NAME="TUNER"
+>1.6. Tuners and Modulators</A
+></H2
+><DIV
+CLASS="SECTION"
+><H3
+CLASS="SECTION"
+><A
+NAME="AEN296"
+>1.6.1. Tuners</A
+></H3
+><P
+>Video input devices can have one or more tuners
+demodulating a RF signal. Each tuner is associated with one or more
+video inputs, depending on the number of RF connectors on the tuner.
+The <CODE
+CLASS="STRUCTFIELD"
+>type</CODE
+> field of the respective
+struct&nbsp;<A
+HREF="#V4L2-INPUT"
+>v4l2_input</A
+> returned by the <A
+HREF="#VIDIOC-ENUMINPUT"
+><CODE
+CLASS="CONSTANT"
+>VIDIOC_ENUMINPUT</CODE
+></A
+> ioctl is set to
+<CODE
+CLASS="CONSTANT"
+>V4L2_INPUT_TYPE_TUNER</CODE
+> and its
+<CODE
+CLASS="STRUCTFIELD"
+>tuner</CODE
+> field contains the index number of
+the tuner.</P
+><P
+>Radio devices have exactly one tuner with index zero, no
+video inputs.</P
+><P
+>To query and change tuner properties applications use the
+<A
+HREF="#VIDIOC-G-TUNER"
+><CODE
+CLASS="CONSTANT"
+>VIDIOC_G_TUNER</CODE
+></A
+> and <A
+HREF="#VIDIOC-G-TUNER"
+><CODE
+CLASS="CONSTANT"
+>VIDIOC_S_TUNER</CODE
+></A
+> ioctl, respectively. The
+struct&nbsp;<A
+HREF="#V4L2-TUNER"
+>v4l2_tuner</A
+> returned by <CODE
+CLASS="CONSTANT"
+>VIDIOC_G_TUNER</CODE
+> also
+contains signal status information applicable when the tuner of the
+current video input, or a radio tuner is queried. Note that
+<CODE
+CLASS="CONSTANT"
+>VIDIOC_S_TUNER</CODE
+> does not switch the current tuner,
+when there is more than one at all. The tuner is solely determined by
+the current video input. Drivers must support both ioctls and set the
+<CODE
+CLASS="CONSTANT"
+>V4L2_CAP_TUNER</CODE
+> flag in the struct&nbsp;<A
+HREF="#V4L2-CAPABILITY"
+>v4l2_capability</A
+>
+returned by the <A
+HREF="#VIDIOC-QUERYCAP"
+><CODE
+CLASS="CONSTANT"
+>VIDIOC_QUERYCAP</CODE
+></A
+> ioctl when the device has one or
+more tuners.</P
+></DIV
+><DIV
+CLASS="SECTION"
+><HR><H3
+CLASS="SECTION"
+><A
+NAME="AEN318"
+>1.6.2. Modulators</A
+></H3
+><P
+>Video output devices can have one or more modulators, uh,
+modulating a video signal for radiation or connection to the antenna
+input of a TV set or video recorder. Each modulator is associated with
+one or more video outputs, depending on the number of RF connectors on
+the modulator. The <CODE
+CLASS="STRUCTFIELD"
+>type</CODE
+> field of the
+respective struct&nbsp;<A
+HREF="#V4L2-OUTPUT"
+>v4l2_output</A
+> returned by the <A
+HREF="#VIDIOC-ENUMOUTPUT"
+><CODE
+CLASS="CONSTANT"
+>VIDIOC_ENUMOUTPUT</CODE
+></A
+> is set to
+<CODE
+CLASS="CONSTANT"
+>V4L2_OUTPUT_TYPE_MODULATOR</CODE
+> and its
+<CODE
+CLASS="STRUCTFIELD"
+>modulator</CODE
+> field contains the index number
+of the modulator. This specification does not define radio output
+devices.</P
+><P
+>To query and change modulator properties applications use
+the <A
+HREF="#VIDIOC-G-MODULATOR"
+><CODE
+CLASS="CONSTANT"
+>VIDIOC_G_MODULATOR</CODE
+></A
+> and <A
+HREF="#VIDIOC-G-MODULATOR"
+><CODE
+CLASS="CONSTANT"
+>VIDIOC_S_MODULATOR</CODE
+></A
+> ioctl. Note that
+<CODE
+CLASS="CONSTANT"
+>VIDIOC_S_MODULATOR</CODE
+> does not switch the current
+modulator, when there is more than one at all. The modulator is solely
+determined by the current video output. Drivers must support both
+ioctls and set the <CODE
+CLASS="CONSTANT"
+>V4L2_CAP_TUNER</CODE
+> (sic) flag in
+the struct&nbsp;<A
+HREF="#V4L2-CAPABILITY"
+>v4l2_capability</A
+> returned by the <A
+HREF="#VIDIOC-QUERYCAP"
+><CODE
+CLASS="CONSTANT"
+>VIDIOC_QUERYCAP</CODE
+></A
+> ioctl when the
+device has one or more modulators.</P
+></DIV
+><DIV
+CLASS="SECTION"
+><HR><H3
+CLASS="SECTION"
+><A
+NAME="AEN337"
+>1.6.3. Radio Frequency</A
+></H3
+><P
+>To get and set the tuner or modulator radio frequency
+applications use the <A
+HREF="#VIDIOC-G-FREQUENCY"
+><CODE
+CLASS="CONSTANT"
+>VIDIOC_G_FREQUENCY</CODE
+></A
+> and <A
+HREF="#VIDIOC-G-FREQUENCY"
+><CODE
+CLASS="CONSTANT"
+>VIDIOC_S_FREQUENCY</CODE
+></A
+>
+ioctl which both take a pointer to a struct&nbsp;<A
+HREF="#V4L2-FREQUENCY"
+>v4l2_frequency</A
+>. These ioctls
+are used for TV and radio devices alike. Drivers must support both
+ioctls when the tuner or modulator ioctls are supported, or
+when the device is a radio device.</P
+></DIV
+><DIV
+CLASS="SECTION"
+><HR><H3
+CLASS="SECTION"
+><A
+NAME="AEN345"
+>1.6.4. Satellite Receivers</A
+></H3
+><P
+>To be discussed. See also
+proposals by Peter Schlaf, video4linux-list@redhat.com on 23 Oct 2002,
+subject: "Re: [V4L] Re: v4l2 api".</P
+></DIV
+></DIV
+><DIV
+CLASS="SECTION"
+><HR><H2
+CLASS="SECTION"
+><A
+NAME="STANDARD"
+>1.7. Video Standards</A
+></H2
+><P
+>Video devices typically support one or more different video
+standards or variations of standards. Each video input and output may
+support another set of standards. This set is reported by the
+<CODE
+CLASS="STRUCTFIELD"
+>std</CODE
+> field of struct&nbsp;<A
+HREF="#V4L2-INPUT"
+>v4l2_input</A
+> and
+struct&nbsp;<A
+HREF="#V4L2-OUTPUT"
+>v4l2_output</A
+> returned by the <A
+HREF="#VIDIOC-ENUMINPUT"
+><CODE
+CLASS="CONSTANT"
+>VIDIOC_ENUMINPUT</CODE
+></A
+> and
+<A
+HREF="#VIDIOC-ENUMOUTPUT"
+><CODE
+CLASS="CONSTANT"
+>VIDIOC_ENUMOUTPUT</CODE
+></A
+> ioctl, respectively.</P
+><P
+>V4L2 defines one bit for each analog video standard
+currently in use worldwide, and sets aside bits for driver defined
+standards, e.&nbsp;g. hybrid standards to watch NTSC video tapes on PAL TVs
+and vice versa. Applications can use the predefined bits to select a
+particular standard, although presenting the user a menu of supported
+standards is preferred. To enumerate and query the attributes of the
+supported standards applications use the <A
+HREF="#VIDIOC-ENUMSTD"
+><CODE
+CLASS="CONSTANT"
+>VIDIOC_ENUMSTD</CODE
+></A
+> ioctl.</P
+><P
+>Many of the defined standards are actually just variations
+of a few major standards. The hardware may in fact not distinguish
+between them, or do so internal and switch automatically. Therefore
+enumerated standards also contain sets of one or more standard
+bits.</P
+><P
+>Assume a hypothetic tuner capable of demodulating B/PAL,
+G/PAL and I/PAL signals. The first enumerated standard is a set of B
+and G/PAL, switched automatically depending on the selected radio
+frequency in UHF or VHF band. Enumeration gives a "PAL-B/G" or "PAL-I"
+choice. Similar a Composite input may collapse standards, enumerating
+"PAL-B/G/H/I", "NTSC-M" and "SECAM-D/K".<A
+NAME="AEN363"
+HREF="#FTN.AEN363"
+><SPAN
+CLASS="footnote"
+>[6]</SPAN
+></A
+></P
+><P
+>To query and select the standard used by the current video
+input or output applications call the <A
+HREF="#VIDIOC-G-STD"
+><CODE
+CLASS="CONSTANT"
+>VIDIOC_G_STD</CODE
+></A
+> and
+<A
+HREF="#VIDIOC-G-STD"
+><CODE
+CLASS="CONSTANT"
+>VIDIOC_S_STD</CODE
+></A
+> ioctl, respectively. The <SPAN
+CLASS="emphasis"
+><I
+CLASS="EMPHASIS"
+>received</I
+></SPAN
+>
+standard can be sensed with the <A
+HREF="#VIDIOC-QUERYSTD"
+><CODE
+CLASS="CONSTANT"
+>VIDIOC_QUERYSTD</CODE
+></A
+> ioctl. Note parameter of all these ioctls is a pointer to a <A
+HREF="#V4L2-STD-ID"
+>v4l2_std_id</A
+> type (a standard set), <SPAN
+CLASS="emphasis"
+><I
+CLASS="EMPHASIS"
+>not</I
+></SPAN
+> an index into the standard enumeration.<A
+NAME="AEN375"
+HREF="#FTN.AEN375"
+><SPAN
+CLASS="footnote"
+>[7]</SPAN
+></A
+> Drivers must implement all video standard ioctls
+when the device has one or more video inputs or outputs.</P
+><P
+>Special rules apply to USB cameras where the notion of video
+standards makes little sense. More generally any capture device,
+output devices accordingly, which is <P
+></P
+><UL
+><LI
+><P
+>incapable of capturing fields or frames at the nominal
+rate of the video standard, or</P
+></LI
+><LI
+><P
+>where <A
+HREF="#BUFFER"
+>timestamps</A
+> refer
+to the instant the field or frame was received by the driver, not the
+capture time, or</P
+></LI
+><LI
+><P
+>where <A
+HREF="#BUFFER"
+>sequence numbers</A
+>
+refer to the frames received by the driver, not the captured
+frames.</P
+></LI
+></UL
+> Here the driver shall set the
+<CODE
+CLASS="STRUCTFIELD"
+>std</CODE
+> field of struct&nbsp;<A
+HREF="#V4L2-INPUT"
+>v4l2_input</A
+> and struct&nbsp;<A
+HREF="#V4L2-OUTPUT"
+>v4l2_output</A
+>
+to zero, the <CODE
+CLASS="CONSTANT"
+>VIDIOC_G_STD</CODE
+>,
+<CODE
+CLASS="CONSTANT"
+>VIDIOC_S_STD</CODE
+>,
+<CODE
+CLASS="CONSTANT"
+>VIDIOC_QUERYSTD</CODE
+> and
+<CODE
+CLASS="CONSTANT"
+>VIDIOC_ENUMSTD</CODE
+> ioctls shall return the
+<SPAN
+CLASS="ERRORCODE"
+>EINVAL</SPAN
+> error code.<A
+NAME="AEN407"
+HREF="#FTN.AEN407"
+><SPAN
+CLASS="footnote"
+>[8]</SPAN
+></A
+></P
+><DIV
+CLASS="EXAMPLE"
+><A
+NAME="AEN410"
+></A
+><P
+><B
+>Example 1-5. Information about the current video standard</B
+></P
+><PRE
+CLASS="PROGRAMLISTING"
+><A
+HREF="#V4L2-STD-ID"
+>v4l2_std_id</A
+> std;
+struct&nbsp;<A
+HREF="#V4L2-STANDARD"
+>v4l2_standard</A
+> standard;
+
+if (-1 == ioctl (fd, <A
+HREF="#VIDIOC-G-STD"
+><CODE
+CLASS="CONSTANT"
+>VIDIOC_G_STD</CODE
+></A
+>, &amp;std)) {
+ /* Note when VIDIOC_ENUMSTD always returns EINVAL this
+ is no video device or it falls under the USB exception,
+ and VIDIOC_G_STD returning EINVAL is no error. */
+
+ perror ("VIDIOC_G_STD");
+ exit (EXIT_FAILURE);
+}
+
+memset (&amp;standard, 0, sizeof (standard));
+standard.index = 0;
+
+while (0 == ioctl (fd, <A
+HREF="#VIDIOC-ENUMSTD"
+><CODE
+CLASS="CONSTANT"
+>VIDIOC_ENUMSTD</CODE
+></A
+>, &amp;standard)) {
+ if (standard.id &amp; std) {
+ printf ("Current video standard: %s\n", standard.name);
+ exit (EXIT_SUCCESS);
+ }
+
+ standard.index++;
+}
+
+/* EINVAL indicates the end of the enumeration, which cannot be
+ empty unless this device falls under the USB exception. */
+
+if (errno == EINVAL || standard.index == 0) {
+ perror ("VIDIOC_ENUMSTD");
+ exit (EXIT_FAILURE);
+}
+ </PRE
+></DIV
+><DIV
+CLASS="EXAMPLE"
+><A
+NAME="AEN419"
+></A
+><P
+><B
+>Example 1-6. Listing the video standards supported by the current
+input</B
+></P
+><PRE
+CLASS="PROGRAMLISTING"
+>struct&nbsp;<A
+HREF="#V4L2-INPUT"
+>v4l2_input</A
+> input;
+struct&nbsp;<A
+HREF="#V4L2-STANDARD"
+>v4l2_standard</A
+> standard;
+
+memset (&amp;input, 0, sizeof (input));
+
+if (-1 == ioctl (fd, <A
+HREF="#VIDIOC-G-INPUT"
+><CODE
+CLASS="CONSTANT"
+>VIDIOC_G_INPUT</CODE
+></A
+>, &amp;input.index)) {
+ perror ("VIDIOC_G_INPUT");
+ exit (EXIT_FAILURE);
+}
+
+if (-1 == ioctl (fd, <A
+HREF="#VIDIOC-ENUMINPUT"
+><CODE
+CLASS="CONSTANT"
+>VIDIOC_ENUMINPUT</CODE
+></A
+>, &amp;input)) {
+ perror ("VIDIOC_ENUM_INPUT");
+ exit (EXIT_FAILURE);
+}
+
+printf ("Current input %s supports:\n", input.name);
+
+memset (&amp;standard, 0, sizeof (standard));
+standard.index = 0;
+
+while (0 == ioctl (fd, <A
+HREF="#VIDIOC-ENUMSTD"
+><CODE
+CLASS="CONSTANT"
+>VIDIOC_ENUMSTD</CODE
+></A
+>, &amp;standard)) {
+ if (standard.id &amp; input.std)
+ printf ("%s\n", standard.name);
+
+ standard.index++;
+}
+
+/* EINVAL indicates the end of the enumeration, which cannot be
+ empty unless this device falls under the USB exception. */
+
+if (errno != EINVAL || standard.index == 0) {
+ perror ("VIDIOC_ENUMSTD");
+ exit (EXIT_FAILURE);
+}
+ </PRE
+></DIV
+><DIV
+CLASS="EXAMPLE"
+><A
+NAME="AEN430"
+></A
+><P
+><B
+>Example 1-7. Selecting a new video standard</B
+></P
+><PRE
+CLASS="PROGRAMLISTING"
+>struct&nbsp;<A
+HREF="#V4L2-INPUT"
+>v4l2_input</A
+> input;
+
+memset (&amp;input, 0, sizeof (input));
+
+if (-1 == ioctl (fd, <A
+HREF="#VIDIOC-G-INPUT"
+><CODE
+CLASS="CONSTANT"
+>VIDIOC_G_INPUT</CODE
+></A
+>, &amp;input.index)) {
+ perror ("VIDIOC_G_INPUT");
+ exit (EXIT_FAILURE);
+}
+
+if (-1 == ioctl (fd, <A
+HREF="#VIDIOC-ENUMINPUT"
+><CODE
+CLASS="CONSTANT"
+>VIDIOC_ENUMINPUT</CODE
+></A
+>, &amp;input)) {
+ perror ("VIDIOC_ENUM_INPUT");
+ exit (EXIT_FAILURE);
+}
+
+if (0 == (input.std &#38; V4L2_STD_PAL_BG)) {
+ fprintf (stderr, "Oops. B/G PAL is not supported.\n");
+ exit (EXIT_FAILURE);
+}
+
+/* Note this is also supposed to work when only B
+ <SPAN
+CLASS="emphasis"
+><I
+CLASS="EMPHASIS"
+>or</I
+></SPAN
+> G/PAL is supported. */
+
+if (-1 == ioctl (fd, <A
+HREF="#VIDIOC-G-STD"
+><CODE
+CLASS="CONSTANT"
+>VIDIOC_S_STD</CODE
+></A
+>, V4L2_STD_PAL_BG)) {
+ perror ("VIDIOC_S_STD");
+ exit (EXIT_FAILURE);
+}
+ </PRE
+></DIV
+></DIV
+><DIV
+CLASS="SECTION"
+><HR><H2
+CLASS="SECTION"
+><A
+NAME="CONTROL"
+>1.8. Controls</A
+></H2
+><P
+>Devices typically have a number of user-settable controls
+such as brightness, saturation and so on, which would be presented to
+the user on a graphical user interface. But, different devices
+will have different controls available, and furthermore, the range of
+possible values, and the default value will vary from device to
+device. The control ioctls provide the information and a mechanism to
+create a nice user interface for these controls that will work
+correctly with any device.</P
+><P
+>All controls are accessed using an ID value. V4L2 defines
+several IDs for specific purposes. Drivers can also implement their
+own custom controls using <CODE
+CLASS="CONSTANT"
+>V4L2_CID_PRIVATE_BASE</CODE
+>
+and higher values. The pre-defined control IDs have the prefix
+<CODE
+CLASS="CONSTANT"
+>V4L2_CID_</CODE
+>, and are listed in <A
+HREF="#CONTROL-ID"
+>Table 1-1</A
+>. The ID is used when querying the attributes of
+a control, and when getting or setting the current value.</P
+><P
+>Generally applications should present controls to the user
+without assumptions about their purpose. Each control comes with a
+name string the user is supposed to understand. When the purpose is
+non-intuitive the driver writer should provide a user manual, a user
+interface plug-in or a driver specific panel application. Predefined
+IDs were introduced to change a few controls programmatically, for
+example to mute a device during a channel switch.</P
+><P
+>Drivers may enumerate different controls after switching the
+current video input or output, tuner or modulator, or audio input or
+output. Different in the sense of other bounds, another default and
+current value, step size or other menu items. A control with a certain
+<SPAN
+CLASS="emphasis"
+><I
+CLASS="EMPHASIS"
+>custom</I
+></SPAN
+> ID can also change name and type.<A
+NAME="AEN451"
+HREF="#FTN.AEN451"
+><SPAN
+CLASS="footnote"
+>[9]</SPAN
+></A
+> Control values are stored globally, they do not
+change when switching except to stay within the reported bounds. They
+also do not change e.&nbsp;g. when the device is opened or closed, when the
+tuner radio frequency is changed or generally never without
+application request. Since V4L2 specifies no event mechanism, panel
+applications intended to cooperate with other panel applications (be
+they built into a larger application, as a TV viewer) may need to
+regularly poll control values to update their user
+interface.<A
+NAME="AEN454"
+HREF="#FTN.AEN454"
+><SPAN
+CLASS="footnote"
+>[10]</SPAN
+></A
+></P
+><DIV
+CLASS="TABLE"
+><A
+NAME="CONTROL-ID"
+></A
+><P
+><B
+>Table 1-1. Control IDs</B
+></P
+><TABLE
+BORDER="0"
+FRAME="void"
+WIDTH="100%"
+CLASS="CALSTABLE"
+><COL
+WIDTH="38%"
+TITLE="C1"><COL
+WIDTH="12%"
+TITLE="C2"><COL
+WIDTH="50%"
+TITLE="C3"><THEAD
+><TR
+><TH
+>ID</TH
+><TH
+>Type</TH
+><TH
+>Description</TH
+></TR
+></THEAD
+><TBODY
+><TR
+><TD
+><CODE
+CLASS="CONSTANT"
+>V4L2_CID_BASE</CODE
+></TD
+><TD
+>&nbsp;</TD
+><TD
+>First predefined ID, equal to
+<CODE
+CLASS="CONSTANT"
+>V4L2_CID_BRIGHTNESS</CODE
+>.</TD
+></TR
+><TR
+><TD
+><CODE
+CLASS="CONSTANT"
+>V4L2_CID_BRIGHTNESS</CODE
+></TD
+><TD
+>integer</TD
+><TD
+>Picture brightness, or more precisely, the black
+ level. Will not turn up the intelligence of the program
+ you're watching.</TD
+></TR
+><TR
+><TD
+><CODE
+CLASS="CONSTANT"
+>V4L2_CID_CONTRAST</CODE
+></TD
+><TD
+>integer</TD
+><TD
+>Picture contrast or luma gain.</TD
+></TR
+><TR
+><TD
+><CODE
+CLASS="CONSTANT"
+>V4L2_CID_SATURATION</CODE
+></TD
+><TD
+>integer</TD
+><TD
+>Picture color saturation or chroma gain.</TD
+></TR
+><TR
+><TD
+><CODE
+CLASS="CONSTANT"
+>V4L2_CID_HUE</CODE
+></TD
+><TD
+>integer</TD
+><TD
+>Hue or color balance.</TD
+></TR
+><TR
+><TD
+><CODE
+CLASS="CONSTANT"
+>V4L2_CID_AUDIO_VOLUME</CODE
+></TD
+><TD
+>integer</TD
+><TD
+>Overall audio volume. Note some drivers also
+provide an OSS or ALSA mixer interface.</TD
+></TR
+><TR
+><TD
+><CODE
+CLASS="CONSTANT"
+>V4L2_CID_AUDIO_BALANCE</CODE
+></TD
+><TD
+>integer</TD
+><TD
+>Audio stereo balance. Minimum corresponds to all
+the way left, maximum to right.</TD
+></TR
+><TR
+><TD
+><CODE
+CLASS="CONSTANT"
+>V4L2_CID_AUDIO_BASS</CODE
+></TD
+><TD
+>integer</TD
+><TD
+>Audio bass adjustment.</TD
+></TR
+><TR
+><TD
+><CODE
+CLASS="CONSTANT"
+>V4L2_CID_AUDIO_TREBLE</CODE
+></TD
+><TD
+>integer</TD
+><TD
+>Audio treble adjustment.</TD
+></TR
+><TR
+><TD
+><CODE
+CLASS="CONSTANT"
+>V4L2_CID_AUDIO_MUTE</CODE
+></TD
+><TD
+>boolean</TD
+><TD
+>Mute audio, i.&nbsp;e. set the volume to zero, however
+without affecting <CODE
+CLASS="CONSTANT"
+>V4L2_CID_AUDIO_VOLUME</CODE
+>. Like
+ALSA drivers, V4L2 drivers must mute at load time to avoid excessive
+noise. Actually the entire device should be reset to a low power
+consumption state.</TD
+></TR
+><TR
+><TD
+><CODE
+CLASS="CONSTANT"
+>V4L2_CID_AUDIO_LOUDNESS</CODE
+></TD
+><TD
+>boolean</TD
+><TD
+>Loudness mode (bass boost).</TD
+></TR
+><TR
+><TD
+><CODE
+CLASS="CONSTANT"
+>V4L2_CID_BLACK_LEVEL</CODE
+></TD
+><TD
+>integer</TD
+><TD
+>Another name for brightness (not a synonym of
+<CODE
+CLASS="CONSTANT"
+>V4L2_CID_BRIGHTNESS</CODE
+>). [?]</TD
+></TR
+><TR
+><TD
+><CODE
+CLASS="CONSTANT"
+>V4L2_CID_AUTO_WHITE_BALANCE</CODE
+></TD
+><TD
+>boolean</TD
+><TD
+>Automatic white balance (cameras).</TD
+></TR
+><TR
+><TD
+><CODE
+CLASS="CONSTANT"
+>V4L2_CID_DO_WHITE_BALANCE</CODE
+></TD
+><TD
+>button</TD
+><TD
+>This is an action control. When set (the value is
+ignored), the device will do a white balance and then hold the current
+setting. Contrast this with the boolean
+<CODE
+CLASS="CONSTANT"
+>V4L2_CID_AUTO_WHITE_BALANCE</CODE
+>, which, when
+activated, keeps adjusting the white balance.</TD
+></TR
+><TR
+><TD
+><CODE
+CLASS="CONSTANT"
+>V4L2_CID_RED_BALANCE</CODE
+></TD
+><TD
+>integer</TD
+><TD
+>Red chroma balance.</TD
+></TR
+><TR
+><TD
+><CODE
+CLASS="CONSTANT"
+>V4L2_CID_BLUE_BALANCE</CODE
+></TD
+><TD
+>integer</TD
+><TD
+>Blue chroma balance.</TD
+></TR
+><TR
+><TD
+><CODE
+CLASS="CONSTANT"
+>V4L2_CID_GAMMA</CODE
+></TD
+><TD
+>integer</TD
+><TD
+>Gamma adjust.</TD
+></TR
+><TR
+><TD
+><CODE
+CLASS="CONSTANT"
+>V4L2_CID_WHITENESS</CODE
+></TD
+><TD
+>integer</TD
+><TD
+>Whiteness for grey-scale devices. This is a synonym
+for <CODE
+CLASS="CONSTANT"
+>V4L2_CID_GAMMA</CODE
+>.</TD
+></TR
+><TR
+><TD
+><CODE
+CLASS="CONSTANT"
+>V4L2_CID_EXPOSURE</CODE
+></TD
+><TD
+>integer</TD
+><TD
+>Exposure (cameras). [Unit?]</TD
+></TR
+><TR
+><TD
+><CODE
+CLASS="CONSTANT"
+>V4L2_CID_AUTOGAIN</CODE
+></TD
+><TD
+>boolean</TD
+><TD
+>Automatic gain/exposure control.</TD
+></TR
+><TR
+><TD
+><CODE
+CLASS="CONSTANT"
+>V4L2_CID_GAIN</CODE
+></TD
+><TD
+>integer</TD
+><TD
+>Gain control.</TD
+></TR
+><TR
+><TD
+><CODE
+CLASS="CONSTANT"
+>V4L2_CID_HFLIP</CODE
+></TD
+><TD
+>boolean</TD
+><TD
+>Mirror the picture horizontally.</TD
+></TR
+><TR
+><TD
+><CODE
+CLASS="CONSTANT"
+>V4L2_CID_VFLIP</CODE
+></TD
+><TD
+>boolean</TD
+><TD
+>Mirror the picture vertically.</TD
+></TR
+><TR
+><TD
+><CODE
+CLASS="CONSTANT"
+>V4L2_CID_HCENTER</CODE
+></TD
+><TD
+>integer</TD
+><TD
+>Horizontal image centering.</TD
+></TR
+><TR
+><TD
+><CODE
+CLASS="CONSTANT"
+>V4L2_CID_VCENTER</CODE
+></TD
+><TD
+>integer</TD
+><TD
+>Vertical image centering. Centering is intended to
+<SPAN
+CLASS="emphasis"
+><I
+CLASS="EMPHASIS"
+>physically</I
+></SPAN
+> adjust cameras. For image cropping see
+<A
+HREF="#CROP"
+>Section 1.10</A
+>, for clipping <A
+HREF="#OVERLAY"
+>Section 4.2</A
+>.</TD
+></TR
+><TR
+><TD
+><CODE
+CLASS="CONSTANT"
+>V4L2_CID_LASTP1</CODE
+></TD
+><TD
+>&nbsp;</TD
+><TD
+>End of the predefined control IDs
+ (currently <CODE
+CLASS="CONSTANT"
+>V4L2_CID_VCENTER</CODE
+> + 1).</TD
+></TR
+><TR
+><TD
+><CODE
+CLASS="CONSTANT"
+>V4L2_CID_PRIVATE_BASE</CODE
+></TD
+><TD
+>&nbsp;</TD
+><TD
+>ID of the first custom (driver specific) control.
+Applications depending on particular custom controls should check the
+driver name and version, see <A
+HREF="#QUERYCAP"
+>Section 1.2</A
+>.</TD
+></TR
+></TBODY
+></TABLE
+></DIV
+><P
+>Applications can enumerate the available controls with the
+<A
+HREF="#VIDIOC-QUERYCTRL"
+><CODE
+CLASS="CONSTANT"
+>VIDIOC_QUERYCTRL</CODE
+></A
+> and <A
+HREF="#VIDIOC-QUERYCTRL"
+><CODE
+CLASS="CONSTANT"
+>VIDIOC_QUERYMENU</CODE
+></A
+> ioctls, get and set a
+control value with the <A
+HREF="#VIDIOC-G-CTRL"
+><CODE
+CLASS="CONSTANT"
+>VIDIOC_G_CTRL</CODE
+></A
+> and <A
+HREF="#VIDIOC-G-CTRL"
+><CODE
+CLASS="CONSTANT"
+>VIDIOC_S_CTRL</CODE
+></A
+> ioctls.
+Drivers must implement <CODE
+CLASS="CONSTANT"
+>VIDIOC_QUERYCTRL</CODE
+>,
+<CODE
+CLASS="CONSTANT"
+>VIDIOC_G_CTRL</CODE
+> and
+<CODE
+CLASS="CONSTANT"
+>VIDIOC_S_CTRL</CODE
+> when the device has one or more
+controls, <CODE
+CLASS="CONSTANT"
+>VIDIOC_QUERYMENU</CODE
+> when it has one or
+more menu type controls.</P
+><DIV
+CLASS="EXAMPLE"
+><A
+NAME="AEN630"
+></A
+><P
+><B
+>Example 1-8. Enumerating all controls</B
+></P
+><PRE
+CLASS="PROGRAMLISTING"
+>struct&nbsp;<A
+HREF="#V4L2-QUERYCTRL"
+>v4l2_queryctrl</A
+> queryctrl;
+struct&nbsp;<A
+HREF="#V4L2-QUERYMENU"
+>v4l2_querymenu</A
+> querymenu;
+
+static void
+enumerate_menu (void)
+{
+ printf (" Menu items:\n");
+
+ memset (&amp;querymenu, 0, sizeof (querymenu));
+ querymenu.id = queryctrl.id;
+
+ for (querymenu.index = queryctrl.minimum;
+ querymenu.index &#60;= queryctrl.maximum;
+ querymenu.index++) {
+ if (0 == ioctl (fd, <A
+HREF="#VIDIOC-QUERYCTRL"
+><CODE
+CLASS="CONSTANT"
+>VIDIOC_QUERYMENU</CODE
+></A
+>, &amp;querymenu)) {
+ printf (" %s\n", querymenu.name);
+ } else {
+ perror ("VIDIOC_QUERYMENU");
+ exit (EXIT_FAILURE);
+ }
+ }
+}
+
+memset (&amp;queryctrl, 0, sizeof (queryctrl));
+
+for (queryctrl.id = V4L2_CID_BASE;
+ queryctrl.id &#60; V4L2_CID_LASTP1;
+ queryctrl.id++) {
+ if (0 == ioctl (fd, <A
+HREF="#VIDIOC-QUERYCTRL"
+><CODE
+CLASS="CONSTANT"
+>VIDIOC_QUERYCTRL</CODE
+></A
+>, &amp;queryctrl)) {
+ if (queryctrl.flags &amp; V4L2_CTRL_FLAG_DISABLED)
+ continue;
+
+ printf ("Control %s\n", queryctrl.name);
+
+ if (queryctrl.type == V4L2_CTRL_TYPE_MENU)
+ enumerate_menu ();
+ } else {
+ if (errno == EINVAL)
+ continue;
+
+ perror ("VIDIOC_QUERYCTRL");
+ exit (EXIT_FAILURE);
+ }
+}
+
+for (queryctrl.id = V4L2_CID_PRIVATE_BASE;;
+ queryctrl.id++) {
+ if (0 == ioctl (fd, <A
+HREF="#VIDIOC-QUERYCTRL"
+><CODE
+CLASS="CONSTANT"
+>VIDIOC_QUERYCTRL</CODE
+></A
+>, &amp;queryctrl)) {
+ if (queryctrl.flags &#38; V4L2_CTRL_FLAG_DISABLED)
+ continue;
+
+ printf ("Control %s\n", queryctrl.name);
+
+ if (queryctrl.type == V4L2_CTRL_TYPE_MENU)
+ enumerate_menu ();
+ } else {
+ if (errno == EINVAL)
+ break;
+
+ perror ("VIDIOC_QUERYCTRL");
+ exit (EXIT_FAILURE);
+ }
+}
+ </PRE
+></DIV
+><DIV
+CLASS="EXAMPLE"
+><A
+NAME="AEN641"
+></A
+><P
+><B
+>Example 1-9. Changing controls</B
+></P
+><PRE
+CLASS="PROGRAMLISTING"
+>struct&nbsp;<A
+HREF="#V4L2-QUERYCTRL"
+>v4l2_queryctrl</A
+> queryctrl;
+struct&nbsp;<A
+HREF="#V4L2-CONTROL"
+>v4l2_control</A
+> control;
+
+memset (&amp;queryctrl, 0, sizeof (queryctrl));
+queryctrl.id = V4L2_CID_BRIGHTNESS;
+
+if (-1 == ioctl (fd, <A
+HREF="#VIDIOC-QUERYCTRL"
+><CODE
+CLASS="CONSTANT"
+>VIDIOC_QUERYCTRL</CODE
+></A
+>, &amp;queryctrl)) {
+ if (errno != EINVAL) {
+ perror ("VIDIOC_QUERYCTRL");
+ exit (EXIT_FAILURE);
+ } else {
+ printf ("V4L2_CID_BRIGHTNESS is not supported\n");
+ }
+} else if (queryctrl.flags &amp; V4L2_CTRL_FLAG_DISABLED) {
+ printf ("V4L2_CID_BRIGHTNESS is not supported\n");
+} else {
+ memset (&amp;control, 0, sizeof (control));
+ control.id = V4L2_CID_BRIGHTNESS;
+ control.value = queryctrl.default_value;
+
+ if (-1 == ioctl (fd, <A
+HREF="#VIDIOC-G-CTRL"
+><CODE
+CLASS="CONSTANT"
+>VIDIOC_S_CTRL</CODE
+></A
+>, &amp;control)) {
+ perror ("VIDIOC_S_CTRL");
+ exit (EXIT_FAILURE);
+ }
+}
+
+memset (&amp;control, 0, sizeof (control));
+control.id = V4L2_CID_CONTRAST;
+
+if (0 == ioctl (fd, <A
+HREF="#VIDIOC-G-CTRL"
+><CODE
+CLASS="CONSTANT"
+>VIDIOC_G_CTRL</CODE
+></A
+>, &amp;control)) {
+ control.value += 1;
+
+ /* The driver may clamp the value or return ERANGE, ignored here */
+
+ if (-1 == ioctl (fd, <A
+HREF="#VIDIOC-G-CTRL"
+><CODE
+CLASS="CONSTANT"
+>VIDIOC_S_CTRL</CODE
+></A
+>, &amp;control)
+ &#38;&#38; errno != ERANGE) {
+ perror ("VIDIOC_S_CTRL");
+ exit (EXIT_FAILURE);
+ }
+/* Ignore if V4L2_CID_CONTRAST is unsupported */
+} else if (errno != EINVAL) {
+ perror ("VIDIOC_G_CTRL");
+ exit (EXIT_FAILURE);
+}
+
+control.id = V4L2_CID_AUDIO_MUTE;
+control.value = TRUE; /* silence */
+
+/* Errors ignored */
+ioctl (fd, VIDIOC_S_CTRL, &amp;control);
+ </PRE
+></DIV
+></DIV
+><DIV
+CLASS="SECTION"
+><HR><H2
+CLASS="SECTION"
+><A
+NAME="FORMAT"
+>1.9. Data Formats</A
+></H2
+><DIV
+CLASS="SECTION"
+><H3
+CLASS="SECTION"
+><A
+NAME="AEN656"
+>1.9.1. Data Format Negotiation</A
+></H3
+><P
+>Different devices exchange different kinds of data with
+applications, for example video images, raw or sliced VBI data, RDS
+datagrams. Even within one kind many different formats are possible,
+in particular an abundance of image formats. Although drivers must
+provide a default and the selection persists across closing and
+reopening a device, applications should always negotiate a data format
+before engaging in data exchange. Negotiation means the application
+asks for a particular format and the driver selects and reports the
+best the hardware can do to satisfy the request. Of course
+applications can also just query the current selection.</P
+><P
+>A single mechanism exists to negotiate all data formats
+using the aggregate struct&nbsp;<A
+HREF="#V4L2-FORMAT"
+>v4l2_format</A
+> and the <A
+HREF="#VIDIOC-G-FMT"
+><CODE
+CLASS="CONSTANT"
+>VIDIOC_G_FMT</CODE
+></A
+> and
+<A
+HREF="#VIDIOC-G-FMT"
+><CODE
+CLASS="CONSTANT"
+>VIDIOC_S_FMT</CODE
+></A
+> ioctls. Additionally the <A
+HREF="#VIDIOC-G-FMT"
+><CODE
+CLASS="CONSTANT"
+>VIDIOC_TRY_FMT</CODE
+></A
+> ioctl can be
+used to examine what the hardware <SPAN
+CLASS="emphasis"
+><I
+CLASS="EMPHASIS"
+>could</I
+></SPAN
+> do,
+without actually selecting a new data format. The data formats
+supported by the V4L2 API are covered in the respective device section
+in <A
+HREF="#DEVICES"
+>Chapter 4</A
+>. For a closer look at image formats see
+<A
+HREF="#PIXFMT"
+>Chapter 2</A
+>.</P
+><P
+>The <CODE
+CLASS="CONSTANT"
+>VIDIOC_S_FMT</CODE
+> ioctl is a major
+turning-point in the initialization sequence. Prior to this point
+multiple panel applications can access the same device concurrently to
+select the current input, change controls or modify other properties.
+The first <CODE
+CLASS="CONSTANT"
+>VIDIOC_S_FMT</CODE
+> assigns a logical stream
+(video data, VBI data etc.) exclusively to one file descriptor.</P
+><P
+>Exclusive means no other application, more precisely no
+other file descriptor, can grab this stream or change device
+properties inconsistent with the negotiated parameters. A video
+standard change for example, when the new standard uses a different
+number of scan lines, can invalidate the selected image format.
+Therefore only the file descriptor owning the stream can make
+invalidating changes. Accordingly multiple file descriptors which
+grabbed different logical streams prevent each other from interfering
+with their settings. When for example video overlay is about to start
+or already in progress, simultaneous video capturing may be restricted
+to the same cropping and image size.</P
+><P
+>When applications omit the
+<CODE
+CLASS="CONSTANT"
+>VIDIOC_S_FMT</CODE
+> ioctl its locking side effects are
+implied by the next step, the selection of an I/O method with the
+<A
+HREF="#VIDIOC-REQBUFS"
+><CODE
+CLASS="CONSTANT"
+>VIDIOC_REQBUFS</CODE
+></A
+> ioctl or implicit with the first <A
+HREF="#FUNC-READ"
+><CODE
+CLASS="FUNCTION"
+>read()</CODE
+></A
+> or
+<A
+HREF="#FUNC-WRITE"
+><CODE
+CLASS="FUNCTION"
+>write()</CODE
+></A
+> call.</P
+><P
+>Generally only one logical stream can be assigned to a
+file descriptor, the exception being drivers permitting simultaneous
+video capturing and overlay using the same file descriptor for
+compatibility with V4L and earlier versions of V4L2. Switching the
+logical stream or returning into "panel mode" is possible by closing
+and reopening the device. Drivers <SPAN
+CLASS="emphasis"
+><I
+CLASS="EMPHASIS"
+>may</I
+></SPAN
+> support a
+switch using <CODE
+CLASS="CONSTANT"
+>VIDIOC_S_FMT</CODE
+>.</P
+><P
+>All drivers exchanging data with
+applications must support the <CODE
+CLASS="CONSTANT"
+>VIDIOC_G_FMT</CODE
+> and
+<CODE
+CLASS="CONSTANT"
+>VIDIOC_S_FMT</CODE
+> ioctl. Implementation of the
+<CODE
+CLASS="CONSTANT"
+>VIDIOC_TRY_FMT</CODE
+> is highly recommended but
+optional.</P
+></DIV
+><DIV
+CLASS="SECTION"
+><HR><H3
+CLASS="SECTION"
+><A
+NAME="AEN689"
+>1.9.2. Image Format Enumeration</A
+></H3
+><P
+>Apart of the generic format negotiation functions
+a special ioctl to enumerate all image formats supported by video
+capture, overlay or output devices is available.<A
+NAME="AEN692"
+HREF="#FTN.AEN692"
+><SPAN
+CLASS="footnote"
+>[11]</SPAN
+></A
+></P
+><P
+>The <A
+HREF="#VIDIOC-ENUM-FMT"
+><CODE
+CLASS="CONSTANT"
+>VIDIOC_ENUM_FMT</CODE
+></A
+> ioctl must be supported
+by all drivers exchanging image data with applications.</P
+><DIV
+CLASS="IMPORTANT"
+><BLOCKQUOTE
+CLASS="IMPORTANT"
+><P
+><B
+>Important: </B
+>Drivers are not supposed to convert image formats in
+kernel space. They must enumerate only formats directly supported by
+the hardware. If necessary driver writers should publish an example
+conversion routine or library for integration into applications.</P
+></BLOCKQUOTE
+></DIV
+></DIV
+></DIV
+><DIV
+CLASS="SECTION"
+><HR><H2
+CLASS="SECTION"
+><A
+NAME="CROP"
+>1.10. Cropping and Scaling</A
+></H2
+><P
+>Some video capture devices can take a subsection of the
+complete picture and shrink or enlarge to an image of arbitrary size.
+We call these abilities cropping and scaling. Not quite correct
+"cropping" shall also refer to the inverse process, output devices
+showing an image in only a region of the picture, and/or scaled
+from a source image of different size.</P
+><P
+>To crop and scale this API defines a source and target
+rectangle. On a video capture and overlay device the source is the
+received video picture, the target is the captured or overlaid image.
+On a video output device the source is the image passed by the
+application and the target is the generated video picture. The
+remainder of this section refers only to video capture drivers, the
+definitions apply to output drivers accordingly.</P
+><DIV
+CLASS="FIGURE"
+><A
+NAME="CROP-SCALE"
+></A
+><P
+><B
+>Figure 1-1. Cropping and Scaling</B
+></P
+><DIV
+CLASS="MEDIAOBJECT"
+><P
+><IMG
+SRC="crop.gif"></P
+></DIV
+></DIV
+><P
+>It is assumed the driver can capture a subsection of the
+picture within an arbitrary capture window. Its bounds are defined by
+struct&nbsp;<A
+HREF="#V4L2-CROPCAP"
+>v4l2_cropcap</A
+>, giving the coordinates of the top, left corner and
+width and height of the window in pixels. Origin and units of the
+coordinate system in the analog domain are arbitrarily chosen by the
+driver writer.<A
+NAME="AEN714"
+HREF="#FTN.AEN714"
+><SPAN
+CLASS="footnote"
+>[12]</SPAN
+></A
+></P
+><P
+>The source rectangle is defined by struct&nbsp;<A
+HREF="#V4L2-CROP"
+>v4l2_crop</A
+>, giving the
+coordinates of its top, left corner, width and height using the same
+coordinate system as struct&nbsp;<A
+HREF="#V4L2-CROPCAP"
+>v4l2_cropcap</A
+>. The source rectangle must lie
+completely within the capture window. Further each driver defines a
+default source rectangle. The center of this rectangle shall align
+with the center of the active picture area of the video signal, and
+cover what the driver writer considers the complete picture. The
+source rectangle is set to the default when the driver is first
+loaded, but not later.</P
+><P
+>The target rectangle is given either by the
+<CODE
+CLASS="STRUCTFIELD"
+>width</CODE
+> and <CODE
+CLASS="STRUCTFIELD"
+>height</CODE
+>
+fields of struct&nbsp;<A
+HREF="#V4L2-PIX-FORMAT"
+>v4l2_pix_format</A
+> or the <CODE
+CLASS="STRUCTFIELD"
+>width</CODE
+>
+and <CODE
+CLASS="STRUCTFIELD"
+>height</CODE
+> fields of the struct&nbsp;<A
+HREF="#V4L2-RECT"
+>v4l2_rect</A
+>
+<CODE
+CLASS="STRUCTFIELD"
+>w</CODE
+> substructure of struct&nbsp;<A
+HREF="#V4L2-WINDOW"
+>v4l2_window</A
+>.</P
+><P
+>In principle cropping and scaling always happens. When the
+device supports scaling but not cropping, applications will be unable
+to change the cropping rectangle. It remains at the defaults all the
+time. When the device supports cropping but not scaling, changing the
+image size will also affect the cropping size in order to maintain a
+constant scaling factor. The position of the cropping rectangle is
+only adjusted to move the rectangle completely inside the capture
+window.</P
+><P
+>When cropping and scaling is supported applications can
+change both the source and target rectangle. Various hardware
+limitations must be expected, for example discrete scaling factors,
+different scaling abilities in horizontal and vertical direction,
+limitations of the image size or the cropping alignment. Therefore as
+usual drivers adjust the requested parameters against hardware
+capabilities and return the actual values selected. An important
+difference, because two rectangles are defined, is that the last
+rectangle changed shall take priority, and the driver may also adjust
+the opposite rectangle.</P
+><P
+>Suppose scaling is restricted to a factor 1:1 or 2:1 in
+either direction and the image size must be a multiple of
+16&nbsp;&times;&nbsp;16 pixels. The cropping rectangle be set to the
+upper limit, 640&nbsp;&times;&nbsp;400 pixels at offset 0,&nbsp;0. Let
+a video capture application request an image size of
+300&nbsp;&times;&nbsp;225 pixels, assuming video will be scaled down
+from the "full picture" accordingly. The driver will set the image
+size to the closest possible values 304&nbsp;&times;&nbsp;224, then
+choose the cropping rectangle closest to the requested size, that is
+608&nbsp;&times;&nbsp;224 (224&nbsp;&times;&nbsp;2:1 would exceed the
+limit 400). The offset 0,&nbsp;0 is still valid, thus unmodified.
+Given the default cropping rectangle reported by
+<CODE
+CLASS="CONSTANT"
+>VIDIOC_CROPCAP</CODE
+> the application can easily propose
+another offset to center the cropping rectangle. Now the application may
+insist on covering an area using an aspect closer to the original
+request. Sheepish it asks for a cropping rectangle of
+608&nbsp;&times;&nbsp;456 pixels. The present scaling factors limit
+cropping to 640&nbsp;&times;&nbsp;384, so the driver returns the
+cropping size 608&nbsp;&times;&nbsp;384 and accordingly adjusts
+the image size to 304&nbsp;&times;&nbsp;192.</P
+><P
+>Eventually some crop or scale parameters are locked, for
+example when the driver supports simultaneous video capturing and
+overlay, another application already started overlay and the cropping
+parameters cannot be changed anymore. Also <A
+HREF="#VIDIOC-G-FMT"
+><CODE
+CLASS="CONSTANT"
+>VIDIOC_TRY_FMT</CODE
+></A
+> cannot
+change the cropping rectangle. In these cases the driver has to
+approach the closest values possible without adjusting the opposite
+rectangle.</P
+><P
+>The struct&nbsp;<A
+HREF="#V4L2-CROPCAP"
+>v4l2_cropcap</A
+>, which also reports the pixel aspect ratio,
+can be obtained with the <A
+HREF="#VIDIOC-CROPCAP"
+><CODE
+CLASS="CONSTANT"
+>VIDIOC_CROPCAP</CODE
+></A
+> ioctl. To get or set the
+current cropping rectangle applications call the <A
+HREF="#VIDIOC-G-CROP"
+><CODE
+CLASS="CONSTANT"
+>VIDIOC_G_CROP</CODE
+></A
+> or
+<A
+HREF="#VIDIOC-G-CROP"
+><CODE
+CLASS="CONSTANT"
+>VIDIOC_S_CROP</CODE
+></A
+> ioctl, respectively. All video capture and output
+devices must support the <CODE
+CLASS="CONSTANT"
+>VIDIOC_CROPCAP</CODE
+> ioctl.
+The <CODE
+CLASS="CONSTANT"
+>VIDIOC_G_CROP</CODE
+> and
+<CODE
+CLASS="CONSTANT"
+>VIDIOC_S_CROP</CODE
+> ioctls only when the cropping
+rectangle can be changed.</P
+><P
+>Note as usual the cropping parameters remain unchanged
+across closing and reopening a device. Applications should ensure the
+parameters are suitable before starting I/O.</P
+><DIV
+CLASS="EXAMPLE"
+><A
+NAME="AEN747"
+></A
+><P
+><B
+>Example 1-10. Resetting the cropping parameters</B
+></P
+><P
+>(A video capture device is assumed.)</P
+><PRE
+CLASS="PROGRAMLISTING"
+>struct&nbsp;<A
+HREF="#V4L2-CROPCAP"
+>v4l2_cropcap</A
+> cropcap;
+struct&nbsp;<A
+HREF="#V4L2-CROP"
+>v4l2_crop</A
+> crop;
+
+memset (&amp;cropcap, 0, sizeof (cropcap));
+cropcap.type = V4L2_BUF_TYPE_VIDEO_CAPTURE;
+
+if (-1 == ioctl (fd, <A
+HREF="#VIDIOC-CROPCAP"
+><CODE
+CLASS="CONSTANT"
+>VIDIOC_CROPCAP</CODE
+></A
+>, &amp;cropcap)) {
+ perror ("VIDIOC_CROPCAP");
+ exit (EXIT_FAILURE);
+}
+
+memset (&amp;crop, 0, sizeof (crop));
+crop.type = V4L2_BUF_TYPE_VIDEO_CAPTURE;
+crop.c = cropcap.defrect;
+
+/* Ignore if cropping is not supported (EINVAL) */
+
+if (-1 == ioctl (fd, <A
+HREF="#VIDIOC-G-CROP"
+><CODE
+CLASS="CONSTANT"
+>VIDIOC_S_CROP</CODE
+></A
+>, &amp;crop)
+ &#38;&#38; errno != EINVAL) {
+ perror ("VIDIOC_S_CROP");
+ exit (EXIT_FAILURE);
+}
+ </PRE
+></DIV
+><DIV
+CLASS="EXAMPLE"
+><A
+NAME="AEN757"
+></A
+><P
+><B
+>Example 1-11. Simple downscaling</B
+></P
+><P
+>(A video capture device is assumed.)</P
+><PRE
+CLASS="PROGRAMLISTING"
+>struct&nbsp;<A
+HREF="#V4L2-CROPCAP"
+>v4l2_cropcap</A
+> cropcap;
+struct&nbsp;<A
+HREF="#V4L2-FORMAT"
+>v4l2_format</A
+> format;
+
+reset_cropping_parameters ();
+
+/* Scale down to 1/4 size of full picture */
+
+memset (&amp;format, 0, sizeof (format)); /* defaults */
+
+format.type = V4L2_BUF_TYPE_VIDEO_CAPTURE;
+
+format.fmt.pix.width = cropcap.defrect.width &#62;&#62; 1;
+format.fmt.pix.height = cropcap.defrect.height &#62;&#62; 1;
+format.fmt.pix.pixelformat = V4L2_PIX_FMT_YUYV;
+
+if (-1 == ioctl (fd, <A
+HREF="#VIDIOC-G-FMT"
+><CODE
+CLASS="CONSTANT"
+>VIDIOC_S_FMT</CODE
+></A
+>, &amp;format)) {
+ perror ("VIDIOC_S_FORMAT");
+ exit (EXIT_FAILURE);
+}
+
+/* We could check now what we got, the exact scaling factor
+ or if the driver can scale at all. At mere 2:1 the cropping
+ rectangle was probably not changed. */
+ </PRE
+></DIV
+><DIV
+CLASS="EXAMPLE"
+><A
+NAME="AEN765"
+></A
+><P
+><B
+>Example 1-12. Current scaling factor and pixel aspect</B
+></P
+><P
+>(A video capture device is assumed.)</P
+><PRE
+CLASS="PROGRAMLISTING"
+>struct&nbsp;<A
+HREF="#V4L2-CROPCAP"
+>v4l2_cropcap</A
+> cropcap;
+struct&nbsp;<A
+HREF="#V4L2-CROP"
+>v4l2_crop</A
+> crop;
+struct&nbsp;<A
+HREF="#V4L2-FORMAT"
+>v4l2_format</A
+> format;
+double hscale, vscale;
+double aspect;
+int dwidth, dheight;
+
+memset (&amp;cropcap, 0, sizeof (cropcap));
+cropcap.type = V4L2_BUF_TYPE_VIDEO_CAPTURE;
+
+if (-1 == ioctl (fd, <A
+HREF="#VIDIOC-CROPCAP"
+><CODE
+CLASS="CONSTANT"
+>VIDIOC_CROPCAP</CODE
+></A
+>, &amp;cropcap)) {
+ perror ("VIDIOC_CROPCAP");
+ exit (EXIT_FAILURE);
+}
+
+memset (&amp;crop, 0, sizeof (crop));
+crop.type = V4L2_BUF_TYPE_VIDEO_CAPTURE;
+
+if (-1 == ioctl (fd, <A
+HREF="#VIDIOC-G-CROP"
+><CODE
+CLASS="CONSTANT"
+>VIDIOC_G_CROP</CODE
+></A
+>, &amp;crop)) {
+ if (errno != EINVAL) {
+ perror ("VIDIOC_G_CROP");
+ exit (EXIT_FAILURE);
+ }
+
+ /* Cropping not supported */
+ crop.c = cropcap.defrect;
+}
+
+memset (&amp;format, 0, sizeof (format));
+format.fmt.type = V4L2_BUF_TYPE_VIDEO_CAPTURE;
+
+if (-1 == ioctl (fd, <A
+HREF="#VIDIOC-G-FMT"
+><CODE
+CLASS="CONSTANT"
+>VIDIOC_G_FMT</CODE
+></A
+>, &amp;format)) {
+ perror ("VIDIOC_G_FMT");
+ exit (EXIT_FAILURE);
+}
+
+hscale = format.fmt.pix.width / (double) crop.c.width;
+vscale = format.fmt.pix.height / (double) crop.c.height;
+
+aspect = cropcap.pixelaspect.numerator /
+ (double) cropcap.pixelaspect.denominator;
+aspect = aspect * hscale / vscale;
+
+/* Aspect corrected display size */
+
+dwidth = format.fmt.pix.width / aspect;
+dheight = format.fmt.pix.height;
+ </PRE
+></DIV
+></DIV
+><DIV
+CLASS="SECTION"
+><HR><H2
+CLASS="SECTION"
+><A
+NAME="STREAMING-PAR"
+>1.11. Streaming Parameters</A
+></H2
+><P
+>Streaming parameters are intended to optimize the video
+capture process as well as I/O. Presently applications can request a
+high quality capture mode with the <A
+HREF="#VIDIOC-G-PARM"
+><CODE
+CLASS="CONSTANT"
+>VIDIOC_S_PARM</CODE
+></A
+> ioctl.</P
+><P
+>The current video standard determines a nominal number of
+frames per second. If less than this number of frames is to be
+captured or output, applications can request frame skipping or
+duplicating on the driver side. This is espcially useful when using
+the <CODE
+CLASS="FUNCTION"
+>read()</CODE
+> or <CODE
+CLASS="FUNCTION"
+>write()</CODE
+>, which
+are not augmented by timestamps or sequence counters, and to avoid
+uneccessary data copying.</P
+><P
+>Finally these ioctls can be used to determine the number of
+buffers used internally by a driver in read/write mode. For
+implications see the section discussing the <A
+HREF="#FUNC-READ"
+><CODE
+CLASS="FUNCTION"
+>read()</CODE
+></A
+>
+function.</P
+><P
+>To get and set the streaming parameters applications call
+the <A
+HREF="#VIDIOC-G-PARM"
+><CODE
+CLASS="CONSTANT"
+>VIDIOC_G_PARM</CODE
+></A
+> and <A
+HREF="#VIDIOC-G-PARM"
+><CODE
+CLASS="CONSTANT"
+>VIDIOC_S_PARM</CODE
+></A
+> ioctl, respectively. They take
+a pointer to a struct&nbsp;<A
+HREF="#V4L2-STREAMPARM"
+>v4l2_streamparm</A
+>, which contains a union holding
+separate parameters for input and output devices.</P
+><P
+>These ioctls are optional, drivers need not implement
+them. If so, they return the <SPAN
+CLASS="ERRORCODE"
+>EINVAL</SPAN
+> error code.</P
+></DIV
+></DIV
+><DIV
+CLASS="CHAPTER"
+><HR><H1
+><A
+NAME="PIXFMT"
+></A
+>Chapter 2. Image Formats</H1
+><P
+>The V4L2 API was primarily designed for devices exchanging
+image data with applications. The
+<CODE
+CLASS="STRUCTNAME"
+>v4l2_pix_format</CODE
+> structure defines the format
+and layout of an image in memory. Image formats are negotiated with
+the <A
+HREF="#VIDIOC-G-FMT"
+><CODE
+CLASS="CONSTANT"
+>VIDIOC_S_FMT</CODE
+></A
+> ioctl. (The explanations here focus on video
+capturing and output, for overlay frame buffer formats see also
+<A
+HREF="#VIDIOC-G-FBUF"
+><CODE
+CLASS="CONSTANT"
+>VIDIOC_G_FBUF</CODE
+></A
+>.)</P
+><DIV
+CLASS="TABLE"
+><A
+NAME="V4L2-PIX-FORMAT"
+></A
+><P
+><B
+>Table 2-1. struct <CODE
+CLASS="STRUCTNAME"
+>v4l2_pix_format</CODE
+></B
+></P
+><TABLE
+BORDER="0"
+FRAME="void"
+WIDTH="100%"
+CLASS="CALSTABLE"
+><COL
+WIDTH="25%"
+TITLE="C1"><COL
+WIDTH="25%"
+TITLE="C2"><COL
+WIDTH="50%"
+TITLE="C3"><TBODY
+><TR
+><TD
+>__u32</TD
+><TD
+><CODE
+CLASS="STRUCTFIELD"
+>width</CODE
+></TD
+><TD
+>Image width in pixels.</TD
+></TR
+><TR
+><TD
+>__u32</TD
+><TD
+><CODE
+CLASS="STRUCTFIELD"
+>height</CODE
+></TD
+><TD
+>Image height in pixels.</TD
+></TR
+><TR
+><TD
+COLSPAN="3"
+>Applications set these fields to
+request an image size, drivers return the closest possible values. In
+case of planar formats the <CODE
+CLASS="STRUCTFIELD"
+>width</CODE
+> and
+<CODE
+CLASS="STRUCTFIELD"
+>height</CODE
+> applies to the largest plane. To
+avoid ambiguities drivers must return values rounded up to a multiple
+of the scale factor of any smaller planes. For example when the image
+format is YUV 4:2:0, <CODE
+CLASS="STRUCTFIELD"
+>width</CODE
+> and
+<CODE
+CLASS="STRUCTFIELD"
+>height</CODE
+> must be multiples of two.</TD
+></TR
+><TR
+><TD
+>__u32</TD
+><TD
+><CODE
+CLASS="STRUCTFIELD"
+>pixelformat</CODE
+></TD
+><TD
+>The pixel format or type of compression, set by the
+application. This is a little endian <A
+HREF="#V4L2-FOURCC"
+>four character code</A
+>. V4L2 defines
+standard RGB formats in <A
+HREF="#RGB-FORMATS"
+>Table 2-3</A
+>, YUV formats in <A
+HREF="#YUV-FORMATS"
+>Section 2.4</A
+>, and reserved codes in <A
+HREF="#RESERVED-FORMATS"
+>Table 2-4</A
+></TD
+></TR
+><TR
+><TD
+>enum&nbsp;<A
+HREF="#V4L2-FIELD"
+>v4l2_field</A
+></TD
+><TD
+><CODE
+CLASS="STRUCTFIELD"
+>field</CODE
+></TD
+><TD
+>Video images are typically interlaced. Applications
+can request to capture or output only the top or bottom field, or both
+fields interlaced or sequentially stored in one buffer or alternating
+in separate buffers. Drivers return the actual field order selected.
+For details see <A
+HREF="#FIELD-ORDER"
+>Section 3.6</A
+>.</TD
+></TR
+><TR
+><TD
+>__u32</TD
+><TD
+><CODE
+CLASS="STRUCTFIELD"
+>bytesperline</CODE
+></TD
+><TD
+>Distance in bytes between the leftmost pixels in two
+adjacent lines.</TD
+></TR
+><TR
+><TD
+COLSPAN="3"
+><P
+>Both applications and drivers
+can set this field to request padding bytes at the end of each line.
+Drivers however may ignore the value requested by the application,
+returning <CODE
+CLASS="STRUCTFIELD"
+>width</CODE
+> times bytes per pixel or a
+larger value required by the hardware. That implies applications can
+just set this field to zero to get a reasonable
+default.</P
+><P
+>Video hardware may access padding bytes,
+therefore they must reside in accessible memory. Consider cases where
+padding bytes after the last line of an image cross a system page
+boundary. Input devices may write padding bytes, the value is
+undefined. Output devices ignore the contents of padding
+bytes.</P
+><P
+>When the image format is planar the
+<CODE
+CLASS="STRUCTFIELD"
+>bytesperline</CODE
+> value applies to the largest
+plane and is divided by the same factor as the
+<CODE
+CLASS="STRUCTFIELD"
+>width</CODE
+> field for any smaller planes. For
+example the Cb and Cr planes of a YUV 4:2:0 image have half as many
+padding bytes following each line as the Y plane. To avoid ambiguities
+drivers must return a <CODE
+CLASS="STRUCTFIELD"
+>bytesperline</CODE
+> value
+rounded up to a multiple of the scale factor.</P
+></TD
+></TR
+><TR
+><TD
+>__u32</TD
+><TD
+><CODE
+CLASS="STRUCTFIELD"
+>sizeimage</CODE
+></TD
+><TD
+>Size in bytes of the buffer to hold a complete image,
+set by the driver. Usually this is
+<CODE
+CLASS="STRUCTFIELD"
+>bytesperline</CODE
+> times
+<CODE
+CLASS="STRUCTFIELD"
+>height</CODE
+>. When the image consists of variable
+length compressed data this is the maximum number of bytes required to
+hold an image.</TD
+></TR
+><TR
+><TD
+>enum&nbsp;<A
+HREF="#V4L2-COLORSPACE"
+>v4l2_colorspace</A
+></TD
+><TD
+><CODE
+CLASS="STRUCTFIELD"
+>colorspace</CODE
+></TD
+><TD
+>This information supplements the
+<CODE
+CLASS="STRUCTFIELD"
+>pixelformat</CODE
+> and must be set by the driver,
+see <A
+HREF="#COLORSPACES"
+>Section 2.2</A
+>.</TD
+></TR
+><TR
+><TD
+>__u32</TD
+><TD
+><CODE
+CLASS="STRUCTFIELD"
+>priv</CODE
+></TD
+><TD
+>Reserved for custom (driver defined) additional
+information about formats. When not used drivers and applications must
+set this field to zero.</TD
+></TR
+></TBODY
+></TABLE
+></DIV
+><DIV
+CLASS="SECTION"
+><HR><H2
+CLASS="SECTION"
+><A
+NAME="AEN880"
+>2.1. Standard Image Formats</A
+></H2
+><P
+>In order to exchange images between drivers and
+applications, it is necessary to have standard image data formats
+which both sides will interpret the same way. V4L2 includes several
+such formats, and this section is intended to be an unambiguous
+specification of the standard image data formats in V4L2.</P
+><P
+>V4L2 drivers are not limited to these formats, however.
+Driver-specific formats are possible. In that case the application may
+depend on a codec to convert images to one of the standard formats
+when needed. But the data can still be stored and retrieved in the
+proprietary format. For example, a device may support a proprietary
+compressed format. Applications can still capture and save the data in
+the compressed format, saving much disk space, and later use a codec
+to convert the images to the X Windows screen format when the video is
+to be displayed.</P
+><P
+>Even so, ultimately, some standard formats are needed, so
+the V4L2 specification would not be complete without well-defined
+standard formats.</P
+><P
+>The V4L2 standard formats are mainly uncompressed formats. The
+pixels are always arranged in memory from left to right, and from top
+to bottom. The first byte of data in the image buffer is always for
+the leftmost pixel of the topmost row. Following that is the pixel
+immediately to its right, and so on until the end of the top row of
+pixels. Following the rightmost pixel of the row there may be zero or
+more bytes of padding to guarantee that each row of pixel data has a
+certain alignment. Following the pad bytes, if any, is data for the
+leftmost pixel of the second row from the top, and so on. The last row
+has just as many pad bytes after it as the other rows.</P
+><P
+>In V4L2 each format has an identifier which looks like
+<CODE
+CLASS="CONSTANT"
+>PIX_FMT_XXX</CODE
+>, defined in the <A
+HREF="#VIDEODEV"
+>videodev.h</A
+> header file. These identifiers
+represent <A
+HREF="#V4L2-FOURCC"
+>four character codes</A
+>
+which are also listed below, however they are not the same as those
+used in the Windows world.</P
+></DIV
+><DIV
+CLASS="SECTION"
+><HR><H2
+CLASS="SECTION"
+><A
+NAME="COLORSPACES"
+>2.2. Colorspaces</A
+></H2
+><P
+>[intro]</P
+><P
+> <P
+></P
+><DIV
+CLASS="VARIABLELIST"
+><DL
+><DT
+>Gamma Correction</DT
+><DD
+><P
+>[to do]</P
+><P
+>E'<SUB
+>R</SUB
+> = f(R)</P
+><P
+>E'<SUB
+>G</SUB
+> = f(G)</P
+><P
+>E'<SUB
+>B</SUB
+> = f(B)</P
+></DD
+><DT
+>Construction of luminance and color-difference
+signals</DT
+><DD
+><P
+>[to do]</P
+><P
+>E'<SUB
+>Y</SUB
+> =
+Coeff<SUB
+>R</SUB
+> E'<SUB
+>R</SUB
+>
++ Coeff<SUB
+>G</SUB
+> E'<SUB
+>G</SUB
+>
++ Coeff<SUB
+>B</SUB
+> E'<SUB
+>B</SUB
+></P
+><P
+>(E'<SUB
+>R</SUB
+> - E'<SUB
+>Y</SUB
+>) = E'<SUB
+>R</SUB
+>
+- Coeff<SUB
+>R</SUB
+> E'<SUB
+>R</SUB
+>
+- Coeff<SUB
+>G</SUB
+> E'<SUB
+>G</SUB
+>
+- Coeff<SUB
+>B</SUB
+> E'<SUB
+>B</SUB
+></P
+><P
+>(E'<SUB
+>B</SUB
+> - E'<SUB
+>Y</SUB
+>) = E'<SUB
+>B</SUB
+>
+- Coeff<SUB
+>R</SUB
+> E'<SUB
+>R</SUB
+>
+- Coeff<SUB
+>G</SUB
+> E'<SUB
+>G</SUB
+>
+- Coeff<SUB
+>B</SUB
+> E'<SUB
+>B</SUB
+></P
+></DD
+><DT
+>Re-normalized color-difference signals</DT
+><DD
+><P
+>The color-difference signals are scaled back to unity
+range [-0.5;+0.5]:</P
+><P
+>K<SUB
+>B</SUB
+> = 0.5 / (1 - Coeff<SUB
+>B</SUB
+>)</P
+><P
+>K<SUB
+>R</SUB
+> = 0.5 / (1 - Coeff<SUB
+>R</SUB
+>)</P
+><P
+>P<SUB
+>B</SUB
+> =
+K<SUB
+>B</SUB
+> (E'<SUB
+>B</SUB
+> - E'<SUB
+>Y</SUB
+>) =
+ 0.5 (Coeff<SUB
+>R</SUB
+> / Coeff<SUB
+>B</SUB
+>) E'<SUB
+>R</SUB
+>
++ 0.5 (Coeff<SUB
+>G</SUB
+> / Coeff<SUB
+>B</SUB
+>) E'<SUB
+>G</SUB
+>
++ 0.5 E'<SUB
+>B</SUB
+></P
+><P
+>P<SUB
+>R</SUB
+> =
+K<SUB
+>R</SUB
+> (E'<SUB
+>R</SUB
+> - E'<SUB
+>Y</SUB
+>) =
+ 0.5 E'<SUB
+>R</SUB
+>
++ 0.5 (Coeff<SUB
+>G</SUB
+> / Coeff<SUB
+>R</SUB
+>) E'<SUB
+>G</SUB
+>
++ 0.5 (Coeff<SUB
+>B</SUB
+> / Coeff<SUB
+>R</SUB
+>) E'<SUB
+>B</SUB
+></P
+></DD
+><DT
+>Quantization</DT
+><DD
+><P
+>[to do]</P
+><P
+>Y' = (Lum. Levels - 1) &middot; E'<SUB
+>Y</SUB
+> + Lum. Offset</P
+><P
+>C<SUB
+>B</SUB
+> = (Chrom. Levels - 1)
+&middot; P<SUB
+>B</SUB
+> + Chrom. Offset</P
+><P
+>C<SUB
+>R</SUB
+> = (Chrom. Levels - 1)
+&middot; P<SUB
+>R</SUB
+> + Chrom. Offset</P
+><P
+>Rounding to the nearest integer and clamping to the range
+[0;255] finally yields the digital color components Y'CbCr
+stored in YUV images.</P
+></DD
+></DL
+></DIV
+>
+ </P
+><DIV
+CLASS="EXAMPLE"
+><A
+NAME="AEN984"
+></A
+><P
+><B
+>Example 2-1. ITU-R Rec. BT.601 color conversion</B
+></P
+><P
+>Forward Transformation</P
+><PRE
+CLASS="PROGRAMLISTING"
+>int ER, EG, EB; /* gamma corrected RGB input [0;255] */
+int Y1, Cb, Cr; /* output [0;255] */
+
+double r, g, b; /* temporaries */
+double y1, pb, pr;
+
+int
+clamp (double x)
+{
+ int r = x; /* round to nearest */
+
+ if (r &#60; 0) return 0;
+ else if (r &#62; 255) return 255;
+ else return r;
+}
+
+r = ER / 255.0;
+g = EG / 255.0;
+b = EB / 255.0;
+
+y1 = 0.299 * r + 0.587 * g + 0.114 * b;
+pb = -0.169 * r - 0.331 * g + 0.5 * b;
+pr = 0.5 * r - 0.419 * g - 0.081 * b;
+
+Y1 = clamp (219 * y1 + 16);
+Cb = clamp (224 * pb + 128);
+Cr = clamp (224 * pr + 128);
+
+/* or shorter */
+
+y1 = 0.299 * ER + 0.587 * EG + 0.114 * EB;
+
+Y1 = clamp ( (219 / 255.0) * y1 + 16);
+Cb = clamp (((224 / 255.0) / (2 - 2 * 0.114)) * (EB - y1) + 128);
+Cr = clamp (((224 / 255.0) / (2 - 2 * 0.299)) * (ER - y1) + 128);
+ </PRE
+><P
+>Inverse Transformation</P
+><PRE
+CLASS="PROGRAMLISTING"
+>int Y1, Cb, Cr; /* gamma pre-corrected input [0;255] */
+int ER, EG, EB; /* output [0;255] */
+
+double r, g, b; /* temporaries */
+double y1, pb, pr;
+
+int
+clamp (double x)
+{
+ int r = x; /* round to nearest */
+
+ if (r &#60; 0) return 0;
+ else if (r &#62; 255) return 255;
+ else return r;
+}
+
+y1 = (255 / 219.0) * (Y1 - 16);
+pb = (255 / 224.0) * (Cb - 128);
+pr = (255 / 224.0) * (Cr - 128);
+
+r = 1.0 * y1 + 0 * pb + 1.402 * pr;
+g = 1.0 * y1 - 0.344 * pb - 0.714 * pr;
+b = 1.0 * y1 + 1.772 * pb + 0 * pr;
+
+ER = clamp (r * 255); /* [ok? one should prob. limit y1,pb,pr] */
+EG = clamp (g * 255);
+EB = clamp (b * 255);
+ </PRE
+></DIV
+><DIV
+CLASS="TABLE"
+><A
+NAME="V4L2-COLORSPACE"
+></A
+><P
+><B
+>Table 2-2. enum v4l2_colorspace</B
+></P
+><TABLE
+BORDER="1"
+WIDTH="100%"
+CLASS="CALSTABLE"
+><COL
+WIDTH="9%"
+ALIGN="LEFT"><COL
+WIDTH="9%"
+ALIGN="CENTER"><COL
+WIDTH="9%"
+ALIGN="LEFT"><COL
+WIDTH="9%"
+TITLE="CR"><COL
+WIDTH="9%"
+TITLE="CG"><COL
+WIDTH="9%"
+TITLE="CB"><COL
+WIDTH="9%"
+TITLE="WP"><COL
+WIDTH="9%"
+TITLE="GC"><COL
+WIDTH="9%"
+TITLE="LUM"><COL
+WIDTH="9%"
+TITLE="QY"><COL
+WIDTH="9%"
+TITLE="QC"><THEAD
+><TR
+><TH
+ROWSPAN="2"
+>Identifier</TH
+><TH
+ROWSPAN="2"
+>Value</TH
+><TH
+ROWSPAN="2"
+>Description</TH
+><TH
+COLSPAN="3"
+>Chromaticities<A
+NAME="AEN1013"
+HREF="#FTN.AEN1013"
+><SPAN
+CLASS="footnote"
+>[a]</SPAN
+></A
+></TH
+><TH
+ROWSPAN="2"
+>White Point</TH
+><TH
+ROWSPAN="2"
+>Gamma Correction</TH
+><TH
+ROWSPAN="2"
+>Luminance E'<SUB
+>Y</SUB
+></TH
+><TH
+COLSPAN="2"
+>Quantization</TH
+></TR
+><TR
+><TH
+>Red</TH
+><TH
+>Green</TH
+><TH
+>Blue</TH
+><TH
+>Y'</TH
+><TH
+>Cb, Cr</TH
+></TR
+></THEAD
+><TBODY
+><TR
+><TD
+><CODE
+CLASS="CONSTANT"
+>V4L2_COLORSPACE_SMPTE170M</CODE
+></TD
+><TD
+>1</TD
+><TD
+>NTSC/PAL according to <A
+HREF="#SMPTE170M"
+><ABBR
+CLASS="ABBREV"
+>SMPTE170M</ABBR
+></A
+>,
+<A
+HREF="#ITU601"
+><ABBR
+CLASS="ABBREV"
+>ITU601</ABBR
+></A
+></TD
+><TD
+>x&nbsp;=&nbsp;0.630, y&nbsp;=&nbsp;0.340</TD
+><TD
+>x&nbsp;=&nbsp;0.310, y&nbsp;=&nbsp;0.595</TD
+><TD
+>x&nbsp;=&nbsp;0.155, y&nbsp;=&nbsp;0.070</TD
+><TD
+>x&nbsp;=&nbsp;0.3127, y&nbsp;=&nbsp;0.3290,
+ Illuminant D<SUB
+>65</SUB
+></TD
+><TD
+>E' = 4.5&nbsp;I&nbsp;for&nbsp;I&nbsp;&le;0.018,
+1.099&nbsp;I<SUP
+>0.45</SUP
+>&nbsp;-&nbsp;0.099&nbsp;for&nbsp;0.018&nbsp;&#60;&nbsp;I</TD
+><TD
+>0.299&nbsp;E'<SUB
+>R</SUB
+>
++&nbsp;0.587&nbsp;E'<SUB
+>G</SUB
+>
++&nbsp;0.114&nbsp;E'<SUB
+>B</SUB
+></TD
+><TD
+>219&nbsp;E'<SUB
+>Y</SUB
+>&nbsp;+&nbsp;16</TD
+><TD
+>224&nbsp;P<SUB
+>B,R</SUB
+>&nbsp;+&nbsp;128</TD
+></TR
+><TR
+><TD
+><CODE
+CLASS="CONSTANT"
+>V4L2_COLORSPACE_SMPTE240M</CODE
+></TD
+><TD
+>2</TD
+><TD
+>1125-Line (US) HDTV, see <A
+HREF="#SMPTE240M"
+><ABBR
+CLASS="ABBREV"
+>SMPTE240M</ABBR
+></A
+></TD
+><TD
+>x&nbsp;=&nbsp;0.630, y&nbsp;=&nbsp;0.340</TD
+><TD
+>x&nbsp;=&nbsp;0.310, y&nbsp;=&nbsp;0.595</TD
+><TD
+>x&nbsp;=&nbsp;0.155, y&nbsp;=&nbsp;0.070</TD
+><TD
+>x&nbsp;=&nbsp;0.3127, y&nbsp;=&nbsp;0.3290,
+ Illuminant D<SUB
+>65</SUB
+></TD
+><TD
+>E' = 4&nbsp;I&nbsp;for&nbsp;I&nbsp;&le;0.0228,
+1.1115&nbsp;I<SUP
+>0.45</SUP
+>&nbsp;-&nbsp;0.1115&nbsp;for&nbsp;0.0228&nbsp;&#60;&nbsp;I</TD
+><TD
+>0.212&nbsp;E'<SUB
+>R</SUB
+>
++&nbsp;0.701&nbsp;E'<SUB
+>G</SUB
+>
++&nbsp;0.087&nbsp;E'<SUB
+>B</SUB
+></TD
+><TD
+>219&nbsp;E'<SUB
+>Y</SUB
+>&nbsp;+&nbsp;16</TD
+><TD
+>224&nbsp;P<SUB
+>B,R</SUB
+>&nbsp;+&nbsp;128</TD
+></TR
+><TR
+><TD
+><CODE
+CLASS="CONSTANT"
+>V4L2_COLORSPACE_REC709</CODE
+></TD
+><TD
+>3</TD
+><TD
+>HDTV and modern devices, see <A
+HREF="#ITU709"
+><ABBR
+CLASS="ABBREV"
+>ITU709</ABBR
+></A
+></TD
+><TD
+>x&nbsp;=&nbsp;0.640, y&nbsp;=&nbsp;0.330</TD
+><TD
+>x&nbsp;=&nbsp;0.300, y&nbsp;=&nbsp;0.600</TD
+><TD
+>x&nbsp;=&nbsp;0.150, y&nbsp;=&nbsp;0.060</TD
+><TD
+>x&nbsp;=&nbsp;0.3127, y&nbsp;=&nbsp;0.3290,
+ Illuminant D<SUB
+>65</SUB
+></TD
+><TD
+>E' = 4.5&nbsp;I&nbsp;for&nbsp;I&nbsp;&le;0.018,
+1.099&nbsp;I<SUP
+>0.45</SUP
+>&nbsp;-&nbsp;0.099&nbsp;for&nbsp;0.018&nbsp;&#60;&nbsp;I</TD
+><TD
+>0.2125&nbsp;E'<SUB
+>R</SUB
+>
++&nbsp;0.7154&nbsp;E'<SUB
+>G</SUB
+>
++&nbsp;0.0721&nbsp;E'<SUB
+>B</SUB
+></TD
+><TD
+>219&nbsp;E'<SUB
+>Y</SUB
+>&nbsp;+&nbsp;16</TD
+><TD
+>224&nbsp;P<SUB
+>B,R</SUB
+>&nbsp;+&nbsp;128</TD
+></TR
+><TR
+><TD
+><CODE
+CLASS="CONSTANT"
+>V4L2_COLORSPACE_BT878</CODE
+></TD
+><TD
+>4</TD
+><TD
+>Broken Bt878 extents<A
+NAME="AEN1096"
+HREF="#FTN.AEN1096"
+><SPAN
+CLASS="footnote"
+>[b]</SPAN
+></A
+>, <A
+HREF="#ITU601"
+><ABBR
+CLASS="ABBREV"
+>ITU601</ABBR
+></A
+></TD
+><TD
+>?</TD
+><TD
+>?</TD
+><TD
+>?</TD
+><TD
+>?</TD
+><TD
+>?</TD
+><TD
+>0.299&nbsp;E'<SUB
+>R</SUB
+>
++&nbsp;0.587&nbsp;E'<SUB
+>G</SUB
+>
++&nbsp;0.114&nbsp;E'<SUB
+>B</SUB
+></TD
+><TD
+><SPAN
+CLASS="emphasis"
+><I
+CLASS="EMPHASIS"
+>237</I
+></SPAN
+>&nbsp;E'<SUB
+>Y</SUB
+>&nbsp;+&nbsp;16</TD
+><TD
+>224&nbsp;P<SUB
+>B,R</SUB
+>&nbsp;+&nbsp;128 (probably)</TD
+></TR
+><TR
+><TD
+><CODE
+CLASS="CONSTANT"
+>V4L2_COLORSPACE_470_SYSTEM_M</CODE
+></TD
+><TD
+>5</TD
+><TD
+>M/NTSC<A
+NAME="AEN1119"
+HREF="#FTN.AEN1119"
+><SPAN
+CLASS="footnote"
+>[c]</SPAN
+></A
+> according to <A
+HREF="#ITU470"
+><ABBR
+CLASS="ABBREV"
+>ITU470</ABBR
+></A
+>, <A
+HREF="#ITU601"
+><ABBR
+CLASS="ABBREV"
+>ITU601</ABBR
+></A
+></TD
+><TD
+>x&nbsp;=&nbsp;0.67, y&nbsp;=&nbsp;0.33</TD
+><TD
+>x&nbsp;=&nbsp;0.21, y&nbsp;=&nbsp;0.71</TD
+><TD
+>x&nbsp;=&nbsp;0.14, y&nbsp;=&nbsp;0.08</TD
+><TD
+>x&nbsp;=&nbsp;0.310, y&nbsp;=&nbsp;0.316, Illuminant C</TD
+><TD
+>?</TD
+><TD
+>0.299&nbsp;E'<SUB
+>R</SUB
+>
++&nbsp;0.587&nbsp;E'<SUB
+>G</SUB
+>
++&nbsp;0.114&nbsp;E'<SUB
+>B</SUB
+></TD
+><TD
+>219&nbsp;E'<SUB
+>Y</SUB
+>&nbsp;+&nbsp;16</TD
+><TD
+>224&nbsp;P<SUB
+>B,R</SUB
+>&nbsp;+&nbsp;128</TD
+></TR
+><TR
+><TD
+><CODE
+CLASS="CONSTANT"
+>V4L2_COLORSPACE_470_SYSTEM_BG</CODE
+></TD
+><TD
+>6</TD
+><TD
+>625-line PAL and SECAM systems according to <A
+HREF="#ITU470"
+><ABBR
+CLASS="ABBREV"
+>ITU470</ABBR
+></A
+>, <A
+HREF="#ITU601"
+><ABBR
+CLASS="ABBREV"
+>ITU601</ABBR
+></A
+></TD
+><TD
+>x&nbsp;=&nbsp;0.64, y&nbsp;=&nbsp;0.33</TD
+><TD
+>x&nbsp;=&nbsp;0.29, y&nbsp;=&nbsp;0.60</TD
+><TD
+>x&nbsp;=&nbsp;0.15, y&nbsp;=&nbsp;0.06</TD
+><TD
+>x&nbsp;=&nbsp;0.313, y&nbsp;=&nbsp;0.329,
+Illuminant D<SUB
+>65</SUB
+></TD
+><TD
+>?</TD
+><TD
+>0.299&nbsp;E'<SUB
+>R</SUB
+>
++&nbsp;0.587&nbsp;E'<SUB
+>G</SUB
+>
++&nbsp;0.114&nbsp;E'<SUB
+>B</SUB
+></TD
+><TD
+>219&nbsp;E'<SUB
+>Y</SUB
+>&nbsp;+&nbsp;16</TD
+><TD
+>224&nbsp;P<SUB
+>B,R</SUB
+>&nbsp;+&nbsp;128</TD
+></TR
+><TR
+><TD
+><CODE
+CLASS="CONSTANT"
+>V4L2_COLORSPACE_JPEG</CODE
+></TD
+><TD
+>7</TD
+><TD
+>JPEG Y'CbCr, see <A
+HREF="#JFIF"
+><ABBR
+CLASS="ABBREV"
+>JFIF</ABBR
+></A
+>, <A
+HREF="#ITU601"
+><ABBR
+CLASS="ABBREV"
+>ITU601</ABBR
+></A
+></TD
+><TD
+>?</TD
+><TD
+>?</TD
+><TD
+>?</TD
+><TD
+>?</TD
+><TD
+>?</TD
+><TD
+>0.299&nbsp;E'<SUB
+>R</SUB
+>
++&nbsp;0.587&nbsp;E'<SUB
+>G</SUB
+>
++&nbsp;0.114&nbsp;E'<SUB
+>B</SUB
+></TD
+><TD
+>256&nbsp;E'<SUB
+>Y</SUB
+>&nbsp;+&nbsp;16<A
+NAME="AEN1175"
+HREF="#FTN.AEN1175"
+><SPAN
+CLASS="footnote"
+>[d]</SPAN
+></A
+></TD
+><TD
+>256&nbsp;P<SUB
+>B,R</SUB
+>&nbsp;+&nbsp;128</TD
+></TR
+><TR
+><TD
+><CODE
+CLASS="CONSTANT"
+>V4L2_COLORSPACE_SRGB</CODE
+></TD
+><TD
+>8</TD
+><TD
+>[?]</TD
+><TD
+>x&nbsp;=&nbsp;0.640, y&nbsp;=&nbsp;0.330</TD
+><TD
+>x&nbsp;=&nbsp;0.300, y&nbsp;=&nbsp;0.600</TD
+><TD
+>x&nbsp;=&nbsp;0.150, y&nbsp;=&nbsp;0.060</TD
+><TD
+>x&nbsp;=&nbsp;0.3127, y&nbsp;=&nbsp;0.3290,
+ Illuminant D<SUB
+>65</SUB
+></TD
+><TD
+>E' = 4.5&nbsp;I&nbsp;for&nbsp;I&nbsp;&le;0.018,
+1.099&nbsp;I<SUP
+>0.45</SUP
+>&nbsp;-&nbsp;0.099&nbsp;for&nbsp;0.018&nbsp;&#60;&nbsp;I</TD
+><TD
+COLSPAN="3"
+>n/a</TD
+></TR
+></TBODY
+><TR
+><TD
+COLSPAN="11"
+>Notes:<BR><A
+NAME="FTN.AEN1013"
+>a. </A
+>The coordinates of the color primaries are
+given in the CIE system (1931)<BR><A
+NAME="FTN.AEN1096"
+>b. </A
+>The ubiquitous Bt878 video capture chip
+quantizes E'<SUB
+>Y</SUB
+> to 238 levels, yielding a range
+of Y' = 16 &hellip; 253, unlike Rec. 601 Y' = 16 &hellip;
+235. This is not a typo in the Bt878 documentation, it has been
+implemented in silicon. The chroma extents are unclear.<BR><A
+NAME="FTN.AEN1119"
+>c. </A
+>No identifier exists for M/PAL which uses
+the chromaticities of M/NTSC, the remaining parameters are equal to B and
+G/PAL.<BR><A
+NAME="FTN.AEN1175"
+>d. </A
+>Note JFIF quantizes
+Y'P<SUB
+>B</SUB
+>P<SUB
+>R</SUB
+> in range [0;+1] and
+[-0.5;+0.5] to <SPAN
+CLASS="emphasis"
+><I
+CLASS="EMPHASIS"
+>257</I
+></SPAN
+> levels, however Y'CbCr signals
+are still clamped to [0;255].<BR></TD
+></TR
+></TABLE
+></DIV
+></DIV
+><DIV
+CLASS="SECTION"
+><HR><H2
+CLASS="SECTION"
+><A
+NAME="PIXFMT-RGB"
+>2.3. RGB Formats</A
+></H2
+><P
+>These formats are designed to match the pixel formats of
+typical PC graphics frame buffers. They occupy 8, 16, 24 or 32 bits
+per pixel. These are all packed-pixel formats, meaning all the data
+for a pixel lie next to each other in memory.</P
+><P
+>When one of these formats is used, drivers shall report the
+colorspace <CODE
+CLASS="CONSTANT"
+>V4L2_COLORSPACE_SRGB</CODE
+>.</P
+><DIV
+CLASS="TABLE"
+><A
+NAME="RGB-FORMATS"
+></A
+><P
+><B
+>Table 2-3. Packed RGB Image Formats</B
+></P
+><TABLE
+BORDER="0"
+FRAME="void"
+WIDTH="100%"
+CLASS="CALSTABLE"
+><COL
+WIDTH="9%"
+ALIGN="LEFT"
+TITLE="ID"><COL
+WIDTH="9%"
+TITLE="FOURCC"><COL
+WIDTH="9%"
+TITLE="BIT"><COL
+WIDTH="9%"
+TITLE="B07"><COL><COL><COL><COL><COL><COL><COL
+WIDTH="9%"
+TITLE="B00"><COL><COL
+WIDTH="9%"
+TITLE="B17"><COL><COL><COL><COL><COL><COL><COL
+WIDTH="9%"
+TITLE="B10"><COL><COL
+WIDTH="9%"
+TITLE="B27"><COL><COL><COL><COL><COL><COL><COL
+WIDTH="9%"
+TITLE="B20"><COL><COL
+WIDTH="9%"
+TITLE="B37"><COL><COL><COL><COL><COL><COL><THEAD
+><TR
+><TH
+ROWSPAN="2"
+>Identifier</TH
+><TH
+ROWSPAN="2"
+>Code</TH
+><TH
+>&nbsp;</TH
+><TH
+COLSPAN="8"
+>Byte&nbsp;0</TH
+><TH
+>&nbsp;</TH
+><TH
+COLSPAN="8"
+>Byte&nbsp;1</TH
+><TH
+>&nbsp;</TH
+><TH
+COLSPAN="8"
+>Byte&nbsp;2</TH
+><TH
+>&nbsp;</TH
+><TH
+COLSPAN="8"
+>Byte&nbsp;3</TH
+></TR
+><TR
+><TH
+>Bit</TH
+><TH
+>7</TH
+><TH
+>6</TH
+><TH
+>5</TH
+><TH
+>4</TH
+><TH
+>3</TH
+><TH
+>2</TH
+><TH
+>1</TH
+><TH
+>0</TH
+><TH
+>&nbsp;</TH
+><TH
+>7</TH
+><TH
+>6</TH
+><TH
+>5</TH
+><TH
+>4</TH
+><TH
+>3</TH
+><TH
+>2</TH
+><TH
+>1</TH
+><TH
+>0</TH
+><TH
+>&nbsp;</TH
+><TH
+>7</TH
+><TH
+>6</TH
+><TH
+>5</TH
+><TH
+>4</TH
+><TH
+>3</TH
+><TH
+>2</TH
+><TH
+>1</TH
+><TH
+>0</TH
+><TH
+>&nbsp;</TH
+><TH
+>7</TH
+><TH
+>6</TH
+><TH
+>5</TH
+><TH
+>4</TH
+><TH
+>3</TH
+><TH
+>2</TH
+><TH
+>1</TH
+><TH
+>0</TH
+></TR
+></THEAD
+><TBODY
+><TR
+><TD
+><CODE
+CLASS="CONSTANT"
+>V4L2_PIX_FMT_RGB332</CODE
+></TD
+><TD
+>'RGB1'</TD
+><TD
+>&nbsp;</TD
+><TD
+>b<SUB
+>1</SUB
+></TD
+><TD
+>b<SUB
+>0</SUB
+></TD
+><TD
+>g<SUB
+>2</SUB
+></TD
+><TD
+>g<SUB
+>1</SUB
+></TD
+><TD
+>g<SUB
+>0</SUB
+></TD
+><TD
+>r<SUB
+>2</SUB
+></TD
+><TD
+>r<SUB
+>1</SUB
+></TD
+><TD
+>r<SUB
+>0</SUB
+></TD
+><TD
+>&nbsp;</TD
+><TD
+>&nbsp;</TD
+><TD
+>&nbsp;</TD
+><TD
+>&nbsp;</TD
+><TD
+>&nbsp;</TD
+><TD
+>&nbsp;</TD
+><TD
+>&nbsp;</TD
+><TD
+>&nbsp;</TD
+><TD
+>&nbsp;</TD
+><TD
+>&nbsp;</TD
+><TD
+>&nbsp;</TD
+><TD
+>&nbsp;</TD
+><TD
+>&nbsp;</TD
+><TD
+>&nbsp;</TD
+><TD
+>&nbsp;</TD
+><TD
+>&nbsp;</TD
+><TD
+>&nbsp;</TD
+><TD
+>&nbsp;</TD
+><TD
+>&nbsp;</TD
+><TD
+>&nbsp;</TD
+><TD
+>&nbsp;</TD
+><TD
+>&nbsp;</TD
+><TD
+>&nbsp;</TD
+><TD
+>&nbsp;</TD
+><TD
+>&nbsp;</TD
+><TD
+>&nbsp;</TD
+></TR
+><TR
+><TD
+><CODE
+CLASS="CONSTANT"
+>V4L2_PIX_FMT_RGB555</CODE
+></TD
+><TD
+>'RGBO'</TD
+><TD
+>&nbsp;</TD
+><TD
+>g<SUB
+>2</SUB
+></TD
+><TD
+>g<SUB
+>1</SUB
+></TD
+><TD
+>g<SUB
+>0</SUB
+></TD
+><TD
+>r<SUB
+>4</SUB
+></TD
+><TD
+>r<SUB
+>3</SUB
+></TD
+><TD
+>r<SUB
+>2</SUB
+></TD
+><TD
+>r<SUB
+>1</SUB
+></TD
+><TD
+>r<SUB
+>0</SUB
+></TD
+><TD
+>&nbsp;</TD
+><TD
+>?</TD
+><TD
+>b<SUB
+>4</SUB
+></TD
+><TD
+>b<SUB
+>3</SUB
+></TD
+><TD
+>b<SUB
+>2</SUB
+></TD
+><TD
+>b<SUB
+>1</SUB
+></TD
+><TD
+>b<SUB
+>0</SUB
+></TD
+><TD
+>g<SUB
+>4</SUB
+></TD
+><TD
+>g<SUB
+>3</SUB
+></TD
+><TD
+>&nbsp;</TD
+><TD
+>&nbsp;</TD
+><TD
+>&nbsp;</TD
+><TD
+>&nbsp;</TD
+><TD
+>&nbsp;</TD
+><TD
+>&nbsp;</TD
+><TD
+>&nbsp;</TD
+><TD
+>&nbsp;</TD
+><TD
+>&nbsp;</TD
+><TD
+>&nbsp;</TD
+><TD
+>&nbsp;</TD
+><TD
+>&nbsp;</TD
+><TD
+>&nbsp;</TD
+><TD
+>&nbsp;</TD
+><TD
+>&nbsp;</TD
+><TD
+>&nbsp;</TD
+><TD
+>&nbsp;</TD
+></TR
+><TR
+><TD
+><CODE
+CLASS="CONSTANT"
+>V4L2_PIX_FMT_RGB565</CODE
+></TD
+><TD
+>'RGBP'</TD
+><TD
+>&nbsp;</TD
+><TD
+>g<SUB
+>2</SUB
+></TD
+><TD
+>g<SUB
+>1</SUB
+></TD
+><TD
+>g<SUB
+>0</SUB
+></TD
+><TD
+>r<SUB
+>4</SUB
+></TD
+><TD
+>r<SUB
+>3</SUB
+></TD
+><TD
+>r<SUB
+>2</SUB
+></TD
+><TD
+>r<SUB
+>1</SUB
+></TD
+><TD
+>r<SUB
+>0</SUB
+></TD
+><TD
+>&nbsp;</TD
+><TD
+>b<SUB
+>4</SUB
+></TD
+><TD
+>b<SUB
+>3</SUB
+></TD
+><TD
+>b<SUB
+>2</SUB
+></TD
+><TD
+>b<SUB
+>1</SUB
+></TD
+><TD
+>b<SUB
+>0</SUB
+></TD
+><TD
+>g<SUB
+>5</SUB
+></TD
+><TD
+>g<SUB
+>4</SUB
+></TD
+><TD
+>g<SUB
+>3</SUB
+></TD
+><TD
+>&nbsp;</TD
+><TD
+>&nbsp;</TD
+><TD
+>&nbsp;</TD
+><TD
+>&nbsp;</TD
+><TD
+>&nbsp;</TD
+><TD
+>&nbsp;</TD
+><TD
+>&nbsp;</TD
+><TD
+>&nbsp;</TD
+><TD
+>&nbsp;</TD
+><TD
+>&nbsp;</TD
+><TD
+>&nbsp;</TD
+><TD
+>&nbsp;</TD
+><TD
+>&nbsp;</TD
+><TD
+>&nbsp;</TD
+><TD
+>&nbsp;</TD
+><TD
+>&nbsp;</TD
+><TD
+>&nbsp;</TD
+></TR
+><TR
+><TD
+><CODE
+CLASS="CONSTANT"
+>V4L2_PIX_FMT_RGB555X</CODE
+></TD
+><TD
+>'RGBQ'</TD
+><TD
+>&nbsp;</TD
+><TD
+>?</TD
+><TD
+>b<SUB
+>4</SUB
+></TD
+><TD
+>b<SUB
+>3</SUB
+></TD
+><TD
+>b<SUB
+>2</SUB
+></TD
+><TD
+>b<SUB
+>1</SUB
+></TD
+><TD
+>b<SUB
+>0</SUB
+></TD
+><TD
+>g<SUB
+>4</SUB
+></TD
+><TD
+>g<SUB
+>3</SUB
+></TD
+><TD
+>&nbsp;</TD
+><TD
+>g<SUB
+>2</SUB
+></TD
+><TD
+>g<SUB
+>1</SUB
+></TD
+><TD
+>g<SUB
+>0</SUB
+></TD
+><TD
+>r<SUB
+>4</SUB
+></TD
+><TD
+>r<SUB
+>3</SUB
+></TD
+><TD
+>r<SUB
+>2</SUB
+></TD
+><TD
+>r<SUB
+>1</SUB
+></TD
+><TD
+>r<SUB
+>0</SUB
+></TD
+><TD
+>&nbsp;</TD
+><TD
+>&nbsp;</TD
+><TD
+>&nbsp;</TD
+><TD
+>&nbsp;</TD
+><TD
+>&nbsp;</TD
+><TD
+>&nbsp;</TD
+><TD
+>&nbsp;</TD
+><TD
+>&nbsp;</TD
+><TD
+>&nbsp;</TD
+><TD
+>&nbsp;</TD
+><TD
+>&nbsp;</TD
+><TD
+>&nbsp;</TD
+><TD
+>&nbsp;</TD
+><TD
+>&nbsp;</TD
+><TD
+>&nbsp;</TD
+><TD
+>&nbsp;</TD
+><TD
+>&nbsp;</TD
+></TR
+><TR
+><TD
+><CODE
+CLASS="CONSTANT"
+>V4L2_PIX_FMT_RGB565X</CODE
+></TD
+><TD
+>'RGBR'</TD
+><TD
+>&nbsp;</TD
+><TD
+>b<SUB
+>4</SUB
+></TD
+><TD
+>b<SUB
+>3</SUB
+></TD
+><TD
+>b<SUB
+>2</SUB
+></TD
+><TD
+>b<SUB
+>1</SUB
+></TD
+><TD
+>b<SUB
+>0</SUB
+></TD
+><TD
+>g<SUB
+>5</SUB
+></TD
+><TD
+>g<SUB
+>4</SUB
+></TD
+><TD
+>g<SUB
+>3</SUB
+></TD
+><TD
+>&nbsp;</TD
+><TD
+>g<SUB
+>2</SUB
+></TD
+><TD
+>g<SUB
+>1</SUB
+></TD
+><TD
+>g<SUB
+>0</SUB
+></TD
+><TD
+>r<SUB
+>4</SUB
+></TD
+><TD
+>r<SUB
+>3</SUB
+></TD
+><TD
+>r<SUB
+>2</SUB
+></TD
+><TD
+>r<SUB
+>1</SUB
+></TD
+><TD
+>r<SUB
+>0</SUB
+></TD
+><TD
+>&nbsp;</TD
+><TD
+>&nbsp;</TD
+><TD
+>&nbsp;</TD
+><TD
+>&nbsp;</TD
+><TD
+>&nbsp;</TD
+><TD
+>&nbsp;</TD
+><TD
+>&nbsp;</TD
+><TD
+>&nbsp;</TD
+><TD
+>&nbsp;</TD
+><TD
+>&nbsp;</TD
+><TD
+>&nbsp;</TD
+><TD
+>&nbsp;</TD
+><TD
+>&nbsp;</TD
+><TD
+>&nbsp;</TD
+><TD
+>&nbsp;</TD
+><TD
+>&nbsp;</TD
+><TD
+>&nbsp;</TD
+></TR
+><TR
+><TD
+><CODE
+CLASS="CONSTANT"
+>V4L2_PIX_FMT_BGR24</CODE
+></TD
+><TD
+>'BGR3'</TD
+><TD
+>&nbsp;</TD
+><TD
+>b<SUB
+>7</SUB
+></TD
+><TD
+>b<SUB
+>6</SUB
+></TD
+><TD
+>b<SUB
+>5</SUB
+></TD
+><TD
+>b<SUB
+>4</SUB
+></TD
+><TD
+>b<SUB
+>3</SUB
+></TD
+><TD
+>b<SUB
+>2</SUB
+></TD
+><TD
+>b<SUB
+>1</SUB
+></TD
+><TD
+>b<SUB
+>0</SUB
+></TD
+><TD
+>&nbsp;</TD
+><TD
+>g<SUB
+>7</SUB
+></TD
+><TD
+>g<SUB
+>6</SUB
+></TD
+><TD
+>g<SUB
+>5</SUB
+></TD
+><TD
+>g<SUB
+>4</SUB
+></TD
+><TD
+>g<SUB
+>3</SUB
+></TD
+><TD
+>g<SUB
+>2</SUB
+></TD
+><TD
+>g<SUB
+>1</SUB
+></TD
+><TD
+>g<SUB
+>0</SUB
+></TD
+><TD
+>&nbsp;</TD
+><TD
+>r<SUB
+>7</SUB
+></TD
+><TD
+>r<SUB
+>6</SUB
+></TD
+><TD
+>r<SUB
+>5</SUB
+></TD
+><TD
+>r<SUB
+>4</SUB
+></TD
+><TD
+>r<SUB
+>3</SUB
+></TD
+><TD
+>r<SUB
+>2</SUB
+></TD
+><TD
+>r<SUB
+>1</SUB
+></TD
+><TD
+>r<SUB
+>0</SUB
+></TD
+><TD
+>&nbsp;</TD
+><TD
+>&nbsp;</TD
+><TD
+>&nbsp;</TD
+><TD
+>&nbsp;</TD
+><TD
+>&nbsp;</TD
+><TD
+>&nbsp;</TD
+><TD
+>&nbsp;</TD
+><TD
+>&nbsp;</TD
+></TR
+><TR
+><TD
+><CODE
+CLASS="CONSTANT"
+>V4L2_PIX_FMT_RGB24</CODE
+></TD
+><TD
+>'RGB3'</TD
+><TD
+>&nbsp;</TD
+><TD
+>r<SUB
+>7</SUB
+></TD
+><TD
+>r<SUB
+>6</SUB
+></TD
+><TD
+>r<SUB
+>5</SUB
+></TD
+><TD
+>r<SUB
+>4</SUB
+></TD
+><TD
+>r<SUB
+>3</SUB
+></TD
+><TD
+>r<SUB
+>2</SUB
+></TD
+><TD
+>r<SUB
+>1</SUB
+></TD
+><TD
+>r<SUB
+>0</SUB
+></TD
+><TD
+>&nbsp;</TD
+><TD
+>g<SUB
+>7</SUB
+></TD
+><TD
+>g<SUB
+>6</SUB
+></TD
+><TD
+>g<SUB
+>5</SUB
+></TD
+><TD
+>g<SUB
+>4</SUB
+></TD
+><TD
+>g<SUB
+>3</SUB
+></TD
+><TD
+>g<SUB
+>2</SUB
+></TD
+><TD
+>g<SUB
+>1</SUB
+></TD
+><TD
+>g<SUB
+>0</SUB
+></TD
+><TD
+>&nbsp;</TD
+><TD
+>b<SUB
+>7</SUB
+></TD
+><TD
+>b<SUB
+>6</SUB
+></TD
+><TD
+>b<SUB
+>5</SUB
+></TD
+><TD
+>b<SUB
+>4</SUB
+></TD
+><TD
+>b<SUB
+>3</SUB
+></TD
+><TD
+>b<SUB
+>2</SUB
+></TD
+><TD
+>b<SUB
+>1</SUB
+></TD
+><TD
+>b<SUB
+>0</SUB
+></TD
+><TD
+>&nbsp;</TD
+><TD
+>&nbsp;</TD
+><TD
+>&nbsp;</TD
+><TD
+>&nbsp;</TD
+><TD
+>&nbsp;</TD
+><TD
+>&nbsp;</TD
+><TD
+>&nbsp;</TD
+><TD
+>&nbsp;</TD
+></TR
+><TR
+><TD
+><CODE
+CLASS="CONSTANT"
+>V4L2_PIX_FMT_BGR32</CODE
+></TD
+><TD
+>'BGR4'</TD
+><TD
+>&nbsp;</TD
+><TD
+>b<SUB
+>7</SUB
+></TD
+><TD
+>b<SUB
+>6</SUB
+></TD
+><TD
+>b<SUB
+>5</SUB
+></TD
+><TD
+>b<SUB
+>4</SUB
+></TD
+><TD
+>b<SUB
+>3</SUB
+></TD
+><TD
+>b<SUB
+>2</SUB
+></TD
+><TD
+>b<SUB
+>1</SUB
+></TD
+><TD
+>b<SUB
+>0</SUB
+></TD
+><TD
+>&nbsp;</TD
+><TD
+>g<SUB
+>7</SUB
+></TD
+><TD
+>g<SUB
+>6</SUB
+></TD
+><TD
+>g<SUB
+>5</SUB
+></TD
+><TD
+>g<SUB
+>4</SUB
+></TD
+><TD
+>g<SUB
+>3</SUB
+></TD
+><TD
+>g<SUB
+>2</SUB
+></TD
+><TD
+>g<SUB
+>1</SUB
+></TD
+><TD
+>g<SUB
+>0</SUB
+></TD
+><TD
+>&nbsp;</TD
+><TD
+>r<SUB
+>7</SUB
+></TD
+><TD
+>r<SUB
+>6</SUB
+></TD
+><TD
+>r<SUB
+>5</SUB
+></TD
+><TD
+>r<SUB
+>4</SUB
+></TD
+><TD
+>r<SUB
+>3</SUB
+></TD
+><TD
+>r<SUB
+>2</SUB
+></TD
+><TD
+>r<SUB
+>1</SUB
+></TD
+><TD
+>r<SUB
+>0</SUB
+></TD
+><TD
+>&nbsp;</TD
+><TD
+>?</TD
+><TD
+>?</TD
+><TD
+>?</TD
+><TD
+>?</TD
+><TD
+>?</TD
+><TD
+>?</TD
+><TD
+>?</TD
+><TD
+>?</TD
+></TR
+><TR
+><TD
+><CODE
+CLASS="CONSTANT"
+>V4L2_PIX_FMT_RGB32</CODE
+></TD
+><TD
+>'RGB4'</TD
+><TD
+>&nbsp;</TD
+><TD
+>r<SUB
+>7</SUB
+></TD
+><TD
+>r<SUB
+>6</SUB
+></TD
+><TD
+>r<SUB
+>5</SUB
+></TD
+><TD
+>r<SUB
+>4</SUB
+></TD
+><TD
+>r<SUB
+>3</SUB
+></TD
+><TD
+>r<SUB
+>2</SUB
+></TD
+><TD
+>r<SUB
+>1</SUB
+></TD
+><TD
+>r<SUB
+>0</SUB
+></TD
+><TD
+>&nbsp;</TD
+><TD
+>g<SUB
+>7</SUB
+></TD
+><TD
+>g<SUB
+>6</SUB
+></TD
+><TD
+>g<SUB
+>5</SUB
+></TD
+><TD
+>g<SUB
+>4</SUB
+></TD
+><TD
+>g<SUB
+>3</SUB
+></TD
+><TD
+>g<SUB
+>2</SUB
+></TD
+><TD
+>g<SUB
+>1</SUB
+></TD
+><TD
+>g<SUB
+>0</SUB
+></TD
+><TD
+>&nbsp;</TD
+><TD
+>b<SUB
+>7</SUB
+></TD
+><TD
+>b<SUB
+>6</SUB
+></TD
+><TD
+>b<SUB
+>5</SUB
+></TD
+><TD
+>b<SUB
+>4</SUB
+></TD
+><TD
+>b<SUB
+>3</SUB
+></TD
+><TD
+>b<SUB
+>2</SUB
+></TD
+><TD
+>b<SUB
+>1</SUB
+></TD
+><TD
+>b<SUB
+>0</SUB
+></TD
+><TD
+>&nbsp;</TD
+><TD
+>?</TD
+><TD
+>?</TD
+><TD
+>?</TD
+><TD
+>?</TD
+><TD
+>?</TD
+><TD
+>?</TD
+><TD
+>?</TD
+><TD
+>?</TD
+></TR
+></TBODY
+></TABLE
+></DIV
+><P
+>Bit 7 is the most significant bit. ? = undefined bit,
+ignored on output, random value on input.</P
+><DIV
+CLASS="EXAMPLE"
+><A
+NAME="AEN1675"
+></A
+><P
+><B
+>Example 2-2. <CODE
+CLASS="CONSTANT"
+>V4L2_PIX_FMT_BGR24</CODE
+> 4 &times; 4 pixel
+image</B
+></P
+><DIV
+CLASS="FORMALPARA"
+><P
+><B
+>Byte Order. </B
+>Each cell is one byte.
+ <DIV
+CLASS="INFORMALTABLE"
+><P
+></P
+><A
+NAME="AEN1681"
+></A
+><TABLE
+BORDER="0"
+FRAME="void"
+CLASS="CALSTABLE"
+><COL
+WIDTH="2*"
+ALIGN="LEFT"><COL><COL><COL><COL><COL><COL><COL><COL><COL><COL><COL><COL><TBODY
+><TR
+><TD
+>start&nbsp;+&nbsp;0:</TD
+><TD
+>B<SUB
+>00</SUB
+></TD
+><TD
+>G<SUB
+>00</SUB
+></TD
+><TD
+>R<SUB
+>00</SUB
+></TD
+><TD
+>B<SUB
+>01</SUB
+></TD
+><TD
+>G<SUB
+>01</SUB
+></TD
+><TD
+>R<SUB
+>01</SUB
+></TD
+><TD
+>B<SUB
+>02</SUB
+></TD
+><TD
+>G<SUB
+>02</SUB
+></TD
+><TD
+>R<SUB
+>02</SUB
+></TD
+><TD
+>B<SUB
+>03</SUB
+></TD
+><TD
+>G<SUB
+>03</SUB
+></TD
+><TD
+>R<SUB
+>03</SUB
+></TD
+></TR
+><TR
+><TD
+>start&nbsp;+&nbsp;12:</TD
+><TD
+>B<SUB
+>10</SUB
+></TD
+><TD
+>G<SUB
+>10</SUB
+></TD
+><TD
+>R<SUB
+>10</SUB
+></TD
+><TD
+>B<SUB
+>11</SUB
+></TD
+><TD
+>G<SUB
+>11</SUB
+></TD
+><TD
+>R<SUB
+>11</SUB
+></TD
+><TD
+>B<SUB
+>12</SUB
+></TD
+><TD
+>G<SUB
+>12</SUB
+></TD
+><TD
+>R<SUB
+>12</SUB
+></TD
+><TD
+>B<SUB
+>13</SUB
+></TD
+><TD
+>G<SUB
+>13</SUB
+></TD
+><TD
+>R<SUB
+>13</SUB
+></TD
+></TR
+><TR
+><TD
+>start&nbsp;+&nbsp;24:</TD
+><TD
+>B<SUB
+>20</SUB
+></TD
+><TD
+>G<SUB
+>20</SUB
+></TD
+><TD
+>R<SUB
+>20</SUB
+></TD
+><TD
+>B<SUB
+>21</SUB
+></TD
+><TD
+>G<SUB
+>21</SUB
+></TD
+><TD
+>R<SUB
+>21</SUB
+></TD
+><TD
+>B<SUB
+>22</SUB
+></TD
+><TD
+>G<SUB
+>22</SUB
+></TD
+><TD
+>R<SUB
+>22</SUB
+></TD
+><TD
+>B<SUB
+>23</SUB
+></TD
+><TD
+>G<SUB
+>23</SUB
+></TD
+><TD
+>R<SUB
+>23</SUB
+></TD
+></TR
+><TR
+><TD
+>start&nbsp;+&nbsp;36:</TD
+><TD
+>B<SUB
+>30</SUB
+></TD
+><TD
+>G<SUB
+>30</SUB
+></TD
+><TD
+>R<SUB
+>30</SUB
+></TD
+><TD
+>B<SUB
+>31</SUB
+></TD
+><TD
+>G<SUB
+>31</SUB
+></TD
+><TD
+>R<SUB
+>31</SUB
+></TD
+><TD
+>B<SUB
+>32</SUB
+></TD
+><TD
+>G<SUB
+>32</SUB
+></TD
+><TD
+>R<SUB
+>32</SUB
+></TD
+><TD
+>B<SUB
+>33</SUB
+></TD
+><TD
+>G<SUB
+>33</SUB
+></TD
+><TD
+>R<SUB
+>33</SUB
+></TD
+></TR
+></TBODY
+></TABLE
+><P
+></P
+></DIV
+>
+ </P
+></DIV
+></DIV
+><DIV
+CLASS="IMPORTANT"
+><BLOCKQUOTE
+CLASS="IMPORTANT"
+><P
+><B
+>Important: </B
+>Drivers may interpret these formats differently.</P
+><P
+>The <CODE
+CLASS="CONSTANT"
+>V4L2_PIX_FMT_RGB555</CODE
+>,
+<CODE
+CLASS="CONSTANT"
+>V4L2_PIX_FMT_RGB565</CODE
+>,
+<CODE
+CLASS="CONSTANT"
+>V4L2_PIX_FMT_RGB555X</CODE
+> and
+<CODE
+CLASS="CONSTANT"
+>V4L2_PIX_FMT_RGB565X</CODE
+> formats are uncommon. Video
+and display hardware typically supports variants with reversed order
+of color components, i.&nbsp;e. blue towards the least, red towards the most
+significant bit. Although presumably the original authors had the
+common formats in mind, the definitions were always very clear and
+cannot be simply regarded as erroneous.</P
+><P
+>If <CODE
+CLASS="CONSTANT"
+>V4L2_PIX_FMT_RGB332</CODE
+> has been
+chosen in accordance with the 15 and 16 bit formats, this format might
+as well be interpreted differently, as "rrrgggbb" rather than
+"bbgggrrr".</P
+><P
+>Finally some drivers, most prominently the BTTV driver,
+might interpret <CODE
+CLASS="CONSTANT"
+>V4L2_PIX_FMT_RGB32</CODE
+> as the
+big-endian variant of <CODE
+CLASS="CONSTANT"
+>V4L2_PIX_FMT_BGR32</CODE
+>,
+consisting of bytes "?RGB" in memory. V4L2 never defined such a
+format, lack of a <CODE
+CLASS="CONSTANT"
+>X</CODE
+> suffix to the symbol suggests
+it was intended this way, and a new symbol and four character code
+should have been used instead.</P
+><P
+>Until these issues are solved, application writers are
+advised that drivers might interpret these formats either way.</P
+></BLOCKQUOTE
+></DIV
+></DIV
+><DIV
+CLASS="SECTION"
+><HR><H2
+CLASS="SECTION"
+><A
+NAME="YUV-FORMATS"
+>2.4. YUV Formats</A
+></H2
+><DIV
+CLASS="TOC"
+><DL
+><DT
+><B
+>Table of Contents</B
+></DT
+><DT
+><A
+HREF="#PIXFMT-GREY"
+><CODE
+CLASS="CONSTANT"
+>V4L2_PIX_FMT_GREY</CODE
+></A
+>&nbsp;--&nbsp;Grey-scale image.</DT
+><DT
+><A
+HREF="#PIXFMT-YUYV"
+><CODE
+CLASS="CONSTANT"
+>V4L2_PIX_FMT_YUYV</CODE
+></A
+>&nbsp;--&nbsp;Packed format with &frac12; horizontal chroma
+resolution, also known as YUV 4:2:2.</DT
+><DT
+><A
+HREF="#PIXFMT-UYVY"
+><CODE
+CLASS="CONSTANT"
+>V4L2_PIX_FMT_UYVY</CODE
+></A
+>&nbsp;--&nbsp;Variation of
+<CODE
+CLASS="CONSTANT"
+>V4L2_PIX_FMT_YUYV</CODE
+> with different order of samples
+in memory.</DT
+><DT
+><A
+HREF="#PIXFMT-Y41P"
+><CODE
+CLASS="CONSTANT"
+>V4L2_PIX_FMT_Y41P</CODE
+></A
+>&nbsp;--&nbsp;Packed format with &frac14; horizontal chroma
+resolution, also known as YUV 4:1:1.</DT
+><DT
+><A
+HREF="#PIXFMT-YVU420"
+><CODE
+CLASS="CONSTANT"
+>V4L2_PIX_FMT_YVU420</CODE
+>,
+<CODE
+CLASS="CONSTANT"
+>V4L2_PIX_FMT_YUV420</CODE
+></A
+>&nbsp;--&nbsp;Planar formats with &frac12; horizontal and
+vertical chroma resolution, also known as YUV 4:2:0.</DT
+><DT
+><A
+HREF="#PIXFMT-YVU410"
+><CODE
+CLASS="CONSTANT"
+>V4L2_PIX_FMT_YVU410</CODE
+>,
+<CODE
+CLASS="CONSTANT"
+>V4L2_PIX_FMT_YUV410</CODE
+></A
+>&nbsp;--&nbsp;Planar formats with &frac14; horizontal and
+vertical chroma resolution, also known as YUV 4:1:0.</DT
+><DT
+><A
+HREF="#PIXFMT-YUV422P"
+><CODE
+CLASS="CONSTANT"
+>V4L2_PIX_FMT_YUV422P</CODE
+></A
+>&nbsp;--&nbsp;Format with &frac12; horizontal chroma resolution,
+also known as YUV 4:2:2. Planar layout as opposed to
+<CODE
+CLASS="CONSTANT"
+>V4L2_PIX_FMT_YUYV</CODE
+>.</DT
+><DT
+><A
+HREF="#PIXFMT-YUV411P"
+><CODE
+CLASS="CONSTANT"
+>V4L2_PIX_FMT_YUV411P</CODE
+></A
+>&nbsp;--&nbsp;Format with &frac14; horizontal chroma resolution,
+also known as YUV 4:1:1. Planar layout as opposed to
+<CODE
+CLASS="CONSTANT"
+>V4L2_PIX_FMT_Y41P</CODE
+>.</DT
+><DT
+><A
+HREF="#AEN3002"
+><CODE
+CLASS="CONSTANT"
+>V4L2_PIX_FMT_NV12</CODE
+>,
+<CODE
+CLASS="CONSTANT"
+>V4L2_PIX_FMT_NV21</CODE
+></A
+>&nbsp;--&nbsp;Formats with &frac12; horizontal and vertical
+chroma resolution, also known as YUV 4:2:0. One luminance and one
+chrominance plane with alternating chroma samples as opposed to
+<CODE
+CLASS="CONSTANT"
+>V4L2_PIX_FMT_YVU420</CODE
+>.</DT
+></DL
+></DIV
+><P
+>YUV is the format native to TV broadcast and composite video
+signals. It separates the brightness information (Y) from the color
+information (U and V or Cb and Cr). The color information consists of
+red and blue <SPAN
+CLASS="emphasis"
+><I
+CLASS="EMPHASIS"
+>color difference</I
+></SPAN
+> signals, this way
+the green component can be reconstructed by subtracting from the
+brightness component. See <A
+HREF="#COLORSPACES"
+>Section 2.2</A
+> for conversion
+examples. YUV was chosen because early television would only transmit
+brightness information. To add color in a way compatible with existing
+receivers a new signal carrier was added to transmit the color
+difference signals. Secondary in the YUV format the U and V components
+usually have lower resolution than the Y component. This is an analog
+video compression technique taking advantage of a property of the
+human visual system, being more sensitive to brightness
+information.</P
+><H1
+><A
+NAME="PIXFMT-GREY"
+></A
+><CODE
+CLASS="CONSTANT"
+>V4L2_PIX_FMT_GREY</CODE
+></H1
+><DIV
+CLASS="REFNAMEDIV"
+><A
+NAME="AEN1812"
+></A
+><H2
+>Name</H2
+><CODE
+CLASS="CONSTANT"
+>V4L2_PIX_FMT_GREY</CODE
+> ('GREY')&nbsp;--&nbsp;Grey-scale image.</DIV
+><DIV
+CLASS="REFSECT1"
+><A
+NAME="AEN1816"
+></A
+><H2
+>Description</H2
+><P
+>This is a grey-scale image. It is really a degenerate
+Y'CbCr format which simply contains no Cb or Cr data.</P
+><DIV
+CLASS="EXAMPLE"
+><A
+NAME="AEN1819"
+></A
+><P
+><B
+>Example 2-1. <CODE
+CLASS="CONSTANT"
+>V4L2_PIX_FMT_GREY</CODE
+> 4 &times; 4
+pixel image</B
+></P
+><DIV
+CLASS="FORMALPARA"
+><P
+><B
+>Byte Order. </B
+>Each cell is one byte.
+ <DIV
+CLASS="INFORMALTABLE"
+><P
+></P
+><A
+NAME="AEN1825"
+></A
+><TABLE
+BORDER="0"
+FRAME="void"
+CLASS="CALSTABLE"
+><COL
+WIDTH="2*"
+ALIGN="LEFT"><COL><COL><COL><COL><TBODY
+><TR
+><TD
+>start&nbsp;+&nbsp;0:</TD
+><TD
+>Y'<SUB
+>00</SUB
+></TD
+><TD
+>Y'<SUB
+>01</SUB
+></TD
+><TD
+>Y'<SUB
+>02</SUB
+></TD
+><TD
+>Y'<SUB
+>03</SUB
+></TD
+></TR
+><TR
+><TD
+>start&nbsp;+&nbsp;4:</TD
+><TD
+>Y'<SUB
+>10</SUB
+></TD
+><TD
+>Y'<SUB
+>11</SUB
+></TD
+><TD
+>Y'<SUB
+>12</SUB
+></TD
+><TD
+>Y'<SUB
+>13</SUB
+></TD
+></TR
+><TR
+><TD
+>start&nbsp;+&nbsp;8:</TD
+><TD
+>Y'<SUB
+>20</SUB
+></TD
+><TD
+>Y'<SUB
+>21</SUB
+></TD
+><TD
+>Y'<SUB
+>22</SUB
+></TD
+><TD
+>Y'<SUB
+>23</SUB
+></TD
+></TR
+><TR
+><TD
+>start&nbsp;+&nbsp;12:</TD
+><TD
+>Y'<SUB
+>30</SUB
+></TD
+><TD
+>Y'<SUB
+>31</SUB
+></TD
+><TD
+>Y'<SUB
+>32</SUB
+></TD
+><TD
+>Y'<SUB
+>33</SUB
+></TD
+></TR
+></TBODY
+></TABLE
+><P
+></P
+></DIV
+>
+ </P
+></DIV
+></DIV
+></DIV
+><H1
+><A
+NAME="PIXFMT-YUYV"
+></A
+><CODE
+CLASS="CONSTANT"
+>V4L2_PIX_FMT_YUYV</CODE
+></H1
+><DIV
+CLASS="REFNAMEDIV"
+><A
+NAME="AEN1873"
+></A
+><H2
+>Name</H2
+><CODE
+CLASS="CONSTANT"
+>V4L2_PIX_FMT_YUYV</CODE
+>
+('YUYV')&nbsp;--&nbsp;Packed format with &frac12; horizontal chroma
+resolution, also known as YUV 4:2:2.</DIV
+><DIV
+CLASS="REFSECT1"
+><A
+NAME="AEN1877"
+></A
+><H2
+>Description</H2
+><P
+>In this format each four bytes is two pixels. Each four
+bytes is two Y's, a Cb and a Cr. Each Y goes to one of the pixels, and
+the Cb and Cr belong to both pixels. As you can see, the Cr and Cb
+components have half the horizontal resolution of the Y component.
+<CODE
+CLASS="CONSTANT"
+>V4L2_PIX_FMT_YUYV </CODE
+> is known in the Windows
+environment as YUY2.</P
+><DIV
+CLASS="EXAMPLE"
+><A
+NAME="AEN1881"
+></A
+><P
+><B
+>Example 2-1. <CODE
+CLASS="CONSTANT"
+>V4L2_PIX_FMT_YUYV</CODE
+> 4 &times; 4
+pixel image</B
+></P
+><DIV
+CLASS="FORMALPARA"
+><P
+><B
+>Byte Order. </B
+>Each cell is one byte.
+ <DIV
+CLASS="INFORMALTABLE"
+><P
+></P
+><A
+NAME="AEN1887"
+></A
+><TABLE
+BORDER="0"
+FRAME="void"
+CLASS="CALSTABLE"
+><COL
+WIDTH="2*"
+ALIGN="LEFT"><COL><COL><COL><COL><COL><COL><COL><COL><TBODY
+><TR
+><TD
+>start&nbsp;+&nbsp;0:</TD
+><TD
+>Y'<SUB
+>00</SUB
+></TD
+><TD
+>Cb<SUB
+>00</SUB
+></TD
+><TD
+>Y'<SUB
+>01</SUB
+></TD
+><TD
+>Cr<SUB
+>00</SUB
+></TD
+><TD
+>Y'<SUB
+>02</SUB
+></TD
+><TD
+>Cb<SUB
+>01</SUB
+></TD
+><TD
+>Y'<SUB
+>03</SUB
+></TD
+><TD
+>Cr<SUB
+>01</SUB
+></TD
+></TR
+><TR
+><TD
+>start&nbsp;+&nbsp;8:</TD
+><TD
+>Y'<SUB
+>10</SUB
+></TD
+><TD
+>Cb<SUB
+>10</SUB
+></TD
+><TD
+>Y'<SUB
+>11</SUB
+></TD
+><TD
+>Cr<SUB
+>10</SUB
+></TD
+><TD
+>Y'<SUB
+>12</SUB
+></TD
+><TD
+>Cb<SUB
+>11</SUB
+></TD
+><TD
+>Y'<SUB
+>13</SUB
+></TD
+><TD
+>Cr<SUB
+>11</SUB
+></TD
+></TR
+><TR
+><TD
+>start&nbsp;+&nbsp;16:</TD
+><TD
+>Y'<SUB
+>20</SUB
+></TD
+><TD
+>Cb<SUB
+>20</SUB
+></TD
+><TD
+>Y'<SUB
+>21</SUB
+></TD
+><TD
+>Cr<SUB
+>20</SUB
+></TD
+><TD
+>Y'<SUB
+>22</SUB
+></TD
+><TD
+>Cb<SUB
+>21</SUB
+></TD
+><TD
+>Y'<SUB
+>23</SUB
+></TD
+><TD
+>Cr<SUB
+>21</SUB
+></TD
+></TR
+><TR
+><TD
+>start&nbsp;+&nbsp;24:</TD
+><TD
+>Y'<SUB
+>30</SUB
+></TD
+><TD
+>Cb<SUB
+>30</SUB
+></TD
+><TD
+>Y'<SUB
+>31</SUB
+></TD
+><TD
+>Cr<SUB
+>30</SUB
+></TD
+><TD
+>Y'<SUB
+>32</SUB
+></TD
+><TD
+>Cb<SUB
+>31</SUB
+></TD
+><TD
+>Y'<SUB
+>33</SUB
+></TD
+><TD
+>Cr<SUB
+>31</SUB
+></TD
+></TR
+></TBODY
+></TABLE
+><P
+></P
+></DIV
+>
+ </P
+></DIV
+><DIV
+CLASS="FORMALPARA"
+><P
+><B
+>Color Sample Location. </B
+> <DIV
+CLASS="INFORMALTABLE"
+><P
+></P
+><A
+NAME="AEN1966"
+></A
+><TABLE
+BORDER="0"
+FRAME="void"
+CLASS="CALSTABLE"
+><COL><COL><COL><COL><COL><COL><COL><TBODY
+><TR
+><TD
+>&nbsp;</TD
+><TD
+>0</TD
+><TD
+>&nbsp;</TD
+><TD
+>1</TD
+><TD
+>&nbsp;</TD
+><TD
+>2</TD
+><TD
+>&nbsp;</TD
+><TD
+>3</TD
+></TR
+><TR
+><TD
+>0</TD
+><TD
+>Y</TD
+><TD
+>C</TD
+><TD
+>Y</TD
+><TD
+>&nbsp;</TD
+><TD
+>Y</TD
+><TD
+>C</TD
+><TD
+>Y</TD
+></TR
+><TR
+><TD
+>1</TD
+><TD
+>Y</TD
+><TD
+>C</TD
+><TD
+>Y</TD
+><TD
+>&nbsp;</TD
+><TD
+>Y</TD
+><TD
+>C</TD
+><TD
+>Y</TD
+></TR
+><TR
+><TD
+>2</TD
+><TD
+>Y</TD
+><TD
+>C</TD
+><TD
+>Y</TD
+><TD
+>&nbsp;</TD
+><TD
+>Y</TD
+><TD
+>C</TD
+><TD
+>Y</TD
+></TR
+><TR
+><TD
+>3</TD
+><TD
+>Y</TD
+><TD
+>C</TD
+><TD
+>Y</TD
+><TD
+>&nbsp;</TD
+><TD
+>Y</TD
+><TD
+>C</TD
+><TD
+>Y</TD
+></TR
+></TBODY
+></TABLE
+><P
+></P
+></DIV
+>
+ </P
+></DIV
+></DIV
+></DIV
+><H1
+><A
+NAME="PIXFMT-UYVY"
+></A
+><CODE
+CLASS="CONSTANT"
+>V4L2_PIX_FMT_UYVY</CODE
+></H1
+><DIV
+CLASS="REFNAMEDIV"
+><A
+NAME="AEN2018"
+></A
+><H2
+>Name</H2
+><CODE
+CLASS="CONSTANT"
+>V4L2_PIX_FMT_UYVY</CODE
+>
+('UYVY')&nbsp;--&nbsp;Variation of
+<CODE
+CLASS="CONSTANT"
+>V4L2_PIX_FMT_YUYV</CODE
+> with different order of samples
+in memory.</DIV
+><DIV
+CLASS="REFSECT1"
+><A
+NAME="AEN2023"
+></A
+><H2
+>Description</H2
+><P
+>In this format each four bytes is two pixels. Each four
+bytes is two Y's, a Cb and a Cr. Each Y goes to one of the pixels, and
+the Cb and Cr belong to both pixels. As you can see, the Cr and Cb
+components have half the horizontal resolution of the Y
+component.</P
+><DIV
+CLASS="EXAMPLE"
+><A
+NAME="AEN2026"
+></A
+><P
+><B
+>Example 2-1. <CODE
+CLASS="CONSTANT"
+>V4L2_PIX_FMT_UYVY</CODE
+> 4 &times; 4
+pixel image</B
+></P
+><DIV
+CLASS="FORMALPARA"
+><P
+><B
+>Byte Order. </B
+>Each cell is one byte.
+ <DIV
+CLASS="INFORMALTABLE"
+><P
+></P
+><A
+NAME="AEN2032"
+></A
+><TABLE
+BORDER="0"
+FRAME="void"
+CLASS="CALSTABLE"
+><COL
+WIDTH="2*"
+ALIGN="LEFT"><COL><COL><COL><COL><COL><COL><COL><COL><TBODY
+><TR
+><TD
+>start&nbsp;+&nbsp;0:</TD
+><TD
+>Cb<SUB
+>00</SUB
+></TD
+><TD
+>Y'<SUB
+>00</SUB
+></TD
+><TD
+>Cr<SUB
+>00</SUB
+></TD
+><TD
+>Y'<SUB
+>01</SUB
+></TD
+><TD
+>Cb<SUB
+>01</SUB
+></TD
+><TD
+>Y'<SUB
+>02</SUB
+></TD
+><TD
+>Cr<SUB
+>01</SUB
+></TD
+><TD
+>Y'<SUB
+>03</SUB
+></TD
+></TR
+><TR
+><TD
+>start&nbsp;+&nbsp;8:</TD
+><TD
+>Cb<SUB
+>10</SUB
+></TD
+><TD
+>Y'<SUB
+>10</SUB
+></TD
+><TD
+>Cr<SUB
+>10</SUB
+></TD
+><TD
+>Y'<SUB
+>11</SUB
+></TD
+><TD
+>Cb<SUB
+>11</SUB
+></TD
+><TD
+>Y'<SUB
+>12</SUB
+></TD
+><TD
+>Cr<SUB
+>11</SUB
+></TD
+><TD
+>Y'<SUB
+>13</SUB
+></TD
+></TR
+><TR
+><TD
+>start&nbsp;+&nbsp;16:</TD
+><TD
+>Cb<SUB
+>20</SUB
+></TD
+><TD
+>Y'<SUB
+>20</SUB
+></TD
+><TD
+>Cr<SUB
+>20</SUB
+></TD
+><TD
+>Y'<SUB
+>21</SUB
+></TD
+><TD
+>Cb<SUB
+>21</SUB
+></TD
+><TD
+>Y'<SUB
+>22</SUB
+></TD
+><TD
+>Cr<SUB
+>21</SUB
+></TD
+><TD
+>Y'<SUB
+>23</SUB
+></TD
+></TR
+><TR
+><TD
+>start&nbsp;+&nbsp;24:</TD
+><TD
+>Cb<SUB
+>30</SUB
+></TD
+><TD
+>Y'<SUB
+>30</SUB
+></TD
+><TD
+>Cr<SUB
+>30</SUB
+></TD
+><TD
+>Y'<SUB
+>31</SUB
+></TD
+><TD
+>Cb<SUB
+>31</SUB
+></TD
+><TD
+>Y'<SUB
+>32</SUB
+></TD
+><TD
+>Cr<SUB
+>31</SUB
+></TD
+><TD
+>Y'<SUB
+>33</SUB
+></TD
+></TR
+></TBODY
+></TABLE
+><P
+></P
+></DIV
+>
+ </P
+></DIV
+><DIV
+CLASS="FORMALPARA"
+><P
+><B
+>Color Sample Location. </B
+> <DIV
+CLASS="INFORMALTABLE"
+><P
+></P
+><A
+NAME="AEN2111"
+></A
+><TABLE
+BORDER="0"
+FRAME="void"
+CLASS="CALSTABLE"
+><COL><COL><COL><COL><COL><COL><COL><TBODY
+><TR
+><TD
+>&nbsp;</TD
+><TD
+>0</TD
+><TD
+>&nbsp;</TD
+><TD
+>1</TD
+><TD
+>&nbsp;</TD
+><TD
+>2</TD
+><TD
+>&nbsp;</TD
+><TD
+>3</TD
+></TR
+><TR
+><TD
+>0</TD
+><TD
+>Y</TD
+><TD
+>C</TD
+><TD
+>Y</TD
+><TD
+>&nbsp;</TD
+><TD
+>Y</TD
+><TD
+>C</TD
+><TD
+>Y</TD
+></TR
+><TR
+><TD
+>1</TD
+><TD
+>Y</TD
+><TD
+>C</TD
+><TD
+>Y</TD
+><TD
+>&nbsp;</TD
+><TD
+>Y</TD
+><TD
+>C</TD
+><TD
+>Y</TD
+></TR
+><TR
+><TD
+>2</TD
+><TD
+>Y</TD
+><TD
+>C</TD
+><TD
+>Y</TD
+><TD
+>&nbsp;</TD
+><TD
+>Y</TD
+><TD
+>C</TD
+><TD
+>Y</TD
+></TR
+><TR
+><TD
+>3</TD
+><TD
+>Y</TD
+><TD
+>C</TD
+><TD
+>Y</TD
+><TD
+>&nbsp;</TD
+><TD
+>Y</TD
+><TD
+>C</TD
+><TD
+>Y</TD
+></TR
+></TBODY
+></TABLE
+><P
+></P
+></DIV
+>
+ </P
+></DIV
+></DIV
+></DIV
+><H1
+><A
+NAME="PIXFMT-Y41P"
+></A
+><CODE
+CLASS="CONSTANT"
+>V4L2_PIX_FMT_Y41P</CODE
+></H1
+><DIV
+CLASS="REFNAMEDIV"
+><A
+NAME="AEN2163"
+></A
+><H2
+>Name</H2
+><CODE
+CLASS="CONSTANT"
+>V4L2_PIX_FMT_Y41P</CODE
+>
+('Y41P')&nbsp;--&nbsp;Packed format with &frac14; horizontal chroma
+resolution, also known as YUV 4:1:1.</DIV
+><DIV
+CLASS="REFSECT1"
+><A
+NAME="AEN2167"
+></A
+><H2
+>Description</H2
+><P
+>In this format each 12 bytes is eight pixels. In the
+twelve bytes are two CbCr pairs and eight Y's. The first CbCr pair
+goes with the first four Y's, and the second CbCr pair goes with the
+other four Y's. The Cb and Cr components have one fourth the
+horizontal resolution of the Y component.</P
+><P
+>Do not confuse this format with <A
+HREF="#PIXFMT-YUV411P"
+><CODE
+CLASS="CONSTANT"
+>V4L2_PIX_FMT_YUV411P</CODE
+></A
+>.
+Y41P is derived from "YUV 4:1:1 <SPAN
+CLASS="emphasis"
+><I
+CLASS="EMPHASIS"
+>packed</I
+></SPAN
+>", possibly
+in reference to a Windows FOURCC, while YUV411P stands for "YUV 4:1:1
+<SPAN
+CLASS="emphasis"
+><I
+CLASS="EMPHASIS"
+>planar</I
+></SPAN
+>".</P
+><DIV
+CLASS="EXAMPLE"
+><A
+NAME="AEN2175"
+></A
+><P
+><B
+>Example 2-1. <CODE
+CLASS="CONSTANT"
+>V4L2_PIX_FMT_Y41P</CODE
+> 8 &times; 4
+pixel image</B
+></P
+><DIV
+CLASS="FORMALPARA"
+><P
+><B
+>Byte Order. </B
+>Each cell is one byte.
+ <DIV
+CLASS="INFORMALTABLE"
+><P
+></P
+><A
+NAME="AEN2181"
+></A
+><TABLE
+BORDER="0"
+FRAME="void"
+CLASS="CALSTABLE"
+><COL
+WIDTH="2*"
+ALIGN="LEFT"><COL><COL><COL><COL><COL><COL><COL><COL><COL><COL><COL><COL><TBODY
+><TR
+><TD
+>start&nbsp;+&nbsp;0:</TD
+><TD
+>Cb<SUB
+>00</SUB
+></TD
+><TD
+>Y'<SUB
+>00</SUB
+></TD
+><TD
+>Cr<SUB
+>00</SUB
+></TD
+><TD
+>Y'<SUB
+>01</SUB
+></TD
+><TD
+>Cb<SUB
+>01</SUB
+></TD
+><TD
+>Y'<SUB
+>02</SUB
+></TD
+><TD
+>Cr<SUB
+>01</SUB
+></TD
+><TD
+>Y'<SUB
+>03</SUB
+></TD
+><TD
+>Y'<SUB
+>04</SUB
+></TD
+><TD
+>Y'<SUB
+>05</SUB
+></TD
+><TD
+>Y'<SUB
+>06</SUB
+></TD
+><TD
+>Y'<SUB
+>07</SUB
+></TD
+></TR
+><TR
+><TD
+>start&nbsp;+&nbsp;12:</TD
+><TD
+>Cb<SUB
+>10</SUB
+></TD
+><TD
+>Y'<SUB
+>10</SUB
+></TD
+><TD
+>Cr<SUB
+>10</SUB
+></TD
+><TD
+>Y'<SUB
+>11</SUB
+></TD
+><TD
+>Cb<SUB
+>11</SUB
+></TD
+><TD
+>Y'<SUB
+>12</SUB
+></TD
+><TD
+>Cr<SUB
+>11</SUB
+></TD
+><TD
+>Y'<SUB
+>13</SUB
+></TD
+><TD
+>Y'<SUB
+>14</SUB
+></TD
+><TD
+>Y'<SUB
+>15</SUB
+></TD
+><TD
+>Y'<SUB
+>16</SUB
+></TD
+><TD
+>Y'<SUB
+>17</SUB
+></TD
+></TR
+><TR
+><TD
+>start&nbsp;+&nbsp;24:</TD
+><TD
+>Cb<SUB
+>20</SUB
+></TD
+><TD
+>Y'<SUB
+>20</SUB
+></TD
+><TD
+>Cr<SUB
+>20</SUB
+></TD
+><TD
+>Y'<SUB
+>21</SUB
+></TD
+><TD
+>Cb<SUB
+>21</SUB
+></TD
+><TD
+>Y'<SUB
+>22</SUB
+></TD
+><TD
+>Cr<SUB
+>21</SUB
+></TD
+><TD
+>Y'<SUB
+>23</SUB
+></TD
+><TD
+>Y'<SUB
+>24</SUB
+></TD
+><TD
+>Y'<SUB
+>25</SUB
+></TD
+><TD
+>Y'<SUB
+>26</SUB
+></TD
+><TD
+>Y'<SUB
+>27</SUB
+></TD
+></TR
+><TR
+><TD
+>start&nbsp;+&nbsp;36:</TD
+><TD
+>Cb<SUB
+>30</SUB
+></TD
+><TD
+>Y'<SUB
+>30</SUB
+></TD
+><TD
+>Cr<SUB
+>30</SUB
+></TD
+><TD
+>Y'<SUB
+>31</SUB
+></TD
+><TD
+>Cb<SUB
+>31</SUB
+></TD
+><TD
+>Y'<SUB
+>32</SUB
+></TD
+><TD
+>Cr<SUB
+>31</SUB
+></TD
+><TD
+>Y'<SUB
+>33</SUB
+></TD
+><TD
+>Y'<SUB
+>34</SUB
+></TD
+><TD
+>Y'<SUB
+>35</SUB
+></TD
+><TD
+>Y'<SUB
+>36</SUB
+></TD
+><TD
+>Y'<SUB
+>37</SUB
+></TD
+></TR
+></TBODY
+></TABLE
+><P
+></P
+></DIV
+></P
+></DIV
+><DIV
+CLASS="FORMALPARA"
+><P
+><B
+>Color Sample Location. </B
+> <DIV
+CLASS="INFORMALTABLE"
+><P
+></P
+><A
+NAME="AEN2292"
+></A
+><TABLE
+BORDER="0"
+FRAME="void"
+CLASS="CALSTABLE"
+><COL><COL><COL><COL><COL><COL><COL><COL><COL><COL><COL><COL><COL><COL><COL><TBODY
+><TR
+><TD
+>&nbsp;</TD
+><TD
+>0</TD
+><TD
+>&nbsp;</TD
+><TD
+>1</TD
+><TD
+>&nbsp;</TD
+><TD
+>2</TD
+><TD
+>&nbsp;</TD
+><TD
+>3</TD
+><TD
+>&nbsp;</TD
+><TD
+>4</TD
+><TD
+>&nbsp;</TD
+><TD
+>5</TD
+><TD
+>&nbsp;</TD
+><TD
+>6</TD
+><TD
+>&nbsp;</TD
+><TD
+>7</TD
+></TR
+><TR
+><TD
+>0</TD
+><TD
+>Y</TD
+><TD
+>&nbsp;</TD
+><TD
+>Y</TD
+><TD
+>C</TD
+><TD
+>Y</TD
+><TD
+>&nbsp;</TD
+><TD
+>Y</TD
+><TD
+>&nbsp;</TD
+><TD
+>Y</TD
+><TD
+>&nbsp;</TD
+><TD
+>Y</TD
+><TD
+>C</TD
+><TD
+>Y</TD
+><TD
+>&nbsp;</TD
+><TD
+>Y</TD
+></TR
+><TR
+><TD
+>1</TD
+><TD
+>Y</TD
+><TD
+>&nbsp;</TD
+><TD
+>Y</TD
+><TD
+>C</TD
+><TD
+>Y</TD
+><TD
+>&nbsp;</TD
+><TD
+>Y</TD
+><TD
+>&nbsp;</TD
+><TD
+>Y</TD
+><TD
+>&nbsp;</TD
+><TD
+>Y</TD
+><TD
+>C</TD
+><TD
+>Y</TD
+><TD
+>&nbsp;</TD
+><TD
+>Y</TD
+></TR
+><TR
+><TD
+>2</TD
+><TD
+>Y</TD
+><TD
+>&nbsp;</TD
+><TD
+>Y</TD
+><TD
+>C</TD
+><TD
+>Y</TD
+><TD
+>&nbsp;</TD
+><TD
+>Y</TD
+><TD
+>&nbsp;</TD
+><TD
+>Y</TD
+><TD
+>&nbsp;</TD
+><TD
+>Y</TD
+><TD
+>C</TD
+><TD
+>Y</TD
+><TD
+>&nbsp;</TD
+><TD
+>Y</TD
+></TR
+><TR
+><TD
+>3</TD
+><TD
+>Y</TD
+><TD
+>&nbsp;</TD
+><TD
+>Y</TD
+><TD
+>C</TD
+><TD
+>Y</TD
+><TD
+>&nbsp;</TD
+><TD
+>Y</TD
+><TD
+>&nbsp;</TD
+><TD
+>Y</TD
+><TD
+>&nbsp;</TD
+><TD
+>Y</TD
+><TD
+>C</TD
+><TD
+>Y</TD
+><TD
+>&nbsp;</TD
+><TD
+>Y</TD
+></TR
+></TBODY
+></TABLE
+><P
+></P
+></DIV
+>
+ </P
+></DIV
+></DIV
+></DIV
+><H1
+><A
+NAME="PIXFMT-YVU420"
+></A
+><CODE
+CLASS="CONSTANT"
+>V4L2_PIX_FMT_YVU420</CODE
+>,
+<CODE
+CLASS="CONSTANT"
+>V4L2_PIX_FMT_YUV420</CODE
+></H1
+><DIV
+CLASS="REFNAMEDIV"
+><A
+NAME="AEN2385"
+></A
+><H2
+>Name</H2
+><CODE
+CLASS="CONSTANT"
+>V4L2_PIX_FMT_YVU420</CODE
+>
+('YV12'), <CODE
+CLASS="CONSTANT"
+>V4L2_PIX_FMT_YUV420</CODE
+>
+('YU12')&nbsp;--&nbsp;Planar formats with &frac12; horizontal and
+vertical chroma resolution, also known as YUV 4:2:0.</DIV
+><DIV
+CLASS="REFSECT1"
+><A
+NAME="AEN2391"
+></A
+><H2
+>Description</H2
+><P
+>These are planar formats, as opposed to a packed format.
+The three components are separated into three sub- images or planes.
+The Y plane is first. The Y plane has one byte per pixel. For
+<CODE
+CLASS="CONSTANT"
+>V4L2_PIX_FMT_YVU420</CODE
+>, the Cr plane immediately
+follows the Y plane in memory. The Cr plane is half the width and half
+the height of the Y plane (and of the image). Each Cr belongs to four
+pixels, a two-by-two square of the image. For example,
+Cr<SUB
+>0</SUB
+> belongs to Y'<SUB
+>00</SUB
+>,
+Y'<SUB
+>01</SUB
+>, Y'<SUB
+>10</SUB
+>, and
+Y'<SUB
+>11</SUB
+>. Following the Cr plane is the Cb plane,
+just like the Cr plane. <CODE
+CLASS="CONSTANT"
+>V4L2_PIX_FMT_YUV420</CODE
+> is
+the same except the Cb plane comes first, then the Cr plane.</P
+><P
+>If the Y plane has pad bytes after each row, then the Cr
+and Cb planes have half as many pad bytes after their rows. In other
+words, two Cx rows (including padding) is exactly as long as one Y row
+(including padding).</P
+><DIV
+CLASS="EXAMPLE"
+><A
+NAME="AEN2402"
+></A
+><P
+><B
+>Example 2-1. <CODE
+CLASS="CONSTANT"
+>V4L2_PIX_FMT_YVU420</CODE
+> 4 &times; 4
+pixel image</B
+></P
+><DIV
+CLASS="FORMALPARA"
+><P
+><B
+>Byte Order. </B
+>Each cell is one byte.
+ <DIV
+CLASS="INFORMALTABLE"
+><P
+></P
+><A
+NAME="AEN2408"
+></A
+><TABLE
+BORDER="0"
+FRAME="void"
+CLASS="CALSTABLE"
+><COL
+WIDTH="2*"
+ALIGN="LEFT"><COL><COL><COL><COL><TBODY
+><TR
+><TD
+>start&nbsp;+&nbsp;0:</TD
+><TD
+>Y'<SUB
+>00</SUB
+></TD
+><TD
+>Y'<SUB
+>01</SUB
+></TD
+><TD
+>Y'<SUB
+>02</SUB
+></TD
+><TD
+>Y'<SUB
+>03</SUB
+></TD
+></TR
+><TR
+><TD
+>start&nbsp;+&nbsp;4:</TD
+><TD
+>Y'<SUB
+>10</SUB
+></TD
+><TD
+>Y'<SUB
+>11</SUB
+></TD
+><TD
+>Y'<SUB
+>12</SUB
+></TD
+><TD
+>Y'<SUB
+>13</SUB
+></TD
+></TR
+><TR
+><TD
+>start&nbsp;+&nbsp;8:</TD
+><TD
+>Y'<SUB
+>20</SUB
+></TD
+><TD
+>Y'<SUB
+>21</SUB
+></TD
+><TD
+>Y'<SUB
+>22</SUB
+></TD
+><TD
+>Y'<SUB
+>23</SUB
+></TD
+></TR
+><TR
+><TD
+>start&nbsp;+&nbsp;12:</TD
+><TD
+>Y'<SUB
+>30</SUB
+></TD
+><TD
+>Y'<SUB
+>31</SUB
+></TD
+><TD
+>Y'<SUB
+>32</SUB
+></TD
+><TD
+>Y'<SUB
+>33</SUB
+></TD
+></TR
+><TR
+><TD
+>start&nbsp;+&nbsp;16:</TD
+><TD
+>Cr<SUB
+>00</SUB
+></TD
+><TD
+>Cr<SUB
+>01</SUB
+></TD
+><TD
+>&nbsp;</TD
+><TD
+>&nbsp;</TD
+></TR
+><TR
+><TD
+>start&nbsp;+&nbsp;18:</TD
+><TD
+>Cr<SUB
+>10</SUB
+></TD
+><TD
+>Cr<SUB
+>11</SUB
+></TD
+><TD
+>&nbsp;</TD
+><TD
+>&nbsp;</TD
+></TR
+><TR
+><TD
+>start&nbsp;+&nbsp;20:</TD
+><TD
+>Cb<SUB
+>00</SUB
+></TD
+><TD
+>Cb<SUB
+>01</SUB
+></TD
+><TD
+>&nbsp;</TD
+><TD
+>&nbsp;</TD
+></TR
+><TR
+><TD
+>start&nbsp;+&nbsp;22:</TD
+><TD
+>Cb<SUB
+>10</SUB
+></TD
+><TD
+>Cb<SUB
+>11</SUB
+></TD
+><TD
+>&nbsp;</TD
+><TD
+>&nbsp;</TD
+></TR
+></TBODY
+></TABLE
+><P
+></P
+></DIV
+>
+ </P
+></DIV
+><DIV
+CLASS="FORMALPARA"
+><P
+><B
+>Color Sample Location. </B
+> <DIV
+CLASS="INFORMALTABLE"
+><P
+></P
+><A
+NAME="AEN2479"
+></A
+><TABLE
+BORDER="0"
+FRAME="void"
+CLASS="CALSTABLE"
+><COL><COL><COL><COL><COL><COL><COL><TBODY
+><TR
+><TD
+>&nbsp;</TD
+><TD
+>0</TD
+><TD
+>&nbsp;</TD
+><TD
+>1</TD
+><TD
+>&nbsp;</TD
+><TD
+>2</TD
+><TD
+>&nbsp;</TD
+><TD
+>3</TD
+></TR
+><TR
+><TD
+>0</TD
+><TD
+>Y</TD
+><TD
+>&nbsp;</TD
+><TD
+>Y</TD
+><TD
+>&nbsp;</TD
+><TD
+>Y</TD
+><TD
+>&nbsp;</TD
+><TD
+>Y</TD
+></TR
+><TR
+><TD
+>&nbsp;</TD
+><TD
+>&nbsp;</TD
+><TD
+>C</TD
+><TD
+>&nbsp;</TD
+><TD
+>&nbsp;</TD
+><TD
+>&nbsp;</TD
+><TD
+>C</TD
+><TD
+>&nbsp;</TD
+></TR
+><TR
+><TD
+>1</TD
+><TD
+>Y</TD
+><TD
+>&nbsp;</TD
+><TD
+>Y</TD
+><TD
+>&nbsp;</TD
+><TD
+>Y</TD
+><TD
+>&nbsp;</TD
+><TD
+>Y</TD
+></TR
+><TR
+><TD
+>&nbsp;</TD
+><TD
+>&nbsp;</TD
+><TD
+>&nbsp;</TD
+><TD
+>&nbsp;</TD
+><TD
+>&nbsp;</TD
+><TD
+>&nbsp;</TD
+><TD
+>&nbsp;</TD
+></TR
+><TR
+><TD
+>2</TD
+><TD
+>Y</TD
+><TD
+>&nbsp;</TD
+><TD
+>Y</TD
+><TD
+>&nbsp;</TD
+><TD
+>Y</TD
+><TD
+>&nbsp;</TD
+><TD
+>Y</TD
+></TR
+><TR
+><TD
+>&nbsp;</TD
+><TD
+>&nbsp;</TD
+><TD
+>C</TD
+><TD
+>&nbsp;</TD
+><TD
+>&nbsp;</TD
+><TD
+>&nbsp;</TD
+><TD
+>C</TD
+><TD
+>&nbsp;</TD
+></TR
+><TR
+><TD
+>3</TD
+><TD
+>Y</TD
+><TD
+>&nbsp;</TD
+><TD
+>Y</TD
+><TD
+>&nbsp;</TD
+><TD
+>Y</TD
+><TD
+>&nbsp;</TD
+><TD
+>Y</TD
+></TR
+></TBODY
+></TABLE
+><P
+></P
+></DIV
+>
+ </P
+></DIV
+></DIV
+></DIV
+><H1
+><A
+NAME="PIXFMT-YVU410"
+></A
+><CODE
+CLASS="CONSTANT"
+>V4L2_PIX_FMT_YVU410</CODE
+>,
+<CODE
+CLASS="CONSTANT"
+>V4L2_PIX_FMT_YUV410</CODE
+></H1
+><DIV
+CLASS="REFNAMEDIV"
+><A
+NAME="AEN2552"
+></A
+><H2
+>Name</H2
+><CODE
+CLASS="CONSTANT"
+>V4L2_PIX_FMT_YVU410</CODE
+>
+('YVU9'), <CODE
+CLASS="CONSTANT"
+>V4L2_PIX_FMT_YUV410</CODE
+>
+('YUV9')&nbsp;--&nbsp;Planar formats with &frac14; horizontal and
+vertical chroma resolution, also known as YUV 4:1:0.</DIV
+><DIV
+CLASS="REFSECT1"
+><A
+NAME="AEN2558"
+></A
+><H2
+>Description</H2
+><P
+>These are planar formats, as opposed to a packed format.
+The three components are separated into three sub-images or planes.
+The Y plane is first. The Y plane has one byte per pixel. For
+<CODE
+CLASS="CONSTANT"
+>V4L2_PIX_FMT_YVU410</CODE
+>, the Cr plane immediately
+follows the Y plane in memory. The Cr plane is &frac14; the width and
+&frac14; the height of the Y plane (and of the image). Each Cr belongs
+to 16 pixels, a four-by-four square of the image. Following the Cr
+plane is the Cb plane, just like the Cr plane.
+<CODE
+CLASS="CONSTANT"
+>V4L2_PIX_FMT_YUV410</CODE
+> is the same, except the Cb
+plane comes first, then the Cr plane.</P
+><P
+>If the Y plane has pad bytes after each row, then the Cr
+and Cb planes have &frac14; as many pad bytes after their rows. In
+other words, four Cx rows (including padding) are exactly as long as
+one Y row (including padding).</P
+><DIV
+CLASS="EXAMPLE"
+><A
+NAME="AEN2564"
+></A
+><P
+><B
+>Example 2-1. <CODE
+CLASS="CONSTANT"
+>V4L2_PIX_FMT_YVU410</CODE
+> 4 &times; 4
+pixel image</B
+></P
+><DIV
+CLASS="FORMALPARA"
+><P
+><B
+>Byte Order. </B
+>Each cell is one byte.
+ <DIV
+CLASS="INFORMALTABLE"
+><P
+></P
+><A
+NAME="AEN2570"
+></A
+><TABLE
+BORDER="0"
+FRAME="void"
+CLASS="CALSTABLE"
+><COL
+WIDTH="2*"
+ALIGN="LEFT"><COL><COL><COL><COL><TBODY
+><TR
+><TD
+>start&nbsp;+&nbsp;0:</TD
+><TD
+>Y'<SUB
+>00</SUB
+></TD
+><TD
+>Y'<SUB
+>01</SUB
+></TD
+><TD
+>Y'<SUB
+>02</SUB
+></TD
+><TD
+>Y'<SUB
+>03</SUB
+></TD
+></TR
+><TR
+><TD
+>start&nbsp;+&nbsp;4:</TD
+><TD
+>Y'<SUB
+>10</SUB
+></TD
+><TD
+>Y'<SUB
+>11</SUB
+></TD
+><TD
+>Y'<SUB
+>12</SUB
+></TD
+><TD
+>Y'<SUB
+>13</SUB
+></TD
+></TR
+><TR
+><TD
+>start&nbsp;+&nbsp;8:</TD
+><TD
+>Y'<SUB
+>20</SUB
+></TD
+><TD
+>Y'<SUB
+>21</SUB
+></TD
+><TD
+>Y'<SUB
+>22</SUB
+></TD
+><TD
+>Y'<SUB
+>23</SUB
+></TD
+></TR
+><TR
+><TD
+>start&nbsp;+&nbsp;12:</TD
+><TD
+>Y'<SUB
+>30</SUB
+></TD
+><TD
+>Y'<SUB
+>31</SUB
+></TD
+><TD
+>Y'<SUB
+>32</SUB
+></TD
+><TD
+>Y'<SUB
+>33</SUB
+></TD
+></TR
+><TR
+><TD
+>start&nbsp;+&nbsp;16:</TD
+><TD
+>Cr<SUB
+>00</SUB
+></TD
+><TD
+>&nbsp;</TD
+><TD
+>&nbsp;</TD
+><TD
+>&nbsp;</TD
+></TR
+><TR
+><TD
+>start&nbsp;+&nbsp;17:</TD
+><TD
+>Cb<SUB
+>00</SUB
+></TD
+><TD
+>&nbsp;</TD
+><TD
+>&nbsp;</TD
+><TD
+>&nbsp;</TD
+></TR
+></TBODY
+></TABLE
+><P
+></P
+></DIV
+>
+ </P
+></DIV
+><DIV
+CLASS="FORMALPARA"
+><P
+><B
+>Color Sample Location. </B
+> <DIV
+CLASS="INFORMALTABLE"
+><P
+></P
+><A
+NAME="AEN2625"
+></A
+><TABLE
+BORDER="0"
+FRAME="void"
+CLASS="CALSTABLE"
+><COL><COL><COL><COL><COL><COL><COL><TBODY
+><TR
+><TD
+>&nbsp;</TD
+><TD
+>0</TD
+><TD
+>&nbsp;</TD
+><TD
+>1</TD
+><TD
+>&nbsp;</TD
+><TD
+>2</TD
+><TD
+>&nbsp;</TD
+><TD
+>3</TD
+></TR
+><TR
+><TD
+>0</TD
+><TD
+>Y</TD
+><TD
+>&nbsp;</TD
+><TD
+>Y</TD
+><TD
+>&nbsp;</TD
+><TD
+>Y</TD
+><TD
+>&nbsp;</TD
+><TD
+>Y</TD
+></TR
+><TR
+><TD
+>&nbsp;</TD
+><TD
+>&nbsp;</TD
+><TD
+>&nbsp;</TD
+><TD
+>&nbsp;</TD
+><TD
+>&nbsp;</TD
+><TD
+>&nbsp;</TD
+><TD
+>&nbsp;</TD
+></TR
+><TR
+><TD
+>1</TD
+><TD
+>Y</TD
+><TD
+>&nbsp;</TD
+><TD
+>Y</TD
+><TD
+>&nbsp;</TD
+><TD
+>Y</TD
+><TD
+>&nbsp;</TD
+><TD
+>Y</TD
+></TR
+><TR
+><TD
+>&nbsp;</TD
+><TD
+>&nbsp;</TD
+><TD
+>&nbsp;</TD
+><TD
+>&nbsp;</TD
+><TD
+>C</TD
+><TD
+>&nbsp;</TD
+><TD
+>&nbsp;</TD
+><TD
+>&nbsp;</TD
+></TR
+><TR
+><TD
+>2</TD
+><TD
+>Y</TD
+><TD
+>&nbsp;</TD
+><TD
+>Y</TD
+><TD
+>&nbsp;</TD
+><TD
+>Y</TD
+><TD
+>&nbsp;</TD
+><TD
+>Y</TD
+></TR
+><TR
+><TD
+>&nbsp;</TD
+><TD
+>&nbsp;</TD
+><TD
+>&nbsp;</TD
+><TD
+>&nbsp;</TD
+><TD
+>&nbsp;</TD
+><TD
+>&nbsp;</TD
+><TD
+>&nbsp;</TD
+></TR
+><TR
+><TD
+>3</TD
+><TD
+>Y</TD
+><TD
+>&nbsp;</TD
+><TD
+>Y</TD
+><TD
+>&nbsp;</TD
+><TD
+>Y</TD
+><TD
+>&nbsp;</TD
+><TD
+>Y</TD
+></TR
+></TBODY
+></TABLE
+><P
+></P
+></DIV
+>
+ </P
+></DIV
+></DIV
+></DIV
+><H1
+><A
+NAME="PIXFMT-YUV422P"
+></A
+><CODE
+CLASS="CONSTANT"
+>V4L2_PIX_FMT_YUV422P</CODE
+></H1
+><DIV
+CLASS="REFNAMEDIV"
+><A
+NAME="AEN2690"
+></A
+><H2
+>Name</H2
+><CODE
+CLASS="CONSTANT"
+>V4L2_PIX_FMT_YUV422P</CODE
+>
+('422P')&nbsp;--&nbsp;Format with &frac12; horizontal chroma resolution,
+also known as YUV 4:2:2. Planar layout as opposed to
+<CODE
+CLASS="CONSTANT"
+>V4L2_PIX_FMT_YUYV</CODE
+>.</DIV
+><DIV
+CLASS="REFSECT1"
+><A
+NAME="AEN2695"
+></A
+><H2
+>Description</H2
+><P
+>This format is not commonly used. This is a planar
+version of the YUYV format. The three components are separated into
+three sub-images or planes. The Y plane is first. The Y plane has one
+byte per pixel. The Cb plane immediately follows the Y plane in
+memory. The Cb plane is half the width of the Y plane (and of the
+image). Each Cb belongs to two pixels. For example,
+Cb<SUB
+>0</SUB
+> belongs to Y'<SUB
+>00</SUB
+>,
+Y'<SUB
+>01</SUB
+>. Following the Cb plane is the Cr plane,
+just like the Cb plane.</P
+><P
+>If the Y plane has pad bytes after each row, then the Cr
+and Cb planes have half as many pad bytes after their rows. In other
+words, two Cx rows (including padding) is exactly as long as one Y row
+(including padding).</P
+><DIV
+CLASS="EXAMPLE"
+><A
+NAME="AEN2702"
+></A
+><P
+><B
+>Example 2-1. <CODE
+CLASS="CONSTANT"
+>V4L2_PIX_FMT_YUV422P</CODE
+> 4 &times; 4
+pixel image</B
+></P
+><DIV
+CLASS="FORMALPARA"
+><P
+><B
+>Byte Order. </B
+>Each cell is one byte.
+ <DIV
+CLASS="INFORMALTABLE"
+><P
+></P
+><A
+NAME="AEN2708"
+></A
+><TABLE
+BORDER="0"
+FRAME="void"
+CLASS="CALSTABLE"
+><COL
+WIDTH="2*"
+ALIGN="LEFT"><COL><COL><COL><COL><TBODY
+><TR
+><TD
+>start&nbsp;+&nbsp;0:</TD
+><TD
+>Y'<SUB
+>00</SUB
+></TD
+><TD
+>Y'<SUB
+>01</SUB
+></TD
+><TD
+>Y'<SUB
+>02</SUB
+></TD
+><TD
+>Y'<SUB
+>03</SUB
+></TD
+></TR
+><TR
+><TD
+>start&nbsp;+&nbsp;4:</TD
+><TD
+>Y'<SUB
+>10</SUB
+></TD
+><TD
+>Y'<SUB
+>11</SUB
+></TD
+><TD
+>Y'<SUB
+>12</SUB
+></TD
+><TD
+>Y'<SUB
+>13</SUB
+></TD
+></TR
+><TR
+><TD
+>start&nbsp;+&nbsp;8:</TD
+><TD
+>Y'<SUB
+>20</SUB
+></TD
+><TD
+>Y'<SUB
+>21</SUB
+></TD
+><TD
+>Y'<SUB
+>22</SUB
+></TD
+><TD
+>Y'<SUB
+>23</SUB
+></TD
+></TR
+><TR
+><TD
+>start&nbsp;+&nbsp;12:</TD
+><TD
+>Y'<SUB
+>30</SUB
+></TD
+><TD
+>Y'<SUB
+>31</SUB
+></TD
+><TD
+>Y'<SUB
+>32</SUB
+></TD
+><TD
+>Y'<SUB
+>33</SUB
+></TD
+></TR
+><TR
+><TD
+>start&nbsp;+&nbsp;16:</TD
+><TD
+>Cb<SUB
+>00</SUB
+></TD
+><TD
+>Cb<SUB
+>01</SUB
+></TD
+><TD
+>&nbsp;</TD
+><TD
+>&nbsp;</TD
+></TR
+><TR
+><TD
+>start&nbsp;+&nbsp;18:</TD
+><TD
+>Cb<SUB
+>10</SUB
+></TD
+><TD
+>Cb<SUB
+>11</SUB
+></TD
+><TD
+>&nbsp;</TD
+><TD
+>&nbsp;</TD
+></TR
+><TR
+><TD
+>start&nbsp;+&nbsp;20:</TD
+><TD
+>Cb<SUB
+>20</SUB
+></TD
+><TD
+>Cb<SUB
+>21</SUB
+></TD
+><TD
+>&nbsp;</TD
+><TD
+>&nbsp;</TD
+></TR
+><TR
+><TD
+>start&nbsp;+&nbsp;22:</TD
+><TD
+>Cb<SUB
+>30</SUB
+></TD
+><TD
+>Cb<SUB
+>31</SUB
+></TD
+><TD
+>&nbsp;</TD
+><TD
+>&nbsp;</TD
+></TR
+><TR
+><TD
+>start&nbsp;+&nbsp;24:</TD
+><TD
+>Cr<SUB
+>00</SUB
+></TD
+><TD
+>Cr<SUB
+>01</SUB
+></TD
+><TD
+>&nbsp;</TD
+><TD
+>&nbsp;</TD
+></TR
+><TR
+><TD
+>start&nbsp;+&nbsp;26:</TD
+><TD
+>Cr<SUB
+>10</SUB
+></TD
+><TD
+>Cr<SUB
+>11</SUB
+></TD
+><TD
+>&nbsp;</TD
+><TD
+>&nbsp;</TD
+></TR
+><TR
+><TD
+>start&nbsp;+&nbsp;28:</TD
+><TD
+>Cr<SUB
+>20</SUB
+></TD
+><TD
+>Cr<SUB
+>21</SUB
+></TD
+><TD
+>&nbsp;</TD
+><TD
+>&nbsp;</TD
+></TR
+><TR
+><TD
+>start&nbsp;+&nbsp;30:</TD
+><TD
+>Cr<SUB
+>30</SUB
+></TD
+><TD
+>Cr<SUB
+>31</SUB
+></TD
+><TD
+>&nbsp;</TD
+><TD
+>&nbsp;</TD
+></TR
+></TBODY
+></TABLE
+><P
+></P
+></DIV
+>
+ </P
+></DIV
+><DIV
+CLASS="FORMALPARA"
+><P
+><B
+>Color Sample Location. </B
+> <DIV
+CLASS="INFORMALTABLE"
+><P
+></P
+><A
+NAME="AEN2803"
+></A
+><TABLE
+BORDER="0"
+FRAME="void"
+CLASS="CALSTABLE"
+><COL><COL><COL><COL><COL><COL><COL><TBODY
+><TR
+><TD
+>&nbsp;</TD
+><TD
+>0</TD
+><TD
+>&nbsp;</TD
+><TD
+>1</TD
+><TD
+>&nbsp;</TD
+><TD
+>2</TD
+><TD
+>&nbsp;</TD
+><TD
+>3</TD
+></TR
+><TR
+><TD
+>0</TD
+><TD
+>Y</TD
+><TD
+>C</TD
+><TD
+>Y</TD
+><TD
+>&nbsp;</TD
+><TD
+>Y</TD
+><TD
+>C</TD
+><TD
+>Y</TD
+></TR
+><TR
+><TD
+>1</TD
+><TD
+>Y</TD
+><TD
+>C</TD
+><TD
+>Y</TD
+><TD
+>&nbsp;</TD
+><TD
+>Y</TD
+><TD
+>C</TD
+><TD
+>Y</TD
+></TR
+><TR
+><TD
+>2</TD
+><TD
+>Y</TD
+><TD
+>C</TD
+><TD
+>Y</TD
+><TD
+>&nbsp;</TD
+><TD
+>Y</TD
+><TD
+>C</TD
+><TD
+>Y</TD
+></TR
+><TR
+><TD
+>3</TD
+><TD
+>Y</TD
+><TD
+>C</TD
+><TD
+>Y</TD
+><TD
+>&nbsp;</TD
+><TD
+>Y</TD
+><TD
+>C</TD
+><TD
+>Y</TD
+></TR
+></TBODY
+></TABLE
+><P
+></P
+></DIV
+>
+ </P
+></DIV
+></DIV
+></DIV
+><H1
+><A
+NAME="PIXFMT-YUV411P"
+></A
+><CODE
+CLASS="CONSTANT"
+>V4L2_PIX_FMT_YUV411P</CODE
+></H1
+><DIV
+CLASS="REFNAMEDIV"
+><A
+NAME="AEN2855"
+></A
+><H2
+>Name</H2
+><CODE
+CLASS="CONSTANT"
+>V4L2_PIX_FMT_YUV411P</CODE
+>
+('411P')&nbsp;--&nbsp;Format with &frac14; horizontal chroma resolution,
+also known as YUV 4:1:1. Planar layout as opposed to
+<CODE
+CLASS="CONSTANT"
+>V4L2_PIX_FMT_Y41P</CODE
+>.</DIV
+><DIV
+CLASS="REFSECT1"
+><A
+NAME="AEN2860"
+></A
+><H2
+>Description</H2
+><P
+>This format is not commonly used. This is a planar
+format similar to the 4:2:2 planar format except with half as many
+chroma. The three components are separated into three sub-images or
+planes. The Y plane is first. The Y plane has one byte per pixel. The
+Cb plane immediately follows the Y plane in memory. The Cb plane is
+&frac14; the width of the Y plane (and of the image). Each Cb belongs
+to 4 pixels all on the same row. For example,
+Cb<SUB
+>0</SUB
+> belongs to Y'<SUB
+>00</SUB
+>,
+Y'<SUB
+>01</SUB
+>, Y'<SUB
+>02</SUB
+> and
+Y'<SUB
+>03</SUB
+>. Following the Cb plane is the Cr plane,
+just like the Cb plane.</P
+><P
+>If the Y plane has pad bytes after each row, then the Cr
+and Cb planes have &frac14; as many pad bytes after their rows. In
+other words, four C x rows (including padding) is exactly as long as
+one Y row (including padding).</P
+><DIV
+CLASS="EXAMPLE"
+><A
+NAME="AEN2869"
+></A
+><P
+><B
+>Example 2-1. <CODE
+CLASS="CONSTANT"
+>V4L2_PIX_FMT_YUV411P</CODE
+> 4 &times; 4
+pixel image</B
+></P
+><DIV
+CLASS="FORMALPARA"
+><P
+><B
+>Byte Order. </B
+>Each cell is one byte.
+ <DIV
+CLASS="INFORMALTABLE"
+><P
+></P
+><A
+NAME="AEN2875"
+></A
+><TABLE
+BORDER="0"
+FRAME="void"
+CLASS="CALSTABLE"
+><COL
+WIDTH="2*"
+ALIGN="LEFT"><COL><COL><COL><COL><TBODY
+><TR
+><TD
+>start&nbsp;+&nbsp;0:</TD
+><TD
+>Y'<SUB
+>00</SUB
+></TD
+><TD
+>Y'<SUB
+>01</SUB
+></TD
+><TD
+>Y'<SUB
+>02</SUB
+></TD
+><TD
+>Y'<SUB
+>03</SUB
+></TD
+></TR
+><TR
+><TD
+>start&nbsp;+&nbsp;4:</TD
+><TD
+>Y'<SUB
+>10</SUB
+></TD
+><TD
+>Y'<SUB
+>11</SUB
+></TD
+><TD
+>Y'<SUB
+>12</SUB
+></TD
+><TD
+>Y'<SUB
+>13</SUB
+></TD
+></TR
+><TR
+><TD
+>start&nbsp;+&nbsp;8:</TD
+><TD
+>Y'<SUB
+>20</SUB
+></TD
+><TD
+>Y'<SUB
+>21</SUB
+></TD
+><TD
+>Y'<SUB
+>22</SUB
+></TD
+><TD
+>Y'<SUB
+>23</SUB
+></TD
+></TR
+><TR
+><TD
+>start&nbsp;+&nbsp;12:</TD
+><TD
+>Y'<SUB
+>30</SUB
+></TD
+><TD
+>Y'<SUB
+>31</SUB
+></TD
+><TD
+>Y'<SUB
+>32</SUB
+></TD
+><TD
+>Y'<SUB
+>33</SUB
+></TD
+></TR
+><TR
+><TD
+>start&nbsp;+&nbsp;16:</TD
+><TD
+>Cb<SUB
+>00</SUB
+></TD
+><TD
+>&nbsp;</TD
+><TD
+>&nbsp;</TD
+><TD
+>&nbsp;</TD
+></TR
+><TR
+><TD
+>start&nbsp;+&nbsp;17:</TD
+><TD
+>Cb<SUB
+>10</SUB
+></TD
+><TD
+>&nbsp;</TD
+><TD
+>&nbsp;</TD
+><TD
+>&nbsp;</TD
+></TR
+><TR
+><TD
+>start&nbsp;+&nbsp;18:</TD
+><TD
+>Cb<SUB
+>20</SUB
+></TD
+><TD
+>&nbsp;</TD
+><TD
+>&nbsp;</TD
+><TD
+>&nbsp;</TD
+></TR
+><TR
+><TD
+>start&nbsp;+&nbsp;19:</TD
+><TD
+>Cb<SUB
+>30</SUB
+></TD
+><TD
+>&nbsp;</TD
+><TD
+>&nbsp;</TD
+><TD
+>&nbsp;</TD
+></TR
+><TR
+><TD
+>start&nbsp;+&nbsp;20:</TD
+><TD
+>Cr<SUB
+>00</SUB
+></TD
+><TD
+>&nbsp;</TD
+><TD
+>&nbsp;</TD
+><TD
+>&nbsp;</TD
+></TR
+><TR
+><TD
+>start&nbsp;+&nbsp;21:</TD
+><TD
+>Cr<SUB
+>10</SUB
+></TD
+><TD
+>&nbsp;</TD
+><TD
+>&nbsp;</TD
+><TD
+>&nbsp;</TD
+></TR
+><TR
+><TD
+>start&nbsp;+&nbsp;22:</TD
+><TD
+>Cr<SUB
+>20</SUB
+></TD
+><TD
+>&nbsp;</TD
+><TD
+>&nbsp;</TD
+><TD
+>&nbsp;</TD
+></TR
+><TR
+><TD
+>start&nbsp;+&nbsp;23:</TD
+><TD
+>Cr<SUB
+>30</SUB
+></TD
+><TD
+>&nbsp;</TD
+><TD
+>&nbsp;</TD
+><TD
+>&nbsp;</TD
+></TR
+></TBODY
+></TABLE
+><P
+></P
+></DIV
+>
+ </P
+></DIV
+><DIV
+CLASS="FORMALPARA"
+><P
+><B
+>Color Sample Location. </B
+> <DIV
+CLASS="INFORMALTABLE"
+><P
+></P
+><A
+NAME="AEN2954"
+></A
+><TABLE
+BORDER="0"
+FRAME="void"
+CLASS="CALSTABLE"
+><COL><COL><COL><COL><COL><COL><COL><TBODY
+><TR
+><TD
+>&nbsp;</TD
+><TD
+>0</TD
+><TD
+>&nbsp;</TD
+><TD
+>1</TD
+><TD
+>&nbsp;</TD
+><TD
+>2</TD
+><TD
+>&nbsp;</TD
+><TD
+>3</TD
+></TR
+><TR
+><TD
+>0</TD
+><TD
+>Y</TD
+><TD
+>&nbsp;</TD
+><TD
+>Y</TD
+><TD
+>C</TD
+><TD
+>Y</TD
+><TD
+>&nbsp;</TD
+><TD
+>Y</TD
+></TR
+><TR
+><TD
+>1</TD
+><TD
+>Y</TD
+><TD
+>&nbsp;</TD
+><TD
+>Y</TD
+><TD
+>C</TD
+><TD
+>Y</TD
+><TD
+>&nbsp;</TD
+><TD
+>Y</TD
+></TR
+><TR
+><TD
+>2</TD
+><TD
+>Y</TD
+><TD
+>&nbsp;</TD
+><TD
+>Y</TD
+><TD
+>C</TD
+><TD
+>Y</TD
+><TD
+>&nbsp;</TD
+><TD
+>Y</TD
+></TR
+><TR
+><TD
+>3</TD
+><TD
+>Y</TD
+><TD
+>&nbsp;</TD
+><TD
+>Y</TD
+><TD
+>C</TD
+><TD
+>Y</TD
+><TD
+>&nbsp;</TD
+><TD
+>Y</TD
+></TR
+></TBODY
+></TABLE
+><P
+></P
+></DIV
+>
+ </P
+></DIV
+></DIV
+></DIV
+><H1
+><A
+NAME="AEN3002"
+></A
+><CODE
+CLASS="CONSTANT"
+>V4L2_PIX_FMT_NV12</CODE
+>,
+<CODE
+CLASS="CONSTANT"
+>V4L2_PIX_FMT_NV21</CODE
+></H1
+><DIV
+CLASS="REFNAMEDIV"
+><A
+NAME="AEN3007"
+></A
+><H2
+>Name</H2
+><CODE
+CLASS="CONSTANT"
+>V4L2_PIX_FMT_NV12</CODE
+>
+('NV12'), <CODE
+CLASS="CONSTANT"
+>V4L2_PIX_FMT_NV21</CODE
+>
+('NV21')&nbsp;--&nbsp;Formats with &frac12; horizontal and vertical
+chroma resolution, also known as YUV 4:2:0. One luminance and one
+chrominance plane with alternating chroma samples as opposed to
+<CODE
+CLASS="CONSTANT"
+>V4L2_PIX_FMT_YVU420</CODE
+>.</DIV
+><DIV
+CLASS="REFSECT1"
+><A
+NAME="AEN3014"
+></A
+><H2
+>Description</H2
+><P
+>These are two-plane versions of the YUV 4:2:0 format.
+The three components are separated into two sub-images or planes. The
+Y plane is first. The Y plane has one byte per pixel. For
+<CODE
+CLASS="CONSTANT"
+>V4L2_PIX_FMT_NV12</CODE
+>, a combined CbCr plane
+immediately follows the Y plane in memory. The CbCr plane is the same
+width, in bytes, as the Y plane (and of the image), but is half as
+tall in pixels. Each CbCr pair belongs to four pixels. For example,
+Cb<SUB
+>0</SUB
+>/Cr<SUB
+>0</SUB
+> belongs to
+Y'<SUB
+>00</SUB
+>, Y'<SUB
+>01</SUB
+>,
+Y'<SUB
+>10</SUB
+>, Y'<SUB
+>11</SUB
+>.
+<CODE
+CLASS="CONSTANT"
+>V4L2_PIX_FMT_NV21</CODE
+> is the same except the Cb and
+Cr bytes are swapped, the CrCb plane starts with a Cr byte.</P
+><P
+>If the Y plane has pad bytes after each row, then the
+CbCr plane has as many pad bytes after its rows.</P
+><DIV
+CLASS="EXAMPLE"
+><A
+NAME="AEN3026"
+></A
+><P
+><B
+>Example 2-1. <CODE
+CLASS="CONSTANT"
+>V4L2_PIX_FMT_NV12</CODE
+> 4 &times; 4
+pixel image</B
+></P
+><DIV
+CLASS="FORMALPARA"
+><P
+><B
+>Byte Order. </B
+>Each cell is one byte.
+ <DIV
+CLASS="INFORMALTABLE"
+><P
+></P
+><A
+NAME="AEN3032"
+></A
+><TABLE
+BORDER="0"
+FRAME="void"
+CLASS="CALSTABLE"
+><COL
+WIDTH="2*"
+ALIGN="LEFT"><COL><COL><COL><COL><TBODY
+><TR
+><TD
+>start&nbsp;+&nbsp;0:</TD
+><TD
+>Y'<SUB
+>00</SUB
+></TD
+><TD
+>Y'<SUB
+>01</SUB
+></TD
+><TD
+>Y'<SUB
+>02</SUB
+></TD
+><TD
+>Y'<SUB
+>03</SUB
+></TD
+></TR
+><TR
+><TD
+>start&nbsp;+&nbsp;4:</TD
+><TD
+>Y'<SUB
+>10</SUB
+></TD
+><TD
+>Y'<SUB
+>11</SUB
+></TD
+><TD
+>Y'<SUB
+>12</SUB
+></TD
+><TD
+>Y'<SUB
+>13</SUB
+></TD
+></TR
+><TR
+><TD
+>start&nbsp;+&nbsp;8:</TD
+><TD
+>Y'<SUB
+>20</SUB
+></TD
+><TD
+>Y'<SUB
+>21</SUB
+></TD
+><TD
+>Y'<SUB
+>22</SUB
+></TD
+><TD
+>Y'<SUB
+>23</SUB
+></TD
+></TR
+><TR
+><TD
+>start&nbsp;+&nbsp;12:</TD
+><TD
+>Y'<SUB
+>30</SUB
+></TD
+><TD
+>Y'<SUB
+>31</SUB
+></TD
+><TD
+>Y'<SUB
+>32</SUB
+></TD
+><TD
+>Y'<SUB
+>33</SUB
+></TD
+></TR
+><TR
+><TD
+>start&nbsp;+&nbsp;16:</TD
+><TD
+>Cb<SUB
+>00</SUB
+></TD
+><TD
+>Cr<SUB
+>00</SUB
+></TD
+><TD
+>Cb<SUB
+>01</SUB
+></TD
+><TD
+>Cr<SUB
+>01</SUB
+></TD
+></TR
+><TR
+><TD
+>start&nbsp;+&nbsp;20:</TD
+><TD
+>Cb<SUB
+>10</SUB
+></TD
+><TD
+>Cr<SUB
+>10</SUB
+></TD
+><TD
+>Cb<SUB
+>11</SUB
+></TD
+><TD
+>Cr<SUB
+>11</SUB
+></TD
+></TR
+></TBODY
+></TABLE
+><P
+></P
+></DIV
+>
+ </P
+></DIV
+><DIV
+CLASS="FORMALPARA"
+><P
+><B
+>Color Sample Location. </B
+> <DIV
+CLASS="INFORMALTABLE"
+><P
+></P
+><A
+NAME="AEN3099"
+></A
+><TABLE
+BORDER="0"
+FRAME="void"
+CLASS="CALSTABLE"
+><COL><COL><COL><COL><COL><COL><COL><TBODY
+><TR
+><TD
+>&nbsp;</TD
+><TD
+>0</TD
+><TD
+>&nbsp;</TD
+><TD
+>1</TD
+><TD
+>&nbsp;</TD
+><TD
+>2</TD
+><TD
+>&nbsp;</TD
+><TD
+>3</TD
+></TR
+><TR
+><TD
+>0</TD
+><TD
+>Y</TD
+><TD
+>&nbsp;</TD
+><TD
+>Y</TD
+><TD
+>&nbsp;</TD
+><TD
+>Y</TD
+><TD
+>&nbsp;</TD
+><TD
+>Y</TD
+></TR
+><TR
+><TD
+>&nbsp;</TD
+><TD
+>&nbsp;</TD
+><TD
+>C</TD
+><TD
+>&nbsp;</TD
+><TD
+>&nbsp;</TD
+><TD
+>&nbsp;</TD
+><TD
+>C</TD
+><TD
+>&nbsp;</TD
+></TR
+><TR
+><TD
+>1</TD
+><TD
+>Y</TD
+><TD
+>&nbsp;</TD
+><TD
+>Y</TD
+><TD
+>&nbsp;</TD
+><TD
+>Y</TD
+><TD
+>&nbsp;</TD
+><TD
+>Y</TD
+></TR
+><TR
+><TD
+>&nbsp;</TD
+><TD
+>&nbsp;</TD
+><TD
+>&nbsp;</TD
+><TD
+>&nbsp;</TD
+><TD
+>&nbsp;</TD
+><TD
+>&nbsp;</TD
+><TD
+>&nbsp;</TD
+></TR
+><TR
+><TD
+>2</TD
+><TD
+>Y</TD
+><TD
+>&nbsp;</TD
+><TD
+>Y</TD
+><TD
+>&nbsp;</TD
+><TD
+>Y</TD
+><TD
+>&nbsp;</TD
+><TD
+>Y</TD
+></TR
+><TR
+><TD
+>&nbsp;</TD
+><TD
+>&nbsp;</TD
+><TD
+>C</TD
+><TD
+>&nbsp;</TD
+><TD
+>&nbsp;</TD
+><TD
+>&nbsp;</TD
+><TD
+>C</TD
+><TD
+>&nbsp;</TD
+></TR
+><TR
+><TD
+>3</TD
+><TD
+>Y</TD
+><TD
+>&nbsp;</TD
+><TD
+>Y</TD
+><TD
+>&nbsp;</TD
+><TD
+>Y</TD
+><TD
+>&nbsp;</TD
+><TD
+>Y</TD
+></TR
+></TBODY
+></TABLE
+><P
+></P
+></DIV
+>
+ </P
+></DIV
+></DIV
+></DIV
+></DIV
+><DIV
+CLASS="SECTION"
+><HR><H2
+CLASS="SECTION"
+><A
+NAME="AEN3167"
+>2.5. Compressed Formats</A
+></H2
+><P
+>[to do, see also <A
+HREF="#VIDIOC-G-COMP"
+><CODE
+CLASS="CONSTANT"
+>VIDIOC_G_COMP</CODE
+></A
+>, <A
+HREF="#VIDIOC-G-COMP"
+><CODE
+CLASS="CONSTANT"
+>VIDIOC_S_COMP</CODE
+></A
+>,
+<A
+HREF="#VIDIOC-G-JPEGCOMP"
+><CODE
+CLASS="CONSTANT"
+>VIDIOC_G_JPEGCOMP</CODE
+></A
+>, <A
+HREF="#VIDIOC-G-JPEGCOMP"
+><CODE
+CLASS="CONSTANT"
+>VIDIOC_S_JPEGCOMP</CODE
+></A
+>. The only compressed standard
+format should be [M]JPEG.]</P
+></DIV
+><DIV
+CLASS="SECTION"
+><HR><H2
+CLASS="SECTION"
+><A
+NAME="PIXFMT-RESERVED"
+>2.6. Reserved Format Identifiers</A
+></H2
+><P
+>These formats are not defined by this specification, they
+are just listed for reference and to avoid naming conflicts. If you
+want to register your own format, send an e-mail to V4L2 maintainer
+Gerd Knorr <A
+HREF="http://bytesex.org/"
+TARGET="_top"
+>http://bytesex.org/</A
+>
+for inclusion in the <TT
+CLASS="FILENAME"
+>videodev.h</TT
+> file. If you want
+to share your format with other developers add a link to your
+documentation and send a copy to the maintainer of this document,
+Michael Schimek <CODE
+CLASS="EMAIL"
+>&#60;<A
+HREF="mailto:mschimek@gmx.at"
+>mschimek@gmx.at</A
+>&#62;</CODE
+>, for inclusion in this
+section. If you think your format should be listed in a standard
+format section please make a proposal on the V4L mailing list:
+<A
+HREF="https://listman.redhat.com/mailman/listinfo/video4linux-list"
+TARGET="_top"
+>https://listman.redhat.com/mailman/listinfo/video4linux-list</A
+>.</P
+><DIV
+CLASS="TABLE"
+><A
+NAME="RESERVED-FORMATS"
+></A
+><P
+><B
+>Table 2-4. Reserved Image Formats</B
+></P
+><TABLE
+BORDER="0"
+FRAME="void"
+WIDTH="100%"
+CLASS="CALSTABLE"
+><COL
+WIDTH="38%"
+TITLE="C1"><COL
+WIDTH="12%"
+TITLE="C2"><COL
+WIDTH="50%"
+TITLE="C3"><THEAD
+><TR
+><TH
+>Identifier</TH
+><TH
+>Code</TH
+><TH
+>Details</TH
+></TR
+></THEAD
+><TBODY
+><TR
+><TD
+> <CODE
+CLASS="CONSTANT"
+>V4L2_PIX_FMT_YYUV</CODE
+>
+ </TD
+><TD
+>'YYUV'</TD
+><TD
+>unknown</TD
+></TR
+><TR
+><TD
+> <CODE
+CLASS="CONSTANT"
+>V4L2_PIX_FMT_HI240</CODE
+>
+ </TD
+><TD
+>'HI24'</TD
+><TD
+> Used by the BTTV driver, <A
+HREF="http://bytesex.org/bttv/"
+TARGET="_top"
+>http://bytesex.org/bttv/</A
+>
+ </TD
+></TR
+><TR
+><TD
+> <CODE
+CLASS="CONSTANT"
+>V4L2_PIX_FMT_MJPEG</CODE
+>
+ </TD
+><TD
+>'MJPG'</TD
+><TD
+>Used by the Zoran driver</TD
+></TR
+><TR
+><TD
+> <CODE
+CLASS="CONSTANT"
+>V4L2_PIX_FMT_JPEG</CODE
+>
+ </TD
+><TD
+>'JPEG'</TD
+><TD
+>unknown [?]</TD
+></TR
+><TR
+><TD
+> <CODE
+CLASS="CONSTANT"
+>V4L2_PIX_FMT_DV</CODE
+>
+ </TD
+><TD
+>'dvsd'</TD
+><TD
+>unknown</TD
+></TR
+><TR
+><TD
+> <CODE
+CLASS="CONSTANT"
+>V4L2_PIX_FMT_MPEG</CODE
+>
+ </TD
+><TD
+>'MPEG'</TD
+><TD
+>unknown</TD
+></TR
+><TR
+><TD
+> <CODE
+CLASS="CONSTANT"
+>V4L2_PIX_FMT_WNVA</CODE
+>
+ </TD
+><TD
+>'WNVA'</TD
+><TD
+> Used by the Winnov Videum driver, <A
+HREF="http://www.thedirks.org/winnov/"
+TARGET="_top"
+>http://www.thedirks.org/winnov/</A
+>
+ </TD
+></TR
+></TBODY
+></TABLE
+></DIV
+></DIV
+></DIV
+><DIV
+CLASS="CHAPTER"
+><HR><H1
+><A
+NAME="IO"
+></A
+>Chapter 3. Input/Output</H1
+><P
+>The V4L2 API defines several different methods to read from or
+write to a device. All drivers exchanging data with applications must
+support at least one of them.</P
+><P
+>The classic I/O method using the <CODE
+CLASS="FUNCTION"
+>read()</CODE
+>
+and <CODE
+CLASS="FUNCTION"
+>write()</CODE
+> function is automatically selected
+after opening a V4L2 device. When the driver does not support this
+method attempts to read or write will fail at any time.</P
+><P
+>Other methods must be negotiated. To select the streaming I/O
+method with memory mapped or user buffers applications call the
+<A
+HREF="#VIDIOC-REQBUFS"
+><CODE
+CLASS="CONSTANT"
+>VIDIOC_REQBUFS</CODE
+></A
+> ioctl. The asynchronous I/O method is not defined
+yet.</P
+><P
+>Video overlay can be considered another I/O method, although
+the application does not directly receive the image data. It is
+selected by initiating video overlay with the <A
+HREF="#VIDIOC-G-FMT"
+><CODE
+CLASS="CONSTANT"
+>VIDIOC_S_FMT</CODE
+></A
+> ioctl.
+For more information see <A
+HREF="#OVERLAY"
+>Section 4.2</A
+>.</P
+><P
+>Generally exactly one I/O method, including overlay, is
+associated with each file descriptor. The only exceptions are
+applications not exchanging data with a driver ("panel applications",
+see <A
+HREF="#OPEN"
+>Section 1.1</A
+>) and drivers permitting simultaneous video capturing
+and overlay using the same file descriptor, for compatibility with V4L
+and earlier versions of V4L2.</P
+><P
+><CODE
+CLASS="CONSTANT"
+>VIDIOC_S_FMT</CODE
+> and
+<CODE
+CLASS="CONSTANT"
+>VIDIOC_REQBUFS</CODE
+> would permit this to some degree,
+but for simplicity drivers need not support switching the I/O method
+(after first switching away from read/write) other than by closing
+and reopening the device.</P
+><P
+>The following sections describe the various I/O methods in
+more detail.</P
+><DIV
+CLASS="SECTION"
+><HR><H2
+CLASS="SECTION"
+><A
+NAME="RW"
+>3.1. Read/Write</A
+></H2
+><P
+>Input and output devices support the
+<CODE
+CLASS="FUNCTION"
+>read()</CODE
+> and <CODE
+CLASS="FUNCTION"
+>write()</CODE
+> function,
+respectively, when the <CODE
+CLASS="CONSTANT"
+>V4L2_CAP_READWRITE</CODE
+> flag in
+the <CODE
+CLASS="STRUCTFIELD"
+>capabilities</CODE
+> field of struct&nbsp;<A
+HREF="#V4L2-CAPABILITY"
+>v4l2_capability</A
+>
+returned by the <A
+HREF="#VIDIOC-QUERYCAP"
+><CODE
+CLASS="CONSTANT"
+>VIDIOC_QUERYCAP</CODE
+></A
+> ioctl is set.</P
+><P
+>Drivers may need the CPU to copy the data, but they may also
+support DMA to or from user memory, so this I/O method is not
+necessarily less efficient than other methods merely exchanging buffer
+pointers. It is considered inferior though because no meta-information
+like frame counters or timestamps are passed. This information is
+necessary to recognize frame dropping and to synchronize with other
+data streams. However this is also the simplest I/O method, requiring
+little or no setup to exchange data. It permits command line stunts
+like this (the <SPAN
+CLASS="APPLICATION"
+>vidctrl</SPAN
+> tool is
+fictitious):</P
+><DIV
+CLASS="INFORMALEXAMPLE"
+><P
+></P
+><A
+NAME="AEN3266"
+></A
+><PRE
+CLASS="SCREEN"
+>&gt; vidctrl /dev/video --input=0 --format=YUYV --size=352x288
+&gt; dd if=/dev/video of=myimage.422 bs=202752 count=1</PRE
+><P
+></P
+></DIV
+><P
+>To read from the device applications use the
+<A
+HREF="#FUNC-READ"
+><CODE
+CLASS="FUNCTION"
+>read()</CODE
+></A
+> function, to write the <A
+HREF="#FUNC-WRITE"
+><CODE
+CLASS="FUNCTION"
+>write()</CODE
+></A
+> function.
+Drivers must implement one I/O method if they
+exchange data with applications, but it need not be this.<A
+NAME="AEN3273"
+HREF="#FTN.AEN3273"
+><SPAN
+CLASS="footnote"
+>[13]</SPAN
+></A
+> When reading or writing is supported, the driver
+must also support the <A
+HREF="#FUNC-SELECT"
+><CODE
+CLASS="FUNCTION"
+>select()</CODE
+></A
+> and <A
+HREF="#FUNC-POLL"
+><CODE
+CLASS="FUNCTION"
+>poll()</CODE
+></A
+>
+function.<A
+NAME="AEN3279"
+HREF="#FTN.AEN3279"
+><SPAN
+CLASS="footnote"
+>[14]</SPAN
+></A
+></P
+></DIV
+><DIV
+CLASS="SECTION"
+><HR><H2
+CLASS="SECTION"
+><A
+NAME="MMAP"
+>3.2. Streaming I/O (Memory Mapping)</A
+></H2
+><P
+>Input and output devices support this I/O method when the
+<CODE
+CLASS="CONSTANT"
+>V4L2_CAP_STREAMING</CODE
+> flag in the
+<CODE
+CLASS="STRUCTFIELD"
+>capabilities</CODE
+> field of struct&nbsp;<A
+HREF="#V4L2-CAPABILITY"
+>v4l2_capability</A
+>
+returned by the <A
+HREF="#VIDIOC-QUERYCAP"
+><CODE
+CLASS="CONSTANT"
+>VIDIOC_QUERYCAP</CODE
+></A
+> ioctl is set. There are two
+streaming methods, to determine if the memory mapping flavor is
+supported applications must call the <A
+HREF="#VIDIOC-REQBUFS"
+><CODE
+CLASS="CONSTANT"
+>VIDIOC_REQBUFS</CODE
+></A
+> ioctl.</P
+><P
+>Streaming is an I/O method where only pointers to buffers
+are exchanged between application and driver, the data itself is not
+copied. Memory mapping is primarily intended to map buffers in device
+memory into the application's address space. Device memory can be for
+example the video memory on a graphics card with a video capture
+add-on. However, being the most efficient I/O method available for a
+long time, many other drivers support streaming as well, allocating
+buffers in DMA-able main memory.</P
+><P
+>A driver can support many sets of buffers. Each set is
+identified by a unique buffer type value. The sets are independent and
+each set can hold a different type of data. To access different sets
+at the same time different file descriptors must be used.<A
+NAME="AEN3296"
+HREF="#FTN.AEN3296"
+><SPAN
+CLASS="footnote"
+>[15]</SPAN
+></A
+></P
+><P
+>To allocate device buffers applications call the
+<A
+HREF="#VIDIOC-REQBUFS"
+><CODE
+CLASS="CONSTANT"
+>VIDIOC_REQBUFS</CODE
+></A
+> ioctl with the desired number of buffers and buffer
+type, for example <CODE
+CLASS="CONSTANT"
+>V4L2_BUF_TYPE_VIDEO_CAPTURE</CODE
+>.
+This ioctl can also be used to change the number of buffers or to free
+the allocated memory, provided none of the buffers are still
+mapped.</P
+><P
+>Before applications can access the buffers they must map
+them into their address space with the <A
+HREF="#FUNC-MMAP"
+><CODE
+CLASS="FUNCTION"
+>mmap()</CODE
+></A
+> function. The
+location of the buffers in device memory can be determined with the
+<A
+HREF="#VIDIOC-QUERYBUF"
+><CODE
+CLASS="CONSTANT"
+>VIDIOC_QUERYBUF</CODE
+></A
+> ioctl. The <CODE
+CLASS="STRUCTFIELD"
+>m.offset</CODE
+> and
+<CODE
+CLASS="STRUCTFIELD"
+>length</CODE
+> returned in a struct&nbsp;<A
+HREF="#V4L2-BUFFER"
+>v4l2_buffer</A
+> are
+passed as sixth and second parameter to the
+<CODE
+CLASS="FUNCTION"
+>mmap()</CODE
+> function. The offset and length values
+must not be modified. Remember the buffers are allocated in physical
+memory, as opposed to virtual memory which can be swapped out to disk.
+Applications should free the buffers as soon as possible with the
+<A
+HREF="#FUNC-MUNMAP"
+><CODE
+CLASS="FUNCTION"
+>munmap()</CODE
+></A
+> function.</P
+><DIV
+CLASS="EXAMPLE"
+><A
+NAME="AEN3316"
+></A
+><P
+><B
+>Example 3-1. Mapping buffers</B
+></P
+><PRE
+CLASS="PROGRAMLISTING"
+>struct&nbsp;<A
+HREF="#V4L2-REQUESTBUFFERS"
+>v4l2_requestbuffers</A
+> reqbuf;
+struct {
+ void *start;
+ size_t length;
+} *buffers;
+unsigned int i;
+
+memset (&amp;reqbuf, 0, sizeof (reqbuf));
+reqbuf.type = V4L2_BUF_TYPE_VIDEO_CAPTURE;
+reqbuf.memory = V4L2_MEMORY_MMAP;
+reqbuf.count = 20;
+
+if (-1 == ioctl (fd, <A
+HREF="#VIDIOC-REQBUFS"
+><CODE
+CLASS="CONSTANT"
+>VIDIOC_REQBUFS</CODE
+></A
+>, &amp;reqbuf)) {
+ if (errno == EINVAL)
+ printf ("Video capturing or mmap-streaming is not supported\n");
+ else
+ perror ("VIDIOC_REQBUFS");
+
+ exit (EXIT_FAILURE);
+}
+
+/* We want at least five buffers. */
+
+if (reqbuf.count &#60; 5) {
+ /* You may need to free the buffers here. */
+ printf ("Not enough buffer memory\n");
+ exit (EXIT_FAILURE);
+}
+
+buffers = calloc (reqbuf.count, sizeof (*buffers));
+assert (buffers != NULL);
+
+for (i = 0; i &#60; reqbuf.count; i++) {
+ struct&nbsp;<A
+HREF="#V4L2-BUFFER"
+>v4l2_buffer</A
+> buffer;
+
+ memset (&amp;buffer, 0, sizeof (buffer));
+ buffer.type = reqbuf.type;
+ buffer.memory = V4L2_MEMORY_MMAP;
+ buffer.index = i;
+
+ if (-1 == ioctl (fd, <A
+HREF="#VIDIOC-QUERYBUF"
+><CODE
+CLASS="CONSTANT"
+>VIDIOC_QUERYBUF</CODE
+></A
+>, &amp;buffer)) {
+ perror ("VIDIOC_QUERYBUF");
+ exit (EXIT_FAILURE);
+ }
+
+ buffers[i].length = buffer.length; /* remember for munmap() */
+
+ buffers[i].start = mmap (NULL, buffer.length,
+ PROT_READ | PROT_WRITE, /* required */
+ MAP_SHARED, /* recommended */
+ fd, buffer.m.offset);
+
+ if (buffers[i].start == MAP_FAILED) {
+ /* You may need to unmap and free the so far
+ mapped buffers here. */
+ perror ("mmap");
+ exit (EXIT_FAILURE);
+ }
+}
+
+/* Cleanup. */
+
+for (i = 0; i &#60; reqbuf.count; i++)
+ munmap (buffers[i].start, buffers[i].length);
+ </PRE
+></DIV
+><P
+>Streaming drivers maintain two buffer queues, an incoming
+and an outgoing queue. They separate the synchronous capture or output
+operation locked to a video clock from the application which is
+subject to random disk or network delays and preemption by
+other processes, thereby reducing the probability of data loss.
+The queues are organized as FIFOs, buffers will be
+output in the order enqueued in the incoming FIFO, and were
+captured in the order dequeued from the outgoing FIFO.</P
+><P
+>The driver may require a minimum number of buffers enqueued
+at all times to function, apart of this no limit exists on the number
+of buffers applications can enqueue in advance, or dequeue and
+process. They can also enqueue in a different order than buffers have
+been dequeued, and the driver can <SPAN
+CLASS="emphasis"
+><I
+CLASS="EMPHASIS"
+>fill</I
+></SPAN
+> enqueued
+<SPAN
+CLASS="emphasis"
+><I
+CLASS="EMPHASIS"
+>empty</I
+></SPAN
+> buffers in any order. <A
+NAME="AEN3329"
+HREF="#FTN.AEN3329"
+><SPAN
+CLASS="footnote"
+>[16]</SPAN
+></A
+> The index number of a buffer (struct&nbsp;<A
+HREF="#V4L2-BUFFER"
+>v4l2_buffer</A
+>
+<CODE
+CLASS="STRUCTFIELD"
+>index</CODE
+>) plays no role here, it only
+identifies the buffer.</P
+><P
+>Initially all mapped buffers are in dequeued state,
+inaccessible by the driver. For capturing applications it is customary
+to first enqueue all mapped buffers, then to start capturing and enter
+the read loop. Here the application waits until a filled buffer can be
+dequeued, and re-enqueues the buffer when the data is no longer
+needed. Output applications fill and enqueue buffers, when enough
+buffers are stacked up the output is started with
+<CODE
+CLASS="CONSTANT"
+>VIDIOC_STREAMON</CODE
+>. In the write loop, when
+the application runs out of free buffers, it must wait until an empty
+buffer can be dequeued and reused.</P
+><P
+>To enqueue and dequeue a buffer applications use the
+<A
+HREF="#VIDIOC-QBUF"
+><CODE
+CLASS="CONSTANT"
+>VIDIOC_QBUF</CODE
+></A
+> and <A
+HREF="#VIDIOC-QBUF"
+><CODE
+CLASS="CONSTANT"
+>VIDIOC_DQBUF</CODE
+></A
+> ioctl. The status of a buffer being
+mapped, enqueued, full or empty can be determined at any time using the
+<A
+HREF="#VIDIOC-QUERYBUF"
+><CODE
+CLASS="CONSTANT"
+>VIDIOC_QUERYBUF</CODE
+></A
+> ioctl. Two methods exist to suspend execution of the
+application until one or more buffers can be dequeued. By default
+<CODE
+CLASS="CONSTANT"
+>VIDIOC_DQBUF</CODE
+> blocks when no buffer is in the
+outgoing queue. When the <CODE
+CLASS="CONSTANT"
+>O_NONBLOCK</CODE
+> flag was
+given to the <A
+HREF="#FUNC-OPEN"
+><CODE
+CLASS="FUNCTION"
+>open()</CODE
+></A
+> function, <CODE
+CLASS="CONSTANT"
+>VIDIOC_DQBUF</CODE
+>
+returns immediately with an <SPAN
+CLASS="ERRORCODE"
+>EAGAIN</SPAN
+> error code when no buffer is available. The
+<A
+HREF="#FUNC-SELECT"
+><CODE
+CLASS="FUNCTION"
+>select()</CODE
+></A
+> or <A
+HREF="#FUNC-POLL"
+><CODE
+CLASS="FUNCTION"
+>poll()</CODE
+></A
+> function are always available.</P
+><P
+>To start and stop capturing or output applications call the
+<A
+HREF="#VIDIOC-STREAMON"
+><CODE
+CLASS="CONSTANT"
+>VIDIOC_STREAMON</CODE
+></A
+> and <A
+HREF="#VIDIOC-STREAMON"
+><CODE
+CLASS="CONSTANT"
+>VIDIOC_STREAMOFF</CODE
+></A
+> ioctl. Note
+<CODE
+CLASS="CONSTANT"
+>VIDIOC_STREAMOFF</CODE
+> removes all buffers from both
+queues as a side effect. Since there is no notion of doing anything
+"now" on a multitasking system, if an application needs to synchronize
+with another event it should examine the struct&nbsp;<A
+HREF="#V4L2-BUFFER"
+>v4l2_buffer</A
+>
+<CODE
+CLASS="STRUCTFIELD"
+>timestamp</CODE
+> of captured buffers, or set the
+field before enqueuing buffers for output.</P
+><P
+>Drivers implementing memory mapping I/O must
+support the <CODE
+CLASS="CONSTANT"
+>VIDIOC_REQBUFS</CODE
+>,
+<CODE
+CLASS="CONSTANT"
+>VIDIOC_QUERYBUF</CODE
+>,
+<CODE
+CLASS="CONSTANT"
+>VIDIOC_QBUF</CODE
+>, <CODE
+CLASS="CONSTANT"
+>VIDIOC_DQBUF</CODE
+>,
+<CODE
+CLASS="CONSTANT"
+>VIDIOC_STREAMON</CODE
+> and
+<CODE
+CLASS="CONSTANT"
+>VIDIOC_STREAMOFF</CODE
+> ioctl, the
+<CODE
+CLASS="FUNCTION"
+>mmap()</CODE
+>, <CODE
+CLASS="FUNCTION"
+>munmap()</CODE
+>,
+<CODE
+CLASS="FUNCTION"
+>select()</CODE
+> and <CODE
+CLASS="FUNCTION"
+>poll()</CODE
+>
+function.<A
+NAME="AEN3371"
+HREF="#FTN.AEN3371"
+><SPAN
+CLASS="footnote"
+>[17]</SPAN
+></A
+></P
+><P
+>[capture example]</P
+></DIV
+><DIV
+CLASS="SECTION"
+><HR><H2
+CLASS="SECTION"
+><A
+NAME="USERP"
+>3.3. Streaming I/O (User Pointers)</A
+></H2
+><P
+>Input and output devices support this I/O method when the
+<CODE
+CLASS="CONSTANT"
+>V4L2_CAP_STREAMING</CODE
+> flag in the
+<CODE
+CLASS="STRUCTFIELD"
+>capabilities</CODE
+> field of struct&nbsp;<A
+HREF="#V4L2-CAPABILITY"
+>v4l2_capability</A
+>
+returned by the <A
+HREF="#VIDIOC-QUERYCAP"
+><CODE
+CLASS="CONSTANT"
+>VIDIOC_QUERYCAP</CODE
+></A
+> ioctl is set. If the particular user
+pointer method (not only memory mapping) is supported must be
+determined by calling the <A
+HREF="#VIDIOC-REQBUFS"
+><CODE
+CLASS="CONSTANT"
+>VIDIOC_REQBUFS</CODE
+></A
+> ioctl.</P
+><P
+>This I/O method combines advantages of the read/write and
+memory mapping methods. Buffers are allocated by the application
+itself, and can reside for example in virtual or shared memory. Only
+pointers to data are exchanged, these pointers and meta-information
+are passed in struct&nbsp;<A
+HREF="#V4L2-BUFFER"
+>v4l2_buffer</A
+>. The driver must be switched
+into user pointer I/O mode by calling the <A
+HREF="#VIDIOC-REQBUFS"
+><CODE
+CLASS="CONSTANT"
+>VIDIOC_REQBUFS</CODE
+></A
+> with the
+desired buffer type. No buffers are allocated beforehands,
+consequently they are not indexed and cannot be queried like mapped
+buffers with the <CODE
+CLASS="CONSTANT"
+>VIDIOC_QUERYBUF</CODE
+> ioctl.</P
+><DIV
+CLASS="EXAMPLE"
+><A
+NAME="AEN3392"
+></A
+><P
+><B
+>Example 3-2. Initiating streaming I/O with user pointers</B
+></P
+><PRE
+CLASS="PROGRAMLISTING"
+>struct&nbsp;<A
+HREF="#V4L2-REQUESTBUFFERS"
+>v4l2_requestbuffers</A
+> reqbuf;
+
+memset (&amp;reqbuf, 0, sizeof (reqbuf));
+reqbuf.type = V4L2_BUF_TYPE_VIDEO_CAPTURE;
+reqbuf.memory = V4L2_MEMORY_USERPTR;
+
+if (ioctl (fd, <A
+HREF="#VIDIOC-REQBUFS"
+><CODE
+CLASS="CONSTANT"
+>VIDIOC_REQBUFS</CODE
+></A
+>, &amp;reqbuf) == -1) {
+ if (errno == EINVAL)
+ printf ("Video capturing or user pointer streaming is not supported\n");
+ else
+ perror ("VIDIOC_REQBUFS");
+
+ exit (EXIT_FAILURE);
+}
+ </PRE
+></DIV
+><P
+>Buffer addresses and sizes are passed on the fly with the
+<A
+HREF="#VIDIOC-QBUF"
+><CODE
+CLASS="CONSTANT"
+>VIDIOC_QBUF</CODE
+></A
+> ioctl. Although buffers are commonly cycled,
+applications can pass different addresses and sizes at each
+<CODE
+CLASS="CONSTANT"
+>VIDIOC_QBUF</CODE
+> call. If required by the hardware the
+driver swaps memory pages within physical memory to create a
+continuous area of memory. This happens transparently to the
+application in the virtual memory subsystem of the kernel. When buffer
+pages have been swapped out to disk they are brought back and finally
+locked in physical memory for DMA.<A
+NAME="AEN3402"
+HREF="#FTN.AEN3402"
+><SPAN
+CLASS="footnote"
+>[18]</SPAN
+></A
+></P
+><P
+>Filled or displayed buffers are dequeued with the
+<A
+HREF="#VIDIOC-QBUF"
+><CODE
+CLASS="CONSTANT"
+>VIDIOC_DQBUF</CODE
+></A
+> ioctl. The driver can unlock the memory pages at any
+time between the completion of the DMA and this ioctl. The memory is
+also unlocked when <A
+HREF="#VIDIOC-STREAMON"
+><CODE
+CLASS="CONSTANT"
+>VIDIOC_STREAMOFF</CODE
+></A
+> is called, <A
+HREF="#VIDIOC-REQBUFS"
+><CODE
+CLASS="CONSTANT"
+>VIDIOC_REQBUFS</CODE
+></A
+>, or
+when the device is closed. Applications must take care not to free
+buffers without dequeuing. For once, the buffers remain locked until
+further, wasting physical memory. Second the driver will not be
+notified when the memory is returned to the application's free list
+and subsequently reused for other purposes, possibly completing the
+requested DMA and overwriting valuable data.</P
+><P
+>For capturing applications it is customary to enqueue a
+number of empty buffers, to start capturing and enter the read loop.
+Here the application waits until a filled buffer can be dequeued, and
+re-enqueues the buffer when the data is no longer needed. Output
+applications fill and enqueue buffers, when enough buffers are stacked
+up output is started. In the write loop, when the application
+runs out of free buffers it must wait until an empty buffer can be
+dequeued and reused. Two methods exist to suspend execution of the
+application until one or more buffers can be dequeued. By default
+<CODE
+CLASS="CONSTANT"
+>VIDIOC_DQBUF</CODE
+> blocks when no buffer is in the
+outgoing queue. When the <CODE
+CLASS="CONSTANT"
+>O_NONBLOCK</CODE
+> flag was
+given to the <A
+HREF="#FUNC-OPEN"
+><CODE
+CLASS="FUNCTION"
+>open()</CODE
+></A
+> function, <CODE
+CLASS="CONSTANT"
+>VIDIOC_DQBUF</CODE
+>
+returns immediately with an <SPAN
+CLASS="ERRORCODE"
+>EAGAIN</SPAN
+> error code when no buffer is available. The
+<A
+HREF="#FUNC-SELECT"
+><CODE
+CLASS="FUNCTION"
+>select()</CODE
+></A
+> or <A
+HREF="#FUNC-POLL"
+><CODE
+CLASS="FUNCTION"
+>poll()</CODE
+></A
+> function are always available.</P
+><P
+>To start and stop capturing or output applications call the
+<A
+HREF="#VIDIOC-STREAMON"
+><CODE
+CLASS="CONSTANT"
+>VIDIOC_STREAMON</CODE
+></A
+> and <A
+HREF="#VIDIOC-STREAMON"
+><CODE
+CLASS="CONSTANT"
+>VIDIOC_STREAMOFF</CODE
+></A
+> ioctl. Note
+<CODE
+CLASS="CONSTANT"
+>VIDIOC_STREAMOFF</CODE
+> removes all buffers from both
+queues and unlocks all buffers as a side effect. Since there is no
+notion of doing anything "now" on a multitasking system, if an
+application needs to synchronize with another event it should examine
+the struct&nbsp;<A
+HREF="#V4L2-BUFFER"
+>v4l2_buffer</A
+> <CODE
+CLASS="STRUCTFIELD"
+>timestamp</CODE
+> of captured
+buffers, or set the field before enqueuing buffers for output.</P
+><P
+>Drivers implementing user pointer I/O must
+support the <CODE
+CLASS="CONSTANT"
+>VIDIOC_REQBUFS</CODE
+>,
+<CODE
+CLASS="CONSTANT"
+>VIDIOC_QBUF</CODE
+>, <CODE
+CLASS="CONSTANT"
+>VIDIOC_DQBUF</CODE
+>,
+<CODE
+CLASS="CONSTANT"
+>VIDIOC_STREAMON</CODE
+> and
+<CODE
+CLASS="CONSTANT"
+>VIDIOC_STREAMOFF</CODE
+> ioctl, the
+<CODE
+CLASS="FUNCTION"
+>select()</CODE
+> and <CODE
+CLASS="FUNCTION"
+>poll()</CODE
+> function.<A
+NAME="AEN3438"
+HREF="#FTN.AEN3438"
+><SPAN
+CLASS="footnote"
+>[19]</SPAN
+></A
+></P
+></DIV
+><DIV
+CLASS="SECTION"
+><HR><H2
+CLASS="SECTION"
+><A
+NAME="ASYNC"
+>3.4. Asynchronous I/O</A
+></H2
+><P
+>This method is not defined yet.</P
+></DIV
+><DIV
+CLASS="SECTION"
+><HR><H2
+CLASS="SECTION"
+><A
+NAME="BUFFER"
+>3.5. Buffers</A
+></H2
+><P
+>A buffer contains data exchanged by application and
+driver using one of the Streaming I/O methods. Only pointers to
+buffers are exchanged, the data itself is not copied. These pointers,
+together with meta-information like timestamps or field parity, are
+stored in a struct <CODE
+CLASS="STRUCTNAME"
+>v4l2_buffer</CODE
+>, argument to
+the <A
+HREF="#VIDIOC-QUERYBUF"
+><CODE
+CLASS="CONSTANT"
+>VIDIOC_QUERYBUF</CODE
+></A
+>, <A
+HREF="#VIDIOC-QBUF"
+><CODE
+CLASS="CONSTANT"
+>VIDIOC_QBUF</CODE
+></A
+> and <A
+HREF="#VIDIOC-QBUF"
+><CODE
+CLASS="CONSTANT"
+>VIDIOC_DQBUF</CODE
+></A
+> ioctl.</P
+><P
+>Nominally timestamps refer to the first data byte transmitted.
+In practice however the wide range of hardware covered by the V4L2 API
+limits timestamp accuracy. Often an interrupt routine will
+sample the system clock shortly after the field or frame was stored
+completely in memory. So applications must expect a constant
+difference up to one field or frame period plus a small (few scan
+lines) random error. The delay and error can be much
+larger due to compression or transmission over an external bus when
+the frames are not properly stamped by the sender. This is frequently
+the case with USB cameras. Here timestamps refer to the instant the
+field or frame was received by the driver, not the capture time. These
+devices identify by not enumerating any video standards, see <A
+HREF="#STANDARD"
+>Section 1.7</A
+>.</P
+><P
+>Similar limitations apply to output timestamps. Typically
+the video hardware locks to a clock controlling the video timing, the
+horizontal and vertical synchronization pulses. At some point in the
+line sequence, possibly the vertical blanking, an interrupt routine
+samples the system clock, compares against the timestamp and programs
+the hardware to repeat the previous field or frame, or to display the
+buffer contents.</P
+><P
+>Apart of limitations of the video device and natural
+inaccuracies of all clocks, it should be noted system time itself is
+not perfectly stable. It can be affected by power saving cycles,
+warped to insert leap seconds, or even turned back or forth by the
+system administrator affecting long term measurements. <A
+NAME="AEN3460"
+HREF="#FTN.AEN3460"
+><SPAN
+CLASS="footnote"
+>[20]</SPAN
+></A
+></P
+><DIV
+CLASS="TABLE"
+><A
+NAME="V4L2-BUFFER"
+></A
+><P
+><B
+>Table 3-1. struct <CODE
+CLASS="STRUCTNAME"
+>v4l2_buffer</CODE
+></B
+></P
+><TABLE
+BORDER="0"
+FRAME="void"
+WIDTH="100%"
+CLASS="CALSTABLE"
+><COL
+WIDTH="50%"
+TITLE="C1"><COL><COL><COL
+WIDTH="50%"
+TITLE="C4"><TBODY
+><TR
+><TD
+>__u32</TD
+><TD
+><CODE
+CLASS="STRUCTFIELD"
+>index</CODE
+></TD
+><TD
+>&nbsp;</TD
+><TD
+>Number of the buffer, set by the application. This
+field is only used for <A
+HREF="#MMAP"
+>memory mapping</A
+> I/O
+and can range from zero to the number of buffers allocated
+with the <A
+HREF="#VIDIOC-REQBUFS"
+><CODE
+CLASS="CONSTANT"
+>VIDIOC_REQBUFS</CODE
+></A
+> ioctl (struct&nbsp;<A
+HREF="#V4L2-REQUESTBUFFERS"
+>v4l2_requestbuffers</A
+> <CODE
+CLASS="STRUCTFIELD"
+>count</CODE
+>) minus one.</TD
+></TR
+><TR
+><TD
+>enum&nbsp;<A
+HREF="#V4L2-BUF-TYPE"
+>v4l2_buf_type</A
+></TD
+><TD
+><CODE
+CLASS="STRUCTFIELD"
+>type</CODE
+></TD
+><TD
+>&nbsp;</TD
+><TD
+>Type of the buffer, same as struct&nbsp;<A
+HREF="#V4L2-FORMAT"
+>v4l2_format</A
+>
+<CODE
+CLASS="STRUCTFIELD"
+>type</CODE
+> or struct&nbsp;<A
+HREF="#V4L2-REQUESTBUFFERS"
+>v4l2_requestbuffers</A
+>
+<CODE
+CLASS="STRUCTFIELD"
+>type</CODE
+>, set by the application.</TD
+></TR
+><TR
+><TD
+>__u32</TD
+><TD
+><CODE
+CLASS="STRUCTFIELD"
+>bytesused</CODE
+></TD
+><TD
+>&nbsp;</TD
+><TD
+>The number of bytes occupied by the data in the
+buffer. It depends on the negotiated data format and may change with
+each buffer for compressed variable size data like JPEG images.
+Drivers must set this field when <CODE
+CLASS="STRUCTFIELD"
+>type</CODE
+>
+refers to an input stream, applications when an output stream.</TD
+></TR
+><TR
+><TD
+>__u32</TD
+><TD
+><CODE
+CLASS="STRUCTFIELD"
+>flags</CODE
+></TD
+><TD
+>&nbsp;</TD
+><TD
+>Flags set by the application or driver, see <A
+HREF="#BUFFER-FLAGS"
+>Table 3-3</A
+>.</TD
+></TR
+><TR
+><TD
+>enum&nbsp;<A
+HREF="#V4L2-FIELD"
+>v4l2_field</A
+></TD
+><TD
+><CODE
+CLASS="STRUCTFIELD"
+>field</CODE
+></TD
+><TD
+>&nbsp;</TD
+><TD
+>Indicates the field order of the image in the
+buffer, see <A
+HREF="#V4L2-FIELD"
+>Table 3-8</A
+>. This field is not used when
+the buffer contains VBI data. Drivers must set it when
+<CODE
+CLASS="STRUCTFIELD"
+>type</CODE
+> refers to an input stream,
+applications when an output stream.</TD
+></TR
+><TR
+><TD
+>struct timeval</TD
+><TD
+><CODE
+CLASS="STRUCTFIELD"
+>timestamp</CODE
+></TD
+><TD
+>&nbsp;</TD
+><TD
+><P
+>For input streams this is the
+system time (as returned by the <CODE
+CLASS="FUNCTION"
+>gettimeofday()</CODE
+>
+function) when the first data byte was captured. For output streams
+the data will not be displayed before this time, secondary to the
+nominal frame rate determined by the current video standard in
+enqueued order. Applications can for example zero this field to
+display frames as soon as possible. The driver stores the time at
+which the first data byte was actually sent out in the
+<CODE
+CLASS="STRUCTFIELD"
+>timestamp</CODE
+> field. This permits
+applications to monitor the drift between the video and system
+clock.</P
+></TD
+></TR
+><TR
+><TD
+>struct&nbsp;<A
+HREF="#V4L2-TIMECODE"
+>v4l2_timecode</A
+></TD
+><TD
+><CODE
+CLASS="STRUCTFIELD"
+>timecode</CODE
+></TD
+><TD
+>&nbsp;</TD
+><TD
+>When <CODE
+CLASS="STRUCTFIELD"
+>type</CODE
+> is
+<CODE
+CLASS="CONSTANT"
+>V4L2_BUF_TYPE_VIDEO_CAPTURE</CODE
+> and the
+<CODE
+CLASS="CONSTANT"
+>V4L2_BUF_FLAG_TIMECODE</CODE
+> flag is set in
+<CODE
+CLASS="STRUCTFIELD"
+>flags</CODE
+>, this structure contains a frame
+timecode. In <A
+HREF="#V4L2-FIELD"
+>V4L2_FIELD_ALTERNATE</A
+>
+mode the top and bottom field contain the same timecode.
+Timecodes are intended to help video editing and are typically recorded on
+video tapes, but also embedded in compressed formats like MPEG. This
+field is independent of the <CODE
+CLASS="STRUCTFIELD"
+>timestamp</CODE
+> and
+<CODE
+CLASS="STRUCTFIELD"
+>sequence</CODE
+> fields.</TD
+></TR
+><TR
+><TD
+>__u32</TD
+><TD
+><CODE
+CLASS="STRUCTFIELD"
+>sequence</CODE
+></TD
+><TD
+>&nbsp;</TD
+><TD
+>Set by the driver, counting the frames in the
+sequence.</TD
+></TR
+><TR
+><TD
+COLSPAN="4"
+><P
+>In <A
+HREF="#V4L2-FIELD"
+>V4L2_FIELD_ALTERNATE</A
+> mode the top and
+bottom field have the same sequence number. The count starts at zero
+and includes dropped or repeated frames. A dropped frame was received
+by an input device but could not be stored due to lack of free buffer
+space. A repeated frame was displayed again by an output device
+because the application did not pass new data in
+time.</P
+><P
+>Note this may count the frames received
+e.g. over USB, without taking into account the frames dropped by the
+remote hardware due to limited compression throughput or bus
+bandwidth. These devices identify by not enumerating any video
+standards, see <A
+HREF="#STANDARD"
+>Section 1.7</A
+>.</P
+></TD
+></TR
+><TR
+><TD
+>enum&nbsp;<A
+HREF="#V4L2-MEMORY"
+>v4l2_memory</A
+></TD
+><TD
+><CODE
+CLASS="STRUCTFIELD"
+>memory</CODE
+></TD
+><TD
+>&nbsp;</TD
+><TD
+>This field must be set by applications and/or drivers
+in accordance with the selected I/O method.</TD
+></TR
+><TR
+><TD
+>union</TD
+><TD
+><CODE
+CLASS="STRUCTFIELD"
+>m</CODE
+></TD
+><TD
+>&nbsp;</TD
+><TD
+>&nbsp;</TD
+></TR
+><TR
+><TD
+>&nbsp;</TD
+><TD
+>__u32</TD
+><TD
+><CODE
+CLASS="STRUCTFIELD"
+>offset</CODE
+></TD
+><TD
+>When <CODE
+CLASS="STRUCTFIELD"
+>memory</CODE
+> is
+<CODE
+CLASS="CONSTANT"
+>V4L2_MEMORY_MMAP</CODE
+> this is the offset of the buffer
+from the start of the device memory. The value is returned by the
+driver and apart of serving as parameter to the <A
+HREF="#FUNC-MMAP"
+><CODE
+CLASS="FUNCTION"
+>mmap()</CODE
+></A
+> function
+not useful for applications. See <A
+HREF="#MMAP"
+>Section 3.2</A
+> for details.</TD
+></TR
+><TR
+><TD
+>&nbsp;</TD
+><TD
+>unsigned long</TD
+><TD
+><CODE
+CLASS="STRUCTFIELD"
+>userptr</CODE
+></TD
+><TD
+>When <CODE
+CLASS="STRUCTFIELD"
+>memory</CODE
+> is
+<CODE
+CLASS="CONSTANT"
+>V4L2_MEMORY_USERPTR</CODE
+> this is a pointer to the
+buffer (casted to unsigned long type) in virtual memory, set by the
+application. See <A
+HREF="#USERP"
+>Section 3.3</A
+> for details.</TD
+></TR
+><TR
+><TD
+>__u32</TD
+><TD
+><CODE
+CLASS="STRUCTFIELD"
+>length</CODE
+></TD
+><TD
+>&nbsp;</TD
+><TD
+>Size of the buffer (not the payload) in bytes.</TD
+></TR
+><TR
+><TD
+>__u32</TD
+><TD
+><CODE
+CLASS="STRUCTFIELD"
+>input</CODE
+></TD
+><TD
+>&nbsp;</TD
+><TD
+>Some video capture drivers support rapid and
+synchronous video input changes, a function useful for example in
+video surveillance applications. For this purpose applications set the
+<CODE
+CLASS="CONSTANT"
+>V4L2_BUF_FLAG_INPUT</CODE
+> flag, and this field to the
+number of a video input as in struct&nbsp;<A
+HREF="#V4L2-INPUT"
+>v4l2_input</A
+> field
+<CODE
+CLASS="STRUCTFIELD"
+>index</CODE
+>.</TD
+></TR
+><TR
+><TD
+>__u32</TD
+><TD
+><CODE
+CLASS="STRUCTFIELD"
+>reserved</CODE
+></TD
+><TD
+>&nbsp;</TD
+><TD
+>A place holder for future extensions and custom
+(driver defined) buffer types
+<CODE
+CLASS="CONSTANT"
+>V4L2_BUF_TYPE_PRIVATE</CODE
+> and higher.</TD
+></TR
+></TBODY
+></TABLE
+></DIV
+><DIV
+CLASS="TABLE"
+><A
+NAME="V4L2-BUF-TYPE"
+></A
+><P
+><B
+>Table 3-2. enum v4l2_buf_type</B
+></P
+><TABLE
+BORDER="0"
+FRAME="void"
+WIDTH="100%"
+CLASS="CALSTABLE"
+><COL
+WIDTH="38%"
+TITLE="C1"><COL
+WIDTH="12%"
+TITLE="C2"><COL
+WIDTH="50%"
+TITLE="C3"><TBODY
+><TR
+><TD
+><CODE
+CLASS="CONSTANT"
+>V4L2_BUF_TYPE_VIDEO_CAPTURE</CODE
+></TD
+><TD
+>1</TD
+><TD
+>Buffer of a video capture stream, see <A
+HREF="#CAPTURE"
+>Section 4.1</A
+>.</TD
+></TR
+><TR
+><TD
+><CODE
+CLASS="CONSTANT"
+>V4L2_BUF_TYPE_VIDEO_OUTPUT</CODE
+></TD
+><TD
+>2</TD
+><TD
+>Buffer of a video output stream, see <A
+HREF="#OUTPUT"
+>Section 4.3</A
+>.</TD
+></TR
+><TR
+><TD
+><CODE
+CLASS="CONSTANT"
+>V4L2_BUF_TYPE_VIDEO_OVERLAY</CODE
+></TD
+><TD
+>3</TD
+><TD
+>Buffer for video overlay, see <A
+HREF="#OVERLAY"
+>Section 4.2</A
+>.</TD
+></TR
+><TR
+><TD
+><CODE
+CLASS="CONSTANT"
+>V4L2_BUF_TYPE_VBI_CAPTURE</CODE
+></TD
+><TD
+>4</TD
+><TD
+>Buffer of a raw VBI capture stream, see <A
+HREF="#RAW-VBI"
+>Section 4.6</A
+>.</TD
+></TR
+><TR
+><TD
+><CODE
+CLASS="CONSTANT"
+>V4L2_BUF_TYPE_VBI_OUTPUT</CODE
+></TD
+><TD
+>5</TD
+><TD
+>Buffer of a raw VBI output stream, see <A
+HREF="#RAW-VBI"
+>Section 4.6</A
+>.</TD
+></TR
+><TR
+><TD
+><CODE
+CLASS="CONSTANT"
+>V4L2_BUF_TYPE_PRIVATE</CODE
+></TD
+><TD
+>0x80</TD
+><TD
+>This and higher values are reserved for custom
+(driver defined) buffer types.</TD
+></TR
+></TBODY
+></TABLE
+></DIV
+><DIV
+CLASS="TABLE"
+><A
+NAME="BUFFER-FLAGS"
+></A
+><P
+><B
+>Table 3-3. Buffer Flags</B
+></P
+><TABLE
+BORDER="0"
+FRAME="void"
+WIDTH="100%"
+CLASS="CALSTABLE"
+><COL
+WIDTH="38%"
+TITLE="C1"><COL
+WIDTH="12%"
+TITLE="C2"><COL
+WIDTH="50%"
+TITLE="C3"><TBODY
+><TR
+><TD
+><CODE
+CLASS="CONSTANT"
+>V4L2_BUF_FLAG_MAPPED</CODE
+></TD
+><TD
+>0x0001</TD
+><TD
+>The buffer resides in device memory and has been mapped
+into the application's address space, see <A
+HREF="#MMAP"
+>Section 3.2</A
+> for details.
+Drivers set or clear this flag when the
+<A
+HREF="#VIDIOC-QUERYBUF"
+>VIDIOC_QUERYBUF</A
+>, <A
+HREF="#VIDIOC-QBUF"
+>VIDIOC_QBUF</A
+> or <A
+HREF="#VIDIOC-QBUF"
+>VIDIOC_DQBUF</A
+> ioctl is called. Set by the driver.</TD
+></TR
+><TR
+><TD
+><CODE
+CLASS="CONSTANT"
+>V4L2_BUF_FLAG_QUEUED</CODE
+></TD
+><TD
+>0x0002</TD
+><TD
+>Internally drivers maintain two buffer queues, an
+incoming and outgoing queue. When this flag is set, the buffer is
+currently on the incoming queue. It automatically moves to the
+outgoing queue after the buffer has been filled (capture devices) or
+displayed (output devices). Drivers set or clear this flag when the
+<CODE
+CLASS="CONSTANT"
+>VIDIOC_QUERYBUF</CODE
+> ioctl is called. After
+(successful) calling the <CODE
+CLASS="CONSTANT"
+>VIDIOC_QBUF </CODE
+>ioctl it is
+always set and after <CODE
+CLASS="CONSTANT"
+>VIDIOC_DQBUF</CODE
+> always
+cleared.</TD
+></TR
+><TR
+><TD
+><CODE
+CLASS="CONSTANT"
+>V4L2_BUF_FLAG_DONE</CODE
+></TD
+><TD
+>0x0004</TD
+><TD
+>When this flag is set, the buffer is currently on
+the outgoing queue, ready to be dequeued from the driver. Drivers set
+or clear this flag when the <CODE
+CLASS="CONSTANT"
+>VIDIOC_QUERYBUF</CODE
+> ioctl
+is called. After calling the <CODE
+CLASS="CONSTANT"
+>VIDIOC_QBUF</CODE
+> or
+<CODE
+CLASS="CONSTANT"
+>VIDIOC_DQBUF</CODE
+> it is always cleared. Of course a
+buffer cannot be on both queues at the same time, the
+<CODE
+CLASS="CONSTANT"
+>V4L2_BUF_FLAG_QUEUED</CODE
+> and
+<CODE
+CLASS="CONSTANT"
+>V4L2_BUF_FLAG_DONE</CODE
+> flag are mutually exclusive.
+They can be both cleared however, then the buffer is in "dequeued"
+state, in the application domain to say so.</TD
+></TR
+><TR
+><TD
+><CODE
+CLASS="CONSTANT"
+>V4L2_BUF_FLAG_KEYFRAME</CODE
+></TD
+><TD
+>0x0008</TD
+><TD
+>Drivers set or clear this flag when calling the
+<CODE
+CLASS="CONSTANT"
+>VIDIOC_DQBUF</CODE
+> ioctl. It may be set by video
+capture devices when the buffer contains a compressed image which is a
+key frame (or field), i.e. can be decompressed on its own.</TD
+></TR
+><TR
+><TD
+><CODE
+CLASS="CONSTANT"
+>V4L2_BUF_FLAG_PFRAME</CODE
+></TD
+><TD
+>0x0010</TD
+><TD
+>Similar to <CODE
+CLASS="CONSTANT"
+>V4L2_BUF_FLAG_KEYFRAME</CODE
+>
+this flags predicted frames or fields which contain only differences to a
+previous key frame.</TD
+></TR
+><TR
+><TD
+><CODE
+CLASS="CONSTANT"
+>V4L2_BUF_FLAG_BFRAME</CODE
+></TD
+><TD
+>0x0020</TD
+><TD
+>Similar to <CODE
+CLASS="CONSTANT"
+>V4L2_BUF_FLAG_PFRAME</CODE
+>
+ this is a bidirectional predicted frame or field. [ooc tbd]</TD
+></TR
+><TR
+><TD
+><CODE
+CLASS="CONSTANT"
+>V4L2_BUF_FLAG_TIMECODE</CODE
+></TD
+><TD
+>0x0100</TD
+><TD
+>The <CODE
+CLASS="STRUCTFIELD"
+>timecode</CODE
+> field is valid.
+Drivers set or clear this flag when the <CODE
+CLASS="CONSTANT"
+>VIDIOC_DQBUF</CODE
+>
+ioctl is called.</TD
+></TR
+><TR
+><TD
+><CODE
+CLASS="CONSTANT"
+>V4L2_BUF_FLAG_INPUT</CODE
+></TD
+><TD
+>0x0200</TD
+><TD
+>The <CODE
+CLASS="STRUCTFIELD"
+>input</CODE
+> field is valid.
+Applications set or clear this flag before calling the
+<CODE
+CLASS="CONSTANT"
+>VIDIOC_QBUF</CODE
+> ioctl.</TD
+></TR
+></TBODY
+></TABLE
+></DIV
+><DIV
+CLASS="TABLE"
+><A
+NAME="V4L2-MEMORY"
+></A
+><P
+><B
+>Table 3-4. enum v4l2_memory</B
+></P
+><TABLE
+BORDER="0"
+FRAME="void"
+WIDTH="100%"
+CLASS="CALSTABLE"
+><COL
+WIDTH="38%"
+TITLE="C1"><COL
+WIDTH="12%"
+TITLE="C2"><COL
+WIDTH="50%"
+TITLE="C3"><TBODY
+><TR
+><TD
+><CODE
+CLASS="CONSTANT"
+>V4L2_MEMORY_MMAP</CODE
+></TD
+><TD
+>1</TD
+><TD
+>The buffer is used for <A
+HREF="#MMAP"
+>memory
+mapping</A
+> I/O.</TD
+></TR
+><TR
+><TD
+><CODE
+CLASS="CONSTANT"
+>V4L2_MEMORY_USERPTR</CODE
+></TD
+><TD
+>2</TD
+><TD
+>The buffer is used for <A
+HREF="#USERP"
+>user
+pointer</A
+> I/O.</TD
+></TR
+><TR
+><TD
+><CODE
+CLASS="CONSTANT"
+>V4L2_MEMORY_OVERLAY</CODE
+></TD
+><TD
+>3</TD
+><TD
+>[to do]</TD
+></TR
+></TBODY
+></TABLE
+></DIV
+><DIV
+CLASS="SECTION"
+><HR><H3
+CLASS="SECTION"
+><A
+NAME="AEN3738"
+>3.5.1. Timecodes</A
+></H3
+><P
+>The <CODE
+CLASS="STRUCTNAME"
+>v4l2_timecode</CODE
+> structure is
+designed to hold a <A
+HREF="#SMPTE12M"
+><ABBR
+CLASS="ABBREV"
+>SMPTE12M</ABBR
+></A
+> or similar timecode.
+(struct <CODE
+CLASS="STRUCTNAME"
+>timeval</CODE
+> timestamps are stored in
+struct&nbsp;<A
+HREF="#V4L2-BUFFER"
+>v4l2_buffer</A
+> field <CODE
+CLASS="STRUCTFIELD"
+>timestamp</CODE
+>.)</P
+><DIV
+CLASS="TABLE"
+><A
+NAME="V4L2-TIMECODE"
+></A
+><P
+><B
+>Table 3-5. struct <CODE
+CLASS="STRUCTNAME"
+>v4l2_timecode</CODE
+></B
+></P
+><TABLE
+BORDER="0"
+FRAME="void"
+WIDTH="100%"
+CLASS="CALSTABLE"
+><COL
+WIDTH="25%"
+TITLE="C1"><COL
+WIDTH="25%"
+TITLE="C2"><COL
+WIDTH="50%"
+TITLE="C3"><TBODY
+><TR
+><TD
+>__u32</TD
+><TD
+><CODE
+CLASS="STRUCTFIELD"
+>type</CODE
+></TD
+><TD
+>Frame rate the timecodes are based on, see <A
+HREF="#TIMECODE-TYPE"
+>Table 3-6</A
+>.</TD
+></TR
+><TR
+><TD
+>__u32</TD
+><TD
+><CODE
+CLASS="STRUCTFIELD"
+>flags</CODE
+></TD
+><TD
+>Timecode flags, see <A
+HREF="#TIMECODE-FLAGS"
+>Table 3-7</A
+>.</TD
+></TR
+><TR
+><TD
+>__u8</TD
+><TD
+><CODE
+CLASS="STRUCTFIELD"
+>frames</CODE
+></TD
+><TD
+>Frame count, 0 ... 23/24/29/49/59, depending on the
+ type of timecode.</TD
+></TR
+><TR
+><TD
+>__u8</TD
+><TD
+><CODE
+CLASS="STRUCTFIELD"
+>seconds</CODE
+></TD
+><TD
+>Seconds count, 0 ... 59. This is a binary, not BCD number.</TD
+></TR
+><TR
+><TD
+>__u8</TD
+><TD
+><CODE
+CLASS="STRUCTFIELD"
+>minutes</CODE
+></TD
+><TD
+>Minutes count, 0 ... 59. This is a binary, not BCD number.</TD
+></TR
+><TR
+><TD
+>__u8</TD
+><TD
+><CODE
+CLASS="STRUCTFIELD"
+>hours</CODE
+></TD
+><TD
+>Hours count, 0 ... 29. This is a binary, not BCD number.</TD
+></TR
+><TR
+><TD
+>__u8</TD
+><TD
+><CODE
+CLASS="STRUCTFIELD"
+>userbits</CODE
+>[4]</TD
+><TD
+>The "user group" bits from the timecode.</TD
+></TR
+></TBODY
+></TABLE
+></DIV
+><DIV
+CLASS="TABLE"
+><A
+NAME="TIMECODE-TYPE"
+></A
+><P
+><B
+>Table 3-6. Timecode Types</B
+></P
+><TABLE
+BORDER="0"
+FRAME="void"
+WIDTH="100%"
+CLASS="CALSTABLE"
+><COL
+WIDTH="38%"
+TITLE="C1"><COL
+WIDTH="12%"
+TITLE="C2"><COL
+WIDTH="50%"
+TITLE="C3"><TBODY
+><TR
+><TD
+><CODE
+CLASS="CONSTANT"
+>V4L2_TC_TYPE_24FPS</CODE
+></TD
+><TD
+>1</TD
+><TD
+>24 frames per second, i.&nbsp;e. film.</TD
+></TR
+><TR
+><TD
+><CODE
+CLASS="CONSTANT"
+>V4L2_TC_TYPE_25FPS</CODE
+></TD
+><TD
+>2</TD
+><TD
+>25 frames per second, i.e. PAL or SECAM video.</TD
+></TR
+><TR
+><TD
+><CODE
+CLASS="CONSTANT"
+>V4L2_TC_TYPE_30FPS</CODE
+></TD
+><TD
+>3</TD
+><TD
+>30 frames per second, i.e. NTSC video.</TD
+></TR
+><TR
+><TD
+><CODE
+CLASS="CONSTANT"
+>V4L2_TC_TYPE_50FPS</CODE
+></TD
+><TD
+>4</TD
+><TD
+>&nbsp;</TD
+></TR
+><TR
+><TD
+><CODE
+CLASS="CONSTANT"
+>V4L2_TC_TYPE_60FPS</CODE
+></TD
+><TD
+>5</TD
+><TD
+>&nbsp;</TD
+></TR
+></TBODY
+></TABLE
+></DIV
+><DIV
+CLASS="TABLE"
+><A
+NAME="TIMECODE-FLAGS"
+></A
+><P
+><B
+>Table 3-7. Timecode Flags</B
+></P
+><TABLE
+BORDER="0"
+FRAME="void"
+WIDTH="100%"
+CLASS="CALSTABLE"
+><COL
+WIDTH="38%"
+TITLE="C1"><COL
+WIDTH="12%"
+TITLE="C2"><COL
+WIDTH="50%"
+TITLE="C3"><TBODY
+><TR
+><TD
+><CODE
+CLASS="CONSTANT"
+>V4L2_TC_FLAG_DROPFRAME</CODE
+></TD
+><TD
+>0x0001</TD
+><TD
+>Indicates "drop frame" semantics for counting frames
+in 29.97 fps material. When set, frame numbers 0 and 1 at the start of
+each minute, except minutes 0, 10, 20, 30, 40, 50 are omitted from the
+count.</TD
+></TR
+><TR
+><TD
+><CODE
+CLASS="CONSTANT"
+>V4L2_TC_FLAG_COLORFRAME</CODE
+></TD
+><TD
+>0x0002</TD
+><TD
+>The "color frame" flag.</TD
+></TR
+><TR
+><TD
+><CODE
+CLASS="CONSTANT"
+>V4L2_TC_USERBITS_field</CODE
+></TD
+><TD
+>0x000C</TD
+><TD
+>Field mask for the "binary group flags".</TD
+></TR
+><TR
+><TD
+><CODE
+CLASS="CONSTANT"
+>V4L2_TC_USERBITS_USERDEFINED</CODE
+></TD
+><TD
+>0x0000</TD
+><TD
+>Unspecified format.</TD
+></TR
+><TR
+><TD
+><CODE
+CLASS="CONSTANT"
+>V4L2_TC_USERBITS_8BITCHARS</CODE
+></TD
+><TD
+>0x0008</TD
+><TD
+>8-bit ISO characters.</TD
+></TR
+></TBODY
+></TABLE
+></DIV
+></DIV
+></DIV
+><DIV
+CLASS="SECTION"
+><HR><H2
+CLASS="SECTION"
+><A
+NAME="FIELD-ORDER"
+>3.6. Field Order</A
+></H2
+><P
+>We have to distinguish between progressive and interlaced
+video. Progressive video transmits all lines of a video image
+sequentially. Interlaced video divides an image into two fields,
+containing only the odd and even lines of the image, respectively.
+Alternating the so called odd and even field are transmitted, and due
+to a small delay between fields a cathode ray TV displays the lines
+interleaved, yielding the original frame. This curious technique was
+invented because at refresh rates similar to film the image would
+fade out too quickly. Transmitting fields reduces the flicker without
+the necessity of doubling the frame rate and with it the bandwidth
+required for each channel.</P
+><P
+>It is important to understand a video camera does not expose
+one frame at a time, merely transmitting the frames separated into
+fields. The fields are in fact captured at two different instances in
+time. An object on screen may well move between one field and the
+next. For applications analysing motion it is of paramount importance
+to recognize which field of a frame is older, the <SPAN
+CLASS="emphasis"
+><I
+CLASS="EMPHASIS"
+>temporal
+order</I
+></SPAN
+>.</P
+><P
+>When the driver provides or accepts images field by field
+rather than interleaved, it is also important applications understand
+how the fields combine to frames. We distinguish between top and
+bottom fields, the <SPAN
+CLASS="emphasis"
+><I
+CLASS="EMPHASIS"
+>spatial order</I
+></SPAN
+>: The first line
+of the top field is the first line of an interlaced frame, the first
+line of the bottom field is the second line of that frame.</P
+><P
+>However because fields were captured one after the other,
+arguing whether a frame commences with the top or bottom field is
+pointless. Any two successive top and bottom, or bottom and top fields
+yield a valid frame. Only when the source was progressive to begin
+with, e.&nbsp;g. when transferring film to video, two fields may come from
+the same frame, creating a natural order.</P
+><P
+>Counter to intuition the top field is not necessarily the
+older field. Whether the older field contains the top or bottom lines
+is a convention determined by the video standard. Hence the
+distinction between temporal and spatial order of fields. The diagrams
+below should make this clearer.</P
+><P
+>All video capture and output devices must report the current
+field order. Some drivers may permit the selection of a different
+order, to this end applications initialize the
+<CODE
+CLASS="STRUCTFIELD"
+>field</CODE
+> field of struct&nbsp;<A
+HREF="#V4L2-PIX-FORMAT"
+>v4l2_pix_format</A
+> before
+calling the <A
+HREF="#VIDIOC-G-FMT"
+><CODE
+CLASS="CONSTANT"
+>VIDIOC_S_FMT</CODE
+></A
+> ioctl. If this is not desired it should
+have the value <CODE
+CLASS="CONSTANT"
+>V4L2_FIELD_ANY</CODE
+> (0).</P
+><DIV
+CLASS="TABLE"
+><A
+NAME="V4L2-FIELD"
+></A
+><P
+><B
+>Table 3-8. enum v4l2_field</B
+></P
+><TABLE
+BORDER="0"
+FRAME="void"
+WIDTH="100%"
+CLASS="CALSTABLE"
+><COL
+WIDTH="38%"
+TITLE="C1"><COL
+WIDTH="12%"
+TITLE="C2"><COL
+WIDTH="50%"
+TITLE="C3"><TBODY
+><TR
+><TD
+><CODE
+CLASS="CONSTANT"
+>V4L2_FIELD_ANY</CODE
+></TD
+><TD
+>0</TD
+><TD
+>Applications request this field order when any
+one of the <CODE
+CLASS="CONSTANT"
+>V4L2_FIELD_NONE</CODE
+>,
+<CODE
+CLASS="CONSTANT"
+>V4L2_FIELD_TOP</CODE
+>,
+<CODE
+CLASS="CONSTANT"
+>V4L2_FIELD_BOTTOM</CODE
+>, or
+<CODE
+CLASS="CONSTANT"
+>V4L2_FIELD_INTERLACED</CODE
+> formats is acceptable.
+Drivers choose depending on hardware capabilities or e.&nbsp;g. the
+requested image size, and return the actual field order. struct&nbsp;<A
+HREF="#V4L2-BUFFER"
+>v4l2_buffer</A
+>
+<CODE
+CLASS="STRUCTFIELD"
+>field</CODE
+> can never be
+<CODE
+CLASS="CONSTANT"
+>V4L2_FIELD_ANY</CODE
+>.</TD
+></TR
+><TR
+><TD
+><CODE
+CLASS="CONSTANT"
+>V4L2_FIELD_NONE</CODE
+></TD
+><TD
+>1</TD
+><TD
+>Images are in progressive format, not interlaced.
+The driver may also indicate this order when it cannot distinguish
+between <CODE
+CLASS="CONSTANT"
+>V4L2_FIELD_TOP</CODE
+> and
+<CODE
+CLASS="CONSTANT"
+>V4L2_FIELD_BOTTOM</CODE
+>.</TD
+></TR
+><TR
+><TD
+><CODE
+CLASS="CONSTANT"
+>V4L2_FIELD_TOP</CODE
+></TD
+><TD
+>2</TD
+><TD
+>Images consist of the top field only.</TD
+></TR
+><TR
+><TD
+><CODE
+CLASS="CONSTANT"
+>V4L2_FIELD_BOTTOM</CODE
+></TD
+><TD
+>3</TD
+><TD
+>Images consist of the bottom field only.
+Applications may wish to prevent a device from capturing interlaced
+images because they will have "comb" or "feathering" artefacts around
+moving objects.</TD
+></TR
+><TR
+><TD
+><CODE
+CLASS="CONSTANT"
+>V4L2_FIELD_INTERLACED</CODE
+></TD
+><TD
+>4</TD
+><TD
+>Images contain both fields, interleaved line by
+line. The temporal order of the fields (whether the top or bottom
+field is first transmitted) depends on the current video standard.
+M/NTSC transmits the bottom field first, all other standards the top
+field first.</TD
+></TR
+><TR
+><TD
+><CODE
+CLASS="CONSTANT"
+>V4L2_FIELD_SEQ_TB</CODE
+></TD
+><TD
+>5</TD
+><TD
+>Images contain both fields, the top field lines
+are stored first in memory, immediately followed by the bottom field
+lines. Fields are always stored in temporal order, the older one first
+in memory. Image sizes refer to the frame, not fields.</TD
+></TR
+><TR
+><TD
+><CODE
+CLASS="CONSTANT"
+>V4L2_FIELD_SEQ_BT</CODE
+></TD
+><TD
+>6</TD
+><TD
+>Images contain both fields, the bottom field
+lines are stored first in memory, immediately followed by the top
+field lines. Fields are always stored in temporal order, the older one
+first in memory. Image sizes refer to the frame, not fields.</TD
+></TR
+><TR
+><TD
+><CODE
+CLASS="CONSTANT"
+>V4L2_FIELD_ALTERNATE</CODE
+></TD
+><TD
+>7</TD
+><TD
+>The two fields of a frame are passed in separate
+buffers, in temporal order, i.&nbsp;e. the older one first. To indicate the field
+parity (whether the current field is a top or bottom field) the driver
+or application, depending on data direction, must set struct&nbsp;<A
+HREF="#V4L2-BUFFER"
+>v4l2_buffer</A
+>
+<CODE
+CLASS="STRUCTFIELD"
+>field</CODE
+> to
+<CODE
+CLASS="CONSTANT"
+>V4L2_FIELD_TOP</CODE
+> or
+<CODE
+CLASS="CONSTANT"
+>V4L2_FIELD_BOTTOM</CODE
+>. Any two successive fields pair
+to build a frame. If fields are successive, without any dropped fields
+between them (fields can drop individually), can be determined from
+the struct&nbsp;<A
+HREF="#V4L2-BUFFER"
+>v4l2_buffer</A
+> <CODE
+CLASS="STRUCTFIELD"
+>sequence</CODE
+> field. Image
+sizes refer to the frame, not fields. This format cannot be selected
+when using the read/write I/O method.</TD
+></TR
+></TBODY
+></TABLE
+></DIV
+><DIV
+CLASS="FIGURE"
+><A
+NAME="FIELDSEQ-TB"
+></A
+><P
+><B
+>Figure 3-1. Field Order, Top Field First Transmitted</B
+></P
+><DIV
+CLASS="MEDIAOBJECT"
+><P
+><IMG
+SRC="fieldseq_tb.gif"></P
+></DIV
+></DIV
+><DIV
+CLASS="FIGURE"
+><A
+NAME="FIELDSEQ-BT"
+></A
+><P
+><B
+>Figure 3-2. Field Order, Bottom Field First Transmitted</B
+></P
+><DIV
+CLASS="MEDIAOBJECT"
+><P
+><IMG
+SRC="fieldseq_bt.gif"></P
+></DIV
+></DIV
+></DIV
+></DIV
+><DIV
+CLASS="CHAPTER"
+><HR><H1
+><A
+NAME="DEVICES"
+></A
+>Chapter 4. Device Types</H1
+><DIV
+CLASS="SECTION"
+><H2
+CLASS="SECTION"
+><A
+NAME="CAPTURE"
+>4.1. Video Capture Interface</A
+></H2
+><P
+>Video capture devices sample an analog video signal and store
+the digitized images in memory. Today nearly all devices can capture
+at full 25 or 30 frames/second. With this interface applications can
+control the capture process and move images from the driver into user
+space.</P
+><P
+>Conventionally V4L2 video capture devices are accessed through
+character device special files named <TT
+CLASS="FILENAME"
+>/dev/video</TT
+>
+and <TT
+CLASS="FILENAME"
+>/dev/video0</TT
+> to
+<TT
+CLASS="FILENAME"
+>/dev/video63</TT
+> with major number 81 and minor
+numbers 0 to 63. <TT
+CLASS="FILENAME"
+>/dev/video</TT
+> is typically a
+symbolic link to the preferred video capture device.</P
+><DIV
+CLASS="SECTION"
+><HR><H3
+CLASS="SECTION"
+><A
+NAME="AEN3960"
+>4.1.1. Querying Capabilities</A
+></H3
+><P
+>Devices supporting the video capture interface set the
+<CODE
+CLASS="CONSTANT"
+>V4L2_CAP_VIDEO_CAPTURE</CODE
+> flag in the
+<CODE
+CLASS="STRUCTFIELD"
+>capabilities</CODE
+> field of struct&nbsp;<A
+HREF="#V4L2-CAPABILITY"
+>v4l2_capability</A
+>
+returned by the <A
+HREF="#VIDIOC-QUERYCAP"
+><CODE
+CLASS="CONSTANT"
+>VIDIOC_QUERYCAP</CODE
+></A
+>. As secondary device functions they
+may also support the <A
+HREF="#OVERLAY"
+>video overlay</A
+>
+(<CODE
+CLASS="CONSTANT"
+>V4L2_CAP_VIDEO_OVERLAY</CODE
+>) and the <A
+HREF="#RAW-VBI"
+>raw VBI capture</A
+>
+(<CODE
+CLASS="CONSTANT"
+>V4L2_CAP_VBI_CAPTURE</CODE
+>) interface. At least one of
+the read/write or streaming I/O methods must be supported. Tuners and
+audio inputs are optional.</P
+></DIV
+><DIV
+CLASS="SECTION"
+><HR><H3
+CLASS="SECTION"
+><A
+NAME="AEN3972"
+>4.1.2. Supplemental Functions</A
+></H3
+><P
+>Video capture devices shall support <A
+HREF="#AUDIO"
+>audio input</A
+>, <A
+HREF="#TUNER"
+>tuner</A
+>, <A
+HREF="#CONTROL"
+>controls</A
+>,
+<A
+HREF="#CROP"
+>cropping and scaling</A
+> and <A
+HREF="#STREAMING-PAR"
+>streaming parameter</A
+> ioctls as needed.
+The <A
+HREF="#VIDEO"
+>video input</A
+> and <A
+HREF="#STANDARD"
+>video standard</A
+> ioctls must be supported by
+all video capture devices.</P
+></DIV
+><DIV
+CLASS="SECTION"
+><HR><H3
+CLASS="SECTION"
+><A
+NAME="AEN3982"
+>4.1.3. Image Format Negotiation</A
+></H3
+><P
+>The result of a capture operation is determined by
+cropping and image format parameters. The former select an area of the
+video picture to capture, the latter how images are stored in memory,
+i.&nbsp;e. in RGB or YUV format, the number of bits per pixel or width and
+height. Together they also define how images are scaled in the
+process.</P
+><P
+>As usual these parameters are <SPAN
+CLASS="emphasis"
+><I
+CLASS="EMPHASIS"
+>not</I
+></SPAN
+>
+reset at <CODE
+CLASS="FUNCTION"
+>open()</CODE
+> time to permit Unix tool chains,
+programming a device and then reading from it as if it was a plain
+file. Well written V4L2 applications ensure they really get what they
+want, including cropping and scaling.</P
+><P
+>Cropping initialization at minimum requires to reset the
+parameters to defaults. An example is given in <A
+HREF="#CROP"
+>Section 1.10</A
+>.</P
+><P
+>To query the current image format applications set the
+<CODE
+CLASS="STRUCTFIELD"
+>type</CODE
+> field of a struct&nbsp;<A
+HREF="#V4L2-FORMAT"
+>v4l2_format</A
+> to
+<CODE
+CLASS="CONSTANT"
+>V4L2_BUF_TYPE_VIDEO_CAPTURE</CODE
+> and call the
+<A
+HREF="#VIDIOC-G-FMT"
+><CODE
+CLASS="CONSTANT"
+>VIDIOC_G_FMT</CODE
+></A
+> ioctl with a pointer to this structure. Drivers fill
+the struct&nbsp;<A
+HREF="#V4L2-PIX-FORMAT"
+>v4l2_pix_format</A
+> <CODE
+CLASS="STRUCTFIELD"
+>pix</CODE
+> member of the
+<CODE
+CLASS="STRUCTFIELD"
+>fmt</CODE
+> union.</P
+><P
+>To request different parameters applications set the
+<CODE
+CLASS="STRUCTFIELD"
+>type</CODE
+> field of a struct&nbsp;<A
+HREF="#V4L2-FORMAT"
+>v4l2_format</A
+> as above and
+initialize all fields of the struct&nbsp;<A
+HREF="#V4L2-PIX-FORMAT"
+>v4l2_pix_format</A
+>
+<CODE
+CLASS="STRUCTFIELD"
+>vbi</CODE
+> member of the
+<CODE
+CLASS="STRUCTFIELD"
+>fmt</CODE
+> union, or better just modify the
+results of <CODE
+CLASS="CONSTANT"
+>VIDIOC_G_FMT</CODE
+>, and call the
+<A
+HREF="#VIDIOC-G-FMT"
+><CODE
+CLASS="CONSTANT"
+>VIDIOC_S_FMT</CODE
+></A
+> ioctl with a pointer to this structure. Drivers may
+adjust the parameters and finally return the actual parameters as
+<CODE
+CLASS="CONSTANT"
+>VIDIOC_G_FMT</CODE
+> does.</P
+><P
+>Like <CODE
+CLASS="CONSTANT"
+>VIDIOC_S_FMT</CODE
+> the
+<A
+HREF="#VIDIOC-G-FMT"
+><CODE
+CLASS="CONSTANT"
+>VIDIOC_TRY_FMT</CODE
+></A
+> ioctl can be used to learn about hardware limitations
+without disabling I/O or possibly time consuming hardware
+preparations.</P
+><P
+>The contents of struct&nbsp;<A
+HREF="#V4L2-PIX-FORMAT"
+>v4l2_pix_format</A
+> are discussed in <A
+HREF="#PIXFMT"
+>Chapter 2</A
+>. See also the specification of the
+<CODE
+CLASS="CONSTANT"
+>VIDIOC_G_FMT</CODE
+>, <CODE
+CLASS="CONSTANT"
+>VIDIOC_S_FMT</CODE
+>
+and <CODE
+CLASS="CONSTANT"
+>VIDIOC_TRY_FMT</CODE
+> ioctls for details. Video
+capture devices must implement both the
+<CODE
+CLASS="CONSTANT"
+>VIDIOC_G_FMT</CODE
+> and
+<CODE
+CLASS="CONSTANT"
+>VIDIOC_S_FMT</CODE
+> ioctl, even if
+<CODE
+CLASS="CONSTANT"
+>VIDIOC_S_FMT</CODE
+> ignores all requests and always
+returns default parameters as <CODE
+CLASS="CONSTANT"
+>VIDIOC_G_FMT</CODE
+> does.
+<CODE
+CLASS="CONSTANT"
+>VIDIOC_TRY_FMT</CODE
+> is optional.</P
+></DIV
+><DIV
+CLASS="SECTION"
+><HR><H3
+CLASS="SECTION"
+><A
+NAME="AEN4024"
+>4.1.4. Reading Images</A
+></H3
+><P
+>A video capture device may support the <A
+HREF="#RW"
+>read() function</A
+> and/or streaming (<A
+HREF="#MMAP"
+>memory mapping</A
+> or <A
+HREF="#USERP"
+>user pointer</A
+>) I/O. See <A
+HREF="#IO"
+>Chapter 3</A
+> for details.</P
+></DIV
+></DIV
+><DIV
+CLASS="SECTION"
+><HR><H2
+CLASS="SECTION"
+><A
+NAME="OVERLAY"
+>4.2. Video Overlay Interface</A
+></H2
+><FONT
+COLOR="RED"
+>Also known as Frame Buffer Overlay or Previewing</FONT
+><P
+>Video overlay devices have the ability to genlock (TV-)video
+into the (VGA-)video signal of a graphics card, or to store captured
+images directly in video memory of a graphics card, typically with
+clipping. This can be considerable more efficient than capturing
+images and displaying them by other means. In the old days when only
+nuclear power plants needed cooling towers this used to be the only
+way to put live video into a window.</P
+><P
+>Video overlay devices are accessed through the same character
+special files as <A
+HREF="#CAPTURE"
+>video capture</A
+> devices.
+Note the default function of a <TT
+CLASS="FILENAME"
+>/dev/video</TT
+> device
+is video capturing. The overlay function is only available after
+calling the <A
+HREF="#VIDIOC-G-FMT"
+><CODE
+CLASS="CONSTANT"
+>VIDIOC_S_FMT</CODE
+></A
+> ioctl.</P
+><P
+>The driver may support simultaneous overlay and capturing
+using the read/write and streaming I/O methods. If so, operation at
+the nominal frame rate of the video standard is not guaranteed. Frames
+may be directed away from overlay to capture, or one field may be used
+for overlay and the other for capture if the capture parameters permit
+this.</P
+><P
+>Applications should use different file descriptors for
+capturing and overlay. This must be supported by all drivers capable
+of simultaneous capturing and overlay. Optionally these drivers may
+also permit capturing and overlay with a single file descriptor for
+compatibility with V4L and earlier versions of V4L2.<A
+NAME="AEN4042"
+HREF="#FTN.AEN4042"
+><SPAN
+CLASS="footnote"
+>[21]</SPAN
+></A
+></P
+><DIV
+CLASS="SECTION"
+><HR><H3
+CLASS="SECTION"
+><A
+NAME="AEN4048"
+>4.2.1. Querying Capabilities</A
+></H3
+><P
+>Devices supporting the video overlay interface set the
+<CODE
+CLASS="CONSTANT"
+>V4L2_CAP_VIDEO_OVERLAY</CODE
+> flag in the
+<CODE
+CLASS="STRUCTFIELD"
+>capabilities</CODE
+> field of struct&nbsp;<A
+HREF="#V4L2-CAPABILITY"
+>v4l2_capability</A
+>
+returned by the <A
+HREF="#VIDIOC-QUERYCAP"
+><CODE
+CLASS="CONSTANT"
+>VIDIOC_QUERYCAP</CODE
+></A
+>. The overlay I/O method specified
+below must be supported. Tuners and audio inputs are optional.</P
+></DIV
+><DIV
+CLASS="SECTION"
+><HR><H3
+CLASS="SECTION"
+><A
+NAME="AEN4056"
+>4.2.2. Supplemental Functions</A
+></H3
+><P
+>Video overlay devices shall support <A
+HREF="#AUDIO"
+>audio input</A
+>, <A
+HREF="#TUNER"
+>tuner</A
+>, <A
+HREF="#CONTROL"
+>controls</A
+>,
+<A
+HREF="#CROP"
+>cropping and scaling</A
+> and <A
+HREF="#STREAMING-PAR"
+>streaming parameter</A
+> ioctls as needed.
+The <A
+HREF="#VIDEO"
+>video input</A
+> and <A
+HREF="#STANDARD"
+>video standard</A
+> ioctls must be supported by
+all video overlay devices.</P
+></DIV
+><DIV
+CLASS="SECTION"
+><HR><H3
+CLASS="SECTION"
+><A
+NAME="AEN4066"
+>4.2.3. Setup</A
+></H3
+><P
+>Before overlay can commence applications must program the
+driver with frame buffer parameters, namely the address and size of
+the frame buffer and the image format, for example RGB 5:6:5. The
+<A
+HREF="#VIDIOC-G-FBUF"
+><CODE
+CLASS="CONSTANT"
+>VIDIOC_G_FBUF</CODE
+></A
+> and <A
+HREF="#VIDIOC-G-FBUF"
+><CODE
+CLASS="CONSTANT"
+>VIDIOC_S_FBUF</CODE
+></A
+> ioctls are available to get
+and set these parameters, respectively. The
+<CODE
+CLASS="CONSTANT"
+>VIDIOC_S_FBUF</CODE
+> ioctl is privileged because it
+allows to set up DMA into physical memory, bypassing the memory
+protection mechanisms of the kernel. Only the superuser can change the
+frame buffer address and size. Users are not supposed to run TV
+applications as root or with SUID bit set. A small helper application
+with suitable privileges should query the graphics system and program
+the V4L2 driver at the appropriate time.</P
+><P
+>Some devices add the video overlay to the output signal
+of the graphics card. In this case the frame buffer is not modified by
+the video device, and the frame buffer address and pixel format are
+not needed by the driver. The <CODE
+CLASS="CONSTANT"
+>VIDIOC_S_FBUF</CODE
+> ioctl
+is not privileged. An application can check for this type of device by
+calling the <CODE
+CLASS="CONSTANT"
+>VIDIOC_G_FBUF</CODE
+> ioctl.</P
+><P
+>A driver may support any (or none) of three clipping
+methods:<P
+></P
+><OL
+TYPE="1"
+><LI
+><P
+>Chroma-keying displays the overlaid image only where
+pixels in the primary graphics surface assume a certain color.</P
+></LI
+><LI
+><P
+>A bitmap can be specified where each bit corresponds
+to a pixel in the overlaid image. When the bit is set, the
+corresponding video pixel is displayed, otherwise a pixel of the
+graphics surface.</P
+></LI
+><LI
+><P
+>A list of clipping rectangles can be specified. In
+these regions <SPAN
+CLASS="emphasis"
+><I
+CLASS="EMPHASIS"
+>no</I
+></SPAN
+> video is displayed, so the
+graphics surface can be seen here.</P
+></LI
+></OL
+></P
+><P
+>When simultaneous capturing and overlay is supported and
+the hardware prohibits different image and frame buffer formats, the
+format requested first takes precedence. The attempt to capture
+(<A
+HREF="#VIDIOC-G-FMT"
+><CODE
+CLASS="CONSTANT"
+>VIDIOC_S_FMT</CODE
+></A
+>) or overlay (<A
+HREF="#VIDIOC-G-FBUF"
+><CODE
+CLASS="CONSTANT"
+>VIDIOC_S_FBUF</CODE
+></A
+>) may fail with an
+<SPAN
+CLASS="ERRORCODE"
+>EBUSY</SPAN
+> error code or return accordingly modified parameters..</P
+></DIV
+><DIV
+CLASS="SECTION"
+><HR><H3
+CLASS="SECTION"
+><A
+NAME="AEN4092"
+>4.2.4. Overlay Window</A
+></H3
+><P
+>The overlaid image is determined by cropping and overlay
+window parameters. The former select an area of the video picture to
+capture, the latter how images are overlaid and clipped. Cropping
+initialization at minimum requires to reset the parameters to
+defaults. An example is given in <A
+HREF="#CROP"
+>Section 1.10</A
+>.</P
+><P
+>The overlay window is described by a struct&nbsp;<A
+HREF="#V4L2-WINDOW"
+>v4l2_window</A
+>. It
+defines the size of the image, its position over the graphics surface
+and the clipping to be applied. To get the current parameters applications
+set the <CODE
+CLASS="STRUCTFIELD"
+>type</CODE
+> field of a struct&nbsp;<A
+HREF="#V4L2-FORMAT"
+>v4l2_format</A
+> to
+<CODE
+CLASS="CONSTANT"
+>V4L2_BUF_TYPE_VIDEO_OVERLAY</CODE
+> and call the
+<A
+HREF="#VIDIOC-G-FMT"
+><CODE
+CLASS="CONSTANT"
+>VIDIOC_G_FMT</CODE
+></A
+> ioctl. The driver fills the
+<CODE
+CLASS="STRUCTNAME"
+>v4l2_window</CODE
+> substructure named
+<CODE
+CLASS="STRUCTFIELD"
+>win</CODE
+>. Retrieving a previously programmed
+clipping list or bitmap is not possible.</P
+><P
+>To program the overlay window applications set the
+<CODE
+CLASS="STRUCTFIELD"
+>type</CODE
+> field of a struct&nbsp;<A
+HREF="#V4L2-FORMAT"
+>v4l2_format</A
+> to
+<CODE
+CLASS="CONSTANT"
+>V4L2_BUF_TYPE_VIDEO_OVERLAY</CODE
+>, initialize the
+<CODE
+CLASS="STRUCTFIELD"
+>win</CODE
+> substructure and call the
+<A
+HREF="#VIDIOC-G-FMT"
+><CODE
+CLASS="CONSTANT"
+>VIDIOC_S_FMT</CODE
+></A
+> ioctl. The driver adjusts the parameters against
+hardware limits and returns the actual parameters as
+<CODE
+CLASS="CONSTANT"
+>VIDIOC_G_FMT</CODE
+> does. Like
+<CODE
+CLASS="CONSTANT"
+>VIDIOC_S_FMT</CODE
+>, the <A
+HREF="#VIDIOC-G-FMT"
+><CODE
+CLASS="CONSTANT"
+>VIDIOC_TRY_FMT</CODE
+></A
+> ioctl can be
+used to learn about driver capabilities without actually changing
+driver state. Unlike <CODE
+CLASS="CONSTANT"
+>VIDIOC_S_FMT</CODE
+> this also works
+after the overlay has been enabled.</P
+><P
+>The scaling factor of the overlaid image is implied by the
+width and height given in struct&nbsp;<A
+HREF="#V4L2-WINDOW"
+>v4l2_window</A
+> and the size of the cropping
+rectangle. For more information see <A
+HREF="#CROP"
+>Section 1.10</A
+>.</P
+><P
+>When simultaneous capturing and overlay is supported and
+the hardware prohibits different image and window sizes, the size
+requested first takes precedence. The attempt to capture or overlay as
+well (<A
+HREF="#VIDIOC-G-FMT"
+><CODE
+CLASS="CONSTANT"
+>VIDIOC_S_FMT</CODE
+></A
+>) may fail with an <SPAN
+CLASS="ERRORCODE"
+>EBUSY</SPAN
+> error code or return accordingly
+modified parameters.</P
+><DIV
+CLASS="TABLE"
+><A
+NAME="V4L2-WINDOW"
+></A
+><P
+><B
+>Table 4-1. struct <CODE
+CLASS="STRUCTNAME"
+>v4l2_window</CODE
+></B
+></P
+><TABLE
+BORDER="0"
+FRAME="void"
+WIDTH="100%"
+CLASS="CALSTABLE"
+><COL
+WIDTH="25%"
+TITLE="C1"><COL
+WIDTH="25%"
+TITLE="C2"><COL
+WIDTH="50%"
+TITLE="C3"><TBODY
+><TR
+><TD
+>struct&nbsp;<A
+HREF="#V4L2-RECT"
+>v4l2_rect</A
+></TD
+><TD
+><CODE
+CLASS="STRUCTFIELD"
+>w</CODE
+></TD
+><TD
+>Size and position of the window relative to the
+top, left corner of the frame buffer defined with <A
+HREF="#VIDIOC-G-FBUF"
+><CODE
+CLASS="CONSTANT"
+>VIDIOC_S_FBUF</CODE
+></A
+>. The
+window can extend the frame buffer width and height, the
+<CODE
+CLASS="STRUCTFIELD"
+>x</CODE
+> and <CODE
+CLASS="STRUCTFIELD"
+>y</CODE
+>
+coordinates can be negative, and it can lie completely outside the
+frame buffer. The driver clips the window accordingly, or if that is
+not possible, modifies its size and/or position.</TD
+></TR
+><TR
+><TD
+>enum&nbsp;<A
+HREF="#V4L2-FIELD"
+>v4l2_field</A
+></TD
+><TD
+><CODE
+CLASS="STRUCTFIELD"
+>field</CODE
+></TD
+><TD
+>Applications set this field to determine which
+video field shall be overlaid, typically one of
+<CODE
+CLASS="CONSTANT"
+>V4L2_FIELD_ANY</CODE
+> (0),
+<CODE
+CLASS="CONSTANT"
+>V4L2_FIELD_TOP</CODE
+>,
+<CODE
+CLASS="CONSTANT"
+>V4L2_FIELD_BOTTOM</CODE
+> or
+<CODE
+CLASS="CONSTANT"
+>V4L2_FIELD_INTERLACED</CODE
+>. Drivers may have to choose
+a different field order and return the actual setting here.</TD
+></TR
+><TR
+><TD
+>__u32</TD
+><TD
+><CODE
+CLASS="STRUCTFIELD"
+>chromakey</CODE
+></TD
+><TD
+>When chroma-keying has been negotiated with
+<A
+HREF="#VIDIOC-G-FBUF"
+><CODE
+CLASS="CONSTANT"
+>VIDIOC_S_FBUF</CODE
+></A
+> applications set this field to the desired host order
+RGB32 value for the chroma key. [host order? alpha channel?]</TD
+></TR
+><TR
+><TD
+>struct&nbsp;<A
+HREF="#V4L2-CLIP"
+>v4l2_clip</A
+> *</TD
+><TD
+><CODE
+CLASS="STRUCTFIELD"
+>clips</CODE
+></TD
+><TD
+>When chroma-keying has <SPAN
+CLASS="emphasis"
+><I
+CLASS="EMPHASIS"
+>not</I
+></SPAN
+>
+been negotiated and <A
+HREF="#VIDIOC-G-FBUF"
+><CODE
+CLASS="CONSTANT"
+>VIDIOC_G_FBUF</CODE
+></A
+> indicated this capability,
+applications can set this field to point to the first in a list of
+clipping rectangles.</TD
+></TR
+><TR
+><TD
+COLSPAN="3"
+>Like the window coordinates
+<CODE
+CLASS="STRUCTFIELD"
+>w</CODE
+>, clipping rectangles are defined relative
+to the top, left corner of the frame buffer. However clipping
+rectangles must not extend the frame buffer width and height, and they
+must not overlap. If possible applications should merge adjacent
+rectangles. Whether this must create x-y or y-x bands, or the order of
+rectangles, is not defined. When clip lists are not supported the
+driver ignores this field. Its contents after calling <A
+HREF="#VIDIOC-G-FMT"
+><CODE
+CLASS="CONSTANT"
+>VIDIOC_S_FMT</CODE
+></A
+>
+are undefined.</TD
+></TR
+><TR
+><TD
+>__u32</TD
+><TD
+><CODE
+CLASS="STRUCTFIELD"
+>clipcount</CODE
+></TD
+><TD
+>When the application set the
+<CODE
+CLASS="STRUCTFIELD"
+>clips</CODE
+> field, this field must contain the
+number of clipping rectangles in the list. When clip lists are not
+supported the driver ignores this field, its contents after calling
+<CODE
+CLASS="CONSTANT"
+>VIDIOC_S_FMT</CODE
+> are undefined. When clip lists are
+supported but no clipping is desired this field must be set to
+zero.</TD
+></TR
+><TR
+><TD
+>void *</TD
+><TD
+><CODE
+CLASS="STRUCTFIELD"
+>bitmap</CODE
+></TD
+><TD
+>When chroma-keying has
+<SPAN
+CLASS="emphasis"
+><I
+CLASS="EMPHASIS"
+>not</I
+></SPAN
+> been negotiated and <A
+HREF="#VIDIOC-G-FBUF"
+><CODE
+CLASS="CONSTANT"
+>VIDIOC_G_FBUF</CODE
+></A
+> indicated
+this capability, applications can set this field to point to a
+clipping bit mask.</TD
+></TR
+><TR
+><TD
+COLSPAN="3"
+><P
+>It must be of the same size
+as the window, <CODE
+CLASS="STRUCTFIELD"
+>w.width</CODE
+> and
+<CODE
+CLASS="STRUCTFIELD"
+>w.height</CODE
+>. Each bit corresponds to a pixel
+in the overlaid image, which is displayed only when the bit is
+<SPAN
+CLASS="emphasis"
+><I
+CLASS="EMPHASIS"
+>set</I
+></SPAN
+>. Pixel coordinates translate to bits like:
+<PRE
+CLASS="PROGRAMLISTING"
+>((__u8 *) <CODE
+CLASS="STRUCTFIELD"
+>bitmap</CODE
+>)[<CODE
+CLASS="STRUCTFIELD"
+>w.width</CODE
+> * y + x / 8] &#38; (1 &#60;&#60; (x &#38; 7))</PRE
+></P
+><P
+>where <CODE
+CLASS="STRUCTFIELD"
+>0</CODE
+> &le; x &lt;
+<CODE
+CLASS="STRUCTFIELD"
+>w.width</CODE
+> and <CODE
+CLASS="STRUCTFIELD"
+>0</CODE
+> &le;
+y &lt;<CODE
+CLASS="STRUCTFIELD"
+>w.height</CODE
+>.<SUP
+>a</SUP
+></P
+><P
+>When a clipping
+bit mask is not supported the driver ignores this field, its contents
+after calling <A
+HREF="#VIDIOC-G-FMT"
+><CODE
+CLASS="CONSTANT"
+>VIDIOC_S_FMT</CODE
+></A
+> are undefined. When a bit mask is supported
+but no clipping is desired this field must be set to
+<CODE
+CLASS="CONSTANT"
+>NULL</CODE
+>.</P
+><P
+>Applications need not create a
+clip list or bit mask. When they pass both, or despite negotiating
+chroma-keying, the results are undefined. Regardless of the chosen
+method, the clipping abilities of the hardware may be limited in
+quantity or quality. The results when these limits are exceeded are
+undefined.<SUP
+>b</SUP
+></P
+></TD
+></TR
+></TBODY
+><TR
+><TD
+COLSPAN="3"
+>Notes:<BR><A
+NAME="FTN.AEN4203"
+>a. </A
+>Should we require
+ <CODE
+CLASS="STRUCTFIELD"
+>w.width</CODE
+> to be a multiple of
+ eight?<BR><A
+NAME="FTN.AEN4211"
+>b. </A
+>When the image is written into frame buffer
+memory it will be undesirable if the driver clips out less pixels
+than expected, because the application and graphics system are not
+aware these regions need to be refreshed. The driver should clip out
+more pixels or not write the image at all.<BR></TD
+></TR
+></TABLE
+></DIV
+><DIV
+CLASS="TABLE"
+><A
+NAME="V4L2-CLIP"
+></A
+><P
+><B
+>Table 4-2. struct <CODE
+CLASS="STRUCTNAME"
+>v4l2_clip</CODE
+><A
+NAME="AEN4216"
+HREF="#FTN.AEN4216"
+><SPAN
+CLASS="footnote"
+>[22]</SPAN
+></A
+></B
+></P
+><TABLE
+BORDER="0"
+FRAME="void"
+WIDTH="100%"
+CLASS="CALSTABLE"
+><COL
+WIDTH="25%"
+TITLE="C1"><COL
+WIDTH="25%"
+TITLE="C2"><COL
+WIDTH="50%"
+TITLE="C3"><TBODY
+><TR
+><TD
+>struct&nbsp;<A
+HREF="#V4L2-RECT"
+>v4l2_rect</A
+></TD
+><TD
+><CODE
+CLASS="STRUCTFIELD"
+>c</CODE
+></TD
+><TD
+>Coordinates of the clipping rectangle, relative to
+the top, left corner of the frame buffer. Only window pixels
+<SPAN
+CLASS="emphasis"
+><I
+CLASS="EMPHASIS"
+>outside</I
+></SPAN
+> all clipping rectangles are
+displayed.</TD
+></TR
+><TR
+><TD
+>struct&nbsp;<A
+HREF="#V4L2-CLIP"
+>v4l2_clip</A
+> *</TD
+><TD
+><CODE
+CLASS="STRUCTFIELD"
+>next</CODE
+></TD
+><TD
+>Pointer to the next clipping rectangle in the list,
+NULL when this is the last rectangle.</TD
+></TR
+></TBODY
+></TABLE
+></DIV
+><DIV
+CLASS="TABLE"
+><A
+NAME="V4L2-RECT"
+></A
+><P
+><B
+>Table 4-3. struct <CODE
+CLASS="STRUCTNAME"
+>v4l2_rect</CODE
+></B
+></P
+><TABLE
+BORDER="0"
+FRAME="void"
+WIDTH="100%"
+CLASS="CALSTABLE"
+><COL
+WIDTH="25%"
+TITLE="C1"><COL
+WIDTH="25%"
+TITLE="C2"><COL
+WIDTH="50%"
+TITLE="C3"><TBODY
+><TR
+><TD
+>__s32</TD
+><TD
+><CODE
+CLASS="STRUCTFIELD"
+>left</CODE
+></TD
+><TD
+>Horizontal offset of the top, left corner of the
+rectangle, in pixels.</TD
+></TR
+><TR
+><TD
+>__s32</TD
+><TD
+><CODE
+CLASS="STRUCTFIELD"
+>top</CODE
+></TD
+><TD
+>Vertical offset of the top, left corner of the
+rectangle, in pixels. Offsets increase to the right and down.</TD
+></TR
+><TR
+><TD
+>__s32</TD
+><TD
+><CODE
+CLASS="STRUCTFIELD"
+>width</CODE
+></TD
+><TD
+>Width of the rectangle, in pixels.</TD
+></TR
+><TR
+><TD
+>__s32</TD
+><TD
+><CODE
+CLASS="STRUCTFIELD"
+>height</CODE
+></TD
+><TD
+>Height of the rectangle, in pixels. Width and
+height cannot be negative, the fields are signed for hysterical
+reasons. </TD
+></TR
+></TBODY
+></TABLE
+></DIV
+></DIV
+><DIV
+CLASS="SECTION"
+><HR><H3
+CLASS="SECTION"
+><A
+NAME="AEN4266"
+>4.2.5. Enabling Overlay</A
+></H3
+><P
+>To start or stop the frame buffer overlay applications call
+the <A
+HREF="#VIDIOC-OVERLAY"
+><CODE
+CLASS="CONSTANT"
+>VIDIOC_OVERLAY</CODE
+></A
+> ioctl.</P
+></DIV
+></DIV
+><DIV
+CLASS="SECTION"
+><HR><H2
+CLASS="SECTION"
+><A
+NAME="OUTPUT"
+>4.3. Video Output Interface</A
+></H2
+><P
+>Video output devices encode stills or image sequences as
+analog video signal. With this interface applications can
+control the encoding process and move images from user space to
+the driver.</P
+><P
+>Conventionally V4L2 video output devices are accessed through
+character device special files named <TT
+CLASS="FILENAME"
+>/dev/vout</TT
+> and
+<TT
+CLASS="FILENAME"
+>/dev/vout0</TT
+> to <TT
+CLASS="FILENAME"
+>/dev/voutN</TT
+>. No
+minor numbers were recommended yet. <TT
+CLASS="FILENAME"
+>/dev/vout</TT
+> is
+typically a symbolic link to the preferred video output device.</P
+><DIV
+CLASS="SECTION"
+><HR><H3
+CLASS="SECTION"
+><A
+NAME="AEN4279"
+>4.3.1. Querying Capabilities</A
+></H3
+><P
+>Devices supporting the video output interface set the
+<CODE
+CLASS="CONSTANT"
+>V4L2_CAP_VIDEO_OUTPUT</CODE
+> flag in the
+<CODE
+CLASS="STRUCTFIELD"
+>capabilities</CODE
+> field of struct&nbsp;<A
+HREF="#V4L2-CAPABILITY"
+>v4l2_capability</A
+>
+returned by the <A
+HREF="#VIDIOC-QUERYCAP"
+><CODE
+CLASS="CONSTANT"
+>VIDIOC_QUERYCAP</CODE
+></A
+>. As secondary device functions they
+may also support the <A
+HREF="#RAW-VBI"
+>raw VBI output</A
+>
+(<CODE
+CLASS="CONSTANT"
+>V4L2_CAP_VBI_OUTPUT</CODE
+>) interface. At least one of
+the read/write or streaming I/O methods must be supported. Modulators
+and audio outputs are optional.</P
+></DIV
+><DIV
+CLASS="SECTION"
+><HR><H3
+CLASS="SECTION"
+><A
+NAME="AEN4289"
+>4.3.2. Supplemental Functions</A
+></H3
+><P
+>Video output devices shall support <A
+HREF="#AUDIO"
+>audio output</A
+>, <A
+HREF="#TUNER"
+>modulator</A
+>, <A
+HREF="#CONTROL"
+>controls</A
+>,
+<A
+HREF="#CROP"
+>cropping and scaling</A
+> and <A
+HREF="#STREAMING-PAR"
+>streaming parameter</A
+> ioctls as needed.
+The <A
+HREF="#VIDEO"
+>video output</A
+> and <A
+HREF="#STANDARD"
+>video standard</A
+> ioctls must be supported by
+all video output devices.</P
+></DIV
+><DIV
+CLASS="SECTION"
+><HR><H3
+CLASS="SECTION"
+><A
+NAME="AEN4299"
+>4.3.3. Image Format Negotiation</A
+></H3
+><P
+>The output is determined by cropping and image format
+parameters. The former select an area of the video picture where the
+image will appear, the latter how images are stored in memory, i.&nbsp;e. in
+RGB or YUV format, the number of bits per pixel or width and height.
+Together they also define how images are scaled in the process.</P
+><P
+>As usual these parameters are <SPAN
+CLASS="emphasis"
+><I
+CLASS="EMPHASIS"
+>not</I
+></SPAN
+>
+reset at <CODE
+CLASS="FUNCTION"
+>open()</CODE
+> time to permit Unix tool chains,
+programming a device and then writing to it as if it was a plain
+file. Well written V4L2 applications ensure they really get what they
+want, including cropping and scaling.</P
+><P
+>Cropping initialization at minimum requires to reset the
+parameters to defaults. An example is given in <A
+HREF="#CROP"
+>Section 1.10</A
+>.</P
+><P
+>To query the current image format applications set the
+<CODE
+CLASS="STRUCTFIELD"
+>type</CODE
+> field of a struct&nbsp;<A
+HREF="#V4L2-FORMAT"
+>v4l2_format</A
+> to
+<CODE
+CLASS="CONSTANT"
+>V4L2_BUF_TYPE_VIDEO_OUTPUT</CODE
+> and call the
+<A
+HREF="#VIDIOC-G-FMT"
+><CODE
+CLASS="CONSTANT"
+>VIDIOC_G_FMT</CODE
+></A
+> ioctl with a pointer to this structure. Drivers fill
+the struct&nbsp;<A
+HREF="#V4L2-PIX-FORMAT"
+>v4l2_pix_format</A
+> <CODE
+CLASS="STRUCTFIELD"
+>pix</CODE
+> member of the
+<CODE
+CLASS="STRUCTFIELD"
+>fmt</CODE
+> union.</P
+><P
+>To request different parameters applications set the
+<CODE
+CLASS="STRUCTFIELD"
+>type</CODE
+> field of a struct&nbsp;<A
+HREF="#V4L2-FORMAT"
+>v4l2_format</A
+> as above and
+initialize all fields of the struct&nbsp;<A
+HREF="#V4L2-PIX-FORMAT"
+>v4l2_pix_format</A
+>
+<CODE
+CLASS="STRUCTFIELD"
+>vbi</CODE
+> member of the
+<CODE
+CLASS="STRUCTFIELD"
+>fmt</CODE
+> union, or better just modify the
+results of <CODE
+CLASS="CONSTANT"
+>VIDIOC_G_FMT</CODE
+>, and call the
+<A
+HREF="#VIDIOC-G-FMT"
+><CODE
+CLASS="CONSTANT"
+>VIDIOC_S_FMT</CODE
+></A
+> ioctl with a pointer to this structure. Drivers may
+adjust the parameters and finally return the actual parameters as
+<CODE
+CLASS="CONSTANT"
+>VIDIOC_G_FMT</CODE
+> does.</P
+><P
+>Like <CODE
+CLASS="CONSTANT"
+>VIDIOC_S_FMT</CODE
+> the
+<A
+HREF="#VIDIOC-G-FMT"
+><CODE
+CLASS="CONSTANT"
+>VIDIOC_TRY_FMT</CODE
+></A
+> ioctl can be used to learn about hardware limitations
+without disabling I/O or possibly time consuming hardware
+preparations.</P
+><P
+>The contents of struct&nbsp;<A
+HREF="#V4L2-PIX-FORMAT"
+>v4l2_pix_format</A
+> are discussed in <A
+HREF="#PIXFMT"
+>Chapter 2</A
+>. See also the specification of the
+<CODE
+CLASS="CONSTANT"
+>VIDIOC_G_FMT</CODE
+>, <CODE
+CLASS="CONSTANT"
+>VIDIOC_S_FMT</CODE
+>
+and <CODE
+CLASS="CONSTANT"
+>VIDIOC_TRY_FMT</CODE
+> ioctls for details. Video
+output devices must implement both the
+<CODE
+CLASS="CONSTANT"
+>VIDIOC_G_FMT</CODE
+> and
+<CODE
+CLASS="CONSTANT"
+>VIDIOC_S_FMT</CODE
+> ioctl, even if
+<CODE
+CLASS="CONSTANT"
+>VIDIOC_S_FMT</CODE
+> ignores all requests and always
+returns default parameters as <CODE
+CLASS="CONSTANT"
+>VIDIOC_G_FMT</CODE
+> does.
+<CODE
+CLASS="CONSTANT"
+>VIDIOC_TRY_FMT</CODE
+> is optional.</P
+></DIV
+><DIV
+CLASS="SECTION"
+><HR><H3
+CLASS="SECTION"
+><A
+NAME="AEN4341"
+>4.3.4. Writing Images</A
+></H3
+><P
+>A video output device may support the <A
+HREF="#RW"
+>write() function</A
+> and/or streaming (<A
+HREF="#MMAP"
+>memory mapping</A
+> or <A
+HREF="#USERP"
+>user pointer</A
+>) I/O. See <A
+HREF="#IO"
+>Chapter 3</A
+> for details.</P
+></DIV
+></DIV
+><DIV
+CLASS="SECTION"
+><HR><H2
+CLASS="SECTION"
+><A
+NAME="CODEC"
+>4.4. Codec Interface</A
+></H2
+><DIV
+CLASS="NOTE"
+><BLOCKQUOTE
+CLASS="NOTE"
+><P
+><B
+>Suspended: </B
+>This interface has been be suspended from the V4L2 API
+implemented in Linux 2.6 until we have more experience with codec
+device interfaces.</P
+></BLOCKQUOTE
+></DIV
+><P
+>A V4L2 codec can compress, decompress, transform, or
+otherwise convert video data from one format into another format, in
+memory. Applications send data to be converted to the driver through
+the <CODE
+CLASS="FUNCTION"
+>write()</CODE
+> call, and receive the converted data
+through the <CODE
+CLASS="FUNCTION"
+>read()</CODE
+> call. For efficiency, a driver
+may also support streaming I/O.</P
+><P
+>[to do]</P
+></DIV
+><DIV
+CLASS="SECTION"
+><HR><H2
+CLASS="SECTION"
+><A
+NAME="EFFECT"
+>4.5. Effect Devices Interface</A
+></H2
+><DIV
+CLASS="NOTE"
+><BLOCKQUOTE
+CLASS="NOTE"
+><P
+><B
+>Suspended: </B
+>This interface has been be suspended from the V4L2 API
+implemented in Linux 2.6 until we have more experience with effect
+device interfaces.</P
+></BLOCKQUOTE
+></DIV
+><P
+>A V4L2 video effect device can do image effects,
+filtering, or combine two or more images or image streams. For example
+video transitions or wipes. Applications send data to be processed and
+receive the result data either with <CODE
+CLASS="FUNCTION"
+>read()</CODE
+> and
+<CODE
+CLASS="FUNCTION"
+>write()</CODE
+> functions, or through the streaming I/O
+mechanism.</P
+><P
+>[to do]</P
+></DIV
+><DIV
+CLASS="SECTION"
+><HR><H2
+CLASS="SECTION"
+><A
+NAME="RAW-VBI"
+>4.6. Raw VBI Data Interface</A
+></H2
+><P
+>VBI is an abbreviation of "Vertical Blanking Interval", a gap
+in the sequence of lines of an analog video signal. During VBI
+no picture information is transmitted, allowing some time while the
+electron beam of a cathode ray tube TV returns to the top of the
+screen. Using an oscilloscope you will find here the vertical
+synchronization pulses and short data packages ASK
+modulated<A
+NAME="AEN4369"
+HREF="#FTN.AEN4369"
+><SPAN
+CLASS="footnote"
+>[23]</SPAN
+></A
+>
+onto the video signal. These are transmissions of services such as
+Teletext or Closed Caption.</P
+><P
+>Subject of this interface type is raw VBI data, as sampled off
+a video signal, or to be added to a signal for output.
+The data format is similar to uncompressed video images, a number of
+lines times a number of samples per line, we call this a VBI image.</P
+><P
+>Conventionally V4L2 VBI devices are accessed through character
+device special files named <TT
+CLASS="FILENAME"
+>/dev/vbi</TT
+> and
+<TT
+CLASS="FILENAME"
+>/dev/vbi0</TT
+> to <TT
+CLASS="FILENAME"
+>/dev/vbi15</TT
+> with
+major number 81 and minor numbers 224 to 239.
+<TT
+CLASS="FILENAME"
+>/dev/vbi</TT
+> is typically a symbolic link to the
+preferred VBI device. This convention applies to both input and output
+devices.</P
+><P
+>To address the problems of finding related video and VBI
+devices VBI capturing is also available as device function under
+<TT
+CLASS="FILENAME"
+>/dev/video</TT
+>, VBI output under
+<TT
+CLASS="FILENAME"
+>/dev/vout</TT
+>. To capture raw VBI data from these
+devices applications must call the <A
+HREF="#VIDIOC-G-FMT"
+><CODE
+CLASS="CONSTANT"
+>VIDIOC_S_FMT</CODE
+></A
+> ioctl. Accessed as
+<TT
+CLASS="FILENAME"
+>/dev/vbi</TT
+>, raw VBI capturing or output is
+the default device function.</P
+><DIV
+CLASS="SECTION"
+><HR><H3
+CLASS="SECTION"
+><A
+NAME="AEN4383"
+>4.6.1. Querying Capabilities</A
+></H3
+><P
+>Devices supporting the raw VBI capturing or output API set
+the <CODE
+CLASS="CONSTANT"
+>V4L2_CAP_VBI_CAPTURE</CODE
+> or
+<CODE
+CLASS="CONSTANT"
+>V4L2_CAP_VBI_OUTPUT</CODE
+> flags, respectively, in the
+<CODE
+CLASS="STRUCTFIELD"
+>capabilities</CODE
+> field of struct&nbsp;<A
+HREF="#V4L2-CAPABILITY"
+>v4l2_capability</A
+>
+returned by the <A
+HREF="#VIDIOC-QUERYCAP"
+><CODE
+CLASS="CONSTANT"
+>VIDIOC_QUERYCAP</CODE
+></A
+>. At least one of the
+read/write, streaming or asynchronous I/O methods must be
+supported. VBI devices may or may not have a tuner or modulator.</P
+></DIV
+><DIV
+CLASS="SECTION"
+><HR><H3
+CLASS="SECTION"
+><A
+NAME="AEN4392"
+>4.6.2. Supplemental Functions</A
+></H3
+><P
+>VBI devices shall support <A
+HREF="#VIDEO"
+>video
+input or output</A
+>, <A
+HREF="#TUNER"
+>tuner or
+modulator</A
+>, and <A
+HREF="#CONTROL"
+>controls</A
+> ioctls
+as needed. The <A
+HREF="#STANDARD"
+>video standard</A
+> ioctls provide
+information vital to program a VBI device, therefore must be
+supported.</P
+></DIV
+><DIV
+CLASS="SECTION"
+><HR><H3
+CLASS="SECTION"
+><A
+NAME="AEN4399"
+>4.6.3. Raw VBI Format Negotiation</A
+></H3
+><P
+>Raw VBI sampling abilities can vary, in particular the
+sampling frequency. To properly interpret the data V4L2 specifies an
+ioctl to query the sampling parameters. Moreover, to allow for some
+flexibility applications can also suggest different parameters.</P
+><P
+>As usual these parameters are <SPAN
+CLASS="emphasis"
+><I
+CLASS="EMPHASIS"
+>not</I
+></SPAN
+>
+reset at <CODE
+CLASS="FUNCTION"
+>open()</CODE
+> time to permit Unix tool chains,
+programming a device and then reading from it as if it was a plain
+file. Well written V4L2 applications should always ensure they really
+get what they want, requesting reasonable parameters and then checking
+if the actual parameters are suitable.</P
+><P
+>To query the current raw VBI capture parameters
+applications set the <CODE
+CLASS="STRUCTFIELD"
+>type</CODE
+> field of a
+struct&nbsp;<A
+HREF="#V4L2-FORMAT"
+>v4l2_format</A
+> to <CODE
+CLASS="CONSTANT"
+>V4L2_BUF_TYPE_VBI_CAPTURE</CODE
+> or
+<CODE
+CLASS="CONSTANT"
+>V4L2_BUF_TYPE_VBI_OUTPUT</CODE
+>, and call the
+<A
+HREF="#VIDIOC-G-FMT"
+><CODE
+CLASS="CONSTANT"
+>VIDIOC_G_FMT</CODE
+></A
+> ioctl with a pointer to this structure. Drivers fill
+the struct&nbsp;<A
+HREF="#V4L2-VBI-FORMAT"
+>v4l2_vbi_format</A
+> <CODE
+CLASS="STRUCTFIELD"
+>vbi</CODE
+> member of the
+<CODE
+CLASS="STRUCTFIELD"
+>fmt</CODE
+> union.</P
+><P
+>To request different parameters applications set the
+<CODE
+CLASS="STRUCTFIELD"
+>type</CODE
+> field of a struct&nbsp;<A
+HREF="#V4L2-FORMAT"
+>v4l2_format</A
+> as above and
+initialize all fields of the struct&nbsp;<A
+HREF="#V4L2-VBI-FORMAT"
+>v4l2_vbi_format</A
+>
+<CODE
+CLASS="STRUCTFIELD"
+>vbi</CODE
+> member of the
+<CODE
+CLASS="STRUCTFIELD"
+>fmt</CODE
+> union, or better just modify the
+results of <CODE
+CLASS="CONSTANT"
+>VIDIOC-G-FMT</CODE
+>, and call the
+<A
+HREF="#VIDIOC-G-FMT"
+><CODE
+CLASS="CONSTANT"
+>VIDIOC_S_FMT</CODE
+></A
+> ioctl with a pointer to this structure. Drivers return
+an <SPAN
+CLASS="ERRORCODE"
+>EINVAL</SPAN
+> error code only when the given parameters are ambiguous, otherwise
+they modify the parameters according to the hardware capabilites and
+return the actual parameters. When the driver allocates resources at
+this point, it may return an <SPAN
+CLASS="ERRORCODE"
+>EBUSY</SPAN
+> error code to indicate the returned
+parameters are valid but the required resources are currently not
+available. That may happen for instance when the video and VBI areas
+to capture would overlap, or when the driver supports multiple opens
+and another process already requested VBI capturing or output. Anyway,
+applications must expect other resource allocation points which may
+return <SPAN
+CLASS="ERRORCODE"
+>EBUSY</SPAN
+>, at the <A
+HREF="#VIDIOC-STREAMON"
+><CODE
+CLASS="CONSTANT"
+>VIDIOC_STREAMON</CODE
+></A
+> ioctl
+and the first read(), write() and select() call.</P
+><P
+>VBI devices must implement both the
+<CODE
+CLASS="CONSTANT"
+>VIDIOC_G_FMT</CODE
+> and
+<CODE
+CLASS="CONSTANT"
+>VIDIOC_S_FMT</CODE
+> ioctl, even if
+<CODE
+CLASS="CONSTANT"
+>VIDIOC_S_FMT</CODE
+> ignores all requests and always
+returns default parameters as <CODE
+CLASS="CONSTANT"
+>VIDIOC_G_FMT</CODE
+> does.
+<CODE
+CLASS="CONSTANT"
+>VIDIOC_TRY_FMT</CODE
+> is optional.</P
+><DIV
+CLASS="TABLE"
+><A
+NAME="V4L2-VBI-FORMAT"
+></A
+><P
+><B
+>Table 4-4. struct <CODE
+CLASS="STRUCTNAME"
+>v4l2_vbi_format</CODE
+></B
+></P
+><TABLE
+BORDER="0"
+FRAME="void"
+WIDTH="100%"
+CLASS="CALSTABLE"
+><COL
+WIDTH="25%"
+TITLE="C1"><COL
+WIDTH="25%"
+TITLE="C2"><COL
+WIDTH="50%"
+TITLE="C3"><TBODY
+><TR
+><TD
+>__u32</TD
+><TD
+><CODE
+CLASS="STRUCTFIELD"
+>sampling_rate</CODE
+></TD
+><TD
+>Samples per second, i.&nbsp;e. unit 1 Hz.</TD
+></TR
+><TR
+><TD
+>__u32</TD
+><TD
+><CODE
+CLASS="STRUCTFIELD"
+>offset</CODE
+></TD
+><TD
+><P
+>Horizontal offset of the VBI image,
+relative to the leading edge of the line synchronization pulse and
+counted in samples: The first sample in the VBI image will be located
+<CODE
+CLASS="STRUCTFIELD"
+>offset</CODE
+> /
+<CODE
+CLASS="STRUCTFIELD"
+>sampling_rate</CODE
+> seconds following the leading
+edge. See also <A
+HREF="#VBI-HSYNC"
+>Figure 4-1</A
+>.</P
+></TD
+></TR
+><TR
+><TD
+>__u32</TD
+><TD
+><CODE
+CLASS="STRUCTFIELD"
+>samples_per_line</CODE
+></TD
+><TD
+>&nbsp;</TD
+></TR
+><TR
+><TD
+>__u32</TD
+><TD
+><CODE
+CLASS="STRUCTFIELD"
+>sample_format</CODE
+></TD
+><TD
+><P
+>Defines the sample format as in <A
+HREF="#PIXFMT"
+>Chapter 2</A
+>, a four-character-code.<SUP
+>a</SUP
+> Usually this is
+<CODE
+CLASS="CONSTANT"
+>V4L2_PIX_FMT_GREY</CODE
+>, i.&nbsp;e. each sample
+consists of 8 bits with lower values oriented towards the black level.
+Do not assume any other correlation of values with the signal level.
+For example, the MSB does not necessarily indicate if the signal is
+'high' or 'low' because 128 may not be the mean value of the
+signal. Drivers shall not convert the sample format by software.</P
+></TD
+></TR
+><TR
+><TD
+>__u32</TD
+><TD
+><CODE
+CLASS="STRUCTFIELD"
+>start</CODE
+>[2]</TD
+><TD
+>This is the scanning system line number
+associated with the first line of the VBI image, of the first and the
+second field respectively. See <A
+HREF="#VBI-525"
+>Figure 4-2</A
+> and
+<A
+HREF="#VBI-625"
+>Figure 4-3</A
+> for valid values. VBI input drivers can
+return start values 0 if the hardware cannot reliable identify
+scanning lines, VBI acquisition may not require this
+information.</TD
+></TR
+><TR
+><TD
+>__u32</TD
+><TD
+><CODE
+CLASS="STRUCTFIELD"
+>count</CODE
+>[2]</TD
+><TD
+>The number of lines in the first and second
+field image, respectively.</TD
+></TR
+><TR
+><TD
+COLSPAN="3"
+><P
+>Drivers should be as
+flexibility as possible. For example, it may be possible to extend or
+move the VBI capture window down to the picture area, implementing a
+'full field mode' to capture data service transmissions embedded in
+the picture.</P
+><P
+>An application can set the first or second
+<CODE
+CLASS="STRUCTFIELD"
+>count</CODE
+> value to zero if no data is required
+from the respective field; <CODE
+CLASS="STRUCTFIELD"
+>count</CODE
+>[1] if the
+scanning system is progressive, i.&nbsp;e. not interlaced. The
+corresponding start value shall be ignored by the application and
+driver. Anyway, drivers may not support single field capturing and
+return both count values non-zero.</P
+><P
+>Both
+<CODE
+CLASS="STRUCTFIELD"
+>count</CODE
+> values set to zero, or line numbers
+outside the bounds depicted in <A
+HREF="#VBI-525"
+>Figure 4-2</A
+> and <A
+HREF="#VBI-625"
+>Figure 4-3</A
+>, or a field image covering
+lines of two fields, are invalid and shall not be returned by the
+driver.</P
+><P
+>To initialize the <CODE
+CLASS="STRUCTFIELD"
+>start</CODE
+>
+and <CODE
+CLASS="STRUCTFIELD"
+>count</CODE
+> fields, applications must first
+determine the current video standard selection. The <A
+HREF="#V4L2-STD-ID"
+>v4l2_std_id</A
+> or
+the <CODE
+CLASS="STRUCTFIELD"
+>framelines</CODE
+> field of struct&nbsp;<A
+HREF="#V4L2-STANDARD"
+>v4l2_standard</A
+> can
+be evaluated for this purpose.</P
+></TD
+></TR
+><TR
+><TD
+>__u32</TD
+><TD
+><CODE
+CLASS="STRUCTFIELD"
+>flags</CODE
+></TD
+><TD
+>See <A
+HREF="#VBIFMT-FLAGS"
+>Table 4-5</A
+> below. Currently
+only drivers set flags, applications must set this field to
+zero.</TD
+></TR
+><TR
+><TD
+>__u32</TD
+><TD
+><CODE
+CLASS="STRUCTFIELD"
+>reserved</CODE
+>[2]</TD
+><TD
+>This array is reserved for future extensions.
+Drivers and applications must set it to zero.</TD
+></TR
+></TBODY
+><TR
+><TD
+COLSPAN="3"
+>Notes:<BR><A
+NAME="FTN.AEN4470"
+>a. </A
+>A few devices may be unable to
+sample VBI data at all but can extend the video capture window to the
+VBI region.<BR></TD
+></TR
+></TABLE
+></DIV
+><DIV
+CLASS="TABLE"
+><A
+NAME="VBIFMT-FLAGS"
+></A
+><P
+><B
+>Table 4-5. Raw VBI Format Flags</B
+></P
+><TABLE
+BORDER="0"
+FRAME="void"
+WIDTH="100%"
+CLASS="CALSTABLE"
+><COL
+WIDTH="38%"
+TITLE="C1"><COL
+WIDTH="12%"
+TITLE="C2"><COL
+WIDTH="50%"
+TITLE="C3"><TBODY
+><TR
+><TD
+><CODE
+CLASS="CONSTANT"
+>V4L2_VBI_UNSYNC</CODE
+></TD
+><TD
+>0x0001</TD
+><TD
+><P
+>This flag indicates hardware which does not
+properly distinguish between fields. Normally the VBI image stores the
+first field (lower scanning line numbers) first in memory. This may be
+a top or bottom field depending on the video standard. When this flag
+is set the first or second field may be stored first, however the
+fields are still in correct temporal order with the older field first
+in memory.<SUP
+>a</SUP
+></P
+></TD
+></TR
+><TR
+><TD
+><CODE
+CLASS="CONSTANT"
+>V4L2_VBI_INTERLACED</CODE
+></TD
+><TD
+>0x0002</TD
+><TD
+>By default the two field images will be passed
+sequentially; all lines of the first field followed by all lines of
+the second field (compare <A
+HREF="#FIELD-ORDER"
+>Section 3.6</A
+>
+<CODE
+CLASS="CONSTANT"
+>V4L2_FIELD_SEQ_TB</CODE
+> and
+<CODE
+CLASS="CONSTANT"
+>V4L2_FIELD_SEQ_BT</CODE
+>, whether the top or bottom
+field is first in memory depends on the video standard). When this
+flag is set, the two fields are interlaced (cf.
+<CODE
+CLASS="CONSTANT"
+>V4L2_FIELD_INTERLACED</CODE
+>). The first line of the
+first field followed by the first line of the second field, then the
+two second lines, and so on. Such a layout may be necessary when the
+hardware has been programmed to capture or output interlaced video
+images and is unable to separate the fields for VBI capturing at
+the same time. For simplicity setting this flag implies that both
+<CODE
+CLASS="STRUCTFIELD"
+>count</CODE
+> values are equal and non-zero.</TD
+></TR
+></TBODY
+><TR
+><TD
+COLSPAN="3"
+>Notes:<BR><A
+NAME="FTN.AEN4526"
+>a. </A
+>Most VBI services transmit on both fields, but
+some have different semantics depending on the field number. These
+cannot be reliable decoded or encoded when
+<CODE
+CLASS="CONSTANT"
+>V4L2_VBI_UNSYNC</CODE
+> is set.<BR></TD
+></TR
+></TABLE
+></DIV
+><DIV
+CLASS="FIGURE"
+><A
+NAME="VBI-HSYNC"
+></A
+><P
+><B
+>Figure 4-1. Line synchronization</B
+></P
+><DIV
+CLASS="MEDIAOBJECT"
+><P
+><IMG
+SRC="vbi_hsync.gif"></P
+></DIV
+></DIV
+><DIV
+CLASS="FIGURE"
+><A
+NAME="VBI-525"
+></A
+><P
+><B
+>Figure 4-2. ITU-R 525 line numbering (M/NTSC and M/PAL)</B
+></P
+><DIV
+CLASS="MEDIAOBJECT"
+><P
+><IMG
+SRC="vbi_525.gif"><DIV
+CLASS="CAPTION"
+><P
+>(1) For the purpose of this specification field 2
+starts in line 264 and not 263.5 because half line capturing is not
+supported.</P
+></DIV
+></P
+></DIV
+></DIV
+><DIV
+CLASS="FIGURE"
+><A
+NAME="VBI-625"
+></A
+><P
+><B
+>Figure 4-3. ITU-R 625 line numbering</B
+></P
+><DIV
+CLASS="MEDIAOBJECT"
+><P
+><IMG
+SRC="vbi_625.gif"><DIV
+CLASS="CAPTION"
+><P
+>(1) For the purpose of this specification field 2
+starts in line 314 and not 313.5 because half line capturing is not
+supported.</P
+></DIV
+></P
+></DIV
+></DIV
+><P
+>Remember the VBI image format depends on the selected
+video standard, therefore the application must choose a new standard or
+query the current standard first. Attempts to read or write data ahead
+of format negotiation, or after switching the video standard which may
+invalidate the negotiated VBI parameters, should be refused by the
+driver. A format change during active I/O is not permitted.</P
+></DIV
+><DIV
+CLASS="SECTION"
+><HR><H3
+CLASS="SECTION"
+><A
+NAME="AEN4571"
+>4.6.4. Reading and writing VBI images</A
+></H3
+><P
+>To assure synchronization with the field number and easier
+implementation, the smallest unit of data passed at a time is one
+frame, consisting of two fields of VBI images immediately following in
+memory.</P
+><P
+>The total size of a frame computes as follows:</P
+><PRE
+CLASS="PROGRAMLISTING"
+>(<CODE
+CLASS="STRUCTFIELD"
+>count</CODE
+>[0] + <CODE
+CLASS="STRUCTFIELD"
+>count</CODE
+>[1]) *
+<CODE
+CLASS="STRUCTFIELD"
+>samples_per_line</CODE
+> * sample size in bytes</PRE
+><P
+>The sample size is most likely always one byte,
+applications must check the <CODE
+CLASS="STRUCTFIELD"
+>sample_format</CODE
+>
+field though, to function properly with other drivers.</P
+><P
+>A VBI device may support <A
+HREF="#RW"
+>read/write</A
+> and/or streaming (<A
+HREF="#MMAP"
+>memory mapping</A
+> or <A
+HREF="#USERP"
+>user pointer</A
+>) I/O. The latter bears the
+possibility of synchronizing video and
+VBI data by using buffer timestamps.</P
+><P
+>Remember the <A
+HREF="#VIDIOC-STREAMON"
+><CODE
+CLASS="CONSTANT"
+>VIDIOC_STREAMON</CODE
+></A
+> ioctl and the first read(),
+write() and select() call can be resource allocation points returning
+an <SPAN
+CLASS="ERRORCODE"
+>EBUSY</SPAN
+> error code if the required hardware resources are temporarily
+unavailable, for example the device is already in use by another
+process.</P
+></DIV
+></DIV
+><DIV
+CLASS="SECTION"
+><HR><H2
+CLASS="SECTION"
+><A
+NAME="SLICED"
+>4.7. Sliced VBI Data Interface</A
+></H2
+><DIV
+CLASS="NOTE"
+><BLOCKQUOTE
+CLASS="NOTE"
+><P
+><B
+>Proposal: </B
+>This interface is not yet implemented in v4l2.</P
+></BLOCKQUOTE
+></DIV
+><P
+>Sliced VBI data is VBI data after demodulation by hardware
+decoders. Kernel drivers shall not convert to or from raw VBI data by
+software. The data is passed as short packets of fixed size covering
+one scan line each. The number of packets per frame is variable.</P
+><P
+>Sliced VBI input and output devices are accessed through the
+same character special files as raw VBI devices. Note the default
+function of a <TT
+CLASS="FILENAME"
+>/dev/vbi</TT
+> device is raw VBI
+capturing or output. The sliced VBI function is only available after
+calling the <A
+HREF="#VIDIOC-G-FMT"
+><CODE
+CLASS="CONSTANT"
+>VIDIOC_S_FMT</CODE
+></A
+> ioctl.</P
+><DIV
+CLASS="SECTION"
+><HR><H3
+CLASS="SECTION"
+><A
+NAME="AEN4599"
+>4.7.1. Querying Capabilities</A
+></H3
+><P
+>Devices supporting the sliced VBI capturing or output API
+set the <CODE
+CLASS="CONSTANT"
+>V4L2_CAP_SLICED_VBI_CAPTURE</CODE
+> or
+<CODE
+CLASS="CONSTANT"
+>V4L2_CAP_SLICED_VBI_OUTPUT</CODE
+> flags in the
+<CODE
+CLASS="STRUCTFIELD"
+>capabilities</CODE
+> field of struct&nbsp;<A
+HREF="#V4L2-CAPABILITY"
+>v4l2_capability</A
+>
+returned by the <A
+HREF="#VIDIOC-QUERYCAP"
+><CODE
+CLASS="CONSTANT"
+>VIDIOC_QUERYCAP</CODE
+></A
+>. At least one of the read/write,
+streaming or asynchronous I/O methods must be supported. VBI devices
+may have a tuner or modulator.</P
+></DIV
+><DIV
+CLASS="SECTION"
+><HR><H3
+CLASS="SECTION"
+><A
+NAME="AEN4608"
+>4.7.2. Supplemental Functions</A
+></H3
+><P
+>VBI devices shall support <A
+HREF="#VIDEO"
+>video
+input or output</A
+>, <A
+HREF="#TUNER"
+>tuner or
+modulator</A
+>, and <A
+HREF="#CONTROL"
+>controls</A
+> ioctls
+as needed. The <A
+HREF="#STANDARD"
+>video standard</A
+> provide
+information vital to program a VBI device, therefore must be
+supported.</P
+></DIV
+><DIV
+CLASS="SECTION"
+><HR><H3
+CLASS="SECTION"
+><A
+NAME="AEN4615"
+>4.7.3. Sliced VBI Format Negotiation</A
+></H3
+><P
+>To determine which data services are supported by the
+hardware and which are desired by the application, the driver and application have to
+negotiate the sliced VBI data format.</P
+><P
+>After setting the <CODE
+CLASS="STRUCTFIELD"
+>type</CODE
+> field of
+struct&nbsp;<A
+HREF="#V4L2-FORMAT"
+>v4l2_format</A
+> to <CODE
+CLASS="CONSTANT"
+>V4L2_BUF_TYPE_SLICED_VBI_CAPTURE</CODE
+>
+or <CODE
+CLASS="CONSTANT"
+>V4L2_BUF_TYPE_SLICED_VBI_OUTPUT</CODE
+>, a
+<A
+HREF="#VIDIOC-G-FMT"
+><CODE
+CLASS="CONSTANT"
+>VIDIOC_G_FMT</CODE
+></A
+> fills the struct <CODE
+CLASS="STRUCTNAME"
+>v4l2_sliced_vbi_format</CODE
+>
+<CODE
+CLASS="STRUCTFIELD"
+>sliced</CODE
+> member of the
+<CODE
+CLASS="STRUCTFIELD"
+>fmt</CODE
+> union of a struct&nbsp;<A
+HREF="#V4L2-FORMAT"
+>v4l2_format</A
+>.</P
+><P
+>Applications can request different parameters by
+initializing or modifying the <CODE
+CLASS="STRUCTFIELD"
+>sliced</CODE
+> member
+and calling the <A
+HREF="#VIDIOC-G-FMT"
+><CODE
+CLASS="CONSTANT"
+>VIDIOC_S_FMT</CODE
+></A
+> ioctl with a pointer to the
+<CODE
+CLASS="STRUCTNAME"
+>v4l2_format</CODE
+> structure. <SPAN
+CLASS="emphasis"
+><I
+CLASS="EMPHASIS"
+>All fields
+of struct <CODE
+CLASS="STRUCTNAME"
+>v4l2_vbi_format</CODE
+> must be
+initialized</I
+></SPAN
+>. Drivers return an <SPAN
+CLASS="ERRORCODE"
+>EINVAL</SPAN
+> error code only when
+the given parameters are ambiguous, otherwise they modify the
+parameters according to the hardware capabilites. When the driver
+allocates resources at this point, it may return an <SPAN
+CLASS="ERRORCODE"
+>EBUSY</SPAN
+> error code to
+indicate the returned parameters are valid but the required resources
+are currently not available. Applications must expect other resource
+allocation points which may return <SPAN
+CLASS="ERRORCODE"
+>EBUSY</SPAN
+> at the
+<A
+HREF="#VIDIOC-STREAMON"
+><CODE
+CLASS="CONSTANT"
+>VIDIOC_STREAMON</CODE
+></A
+> ioctl and the first read(), write() and select()
+call. Different file descriptors must be used to pass raw and sliced
+VBI data simultaneously, if this is supported by the driver.</P
+><DIV
+CLASS="TABLE"
+><A
+NAME="V4L2-SLICED-VBI-FORMAT"
+></A
+><P
+><B
+>Table 4-6. struct <CODE
+CLASS="STRUCTNAME"
+>v4l2_sliced_vbi_format</CODE
+></B
+></P
+><TABLE
+BORDER="0"
+FRAME="void"
+WIDTH="100%"
+CLASS="CALSTABLE"
+><COL
+WIDTH="25%"
+TITLE="C1"><COL
+WIDTH="25%"
+TITLE="C2"><COL
+WIDTH="50%"
+TITLE="C3"><TBODY
+><TR
+><TD
+>__u32</TD
+><TD
+><CODE
+CLASS="STRUCTFIELD"
+>service_set</CODE
+></TD
+><TD
+>A set of symbols defining which types of data
+packets are passed. See <A
+HREF="#SLICED-VBI-TYPES"
+>Table 4-8</A
+> for details.</TD
+></TR
+><TR
+><TD
+>__u32</TD
+><TD
+><CODE
+CLASS="STRUCTFIELD"
+>packet_size</CODE
+></TD
+><TD
+><P
+>The size of each type of packet is fixed,
+however when different types of packets are exchanged between driver
+and application their size can vary. This value defines the size of
+the largest packet (struct <A
+HREF="#V4L2-SLICED-DATA"
+>v4l2_sliced_data</A
+>) that will be
+passed, smaller packets must be padded accordingly. When the
+architecture requires special alignment of __u32 quantities the driver
+shall round up <CODE
+CLASS="STRUCTFIELD"
+>packet_size </CODE
+> as
+necessary.</P
+></TD
+></TR
+><TR
+><TD
+>__u32</TD
+><TD
+><CODE
+CLASS="STRUCTFIELD"
+>io_size</CODE
+></TD
+><TD
+>Maximum number of bytes passed by one <CODE
+CLASS="FUNCTION"
+>read()</CODE
+> or
+<CODE
+CLASS="FUNCTION"
+>write()</CODE
+> call, and the buffer size in bytes for the <A
+HREF="#VIDIOC-QBUF"
+><CODE
+CLASS="CONSTANT"
+>VIDIOC_QBUF</CODE
+></A
+> and
+<A
+HREF="#VIDIOC-QBUF"
+><CODE
+CLASS="CONSTANT"
+>VIDIOC_DQBUF</CODE
+></A
+> ioctl. Usually this will be
+<CODE
+CLASS="STRUCTFIELD"
+>packet_size</CODE
+> times the number of scan lines
+potentially containing the data in question. On input, applications
+should set this field to zero and accept the value proposed by the
+driver.</TD
+></TR
+><TR
+><TD
+>__u32</TD
+><TD
+><CODE
+CLASS="STRUCTFIELD"
+>reserved</CODE
+></TD
+><TD
+>Applications and drivers must set this field to
+zero.</TD
+></TR
+></TBODY
+></TABLE
+></DIV
+><DIV
+CLASS="TABLE"
+><A
+NAME="V4L2-SLICED-DATA"
+></A
+><P
+><B
+>Table 4-7. struct <CODE
+CLASS="STRUCTNAME"
+>v4l2_sliced_data</CODE
+></B
+></P
+><TABLE
+BORDER="0"
+FRAME="void"
+WIDTH="100%"
+CLASS="CALSTABLE"
+><COL
+WIDTH="38%"
+TITLE="C1"><COL
+WIDTH="12%"
+TITLE="C2"><COL
+WIDTH="50%"
+TITLE="C3"><TBODY
+><TR
+><TD
+>__u32</TD
+><TD
+><CODE
+CLASS="STRUCTFIELD"
+>id</CODE
+></TD
+><TD
+>One of the symbols in <A
+HREF="#SLICED-VBI-TYPES"
+>Table 4-8</A
+> defining the type of data in this packet. A
+value of zero indicates an empty packet with no payload, in this case
+<CODE
+CLASS="STRUCTFIELD"
+>line</CODE
+> and <CODE
+CLASS="STRUCTFIELD"
+>data</CODE
+>
+are undefined.</TD
+></TR
+><TR
+><TD
+>__u32</TD
+><TD
+><CODE
+CLASS="STRUCTFIELD"
+>line</CODE
+></TD
+><TD
+>The scanning system line number this data has
+been captured from, or shall be inserted at. See <A
+HREF="#VBI-525"
+>Figure 4-2</A
+>
+and <A
+HREF="#VBI-625"
+>Figure 4-3</A
+> for valid values. Sliced VBI input drivers
+can set the line number of all packets to <CODE
+CLASS="CONSTANT"
+>0</CODE
+> if
+the hardware cannot reliable identify scan lines.</TD
+></TR
+><TR
+><TD
+>__u8</TD
+><TD
+><CODE
+CLASS="STRUCTFIELD"
+>data</CODE
+>[]</TD
+><TD
+>The packet payload. See <A
+HREF="#SLICED-VBI-TYPES"
+>Table 4-8</A
+> for the contents and number of bytes passed
+for each data type. The contents of padding bytes following up to
+<CODE
+CLASS="STRUCTFIELD"
+>packet_size</CODE
+> is undefined.</TD
+></TR
+></TBODY
+></TABLE
+></DIV
+><DIV
+CLASS="TABLE"
+><A
+NAME="SLICED-VBI-TYPES"
+></A
+><P
+><B
+>Table 4-8. Sliced VBI data formats</B
+></P
+><TABLE
+BORDER="1"
+WIDTH="100%"
+CLASS="CALSTABLE"
+><COL><COL><COL><COL><THEAD
+><TR
+><TH
+>Symbol</TH
+><TH
+>Reference</TH
+><TH
+>Lines, usually</TH
+><TH
+>Payload</TH
+></TR
+></THEAD
+><TBODY
+><TR
+><TD
+>V4L2_SLICED_TELETEXT_B (Teletext System B)</TD
+><TD
+><A
+HREF="#TELETEXT"
+><ABBR
+CLASS="ABBREV"
+>TELETEXT</ABBR
+></A
+></TD
+><TD
+>PAL/SECAM line 6-22, 318-335</TD
+><TD
+>Last 42 of the 45 byte Teletext packet, that is
+without clock run-in and framing code, lsb first transmitted.</TD
+></TR
+><TR
+><TD
+>V4L2_SLICED_VPS</TD
+><TD
+><A
+HREF="#VPS"
+><ABBR
+CLASS="ABBREV"
+>VPS</ABBR
+></A
+></TD
+><TD
+>PAL line 16</TD
+><TD
+>Byte number 3 to 15 according to Figure 9 of ETS
+300 231, lsb first transmitted.</TD
+></TR
+><TR
+><TD
+>V4L2_SLICED_CAPTION_625</TD
+><TD
+><A
+HREF="#EIA608"
+><ABBR
+CLASS="ABBREV"
+>EIA608</ABBR
+></A
+></TD
+><TD
+>PAL line 22 (?)</TD
+><TD
+>First and second byte including parity bit, lsb
+first transmitted.</TD
+></TR
+><TR
+><TD
+>V4L2_SLICED_WSS_625</TD
+><TD
+><A
+HREF="#WSS"
+><ABBR
+CLASS="ABBREV"
+>WSS</ABBR
+></A
+></TD
+><TD
+>PAL/SECAM line 23</TD
+><TD
+><PRE
+CLASS="SCREEN"
+>Byte 0 1
+ msb lsb msb lsb
+Bit 7 6 5 4 3 2 1 0 x x 13 12 11 10 9</PRE
+></TD
+></TR
+><TR
+><TD
+>V4L2_SLICED_CAPTION_525</TD
+><TD
+><A
+HREF="#EIA608"
+><ABBR
+CLASS="ABBREV"
+>EIA608</ABBR
+></A
+></TD
+><TD
+>NTSC line 21, 284</TD
+><TD
+>First and second byte including parity bit, lsb
+first transmitted.</TD
+></TR
+><TR
+><TD
+>V4L2_SLICED_RESERVED</TD
+><TD
+>&nbsp;</TD
+><TD
+>undefined</TD
+><TD
+>undefined</TD
+></TR
+></TBODY
+></TABLE
+></DIV
+><P
+>Remember the VBI image format depends on the selected
+video standard, therefore the application must choose a new standard or
+query the current standard first. Attempts to read or write data ahead
+of format negotiation, or after switching the video standard which may
+invalidate the negotiated VBI parameters, should be refused by the
+driver. A format change is not permitted during active i/o.</P
+></DIV
+><DIV
+CLASS="SECTION"
+><HR><H3
+CLASS="SECTION"
+><A
+NAME="AEN4760"
+>4.7.4. Reading and writing sliced VBI data</A
+></H3
+><P
+>The smallest unit of data passed at a time is one sliced
+data packet. Within the bounds of <CODE
+CLASS="STRUCTFIELD"
+>io_size</CODE
+>
+multiple packets can (and should) be passed, but no more than one
+frame at a time (to keep the processing time low, for example from
+reception to display of subtitles). Packets are always passed in
+ascending line number order, without duplicate line numbers. If the
+line numbers are unknown the driver must pass the packets in
+transmitted order. Empty packets with <CODE
+CLASS="STRUCTFIELD"
+>id</CODE
+>
+set to zero can be inserted anywhere.</P
+><P
+>To assure synchronization and to distinguish from frame
+dropping, when one frame does not contain any data in question one or
+more empty packets must be passed. In streaming I/O mode one buffer of
+<CODE
+CLASS="STRUCTFIELD"
+>io_size</CODE
+> shall coincide with one video
+frame. The <CODE
+CLASS="STRUCTFIELD"
+>id</CODE
+> of unused packets must be
+zero.</P
+><P
+>A sliced VBI device may support <A
+HREF="#RW"
+>read/write</A
+> and/or streaming (<A
+HREF="#MMAP"
+>memory mapping</A
+> or <A
+HREF="#USERP"
+>user pointer</A
+>) I/O. The latter bears the
+possibility of synchronizing video and VBI data by using buffer
+timestamps.</P
+><P
+>Remember the <A
+HREF="#VIDIOC-STREAMON"
+><CODE
+CLASS="CONSTANT"
+>VIDIOC_STREAMON</CODE
+></A
+> ioctl and the first read(),
+write() and select() call can be resource allocation points returning
+an <SPAN
+CLASS="ERRORCODE"
+>EBUSY</SPAN
+> error code if the required hardware resources are temporarily
+unavailable, for example the device is already in use by another
+process.</P
+></DIV
+></DIV
+><DIV
+CLASS="SECTION"
+><HR><H2
+CLASS="SECTION"
+><A
+NAME="TTX"
+>4.8. Teletext Interface</A
+></H2
+><P
+>This interface aims at devices receiving and demodulating
+Teletext data [<A
+HREF="#TELETEXT"
+><ABBR
+CLASS="ABBREV"
+>TELETEXT</ABBR
+></A
+>], evaluating the
+Teletext packages and storing formatted pages in cache memory. Such
+devices are usually implemented as microcontrollers with serial
+interface (I<SUP
+>2</SUP
+>C) and can be found on older
+TV cards, dedicated Teletext decoding cards and home-brew devices
+connected to the PC parallel port.</P
+><P
+>The Teletext API was designed by Martin Buck. It is defined in
+the kernel header file <TT
+CLASS="FILENAME"
+>linux/videotext.h</TT
+>, the
+specification is available from <A
+HREF="http://home.pages.de/~videotext/"
+TARGET="_top"
+>http://home.pages.de/~videotext/</A
+>. (Videotext is the name of
+the German public television Teletext service.) Conventional character
+device file names are <TT
+CLASS="FILENAME"
+>/dev/vtx</TT
+> and
+<TT
+CLASS="FILENAME"
+>/dev/vttuner</TT
+>, with device number 83, 0 and 83, 16
+respectively. A similar interface exists for the Philips SAA5249
+Teletext decoder [specification?] with character device file names
+<TT
+CLASS="FILENAME"
+>/dev/tlkN</TT
+>, device number 102, N.</P
+><P
+>Eventually the Teletext API was integrated into the V4L API
+with character device file names <TT
+CLASS="FILENAME"
+>/dev/vtx0</TT
+> to
+<TT
+CLASS="FILENAME"
+>/dev/vtx31</TT
+>, device major number 81, minor numbers
+192 to 223. For reference the V4L Teletext API specification is
+reproduced here in full: "Teletext interfaces talk the existing VTX
+API." Teletext devices with major number 83 and 102 will be removed in
+Linux 2.6.</P
+><P
+>There are no plans to replace the Teletext API or to integrate
+it into V4L2. Please write to the Video4Linux mailing list: <A
+HREF="https://listman.redhat.com/mailman/listinfo/video4linux-list"
+TARGET="_top"
+>https://listman.redhat.com/mailman/listinfo/video4linux-list</A
+>
+when the need arises.</P
+></DIV
+><DIV
+CLASS="SECTION"
+><HR><H2
+CLASS="SECTION"
+><A
+NAME="RADIO"
+>4.9. Radio Interface</A
+></H2
+><P
+>This interface is intended for AM and FM (analog) radio
+receivers.</P
+><P
+>Conventionally V4L2 radio devices are accessed through
+character device special files named <TT
+CLASS="FILENAME"
+>/dev/radio</TT
+>
+and <TT
+CLASS="FILENAME"
+>/dev/radio0</TT
+> to
+<TT
+CLASS="FILENAME"
+>/dev/radio63</TT
+> with major number 81 and minor
+numbers 64 to 127.</P
+><DIV
+CLASS="SECTION"
+><HR><H3
+CLASS="SECTION"
+><A
+NAME="AEN4799"
+>4.9.1. Querying Capabilities</A
+></H3
+><P
+>Devices supporting the radio interface set the
+<CODE
+CLASS="CONSTANT"
+>V4L2_CAP_RADIO</CODE
+> and
+<CODE
+CLASS="CONSTANT"
+>V4L2_CAP_TUNER</CODE
+> flag in the
+<CODE
+CLASS="STRUCTFIELD"
+>capabilities</CODE
+> field of struct&nbsp;<A
+HREF="#V4L2-CAPABILITY"
+>v4l2_capability</A
+>
+returned by the <A
+HREF="#VIDIOC-QUERYCAP"
+><CODE
+CLASS="CONSTANT"
+>VIDIOC_QUERYCAP</CODE
+></A
+> ioctl. Other combinations of
+capability flags are reserved for future extensions.</P
+></DIV
+><DIV
+CLASS="SECTION"
+><HR><H3
+CLASS="SECTION"
+><A
+NAME="AEN4808"
+>4.9.2. Supplemental Functions</A
+></H3
+><P
+>Radio devices can support <A
+HREF="#CONTROL"
+>controls</A
+>, and must support the <A
+HREF="#TUNER"
+>tuner</A
+> ioctls.</P
+><P
+>They do not support the video input or output, audio input
+or output, video standard, cropping and scaling, compression and
+streaming parameter, or overlay ioctls. All other ioctls and I/O
+methods are reserved for future extensions.</P
+></DIV
+><DIV
+CLASS="SECTION"
+><HR><H3
+CLASS="SECTION"
+><A
+NAME="AEN4814"
+>4.9.3. Programming</A
+></H3
+><P
+>Radio devices may have a couple audio controls (as discussed
+in <A
+HREF="#CONTROL"
+>Section 1.8</A
+>) such as a volume control, possibly custom
+controls. Further all radio devices have one tuner (these are
+discussed in <A
+HREF="#TUNER"
+>Section 1.6</A
+>) with index number zero to select
+the radio frequency and to determine if a monaural or FM stereo
+program is received. Drivers switch automatically between AM and FM
+depending on the selected frequency. The <A
+HREF="#VIDIOC-G-TUNER"
+><CODE
+CLASS="CONSTANT"
+>VIDIOC_G_TUNER</CODE
+></A
+> ioctl
+reports the supported frequency range.</P
+></DIV
+></DIV
+><DIV
+CLASS="SECTION"
+><HR><H2
+CLASS="SECTION"
+><A
+NAME="RDS"
+>4.10. RDS Interface</A
+></H2
+><P
+>The Radio Data System transmits supplementary
+information in binary format, for example the station name or travel
+information, on a inaudible audio subcarrier of a radio program. This
+interface aims at devices capable of receiving and decoding RDS
+information.</P
+><P
+>The V4L API defines its RDS API as follows.</P
+><P
+>From radio devices supporting it, RDS data can be
+read with the <CODE
+CLASS="FUNCTION"
+>read()</CODE
+> function. The data is packed
+in groups of three, as follows:<P
+></P
+><OL
+TYPE="1"
+><LI
+><P
+>First Octet Least Significant Byte of RDS
+Block</P
+></LI
+><LI
+><P
+>Second Octet Most Significant Byte of RDS
+Block</P
+></LI
+><LI
+><P
+>Third Octet Bit 7: Error bit. Indicates that an
+uncorrectable error occurred during reception of this block. Bit 6:
+Corrected bit. Indicates that an error was corrected for this data
+block. Bits 5-3: Received Offset. Indicates the offset received by the
+sync system. Bits 2-0: Offset Name. Indicates the offset applied to
+this data.</P
+></LI
+></OL
+></P
+><P
+>It was argued <SPAN
+CLASS="COMMENT"
+>video4linux-list@redhat.com
+on 12 Nov 2002, subject "RDS/RBDS"</SPAN
+> the RDS API should be
+extended before integration into V4L2, no new API has been devised yet.
+Please write to the Video4Linux mailing list for discussion: <A
+HREF="https://listman.redhat.com/mailman/listinfo/video4linux-list"
+TARGET="_top"
+>https://listman.redhat.com/mailman/listinfo/video4linux-list</A
+>.
+Meanwhile no V4L2 driver should set the
+<CODE
+CLASS="CONSTANT"
+>V4L2_CAP_RDS_CAPTURE</CODE
+> capability flag.</P
+></DIV
+></DIV
+><DIV
+CLASS="REFERENCE"
+><A
+NAME="USER-FUNC"
+></A
+><DIV
+CLASS="TITLEPAGE"
+><H1
+CLASS="TITLE"
+>I. Function Reference</H1
+><DIV
+CLASS="TOC"
+><DL
+><DT
+><B
+>Table of Contents</B
+></DT
+><DT
+><A
+HREF="#FUNC-CLOSE"
+>close</A
+>&nbsp;--&nbsp;Close a V4L2 device</DT
+><DT
+><A
+HREF="#FUNC-IOCTL"
+>ioctl</A
+>&nbsp;--&nbsp;Program a V4L2 device</DT
+><DT
+><A
+HREF="#VIDIOC-CROPCAP"
+>ioctl VIDIOC_CROPCAP</A
+>&nbsp;--&nbsp;Information about the video cropping and scaling abilities.</DT
+><DT
+><A
+HREF="#VIDIOC-ENUMAUDIO"
+>ioctl VIDIOC_ENUMAUDIO</A
+>&nbsp;--&nbsp;Enumerate audio inputs</DT
+><DT
+><A
+HREF="#VIDIOC-ENUMAUDIOOUT"
+>ioctl VIDIOC_ENUMAUDOUT</A
+>&nbsp;--&nbsp;Enumerate audio outputs</DT
+><DT
+><A
+HREF="#VIDIOC-ENUM-FMT"
+>ioctl VIDIOC_ENUM_FMT</A
+>&nbsp;--&nbsp;Enumerate image formats</DT
+><DT
+><A
+HREF="#VIDIOC-ENUMINPUT"
+>ioctl VIDIOC_ENUMINPUT</A
+>&nbsp;--&nbsp;Enumerate video inputs</DT
+><DT
+><A
+HREF="#VIDIOC-ENUMOUTPUT"
+>ioctl VIDIOC_ENUMOUTPUT</A
+>&nbsp;--&nbsp;Enumerate video outputs</DT
+><DT
+><A
+HREF="#VIDIOC-ENUMSTD"
+>ioctl VIDIOC_ENUMSTD</A
+>&nbsp;--&nbsp;Enumerate supported video standards</DT
+><DT
+><A
+HREF="#VIDIOC-G-AUDIO"
+>ioctl VIDIOC_G_AUDIO, VIDIOC_S_AUDIO</A
+>&nbsp;--&nbsp;Query or select the current audio input and its
+attributes</DT
+><DT
+><A
+HREF="#VIDIOC-G-AUDIOOUT"
+>ioctl VIDIOC_G_AUDOUT, VIDIOC_S_AUDOUT</A
+>&nbsp;--&nbsp;Query or select the current audio output</DT
+><DT
+><A
+HREF="#VIDIOC-G-COMP"
+>ioctl VIDIOC_G_COMP, VIDIOC_S_COMP</A
+>&nbsp;--&nbsp;Get or set compression parameters</DT
+><DT
+><A
+HREF="#VIDIOC-G-CROP"
+>ioctl VIDIOC_G_CROP, VIDIOC_S_CROP</A
+>&nbsp;--&nbsp;Get or set the current cropping rectangle</DT
+><DT
+><A
+HREF="#VIDIOC-G-CTRL"
+>ioctl VIDIOC_G_CTRL, VIDIOC_S_CTRL</A
+>&nbsp;--&nbsp;Get or set the value of a control</DT
+><DT
+><A
+HREF="#VIDIOC-G-FBUF"
+>ioctl VIDIOC_G_FBUF, VIDIOC_S_FBUF</A
+>&nbsp;--&nbsp;Get or set frame buffer overlay parameters.</DT
+><DT
+><A
+HREF="#VIDIOC-G-FMT"
+>ioctl VIDIOC_G_FMT, VIDIOC_S_FMT, VIDIOC_TRY_FMT</A
+>&nbsp;--&nbsp;Get or set the data format, try a format.</DT
+><DT
+><A
+HREF="#VIDIOC-G-FREQUENCY"
+>ioctl VIDIOC_G_FREQUENCY, VIDIOC_S_FREQUENCY</A
+>&nbsp;--&nbsp;Get or set tuner or modulator radio
+frequency</DT
+><DT
+><A
+HREF="#VIDIOC-G-INPUT"
+>ioctl VIDIOC_G_INPUT, VIDIOC_S_INPUT</A
+>&nbsp;--&nbsp;Query or select the current video input</DT
+><DT
+><A
+HREF="#VIDIOC-G-JPEGCOMP"
+>ioctl VIDIOC_G_JPEGCOMP, VIDIOC_S_JPEGCOMP</A
+>&nbsp;--&nbsp;</DT
+><DT
+><A
+HREF="#VIDIOC-G-MODULATOR"
+>ioctl VIDIOC_G_MODULATOR, VIDIOC_S_MODULATOR</A
+>&nbsp;--&nbsp;Get or set modulator attributes</DT
+><DT
+><A
+HREF="#VIDIOC-G-OUTPUT"
+>ioctl VIDIOC_G_OUTPUT, VIDIOC_S_OUTPUT</A
+>&nbsp;--&nbsp;Query or select the current video output</DT
+><DT
+><A
+HREF="#VIDIOC-G-PARM"
+>ioctl VIDIOC_G_PARM, VIDIOC_S_PARM</A
+>&nbsp;--&nbsp;Get or set streaming parameters</DT
+><DT
+><A
+HREF="#VIDIOC-G-PRIORITY"
+>ioctl VIDIOC_G_PRIORITY, VIDIOC_S_PRIORITY</A
+>&nbsp;--&nbsp;Query or request the access priority associated with a
+file descriptor</DT
+><DT
+><A
+HREF="#VIDIOC-G-STD"
+>ioctl VIDIOC_G_STD, VIDIOC_S_STD</A
+>&nbsp;--&nbsp;Query or select the video standard of the current input</DT
+><DT
+><A
+HREF="#VIDIOC-G-TUNER"
+>ioctl VIDIOC_G_TUNER, VIDIOC_S_TUNER</A
+>&nbsp;--&nbsp;Get or set tuner attributes</DT
+><DT
+><A
+HREF="#VIDIOC-OVERLAY"
+>ioctl VIDIOC_OVERLAY</A
+>&nbsp;--&nbsp;Start or stop video overlay</DT
+><DT
+><A
+HREF="#VIDIOC-QBUF"
+>ioctl VIDIOC_QBUF, VIDIOC_DQBUF</A
+>&nbsp;--&nbsp;Exchange a buffer with the driver</DT
+><DT
+><A
+HREF="#VIDIOC-QUERYBUF"
+>ioctl VIDIOC_QUERYBUF</A
+>&nbsp;--&nbsp;Query the status of a buffer</DT
+><DT
+><A
+HREF="#VIDIOC-QUERYCAP"
+>ioctl VIDIOC_QUERYCAP</A
+>&nbsp;--&nbsp;Query device capabilities</DT
+><DT
+><A
+HREF="#VIDIOC-QUERYCTRL"
+>ioctl VIDIOC_QUERYCTRL, VIDIOC_QUERYMENU</A
+>&nbsp;--&nbsp;Enumerate controls and menu control items</DT
+><DT
+><A
+HREF="#VIDIOC-QUERYSTD"
+>ioctl VIDIOC_QUERYSTD</A
+>&nbsp;--&nbsp;Sense the video standard received by the current input</DT
+><DT
+><A
+HREF="#VIDIOC-REQBUFS"
+>ioctl VIDIOC_REQBUFS</A
+>&nbsp;--&nbsp;Initiate Memory Mapping or User Pointer I/O</DT
+><DT
+><A
+HREF="#VIDIOC-STREAMON"
+>ioctl VIDIOC_STREAMON, VIDIOC_STREAMOFF</A
+>&nbsp;--&nbsp;Start or stop streaming I/O.</DT
+><DT
+><A
+HREF="#FUNC-MMAP"
+>mmap</A
+>&nbsp;--&nbsp;Map device memory into application address space</DT
+><DT
+><A
+HREF="#FUNC-MUNMAP"
+>munmap</A
+>&nbsp;--&nbsp;Unmap device memory</DT
+><DT
+><A
+HREF="#FUNC-OPEN"
+>open</A
+>&nbsp;--&nbsp;Open a V4L2 device</DT
+><DT
+><A
+HREF="#FUNC-POLL"
+>poll</A
+>&nbsp;--&nbsp;Wait for some event on a file descriptor</DT
+><DT
+><A
+HREF="#FUNC-READ"
+>read</A
+>&nbsp;--&nbsp;Read from a V4L2 device</DT
+><DT
+><A
+HREF="#FUNC-SELECT"
+>select</A
+>&nbsp;--&nbsp;Synchronous I/O multiplexing</DT
+><DT
+><A
+HREF="#FUNC-WRITE"
+>write</A
+>&nbsp;--&nbsp;Write to a V4L2 device</DT
+></DL
+></DIV
+></DIV
+><H1
+><A
+NAME="FUNC-CLOSE"
+></A
+>close</H1
+><DIV
+CLASS="REFNAMEDIV"
+><A
+NAME="AEN4841"
+></A
+><H2
+>Name</H2
+>close&nbsp;--&nbsp;Close a V4L2 device</DIV
+><DIV
+CLASS="REFSYNOPSISDIV"
+><A
+NAME="AEN4844"
+></A
+><H2
+>Synopsis</H2
+><DIV
+CLASS="FUNCSYNOPSIS"
+><P
+></P
+><A
+NAME="AEN4845"
+></A
+><PRE
+CLASS="FUNCSYNOPSISINFO"
+>#include &lt;unistd.h&gt;</PRE
+><P
+><CODE
+><CODE
+CLASS="FUNCDEF"
+>int close</CODE
+>(int fd);</CODE
+></P
+><P
+></P
+></DIV
+></DIV
+><DIV
+CLASS="REFSECT1"
+><A
+NAME="AEN4852"
+></A
+><H2
+>Arguments</H2
+><P
+></P
+><DIV
+CLASS="VARIABLELIST"
+><DL
+><DT
+><VAR
+CLASS="PARAMETER"
+>fd</VAR
+></DT
+><DD
+><P
+>File descriptor returned by <A
+HREF="#FUNC-OPEN"
+><CODE
+CLASS="FUNCTION"
+>open()</CODE
+></A
+>.</P
+></DD
+></DL
+></DIV
+></DIV
+><DIV
+CLASS="REFSECT1"
+><A
+NAME="AEN4862"
+></A
+><H2
+>Description</H2
+><P
+>Closes the device. Any I/O in progress is terminated and
+resources associated with the file descriptor are freed. However data
+format parameters, current input or output, control values or other
+properties remain unchanged.</P
+></DIV
+><DIV
+CLASS="REFSECT1"
+><A
+NAME="AEN4865"
+></A
+><H2
+>Return Value</H2
+><P
+>The function returns <SPAN
+CLASS="RETURNVALUE"
+>0</SPAN
+> on
+success, <SPAN
+CLASS="RETURNVALUE"
+>-1</SPAN
+> on failure and the
+<VAR
+CLASS="VARNAME"
+>errno</VAR
+> is set appropriately. Possible error
+codes:</P
+><P
+></P
+><DIV
+CLASS="VARIABLELIST"
+><DL
+><DT
+><SPAN
+CLASS="ERRORCODE"
+>EBADF</SPAN
+></DT
+><DD
+><P
+><VAR
+CLASS="PARAMETER"
+>fd</VAR
+> is not a valid open file
+descriptor.</P
+></DD
+></DL
+></DIV
+></DIV
+><H1
+><A
+NAME="FUNC-IOCTL"
+></A
+>ioctl</H1
+><DIV
+CLASS="REFNAMEDIV"
+><A
+NAME="AEN4879"
+></A
+><H2
+>Name</H2
+>ioctl&nbsp;--&nbsp;Program a V4L2 device</DIV
+><DIV
+CLASS="REFSYNOPSISDIV"
+><A
+NAME="AEN4882"
+></A
+><H2
+>Synopsis</H2
+><DIV
+CLASS="FUNCSYNOPSIS"
+><P
+></P
+><A
+NAME="AEN4883"
+></A
+><PRE
+CLASS="FUNCSYNOPSISINFO"
+>#include &lt;sys/ioctl.h&gt;</PRE
+><P
+><CODE
+><CODE
+CLASS="FUNCDEF"
+>int ioctl</CODE
+>(int fd, int request, void *argp);</CODE
+></P
+><P
+></P
+></DIV
+></DIV
+><DIV
+CLASS="REFSECT1"
+><A
+NAME="AEN4894"
+></A
+><H2
+>Arguments</H2
+><P
+></P
+><DIV
+CLASS="VARIABLELIST"
+><DL
+><DT
+><VAR
+CLASS="PARAMETER"
+>fd</VAR
+></DT
+><DD
+><P
+>File descriptor returned by <A
+HREF="#FUNC-OPEN"
+><CODE
+CLASS="FUNCTION"
+>open()</CODE
+></A
+>.</P
+></DD
+><DT
+><VAR
+CLASS="PARAMETER"
+>request</VAR
+></DT
+><DD
+><P
+>V4L2 ioctl request code as defined in the <A
+HREF="#VIDEODEV"
+>videodev.h</A
+> header file, for example
+VIDIOC_QUERYCAP.</P
+></DD
+><DT
+><VAR
+CLASS="PARAMETER"
+>argp</VAR
+></DT
+><DD
+><P
+>Pointer to a function parameter, usually a structure.</P
+></DD
+></DL
+></DIV
+></DIV
+><DIV
+CLASS="REFSECT1"
+><A
+NAME="AEN4915"
+></A
+><H2
+>Description</H2
+><P
+>The <CODE
+CLASS="FUNCTION"
+>ioctl()</CODE
+> function is used to program
+V4L2 devices. The argument <VAR
+CLASS="PARAMETER"
+>fd</VAR
+> must be an open
+file descriptor. An ioctl <VAR
+CLASS="PARAMETER"
+>request</VAR
+> has encoded
+in it whether the argument is an input, output or read/write
+parameter, and the size of the argument <VAR
+CLASS="PARAMETER"
+>argp</VAR
+> in
+bytes. Macros and defines specifying V4L2 ioctl requests are located
+in the <A
+HREF="#VIDEODEV"
+>videodev.h</A
+> header file.
+Applications should use their own copy, not include the version in the
+kernel sources on the system they compile on. All V4L2 ioctl requests,
+their respective function and parameters are specified in <A
+HREF="#USER-FUNC"
+>Reference I, <I
+>Function Reference</I
+></A
+>.</P
+></DIV
+><DIV
+CLASS="REFSECT1"
+><A
+NAME="AEN4924"
+></A
+><H2
+>Return Value</H2
+><P
+>On success the <CODE
+CLASS="FUNCTION"
+>ioctl()</CODE
+> function returns
+<SPAN
+CLASS="RETURNVALUE"
+>0</SPAN
+> and does not reset the
+<VAR
+CLASS="VARNAME"
+>errno</VAR
+> variable. On failure
+<SPAN
+CLASS="RETURNVALUE"
+>-1</SPAN
+> is returned, when the ioctl takes an
+output or read/write parameter it remains unmodified, and the
+<VAR
+CLASS="VARNAME"
+>errno</VAR
+> variable is set appropriately. See below for
+possible error codes. Generic errors like <SPAN
+CLASS="ERRORCODE"
+>EBADF</SPAN
+>
+or <SPAN
+CLASS="ERRORCODE"
+>EFAULT</SPAN
+> are not listed in the sections
+discussing individual ioctl requests.</P
+><P
+>Note ioctls may return undefined error codes. Since errors
+may have side effects such as a driver reset applications should
+abort on unexpected errors.</P
+><P
+></P
+><DIV
+CLASS="VARIABLELIST"
+><DL
+><DT
+><SPAN
+CLASS="ERRORCODE"
+>EBADF</SPAN
+></DT
+><DD
+><P
+><VAR
+CLASS="PARAMETER"
+>fd</VAR
+> is not a valid open file
+descriptor.</P
+></DD
+><DT
+><SPAN
+CLASS="ERRORCODE"
+>EBUSY</SPAN
+></DT
+><DD
+><P
+>The property cannot be changed right now. Typically
+this error code is returned when I/O is in progress or the driver
+supports multiple opens and another process locked the property.</P
+></DD
+><DT
+><SPAN
+CLASS="ERRORCODE"
+>EFAULT</SPAN
+></DT
+><DD
+><P
+><VAR
+CLASS="PARAMETER"
+>argp</VAR
+> references an inaccessible
+memory area.</P
+></DD
+><DT
+><SPAN
+CLASS="ERRORCODE"
+>ENOTTY</SPAN
+></DT
+><DD
+><P
+><VAR
+CLASS="PARAMETER"
+>fd</VAR
+> is not associated with a
+character special device.</P
+></DD
+><DT
+><SPAN
+CLASS="ERRORCODE"
+>EINVAL</SPAN
+></DT
+><DD
+><P
+>The <VAR
+CLASS="PARAMETER"
+>request</VAR
+> or the data pointed
+to by <VAR
+CLASS="PARAMETER"
+>argp</VAR
+> is not valid. This is a very common
+error code, see the individual ioctl requests listed in <A
+HREF="#USER-FUNC"
+>Reference I, <I
+>Function Reference</I
+></A
+> for actual causes.</P
+></DD
+><DT
+><SPAN
+CLASS="ERRORCODE"
+>ENOMEM</SPAN
+></DT
+><DD
+><P
+>Insufficient memory to complete the request.</P
+></DD
+><DT
+><SPAN
+CLASS="ERRORCODE"
+>ERANGE</SPAN
+></DT
+><DD
+><P
+>The application attempted to set a control with the
+<A
+HREF="#VIDIOC-G-CTRL"
+><CODE
+CLASS="CONSTANT"
+>VIDIOC_S_CTRL</CODE
+></A
+> ioctl to a value which is out of bounds.</P
+></DD
+></DL
+></DIV
+></DIV
+><H1
+><A
+NAME="VIDIOC-CROPCAP"
+></A
+>ioctl VIDIOC_CROPCAP</H1
+><DIV
+CLASS="REFNAMEDIV"
+><A
+NAME="AEN4980"
+></A
+><H2
+>Name</H2
+>ioctl VIDIOC_CROPCAP&nbsp;--&nbsp;Information about the video cropping and scaling abilities.</DIV
+><DIV
+CLASS="REFSYNOPSISDIV"
+><A
+NAME="AEN4983"
+></A
+><H2
+>Synopsis</H2
+><DIV
+CLASS="FUNCSYNOPSIS"
+><P
+></P
+><A
+NAME="AEN4984"
+></A
+><P
+><CODE
+><CODE
+CLASS="FUNCDEF"
+>int ioctl</CODE
+>(int fd, int request, struct v4l2_cropcap
+*argp);</CODE
+></P
+><P
+></P
+></DIV
+></DIV
+><DIV
+CLASS="REFSECT1"
+><A
+NAME="AEN4994"
+></A
+><H2
+>Arguments</H2
+><P
+></P
+><DIV
+CLASS="VARIABLELIST"
+><DL
+><DT
+><VAR
+CLASS="PARAMETER"
+>fd</VAR
+></DT
+><DD
+><P
+>File descriptor returned by <A
+HREF="#FUNC-OPEN"
+><CODE
+CLASS="FUNCTION"
+>open()</CODE
+></A
+>.</P
+></DD
+><DT
+><VAR
+CLASS="PARAMETER"
+>request</VAR
+></DT
+><DD
+><P
+>VIDIOC_CROPCAP</P
+></DD
+><DT
+><VAR
+CLASS="PARAMETER"
+>argp</VAR
+></DT
+><DD
+><P
+></P
+></DD
+></DL
+></DIV
+></DIV
+><DIV
+CLASS="REFSECT1"
+><A
+NAME="AEN5014"
+></A
+><H2
+>Description</H2
+><P
+>Applications use this function to query the cropping
+limits, the pixel aspect of images and to calculate scale factors.
+They set the <CODE
+CLASS="STRUCTFIELD"
+>type</CODE
+> field of a v4l2_cropcap
+structure to the respective buffer (stream) type and call the
+<CODE
+CLASS="CONSTANT"
+>VIDIOC_CROPCAP</CODE
+> ioctl with a pointer to this
+structure. Drivers fill the rest of the structure. The results are
+constant except when switching the video standard. Remember this
+switch can occur implicit when switching the video input or
+output.</P
+><DIV
+CLASS="TABLE"
+><A
+NAME="V4L2-CROPCAP"
+></A
+><P
+><B
+>Table 1. struct <CODE
+CLASS="STRUCTNAME"
+>v4l2_cropcap</CODE
+></B
+></P
+><TABLE
+BORDER="0"
+FRAME="void"
+WIDTH="100%"
+CLASS="CALSTABLE"
+><COL
+WIDTH="25%"
+TITLE="C1"><COL
+WIDTH="25%"
+TITLE="C2"><COL
+WIDTH="50%"
+TITLE="C3"><TBODY
+><TR
+><TD
+>enum&nbsp;<A
+HREF="#V4L2-BUF-TYPE"
+>v4l2_buf_type</A
+></TD
+><TD
+><CODE
+CLASS="STRUCTFIELD"
+>type</CODE
+></TD
+><TD
+>Type of the data stream, set by the application.
+Only these types are valid here:
+<CODE
+CLASS="CONSTANT"
+>V4L2_BUF_TYPE_VIDEO_CAPTURE</CODE
+>,
+<CODE
+CLASS="CONSTANT"
+>V4L2_BUF_TYPE_VIDEO_OUTPUT</CODE
+>,
+<CODE
+CLASS="CONSTANT"
+>V4L2_BUF_TYPE_VIDEO_OVERLAY</CODE
+>, and custom (driver
+defined) types with code <CODE
+CLASS="CONSTANT"
+>V4L2_BUF_TYPE_PRIVATE</CODE
+>
+and higher.</TD
+></TR
+><TR
+><TD
+>struct <A
+HREF="#V4L2-RECT-CROP"
+>v4l2_rect</A
+></TD
+><TD
+><CODE
+CLASS="STRUCTFIELD"
+>bounds</CODE
+></TD
+><TD
+>Defines the window within capturing or output is
+possible, this may exclude for example the horizontal and vertical
+blanking areas. The cropping rectangle cannot exceed these limits.
+Width and height are defined in pixels, the driver writer is free to
+choose origin and units of the coordinate system in the analog
+domain.</TD
+></TR
+><TR
+><TD
+>struct <A
+HREF="#V4L2-RECT-CROP"
+>v4l2_rect</A
+></TD
+><TD
+><CODE
+CLASS="STRUCTFIELD"
+>defrect</CODE
+></TD
+><TD
+>Default cropping rectangle, it shall cover the
+"whole picture". Assuming pixel aspect 1/1 this could be for example a
+640&nbsp;&times;&nbsp;480 rectangle for NTSC, a
+768&nbsp;&times;&nbsp;576 rectangle for PAL and SECAM centered over
+the active picture area. The same co-ordinate system as for
+ <CODE
+CLASS="STRUCTFIELD"
+>bounds</CODE
+> is used.</TD
+></TR
+><TR
+><TD
+>struct&nbsp;<A
+HREF="#V4L2-FRACT"
+>v4l2_fract</A
+></TD
+><TD
+><CODE
+CLASS="STRUCTFIELD"
+>pixelaspect</CODE
+></TD
+><TD
+><P
+>This is the pixel aspect (y / x) when no
+scaling is applied, the ratio of the actual sampling
+frequency and the frequency required to get square
+pixels.</P
+><P
+>When cropping coordinates refer to square pixels,
+the driver sets <CODE
+CLASS="STRUCTFIELD"
+>pixelaspect</CODE
+> to 1/1. Other
+common values are 54/59 for PAL and SECAM, 11/10 for NTSC sampled
+according to [<A
+HREF="#ITU601"
+><ABBR
+CLASS="ABBREV"
+>ITU601</ABBR
+></A
+>].</P
+></TD
+></TR
+></TBODY
+></TABLE
+></DIV
+><DIV
+CLASS="TABLE"
+><A
+NAME="V4L2-RECT-CROP"
+></A
+><P
+><B
+>Table 2. struct <CODE
+CLASS="STRUCTNAME"
+>v4l2_rect</CODE
+></B
+></P
+><TABLE
+BORDER="0"
+FRAME="void"
+WIDTH="100%"
+CLASS="CALSTABLE"
+><COL
+WIDTH="25%"
+TITLE="C1"><COL
+WIDTH="25%"
+TITLE="C2"><COL
+WIDTH="50%"
+TITLE="C3"><TBODY
+><TR
+><TD
+>__s32</TD
+><TD
+><CODE
+CLASS="STRUCTFIELD"
+>left</CODE
+></TD
+><TD
+>Horizontal offset of the top, left corner of the
+rectangle, in pixels.</TD
+></TR
+><TR
+><TD
+>__s32</TD
+><TD
+><CODE
+CLASS="STRUCTFIELD"
+>top</CODE
+></TD
+><TD
+>Vertical offset of the top, left corner of the
+rectangle, in pixels.</TD
+></TR
+><TR
+><TD
+>__s32</TD
+><TD
+><CODE
+CLASS="STRUCTFIELD"
+>width</CODE
+></TD
+><TD
+>Width of the rectangle, in pixels.</TD
+></TR
+><TR
+><TD
+>__s32</TD
+><TD
+><CODE
+CLASS="STRUCTFIELD"
+>height</CODE
+></TD
+><TD
+>Height of the rectangle, in pixels. Width
+and height cannot be negative, the fields are signed for
+hysterical reasons. <P
+CLASS="COMMENT"
+>video4linux-list@redhat.com
+on 22 Oct 2002 subject "Re:[V4L][patches!] Re:v4l2/kernel-2.5"</P
+></TD
+></TR
+></TBODY
+></TABLE
+></DIV
+></DIV
+><DIV
+CLASS="REFSECT1"
+><A
+NAME="AEN5091"
+></A
+><H2
+>Return Value</H2
+><P
+>On success <SPAN
+CLASS="RETURNVALUE"
+>0</SPAN
+> is returned, on
+error <SPAN
+CLASS="RETURNVALUE"
+>-1</SPAN
+> and <VAR
+CLASS="VARNAME"
+>errno</VAR
+> is
+set appropriately:</P
+><P
+></P
+><DIV
+CLASS="VARIABLELIST"
+><DL
+><DT
+><SPAN
+CLASS="ERRORCODE"
+>EINVAL</SPAN
+></DT
+><DD
+><P
+>The struct&nbsp;<A
+HREF="#V4L2-CROPCAP"
+>v4l2_cropcap</A
+> <CODE
+CLASS="STRUCTFIELD"
+>type</CODE
+> is
+invalid or the ioctl is not supported. This is not permitted for
+video capture, output and overlay devices, which must support
+<CODE
+CLASS="CONSTANT"
+>VIDIOC_CROPCAP</CODE
+>.</P
+></DD
+></DL
+></DIV
+></DIV
+><H1
+><A
+NAME="VIDIOC-ENUMAUDIO"
+></A
+>ioctl VIDIOC_ENUMAUDIO</H1
+><DIV
+CLASS="REFNAMEDIV"
+><A
+NAME="AEN5107"
+></A
+><H2
+>Name</H2
+>ioctl VIDIOC_ENUMAUDIO&nbsp;--&nbsp;Enumerate audio inputs</DIV
+><DIV
+CLASS="REFSYNOPSISDIV"
+><A
+NAME="AEN5110"
+></A
+><H2
+>Synopsis</H2
+><DIV
+CLASS="FUNCSYNOPSIS"
+><P
+></P
+><A
+NAME="AEN5111"
+></A
+><P
+><CODE
+><CODE
+CLASS="FUNCDEF"
+>int ioctl</CODE
+>(int fd, int request, struct v4l2_audio *argp);</CODE
+></P
+><P
+></P
+></DIV
+></DIV
+><DIV
+CLASS="REFSECT1"
+><A
+NAME="AEN5121"
+></A
+><H2
+>Arguments</H2
+><P
+></P
+><DIV
+CLASS="VARIABLELIST"
+><DL
+><DT
+><VAR
+CLASS="PARAMETER"
+>fd</VAR
+></DT
+><DD
+><P
+>File descriptor returned by <A
+HREF="#FUNC-OPEN"
+><CODE
+CLASS="FUNCTION"
+>open()</CODE
+></A
+>.</P
+></DD
+><DT
+><VAR
+CLASS="PARAMETER"
+>request</VAR
+></DT
+><DD
+><P
+>VIDIOC_ENUMAUDIO</P
+></DD
+><DT
+><VAR
+CLASS="PARAMETER"
+>argp</VAR
+></DT
+><DD
+><P
+></P
+></DD
+></DL
+></DIV
+></DIV
+><DIV
+CLASS="REFSECT1"
+><A
+NAME="AEN5141"
+></A
+><H2
+>Description</H2
+><P
+>To query the attributes of an audio input applications
+initialize the <CODE
+CLASS="STRUCTFIELD"
+>index</CODE
+> field and zero out the
+<CODE
+CLASS="STRUCTFIELD"
+>reserved</CODE
+> array of a struct&nbsp;<A
+HREF="#V4L2-AUDIO"
+>v4l2_audio</A
+>
+and call the <CODE
+CLASS="CONSTANT"
+>VIDIOC_ENUMAUDIO</CODE
+> ioctl with a pointer
+to this structure. Drivers fill the rest of the structure or return an
+<SPAN
+CLASS="ERRORCODE"
+>EINVAL</SPAN
+> error code when the index is out of bounds. To enumerate all audio
+inputs applications shall begin at index zero, incrementing by one
+until the driver returns <SPAN
+CLASS="ERRORCODE"
+>EINVAL</SPAN
+>.</P
+><P
+>See <A
+HREF="#VIDIOC-G-AUDIO"
+>ioctl VIDIOC_G_AUDIO, VIDIOC_S_AUDIO</A
+> for a description of
+struct&nbsp;<A
+HREF="#V4L2-AUDIO"
+>v4l2_audio</A
+>.</P
+></DIV
+><DIV
+CLASS="REFSECT1"
+><A
+NAME="AEN5153"
+></A
+><H2
+>Return Value</H2
+><P
+>On success <SPAN
+CLASS="RETURNVALUE"
+>0</SPAN
+> is returned, on
+error <SPAN
+CLASS="RETURNVALUE"
+>-1</SPAN
+> and <VAR
+CLASS="VARNAME"
+>errno</VAR
+> is
+set appropriately:</P
+><P
+></P
+><DIV
+CLASS="VARIABLELIST"
+><DL
+><DT
+><SPAN
+CLASS="ERRORCODE"
+>EINVAL</SPAN
+></DT
+><DD
+><P
+>The number of the audio input is out of bounds, or
+there are no audio inputs at all and this ioctl is not
+supported.</P
+></DD
+></DL
+></DIV
+></DIV
+><H1
+><A
+NAME="VIDIOC-ENUMAUDIOOUT"
+></A
+>ioctl VIDIOC_ENUMAUDOUT</H1
+><DIV
+CLASS="REFNAMEDIV"
+><A
+NAME="AEN5166"
+></A
+><H2
+>Name</H2
+>ioctl VIDIOC_ENUMAUDOUT&nbsp;--&nbsp;Enumerate audio outputs</DIV
+><DIV
+CLASS="REFSYNOPSISDIV"
+><A
+NAME="AEN5169"
+></A
+><H2
+>Synopsis</H2
+><DIV
+CLASS="FUNCSYNOPSIS"
+><P
+></P
+><A
+NAME="AEN5170"
+></A
+><P
+><CODE
+><CODE
+CLASS="FUNCDEF"
+>int ioctl</CODE
+>(int fd, int request, struct v4l2_audioout *argp);</CODE
+></P
+><P
+></P
+></DIV
+></DIV
+><DIV
+CLASS="REFSECT1"
+><A
+NAME="AEN5180"
+></A
+><H2
+>Arguments</H2
+><P
+></P
+><DIV
+CLASS="VARIABLELIST"
+><DL
+><DT
+><VAR
+CLASS="PARAMETER"
+>fd</VAR
+></DT
+><DD
+><P
+>File descriptor returned by <A
+HREF="#FUNC-OPEN"
+><CODE
+CLASS="FUNCTION"
+>open()</CODE
+></A
+>.</P
+></DD
+><DT
+><VAR
+CLASS="PARAMETER"
+>request</VAR
+></DT
+><DD
+><P
+>VIDIOC_ENUMAUDOUT</P
+></DD
+><DT
+><VAR
+CLASS="PARAMETER"
+>argp</VAR
+></DT
+><DD
+><P
+></P
+></DD
+></DL
+></DIV
+></DIV
+><DIV
+CLASS="REFSECT1"
+><A
+NAME="AEN5200"
+></A
+><H2
+>Description</H2
+><P
+>To query the attributes of an audio output applications
+initialize the <CODE
+CLASS="STRUCTFIELD"
+>index</CODE
+> field and zero out the
+<CODE
+CLASS="STRUCTFIELD"
+>reserved</CODE
+> array of a struct&nbsp;<A
+HREF="#V4L2-AUDIOOUT"
+>v4l2_audioout</A
+> and
+call the <CODE
+CLASS="CONSTANT"
+>VIDIOC_G_AUDOUT</CODE
+> ioctl with a pointer
+to this structure. Drivers fill the rest of the structure or return an
+<SPAN
+CLASS="ERRORCODE"
+>EINVAL</SPAN
+> error code when the index is out of bounds. To enumerate all audio
+outputs applications shall begin at index zero, incrementing by one
+until the driver returns <SPAN
+CLASS="ERRORCODE"
+>EINVAL</SPAN
+>.</P
+><P
+>Note connectors on a TV card to loop back the received audio
+signal to a sound card are not audio outputs in this sense.</P
+><P
+>See <A
+HREF="#VIDIOC-G-AUDIOOUT"
+>ioctl VIDIOC_G_AUDOUT, VIDIOC_S_AUDOUT</A
+> for a description of
+struct&nbsp;<A
+HREF="#V4L2-AUDIOOUT"
+>v4l2_audioout</A
+>.</P
+></DIV
+><DIV
+CLASS="REFSECT1"
+><A
+NAME="AEN5213"
+></A
+><H2
+>Return Value</H2
+><P
+>On success <SPAN
+CLASS="RETURNVALUE"
+>0</SPAN
+> is returned, on
+error <SPAN
+CLASS="RETURNVALUE"
+>-1</SPAN
+> and <VAR
+CLASS="VARNAME"
+>errno</VAR
+> is
+set appropriately:</P
+><P
+></P
+><DIV
+CLASS="VARIABLELIST"
+><DL
+><DT
+><SPAN
+CLASS="ERRORCODE"
+>EINVAL</SPAN
+></DT
+><DD
+><P
+>The number of the audio output is out of bounds, or
+there are no audio outputs at all and this ioctl is not
+supported.</P
+></DD
+></DL
+></DIV
+></DIV
+><H1
+><A
+NAME="VIDIOC-ENUM-FMT"
+></A
+>ioctl VIDIOC_ENUM_FMT</H1
+><DIV
+CLASS="REFNAMEDIV"
+><A
+NAME="AEN5226"
+></A
+><H2
+>Name</H2
+>ioctl VIDIOC_ENUM_FMT&nbsp;--&nbsp;Enumerate image formats</DIV
+><DIV
+CLASS="REFSYNOPSISDIV"
+><A
+NAME="AEN5229"
+></A
+><H2
+>Synopsis</H2
+><DIV
+CLASS="FUNCSYNOPSIS"
+><P
+></P
+><A
+NAME="AEN5230"
+></A
+><P
+><CODE
+><CODE
+CLASS="FUNCDEF"
+>int ioctl</CODE
+>(int fd, int request, struct v4l2_fmtdesc
+*argp);</CODE
+></P
+><P
+></P
+></DIV
+></DIV
+><DIV
+CLASS="REFSECT1"
+><A
+NAME="AEN5240"
+></A
+><H2
+>Arguments</H2
+><P
+></P
+><DIV
+CLASS="VARIABLELIST"
+><DL
+><DT
+><VAR
+CLASS="PARAMETER"
+>fd</VAR
+></DT
+><DD
+><P
+>File descriptor returned by <A
+HREF="#FUNC-OPEN"
+><CODE
+CLASS="FUNCTION"
+>open()</CODE
+></A
+>.</P
+></DD
+><DT
+><VAR
+CLASS="PARAMETER"
+>request</VAR
+></DT
+><DD
+><P
+>VIDIOC_ENUM_FMT</P
+></DD
+><DT
+><VAR
+CLASS="PARAMETER"
+>argp</VAR
+></DT
+><DD
+><P
+></P
+></DD
+></DL
+></DIV
+></DIV
+><DIV
+CLASS="REFSECT1"
+><A
+NAME="AEN5260"
+></A
+><H2
+>Description</H2
+><P
+>To enumerate image formats applications initialize the
+<CODE
+CLASS="STRUCTFIELD"
+>type</CODE
+> and <CODE
+CLASS="STRUCTFIELD"
+>index</CODE
+>
+field of struct&nbsp;<A
+HREF="#V4L2-FMTDESC"
+>v4l2_fmtdesc</A
+> and call the
+<CODE
+CLASS="CONSTANT"
+>VIDIOC_ENUM_FMT</CODE
+> ioctl with a pointer to this
+structure. Drivers fill the rest of the structure or return an
+<SPAN
+CLASS="ERRORCODE"
+>EINVAL</SPAN
+> error code. All formats are enumerable by beginning at index zero and
+incrementing by one until <SPAN
+CLASS="ERRORCODE"
+>EINVAL</SPAN
+> is
+returned.</P
+><DIV
+CLASS="TABLE"
+><A
+NAME="V4L2-FMTDESC"
+></A
+><P
+><B
+>Table 1. struct <CODE
+CLASS="STRUCTNAME"
+>v4l2_fmtdesc</CODE
+></B
+></P
+><TABLE
+BORDER="0"
+FRAME="void"
+WIDTH="100%"
+CLASS="CALSTABLE"
+><COL
+WIDTH="25%"
+TITLE="C1"><COL
+WIDTH="25%"
+TITLE="C2"><COL
+WIDTH="50%"
+TITLE="C3"><TBODY
+><TR
+><TD
+>__u32</TD
+><TD
+><CODE
+CLASS="STRUCTFIELD"
+>index</CODE
+></TD
+><TD
+>Number of the format in the enumeration, set by
+the application. This is in no way related to the <CODE
+CLASS="STRUCTFIELD"
+>pixelformat</CODE
+> field.</TD
+></TR
+><TR
+><TD
+>enum&nbsp;<A
+HREF="#V4L2-BUF-TYPE"
+>v4l2_buf_type</A
+></TD
+><TD
+><CODE
+CLASS="STRUCTFIELD"
+>type</CODE
+></TD
+><TD
+>Type of the data stream, set by the application.
+Only these types are valid here:
+<CODE
+CLASS="CONSTANT"
+>V4L2_BUF_TYPE_VIDEO_CAPTURE</CODE
+>,
+<CODE
+CLASS="CONSTANT"
+>V4L2_BUF_TYPE_VIDEO_OUTPUT</CODE
+>,
+<CODE
+CLASS="CONSTANT"
+>V4L2_BUF_TYPE_VIDEO_OVERLAY</CODE
+>, and custom (driver
+defined) types with code <CODE
+CLASS="CONSTANT"
+>V4L2_BUF_TYPE_PRIVATE</CODE
+>
+and higher.</TD
+></TR
+><TR
+><TD
+>__u32</TD
+><TD
+><CODE
+CLASS="STRUCTFIELD"
+>flags</CODE
+></TD
+><TD
+>See <A
+HREF="#FMTDESC-FLAGS"
+>Table 2</A
+></TD
+></TR
+><TR
+><TD
+>__u8</TD
+><TD
+><CODE
+CLASS="STRUCTFIELD"
+>description</CODE
+>[32]</TD
+><TD
+>Description of the format, a NUL-terminated ASCII
+string. This information is intended for the user, for example: "YUV
+4:2:2".</TD
+></TR
+><TR
+><TD
+>__u32</TD
+><TD
+><CODE
+CLASS="STRUCTFIELD"
+>pixelformat</CODE
+></TD
+><TD
+>The image format identifier. This is a
+four character code as computed by the v4l2_fourcc()
+macro:</TD
+></TR
+><TR
+><TD
+COLSPAN="3"
+><P
+><PRE
+CLASS="PROGRAMLISTING"
+>#define v4l2_fourcc(a,b,c,d) (((__u32)(a)&#60;&#60;0)|((__u32)(b)&#60;&#60;8)|((__u32)(c)&#60;&#60;16)|((__u32)(d)&#60;&#60;24))</PRE
+></P
+><P
+>Several image formats are already
+defined by this specification in <A
+HREF="#PIXFMT"
+>Chapter 2</A
+>. Note these
+codes are not the same as those used in the Windows world.</P
+></TD
+></TR
+><TR
+><TD
+>__u32</TD
+><TD
+><CODE
+CLASS="STRUCTFIELD"
+>reserved</CODE
+>[4]</TD
+><TD
+>Reserved for future extensions. Drivers must set
+the array to zero.</TD
+></TR
+></TBODY
+></TABLE
+></DIV
+><DIV
+CLASS="TABLE"
+><A
+NAME="FMTDESC-FLAGS"
+></A
+><P
+><B
+>Table 2. Image Format Description Flags</B
+></P
+><TABLE
+BORDER="0"
+FRAME="void"
+WIDTH="100%"
+CLASS="CALSTABLE"
+><COL
+WIDTH="38%"
+TITLE="C1"><COL
+WIDTH="12%"
+TITLE="C2"><COL
+WIDTH="50%"
+TITLE="C3"><TBODY
+><TR
+><TD
+><CODE
+CLASS="CONSTANT"
+>V4L2_FMT_FLAG_COMPRESSED</CODE
+></TD
+><TD
+>0x0001</TD
+><TD
+>This is a compressed format.</TD
+></TR
+></TBODY
+></TABLE
+></DIV
+></DIV
+><DIV
+CLASS="REFSECT1"
+><A
+NAME="AEN5334"
+></A
+><H2
+>Return Value</H2
+><P
+>On success <SPAN
+CLASS="RETURNVALUE"
+>0</SPAN
+> is returned, on
+error <SPAN
+CLASS="RETURNVALUE"
+>-1</SPAN
+> and <VAR
+CLASS="VARNAME"
+>errno</VAR
+> is
+set appropriately:</P
+><P
+></P
+><DIV
+CLASS="VARIABLELIST"
+><DL
+><DT
+><SPAN
+CLASS="ERRORCODE"
+>EINVAL</SPAN
+></DT
+><DD
+><P
+>The struct&nbsp;<A
+HREF="#V4L2-FMTDESC"
+>v4l2_fmtdesc</A
+> <CODE
+CLASS="STRUCTFIELD"
+>type</CODE
+>
+is not supported or the <CODE
+CLASS="STRUCTFIELD"
+>index</CODE
+> is out of
+bounds.</P
+></DD
+></DL
+></DIV
+></DIV
+><H1
+><A
+NAME="VIDIOC-ENUMINPUT"
+></A
+>ioctl VIDIOC_ENUMINPUT</H1
+><DIV
+CLASS="REFNAMEDIV"
+><A
+NAME="AEN5350"
+></A
+><H2
+>Name</H2
+>ioctl VIDIOC_ENUMINPUT&nbsp;--&nbsp;Enumerate video inputs</DIV
+><DIV
+CLASS="REFSYNOPSISDIV"
+><A
+NAME="AEN5353"
+></A
+><H2
+>Synopsis</H2
+><DIV
+CLASS="FUNCSYNOPSIS"
+><P
+></P
+><A
+NAME="AEN5354"
+></A
+><P
+><CODE
+><CODE
+CLASS="FUNCDEF"
+>int ioctl</CODE
+>(int fd, int request, struct v4l2_input
+*argp);</CODE
+></P
+><P
+></P
+></DIV
+></DIV
+><DIV
+CLASS="REFSECT1"
+><A
+NAME="AEN5364"
+></A
+><H2
+>Arguments</H2
+><P
+></P
+><DIV
+CLASS="VARIABLELIST"
+><DL
+><DT
+><VAR
+CLASS="PARAMETER"
+>fd</VAR
+></DT
+><DD
+><P
+>File descriptor returned by <A
+HREF="#FUNC-OPEN"
+><CODE
+CLASS="FUNCTION"
+>open()</CODE
+></A
+>.</P
+></DD
+><DT
+><VAR
+CLASS="PARAMETER"
+>request</VAR
+></DT
+><DD
+><P
+>VIDIOC_ENUMINPUT</P
+></DD
+><DT
+><VAR
+CLASS="PARAMETER"
+>argp</VAR
+></DT
+><DD
+><P
+></P
+></DD
+></DL
+></DIV
+></DIV
+><DIV
+CLASS="REFSECT1"
+><A
+NAME="AEN5384"
+></A
+><H2
+>Description</H2
+><P
+>To query the attributes of a video input applications
+initialize the <CODE
+CLASS="STRUCTFIELD"
+>index</CODE
+> field of struct&nbsp;<A
+HREF="#V4L2-INPUT"
+>v4l2_input</A
+>
+and call the <CODE
+CLASS="CONSTANT"
+>VIDIOC_ENUMINPUT</CODE
+> ioctl with a
+pointer to this structure. Drivers fill the rest of the structure or
+return an <SPAN
+CLASS="ERRORCODE"
+>EINVAL</SPAN
+> error code when the index is out of bounds. To enumerate all
+inputs applications shall begin at index zero, incrementing by one
+until the driver returns <SPAN
+CLASS="ERRORCODE"
+>EINVAL</SPAN
+>.</P
+><DIV
+CLASS="TABLE"
+><A
+NAME="V4L2-INPUT"
+></A
+><P
+><B
+>Table 1. struct <CODE
+CLASS="STRUCTNAME"
+>v4l2_input</CODE
+></B
+></P
+><TABLE
+BORDER="0"
+FRAME="void"
+WIDTH="100%"
+CLASS="CALSTABLE"
+><COL
+WIDTH="25%"
+TITLE="C1"><COL
+WIDTH="25%"
+TITLE="C2"><COL
+WIDTH="50%"
+TITLE="C3"><TBODY
+><TR
+><TD
+>__u32</TD
+><TD
+><CODE
+CLASS="STRUCTFIELD"
+>index</CODE
+></TD
+><TD
+>Identifies the input, set by the
+application.</TD
+></TR
+><TR
+><TD
+>__u8</TD
+><TD
+><CODE
+CLASS="STRUCTFIELD"
+>name</CODE
+>[32]</TD
+><TD
+>Name of the video input, a NUL-terminated ASCII
+string, for example: "Vin (Composite 2)". This information is intended
+for the user, preferably the connector label on the device itself.</TD
+></TR
+><TR
+><TD
+>__u32</TD
+><TD
+><CODE
+CLASS="STRUCTFIELD"
+>type</CODE
+></TD
+><TD
+>Type of the input, see <A
+HREF="#INPUT-TYPE"
+>Table 2</A
+>.</TD
+></TR
+><TR
+><TD
+>__u32</TD
+><TD
+><CODE
+CLASS="STRUCTFIELD"
+>audioset</CODE
+></TD
+><TD
+>Video inputs combine with zero or more audio
+inputs. For example one composite video connectors may exist, but two
+audio connectors. On the other hand, video from a tuner will likely
+combine only with audio from the same tuner. Devices with N audio
+inputs number them 0 &hellip; N-1 with N &le; 32. Each bit position of
+<CODE
+CLASS="STRUCTFIELD"
+>audioset</CODE
+> represents one audio input. For
+details on audio inputs and how to switch see <A
+HREF="#AUDIO"
+>Section 1.5</A
+>.</TD
+></TR
+><TR
+><TD
+>__u32</TD
+><TD
+><CODE
+CLASS="STRUCTFIELD"
+>tuner</CODE
+></TD
+><TD
+>Capture devices can have zero or more tuners (RF
+demodulators). When the <CODE
+CLASS="STRUCTFIELD"
+>type</CODE
+> is set to
+<CODE
+CLASS="CONSTANT"
+>V4L2_INPUT_TYPE_TUNER</CODE
+> this is an RF connector and
+this field identifies the tuner. It corresponds to
+struct&nbsp;<A
+HREF="#V4L2-TUNER"
+>v4l2_tuner</A
+> field <CODE
+CLASS="STRUCTFIELD"
+>index</CODE
+>. For details on
+tuners see <A
+HREF="#TUNER"
+>Section 1.6</A
+>.</TD
+></TR
+><TR
+><TD
+><A
+HREF="#V4L2-STD-ID"
+>v4l2_std_id</A
+></TD
+><TD
+><CODE
+CLASS="STRUCTFIELD"
+>std</CODE
+></TD
+><TD
+>Every video input supports one or more different
+video standards. This field is a set of all supported standards. For
+details on video standards and how to switch see <A
+HREF="#STANDARD"
+>Section 1.7</A
+>.</TD
+></TR
+><TR
+><TD
+>__u32</TD
+><TD
+><CODE
+CLASS="STRUCTFIELD"
+>status</CODE
+></TD
+><TD
+>This field provides status information about the
+input. See <A
+HREF="#INPUT-STATUS"
+>Table 3</A
+> for flags.
+<CODE
+CLASS="STRUCTFIELD"
+>status</CODE
+> is only valid when this is the
+current input.</TD
+></TR
+><TR
+><TD
+>__u32</TD
+><TD
+><CODE
+CLASS="STRUCTFIELD"
+>reserved</CODE
+>[4]</TD
+><TD
+>Reserved for future extensions. Drivers must set
+the array to zero.</TD
+></TR
+></TBODY
+></TABLE
+></DIV
+><DIV
+CLASS="TABLE"
+><A
+NAME="INPUT-TYPE"
+></A
+><P
+><B
+>Table 2. Input Types</B
+></P
+><TABLE
+BORDER="0"
+FRAME="void"
+WIDTH="100%"
+CLASS="CALSTABLE"
+><COL
+WIDTH="38%"
+TITLE="C1"><COL
+WIDTH="12%"
+TITLE="C2"><COL
+WIDTH="50%"
+TITLE="C3"><TBODY
+><TR
+><TD
+><CODE
+CLASS="CONSTANT"
+>V4L2_INPUT_TYPE_TUNER</CODE
+></TD
+><TD
+>1</TD
+><TD
+>This input uses a tuner (RF demodulator).</TD
+></TR
+><TR
+><TD
+><CODE
+CLASS="CONSTANT"
+>V4L2_INPUT_TYPE_CAMERA</CODE
+></TD
+><TD
+>2</TD
+><TD
+>Analog baseband input, for example CVBS /
+Composite Video, S-Video, RGB.</TD
+></TR
+></TBODY
+></TABLE
+></DIV
+><DIV
+CLASS="TABLE"
+><A
+NAME="INPUT-STATUS"
+></A
+><P
+><B
+>Table 3. Input Status Flags</B
+></P
+><TABLE
+BORDER="0"
+FRAME="void"
+WIDTH="100%"
+CLASS="CALSTABLE"
+><COL
+WIDTH="33%"
+TITLE="C1"><COL
+WIDTH="33%"
+ALIGN="CENTER"
+TITLE="C2"><COL
+WIDTH="33%"
+TITLE="C3"><TBODY
+><TR
+><TD
+COLSPAN="3"
+ALIGN="LEFT"
+>General</TD
+></TR
+><TR
+><TD
+><CODE
+CLASS="CONSTANT"
+>V4L2_IN_ST_NO_POWER</CODE
+></TD
+><TD
+>0x00000001</TD
+><TD
+>Attached device is off.</TD
+></TR
+><TR
+><TD
+><CODE
+CLASS="CONSTANT"
+>V4L2_IN_ST_NO_SIGNAL</CODE
+></TD
+><TD
+>0x00000002</TD
+><TD
+>&nbsp;</TD
+></TR
+><TR
+><TD
+><CODE
+CLASS="CONSTANT"
+>V4L2_IN_ST_NO_COLOR</CODE
+></TD
+><TD
+>0x00000004</TD
+><TD
+>&nbsp;</TD
+></TR
+><TR
+><TD
+COLSPAN="3"
+ALIGN="LEFT"
+>Analog Video</TD
+></TR
+><TR
+><TD
+><CODE
+CLASS="CONSTANT"
+>V4L2_IN_ST_NO_H_LOCK</CODE
+></TD
+><TD
+>0x00000100</TD
+><TD
+>No horizontal sync lock.</TD
+></TR
+><TR
+><TD
+><CODE
+CLASS="CONSTANT"
+>V4L2_IN_ST_COLOR_KILL</CODE
+></TD
+><TD
+>0x00000200</TD
+><TD
+>The color killer is a circuit that shuts off the
+color decoding when it cannot find the color burst. This flag
+indicates if the color killer is <SPAN
+CLASS="emphasis"
+><I
+CLASS="EMPHASIS"
+>enabled</I
+></SPAN
+>, while
+<CODE
+CLASS="CONSTANT"
+>V4L2_IN_ST_NO_COLOR</CODE
+> is set when no color is
+<SPAN
+CLASS="emphasis"
+><I
+CLASS="EMPHASIS"
+>detected</I
+></SPAN
+>.</TD
+></TR
+><TR
+><TD
+COLSPAN="3"
+ALIGN="LEFT"
+>Digital Video</TD
+></TR
+><TR
+><TD
+><CODE
+CLASS="CONSTANT"
+>V4L2_IN_ST_NO_SYNC</CODE
+></TD
+><TD
+>0x00010000</TD
+><TD
+>No synchronization lock.</TD
+></TR
+><TR
+><TD
+><CODE
+CLASS="CONSTANT"
+>V4L2_IN_ST_NO_EQU</CODE
+></TD
+><TD
+>0x00020000</TD
+><TD
+>No equalizer lock.</TD
+></TR
+><TR
+><TD
+><CODE
+CLASS="CONSTANT"
+>V4L2_IN_ST_NO_CARRIER</CODE
+></TD
+><TD
+>0x00040000</TD
+><TD
+>Carrier recovery failed.</TD
+></TR
+><TR
+><TD
+COLSPAN="3"
+ALIGN="LEFT"
+>VCR and Set-Top Box</TD
+></TR
+><TR
+><TD
+><CODE
+CLASS="CONSTANT"
+>V4L2_IN_ST_MACROVISION</CODE
+></TD
+><TD
+>0x01000000</TD
+><TD
+>Macrovision is an analog copy protection system
+mangling the video signal to confuse video recorders. When this
+flag is set Macrovision protection has been detected.</TD
+></TR
+><TR
+><TD
+><CODE
+CLASS="CONSTANT"
+>V4L2_IN_ST_NO_ACCESS</CODE
+></TD
+><TD
+>0x02000000</TD
+><TD
+>Conditional access denied.</TD
+></TR
+><TR
+><TD
+><CODE
+CLASS="CONSTANT"
+>V4L2_IN_ST_VTR</CODE
+></TD
+><TD
+>0x04000000</TD
+><TD
+>VTR time constant. [?]</TD
+></TR
+></TBODY
+></TABLE
+></DIV
+></DIV
+><DIV
+CLASS="REFSECT1"
+><A
+NAME="AEN5545"
+></A
+><H2
+>Return Value</H2
+><P
+>On success <SPAN
+CLASS="RETURNVALUE"
+>0</SPAN
+> is returned, on
+error <SPAN
+CLASS="RETURNVALUE"
+>-1</SPAN
+> and <VAR
+CLASS="VARNAME"
+>errno</VAR
+> is
+set appropriately:</P
+><P
+></P
+><DIV
+CLASS="VARIABLELIST"
+><DL
+><DT
+><SPAN
+CLASS="ERRORCODE"
+>EINVAL</SPAN
+></DT
+><DD
+><P
+>The struct&nbsp;<A
+HREF="#V4L2-INPUT"
+>v4l2_input</A
+> <CODE
+CLASS="STRUCTFIELD"
+>index</CODE
+> is
+out of bounds.</P
+></DD
+></DL
+></DIV
+></DIV
+><H1
+><A
+NAME="VIDIOC-ENUMOUTPUT"
+></A
+>ioctl VIDIOC_ENUMOUTPUT</H1
+><DIV
+CLASS="REFNAMEDIV"
+><A
+NAME="AEN5560"
+></A
+><H2
+>Name</H2
+>ioctl VIDIOC_ENUMOUTPUT&nbsp;--&nbsp;Enumerate video outputs</DIV
+><DIV
+CLASS="REFSYNOPSISDIV"
+><A
+NAME="AEN5563"
+></A
+><H2
+>Synopsis</H2
+><DIV
+CLASS="FUNCSYNOPSIS"
+><P
+></P
+><A
+NAME="AEN5564"
+></A
+><P
+><CODE
+><CODE
+CLASS="FUNCDEF"
+>int ioctl</CODE
+>(int fd, int request, struct v4l2_output *argp);</CODE
+></P
+><P
+></P
+></DIV
+></DIV
+><DIV
+CLASS="REFSECT1"
+><A
+NAME="AEN5574"
+></A
+><H2
+>Arguments</H2
+><P
+></P
+><DIV
+CLASS="VARIABLELIST"
+><DL
+><DT
+><VAR
+CLASS="PARAMETER"
+>fd</VAR
+></DT
+><DD
+><P
+>File descriptor returned by <A
+HREF="#FUNC-OPEN"
+><CODE
+CLASS="FUNCTION"
+>open()</CODE
+></A
+>.</P
+></DD
+><DT
+><VAR
+CLASS="PARAMETER"
+>request</VAR
+></DT
+><DD
+><P
+>VIDIOC_ENUMOUTPUT</P
+></DD
+><DT
+><VAR
+CLASS="PARAMETER"
+>argp</VAR
+></DT
+><DD
+><P
+></P
+></DD
+></DL
+></DIV
+></DIV
+><DIV
+CLASS="REFSECT1"
+><A
+NAME="AEN5594"
+></A
+><H2
+>Description</H2
+><P
+>To query the attributes of a video outputs applications
+initialize the <CODE
+CLASS="STRUCTFIELD"
+>index</CODE
+> field of struct&nbsp;<A
+HREF="#V4L2-OUTPUT"
+>v4l2_output</A
+>
+and call the <CODE
+CLASS="CONSTANT"
+>VIDIOC_ENUMOUTPUT</CODE
+> ioctl with a
+pointer to this structure. Drivers fill the rest of the structure or
+return an <SPAN
+CLASS="ERRORCODE"
+>EINVAL</SPAN
+> error code when the index is out of bounds. To enumerate all
+outputs applications shall begin at index zero, incrementing by one
+until the driver returns <SPAN
+CLASS="ERRORCODE"
+>EINVAL</SPAN
+>.</P
+><DIV
+CLASS="TABLE"
+><A
+NAME="V4L2-OUTPUT"
+></A
+><P
+><B
+>Table 1. struct <CODE
+CLASS="STRUCTNAME"
+>v4l2_output</CODE
+></B
+></P
+><TABLE
+BORDER="0"
+FRAME="void"
+WIDTH="100%"
+CLASS="CALSTABLE"
+><COL
+WIDTH="25%"
+TITLE="C1"><COL
+WIDTH="25%"
+TITLE="C2"><COL
+WIDTH="50%"
+TITLE="C3"><TBODY
+><TR
+><TD
+>__u32</TD
+><TD
+><CODE
+CLASS="STRUCTFIELD"
+>index</CODE
+></TD
+><TD
+>Identifies the output, set by the
+application.</TD
+></TR
+><TR
+><TD
+>__u8</TD
+><TD
+><CODE
+CLASS="STRUCTFIELD"
+>name</CODE
+>[32]</TD
+><TD
+>Name of the video output, a NUL-terminated ASCII
+string, for example: "Vout". This information is intended for the
+user, preferably the connector label on the device itself.</TD
+></TR
+><TR
+><TD
+>__u32</TD
+><TD
+><CODE
+CLASS="STRUCTFIELD"
+>type</CODE
+></TD
+><TD
+>Type of the output, see <A
+HREF="#OUTPUT-TYPE"
+>Table 2</A
+>.</TD
+></TR
+><TR
+><TD
+>__u32</TD
+><TD
+><CODE
+CLASS="STRUCTFIELD"
+>audioset</CODE
+></TD
+><TD
+>Video outputs combine with zero or more audio
+outputs. For example one composite video connectors may exist, but two
+audio connectors. On the other hand, video to a modulator will likely
+combine only with audio to the same modulator. Devices with N audio
+outputs number them 0 &hellip; N-1 with N &le; 32. Each bit position of
+<CODE
+CLASS="STRUCTFIELD"
+>audioset</CODE
+> represents one audio output. For
+details on audio outputs and how to switch see <A
+HREF="#AUDIO"
+>Section 1.5</A
+>.</TD
+></TR
+><TR
+><TD
+>__u32</TD
+><TD
+><CODE
+CLASS="STRUCTFIELD"
+>modulator</CODE
+></TD
+><TD
+>Output devices can have zero or more RF modulators.
+When the <CODE
+CLASS="STRUCTFIELD"
+>type</CODE
+> is
+<CODE
+CLASS="CONSTANT"
+>V4L2_OUTPUT_TYPE_MODULATOR</CODE
+> this is an RF
+connector and this field identifies the modulator. It corresponds to
+struct&nbsp;<A
+HREF="#V4L2-MODULATOR"
+>v4l2_modulator</A
+> field <CODE
+CLASS="STRUCTFIELD"
+>index</CODE
+>. For details
+on modulators see <A
+HREF="#TUNER"
+>Section 1.6</A
+>.</TD
+></TR
+><TR
+><TD
+><A
+HREF="#V4L2-STD-ID"
+>v4l2_std_id</A
+></TD
+><TD
+><CODE
+CLASS="STRUCTFIELD"
+>std</CODE
+></TD
+><TD
+>Every video output supports one or more different
+video standards. This field is a set of all supported standards. For
+details on video standards and how to switch see <A
+HREF="#STANDARD"
+>Section 1.7</A
+>.</TD
+></TR
+><TR
+><TD
+>__u32</TD
+><TD
+><CODE
+CLASS="STRUCTFIELD"
+>reserved</CODE
+>[4]</TD
+><TD
+>Reserved for future extensions. Drivers must set
+the array to zero.</TD
+></TR
+></TBODY
+></TABLE
+></DIV
+><DIV
+CLASS="TABLE"
+><A
+NAME="OUTPUT-TYPE"
+></A
+><P
+><B
+>Table 2. Output Type</B
+></P
+><TABLE
+BORDER="0"
+FRAME="void"
+WIDTH="100%"
+CLASS="CALSTABLE"
+><COL
+WIDTH="38%"
+TITLE="C1"><COL
+WIDTH="12%"
+TITLE="C2"><COL
+WIDTH="50%"
+TITLE="C3"><TBODY
+><TR
+><TD
+><CODE
+CLASS="CONSTANT"
+>V4L2_OUTPUT_TYPE_MODULATOR</CODE
+></TD
+><TD
+>1</TD
+><TD
+>This output is an analog TV modulator.</TD
+></TR
+><TR
+><TD
+><CODE
+CLASS="CONSTANT"
+>V4L2_OUTPUT_TYPE_ANALOG</CODE
+></TD
+><TD
+>2</TD
+><TD
+>Analog baseband output, for example Composite /
+CVBS, S-Video, RGB.</TD
+></TR
+><TR
+><TD
+><CODE
+CLASS="CONSTANT"
+>V4L2_OUTPUT_TYPE_ANALOGVGAOVERLAY</CODE
+></TD
+><TD
+>3</TD
+><TD
+>[?]</TD
+></TR
+></TBODY
+></TABLE
+></DIV
+></DIV
+><DIV
+CLASS="REFSECT1"
+><A
+NAME="AEN5679"
+></A
+><H2
+>Return Value</H2
+><P
+>On success <SPAN
+CLASS="RETURNVALUE"
+>0</SPAN
+> is returned, on
+error <SPAN
+CLASS="RETURNVALUE"
+>-1</SPAN
+> and <VAR
+CLASS="VARNAME"
+>errno</VAR
+> is
+set appropriately:</P
+><P
+></P
+><DIV
+CLASS="VARIABLELIST"
+><DL
+><DT
+><SPAN
+CLASS="ERRORCODE"
+>EINVAL</SPAN
+></DT
+><DD
+><P
+>The struct&nbsp;<A
+HREF="#V4L2-OUTPUT"
+>v4l2_output</A
+> <CODE
+CLASS="STRUCTFIELD"
+>index</CODE
+>
+is out of bounds.</P
+></DD
+></DL
+></DIV
+></DIV
+><H1
+><A
+NAME="VIDIOC-ENUMSTD"
+></A
+>ioctl VIDIOC_ENUMSTD</H1
+><DIV
+CLASS="REFNAMEDIV"
+><A
+NAME="AEN5694"
+></A
+><H2
+>Name</H2
+>ioctl VIDIOC_ENUMSTD&nbsp;--&nbsp;Enumerate supported video standards</DIV
+><DIV
+CLASS="REFSYNOPSISDIV"
+><A
+NAME="AEN5697"
+></A
+><H2
+>Synopsis</H2
+><DIV
+CLASS="FUNCSYNOPSIS"
+><P
+></P
+><A
+NAME="AEN5698"
+></A
+><P
+><CODE
+><CODE
+CLASS="FUNCDEF"
+>int ioctl</CODE
+>(int fd, int request, struct v4l2_standard *argp);</CODE
+></P
+><P
+></P
+></DIV
+></DIV
+><DIV
+CLASS="REFSECT1"
+><A
+NAME="AEN5708"
+></A
+><H2
+>Arguments</H2
+><P
+></P
+><DIV
+CLASS="VARIABLELIST"
+><DL
+><DT
+><VAR
+CLASS="PARAMETER"
+>fd</VAR
+></DT
+><DD
+><P
+>File descriptor returned by <A
+HREF="#FUNC-OPEN"
+><CODE
+CLASS="FUNCTION"
+>open()</CODE
+></A
+>.</P
+></DD
+><DT
+><VAR
+CLASS="PARAMETER"
+>request</VAR
+></DT
+><DD
+><P
+>VIDIOC_ENUMSTD</P
+></DD
+><DT
+><VAR
+CLASS="PARAMETER"
+>argp</VAR
+></DT
+><DD
+><P
+></P
+></DD
+></DL
+></DIV
+></DIV
+><DIV
+CLASS="REFSECT1"
+><A
+NAME="AEN5728"
+></A
+><H2
+>Description</H2
+><P
+>To query the attributes of a video standard,
+especially a custom (driver defined) one, applications initialize the
+<CODE
+CLASS="STRUCTFIELD"
+>index</CODE
+> field of struct&nbsp;<A
+HREF="#V4L2-STANDARD"
+>v4l2_standard</A
+> and call the
+<CODE
+CLASS="CONSTANT"
+>VIDIOC_ENUMSTD</CODE
+> ioctl with a pointer to this
+structure. Drivers fill the rest of the structure or return an
+<SPAN
+CLASS="ERRORCODE"
+>EINVAL</SPAN
+> error code when the index is out of bounds. To enumerate all standards
+applications shall begin at index zero, incrementing by one until the
+driver returns <SPAN
+CLASS="ERRORCODE"
+>EINVAL</SPAN
+>. Drivers may enumerate a
+different set of standards after switching the video input or
+output.<A
+NAME="AEN5736"
+HREF="#FTN.AEN5736"
+><SPAN
+CLASS="footnote"
+>[24]</SPAN
+></A
+></P
+><DIV
+CLASS="TABLE"
+><A
+NAME="V4L2-STANDARD"
+></A
+><P
+><B
+>Table 1. struct <CODE
+CLASS="STRUCTNAME"
+>v4l2_standard</CODE
+></B
+></P
+><TABLE
+BORDER="0"
+FRAME="void"
+WIDTH="100%"
+CLASS="CALSTABLE"
+><COL
+WIDTH="25%"
+TITLE="C1"><COL
+WIDTH="25%"
+TITLE="C2"><COL
+WIDTH="50%"
+TITLE="C3"><TBODY
+><TR
+><TD
+>__u32</TD
+><TD
+><CODE
+CLASS="STRUCTFIELD"
+>index</CODE
+></TD
+><TD
+>Number of the video standard, set by the
+application.</TD
+></TR
+><TR
+><TD
+><A
+HREF="#V4L2-STD-ID"
+>v4l2_std_id</A
+></TD
+><TD
+><CODE
+CLASS="STRUCTFIELD"
+>id</CODE
+></TD
+><TD
+>The bits in this field identify the standard as
+one of the common standards listed in <A
+HREF="#V4L2-STD-ID"
+>Table 3</A
+>,
+or if bits 32 to 63 are set as custom standards. Multiple bits can be
+set if the hardware does not distinguish between these standards,
+however separate indices do not indicate the opposite. The
+<CODE
+CLASS="STRUCTFIELD"
+>id</CODE
+> must be unique. No other enumerated
+<CODE
+CLASS="STRUCTNAME"
+>v4l2_standard</CODE
+> structure, for this input or
+output anyway, can contain the same set of bits.</TD
+></TR
+><TR
+><TD
+>__u8</TD
+><TD
+><CODE
+CLASS="STRUCTFIELD"
+>name</CODE
+>[24]</TD
+><TD
+>Name of the standard, a NUL-terminated ASCII
+string, for example: "PAL-B/G", "NTSC Japan". This information is
+intended for the user.</TD
+></TR
+><TR
+><TD
+>struct&nbsp;<A
+HREF="#V4L2-FRACT"
+>v4l2_fract</A
+></TD
+><TD
+><CODE
+CLASS="STRUCTFIELD"
+>frameperiod</CODE
+></TD
+><TD
+>The frame period (not field period) is numerator
+/ denominator. For example M/NTSC has a frame period of 1001 /
+30000 seconds.</TD
+></TR
+><TR
+><TD
+>__u32</TD
+><TD
+><CODE
+CLASS="STRUCTFIELD"
+>framelines</CODE
+></TD
+><TD
+>Total lines per frame including blanking,
+e.&nbsp;g. 625 for B/PAL.</TD
+></TR
+><TR
+><TD
+>__u32</TD
+><TD
+><CODE
+CLASS="STRUCTFIELD"
+>reserved</CODE
+>[4]</TD
+><TD
+>Reserved for future extensions. Drivers must set
+the array to zero.</TD
+></TR
+></TBODY
+></TABLE
+></DIV
+><DIV
+CLASS="TABLE"
+><A
+NAME="V4L2-FRACT"
+></A
+><P
+><B
+>Table 2. struct <CODE
+CLASS="STRUCTNAME"
+>v4l2_fract</CODE
+></B
+></P
+><TABLE
+BORDER="0"
+FRAME="void"
+WIDTH="100%"
+CLASS="CALSTABLE"
+><COL
+WIDTH="25%"
+TITLE="C1"><COL
+WIDTH="25%"
+TITLE="C2"><COL
+WIDTH="50%"
+TITLE="C3"><TBODY
+><TR
+><TD
+>__u32</TD
+><TD
+><CODE
+CLASS="STRUCTFIELD"
+>numerator</CODE
+></TD
+><TD
+>&nbsp;</TD
+></TR
+><TR
+><TD
+>__u32</TD
+><TD
+><CODE
+CLASS="STRUCTFIELD"
+>denominator</CODE
+></TD
+><TD
+>&nbsp;</TD
+></TR
+></TBODY
+></TABLE
+></DIV
+><DIV
+CLASS="TABLE"
+><A
+NAME="V4L2-STD-ID"
+></A
+><P
+><B
+>Table 3. typedef <CODE
+CLASS="STRUCTNAME"
+>v4l2_std_id</CODE
+></B
+></P
+><TABLE
+BORDER="0"
+FRAME="void"
+WIDTH="100%"
+CLASS="CALSTABLE"
+><COL
+WIDTH="25%"
+TITLE="C1"><COL
+WIDTH="25%"
+TITLE="C2"><COL
+WIDTH="50%"
+TITLE="C3"><TBODY
+><TR
+><TD
+>__u64</TD
+><TD
+><CODE
+CLASS="STRUCTFIELD"
+>v4l2_std_id</CODE
+></TD
+><TD
+>This type is a set, each bit representing
+another video standard as listed below and in <A
+HREF="#VIDEO-STANDARDS"
+>Table 4</A
+>.</TD
+></TR
+><TR
+><TD
+COLSPAN="3"
+><P
+><CODE
+CLASS="CONSTANT"
+>V4L2_STD_PAL_60</CODE
+> is a
+hybrid standard with 525 lines, 60 Hz refresh rate, but PAL
+color modulation. Some PAL video recorders can play back NTSC tapes in this
+mode for display on 50/60 Hz agnostic PAL TVs.</P
+><P
+><CODE
+CLASS="CONSTANT"
+>V4L2_STD_ATSC_8_VSB</CODE
+> and
+<CODE
+CLASS="CONSTANT"
+>V4L2_STD_ATSC_16_VSB</CODE
+> are the U.S. terrestrial
+digital TV standards. The present V4L2 API makes no provisions for
+digital TV reception, so no driver will report these standards
+yet. See also the Linux DVB API at
+<A
+HREF="http://linuxtv.org"
+TARGET="_top"
+>http://linuxtv.org</A
+>.</P
+><P
+>Bit
+32 to 63 are reserved for custom (driver defined) video
+standards.</P
+></TD
+></TR
+></TBODY
+></TABLE
+></DIV
+><P
+><PRE
+CLASS="PROGRAMLISTING"
+>#define V4L2_STD_PAL_B ((v4l2_std_id)0x00000001)
+#define V4L2_STD_PAL_B1 ((v4l2_std_id)0x00000002)
+#define V4L2_STD_PAL_G ((v4l2_std_id)0x00000004)
+#define V4L2_STD_PAL_H ((v4l2_std_id)0x00000008)
+#define V4L2_STD_PAL_I ((v4l2_std_id)0x00000010)
+#define V4L2_STD_PAL_D ((v4l2_std_id)0x00000020)
+#define V4L2_STD_PAL_D1 ((v4l2_std_id)0x00000040)
+#define V4L2_STD_PAL_K ((v4l2_std_id)0x00000080)
+
+#define V4L2_STD_PAL_M ((v4l2_std_id)0x00000100)
+#define V4L2_STD_PAL_N ((v4l2_std_id)0x00000200)
+#define V4L2_STD_PAL_Nc ((v4l2_std_id)0x00000400)
+#define V4L2_STD_PAL_60 ((v4l2_std_id)0x00000800)
+
+#define V4L2_STD_NTSC_M ((v4l2_std_id)0x00001000)
+#define V4L2_STD_NTSC_M_JP ((v4l2_std_id)0x00002000)
+
+#define V4L2_STD_SECAM_B ((v4l2_std_id)0x00010000)
+#define V4L2_STD_SECAM_D ((v4l2_std_id)0x00020000)
+#define V4L2_STD_SECAM_G ((v4l2_std_id)0x00040000)
+#define V4L2_STD_SECAM_H ((v4l2_std_id)0x00080000)
+#define V4L2_STD_SECAM_K ((v4l2_std_id)0x00100000)
+#define V4L2_STD_SECAM_K1 ((v4l2_std_id)0x00200000)
+#define V4L2_STD_SECAM_L ((v4l2_std_id)0x00400000)
+
+/* ATSC/HDTV */
+#define V4L2_STD_ATSC_8_VSB ((v4l2_std_id)0x01000000)
+#define V4L2_STD_ATSC_16_VSB ((v4l2_std_id)0x02000000)
+
+#define V4L2_STD_PAL_BG (V4L2_STD_PAL_B |\
+ V4L2_STD_PAL_B1 |\
+ V4L2_STD_PAL_G)
+#define V4L2_STD_PAL_DK (V4L2_STD_PAL_D |\
+ V4L2_STD_PAL_D1 |\
+ V4L2_STD_PAL_K)
+#define V4L2_STD_PAL (V4L2_STD_PAL_BG |\
+ V4L2_STD_PAL_DK |\
+ V4L2_STD_PAL_H |\
+ V4L2_STD_PAL_I)
+#define V4L2_STD_NTSC (V4L2_STD_NTSC_M |\
+ V4L2_STD_NTSC_M_JP)
+#define V4L2_STD_SECAM (V4L2_STD_SECAM_B |\
+ V4L2_STD_SECAM_D |\
+ V4L2_STD_SECAM_G |\
+ V4L2_STD_SECAM_H |\
+ V4L2_STD_SECAM_K |\
+ V4L2_STD_SECAM_K1 |\
+ V4L2_STD_SECAM_L)
+
+#define V4L2_STD_525_60 (V4L2_STD_PAL_M |\
+ V4L2_STD_PAL_60 |\
+ V4L2_STD_NTSC)
+#define V4L2_STD_625_50 (V4L2_STD_PAL |\
+ V4L2_STD_PAL_N |\
+ V4L2_STD_PAL_Nc |\
+ V4L2_STD_SECAM)
+
+#define V4L2_STD_UNKNOWN 0
+#define V4L2_STD_ALL (V4L2_STD_525_60 |\
+ V4L2_STD_625_50)</PRE
+></P
+><DIV
+CLASS="TABLE"
+><A
+NAME="VIDEO-STANDARDS"
+></A
+><P
+><B
+>Table 4. Video Standards (based on [<A
+HREF="#ITU470"
+><ABBR
+CLASS="ABBREV"
+>ITU470</ABBR
+></A
+>])</B
+></P
+><TABLE
+BORDER="1"
+RULES="all"
+WIDTH="100%"
+CLASS="CALSTABLE"
+><COL
+WIDTH="12%"
+ALIGN="LEFT"
+TITLE="C1"><COL
+WIDTH="12%"
+TITLE="C2"><COL
+WIDTH="12%"
+TITLE="C3"><COL
+WIDTH="12%"
+TITLE="C4"><COL
+WIDTH="12%"
+TITLE="C5"><COL><COL
+WIDTH="12%"
+TITLE="C7"><COL><COL
+WIDTH="12%"
+TITLE="C9"><COL><COL><COL
+WIDTH="12%"
+TITLE="C12"><THEAD
+><TR
+><TH
+>Characteristics</TH
+><TH
+><P
+>M/NTSC<SUP
+>a</SUP
+></P
+></TH
+><TH
+>M/PAL</TH
+><TH
+><P
+>N/PAL<SUP
+>b</SUP
+></P
+></TH
+><TH
+ALIGN="CENTER"
+>B, B1, G/PAL</TH
+><TH
+ALIGN="CENTER"
+>D, D1, K/PAL</TH
+><TH
+ALIGN="CENTER"
+>H/PAL</TH
+><TH
+ALIGN="CENTER"
+>I/PAL</TH
+><TH
+ALIGN="CENTER"
+>B, G/SECAM</TH
+><TH
+ALIGN="CENTER"
+>D, K/SECAM</TH
+><TH
+ALIGN="CENTER"
+>K1/SECAM</TH
+><TH
+ALIGN="CENTER"
+>L/SECAM</TH
+></TR
+></THEAD
+><TBODY
+><TR
+><TD
+>Frame lines</TD
+><TD
+COLSPAN="2"
+ALIGN="CENTER"
+>525</TD
+><TD
+COLSPAN="9"
+ALIGN="CENTER"
+>625</TD
+></TR
+><TR
+><TD
+>Frame period (s)</TD
+><TD
+COLSPAN="2"
+ALIGN="CENTER"
+>1001/30000</TD
+><TD
+COLSPAN="9"
+ALIGN="CENTER"
+>1/25</TD
+></TR
+><TR
+><TD
+>Chrominance sub-carrier frequency (Hz)</TD
+><TD
+>3579545 &plusmn;&nbsp;10</TD
+><TD
+>3579611.49 &plusmn;&nbsp;10</TD
+><TD
+>4433618.75 &plusmn;&nbsp;5 (3582056.25
+&plusmn;&nbsp;5)</TD
+><TD
+COLSPAN="3"
+ALIGN="CENTER"
+>4433618.75 &plusmn;&nbsp;5</TD
+><TD
+>4433618.75 &plusmn;&nbsp;1</TD
+><TD
+COLSPAN="4"
+ALIGN="CENTER"
+>f<SUB
+>OR</SUB
+>&nbsp;=
+4406250 &plusmn;&nbsp;2000, f<SUB
+>OB</SUB
+>&nbsp;= 4250000
+&plusmn;&nbsp;2000</TD
+></TR
+><TR
+><TD
+>Nominal radio-frequency channel bandwidth
+(MHz)</TD
+><TD
+>6</TD
+><TD
+>6</TD
+><TD
+>6</TD
+><TD
+>B: 7; B1, G: 8</TD
+><TD
+>8</TD
+><TD
+>8</TD
+><TD
+>8</TD
+><TD
+>8</TD
+><TD
+>8</TD
+><TD
+>8</TD
+><TD
+>8</TD
+></TR
+><TR
+><TD
+>Sound carrier relative to vision carrier
+(MHz)</TD
+><TD
+>+&nbsp;4.5</TD
+><TD
+>+&nbsp;4.5</TD
+><TD
+>+&nbsp;4.5</TD
+><TD
+><P
+>+&nbsp;5.5 &plusmn;&nbsp;0.001
+<SUP
+>c</SUP
+> <SUP
+>d</SUP
+> <SUP
+>e</SUP
+> <SUP
+>f</SUP
+></P
+></TD
+><TD
+>+&nbsp;6.5 &plusmn;&nbsp;0.001</TD
+><TD
+>+&nbsp;5.5</TD
+><TD
+>+&nbsp;5.9996 &plusmn;&nbsp;0.0005</TD
+><TD
+>+&nbsp;5.5 &plusmn;&nbsp;0.001</TD
+><TD
+>+&nbsp;6.5 &plusmn;&nbsp;0.001</TD
+><TD
+>+&nbsp;6.5</TD
+><TD
+><P
+>+&nbsp;6.5 <SUP
+>g</SUP
+></P
+></TD
+></TR
+></TBODY
+><TR
+><TD
+COLSPAN="12"
+>Notes:<BR><A
+NAME="FTN.AEN5849"
+>a. </A
+>Japan uses a standard
+similar to M/NTSC
+(V4L2_STD_NTSC_M_JP).<BR><A
+NAME="FTN.AEN5854"
+>b. </A
+> The values in
+brackets apply to the combination N/PAL a.k.a.
+N<SUB
+>C</SUB
+> used in Argentina
+(V4L2_STD_PAL_Nc).<BR><A
+NAME="FTN.AEN5904"
+>c. </A
+>In the Federal Republic of Germany, Austria, Italy,
+the Netherlands, Slovakia and Switzerland a system of two sound
+carriers is used, the frequency of the second carrier being
+242.1875&nbsp;kHz above the frequency of the first sound carrier. For
+stereophonic sound transmissions a similar system is used in
+Australia.<BR><A
+NAME="FTN.AEN5906"
+>d. </A
+>New Zealand uses a sound
+carrier displaced 5.4996 &plusmn;&nbsp;0.0005 MHz from the vision
+carrier.<BR><A
+NAME="FTN.AEN5908"
+>e. </A
+>In Denmark, Finland, New
+Zealand, Sweden and Spain a system of two sound carriers is used. In
+Iceland, Norway and Poland the same system is being introduced. The
+second carrier is 5.85&nbsp;MHz above the vision carrier and is DQPSK
+modulated with 728&nbsp;kbit/s sound and data multiplex. (NICAM
+system)<BR><A
+NAME="FTN.AEN5910"
+>f. </A
+>In the United Kingdom, a
+system of two sound carriers is used. The second sound carrier is
+6.552&nbsp;MHz above the vision carrier and is DQPSK modulated with a
+728&nbsp;kbit/s sound and data multiplex able to carry two sound
+channels. (NICAM system)<BR><A
+NAME="FTN.AEN5920"
+>g. </A
+>In France, a
+digital carrier 5.85 MHz away from the vision carrier may be used in
+addition to the main sound carrier. It is modulated in differentially
+encoded QPSK with a 728 kbit/s sound and data multiplexer capable of
+carrying two sound channels. (NICAM
+system)<BR></TD
+></TR
+></TABLE
+></DIV
+></DIV
+><DIV
+CLASS="REFSECT1"
+><A
+NAME="AEN5922"
+></A
+><H2
+>Return Value</H2
+><P
+>On success <SPAN
+CLASS="RETURNVALUE"
+>0</SPAN
+> is returned, on
+error <SPAN
+CLASS="RETURNVALUE"
+>-1</SPAN
+> and <VAR
+CLASS="VARNAME"
+>errno</VAR
+> is
+set appropriately:</P
+><P
+></P
+><DIV
+CLASS="VARIABLELIST"
+><DL
+><DT
+><SPAN
+CLASS="ERRORCODE"
+>EINVAL</SPAN
+></DT
+><DD
+><P
+>The struct&nbsp;<A
+HREF="#V4L2-STANDARD"
+>v4l2_standard</A
+> <CODE
+CLASS="STRUCTFIELD"
+>index</CODE
+>
+is out of bounds.</P
+></DD
+></DL
+></DIV
+></DIV
+><H1
+><A
+NAME="VIDIOC-G-AUDIO"
+></A
+>ioctl VIDIOC_G_AUDIO, VIDIOC_S_AUDIO</H1
+><DIV
+CLASS="REFNAMEDIV"
+><A
+NAME="AEN5939"
+></A
+><H2
+>Name</H2
+>ioctl VIDIOC_G_AUDIO, ioctl VIDIOC_S_AUDIO&nbsp;--&nbsp;Query or select the current audio input and its
+attributes</DIV
+><DIV
+CLASS="REFSYNOPSISDIV"
+><A
+NAME="AEN5943"
+></A
+><H2
+>Synopsis</H2
+><DIV
+CLASS="FUNCSYNOPSIS"
+><P
+></P
+><A
+NAME="AEN5944"
+></A
+><P
+><CODE
+><CODE
+CLASS="FUNCDEF"
+>int ioctl</CODE
+>(int fd, int request, struct v4l2_audio *argp);</CODE
+></P
+><P
+></P
+></DIV
+><DIV
+CLASS="FUNCSYNOPSIS"
+><P
+></P
+><A
+NAME="AEN5954"
+></A
+><P
+><CODE
+><CODE
+CLASS="FUNCDEF"
+>int ioctl</CODE
+>(int fd, int request, const struct v4l2_audio *argp);</CODE
+></P
+><P
+></P
+></DIV
+></DIV
+><DIV
+CLASS="REFSECT1"
+><A
+NAME="AEN5964"
+></A
+><H2
+>Arguments</H2
+><P
+></P
+><DIV
+CLASS="VARIABLELIST"
+><DL
+><DT
+><VAR
+CLASS="PARAMETER"
+>fd</VAR
+></DT
+><DD
+><P
+>File descriptor returned by <A
+HREF="#FUNC-OPEN"
+><CODE
+CLASS="FUNCTION"
+>open()</CODE
+></A
+>.</P
+></DD
+><DT
+><VAR
+CLASS="PARAMETER"
+>request</VAR
+></DT
+><DD
+><P
+>VIDIOC_G_AUDIO, VIDIOC_S_AUDIO</P
+></DD
+><DT
+><VAR
+CLASS="PARAMETER"
+>argp</VAR
+></DT
+><DD
+><P
+></P
+></DD
+></DL
+></DIV
+></DIV
+><DIV
+CLASS="REFSECT1"
+><A
+NAME="AEN5984"
+></A
+><H2
+>Description</H2
+><P
+>To query the current audio input applications zero out the
+<CODE
+CLASS="STRUCTFIELD"
+>reserved</CODE
+> array of a struct&nbsp;<A
+HREF="#V4L2-AUDIO"
+>v4l2_audio</A
+>
+and call the <CODE
+CLASS="CONSTANT"
+>VIDIOC_G_AUDIO</CODE
+> ioctl with a pointer
+to this structure. Drivers fill the rest of the structure or return an
+<SPAN
+CLASS="ERRORCODE"
+>EINVAL</SPAN
+> error code when the device has no audio inputs, or none which combine
+with the current video input.</P
+><P
+>Audio inputs have one writable property, the audio mode. To
+select the current audio input <SPAN
+CLASS="emphasis"
+><I
+CLASS="EMPHASIS"
+>and</I
+></SPAN
+> change the
+audio mode, applications initialize the
+<CODE
+CLASS="STRUCTFIELD"
+>index</CODE
+> and <CODE
+CLASS="STRUCTFIELD"
+>mode</CODE
+>
+fields, and the
+<CODE
+CLASS="STRUCTFIELD"
+>reserved</CODE
+> array of a
+<CODE
+CLASS="STRUCTNAME"
+>v4l2_audio</CODE
+> structure and call the
+<CODE
+CLASS="CONSTANT"
+>VIDIOC_S_AUDIO</CODE
+> ioctl. Drivers may switch to a
+different audio mode if the request cannot be satisfied. However, this
+is a write-only ioctl, it does not return the actual new audio
+mode.</P
+><DIV
+CLASS="TABLE"
+><A
+NAME="V4L2-AUDIO"
+></A
+><P
+><B
+>Table 1. struct <CODE
+CLASS="STRUCTNAME"
+>v4l2_audio</CODE
+></B
+></P
+><TABLE
+BORDER="0"
+FRAME="void"
+WIDTH="100%"
+CLASS="CALSTABLE"
+><COL
+WIDTH="25%"
+TITLE="C1"><COL
+WIDTH="25%"
+TITLE="C2"><COL
+WIDTH="50%"
+TITLE="C3"><TBODY
+><TR
+><TD
+>__u32</TD
+><TD
+><CODE
+CLASS="STRUCTFIELD"
+>index</CODE
+></TD
+><TD
+>Identifies the audio input, set by the
+driver or application.</TD
+></TR
+><TR
+><TD
+>__u8</TD
+><TD
+><CODE
+CLASS="STRUCTFIELD"
+>name</CODE
+>[32]</TD
+><TD
+>Name of the audio input, a NUL-terminated ASCII
+string, for example: "Line In". This information is intended for the
+user, preferably the connector label on the device itself.</TD
+></TR
+><TR
+><TD
+>__u32</TD
+><TD
+><CODE
+CLASS="STRUCTFIELD"
+>capability</CODE
+></TD
+><TD
+>Audio capability flags, see <A
+HREF="#AUDIO-CAPABILITY"
+>Table 2</A
+>.</TD
+></TR
+><TR
+><TD
+>__u32</TD
+><TD
+><CODE
+CLASS="STRUCTFIELD"
+>mode</CODE
+></TD
+><TD
+>Audio mode set by drivers and applications (on
+ <CODE
+CLASS="CONSTANT"
+>VIDIOC_S_AUDIO</CODE
+> ioctl), see <A
+HREF="#AUDIO-MODE"
+>Table 3</A
+>.</TD
+></TR
+><TR
+><TD
+>__u32</TD
+><TD
+><CODE
+CLASS="STRUCTFIELD"
+>reserved</CODE
+>[2]</TD
+><TD
+>Reserved for future extensions. Drivers and
+applications must set the array to zero.</TD
+></TR
+></TBODY
+></TABLE
+></DIV
+><DIV
+CLASS="TABLE"
+><A
+NAME="AUDIO-CAPABILITY"
+></A
+><P
+><B
+>Table 2. Audio Capability Flags</B
+></P
+><TABLE
+BORDER="0"
+FRAME="void"
+WIDTH="100%"
+CLASS="CALSTABLE"
+><COL
+WIDTH="38%"
+TITLE="C1"><COL
+WIDTH="12%"
+TITLE="C2"><COL
+WIDTH="50%"
+TITLE="C3"><TBODY
+><TR
+><TD
+><CODE
+CLASS="CONSTANT"
+>V4L2_AUDCAP_STEREO</CODE
+></TD
+><TD
+>0x00001</TD
+><TD
+>This is a stereo input. The flag is intended to
+automatically disable stereo recording etc. when the signal is always
+monaural. The API provides no means to detect if stereo is
+<SPAN
+CLASS="emphasis"
+><I
+CLASS="EMPHASIS"
+>received</I
+></SPAN
+>, unless the audio input belongs to a
+tuner.</TD
+></TR
+><TR
+><TD
+><CODE
+CLASS="CONSTANT"
+>V4L2_AUDCAP_AVL</CODE
+></TD
+><TD
+>0x00002</TD
+><TD
+>Automatic Volume Level mode is supported.</TD
+></TR
+></TBODY
+></TABLE
+></DIV
+><DIV
+CLASS="TABLE"
+><A
+NAME="AUDIO-MODE"
+></A
+><P
+><B
+>Table 3. Audio Modes</B
+></P
+><TABLE
+BORDER="0"
+FRAME="void"
+WIDTH="100%"
+CLASS="CALSTABLE"
+><COL
+WIDTH="38%"
+TITLE="C1"><COL
+WIDTH="12%"
+TITLE="C2"><COL
+WIDTH="50%"
+TITLE="C3"><TBODY
+><TR
+><TD
+><CODE
+CLASS="CONSTANT"
+>V4L2_AUDMODE_AVL</CODE
+></TD
+><TD
+>0x00001</TD
+><TD
+>AVL mode is on.</TD
+></TR
+></TBODY
+></TABLE
+></DIV
+></DIV
+><DIV
+CLASS="REFSECT1"
+><A
+NAME="AEN6067"
+></A
+><H2
+>Return Value</H2
+><P
+>On success <SPAN
+CLASS="RETURNVALUE"
+>0</SPAN
+> is returned, on
+error <SPAN
+CLASS="RETURNVALUE"
+>-1</SPAN
+> and <VAR
+CLASS="VARNAME"
+>errno</VAR
+> is
+set appropriately:</P
+><P
+></P
+><DIV
+CLASS="VARIABLELIST"
+><DL
+><DT
+><SPAN
+CLASS="ERRORCODE"
+>EINVAL</SPAN
+></DT
+><DD
+><P
+>No audio inputs combine with the current video input,
+or the number of the selected audio input is out of bounds or it does
+not combine, or there are no audio inputs at all and the ioctl is not
+supported.</P
+></DD
+><DT
+><SPAN
+CLASS="ERRORCODE"
+>EBUSY</SPAN
+></DT
+><DD
+><P
+>I/O is in progress, the input cannot be
+switched.</P
+></DD
+></DL
+></DIV
+></DIV
+><H1
+><A
+NAME="VIDIOC-G-AUDIOOUT"
+></A
+>ioctl VIDIOC_G_AUDOUT, VIDIOC_S_AUDOUT</H1
+><DIV
+CLASS="REFNAMEDIV"
+><A
+NAME="AEN6087"
+></A
+><H2
+>Name</H2
+>ioctl VIDIOC_G_AUDOUT, ioctl VIDIOC_S_AUDOUT&nbsp;--&nbsp;Query or select the current audio output</DIV
+><DIV
+CLASS="REFSYNOPSISDIV"
+><A
+NAME="AEN6091"
+></A
+><H2
+>Synopsis</H2
+><DIV
+CLASS="FUNCSYNOPSIS"
+><P
+></P
+><A
+NAME="AEN6092"
+></A
+><P
+><CODE
+><CODE
+CLASS="FUNCDEF"
+>int ioctl</CODE
+>(int fd, int request, struct v4l2_audioout *argp);</CODE
+></P
+><P
+></P
+></DIV
+><DIV
+CLASS="FUNCSYNOPSIS"
+><P
+></P
+><A
+NAME="AEN6102"
+></A
+><P
+><CODE
+><CODE
+CLASS="FUNCDEF"
+>int ioctl</CODE
+>(int fd, int request, const struct v4l2_audioout *argp);</CODE
+></P
+><P
+></P
+></DIV
+></DIV
+><DIV
+CLASS="REFSECT1"
+><A
+NAME="AEN6112"
+></A
+><H2
+>Arguments</H2
+><P
+></P
+><DIV
+CLASS="VARIABLELIST"
+><DL
+><DT
+><VAR
+CLASS="PARAMETER"
+>fd</VAR
+></DT
+><DD
+><P
+>File descriptor returned by <A
+HREF="#FUNC-OPEN"
+><CODE
+CLASS="FUNCTION"
+>open()</CODE
+></A
+>.</P
+></DD
+><DT
+><VAR
+CLASS="PARAMETER"
+>request</VAR
+></DT
+><DD
+><P
+>VIDIOC_G_AUDOUT, VIDIOC_S_AUDOUT</P
+></DD
+><DT
+><VAR
+CLASS="PARAMETER"
+>argp</VAR
+></DT
+><DD
+><P
+></P
+></DD
+></DL
+></DIV
+></DIV
+><DIV
+CLASS="REFSECT1"
+><A
+NAME="AEN6132"
+></A
+><H2
+>Description</H2
+><P
+>To query the current audio output applications zero out the
+<CODE
+CLASS="STRUCTFIELD"
+>reserved</CODE
+> array of a struct&nbsp;<A
+HREF="#V4L2-AUDIOOUT"
+>v4l2_audioout</A
+> and
+call the <CODE
+CLASS="CONSTANT"
+>VIDIOC_G_AUDOUT</CODE
+> ioctl with a pointer
+to this structure. Drivers fill the rest of the structure or return an
+<SPAN
+CLASS="ERRORCODE"
+>EINVAL</SPAN
+> error code when the device has no audio inputs, or none which combine
+with the current video output.</P
+><P
+>Audio outputs have no writable properties. Nevertheless, to
+select the current audio output applications can initialize the
+<CODE
+CLASS="STRUCTFIELD"
+>index</CODE
+> field and
+<CODE
+CLASS="STRUCTFIELD"
+>reserved</CODE
+> array (which in the future may
+contain writable properties) of a
+<CODE
+CLASS="STRUCTNAME"
+>v4l2_audioout</CODE
+> structure and call the
+<CODE
+CLASS="CONSTANT"
+>VIDIOC_S_AUDOUT</CODE
+> ioctl. Drivers switch to the
+requested output or return the <SPAN
+CLASS="ERRORCODE"
+>EINVAL</SPAN
+> error code when the index is out of
+bounds. This is a write-only ioctl, it does not return the current
+audio output attributes as <CODE
+CLASS="CONSTANT"
+>VIDIOC_G_AUDOUT</CODE
+>
+does.</P
+><P
+>Note connectors on a TV card to loop back the received audio
+signal to a sound card are not audio outputs in this sense.</P
+><DIV
+CLASS="TABLE"
+><A
+NAME="V4L2-AUDIOOUT"
+></A
+><P
+><B
+>Table 1. struct <CODE
+CLASS="STRUCTNAME"
+>v4l2_audioout</CODE
+></B
+></P
+><TABLE
+BORDER="0"
+FRAME="void"
+WIDTH="100%"
+CLASS="CALSTABLE"
+><COL
+WIDTH="25%"
+TITLE="C1"><COL
+WIDTH="25%"
+TITLE="C2"><COL
+WIDTH="50%"
+TITLE="C3"><TBODY
+><TR
+><TD
+>__u32</TD
+><TD
+><CODE
+CLASS="STRUCTFIELD"
+>index</CODE
+></TD
+><TD
+>Identifies the audio output, set by the
+driver or application.</TD
+></TR
+><TR
+><TD
+>__u8</TD
+><TD
+><CODE
+CLASS="STRUCTFIELD"
+>name</CODE
+>[32]</TD
+><TD
+>Name of the audio output, a NUL-terminated ASCII
+string, for example: "Line Out". This information is intended for the
+user, preferably the connector label on the device itself.</TD
+></TR
+><TR
+><TD
+>__u32</TD
+><TD
+><CODE
+CLASS="STRUCTFIELD"
+>capability</CODE
+></TD
+><TD
+>Audio capability flags, none defined yet. Drivers
+must set this field to zero.</TD
+></TR
+><TR
+><TD
+>__u32</TD
+><TD
+><CODE
+CLASS="STRUCTFIELD"
+>mode</CODE
+></TD
+><TD
+>Audio mode, none defined yet. Drivers and
+applications (on <CODE
+CLASS="CONSTANT"
+>VIDIOC_S_AUDOUT</CODE
+>) must set this
+field to zero.</TD
+></TR
+><TR
+><TD
+>__u32</TD
+><TD
+><CODE
+CLASS="STRUCTFIELD"
+>reserved</CODE
+>[2]</TD
+><TD
+>Reserved for future extensions. Drivers and
+applications must set the array to zero.</TD
+></TR
+></TBODY
+></TABLE
+></DIV
+></DIV
+><DIV
+CLASS="REFSECT1"
+><A
+NAME="AEN6182"
+></A
+><H2
+>Return Value</H2
+><P
+>On success <SPAN
+CLASS="RETURNVALUE"
+>0</SPAN
+> is returned, on
+error <SPAN
+CLASS="RETURNVALUE"
+>-1</SPAN
+> and <VAR
+CLASS="VARNAME"
+>errno</VAR
+> is
+set appropriately:</P
+><P
+></P
+><DIV
+CLASS="VARIABLELIST"
+><DL
+><DT
+><SPAN
+CLASS="ERRORCODE"
+>EINVAL</SPAN
+></DT
+><DD
+><P
+>No audio outputs combine with the current video
+output, or the number of the selected audio output is out of bounds or
+it does not combine, or there are no audio outputs at all and the
+ioctl is not supported.</P
+></DD
+><DT
+><SPAN
+CLASS="ERRORCODE"
+>EBUSY</SPAN
+></DT
+><DD
+><P
+>I/O is in progress, the output cannot be
+switched.</P
+></DD
+></DL
+></DIV
+></DIV
+><H1
+><A
+NAME="VIDIOC-G-COMP"
+></A
+>ioctl VIDIOC_G_COMP, VIDIOC_S_COMP</H1
+><DIV
+CLASS="REFNAMEDIV"
+><A
+NAME="AEN6202"
+></A
+><H2
+>Name</H2
+>ioctl VIDIOC_G_COMP, ioctl VIDIOC_S_COMP&nbsp;--&nbsp;Get or set compression parameters</DIV
+><DIV
+CLASS="REFSYNOPSISDIV"
+><A
+NAME="AEN6206"
+></A
+><H2
+>Synopsis</H2
+><DIV
+CLASS="FUNCSYNOPSIS"
+><P
+></P
+><A
+NAME="AEN6207"
+></A
+><P
+><CODE
+><CODE
+CLASS="FUNCDEF"
+>int ioctl</CODE
+>(int fd, int request, v4l2_compression *argp);</CODE
+></P
+><P
+></P
+></DIV
+></DIV
+><DIV
+CLASS="REFSECT1"
+><A
+NAME="AEN6217"
+></A
+><H2
+>Arguments</H2
+><P
+></P
+><DIV
+CLASS="VARIABLELIST"
+><DL
+><DT
+><VAR
+CLASS="PARAMETER"
+>fd</VAR
+></DT
+><DD
+><P
+>File descriptor returned by <A
+HREF="#FUNC-OPEN"
+><CODE
+CLASS="FUNCTION"
+>open()</CODE
+></A
+>.</P
+></DD
+><DT
+><VAR
+CLASS="PARAMETER"
+>request</VAR
+></DT
+><DD
+><P
+>VIDIOC_G_COMP, VIDIOC_S_COMP</P
+></DD
+><DT
+><VAR
+CLASS="PARAMETER"
+>argp</VAR
+></DT
+><DD
+><P
+></P
+></DD
+></DL
+></DIV
+></DIV
+><DIV
+CLASS="REFSECT1"
+><A
+NAME="AEN6237"
+></A
+><H2
+>Description</H2
+><P
+>[to do]</P
+><DIV
+CLASS="TABLE"
+><A
+NAME="V4L2-COMPRESSION"
+></A
+><P
+><B
+>Table 1. struct <CODE
+CLASS="STRUCTNAME"
+>v4l2_compression</CODE
+></B
+></P
+><TABLE
+BORDER="0"
+FRAME="void"
+WIDTH="100%"
+CLASS="CALSTABLE"
+><COL
+WIDTH="25%"
+TITLE="C1"><COL
+WIDTH="25%"
+TITLE="C2"><COL
+WIDTH="50%"
+TITLE="C3"><TBODY
+><TR
+><TD
+>__u32</TD
+><TD
+><CODE
+CLASS="STRUCTFIELD"
+>quality</CODE
+></TD
+><TD
+>&nbsp;</TD
+></TR
+><TR
+><TD
+>__u32</TD
+><TD
+><CODE
+CLASS="STRUCTFIELD"
+>keyframerate</CODE
+></TD
+><TD
+>&nbsp;</TD
+></TR
+><TR
+><TD
+>__u32</TD
+><TD
+><CODE
+CLASS="STRUCTFIELD"
+>pframerate</CODE
+></TD
+><TD
+>&nbsp;</TD
+></TR
+><TR
+><TD
+>__u32</TD
+><TD
+><CODE
+CLASS="STRUCTFIELD"
+>reserved</CODE
+>[5]</TD
+><TD
+>&nbsp;</TD
+></TR
+></TBODY
+></TABLE
+></DIV
+></DIV
+><DIV
+CLASS="REFSECT1"
+><A
+NAME="AEN6269"
+></A
+><H2
+>Return Value</H2
+><P
+>On success <SPAN
+CLASS="RETURNVALUE"
+>0</SPAN
+> is returned, on
+error <SPAN
+CLASS="RETURNVALUE"
+>-1</SPAN
+> and <VAR
+CLASS="VARNAME"
+>errno</VAR
+> is
+set appropriately:</P
+><P
+></P
+><DIV
+CLASS="VARIABLELIST"
+><DL
+><DT
+><SPAN
+CLASS="ERRORCODE"
+>EINVAL</SPAN
+></DT
+><DD
+><P
+>This ioctl is not supported</P
+></DD
+></DL
+></DIV
+></DIV
+><H1
+><A
+NAME="VIDIOC-G-CROP"
+></A
+>ioctl VIDIOC_G_CROP, VIDIOC_S_CROP</H1
+><DIV
+CLASS="REFNAMEDIV"
+><A
+NAME="AEN6284"
+></A
+><H2
+>Name</H2
+>ioctl VIDIOC_G_CROP, ioctl VIDIOC_S_CROP&nbsp;--&nbsp;Get or set the current cropping rectangle</DIV
+><DIV
+CLASS="REFSYNOPSISDIV"
+><A
+NAME="AEN6288"
+></A
+><H2
+>Synopsis</H2
+><DIV
+CLASS="FUNCSYNOPSIS"
+><P
+></P
+><A
+NAME="AEN6289"
+></A
+><P
+><CODE
+><CODE
+CLASS="FUNCDEF"
+>int ioctl</CODE
+>(int fd, int request, struct v4l2_crop *argp);</CODE
+></P
+><P
+></P
+></DIV
+><DIV
+CLASS="FUNCSYNOPSIS"
+><P
+></P
+><A
+NAME="AEN6299"
+></A
+><P
+><CODE
+><CODE
+CLASS="FUNCDEF"
+>int ioctl</CODE
+>(int fd, int request, const struct v4l2_crop *argp);</CODE
+></P
+><P
+></P
+></DIV
+></DIV
+><DIV
+CLASS="REFSECT1"
+><A
+NAME="AEN6309"
+></A
+><H2
+>Arguments</H2
+><P
+></P
+><DIV
+CLASS="VARIABLELIST"
+><DL
+><DT
+><VAR
+CLASS="PARAMETER"
+>fd</VAR
+></DT
+><DD
+><P
+>File descriptor returned by <A
+HREF="#FUNC-OPEN"
+><CODE
+CLASS="FUNCTION"
+>open()</CODE
+></A
+>.</P
+></DD
+><DT
+><VAR
+CLASS="PARAMETER"
+>request</VAR
+></DT
+><DD
+><P
+>VIDIOC_G_CROP, VIDIOC_S_CROP</P
+></DD
+><DT
+><VAR
+CLASS="PARAMETER"
+>argp</VAR
+></DT
+><DD
+><P
+></P
+></DD
+></DL
+></DIV
+></DIV
+><DIV
+CLASS="REFSECT1"
+><A
+NAME="AEN6329"
+></A
+><H2
+>Description</H2
+><P
+>To query the cropping rectangle size and position
+applications set the <CODE
+CLASS="STRUCTFIELD"
+>type</CODE
+> field of a
+<CODE
+CLASS="STRUCTNAME"
+>v4l2_crop</CODE
+> structure to the respective buffer
+(stream) type and call the <CODE
+CLASS="CONSTANT"
+>VIDIOC_G_CROP</CODE
+> ioctl
+with a pointer to this structure. The driver fills the rest of the
+structure or returns the <SPAN
+CLASS="ERRORCODE"
+>EINVAL</SPAN
+> error code if cropping is not supported.</P
+><P
+>To change the cropping rectangle applications initialize the
+<CODE
+CLASS="STRUCTFIELD"
+>type</CODE
+> and struct&nbsp;<A
+HREF="#V4L2-RECT"
+>v4l2_rect</A
+> substructure named
+<CODE
+CLASS="STRUCTFIELD"
+>c</CODE
+> of a v4l2_crop structure and call the
+<CODE
+CLASS="CONSTANT"
+>VIDIOC_S_CROP</CODE
+> ioctl with a pointer to this
+structure.</P
+><P
+>The driver first adjusts the requested dimensions against
+hardware limits, i.&nbsp;e. the bounds given by the capture/output window,
+and it rounds to the closest possible values of horizontal and
+vertical offset, width and height. In particular the driver must round
+the vertical offset of the cropping rectangle to frame lines modulo
+two, such that the field order cannot be confused.</P
+><P
+>Second the driver adjusts the image size (the opposite
+rectangle of the scaling process, source or target depending on the
+data direction) to the closest size possible while maintaining the
+current horizontal and vertical scaling factor.</P
+><P
+>Finally the driver programs the hardware with the actual
+cropping and image parameters. <CODE
+CLASS="CONSTANT"
+>VIDIOC_S_CROP</CODE
+> is a
+write-only ioctl, it does not return the actual parameters. To query
+them applications must call <CODE
+CLASS="CONSTANT"
+>VIDIOC_G_CROP</CODE
+> and
+<A
+HREF="#VIDIOC-G-FMT"
+><CODE
+CLASS="CONSTANT"
+>VIDIOC_G_FMT</CODE
+></A
+>. When the parameters are unsuitable the application may
+modify the cropping or image parameters and repeat the cycle until
+satisfactory parameters have been negotiated.</P
+><P
+>When cropping is not supported then no parameters are
+changed and <CODE
+CLASS="CONSTANT"
+>VIDIOC_S_CROP</CODE
+> returns the
+<SPAN
+CLASS="ERRORCODE"
+>EINVAL</SPAN
+> error code.</P
+><DIV
+CLASS="TABLE"
+><A
+NAME="V4L2-CROP"
+></A
+><P
+><B
+>Table 1. struct <CODE
+CLASS="STRUCTNAME"
+>v4l2_crop</CODE
+></B
+></P
+><TABLE
+BORDER="0"
+FRAME="void"
+WIDTH="100%"
+CLASS="CALSTABLE"
+><COL
+WIDTH="25%"
+TITLE="C1"><COL
+WIDTH="25%"
+TITLE="C2"><COL
+WIDTH="50%"
+TITLE="C3"><TBODY
+><TR
+><TD
+>enum&nbsp;<A
+HREF="#V4L2-BUF-TYPE"
+>v4l2_buf_type</A
+></TD
+><TD
+><CODE
+CLASS="STRUCTFIELD"
+>type</CODE
+></TD
+><TD
+>Type of the data stream, set by the application.
+Only these types are valid here: <CODE
+CLASS="CONSTANT"
+>V4L2_BUF_TYPE_VIDEO_CAPTURE</CODE
+>,
+<CODE
+CLASS="CONSTANT"
+>V4L2_BUF_TYPE_VIDEO_OUTPUT</CODE
+>,
+<CODE
+CLASS="CONSTANT"
+>V4L2_BUF_TYPE_VIDEO_OVERLAY</CODE
+>, and custom (driver
+defined) types with code <CODE
+CLASS="CONSTANT"
+>V4L2_BUF_TYPE_PRIVATE</CODE
+>
+and higher.</TD
+></TR
+><TR
+><TD
+>struct&nbsp;<A
+HREF="#V4L2-RECT"
+>v4l2_rect</A
+></TD
+><TD
+><CODE
+CLASS="STRUCTFIELD"
+>c</CODE
+></TD
+><TD
+>Cropping rectangle. The same co-ordinate system as
+for struct&nbsp;<A
+HREF="#V4L2-CROPCAP"
+>v4l2_cropcap</A
+> <CODE
+CLASS="STRUCTFIELD"
+>bounds</CODE
+> is used.</TD
+></TR
+></TBODY
+></TABLE
+></DIV
+></DIV
+><DIV
+CLASS="REFSECT1"
+><A
+NAME="AEN6378"
+></A
+><H2
+>Return Value</H2
+><P
+>On success <SPAN
+CLASS="RETURNVALUE"
+>0</SPAN
+> is returned, on
+error <SPAN
+CLASS="RETURNVALUE"
+>-1</SPAN
+> and <VAR
+CLASS="VARNAME"
+>errno</VAR
+> is
+set appropriately:</P
+><P
+></P
+><DIV
+CLASS="VARIABLELIST"
+><DL
+><DT
+><SPAN
+CLASS="ERRORCODE"
+>EINVAL</SPAN
+></DT
+><DD
+><P
+>Cropping is not supported.</P
+></DD
+></DL
+></DIV
+></DIV
+><H1
+><A
+NAME="VIDIOC-G-CTRL"
+></A
+>ioctl VIDIOC_G_CTRL, VIDIOC_S_CTRL</H1
+><DIV
+CLASS="REFNAMEDIV"
+><A
+NAME="AEN6393"
+></A
+><H2
+>Name</H2
+>ioctl VIDIOC_G_CTRL, ioctl VIDIOC_S_CTRL&nbsp;--&nbsp;Get or set the value of a control</DIV
+><DIV
+CLASS="REFSYNOPSISDIV"
+><A
+NAME="AEN6397"
+></A
+><H2
+>Synopsis</H2
+><DIV
+CLASS="FUNCSYNOPSIS"
+><P
+></P
+><A
+NAME="AEN6398"
+></A
+><P
+><CODE
+><CODE
+CLASS="FUNCDEF"
+>int ioctl</CODE
+>(int fd, int request, struct v4l2_control
+*argp);</CODE
+></P
+><P
+></P
+></DIV
+></DIV
+><DIV
+CLASS="REFSECT1"
+><A
+NAME="AEN6408"
+></A
+><H2
+>Arguments</H2
+><P
+></P
+><DIV
+CLASS="VARIABLELIST"
+><DL
+><DT
+><VAR
+CLASS="PARAMETER"
+>fd</VAR
+></DT
+><DD
+><P
+>File descriptor returned by <A
+HREF="#FUNC-OPEN"
+><CODE
+CLASS="FUNCTION"
+>open()</CODE
+></A
+>.</P
+></DD
+><DT
+><VAR
+CLASS="PARAMETER"
+>request</VAR
+></DT
+><DD
+><P
+>VIDIOC_G_CTRL, VIDIOC_S_CTRL</P
+></DD
+><DT
+><VAR
+CLASS="PARAMETER"
+>argp</VAR
+></DT
+><DD
+><P
+></P
+></DD
+></DL
+></DIV
+></DIV
+><DIV
+CLASS="REFSECT1"
+><A
+NAME="AEN6428"
+></A
+><H2
+>Description</H2
+><P
+>To get the current value of a control applications
+initialize the <CODE
+CLASS="STRUCTFIELD"
+>id</CODE
+> field of a struct
+<CODE
+CLASS="STRUCTNAME"
+>v4l2_control</CODE
+> and call the
+<CODE
+CLASS="CONSTANT"
+>VIDIOC_G_CTRL</CODE
+> ioctl with a pointer to this
+structure. To change the value of a control applications initialize
+the <CODE
+CLASS="STRUCTFIELD"
+>id</CODE
+> and <CODE
+CLASS="STRUCTFIELD"
+>value</CODE
+>
+fields of a struct <CODE
+CLASS="STRUCTNAME"
+>v4l2_control</CODE
+> and call the
+<CODE
+CLASS="CONSTANT"
+>VIDIOC_S_CTRL</CODE
+> ioctl.</P
+><P
+>When the <CODE
+CLASS="STRUCTFIELD"
+>id</CODE
+> is invalid drivers
+return an <SPAN
+CLASS="ERRORCODE"
+>EINVAL</SPAN
+> error code. When the <CODE
+CLASS="STRUCTFIELD"
+>value</CODE
+> is out
+of bounds drivers can choose to take the closest valid value or return
+an <SPAN
+CLASS="ERRORCODE"
+>ERANGE</SPAN
+> error code, whatever seems more appropriate. However,
+<CODE
+CLASS="CONSTANT"
+>VIDIOC_S_CTRL</CODE
+> is a write-only ioctl, it does not
+return the actual new value.</P
+><DIV
+CLASS="TABLE"
+><A
+NAME="V4L2-CONTROL"
+></A
+><P
+><B
+>Table 1. struct <CODE
+CLASS="STRUCTNAME"
+>v4l2_control</CODE
+></B
+></P
+><TABLE
+BORDER="0"
+FRAME="void"
+WIDTH="100%"
+CLASS="CALSTABLE"
+><COL
+WIDTH="25%"
+TITLE="C1"><COL
+WIDTH="25%"
+TITLE="C2"><COL
+WIDTH="50%"
+TITLE="C3"><TBODY
+><TR
+><TD
+>__u32</TD
+><TD
+><CODE
+CLASS="STRUCTFIELD"
+>id</CODE
+></TD
+><TD
+>Identifies the control, set by the
+application.</TD
+></TR
+><TR
+><TD
+>__s32</TD
+><TD
+><CODE
+CLASS="STRUCTFIELD"
+>value</CODE
+></TD
+><TD
+>New value or current value.</TD
+></TR
+></TBODY
+></TABLE
+></DIV
+></DIV
+><DIV
+CLASS="REFSECT1"
+><A
+NAME="AEN6463"
+></A
+><H2
+>Return Value</H2
+><P
+>On success <SPAN
+CLASS="RETURNVALUE"
+>0</SPAN
+> is returned, on
+error <SPAN
+CLASS="RETURNVALUE"
+>-1</SPAN
+> and <VAR
+CLASS="VARNAME"
+>errno</VAR
+> is
+set appropriately:</P
+><P
+></P
+><DIV
+CLASS="VARIABLELIST"
+><DL
+><DT
+><SPAN
+CLASS="ERRORCODE"
+>EINVAL</SPAN
+></DT
+><DD
+><P
+>The struct&nbsp;<A
+HREF="#V4L2-CONTROL"
+>v4l2_control</A
+> <CODE
+CLASS="STRUCTFIELD"
+>id</CODE
+> is
+invalid.</P
+></DD
+><DT
+><SPAN
+CLASS="ERRORCODE"
+>ERANGE</SPAN
+></DT
+><DD
+><P
+>The struct&nbsp;<A
+HREF="#V4L2-CONTROL"
+>v4l2_control</A
+> <CODE
+CLASS="STRUCTFIELD"
+>value</CODE
+>
+is out of bounds.</P
+></DD
+><DT
+><SPAN
+CLASS="ERRORCODE"
+>EBUSY</SPAN
+></DT
+><DD
+><P
+>The control is temporarily not changeable, possibly
+because another applications took over control of the device function
+this control belongs to.</P
+></DD
+></DL
+></DIV
+></DIV
+><H1
+><A
+NAME="VIDIOC-G-FBUF"
+></A
+>ioctl VIDIOC_G_FBUF, VIDIOC_S_FBUF</H1
+><DIV
+CLASS="REFNAMEDIV"
+><A
+NAME="AEN6492"
+></A
+><H2
+>Name</H2
+>ioctl VIDIOC_G_FBUF, ioctl VIDIOC_S_FBUF&nbsp;--&nbsp;Get or set frame buffer overlay parameters.</DIV
+><DIV
+CLASS="REFSYNOPSISDIV"
+><A
+NAME="AEN6496"
+></A
+><H2
+>Synopsis</H2
+><DIV
+CLASS="FUNCSYNOPSIS"
+><P
+></P
+><A
+NAME="AEN6497"
+></A
+><P
+><CODE
+><CODE
+CLASS="FUNCDEF"
+>int ioctl</CODE
+>(int fd, int request, struct v4l2_framebuffer *argp);</CODE
+></P
+><P
+></P
+></DIV
+><DIV
+CLASS="FUNCSYNOPSIS"
+><P
+></P
+><A
+NAME="AEN6507"
+></A
+><P
+><CODE
+><CODE
+CLASS="FUNCDEF"
+>int ioctl</CODE
+>(int fd, int request, const struct v4l2_framebuffer *argp);</CODE
+></P
+><P
+></P
+></DIV
+></DIV
+><DIV
+CLASS="REFSECT1"
+><A
+NAME="AEN6517"
+></A
+><H2
+>Arguments</H2
+><P
+></P
+><DIV
+CLASS="VARIABLELIST"
+><DL
+><DT
+><VAR
+CLASS="PARAMETER"
+>fd</VAR
+></DT
+><DD
+><P
+>File descriptor returned by <A
+HREF="#FUNC-OPEN"
+><CODE
+CLASS="FUNCTION"
+>open()</CODE
+></A
+>.</P
+></DD
+><DT
+><VAR
+CLASS="PARAMETER"
+>request</VAR
+></DT
+><DD
+><P
+>VIDIOC_G_FBUF, VIDIOC_S_FBUF</P
+></DD
+><DT
+><VAR
+CLASS="PARAMETER"
+>argp</VAR
+></DT
+><DD
+><P
+></P
+></DD
+></DL
+></DIV
+></DIV
+><DIV
+CLASS="REFSECT1"
+><A
+NAME="AEN6537"
+></A
+><H2
+>Description</H2
+><P
+>The <CODE
+CLASS="CONSTANT"
+>VIDIOC_G_FBUF</CODE
+> and
+<CODE
+CLASS="CONSTANT"
+>VIDIOC_S_FBUF</CODE
+> ioctl are used to get and set the
+frame buffer parameters for <A
+HREF="#OVERLAY"
+>video overlay</A
+>.</P
+><P
+>To get the current parameters applications call the
+<CODE
+CLASS="CONSTANT"
+>VIDIOC_G_FBUF</CODE
+> ioctl with a pointer to a
+<CODE
+CLASS="STRUCTNAME"
+>v4l2_framebuffer</CODE
+> structure, the driver fills
+all fields of the structure or returns the <SPAN
+CLASS="ERRORCODE"
+>EINVAL</SPAN
+> error code when overlay is
+not supported. To set the parameters applications initialize the
+<CODE
+CLASS="STRUCTFIELD"
+>flags</CODE
+> field,
+<CODE
+CLASS="STRUCTFIELD"
+>base</CODE
+> unless the overlay is of
+<CODE
+CLASS="CONSTANT"
+>V4L2_FBUF_CAP_EXTERNOVERLAY</CODE
+> type, and the
+struct&nbsp;<A
+HREF="#V4L2-PIX-FORMAT"
+>v4l2_pix_format</A
+> <CODE
+CLASS="STRUCTFIELD"
+>fmt</CODE
+> substructure. The driver
+accordingly prepares for overlay or returns an error code.</P
+><P
+>When the driver does <SPAN
+CLASS="emphasis"
+><I
+CLASS="EMPHASIS"
+>not</I
+></SPAN
+> support
+<CODE
+CLASS="CONSTANT"
+>V4L2_FBUF_CAP_EXTERNOVERLAY</CODE
+>, i.&nbsp;e. it will
+write into video memory, the <CODE
+CLASS="CONSTANT"
+>VIDIOC_S_FBUF</CODE
+> ioctl
+is a privileged function and only the superuser can change the frame
+buffer parameters.</P
+><DIV
+CLASS="TABLE"
+><A
+NAME="V4L2-FRAMEBUFFER"
+></A
+><P
+><B
+>Table 1. struct <CODE
+CLASS="STRUCTNAME"
+>v4l2_framebuffer</CODE
+></B
+></P
+><TABLE
+BORDER="0"
+FRAME="void"
+WIDTH="100%"
+CLASS="CALSTABLE"
+><COL
+WIDTH="50%"
+TITLE="C1"><COL><COL><COL
+WIDTH="50%"
+TITLE="C4"><TBODY
+><TR
+><TD
+>__u32</TD
+><TD
+><CODE
+CLASS="STRUCTFIELD"
+>capability</CODE
+></TD
+><TD
+>&nbsp;</TD
+><TD
+>Overlay capability flags set by the driver, see
+<A
+HREF="#FRAMEBUFFER-CAP"
+>Table 2</A
+>.</TD
+></TR
+><TR
+><TD
+>__u32</TD
+><TD
+><CODE
+CLASS="STRUCTFIELD"
+>flags</CODE
+></TD
+><TD
+>&nbsp;</TD
+><TD
+>Overlay control flags set by application and
+driver, see <A
+HREF="#FRAMEBUFFER-FLAGS"
+>Table 3</A
+></TD
+></TR
+><TR
+><TD
+>void *</TD
+><TD
+><CODE
+CLASS="STRUCTFIELD"
+>base</CODE
+></TD
+><TD
+>&nbsp;</TD
+><TD
+><P
+>Physical base address of the frame buffer,
+the address of the pixel at coordinates (0; 0) in the frame buffer.
+This field is not used when <CODE
+CLASS="CONSTANT"
+>VIDIOC_G_FBUF</CODE
+> sets
+the <CODE
+CLASS="CONSTANT"
+>V4L2_FBUF_CAP_EXTERNOVERLAY</CODE
+> flag in the
+<CODE
+CLASS="STRUCTFIELD"
+>capability</CODE
+> field.<SUP
+>a</SUP
+></P
+></TD
+></TR
+><TR
+><TD
+>struct&nbsp;<A
+HREF="#V4L2-PIX-FORMAT"
+>v4l2_pix_format</A
+></TD
+><TD
+><CODE
+CLASS="STRUCTFIELD"
+>fmt</CODE
+></TD
+><TD
+>&nbsp;</TD
+><TD
+>Physical layout of the frame buffer. The
+<CODE
+CLASS="STRUCTNAME"
+>v4l2_pix_format</CODE
+> structure is defined in <A
+HREF="#PIXFMT"
+>Chapter 2</A
+>, for clarification the fields and expected values
+are listed below.</TD
+></TR
+><TR
+><TD
+>&nbsp;</TD
+><TD
+>__u32</TD
+><TD
+><CODE
+CLASS="STRUCTFIELD"
+>width</CODE
+></TD
+><TD
+>Width of the frame buffer in pixels.</TD
+></TR
+><TR
+><TD
+>&nbsp;</TD
+><TD
+>__u32</TD
+><TD
+><CODE
+CLASS="STRUCTFIELD"
+>height</CODE
+></TD
+><TD
+>Height of the frame buffer in pixels. When the
+driver <SPAN
+CLASS="emphasis"
+><I
+CLASS="EMPHASIS"
+>clears</I
+></SPAN
+>
+<CODE
+CLASS="CONSTANT"
+>V4L2_FBUF_CAP_EXTERNOVERLAY</CODE
+>, the visible portion
+of the frame buffer can be smaller than width and height.</TD
+></TR
+><TR
+><TD
+>&nbsp;</TD
+><TD
+>__u32</TD
+><TD
+><CODE
+CLASS="STRUCTFIELD"
+>pixelformat</CODE
+></TD
+><TD
+>The pixel format of the graphics surface, set by
+the application. Usually this is an RGB format (for example RGB 5:6:5)
+but YUV formats are also permitted. The behavior of the driver when
+requesting a compressed format is undefined. See <A
+HREF="#PIXFMT"
+>Chapter 2</A
+> for information on pixel formats. This field is not
+used when the driver sets
+<CODE
+CLASS="CONSTANT"
+>V4L2_FBUF_CAP_EXTERNOVERLAY</CODE
+>.</TD
+></TR
+><TR
+><TD
+>&nbsp;</TD
+><TD
+>enum&nbsp;<A
+HREF="#V4L2-FIELD"
+>v4l2_field</A
+></TD
+><TD
+><CODE
+CLASS="STRUCTFIELD"
+>field</CODE
+></TD
+><TD
+>Ignored. The field order is selected with the
+<A
+HREF="#VIDIOC-G-FMT"
+><CODE
+CLASS="CONSTANT"
+>VIDIOC_S_FMT</CODE
+></A
+> ioctl using struct&nbsp;<A
+HREF="#V4L2-WINDOW"
+>v4l2_window</A
+>.</TD
+></TR
+><TR
+><TD
+>&nbsp;</TD
+><TD
+>__u32</TD
+><TD
+><CODE
+CLASS="STRUCTFIELD"
+>bytesperline</CODE
+></TD
+><TD
+>Distance in bytes between the leftmost pixels in two
+adjacent lines.</TD
+></TR
+><TR
+><TD
+COLSPAN="4"
+><P
+>Both applications and drivers
+can set this field to request padding bytes at the end of each line.
+Drivers however may ignore the value requested by the application,
+returning <CODE
+CLASS="STRUCTFIELD"
+>width</CODE
+> times bytes per pixel or a
+larger value required by the hardware. That implies applications can
+just set this field to zero to get a reasonable
+default.</P
+><P
+>Video hardware may access padding bytes,
+therefore they must reside in accessible memory. Consider cases where
+padding bytes after the last line of an image cross a system page
+boundary. Input devices may write padding bytes, the value is
+undefined. Output devices ignore the contents of padding
+bytes.</P
+><P
+>When the image format is planar the
+<CODE
+CLASS="STRUCTFIELD"
+>bytesperline</CODE
+> value applies to the largest
+plane and is divided by the same factor as the
+<CODE
+CLASS="STRUCTFIELD"
+>width</CODE
+> field for any smaller planes. For
+example the Cb and Cr planes of a YUV 4:2:0 image have half as many
+padding bytes following each line as the Y plane. To avoid ambiguities
+drivers must return a <CODE
+CLASS="STRUCTFIELD"
+>bytesperline</CODE
+> value
+rounded up to a multiple of the scale factor.</P
+><P
+>This
+field is not used when the driver sets
+<CODE
+CLASS="CONSTANT"
+>V4L2_FBUF_CAP_EXTERNOVERLAY</CODE
+>.</P
+></TD
+></TR
+><TR
+><TD
+>&nbsp;</TD
+><TD
+>__u32</TD
+><TD
+><CODE
+CLASS="STRUCTFIELD"
+>sizeimage</CODE
+></TD
+><TD
+><P
+>Applications must initialize this field.
+Together with <CODE
+CLASS="STRUCTFIELD"
+>base</CODE
+> it defines the frame
+buffer memory accessible by the driver.</P
+><P
+>The field is not
+used when the driver sets
+<CODE
+CLASS="CONSTANT"
+>V4L2_FBUF_CAP_EXTERNOVERLAY</CODE
+>.</P
+></TD
+></TR
+><TR
+><TD
+>&nbsp;</TD
+><TD
+>enum&nbsp;<A
+HREF="#V4L2-COLORSPACE"
+>v4l2_colorspace</A
+></TD
+><TD
+><CODE
+CLASS="STRUCTFIELD"
+>colorspace</CODE
+></TD
+><TD
+>This information supplements the
+<CODE
+CLASS="STRUCTFIELD"
+>pixelformat</CODE
+> and must be set by the driver,
+see <A
+HREF="#COLORSPACES"
+>Section 2.2</A
+>.</TD
+></TR
+><TR
+><TD
+>&nbsp;</TD
+><TD
+>__u32</TD
+><TD
+><CODE
+CLASS="STRUCTFIELD"
+>priv</CODE
+></TD
+><TD
+>Reserved for additional information about custom
+(driver defined) formats. When not used drivers and applications must
+set this field to zero.</TD
+></TR
+></TBODY
+><TR
+><TD
+COLSPAN="4"
+>Notes:<BR><A
+NAME="FTN.AEN6588"
+>a. </A
+>A
+physical base address may not suit all platforms. GK notes in theory
+we should pass something like PCI device + memory region + offset
+instead. If you encounter problems please discuss on the Video4Linux
+mailing list: <A
+HREF="https://listman.redhat.com/mailman/listinfo/video4linux-list"
+TARGET="_top"
+>https://listman.redhat.com/mailman/listinfo/video4linux-list</A
+>.<BR></TD
+></TR
+></TABLE
+></DIV
+><DIV
+CLASS="TABLE"
+><A
+NAME="FRAMEBUFFER-CAP"
+></A
+><P
+><B
+>Table 2. Frame Buffer Capability Flags</B
+></P
+><TABLE
+BORDER="0"
+FRAME="void"
+WIDTH="100%"
+CLASS="CALSTABLE"
+><COL
+WIDTH="38%"
+TITLE="C1"><COL
+WIDTH="12%"
+TITLE="C2"><COL
+WIDTH="50%"
+TITLE="C3"><TBODY
+><TR
+><TD
+><CODE
+CLASS="CONSTANT"
+>V4L2_FBUF_CAP_EXTERNOVERLAY</CODE
+></TD
+><TD
+>0x0001</TD
+><TD
+>The video is overlaid externally onto the
+video signal of the graphics card.</TD
+></TR
+><TR
+><TD
+><CODE
+CLASS="CONSTANT"
+>V4L2_FBUF_CAP_CHROMAKEY</CODE
+></TD
+><TD
+>0x0002</TD
+><TD
+>The device supports clipping by chroma-keying the
+image into the display.</TD
+></TR
+><TR
+><TD
+><CODE
+CLASS="CONSTANT"
+>V4L2_FBUF_CAP_LIST_CLIPPING</CODE
+></TD
+><TD
+>0x0004</TD
+><TD
+>The device supports clipping using a list of clip
+rectangles.</TD
+></TR
+><TR
+><TD
+><CODE
+CLASS="CONSTANT"
+>V4L2_FBUF_CAP_BITMAP_CLIPPING</CODE
+></TD
+><TD
+>0x0008</TD
+><TD
+>The device supports clipping using a bit mask.</TD
+></TR
+></TBODY
+></TABLE
+></DIV
+><DIV
+CLASS="TABLE"
+><A
+NAME="FRAMEBUFFER-FLAGS"
+></A
+><P
+><B
+>Table 3. Frame Buffer Flags</B
+></P
+><TABLE
+BORDER="0"
+FRAME="void"
+WIDTH="100%"
+CLASS="CALSTABLE"
+><COL
+WIDTH="38%"
+TITLE="C1"><COL
+WIDTH="12%"
+TITLE="C2"><COL
+WIDTH="50%"
+TITLE="C3"><TBODY
+><TR
+><TD
+><CODE
+CLASS="CONSTANT"
+>V4L2_FBUF_FLAG_PRIMARY</CODE
+></TD
+><TD
+>0x0001</TD
+><TD
+>The frame buffer is the primary graphics surface.
+In other words, the overlay is destructive, the video hardware will
+write the image into visible graphics memory as opposed to merely
+displaying the image in place of the original display contents.</TD
+></TR
+><TR
+><TD
+><CODE
+CLASS="CONSTANT"
+>V4L2_FBUF_FLAG_OVERLAY</CODE
+></TD
+><TD
+>0x0002</TD
+><TD
+>The frame buffer is an overlay surface the same
+size as the capture. [?]</TD
+></TR
+><TR
+><TD
+><CODE
+CLASS="CONSTANT"
+>V4L2_FBUF_FLAG_CHROMAKEY</CODE
+></TD
+><TD
+>0x0004</TD
+><TD
+>Use chromakey (when
+<CODE
+CLASS="CONSTANT"
+>V4L2_FBUF_CAP_CHROMAKEY</CODE
+> indicates this
+capability). The other clipping methods are negotiated with the
+<A
+HREF="#VIDIOC-G-FMT"
+><CODE
+CLASS="CONSTANT"
+>VIDIOC_S_FMT</CODE
+></A
+> ioctl, see also <A
+HREF="#OVERLAY"
+>Section 4.2</A
+>.</TD
+></TR
+></TBODY
+></TABLE
+></DIV
+></DIV
+><DIV
+CLASS="REFSECT1"
+><A
+NAME="AEN6729"
+></A
+><H2
+>Return Value</H2
+><P
+>On success <SPAN
+CLASS="RETURNVALUE"
+>0</SPAN
+> is returned, on
+error <SPAN
+CLASS="RETURNVALUE"
+>-1</SPAN
+> and <VAR
+CLASS="VARNAME"
+>errno</VAR
+> is
+set appropriately:</P
+><P
+></P
+><DIV
+CLASS="VARIABLELIST"
+><DL
+><DT
+><SPAN
+CLASS="ERRORCODE"
+>EACCES</SPAN
+></DT
+><DD
+><P
+><CODE
+CLASS="CONSTANT"
+>VIDIOC_S_FBUF</CODE
+> can only be called
+by a privileged user.</P
+></DD
+><DT
+><SPAN
+CLASS="ERRORCODE"
+>EBUSY</SPAN
+></DT
+><DD
+><P
+>The frame buffer parameters cannot be changed at this
+time because overlay is already enabled, or capturing is enabled
+and the hardware cannot capture and overlay simultaneously.</P
+></DD
+><DT
+><SPAN
+CLASS="ERRORCODE"
+>EINVAL</SPAN
+></DT
+><DD
+><P
+>The ioctl is not supported or the
+<CODE
+CLASS="CONSTANT"
+>VIDIOC_S_FBUF</CODE
+> parameters are unsuitable.</P
+></DD
+></DL
+></DIV
+></DIV
+><H1
+><A
+NAME="VIDIOC-G-FMT"
+></A
+>ioctl VIDIOC_G_FMT, VIDIOC_S_FMT, VIDIOC_TRY_FMT</H1
+><DIV
+CLASS="REFNAMEDIV"
+><A
+NAME="AEN6756"
+></A
+><H2
+>Name</H2
+>ioctl VIDIOC_G_FMT, ioctl VIDIOC_S_FMT, ioctl VIDIOC_TRY_FMT&nbsp;--&nbsp;Get or set the data format, try a format.</DIV
+><DIV
+CLASS="REFSYNOPSISDIV"
+><A
+NAME="AEN6761"
+></A
+><H2
+>Synopsis</H2
+><DIV
+CLASS="FUNCSYNOPSIS"
+><P
+></P
+><A
+NAME="AEN6762"
+></A
+><P
+><CODE
+><CODE
+CLASS="FUNCDEF"
+>int ioctl</CODE
+>(int fd, int request, struct v4l2_format
+*argp);</CODE
+></P
+><P
+></P
+></DIV
+></DIV
+><DIV
+CLASS="REFSECT1"
+><A
+NAME="AEN6772"
+></A
+><H2
+>Arguments</H2
+><P
+></P
+><DIV
+CLASS="VARIABLELIST"
+><DL
+><DT
+><VAR
+CLASS="PARAMETER"
+>fd</VAR
+></DT
+><DD
+><P
+>File descriptor returned by <A
+HREF="#FUNC-OPEN"
+><CODE
+CLASS="FUNCTION"
+>open()</CODE
+></A
+>.</P
+></DD
+><DT
+><VAR
+CLASS="PARAMETER"
+>request</VAR
+></DT
+><DD
+><P
+>VIDIOC_G_FMT, VIDIOC_S_FMT, VIDIOC_TRY_FMT</P
+></DD
+><DT
+><VAR
+CLASS="PARAMETER"
+>argp</VAR
+></DT
+><DD
+><P
+></P
+></DD
+></DL
+></DIV
+></DIV
+><DIV
+CLASS="REFSECT1"
+><A
+NAME="AEN6792"
+></A
+><H2
+>Description</H2
+><P
+>These ioctls are used to negotiate the format of data
+(typically image format) exchanged between driver and
+application.</P
+><P
+>To query the current parameters applications set the
+<CODE
+CLASS="STRUCTFIELD"
+>type</CODE
+> field of a struct
+<CODE
+CLASS="STRUCTNAME"
+>v4l2_format</CODE
+> to the respective buffer (stream)
+type. For example video capture devices use
+<CODE
+CLASS="CONSTANT"
+>V4L2_BUF_TYPE_VIDEO_CAPTURE</CODE
+>. When the application
+calls the <CODE
+CLASS="CONSTANT"
+>VIDIOC_G_FMT</CODE
+> ioctl with a pointer to
+this structure the driver fills the respective member of the
+<CODE
+CLASS="STRUCTFIELD"
+>fmt</CODE
+> union. In case of video capture devices
+that is the struct&nbsp;<A
+HREF="#V4L2-PIX-FORMAT"
+>v4l2_pix_format</A
+> <CODE
+CLASS="STRUCTFIELD"
+>pix</CODE
+> member.
+When the requested buffer type is not supported drivers return an
+<SPAN
+CLASS="ERRORCODE"
+>EINVAL</SPAN
+> error code.</P
+><P
+>To change the current format parameters applications
+initialize the <CODE
+CLASS="STRUCTFIELD"
+>type</CODE
+> field and all
+fields of the respective <CODE
+CLASS="STRUCTFIELD"
+>fmt</CODE
+>
+union member. For details see the documentation of the various devices
+types in <A
+HREF="#DEVICES"
+>Chapter 4</A
+>. Good practice is to query the
+current parameters first, and to
+modify only those parameters not suitable for the application. When
+the application calls the <CODE
+CLASS="CONSTANT"
+>VIDIOC_S_FMT</CODE
+> ioctl
+with a pointer to a <CODE
+CLASS="STRUCTNAME"
+>v4l2_format</CODE
+> structure
+the driver checks
+and adjusts the parameters against hardware abilities. Drivers
+should not return an error code unless the input is ambiguous, this is
+a mechanism to fathom device capabilities and to approach parameters
+acceptable for both the application and driver. On success the driver
+may program the hardware, allocate resources and generally prepare for
+data exchange.
+Finally the <CODE
+CLASS="CONSTANT"
+>VIDIOC_S_FMT</CODE
+> ioctl returns the
+current format parameters as <CODE
+CLASS="CONSTANT"
+>VIDIOC_G_FMT</CODE
+> does.
+Very simple, inflexible devices may even ignore all input and always
+return the default parameters. However all V4L2 devices exchanging
+data with the application must implement the
+<CODE
+CLASS="CONSTANT"
+>VIDIOC_G_FMT</CODE
+> and
+<CODE
+CLASS="CONSTANT"
+>VIDIOC_S_FMT</CODE
+> ioctl. When the requested buffer
+type is not supported drivers return an <SPAN
+CLASS="ERRORCODE"
+>EINVAL</SPAN
+> error code on a
+<CODE
+CLASS="CONSTANT"
+>VIDIOC_S_FMT</CODE
+> attempt. When I/O is already in
+progress or the resource is not available for other reasons drivers
+return the <SPAN
+CLASS="ERRORCODE"
+>EBUSY</SPAN
+> error code.</P
+><P
+>The <CODE
+CLASS="CONSTANT"
+>VIDIOC_TRY_FMT</CODE
+> ioctl is equivalent
+to <CODE
+CLASS="CONSTANT"
+>VIDIOC_S_FMT</CODE
+> with one exception: it does not
+change driver state. It can also be called at any time, never
+returning <SPAN
+CLASS="ERRORCODE"
+>EBUSY</SPAN
+>. This function is provided to
+negotiate parameters, to learn about hardware limitations, without
+disabling I/O or possibly time consuming hardware preparations.
+Although strongly recommended drivers are not required to implement
+this ioctl.</P
+><DIV
+CLASS="TABLE"
+><A
+NAME="V4L2-FORMAT"
+></A
+><P
+><B
+>Table 1. struct <CODE
+CLASS="STRUCTNAME"
+>v4l2_format</CODE
+></B
+></P
+><TABLE
+BORDER="0"
+FRAME="void"
+WIDTH="100%"
+CLASS="CALSTABLE"
+><COL
+WIDTH="25%"
+TITLE="C1"><COL
+WIDTH="25%"
+TITLE="C2"><COL
+WIDTH="25%"
+TITLE="C3"><COL
+WIDTH="25%"
+TITLE="C4"><TBODY
+><TR
+><TD
+>enum&nbsp;<A
+HREF="#V4L2-BUF-TYPE"
+>v4l2_buf_type</A
+></TD
+><TD
+><CODE
+CLASS="STRUCTFIELD"
+>type</CODE
+></TD
+><TD
+>&nbsp;</TD
+><TD
+>Type of the data stream, see <A
+HREF="#V4L2-BUF-TYPE"
+>Table 3-2</A
+>.</TD
+></TR
+><TR
+><TD
+>union</TD
+><TD
+><CODE
+CLASS="STRUCTFIELD"
+>fmt</CODE
+></TD
+><TD
+>&nbsp;</TD
+><TD
+>&nbsp;</TD
+></TR
+><TR
+><TD
+>&nbsp;</TD
+><TD
+>struct&nbsp;<A
+HREF="#V4L2-PIX-FORMAT"
+>v4l2_pix_format</A
+></TD
+><TD
+><CODE
+CLASS="STRUCTFIELD"
+>pix</CODE
+></TD
+><TD
+>Definition of an image format, see <A
+HREF="#PIXFMT"
+>Chapter 2</A
+>, used by video capture and output
+devices.</TD
+></TR
+><TR
+><TD
+>&nbsp;</TD
+><TD
+>struct&nbsp;<A
+HREF="#V4L2-WINDOW"
+>v4l2_window</A
+></TD
+><TD
+><CODE
+CLASS="STRUCTFIELD"
+>win</CODE
+></TD
+><TD
+>Definition of an overlaid image, see <A
+HREF="#OVERLAY"
+>Section 4.2</A
+>, used by video overlay devices.</TD
+></TR
+><TR
+><TD
+>&nbsp;</TD
+><TD
+>struct&nbsp;<A
+HREF="#V4L2-VBI-FORMAT"
+>v4l2_vbi_format</A
+></TD
+><TD
+><CODE
+CLASS="STRUCTFIELD"
+>vbi</CODE
+></TD
+><TD
+>Raw VBI capture or output parameters. This is
+discussed in more detail in <A
+HREF="#RAW-VBI"
+>Section 4.6</A
+>. Used by raw VBI
+capture and output devices.</TD
+></TR
+><TR
+><TD
+>&nbsp;</TD
+><TD
+>__u8</TD
+><TD
+><CODE
+CLASS="STRUCTFIELD"
+>raw_data</CODE
+>[200]</TD
+><TD
+>Place holder for future extensions and custom
+(driver defined) formats with <CODE
+CLASS="STRUCTFIELD"
+>type</CODE
+>
+<CODE
+CLASS="CONSTANT"
+>V4L2_BUF_TYPE_PRIVATE</CODE
+> and higher.</TD
+></TR
+></TBODY
+></TABLE
+></DIV
+></DIV
+><DIV
+CLASS="REFSECT1"
+><A
+NAME="AEN6874"
+></A
+><H2
+>Return Value</H2
+><P
+>On success <SPAN
+CLASS="RETURNVALUE"
+>0</SPAN
+> is returned, on
+error <SPAN
+CLASS="RETURNVALUE"
+>-1</SPAN
+> and <VAR
+CLASS="VARNAME"
+>errno</VAR
+> is
+set appropriately:</P
+><P
+></P
+><DIV
+CLASS="VARIABLELIST"
+><DL
+><DT
+><SPAN
+CLASS="ERRORCODE"
+>EBUSY</SPAN
+></DT
+><DD
+><P
+>The data format cannot be changed at this
+time, for example because I/O is already in progress.</P
+></DD
+><DT
+><SPAN
+CLASS="ERRORCODE"
+>EINVAL</SPAN
+></DT
+><DD
+><P
+>The struct&nbsp;<A
+HREF="#V4L2-FORMAT"
+>v4l2_format</A
+> <CODE
+CLASS="STRUCTFIELD"
+>type</CODE
+>
+field is invalid, the requested buffer type not supported, or
+<CODE
+CLASS="CONSTANT"
+>VIDIOC_TRY_FMT</CODE
+> was called and is not
+supported with this buffer type.</P
+></DD
+></DL
+></DIV
+></DIV
+><H1
+><A
+NAME="VIDIOC-G-FREQUENCY"
+></A
+>ioctl VIDIOC_G_FREQUENCY, VIDIOC_S_FREQUENCY</H1
+><DIV
+CLASS="REFNAMEDIV"
+><A
+NAME="AEN6897"
+></A
+><H2
+>Name</H2
+>ioctl VIDIOC_G_FREQUENCY, ioctl VIDIOC_S_FREQUENCY&nbsp;--&nbsp;Get or set tuner or modulator radio
+frequency</DIV
+><DIV
+CLASS="REFSYNOPSISDIV"
+><A
+NAME="AEN6901"
+></A
+><H2
+>Synopsis</H2
+><DIV
+CLASS="FUNCSYNOPSIS"
+><P
+></P
+><A
+NAME="AEN6902"
+></A
+><P
+><CODE
+><CODE
+CLASS="FUNCDEF"
+>int ioctl</CODE
+>(int fd, int request, struct v4l2_frequency
+*argp);</CODE
+></P
+><P
+></P
+></DIV
+><DIV
+CLASS="FUNCSYNOPSIS"
+><P
+></P
+><A
+NAME="AEN6912"
+></A
+><P
+><CODE
+><CODE
+CLASS="FUNCDEF"
+>int ioctl</CODE
+>(int fd, int request, const struct v4l2_frequency
+*argp);</CODE
+></P
+><P
+></P
+></DIV
+></DIV
+><DIV
+CLASS="REFSECT1"
+><A
+NAME="AEN6922"
+></A
+><H2
+>Arguments</H2
+><P
+></P
+><DIV
+CLASS="VARIABLELIST"
+><DL
+><DT
+><VAR
+CLASS="PARAMETER"
+>fd</VAR
+></DT
+><DD
+><P
+>File descriptor returned by <A
+HREF="#FUNC-OPEN"
+><CODE
+CLASS="FUNCTION"
+>open()</CODE
+></A
+>.</P
+></DD
+><DT
+><VAR
+CLASS="PARAMETER"
+>request</VAR
+></DT
+><DD
+><P
+>VIDIOC_G_FREQUENCY, VIDIOC_S_FREQUENCY</P
+></DD
+><DT
+><VAR
+CLASS="PARAMETER"
+>argp</VAR
+></DT
+><DD
+><P
+></P
+></DD
+></DL
+></DIV
+></DIV
+><DIV
+CLASS="REFSECT1"
+><A
+NAME="AEN6942"
+></A
+><H2
+>Description</H2
+><P
+>To get the current tuner or modulator radio frequency
+applications set the <CODE
+CLASS="STRUCTFIELD"
+>tuner</CODE
+> field of a
+struct&nbsp;<A
+HREF="#V4L2-FREQUENCY"
+>v4l2_frequency</A
+> to the respective tuner or modulator number (only
+input devices have tuners, only output devices have modulators), zero
+out the <CODE
+CLASS="STRUCTFIELD"
+>reserved</CODE
+> array and
+call the <CODE
+CLASS="CONSTANT"
+>VIDIOC_G_FREQUENCY</CODE
+> ioctl with a pointer
+to this structure. The driver stores the current frequency in the
+<CODE
+CLASS="STRUCTFIELD"
+>frequency</CODE
+> field.</P
+><P
+>To change the current tuner or modulator radio frequency
+applications initialize the <CODE
+CLASS="STRUCTFIELD"
+>tuner</CODE
+> and
+<CODE
+CLASS="STRUCTFIELD"
+>frequency</CODE
+> fields, and the
+<CODE
+CLASS="STRUCTFIELD"
+>reserved</CODE
+> array of a struct&nbsp;<A
+HREF="#V4L2-FREQUENCY"
+>v4l2_frequency</A
+> and
+call the <CODE
+CLASS="CONSTANT"
+>VIDIOC_S_FREQUENCY</CODE
+> ioctl with a pointer
+to this structure. When the requested frequency is not possible the
+driver assumes the closest possible value. However,
+<CODE
+CLASS="CONSTANT"
+>VIDIOC_S_FREQUENCY</CODE
+> is a write-only ioctl, it does
+not return the actual new frequency.</P
+><DIV
+CLASS="TABLE"
+><A
+NAME="V4L2-FREQUENCY"
+></A
+><P
+><B
+>Table 1. struct <CODE
+CLASS="STRUCTNAME"
+>v4l2_frequency</CODE
+></B
+></P
+><TABLE
+BORDER="0"
+FRAME="void"
+WIDTH="100%"
+CLASS="CALSTABLE"
+><COL
+WIDTH="25%"
+TITLE="C1"><COL
+WIDTH="25%"
+TITLE="C2"><COL
+WIDTH="50%"
+TITLE="C3"><TBODY
+><TR
+><TD
+>__u32</TD
+><TD
+><CODE
+CLASS="STRUCTFIELD"
+>tuner</CODE
+></TD
+><TD
+>The tuner or modulator index number. This is the
+same value as in the struct&nbsp;<A
+HREF="#V4L2-INPUT"
+>v4l2_input</A
+> <CODE
+CLASS="STRUCTFIELD"
+>tuner</CODE
+>
+field and the struct&nbsp;<A
+HREF="#V4L2-TUNER"
+>v4l2_tuner</A
+> <CODE
+CLASS="STRUCTFIELD"
+>index</CODE
+> field, or
+the struct&nbsp;<A
+HREF="#V4L2-OUTPUT"
+>v4l2_output</A
+> <CODE
+CLASS="STRUCTFIELD"
+>modulator</CODE
+> field and the
+struct&nbsp;<A
+HREF="#V4L2-MODULATOR"
+>v4l2_modulator</A
+> <CODE
+CLASS="STRUCTFIELD"
+>index</CODE
+> field.</TD
+></TR
+><TR
+><TD
+>enum&nbsp;<A
+HREF="#V4L2-TUNER-TYPE"
+>v4l2_tuner_type</A
+></TD
+><TD
+><CODE
+CLASS="STRUCTFIELD"
+>type</CODE
+></TD
+><TD
+>The tuner type. This is the same value as in the
+struct&nbsp;<A
+HREF="#V4L2-TUNER"
+>v4l2_tuner</A
+> <CODE
+CLASS="STRUCTFIELD"
+>type</CODE
+> field. The field is not
+applicable to modulators, i.&nbsp;e. ignored by drivers.</TD
+></TR
+><TR
+><TD
+>__u32</TD
+><TD
+><CODE
+CLASS="STRUCTFIELD"
+>frequency</CODE
+></TD
+><TD
+>Tuning frequency in units of 62.5 kHz, or if the
+struct&nbsp;<A
+HREF="#V4L2-TUNER"
+>v4l2_tuner</A
+> or struct&nbsp;<A
+HREF="#V4L2-MODULATOR"
+>v4l2_modulator</A
+> <CODE
+CLASS="STRUCTFIELD"
+>capabilities</CODE
+> flag
+<CODE
+CLASS="CONSTANT"
+>V4L2_TUNER_CAP_LOW</CODE
+> is set, in units of 62.5
+Hz.</TD
+></TR
+><TR
+><TD
+>__u32</TD
+><TD
+><CODE
+CLASS="STRUCTFIELD"
+>reserved</CODE
+>[8];</TD
+><TD
+>Reserved for future extensions. Drivers and
+ applications must set the array to zero.</TD
+></TR
+></TBODY
+></TABLE
+></DIV
+></DIV
+><DIV
+CLASS="REFSECT1"
+><A
+NAME="AEN7001"
+></A
+><H2
+>Return Value</H2
+><P
+>On success <SPAN
+CLASS="RETURNVALUE"
+>0</SPAN
+> is returned, on
+error <SPAN
+CLASS="RETURNVALUE"
+>-1</SPAN
+> and <VAR
+CLASS="VARNAME"
+>errno</VAR
+> is
+set appropriately:</P
+><P
+></P
+><DIV
+CLASS="VARIABLELIST"
+><DL
+><DT
+><SPAN
+CLASS="ERRORCODE"
+>EINVAL</SPAN
+></DT
+><DD
+><P
+>The <CODE
+CLASS="STRUCTFIELD"
+>tuner</CODE
+> field is out of
+bounds.</P
+></DD
+></DL
+></DIV
+></DIV
+><H1
+><A
+NAME="VIDIOC-G-INPUT"
+></A
+>ioctl VIDIOC_G_INPUT, VIDIOC_S_INPUT</H1
+><DIV
+CLASS="REFNAMEDIV"
+><A
+NAME="AEN7017"
+></A
+><H2
+>Name</H2
+>ioctl VIDIOC_G_INPUT, ioctl VIDIOC_S_INPUT&nbsp;--&nbsp;Query or select the current video input</DIV
+><DIV
+CLASS="REFSYNOPSISDIV"
+><A
+NAME="AEN7021"
+></A
+><H2
+>Synopsis</H2
+><DIV
+CLASS="FUNCSYNOPSIS"
+><P
+></P
+><A
+NAME="AEN7022"
+></A
+><P
+><CODE
+><CODE
+CLASS="FUNCDEF"
+>int ioctl</CODE
+>(int fd, int request, int *argp);</CODE
+></P
+><P
+></P
+></DIV
+></DIV
+><DIV
+CLASS="REFSECT1"
+><A
+NAME="AEN7032"
+></A
+><H2
+>Arguments</H2
+><P
+></P
+><DIV
+CLASS="VARIABLELIST"
+><DL
+><DT
+><VAR
+CLASS="PARAMETER"
+>fd</VAR
+></DT
+><DD
+><P
+>File descriptor returned by <A
+HREF="#FUNC-OPEN"
+><CODE
+CLASS="FUNCTION"
+>open()</CODE
+></A
+>.</P
+></DD
+><DT
+><VAR
+CLASS="PARAMETER"
+>request</VAR
+></DT
+><DD
+><P
+>VIDIOC_G_INPUT, VIDIOC_S_INPUT</P
+></DD
+><DT
+><VAR
+CLASS="PARAMETER"
+>argp</VAR
+></DT
+><DD
+><P
+></P
+></DD
+></DL
+></DIV
+></DIV
+><DIV
+CLASS="REFSECT1"
+><A
+NAME="AEN7052"
+></A
+><H2
+>Description</H2
+><P
+>To query the current video input applications call the
+<CODE
+CLASS="CONSTANT"
+>VIDIOC_G_INPUT</CODE
+> ioctl with a pointer to an integer
+where the driver stores the number of the input, as in the
+struct&nbsp;<A
+HREF="#V4L2-INPUT"
+>v4l2_input</A
+> <CODE
+CLASS="STRUCTFIELD"
+>index</CODE
+> field. This ioctl will
+fail only when there are no video inputs, returning
+<SPAN
+CLASS="ERRORCODE"
+>EINVAL</SPAN
+>.</P
+><P
+>To select a video input applications store the number of the
+desired input in an integer and call the
+<CODE
+CLASS="CONSTANT"
+>VIDIOC_S_INPUT</CODE
+> ioctl with a pointer to this
+integer. Side effects are possible. For example inputs may support
+different video standards, so the driver may implicitly switch the
+current standard. It is good practice to select an input before
+querying or negotiating any other parameters.</P
+><P
+>Information about video inputs is available using the
+<A
+HREF="#VIDIOC-ENUMINPUT"
+><CODE
+CLASS="CONSTANT"
+>VIDIOC_ENUMINPUT</CODE
+></A
+> ioctl.</P
+></DIV
+><DIV
+CLASS="REFSECT1"
+><A
+NAME="AEN7064"
+></A
+><H2
+>Return Value</H2
+><P
+>On success <SPAN
+CLASS="RETURNVALUE"
+>0</SPAN
+> is returned, on
+error <SPAN
+CLASS="RETURNVALUE"
+>-1</SPAN
+> and <VAR
+CLASS="VARNAME"
+>errno</VAR
+> is
+set appropriately:</P
+><P
+></P
+><DIV
+CLASS="VARIABLELIST"
+><DL
+><DT
+><SPAN
+CLASS="ERRORCODE"
+>EINVAL</SPAN
+></DT
+><DD
+><P
+>The number of the video input is out of bounds, or
+there are no video inputs at all and this ioctl is not
+supported.</P
+></DD
+><DT
+><SPAN
+CLASS="ERRORCODE"
+>EBUSY</SPAN
+></DT
+><DD
+><P
+>I/O is in progress, the input cannot be
+switched.</P
+></DD
+></DL
+></DIV
+></DIV
+><H1
+><A
+NAME="VIDIOC-G-JPEGCOMP"
+></A
+>ioctl VIDIOC_G_JPEGCOMP, VIDIOC_S_JPEGCOMP</H1
+><DIV
+CLASS="REFNAMEDIV"
+><A
+NAME="AEN7084"
+></A
+><H2
+>Name</H2
+>ioctl VIDIOC_G_JPEGCOMP, ioctl VIDIOC_S_JPEGCOMP&nbsp;--&nbsp;</DIV
+><DIV
+CLASS="REFSYNOPSISDIV"
+><A
+NAME="AEN7088"
+></A
+><H2
+>Synopsis</H2
+><DIV
+CLASS="FUNCSYNOPSIS"
+><P
+></P
+><A
+NAME="AEN7089"
+></A
+><P
+><CODE
+><CODE
+CLASS="FUNCDEF"
+>int ioctl</CODE
+>(int fd, int request, v4l2_jpegcompression *argp);</CODE
+></P
+><P
+></P
+></DIV
+><DIV
+CLASS="FUNCSYNOPSIS"
+><P
+></P
+><A
+NAME="AEN7099"
+></A
+><P
+><CODE
+><CODE
+CLASS="FUNCDEF"
+>int ioctl</CODE
+>(int fd, int request, const v4l2_jpegcompression *argp);</CODE
+></P
+><P
+></P
+></DIV
+></DIV
+><DIV
+CLASS="REFSECT1"
+><A
+NAME="AEN7109"
+></A
+><H2
+>Arguments</H2
+><P
+></P
+><DIV
+CLASS="VARIABLELIST"
+><DL
+><DT
+><VAR
+CLASS="PARAMETER"
+>fd</VAR
+></DT
+><DD
+><P
+>File descriptor returned by <A
+HREF="#FUNC-OPEN"
+><CODE
+CLASS="FUNCTION"
+>open()</CODE
+></A
+>.</P
+></DD
+><DT
+><VAR
+CLASS="PARAMETER"
+>request</VAR
+></DT
+><DD
+><P
+>VIDIOC_G_JPEGCOMP, VIDIOC_S_JPEGCOMP</P
+></DD
+><DT
+><VAR
+CLASS="PARAMETER"
+>argp</VAR
+></DT
+><DD
+><P
+></P
+></DD
+></DL
+></DIV
+></DIV
+><DIV
+CLASS="REFSECT1"
+><A
+NAME="AEN7129"
+></A
+><H2
+>Description</H2
+><P
+>[to do]</P
+><P
+>Ronald Bultje elaborates:</P
+><P
+>APP is some application-specific information. The
+application can set it itself, and it'll be stored in the JPEG-encoded
+fields (e.g. interlacing information for in an AVI or so). COM is the
+same, but it's comments, like 'encoded by me' or so.</P
+><P
+>jpeg_markers describes whether the huffman tables,
+quantization tables and the restart interval information (all
+JPEG-specific stuff) should be stored in the JPEG-encoded fields.
+These define how the JPEG field is encoded. If you omit them,
+applications assume you've used standard encoding. You usually do want
+to add them.</P
+><P
+CLASS="COMMENT"
+>NB VIDIOC_S_JPEGCOMP is w/o.</P
+><DIV
+CLASS="TABLE"
+><A
+NAME="V4L2-JPEGCOMPRESSION"
+></A
+><P
+><B
+>Table 1. struct <CODE
+CLASS="STRUCTNAME"
+>v4l2_jpegcompression</CODE
+></B
+></P
+><TABLE
+BORDER="0"
+FRAME="void"
+WIDTH="100%"
+CLASS="CALSTABLE"
+><COL
+WIDTH="25%"
+TITLE="C1"><COL
+WIDTH="25%"
+TITLE="C2"><COL
+WIDTH="50%"
+TITLE="C3"><TBODY
+><TR
+><TD
+>int</TD
+><TD
+><CODE
+CLASS="STRUCTFIELD"
+>quality</CODE
+></TD
+><TD
+>&nbsp;</TD
+></TR
+><TR
+><TD
+>int</TD
+><TD
+><CODE
+CLASS="STRUCTFIELD"
+>APPn</CODE
+></TD
+><TD
+>&nbsp;</TD
+></TR
+><TR
+><TD
+>int</TD
+><TD
+><CODE
+CLASS="STRUCTFIELD"
+>APP_len</CODE
+></TD
+><TD
+>&nbsp;</TD
+></TR
+><TR
+><TD
+>char</TD
+><TD
+><CODE
+CLASS="STRUCTFIELD"
+>APP_data</CODE
+>[60]</TD
+><TD
+>&nbsp;</TD
+></TR
+><TR
+><TD
+>int</TD
+><TD
+><CODE
+CLASS="STRUCTFIELD"
+>COM_len</CODE
+></TD
+><TD
+>&nbsp;</TD
+></TR
+><TR
+><TD
+>char</TD
+><TD
+><CODE
+CLASS="STRUCTFIELD"
+>COM_data</CODE
+>[60]</TD
+><TD
+>&nbsp;</TD
+></TR
+><TR
+><TD
+>__u32</TD
+><TD
+><CODE
+CLASS="STRUCTFIELD"
+>jpeg_markers</CODE
+></TD
+><TD
+>See <A
+HREF="#JPEG-MARKERS"
+>Table 2</A
+>.</TD
+></TR
+></TBODY
+></TABLE
+></DIV
+><DIV
+CLASS="TABLE"
+><A
+NAME="JPEG-MARKERS"
+></A
+><P
+><B
+>Table 2. JPEG Markers Flags</B
+></P
+><TABLE
+BORDER="0"
+FRAME="void"
+WIDTH="100%"
+CLASS="CALSTABLE"
+><COL
+WIDTH="38%"
+TITLE="C1"><COL
+WIDTH="12%"
+TITLE="C2"><COL
+WIDTH="50%"
+TITLE="C3"><TBODY
+><TR
+><TD
+><CODE
+CLASS="CONSTANT"
+>V4L2_JPEG_MARKER_DHT</CODE
+></TD
+><TD
+>(1&lt;&lt;3)</TD
+><TD
+>Define Huffman Tables</TD
+></TR
+><TR
+><TD
+><CODE
+CLASS="CONSTANT"
+>V4L2_JPEG_MARKER_DQT</CODE
+></TD
+><TD
+>(1&lt;&lt;4)</TD
+><TD
+>Define Quantization Tables</TD
+></TR
+><TR
+><TD
+><CODE
+CLASS="CONSTANT"
+>V4L2_JPEG_MARKER_DRI</CODE
+></TD
+><TD
+>(1&lt;&lt;5)</TD
+><TD
+>Define Restart Interval</TD
+></TR
+><TR
+><TD
+><CODE
+CLASS="CONSTANT"
+>V4L2_JPEG_MARKER_COM</CODE
+></TD
+><TD
+>(1&lt;&lt;6)</TD
+><TD
+>Comment segment</TD
+></TR
+><TR
+><TD
+><CODE
+CLASS="CONSTANT"
+>V4L2_JPEG_MARKER_APP</CODE
+></TD
+><TD
+>(1&lt;&lt;7)</TD
+><TD
+>App segment, driver will always use APP0</TD
+></TR
+></TBODY
+></TABLE
+></DIV
+></DIV
+><DIV
+CLASS="REFSECT1"
+><A
+NAME="AEN7214"
+></A
+><H2
+>Return Value</H2
+><P
+>On success <SPAN
+CLASS="RETURNVALUE"
+>0</SPAN
+> is returned, on
+error <SPAN
+CLASS="RETURNVALUE"
+>-1</SPAN
+> and <VAR
+CLASS="VARNAME"
+>errno</VAR
+> is
+set appropriately:</P
+><P
+></P
+><DIV
+CLASS="VARIABLELIST"
+><DL
+><DT
+><SPAN
+CLASS="ERRORCODE"
+>EINVAL</SPAN
+></DT
+><DD
+><P
+>This ioctl is not supported.</P
+></DD
+></DL
+></DIV
+></DIV
+><H1
+><A
+NAME="VIDIOC-G-MODULATOR"
+></A
+>ioctl VIDIOC_G_MODULATOR, VIDIOC_S_MODULATOR</H1
+><DIV
+CLASS="REFNAMEDIV"
+><A
+NAME="AEN7229"
+></A
+><H2
+>Name</H2
+>ioctl VIDIOC_G_MODULATOR, ioctl VIDIOC_S_MODULATOR&nbsp;--&nbsp;Get or set modulator attributes</DIV
+><DIV
+CLASS="REFSYNOPSISDIV"
+><A
+NAME="AEN7233"
+></A
+><H2
+>Synopsis</H2
+><DIV
+CLASS="FUNCSYNOPSIS"
+><P
+></P
+><A
+NAME="AEN7234"
+></A
+><P
+><CODE
+><CODE
+CLASS="FUNCDEF"
+>int ioctl</CODE
+>(int fd, int request, struct v4l2_modulator
+*argp);</CODE
+></P
+><P
+></P
+></DIV
+><DIV
+CLASS="FUNCSYNOPSIS"
+><P
+></P
+><A
+NAME="AEN7244"
+></A
+><P
+><CODE
+><CODE
+CLASS="FUNCDEF"
+>int ioctl</CODE
+>(int fd, int request, const struct v4l2_modulator
+*argp);</CODE
+></P
+><P
+></P
+></DIV
+></DIV
+><DIV
+CLASS="REFSECT1"
+><A
+NAME="AEN7254"
+></A
+><H2
+>Arguments</H2
+><P
+></P
+><DIV
+CLASS="VARIABLELIST"
+><DL
+><DT
+><VAR
+CLASS="PARAMETER"
+>fd</VAR
+></DT
+><DD
+><P
+>File descriptor returned by <A
+HREF="#FUNC-OPEN"
+><CODE
+CLASS="FUNCTION"
+>open()</CODE
+></A
+>.</P
+></DD
+><DT
+><VAR
+CLASS="PARAMETER"
+>request</VAR
+></DT
+><DD
+><P
+>VIDIOC_G_MODULATOR, VIDIOC_S_MODULATOR</P
+></DD
+><DT
+><VAR
+CLASS="PARAMETER"
+>argp</VAR
+></DT
+><DD
+><P
+></P
+></DD
+></DL
+></DIV
+></DIV
+><DIV
+CLASS="REFSECT1"
+><A
+NAME="AEN7274"
+></A
+><H2
+>Description</H2
+><P
+>To query the attributes of a modulator applications initialize
+the <CODE
+CLASS="STRUCTFIELD"
+>index</CODE
+> field and zero out the
+<CODE
+CLASS="STRUCTFIELD"
+>reserved</CODE
+> array of a struct&nbsp;<A
+HREF="#V4L2-MODULATOR"
+>v4l2_modulator</A
+> and
+call the <CODE
+CLASS="CONSTANT"
+>VIDIOC_G_MODULATOR</CODE
+> ioctl with a pointer
+to this structure. Drivers fill the rest of the structure or return an
+<SPAN
+CLASS="ERRORCODE"
+>EINVAL</SPAN
+> error code when the index is out of bounds. To enumerate all modulators
+applications shall begin at index zero, incrementing by one until the
+driver returns <SPAN
+CLASS="ERRORCODE"
+>EINVAL</SPAN
+>.</P
+><P
+>Modulators have two writable properties, an audio
+modulation set and the radio frequency. To change the modulated audio
+subprograms, applications initialize the <CODE
+CLASS="STRUCTFIELD"
+>index</CODE
+> and <CODE
+CLASS="STRUCTFIELD"
+>txsubchans</CODE
+> fields and the
+<CODE
+CLASS="STRUCTFIELD"
+>reserved</CODE
+> array and call the
+<CODE
+CLASS="CONSTANT"
+>VIDIOC_S_MODULATOR</CODE
+> ioctl. Drivers may choose a
+different audio modulation if the request cannot be satisfied. However
+this is a write-only ioctl, it does not return the actual audio
+modulation selected.</P
+><P
+>To change the radio frequency the <A
+HREF="#VIDIOC-G-FREQUENCY"
+><CODE
+CLASS="CONSTANT"
+>VIDIOC_S_FREQUENCY</CODE
+></A
+> ioctl
+is available.</P
+><DIV
+CLASS="TABLE"
+><A
+NAME="V4L2-MODULATOR"
+></A
+><P
+><B
+>Table 1. struct <CODE
+CLASS="STRUCTNAME"
+>v4l2_modulator</CODE
+></B
+></P
+><TABLE
+BORDER="0"
+FRAME="void"
+WIDTH="100%"
+CLASS="CALSTABLE"
+><COL
+WIDTH="25%"
+TITLE="C1"><COL
+WIDTH="25%"
+TITLE="C2"><COL
+WIDTH="50%"
+TITLE="C3"><TBODY
+><TR
+><TD
+>__u32</TD
+><TD
+><CODE
+CLASS="STRUCTFIELD"
+>index</CODE
+></TD
+><TD
+>Identifies the modulator, set by the
+application.</TD
+></TR
+><TR
+><TD
+>__u8</TD
+><TD
+><CODE
+CLASS="STRUCTFIELD"
+>name</CODE
+>[32]</TD
+><TD
+>Name of the modulator, a NUL-terminated ASCII
+string. This information is intended for the user.</TD
+></TR
+><TR
+><TD
+>__u32</TD
+><TD
+><CODE
+CLASS="STRUCTFIELD"
+>capability</CODE
+></TD
+><TD
+>Modulator capability flags. No flags are defined
+for this field, the tuner flags in struct&nbsp;<A
+HREF="#V4L2-TUNER"
+>v4l2_tuner</A
+>
+are used accordingly. The audio flags indicate the ability
+to encode audio subprograms. They will <SPAN
+CLASS="emphasis"
+><I
+CLASS="EMPHASIS"
+>not</I
+></SPAN
+>
+change for example with the current video standard.</TD
+></TR
+><TR
+><TD
+>__u32</TD
+><TD
+><CODE
+CLASS="STRUCTFIELD"
+>rangelow</CODE
+></TD
+><TD
+>The lowest tunable frequency in units of 62.5
+KHz, or if the <CODE
+CLASS="STRUCTFIELD"
+>capability</CODE
+> flag
+<CODE
+CLASS="CONSTANT"
+>V4L2_TUNER_CAP_LOW</CODE
+> is set, in units of 62.5
+Hz.</TD
+></TR
+><TR
+><TD
+>__u32</TD
+><TD
+><CODE
+CLASS="STRUCTFIELD"
+>rangehigh</CODE
+></TD
+><TD
+>The highest tunable frequency in units of 62.5
+KHz, or if the <CODE
+CLASS="STRUCTFIELD"
+>capability</CODE
+> flag
+<CODE
+CLASS="CONSTANT"
+>V4L2_TUNER_CAP_LOW</CODE
+> is set, in units of 62.5
+Hz.</TD
+></TR
+><TR
+><TD
+>__u32</TD
+><TD
+><CODE
+CLASS="STRUCTFIELD"
+>txsubchans</CODE
+></TD
+><TD
+>With this field applications can determine how
+audio sub-carriers shall be modulated. It contains a set of flags as
+defined in <A
+HREF="#MODULATOR-TXSUBCHANS"
+>Table 2</A
+>. Note the tuner
+<CODE
+CLASS="STRUCTFIELD"
+>rxsubchans</CODE
+> flags are reused, but the
+semantics are different. Video output devices are assumed to have an
+analog or PCM audio input with 1-3 channels. The
+<CODE
+CLASS="STRUCTFIELD"
+>txsubchans</CODE
+> flags select one or more
+channels for modulation, together with some audio subprogram
+indicator, for example a stereo pilot tone.</TD
+></TR
+><TR
+><TD
+>__u32</TD
+><TD
+><CODE
+CLASS="STRUCTFIELD"
+>reserved</CODE
+>[4]</TD
+><TD
+>Reserved for future extensions. Drivers and
+applications must set the array to zero.</TD
+></TR
+></TBODY
+></TABLE
+></DIV
+><DIV
+CLASS="TABLE"
+><A
+NAME="MODULATOR-TXSUBCHANS"
+></A
+><P
+><B
+>Table 2. Modulator Audio Transmission Flags</B
+></P
+><TABLE
+BORDER="0"
+FRAME="void"
+WIDTH="100%"
+CLASS="CALSTABLE"
+><COL
+WIDTH="38%"
+TITLE="C1"><COL
+WIDTH="12%"
+TITLE="C2"><COL
+WIDTH="50%"
+TITLE="C3"><TBODY
+><TR
+><TD
+><CODE
+CLASS="CONSTANT"
+>V4L2_TUNER_SUB_MONO</CODE
+></TD
+><TD
+>0x0001</TD
+><TD
+>Modulate channel 1 as mono audio, when the input
+has more channels, a down-mix of channel 1 and 2. This flag does not
+combine with <CODE
+CLASS="CONSTANT"
+>V4L2_TUNER_SUB_STEREO</CODE
+> or
+<CODE
+CLASS="CONSTANT"
+>V4L2_TUNER_SUB_LANG1</CODE
+>.</TD
+></TR
+><TR
+><TD
+><CODE
+CLASS="CONSTANT"
+>V4L2_TUNER_SUB_STEREO</CODE
+></TD
+><TD
+>0x0002</TD
+><TD
+>Modulate channel 1 and 2 as left and right
+channel of a stereo audio signal. When the input has only one channel
+or two channels and <CODE
+CLASS="CONSTANT"
+>V4L2_TUNER_SUB_SAP</CODE
+> is also
+set, channel 1 is encoded as left and right channel. This flag does
+not combine with <CODE
+CLASS="CONSTANT"
+>V4L2_TUNER_SUB_MONO </CODE
+> or
+<CODE
+CLASS="CONSTANT"
+>V4L2_TUNER_SUB_LANG1</CODE
+>. When the driver does not
+support stereo audio it shall fall back to mono.</TD
+></TR
+><TR
+><TD
+><CODE
+CLASS="CONSTANT"
+>V4L2_TUNER_SUB_LANG1</CODE
+></TD
+><TD
+>0x0008</TD
+><TD
+>Modulate channel 1 and 2 as primary and secondary
+language of a bilingual audio signal. When the input has only one
+channel it is used for both languages. It is not possible to encode
+the primary or secondary language only. This flag does not combine
+with <CODE
+CLASS="CONSTANT"
+>V4L2_TUNER_SUB_MONO </CODE
+> or
+<CODE
+CLASS="CONSTANT"
+>V4L2_TUNER_SUB_STEREO</CODE
+>. If the hardware does not
+support the respective audio matrix, or the current video standard
+does not permit bilingual audio the
+<CODE
+CLASS="CONSTANT"
+>VIDIOC_S_MODULATOR</CODE
+> ioctl shall return an <SPAN
+CLASS="ERRORCODE"
+>EINVAL</SPAN
+> error code
+and the driver shall fall back to mono or stereo mode.
+<A
+HREF="#FTN.TUNER-AUDIO-CAP"
+><SPAN
+CLASS="footnote"
+>[a]</SPAN
+></A
+></TD
+></TR
+><TR
+><TD
+><CODE
+CLASS="CONSTANT"
+>V4L2_TUNER_SUB_LANG2</CODE
+></TD
+><TD
+>0x0004</TD
+><TD
+>Same effect as
+<CODE
+CLASS="CONSTANT"
+>V4L2_TUNER_SUB_LANG1</CODE
+>.
+<A
+HREF="#FTN.TUNER-AUDIO-CAP"
+><SPAN
+CLASS="footnote"
+>[a]</SPAN
+></A
+></TD
+></TR
+><TR
+><TD
+><CODE
+CLASS="CONSTANT"
+>V4L2_TUNER_SUB_SAP</CODE
+></TD
+><TD
+>0x0004</TD
+><TD
+>When combined with <CODE
+CLASS="CONSTANT"
+>V4L2_TUNER_SUB_MONO</CODE
+> the first channel is encoded as mono audio, the last
+channel as Second Audio Program. When the input has only one channel
+it is used for both audio tracks. When the input has three channels
+the mono track is a down-mix of channel 1 and 2. When combined with
+<CODE
+CLASS="CONSTANT"
+>V4L2_TUNER_SUB_STEREO </CODE
+> channel 1 and 2 are
+encoded as left and right stereo audio, channel 3 as Second Audio
+Program. When the input has only two channels, the first is encoded as
+left and right channel and the second as SAP. When the input has only
+one channel it is used for all audio tracks. It is not possible to
+encode a Second Audio Program only. This flag must combine with
+<CODE
+CLASS="CONSTANT"
+>V4L2_TUNER_SUB_MONO</CODE
+> or
+<CODE
+CLASS="CONSTANT"
+>V4L2_TUNER_SUB_STEREO</CODE
+>. If the hardware does not
+support the respective audio matrix, or the current video standard
+does not permit SAP the <CODE
+CLASS="CONSTANT"
+> VIDIOC_S_MODULATOR</CODE
+> ioctl
+shall return an <SPAN
+CLASS="ERRORCODE"
+>EINVAL</SPAN
+> error code and driver shall fall back to mono or stereo
+mode.<A
+HREF="#FTN.TUNER-AUDIO-CAP"
+><SPAN
+CLASS="footnote"
+>[a]</SPAN
+></A
+></TD
+></TR
+></TBODY
+></TABLE
+></DIV
+></DIV
+><DIV
+CLASS="REFSECT1"
+><A
+NAME="AEN7396"
+></A
+><H2
+>Return Value</H2
+><P
+>On success 0 is returned, on error -1 and
+<VAR
+CLASS="VARNAME"
+>errno</VAR
+> is set appropriately:</P
+><P
+></P
+><DIV
+CLASS="VARIABLELIST"
+><DL
+><DT
+><SPAN
+CLASS="ERRORCODE"
+>EINVAL</SPAN
+></DT
+><DD
+><P
+>The struct&nbsp;<A
+HREF="#V4L2-MODULATOR"
+>v4l2_modulator</A
+>
+<CODE
+CLASS="STRUCTFIELD"
+>index</CODE
+> is out of bounds.</P
+></DD
+></DL
+></DIV
+></DIV
+><H1
+><A
+NAME="VIDIOC-G-OUTPUT"
+></A
+>ioctl VIDIOC_G_OUTPUT, VIDIOC_S_OUTPUT</H1
+><DIV
+CLASS="REFNAMEDIV"
+><A
+NAME="AEN7411"
+></A
+><H2
+>Name</H2
+>ioctl VIDIOC_G_OUTPUT, ioctl VIDIOC_S_OUTPUT&nbsp;--&nbsp;Query or select the current video output</DIV
+><DIV
+CLASS="REFSYNOPSISDIV"
+><A
+NAME="AEN7415"
+></A
+><H2
+>Synopsis</H2
+><DIV
+CLASS="FUNCSYNOPSIS"
+><P
+></P
+><A
+NAME="AEN7416"
+></A
+><P
+><CODE
+><CODE
+CLASS="FUNCDEF"
+>int ioctl</CODE
+>(int fd, int request, int *argp);</CODE
+></P
+><P
+></P
+></DIV
+></DIV
+><DIV
+CLASS="REFSECT1"
+><A
+NAME="AEN7426"
+></A
+><H2
+>Arguments</H2
+><P
+></P
+><DIV
+CLASS="VARIABLELIST"
+><DL
+><DT
+><VAR
+CLASS="PARAMETER"
+>fd</VAR
+></DT
+><DD
+><P
+>File descriptor returned by <A
+HREF="#FUNC-OPEN"
+><CODE
+CLASS="FUNCTION"
+>open()</CODE
+></A
+>.</P
+></DD
+><DT
+><VAR
+CLASS="PARAMETER"
+>request</VAR
+></DT
+><DD
+><P
+>VIDIOC_G_OUTPUT, VIDIOC_S_OUTPUT</P
+></DD
+><DT
+><VAR
+CLASS="PARAMETER"
+>argp</VAR
+></DT
+><DD
+><P
+></P
+></DD
+></DL
+></DIV
+></DIV
+><DIV
+CLASS="REFSECT1"
+><A
+NAME="AEN7446"
+></A
+><H2
+>Description</H2
+><P
+>To query the current video output applications call the
+<CODE
+CLASS="CONSTANT"
+>VIDIOC_G_OUTPUT</CODE
+> ioctl with a pointer to an integer
+where the driver stores the number of the output, as in the
+struct&nbsp;<A
+HREF="#V4L2-OUTPUT"
+>v4l2_output</A
+> <CODE
+CLASS="STRUCTFIELD"
+>index</CODE
+> field. This ioctl
+will fail only when there are no video outputs, returning the
+<SPAN
+CLASS="ERRORCODE"
+>EINVAL</SPAN
+> error code.</P
+><P
+>To select a video output applications store the number of the
+desired output in an integer and call the
+<CODE
+CLASS="CONSTANT"
+>VIDIOC_S_OUTPUT</CODE
+> ioctl with a pointer to this integer.
+Side effects are possible. For example outputs may support different
+video standards, so the driver may implicitly switch the current
+standard. It is good practice to select an output before querying or
+negotiating any other parameters.</P
+><P
+>Information about video outputs is available using the
+<A
+HREF="#VIDIOC-ENUMOUTPUT"
+><CODE
+CLASS="CONSTANT"
+>VIDIOC_ENUMOUTPUT</CODE
+></A
+> ioctl.</P
+></DIV
+><DIV
+CLASS="REFSECT1"
+><A
+NAME="AEN7458"
+></A
+><H2
+>Return Value</H2
+><P
+>On success <SPAN
+CLASS="RETURNVALUE"
+>0</SPAN
+> is returned, on
+error <SPAN
+CLASS="RETURNVALUE"
+>-1</SPAN
+> and <VAR
+CLASS="VARNAME"
+>errno</VAR
+> is
+set appropriately:</P
+><P
+></P
+><DIV
+CLASS="VARIABLELIST"
+><DL
+><DT
+><SPAN
+CLASS="ERRORCODE"
+>EINVAL</SPAN
+></DT
+><DD
+><P
+>The number of the video output is out of bounds, or
+there are no video outputs at all and this ioctl is not
+supported.</P
+></DD
+><DT
+><SPAN
+CLASS="ERRORCODE"
+>EBUSY</SPAN
+></DT
+><DD
+><P
+>I/O is in progress, the output cannot be
+switched.</P
+></DD
+></DL
+></DIV
+></DIV
+><H1
+><A
+NAME="VIDIOC-G-PARM"
+></A
+>ioctl VIDIOC_G_PARM, VIDIOC_S_PARM</H1
+><DIV
+CLASS="REFNAMEDIV"
+><A
+NAME="AEN7478"
+></A
+><H2
+>Name</H2
+>ioctl VIDIOC_G_PARM, ioctl VIDIOC_S_PARM&nbsp;--&nbsp;Get or set streaming parameters</DIV
+><DIV
+CLASS="REFSYNOPSISDIV"
+><A
+NAME="AEN7482"
+></A
+><H2
+>Synopsis</H2
+><DIV
+CLASS="FUNCSYNOPSIS"
+><P
+></P
+><A
+NAME="AEN7483"
+></A
+><P
+><CODE
+><CODE
+CLASS="FUNCDEF"
+>int ioctl</CODE
+>(int fd, int request, v4l2_streamparm *argp);</CODE
+></P
+><P
+></P
+></DIV
+></DIV
+><DIV
+CLASS="REFSECT1"
+><A
+NAME="AEN7493"
+></A
+><H2
+>Arguments</H2
+><P
+></P
+><DIV
+CLASS="VARIABLELIST"
+><DL
+><DT
+><VAR
+CLASS="PARAMETER"
+>fd</VAR
+></DT
+><DD
+><P
+>File descriptor returned by <A
+HREF="#FUNC-OPEN"
+><CODE
+CLASS="FUNCTION"
+>open()</CODE
+></A
+>.</P
+></DD
+><DT
+><VAR
+CLASS="PARAMETER"
+>request</VAR
+></DT
+><DD
+><P
+>VIDIOC_G_PARM, VIDIOC_S_PARM</P
+></DD
+><DT
+><VAR
+CLASS="PARAMETER"
+>argp</VAR
+></DT
+><DD
+><P
+></P
+></DD
+></DL
+></DIV
+></DIV
+><DIV
+CLASS="REFSECT1"
+><A
+NAME="AEN7513"
+></A
+><H2
+>Description</H2
+><P
+>[to do]</P
+><P
+><CODE
+CLASS="CONSTANT"
+>VIDIOC_S_PARM</CODE
+> is a write-only ioctl,
+ it does not return the actual parameters.</P
+><DIV
+CLASS="TABLE"
+><A
+NAME="V4L2-STREAMPARM"
+></A
+><P
+><B
+>Table 1. struct <CODE
+CLASS="STRUCTNAME"
+>v4l2_streamparm</CODE
+></B
+></P
+><TABLE
+BORDER="0"
+FRAME="void"
+WIDTH="100%"
+CLASS="CALSTABLE"
+><COL
+WIDTH="50%"
+TITLE="C1"><COL><COL><TBODY
+><TR
+><TD
+>enum&nbsp;<A
+HREF="#V4L2-BUF-TYPE"
+>v4l2_buf_type</A
+></TD
+><TD
+><CODE
+CLASS="STRUCTFIELD"
+>type</CODE
+></TD
+><TD
+>&nbsp;</TD
+><TD
+>The buffer (stream) type, same as struct&nbsp;<A
+HREF="#V4L2-FORMAT"
+>v4l2_format</A
+>
+<CODE
+CLASS="STRUCTFIELD"
+>type</CODE
+>, set by the application.</TD
+></TR
+><TR
+><TD
+>union</TD
+><TD
+><CODE
+CLASS="STRUCTFIELD"
+>parm</CODE
+></TD
+><TD
+>&nbsp;</TD
+><TD
+>&nbsp;</TD
+></TR
+><TR
+><TD
+>&nbsp;</TD
+><TD
+>struct&nbsp;<A
+HREF="#V4L2-CAPTUREPARM"
+>v4l2_captureparm</A
+></TD
+><TD
+><CODE
+CLASS="STRUCTFIELD"
+>capture</CODE
+></TD
+><TD
+>Parameters for capture devices, used when
+<CODE
+CLASS="STRUCTFIELD"
+>type</CODE
+> is
+<CODE
+CLASS="CONSTANT"
+>V4L2_BUF_TYPE_VIDEO_CAPTURE</CODE
+>.</TD
+></TR
+><TR
+><TD
+>&nbsp;</TD
+><TD
+>struct&nbsp;<A
+HREF="#V4L2-OUTPUTPARM"
+>v4l2_outputparm</A
+></TD
+><TD
+><CODE
+CLASS="STRUCTFIELD"
+>output</CODE
+></TD
+><TD
+>Parameters for output devices, used when
+<CODE
+CLASS="STRUCTFIELD"
+>type</CODE
+> is
+<CODE
+CLASS="CONSTANT"
+>V4L2_BUF_TYPE_VIDEO_OUTPUT</CODE
+>.</TD
+></TR
+><TR
+><TD
+>&nbsp;</TD
+><TD
+>__u8</TD
+><TD
+><CODE
+CLASS="STRUCTFIELD"
+>raw_data</CODE
+>[200]</TD
+><TD
+>A place holder for future extensions and custom
+(driver defined) buffer types <CODE
+CLASS="CONSTANT"
+>V4L2_BUF_TYPE_PRIVATE</CODE
+> and
+higher.</TD
+></TR
+></TBODY
+></TABLE
+></DIV
+><DIV
+CLASS="TABLE"
+><A
+NAME="V4L2-CAPTUREPARM"
+></A
+><P
+><B
+>Table 2. struct <CODE
+CLASS="STRUCTNAME"
+>v4l2_captureparm</CODE
+></B
+></P
+><TABLE
+BORDER="0"
+FRAME="void"
+WIDTH="100%"
+CLASS="CALSTABLE"
+><COL
+WIDTH="25%"
+TITLE="C1"><COL
+WIDTH="25%"
+TITLE="C2"><COL
+WIDTH="50%"
+TITLE="C3"><TBODY
+><TR
+><TD
+>__u32</TD
+><TD
+><CODE
+CLASS="STRUCTFIELD"
+>capability</CODE
+></TD
+><TD
+>See <A
+HREF="#PARM-CAPS"
+>Table 4</A
+>.</TD
+></TR
+><TR
+><TD
+>__u32</TD
+><TD
+><CODE
+CLASS="STRUCTFIELD"
+>capturemode</CODE
+></TD
+><TD
+>Set by drivers and applications, see <A
+HREF="#PARM-FLAGS"
+>Table 5</A
+>.</TD
+></TR
+><TR
+><TD
+>struct&nbsp;<A
+HREF="#V4L2-FRACT"
+>v4l2_fract</A
+></TD
+><TD
+><CODE
+CLASS="STRUCTFIELD"
+>timeperframe</CODE
+></TD
+><TD
+><P
+>This is is the desired period between
+successive frames captured by the driver, expressed in 0.1 &micro;s
+units. The field is intended to skip frames on the driver side, saving
+I/O bandwidth.</P
+><P
+>Applications store here the desired frame
+period, drivers return the actual frame period, which must be greater
+or equal to the nominal frame period determined by the current video
+standard (struct&nbsp;<A
+HREF="#V4L2-STANDARD"
+>v4l2_standard</A
+> <CODE
+CLASS="STRUCTFIELD"
+>frameperiod</CODE
+>
+field). Changing the video standard (also implicitly by switching the
+video input) may reset this parameter to the nominal frame period. To
+reset manually applications can just set this field to
+zero.</P
+><P
+>Drivers support this function only when they set the
+<CODE
+CLASS="CONSTANT"
+>V4L2_CAP_TIMEPERFRAME</CODE
+> flag in the
+<CODE
+CLASS="STRUCTFIELD"
+>capability</CODE
+> field.</P
+></TD
+></TR
+><TR
+><TD
+>__u32</TD
+><TD
+><CODE
+CLASS="STRUCTFIELD"
+>extendedmode</CODE
+></TD
+><TD
+>Custom (driver specific) streaming parameters. When
+unused, applications and drivers must set this field to zero.
+Applications using this field should check the driver name and
+version, see <A
+HREF="#QUERYCAP"
+>Section 1.2</A
+>.</TD
+></TR
+><TR
+><TD
+>__u32</TD
+><TD
+><CODE
+CLASS="STRUCTFIELD"
+>readbuffers</CODE
+></TD
+><TD
+>Applications set this field to the desired number
+ of buffers used internally by the driver in <A
+HREF="#FUNC-READ"
+><CODE
+CLASS="FUNCTION"
+>read()</CODE
+></A
+>
+ mode. Drivers return the actual number of buffers. When an application requests
+ zero buffers, drivers should just return the current
+ setting rather than the minimum or an error code. For
+ details see <A
+HREF="#RW"
+>Section 3.1</A
+>.</TD
+></TR
+><TR
+><TD
+>__u32</TD
+><TD
+><CODE
+CLASS="STRUCTFIELD"
+>reserved</CODE
+>[4]</TD
+><TD
+>Reserved for future extensions. Drivers and
+applications must set the array to zero.</TD
+></TR
+></TBODY
+></TABLE
+></DIV
+><DIV
+CLASS="TABLE"
+><A
+NAME="V4L2-OUTPUTPARM"
+></A
+><P
+><B
+>Table 3. struct <CODE
+CLASS="STRUCTNAME"
+>v4l2_outputparm</CODE
+></B
+></P
+><TABLE
+BORDER="0"
+FRAME="void"
+WIDTH="100%"
+CLASS="CALSTABLE"
+><COL
+WIDTH="25%"
+TITLE="C1"><COL
+WIDTH="25%"
+TITLE="C2"><COL
+WIDTH="50%"
+TITLE="C3"><TBODY
+><TR
+><TD
+>__u32</TD
+><TD
+><CODE
+CLASS="STRUCTFIELD"
+>capability</CODE
+></TD
+><TD
+>See <A
+HREF="#PARM-CAPS"
+>Table 4</A
+>.</TD
+></TR
+><TR
+><TD
+>__u32</TD
+><TD
+><CODE
+CLASS="STRUCTFIELD"
+>outputmode</CODE
+></TD
+><TD
+>Set by drivers and applications, see <A
+HREF="#PARM-FLAGS"
+>Table 5</A
+>.</TD
+></TR
+><TR
+><TD
+>struct&nbsp;<A
+HREF="#V4L2-FRACT"
+>v4l2_fract</A
+></TD
+><TD
+><CODE
+CLASS="STRUCTFIELD"
+>timeperframe</CODE
+></TD
+><TD
+>This is is the desired period between
+successive frames output by the driver, expressed in 0.1 &micro;s
+units.</TD
+></TR
+><TR
+><TD
+COLSPAN="3"
+><P
+>The field is intended to
+repeat frames on the driver side in <A
+HREF="#FUNC-WRITE"
+><CODE
+CLASS="FUNCTION"
+>write()</CODE
+></A
+> mode (in streaming
+mode timestamps can be used to throttle the output), saving I/O
+bandwidth.</P
+><P
+>Applications store here the desired frame
+period, drivers return the actual frame period, which must be greater
+or equal to the nominal frame period determined by the current video
+standard (struct&nbsp;<A
+HREF="#V4L2-STANDARD"
+>v4l2_standard</A
+> <CODE
+CLASS="STRUCTFIELD"
+>frameperiod</CODE
+>
+field). Changing the video standard (also implicitly by switching the
+video output) may reset this parameter to the nominal frame period. To
+reset manually applications can just set this field to
+zero.</P
+><P
+>Drivers support this function only when they set the
+<CODE
+CLASS="CONSTANT"
+>V4L2_CAP_TIMEPERFRAME</CODE
+> flag in the
+<CODE
+CLASS="STRUCTFIELD"
+>capability</CODE
+> field.</P
+></TD
+></TR
+><TR
+><TD
+>__u32</TD
+><TD
+><CODE
+CLASS="STRUCTFIELD"
+>extendedmode</CODE
+></TD
+><TD
+>Custom (driver specific) streaming parameters. When
+unused, applications and drivers must set this field to zero.
+Applications using this field should check the driver name and
+version, see <A
+HREF="#QUERYCAP"
+>Section 1.2</A
+>.</TD
+></TR
+><TR
+><TD
+>__u32</TD
+><TD
+><CODE
+CLASS="STRUCTFIELD"
+>writebuffers</CODE
+></TD
+><TD
+>Applications set this field to the desired number
+of buffers used internally by the driver in
+<CODE
+CLASS="FUNCTION"
+>write()</CODE
+> mode. Drivers return the actual number of
+buffers. When an application requests zero buffers, drivers should
+just return the current setting rather than the minimum or an error
+code. For details see <A
+HREF="#RW"
+>Section 3.1</A
+>.</TD
+></TR
+><TR
+><TD
+>__u32</TD
+><TD
+><CODE
+CLASS="STRUCTFIELD"
+>reserved</CODE
+>[4]</TD
+><TD
+>Reserved for future extensions. Drivers and
+applications must set the array to zero.</TD
+></TR
+></TBODY
+></TABLE
+></DIV
+><DIV
+CLASS="TABLE"
+><A
+NAME="PARM-CAPS"
+></A
+><P
+><B
+>Table 4. Streaming Parameters Capabilites</B
+></P
+><TABLE
+BORDER="0"
+FRAME="void"
+WIDTH="100%"
+CLASS="CALSTABLE"
+><COL
+WIDTH="38%"
+TITLE="C1"><COL
+WIDTH="12%"
+TITLE="C2"><COL
+WIDTH="50%"
+TITLE="C3"><TBODY
+><TR
+><TD
+><CODE
+CLASS="CONSTANT"
+>V4L2_CAP_TIMEPERFRAME</CODE
+></TD
+><TD
+>0x1000</TD
+><TD
+>The frame skipping/repeating controlled by the
+<CODE
+CLASS="STRUCTFIELD"
+>timeperframe</CODE
+> field is supported.</TD
+></TR
+></TBODY
+></TABLE
+></DIV
+><DIV
+CLASS="TABLE"
+><A
+NAME="PARM-FLAGS"
+></A
+><P
+><B
+>Table 5. Capture Parameters Flags</B
+></P
+><TABLE
+BORDER="0"
+FRAME="void"
+WIDTH="100%"
+CLASS="CALSTABLE"
+><COL
+WIDTH="38%"
+TITLE="C1"><COL
+WIDTH="12%"
+TITLE="C2"><COL
+WIDTH="50%"
+TITLE="C3"><TBODY
+><TR
+><TD
+><CODE
+CLASS="CONSTANT"
+>V4L2_MODE_HIGHQUALITY</CODE
+></TD
+><TD
+>0x0001</TD
+><TD
+><P
+>High quality imaging mode. High quality mode
+is intended for still imaging applications. The idea is to get the
+best possible image quality that the hardware can deliver. It is not
+defined how the driver writer may achieve that; it will depend on the
+hardware and the ingenuity of the driver writer. High quality mode is
+a different mode from the the regular motion video capture modes. In
+high quality mode:<P
+></P
+><UL
+><LI
+><P
+>The driver may be able to capture higher
+resolutions than for motion capture.</P
+></LI
+><LI
+><P
+>The driver may support fewer pixel formats
+than motion capture (e.g. true color).</P
+></LI
+><LI
+><P
+>The driver may capture and arithmetically
+combine multiple successive fields or frames to remove color edge
+artifacts and reduce the noise in the video data.</P
+></LI
+><LI
+><P
+>The driver may capture images in slices like
+a scanner in order to handle larger format images than would otherwise
+be possible. </P
+></LI
+><LI
+><P
+>An image capture operation may be
+significantly slower than motion capture. </P
+></LI
+><LI
+><P
+>Moving objects in the image might have
+excessive motion blur. </P
+></LI
+><LI
+><P
+>Capture might only work through the
+<CODE
+CLASS="FUNCTION"
+>read()</CODE
+> call.</P
+></LI
+></UL
+></P
+></TD
+></TR
+></TBODY
+></TABLE
+></DIV
+></DIV
+><DIV
+CLASS="REFSECT1"
+><A
+NAME="AEN7719"
+></A
+><H2
+>Return Value</H2
+><P
+>On success <SPAN
+CLASS="RETURNVALUE"
+>0</SPAN
+> is returned, on
+error <SPAN
+CLASS="RETURNVALUE"
+>-1</SPAN
+> and <VAR
+CLASS="VARNAME"
+>errno</VAR
+> is
+set appropriately:</P
+><P
+></P
+><DIV
+CLASS="VARIABLELIST"
+><DL
+><DT
+><SPAN
+CLASS="ERRORCODE"
+>EINVAL</SPAN
+></DT
+><DD
+><P
+>This ioctl is not supported.</P
+></DD
+></DL
+></DIV
+></DIV
+><H1
+><A
+NAME="VIDIOC-G-PRIORITY"
+></A
+>ioctl VIDIOC_G_PRIORITY, VIDIOC_S_PRIORITY</H1
+><DIV
+CLASS="REFNAMEDIV"
+><A
+NAME="AEN7734"
+></A
+><H2
+>Name</H2
+>ioctl VIDIOC_G_PRIORITY, ioctl VIDIOC_S_PRIORITY&nbsp;--&nbsp;Query or request the access priority associated with a
+file descriptor</DIV
+><DIV
+CLASS="REFSYNOPSISDIV"
+><A
+NAME="AEN7738"
+></A
+><H2
+>Synopsis</H2
+><DIV
+CLASS="FUNCSYNOPSIS"
+><P
+></P
+><A
+NAME="AEN7739"
+></A
+><P
+><CODE
+><CODE
+CLASS="FUNCDEF"
+>int ioctl</CODE
+>(int fd, int request, enum v4l2_priority *argp);</CODE
+></P
+><P
+></P
+></DIV
+><DIV
+CLASS="FUNCSYNOPSIS"
+><P
+></P
+><A
+NAME="AEN7749"
+></A
+><P
+><CODE
+><CODE
+CLASS="FUNCDEF"
+>int ioctl</CODE
+>(int fd, int request, const enum v4l2_priority *argp);</CODE
+></P
+><P
+></P
+></DIV
+></DIV
+><DIV
+CLASS="REFSECT1"
+><A
+NAME="AEN7759"
+></A
+><H2
+>Arguments</H2
+><P
+></P
+><DIV
+CLASS="VARIABLELIST"
+><DL
+><DT
+><VAR
+CLASS="PARAMETER"
+>fd</VAR
+></DT
+><DD
+><P
+>File descriptor returned by <A
+HREF="#FUNC-OPEN"
+><CODE
+CLASS="FUNCTION"
+>open()</CODE
+></A
+>.</P
+></DD
+><DT
+><VAR
+CLASS="PARAMETER"
+>request</VAR
+></DT
+><DD
+><P
+>VIDIOC_G_PRIORITY, VIDIOC_S_PRIORITY</P
+></DD
+><DT
+><VAR
+CLASS="PARAMETER"
+>argp</VAR
+></DT
+><DD
+><P
+>Pointer to an enum v4l2_priority type.</P
+></DD
+></DL
+></DIV
+></DIV
+><DIV
+CLASS="REFSECT1"
+><A
+NAME="AEN7779"
+></A
+><H2
+>Description</H2
+><P
+>To query the current access priority
+applications call the <CODE
+CLASS="CONSTANT"
+>VIDIOC_G_PRIORITY</CODE
+> ioctl
+with a pointer to an enum v4l2_priority variable where the driver stores
+the current priority.</P
+><P
+>To request an access priority applications store the
+desired priority in an enum v4l2_priority variable and call
+<CODE
+CLASS="CONSTANT"
+>VIDIOC_S_PRIORITY</CODE
+> ioctl with a pointer to this
+variable.</P
+><DIV
+CLASS="TABLE"
+><A
+NAME="V4L2-PRIORITY"
+></A
+><P
+><B
+>Table 1. enum v4l2_priority</B
+></P
+><TABLE
+BORDER="0"
+FRAME="void"
+WIDTH="100%"
+CLASS="CALSTABLE"
+><COL
+WIDTH="38%"
+TITLE="C1"><COL
+WIDTH="12%"
+TITLE="C2"><COL
+WIDTH="50%"
+TITLE="C3"><TBODY
+><TR
+><TD
+><CODE
+CLASS="CONSTANT"
+>V4L2_PRIORITY_UNSET</CODE
+></TD
+><TD
+>0</TD
+><TD
+>&nbsp;</TD
+></TR
+><TR
+><TD
+><CODE
+CLASS="CONSTANT"
+>V4L2_PRIORITY_BACKGROUND</CODE
+></TD
+><TD
+>1</TD
+><TD
+>Lowest priority, usually applications running in
+background, for example monitoring VBI transmissions. A proxy
+application running in user space will be necessary if multiple
+applications want to read from a device at this priority.</TD
+></TR
+><TR
+><TD
+><CODE
+CLASS="CONSTANT"
+>V4L2_PRIORITY_INTERACTIVE</CODE
+></TD
+><TD
+>2</TD
+><TD
+>&nbsp;</TD
+></TR
+><TR
+><TD
+><CODE
+CLASS="CONSTANT"
+>V4L2_PRIORITY_DEFAULT</CODE
+></TD
+><TD
+>2</TD
+><TD
+>Medium priority, usually applications started and
+interactively controlled by the user. For example TV viewers, Teletext
+browsers, or just "panel" applications to change the channel or video
+controls. This is the default priority unless an application requests
+another.</TD
+></TR
+><TR
+><TD
+><CODE
+CLASS="CONSTANT"
+>V4L2_PRIORITY_RECORD</CODE
+></TD
+><TD
+>3</TD
+><TD
+>Highest priority. Only one file descriptor can have
+this priority, it blocks any other fd from changing device properties.
+Usually applications which must not be interrupted, like video
+recording.</TD
+></TR
+></TBODY
+></TABLE
+></DIV
+></DIV
+><DIV
+CLASS="REFSECT1"
+><A
+NAME="AEN7818"
+></A
+><H2
+>Return Value</H2
+><P
+>On success <SPAN
+CLASS="RETURNVALUE"
+>0</SPAN
+> is returned, on
+error <SPAN
+CLASS="RETURNVALUE"
+>-1</SPAN
+> and <VAR
+CLASS="VARNAME"
+>errno</VAR
+> is
+set appropriately:</P
+><P
+></P
+><DIV
+CLASS="VARIABLELIST"
+><DL
+><DT
+><SPAN
+CLASS="ERRORCODE"
+>EINVAL</SPAN
+></DT
+><DD
+><P
+>The requested priority value is invalid, or the
+driver does not support access priorities.</P
+></DD
+><DT
+><SPAN
+CLASS="ERRORCODE"
+>EBUSY</SPAN
+></DT
+><DD
+><P
+>Another application already requested higher
+priority.</P
+></DD
+></DL
+></DIV
+></DIV
+><H1
+><A
+NAME="VIDIOC-G-STD"
+></A
+>ioctl VIDIOC_G_STD, VIDIOC_S_STD</H1
+><DIV
+CLASS="REFNAMEDIV"
+><A
+NAME="AEN7838"
+></A
+><H2
+>Name</H2
+>ioctl VIDIOC_G_STD, ioctl VIDIOC_S_STD&nbsp;--&nbsp;Query or select the video standard of the current input</DIV
+><DIV
+CLASS="REFSYNOPSISDIV"
+><A
+NAME="AEN7842"
+></A
+><H2
+>Synopsis</H2
+><DIV
+CLASS="FUNCSYNOPSIS"
+><P
+></P
+><A
+NAME="AEN7843"
+></A
+><P
+><CODE
+><CODE
+CLASS="FUNCDEF"
+>int ioctl</CODE
+>(int fd, int request, v4l2_std_id
+*argp);</CODE
+></P
+><P
+></P
+></DIV
+><DIV
+CLASS="FUNCSYNOPSIS"
+><P
+></P
+><A
+NAME="AEN7853"
+></A
+><P
+><CODE
+><CODE
+CLASS="FUNCDEF"
+>int ioctl</CODE
+>(int fd, int request, const v4l2_std_id
+*argp);</CODE
+></P
+><P
+></P
+></DIV
+></DIV
+><DIV
+CLASS="REFSECT1"
+><A
+NAME="AEN7863"
+></A
+><H2
+>Arguments</H2
+><P
+></P
+><DIV
+CLASS="VARIABLELIST"
+><DL
+><DT
+><VAR
+CLASS="PARAMETER"
+>fd</VAR
+></DT
+><DD
+><P
+>File descriptor returned by <A
+HREF="#FUNC-OPEN"
+><CODE
+CLASS="FUNCTION"
+>open()</CODE
+></A
+>.</P
+></DD
+><DT
+><VAR
+CLASS="PARAMETER"
+>request</VAR
+></DT
+><DD
+><P
+>VIDIOC_G_STD, VIDIOC_S_STD</P
+></DD
+><DT
+><VAR
+CLASS="PARAMETER"
+>argp</VAR
+></DT
+><DD
+><P
+></P
+></DD
+></DL
+></DIV
+></DIV
+><DIV
+CLASS="REFSECT1"
+><A
+NAME="AEN7883"
+></A
+><H2
+>Description</H2
+><P
+>To query and select the current video standard applications
+use the <CODE
+CLASS="CONSTANT"
+>VIDIOC_G_STD</CODE
+> and <CODE
+CLASS="CONSTANT"
+>VIDIOC_S_STD</CODE
+> ioctls which take a pointer to a
+<A
+HREF="#V4L2-STD-ID"
+>v4l2_std_id</A
+> type as argument. <CODE
+CLASS="CONSTANT"
+>VIDIOC_G_STD</CODE
+> can
+return a single flag or a set of flags as in struct&nbsp;<A
+HREF="#V4L2-STANDARD"
+>v4l2_standard</A
+> field
+<CODE
+CLASS="STRUCTFIELD"
+>id</CODE
+>. The flags must be unambiguous such
+that they appear in only one enumerated <CODE
+CLASS="STRUCTNAME"
+>v4l2_standard</CODE
+> structure.</P
+><P
+><CODE
+CLASS="CONSTANT"
+>VIDIOC_S_STD</CODE
+> accepts one or more
+flags, being a write-only ioctl it does not return the actual new standard as
+<CODE
+CLASS="CONSTANT"
+>VIDIOC_G_STD</CODE
+> does. When no flags are given or
+the current input does not support the requested standard the driver
+returns an <SPAN
+CLASS="ERRORCODE"
+>EINVAL</SPAN
+> error code. When the standard set is ambiguous drivers may
+return <SPAN
+CLASS="ERRORCODE"
+>EINVAL</SPAN
+> or choose any of the requested
+standards.</P
+></DIV
+><DIV
+CLASS="REFSECT1"
+><A
+NAME="AEN7898"
+></A
+><H2
+>Return Value</H2
+><P
+>On success <SPAN
+CLASS="RETURNVALUE"
+>0</SPAN
+> is returned, on
+error <SPAN
+CLASS="RETURNVALUE"
+>-1</SPAN
+> and <VAR
+CLASS="VARNAME"
+>errno</VAR
+> is
+set appropriately:</P
+><P
+></P
+><DIV
+CLASS="VARIABLELIST"
+><DL
+><DT
+><SPAN
+CLASS="ERRORCODE"
+>EINVAL</SPAN
+></DT
+><DD
+><P
+>This ioctl is not supported, or the
+<CODE
+CLASS="CONSTANT"
+>VIDIOC_S_STD</CODE
+> parameter was unsuitable.</P
+></DD
+></DL
+></DIV
+></DIV
+><H1
+><A
+NAME="VIDIOC-G-TUNER"
+></A
+>ioctl VIDIOC_G_TUNER, VIDIOC_S_TUNER</H1
+><DIV
+CLASS="REFNAMEDIV"
+><A
+NAME="AEN7914"
+></A
+><H2
+>Name</H2
+>ioctl VIDIOC_G_TUNER, ioctl VIDIOC_S_TUNER&nbsp;--&nbsp;Get or set tuner attributes</DIV
+><DIV
+CLASS="REFSYNOPSISDIV"
+><A
+NAME="AEN7918"
+></A
+><H2
+>Synopsis</H2
+><DIV
+CLASS="FUNCSYNOPSIS"
+><P
+></P
+><A
+NAME="AEN7919"
+></A
+><P
+><CODE
+><CODE
+CLASS="FUNCDEF"
+>int ioctl</CODE
+>(int fd, int request, struct v4l2_tuner
+*argp);</CODE
+></P
+><P
+></P
+></DIV
+><DIV
+CLASS="FUNCSYNOPSIS"
+><P
+></P
+><A
+NAME="AEN7929"
+></A
+><P
+><CODE
+><CODE
+CLASS="FUNCDEF"
+>int ioctl</CODE
+>(int fd, int request, const struct v4l2_tuner
+*argp);</CODE
+></P
+><P
+></P
+></DIV
+></DIV
+><DIV
+CLASS="REFSECT1"
+><A
+NAME="AEN7939"
+></A
+><H2
+>Arguments</H2
+><P
+></P
+><DIV
+CLASS="VARIABLELIST"
+><DL
+><DT
+><VAR
+CLASS="PARAMETER"
+>fd</VAR
+></DT
+><DD
+><P
+>File descriptor returned by <A
+HREF="#FUNC-OPEN"
+><CODE
+CLASS="FUNCTION"
+>open()</CODE
+></A
+>.</P
+></DD
+><DT
+><VAR
+CLASS="PARAMETER"
+>request</VAR
+></DT
+><DD
+><P
+>VIDIOC_G_TUNER, VIDIOC_S_TUNER</P
+></DD
+><DT
+><VAR
+CLASS="PARAMETER"
+>argp</VAR
+></DT
+><DD
+><P
+></P
+></DD
+></DL
+></DIV
+></DIV
+><DIV
+CLASS="REFSECT1"
+><A
+NAME="AEN7959"
+></A
+><H2
+>Description</H2
+><P
+>To query the attributes of a tuner applications initialize the
+<CODE
+CLASS="STRUCTFIELD"
+>index</CODE
+> field and zero out the
+<CODE
+CLASS="STRUCTFIELD"
+>reserved</CODE
+> array of a struct&nbsp;<A
+HREF="#V4L2-TUNER"
+>v4l2_tuner</A
+> and call the
+<CODE
+CLASS="CONSTANT"
+>VIDIOC_G_TUNER</CODE
+> ioctl with a pointer to this
+structure. Drivers fill the rest of the structure or return an
+<SPAN
+CLASS="ERRORCODE"
+>EINVAL</SPAN
+> error code when the index is out of bounds. To enumerate all tuners
+applications shall begin at index zero, incrementing by one until the
+driver returns <SPAN
+CLASS="ERRORCODE"
+>EINVAL</SPAN
+>.</P
+><P
+>Tuners have two writable properties, the audio mode and
+the radio frequency. To switch the audio mode, applications initialize
+the <CODE
+CLASS="STRUCTFIELD"
+>index</CODE
+> and
+<CODE
+CLASS="STRUCTFIELD"
+>audmode</CODE
+> fields and the
+<CODE
+CLASS="STRUCTFIELD"
+>reserved</CODE
+> array and call the
+<CODE
+CLASS="CONSTANT"
+>VIDIOC_S_TUNER</CODE
+> ioctl. This will
+<SPAN
+CLASS="emphasis"
+><I
+CLASS="EMPHASIS"
+>not</I
+></SPAN
+> change the currently selected tuner,
+which is determined by the current video input. Drivers may choose a
+different audio mode if the request cannot be satisfied. Since this
+is a write-only ioctl it does not return the actual audio mode
+selected.</P
+><P
+>To change the radio frequency the <A
+HREF="#VIDIOC-G-FREQUENCY"
+><CODE
+CLASS="CONSTANT"
+>VIDIOC_S_FREQUENCY</CODE
+></A
+> ioctl
+is available.</P
+><DIV
+CLASS="TABLE"
+><A
+NAME="V4L2-TUNER"
+></A
+><P
+><B
+>Table 1. struct <CODE
+CLASS="STRUCTNAME"
+>v4l2_tuner</CODE
+></B
+></P
+><TABLE
+BORDER="0"
+FRAME="void"
+WIDTH="100%"
+CLASS="CALSTABLE"
+><COL
+WIDTH="25%"
+TITLE="C1"><COL
+WIDTH="25%"
+TITLE="C2"><COL
+WIDTH="50%"
+TITLE="C3"><TBODY
+><TR
+><TD
+>__u32</TD
+><TD
+><CODE
+CLASS="STRUCTFIELD"
+>index</CODE
+></TD
+><TD
+>Identifies the tuner, set by the
+application.</TD
+></TR
+><TR
+><TD
+>__u8</TD
+><TD
+><CODE
+CLASS="STRUCTFIELD"
+>name</CODE
+>[32]</TD
+><TD
+><P
+>Name of the tuner, a NUL-terminated ASCII
+string. This information is intended for the user.<SUP
+>a</SUP
+></P
+></TD
+></TR
+><TR
+><TD
+>enum&nbsp;<A
+HREF="#V4L2-TUNER-TYPE"
+>v4l2_tuner_type</A
+></TD
+><TD
+><CODE
+CLASS="STRUCTFIELD"
+>type</CODE
+></TD
+><TD
+>Type of the tuner, see <A
+HREF="#V4L2-TUNER-TYPE"
+>Table 2</A
+>.</TD
+></TR
+><TR
+><TD
+>__u32</TD
+><TD
+><CODE
+CLASS="STRUCTFIELD"
+>capability</CODE
+></TD
+><TD
+><P
+>Tuner capability flags, see <A
+HREF="#TUNER-CAPABILITY"
+>Table 3</A
+>. Audio flags indicate
+the ability to decode audio subprograms. They will
+<SPAN
+CLASS="emphasis"
+><I
+CLASS="EMPHASIS"
+>not</I
+></SPAN
+> change for example with the current video
+standard.</P
+><P
+>When the structure refers to a radio tuner only
+the <CODE
+CLASS="CONSTANT"
+>V4L2_TUNER_CAP_LOW</CODE
+> and
+<CODE
+CLASS="CONSTANT"
+>V4L2_TUNER_CAP_STEREO</CODE
+> flags can be
+set.</P
+></TD
+></TR
+><TR
+><TD
+>__u32</TD
+><TD
+><CODE
+CLASS="STRUCTFIELD"
+>rangelow</CODE
+></TD
+><TD
+>The lowest tunable frequency in units of 62.5
+KHz, or if the <CODE
+CLASS="STRUCTFIELD"
+>capability</CODE
+> flag
+<CODE
+CLASS="CONSTANT"
+>V4L2_TUNER_CAP_LOW</CODE
+> is set, in units of 62.5
+Hz.</TD
+></TR
+><TR
+><TD
+>__u32</TD
+><TD
+><CODE
+CLASS="STRUCTFIELD"
+>rangehigh</CODE
+></TD
+><TD
+>The highest tunable frequency in units of 62.5
+KHz, or if the <CODE
+CLASS="STRUCTFIELD"
+>capability</CODE
+> flag
+<CODE
+CLASS="CONSTANT"
+>V4L2_TUNER_CAP_LOW</CODE
+> is set, in units of 62.5
+Hz.</TD
+></TR
+><TR
+><TD
+>__u32</TD
+><TD
+><CODE
+CLASS="STRUCTFIELD"
+>rxsubchans</CODE
+></TD
+><TD
+><P
+>Some tuners can report the audio subprograms
+received by analyzing audio carriers, pilot tones or other indicators.
+The <CODE
+CLASS="STRUCTFIELD"
+>rxsubchans</CODE
+> field contains flags defined
+in <A
+HREF="#TUNER-RXSUBCHANS"
+>Table 4</A
+>, which are set by the driver to
+indicate the audio subprograms the hardware <SPAN
+CLASS="emphasis"
+><I
+CLASS="EMPHASIS"
+>may</I
+></SPAN
+>
+currently receive.</P
+></TD
+></TR
+><TR
+><TD
+COLSPAN="3"
+><P
+>Only those flags can be set
+here which are also set in the <CODE
+CLASS="STRUCTFIELD"
+>capability</CODE
+>
+field. When the detection is inconclusive the flags of all possible
+audio subprograms must be set. When the driver cannot detect the audio
+subprograms at all, this field must contain the same audio flags as
+<CODE
+CLASS="STRUCTFIELD"
+>capability </CODE
+>.<SUP
+>b</SUP
+></P
+><P
+>For example when two audio
+channels are detected but the hardware cannot distinguish between
+stereo and bilingual mode all the
+<CODE
+CLASS="CONSTANT"
+>V4L2_TUNER_SUB_STEREO</CODE
+>,
+<CODE
+CLASS="CONSTANT"
+>V4L2_TUNER_SUB_LANG1</CODE
+>, and
+<CODE
+CLASS="CONSTANT"
+>V4L2_TUNER_SUB_LANG2</CODE
+> flags may be set.</P
+><P
+>When the structure refers to a radio tuner only the
+<CODE
+CLASS="CONSTANT"
+>V4L2_TUNER_SUB_MONO</CODE
+> and
+<CODE
+CLASS="CONSTANT"
+>V4L2_TUNER_SUB_STEREO</CODE
+> flag can be
+set.</P
+><P
+>The field is valid only when this is the tuner of the
+current video input or a radio tuner.</P
+></TD
+></TR
+><TR
+><TD
+>__u32</TD
+><TD
+><CODE
+CLASS="STRUCTFIELD"
+>audmode</CODE
+></TD
+><TD
+><P
+>The selected audio mode, see <A
+HREF="#TUNER-AUDMODE"
+>Table 5</A
+> for valid values. The audio mode
+does not affect audio subprogram detection, and it does not change
+automatically. See <A
+HREF="#TUNER-MATRIX"
+>Table 6</A
+> for possible results
+when the selected and received audio programs do not
+match.</P
+><P
+>When the structure refers to a radio tuner only the
+<CODE
+CLASS="CONSTANT"
+>V4L2_TUNER_MODE_MONO</CODE
+> and
+<CODE
+CLASS="CONSTANT"
+>V4L2_TUNER_MODE_STEREO</CODE
+> are valid
+values.</P
+><P
+>Currently this is the only field of struct
+<CODE
+CLASS="STRUCTNAME"
+>v4l2_tuner</CODE
+> applications can change.</P
+></TD
+></TR
+><TR
+><TD
+>__u32</TD
+><TD
+><CODE
+CLASS="STRUCTFIELD"
+>signal</CODE
+></TD
+><TD
+>The signal strength if known, supposedly ranging
+from 0 to 65535. Higher values indicate a better signal.</TD
+></TR
+><TR
+><TD
+>__s32</TD
+><TD
+><CODE
+CLASS="STRUCTFIELD"
+>afc</CODE
+></TD
+><TD
+>Automatic frequency control: When the
+<CODE
+CLASS="STRUCTFIELD"
+>afc</CODE
+> value is negative, the frequency is too
+low, when positive too high. [need example what to do when it never
+settles at zero, i.&nbsp;e. range is what?]</TD
+></TR
+><TR
+><TD
+>__u32</TD
+><TD
+><CODE
+CLASS="STRUCTFIELD"
+>reserved</CODE
+>[4]</TD
+><TD
+>Reserved for future extensions. Drivers and
+applications must set the array to zero.</TD
+></TR
+></TBODY
+><TR
+><TD
+COLSPAN="3"
+>Notes:<BR><A
+NAME="FTN.AEN7997"
+>a. </A
+>Video inputs already have a name, the purpose
+of this field is not quite clear.<BR><A
+NAME="FTN.AEN8045"
+>b. </A
+>Purpose of
+<CODE
+CLASS="STRUCTFIELD"
+>rxsubchans</CODE
+> is to eliminate choice, i.&nbsp;e.
+those audio subprograms the driver knows for sure are not received
+right now.<BR></TD
+></TR
+></TABLE
+></DIV
+><DIV
+CLASS="TABLE"
+><A
+NAME="V4L2-TUNER-TYPE"
+></A
+><P
+><B
+>Table 2. enum v4l2_tuner_type</B
+></P
+><TABLE
+BORDER="0"
+FRAME="void"
+WIDTH="100%"
+CLASS="CALSTABLE"
+><COL
+WIDTH="38%"
+TITLE="C1"><COL
+WIDTH="12%"
+TITLE="C2"><COL
+WIDTH="50%"
+TITLE="C3"><TBODY
+><TR
+><TD
+><CODE
+CLASS="CONSTANT"
+>V4L2_TUNER_RADIO</CODE
+></TD
+><TD
+>1</TD
+><TD
+>&nbsp;</TD
+></TR
+><TR
+><TD
+><CODE
+CLASS="CONSTANT"
+>V4L2_TUNER_ANALOG_TV</CODE
+></TD
+><TD
+>2</TD
+><TD
+>&nbsp;</TD
+></TR
+></TBODY
+></TABLE
+></DIV
+><DIV
+CLASS="TABLE"
+><A
+NAME="TUNER-CAPABILITY"
+></A
+><P
+><B
+>Table 3. Tuner and Modulator Capability Flags</B
+></P
+><TABLE
+BORDER="0"
+FRAME="void"
+WIDTH="100%"
+CLASS="CALSTABLE"
+><COL
+WIDTH="38%"
+TITLE="C1"><COL
+WIDTH="12%"
+TITLE="C2"><COL
+WIDTH="50%"
+TITLE="C3"><TBODY
+><TR
+><TD
+><CODE
+CLASS="CONSTANT"
+>V4L2_TUNER_CAP_LOW</CODE
+></TD
+><TD
+>0x0001</TD
+><TD
+>When set frequencies are expressed in units of
+62.5&nbsp;Hz, otherwise in units of 62.5&nbsp;kHz.</TD
+></TR
+><TR
+><TD
+><CODE
+CLASS="CONSTANT"
+>V4L2_TUNER_CAP_NORM</CODE
+></TD
+><TD
+>0x0002</TD
+><TD
+>This is a multi-standard tuner; the video
+standard can or must be switched. (B/G PAL tuners for example are
+typically not considered multi-standard because the video standard is
+automatically selected depending on the frequency band.) The supported
+video standards are reported in the respective struct&nbsp;<A
+HREF="#V4L2-INPUT"
+>v4l2_input</A
+> field
+<CODE
+CLASS="STRUCTFIELD"
+>std</CODE
+>. For details on video standards and how
+to switch see <A
+HREF="#STANDARD"
+>Section 1.7</A
+>.</TD
+></TR
+><TR
+><TD
+><CODE
+CLASS="CONSTANT"
+>V4L2_TUNER_CAP_STEREO</CODE
+></TD
+><TD
+>0x0010</TD
+><TD
+>Stereo audio reception is supported.</TD
+></TR
+><TR
+><TD
+><CODE
+CLASS="CONSTANT"
+>V4L2_TUNER_CAP_LANG1</CODE
+></TD
+><TD
+>0x0040</TD
+><TD
+>Reception of a primary language (of two) is
+supported.<A
+HREF="#FTN.TUNER-AUDIO-CAP"
+><SPAN
+CLASS="footnote"
+>[a]</SPAN
+></A
+></TD
+></TR
+><TR
+><TD
+><CODE
+CLASS="CONSTANT"
+>V4L2_TUNER_CAP_LANG2</CODE
+></TD
+><TD
+>0x0020</TD
+><TD
+>Reception of a secondary language is
+supported.<A
+HREF="#FTN.TUNER-AUDIO-CAP"
+><SPAN
+CLASS="footnote"
+>[a]</SPAN
+></A
+></TD
+></TR
+><TR
+><TD
+><CODE
+CLASS="CONSTANT"
+>V4L2_TUNER_CAP_SAP</CODE
+></TD
+><TD
+>0x0020</TD
+><TD
+><P
+>Reception of the Secondary Audio Program
+(typically a secondary language of the current program) is supported.
+Note the <CODE
+CLASS="CONSTANT"
+>V4L2_TUNER_CAP_LANG2</CODE
+> and
+<CODE
+CLASS="CONSTANT"
+>V4L2_TUNER_CAP_SAP</CODE
+> flags are synonyms. <SUP
+>a</SUP
+></P
+></TD
+></TR
+></TBODY
+><TR
+><TD
+COLSPAN="3"
+>Notes:<BR><A
+NAME="FTN.TUNER-AUDIO-CAP"
+>a. </A
+>The LANG1/LANG2
+nomenclature refers to audio systems transmitting different languages
+monaural on two audio subcarriers ("bilingual mode"), otherwise the
+left and right stereo channel. Similar the NICAM digital audio system
+with two audio channels, transmitted on a second audio subcarrier
+while the main AM/FM audio carrier provides mono or primary language
+audio for older TV sets. SAP is a feature of the U.S. BTSC audio
+system, which consists of up to three audio subcarriers. Unlike LANG2
+SAP is a separate mono audio track besides the primary mono or stereo
+audio track.<BR>The <CODE
+CLASS="CONSTANT"
+>V4L2_TUNER_CAP_SAP</CODE
+>
+capability flag applies when the tuner supports the M/NTSC video
+standard. <CODE
+CLASS="CONSTANT"
+>V4L2_TUNER_SUB_SAP</CODE
+> and
+<CODE
+CLASS="CONSTANT"
+>V4L2_TUNER_MODE_SAP</CODE
+> apply when the M/NTSC video
+standard is currently selected.<BR></TD
+></TR
+></TABLE
+></DIV
+><DIV
+CLASS="TABLE"
+><A
+NAME="TUNER-RXSUBCHANS"
+></A
+><P
+><B
+>Table 4. Tuner Audio Reception Flags</B
+></P
+><TABLE
+BORDER="0"
+FRAME="void"
+WIDTH="100%"
+CLASS="CALSTABLE"
+><COL
+WIDTH="38%"
+TITLE="C1"><COL
+WIDTH="12%"
+TITLE="C2"><COL
+WIDTH="50%"
+TITLE="C3"><TBODY
+><TR
+><TD
+><CODE
+CLASS="CONSTANT"
+>V4L2_TUNER_SUB_MONO</CODE
+></TD
+><TD
+>0x0001</TD
+><TD
+>The tuner receives a mono audio signal.</TD
+></TR
+><TR
+><TD
+><CODE
+CLASS="CONSTANT"
+>V4L2_TUNER_SUB_STEREO</CODE
+></TD
+><TD
+>0x0002</TD
+><TD
+>The tuner receives a stereo audio signal.</TD
+></TR
+><TR
+><TD
+><CODE
+CLASS="CONSTANT"
+>V4L2_TUNER_SUB_LANG1</CODE
+></TD
+><TD
+>0x0008</TD
+><TD
+>The tuner receives the primary language of a
+bilingual audio signal. This flag is not supposed to be set when the
+tuner receives Mono + SAP or Stereo + SAP audio.<A
+HREF="#FTN.TUNER-AUDIO-CAP"
+><SPAN
+CLASS="footnote"
+>[a]</SPAN
+></A
+></TD
+></TR
+><TR
+><TD
+><CODE
+CLASS="CONSTANT"
+>V4L2_TUNER_SUB_LANG2</CODE
+></TD
+><TD
+>0x0004</TD
+><TD
+>The tuner receives the secondary language of a
+bilingual audio signal.<A
+HREF="#FTN.TUNER-AUDIO-CAP"
+><SPAN
+CLASS="footnote"
+>[a]</SPAN
+></A
+></TD
+></TR
+><TR
+><TD
+><CODE
+CLASS="CONSTANT"
+>V4L2_TUNER_SUB_SAP</CODE
+></TD
+><TD
+>0x0004</TD
+><TD
+>The tuner receives a Second Audio Program. Note
+the <CODE
+CLASS="CONSTANT"
+>V4L2_TUNER_SUB_LANG2</CODE
+> and
+<CODE
+CLASS="CONSTANT"
+>V4L2_TUNER_SUB_SAP</CODE
+> flags are
+synonyms.<A
+HREF="#FTN.TUNER-AUDIO-CAP"
+><SPAN
+CLASS="footnote"
+>[a]</SPAN
+></A
+></TD
+></TR
+></TBODY
+></TABLE
+></DIV
+><DIV
+CLASS="TABLE"
+><A
+NAME="TUNER-AUDMODE"
+></A
+><P
+><B
+>Table 5. Tuner Audio Modes</B
+></P
+><TABLE
+BORDER="0"
+FRAME="void"
+WIDTH="100%"
+CLASS="CALSTABLE"
+><COL
+WIDTH="38%"
+TITLE="C1"><COL
+WIDTH="12%"
+TITLE="C2"><COL
+WIDTH="50%"
+TITLE="C3"><TBODY
+><TR
+><TD
+><CODE
+CLASS="CONSTANT"
+>V4L2_TUNER_MODE_MONO</CODE
+></TD
+><TD
+>0</TD
+><TD
+>Play mono audio. When the tuner receives a stereo
+signal this a down-mix of the left and right channel. When the tuner
+receives a bilingual or SAP signal this mode selects the primary
+language.</TD
+></TR
+><TR
+><TD
+><CODE
+CLASS="CONSTANT"
+>V4L2_TUNER_MODE_STEREO</CODE
+></TD
+><TD
+>1</TD
+><TD
+>Play stereo audio. When the tuner receives
+bilingual audio it may play different languages on the left and right
+channel or the primary language on both channels. When it receives no
+stereo signal or does not support stereo reception the driver shall
+fall back to mono mode.</TD
+></TR
+><TR
+><TD
+><CODE
+CLASS="CONSTANT"
+>V4L2_TUNER_MODE_LANG1</CODE
+></TD
+><TD
+>3</TD
+><TD
+>Play the primary language, mono or
+stereo.</TD
+></TR
+><TR
+><TD
+><CODE
+CLASS="CONSTANT"
+>V4L2_TUNER_MODE_LANG2</CODE
+></TD
+><TD
+>2</TD
+><TD
+>Play the secondary language, mono. When the tuner
+receives no bilingual audio or SAP, or their reception is not
+supported the driver shall fall back to mono or stereo mode.</TD
+></TR
+><TR
+><TD
+><CODE
+CLASS="CONSTANT"
+>V4L2_TUNER_MODE_SAP</CODE
+></TD
+><TD
+>2</TD
+><TD
+>Play the Second Audio Program. When the tuner
+receives no bilingual audio or SAP, or their reception is not
+supported the driver shall fall back to mono or stereo mode. Note the
+<CODE
+CLASS="CONSTANT"
+>V4L2_TUNER_MODE_LANG2</CODE
+> and
+<CODE
+CLASS="CONSTANT"
+>V4L2_TUNER_MODE_SAP</CODE
+> identifiers are
+synonyms.<A
+HREF="#FTN.TUNER-AUDIO-CAP"
+><SPAN
+CLASS="footnote"
+>[a]</SPAN
+></A
+></TD
+></TR
+></TBODY
+></TABLE
+></DIV
+><DIV
+CLASS="TABLE"
+><A
+NAME="TUNER-MATRIX"
+></A
+><P
+><B
+>Table 6. Tuner Audio Matrix</B
+></P
+><TABLE
+BORDER="1"
+FRAME="border"
+WIDTH="100%"
+CLASS="CALSTABLE"
+><COL
+WIDTH="33%"
+ALIGN="LEFT"><COL
+WIDTH="33%"
+TITLE="C2"><COL><COL><COL
+WIDTH="33%"
+TITLE="C5"><THEAD
+><TR
+><TH
+>&nbsp;</TH
+><TH
+COLSPAN="4"
+ALIGN="CENTER"
+>Selected</TH
+></TR
+><TR
+><TH
+>Received</TH
+><TH
+>Mono</TH
+><TH
+>Stereo</TH
+><TH
+>Language&nbsp;1</TH
+><TH
+>Language&nbsp;2 / SAP</TH
+></TR
+></THEAD
+><TBODY
+><TR
+><TD
+>Mono</TD
+><TD
+>Mono</TD
+><TD
+>Mono/Mono</TD
+><TD
+>Mono</TD
+><TD
+>Mono</TD
+></TR
+><TR
+><TD
+>Stereo</TD
+><TD
+>L+R</TD
+><TD
+>L/R</TD
+><TD
+>Undefined: L/L or L+R&nbsp;Mono or
+L/R&nbsp;Stereo</TD
+><TD
+>Undefined: R/R or L+R&nbsp;Mono or
+L/R&nbsp;Stereo</TD
+></TR
+><TR
+><TD
+>Mono/Stereo + SAP (BTSC only)</TD
+><TD
+>-</TD
+><TD
+>-</TD
+><TD
+>Main audio program, mono or stereo</TD
+><TD
+>SAP Mono</TD
+></TR
+><TR
+><TD
+>Bilingual (two carrier systems only)</TD
+><TD
+>Language&nbsp;1</TD
+><TD
+>Undefined: Lang1/Lang1 or Lang1/Lang2</TD
+><TD
+>Language&nbsp;1&nbsp;Mono</TD
+><TD
+>Language&nbsp;2&nbsp;Mono</TD
+></TR
+></TBODY
+></TABLE
+></DIV
+></DIV
+><DIV
+CLASS="REFSECT1"
+><A
+NAME="AEN8271"
+></A
+><H2
+>Return Value</H2
+><P
+>On success <SPAN
+CLASS="RETURNVALUE"
+>0</SPAN
+> is returned, on
+error <SPAN
+CLASS="RETURNVALUE"
+>-1</SPAN
+> and <VAR
+CLASS="VARNAME"
+>errno</VAR
+> is
+set appropriately:</P
+><P
+></P
+><DIV
+CLASS="VARIABLELIST"
+><DL
+><DT
+><SPAN
+CLASS="ERRORCODE"
+>EINVAL</SPAN
+></DT
+><DD
+><P
+>The struct&nbsp;<A
+HREF="#V4L2-TUNER"
+>v4l2_tuner</A
+> <CODE
+CLASS="STRUCTFIELD"
+>index</CODE
+> is
+out of bounds.</P
+></DD
+></DL
+></DIV
+></DIV
+><H1
+><A
+NAME="VIDIOC-OVERLAY"
+></A
+>ioctl VIDIOC_OVERLAY</H1
+><DIV
+CLASS="REFNAMEDIV"
+><A
+NAME="AEN8288"
+></A
+><H2
+>Name</H2
+>ioctl VIDIOC_OVERLAY&nbsp;--&nbsp;Start or stop video overlay</DIV
+><DIV
+CLASS="REFSYNOPSISDIV"
+><A
+NAME="AEN8291"
+></A
+><H2
+>Synopsis</H2
+><DIV
+CLASS="FUNCSYNOPSIS"
+><P
+></P
+><A
+NAME="AEN8292"
+></A
+><P
+><CODE
+><CODE
+CLASS="FUNCDEF"
+>int ioctl</CODE
+>(int fd, int request, const int *argp);</CODE
+></P
+><P
+></P
+></DIV
+></DIV
+><DIV
+CLASS="REFSECT1"
+><A
+NAME="AEN8302"
+></A
+><H2
+>Arguments</H2
+><P
+></P
+><DIV
+CLASS="VARIABLELIST"
+><DL
+><DT
+><VAR
+CLASS="PARAMETER"
+>fd</VAR
+></DT
+><DD
+><P
+>File descriptor returned by <A
+HREF="#FUNC-OPEN"
+><CODE
+CLASS="FUNCTION"
+>open()</CODE
+></A
+>.</P
+></DD
+><DT
+><VAR
+CLASS="PARAMETER"
+>request</VAR
+></DT
+><DD
+><P
+>VIDIOC_OVERLAY</P
+></DD
+><DT
+><VAR
+CLASS="PARAMETER"
+>argp</VAR
+></DT
+><DD
+><P
+></P
+></DD
+></DL
+></DIV
+></DIV
+><DIV
+CLASS="REFSECT1"
+><A
+NAME="AEN8322"
+></A
+><H2
+>Description</H2
+><P
+>This ioctl is part of the <A
+HREF="#OVERLAY"
+>video
+ overlay</A
+> I/O method. Applications call
+ <CODE
+CLASS="CONSTANT"
+>VIDIOC_OVERLAY</CODE
+> to start or stop the
+ overlay. It takes a pointer to an integer which must be set to
+ zero by the application to stop overlay, to one to start.</P
+><P
+>Drivers do not support <A
+HREF="#VIDIOC-STREAMON"
+><CODE
+CLASS="CONSTANT"
+>VIDIOC_STREAMON</CODE
+></A
+> or
+<A
+HREF="#VIDIOC-STREAMON"
+><CODE
+CLASS="CONSTANT"
+>VIDIOC_STREAMOFF</CODE
+></A
+> with <CODE
+CLASS="CONSTANT"
+>V4L2_BUF_TYPE_VIDEO_OVERLAY</CODE
+>.</P
+></DIV
+><DIV
+CLASS="REFSECT1"
+><A
+NAME="AEN8333"
+></A
+><H2
+>Return Value</H2
+><P
+>On success <SPAN
+CLASS="RETURNVALUE"
+>0</SPAN
+> is returned, on
+error <SPAN
+CLASS="RETURNVALUE"
+>-1</SPAN
+> and <VAR
+CLASS="VARNAME"
+>errno</VAR
+> is
+set appropriately:</P
+><P
+></P
+><DIV
+CLASS="VARIABLELIST"
+><DL
+><DT
+><SPAN
+CLASS="ERRORCODE"
+>EINVAL</SPAN
+></DT
+><DD
+><P
+>Video overlay is not supported, or the
+parameters have not been set up. See <A
+HREF="#OVERLAY"
+>Section 4.2</A
+> for the necessary steps.</P
+></DD
+></DL
+></DIV
+></DIV
+><H1
+><A
+NAME="VIDIOC-QBUF"
+></A
+>ioctl VIDIOC_QBUF, VIDIOC_DQBUF</H1
+><DIV
+CLASS="REFNAMEDIV"
+><A
+NAME="AEN8349"
+></A
+><H2
+>Name</H2
+>ioctl VIDIOC_QBUF, ioctl VIDIOC_DQBUF&nbsp;--&nbsp;Exchange a buffer with the driver</DIV
+><DIV
+CLASS="REFSYNOPSISDIV"
+><A
+NAME="AEN8353"
+></A
+><H2
+>Synopsis</H2
+><DIV
+CLASS="FUNCSYNOPSIS"
+><P
+></P
+><A
+NAME="AEN8354"
+></A
+><P
+><CODE
+><CODE
+CLASS="FUNCDEF"
+>int ioctl</CODE
+>(int fd, int request, struct v4l2_buffer *argp);</CODE
+></P
+><P
+></P
+></DIV
+></DIV
+><DIV
+CLASS="REFSECT1"
+><A
+NAME="AEN8364"
+></A
+><H2
+>Arguments</H2
+><P
+></P
+><DIV
+CLASS="VARIABLELIST"
+><DL
+><DT
+><VAR
+CLASS="PARAMETER"
+>fd</VAR
+></DT
+><DD
+><P
+>File descriptor returned by <A
+HREF="#FUNC-OPEN"
+><CODE
+CLASS="FUNCTION"
+>open()</CODE
+></A
+>.</P
+></DD
+><DT
+><VAR
+CLASS="PARAMETER"
+>request</VAR
+></DT
+><DD
+><P
+>VIDIOC_QBUF, VIDIOC_DQBUF</P
+></DD
+><DT
+><VAR
+CLASS="PARAMETER"
+>argp</VAR
+></DT
+><DD
+><P
+></P
+></DD
+></DL
+></DIV
+></DIV
+><DIV
+CLASS="REFSECT1"
+><A
+NAME="AEN8384"
+></A
+><H2
+>Description</H2
+><P
+>Applications call the <CODE
+CLASS="CONSTANT"
+>VIDIOC_QBUF</CODE
+> ioctl
+to enqueue an empty (capturing) or filled (output) buffer in the
+driver's incoming queue. The semantics depend on the selected I/O
+method.</P
+><P
+>To enqueue a <A
+HREF="#MMAP"
+>memory mapped</A
+>
+buffer applications set the <CODE
+CLASS="STRUCTFIELD"
+>type</CODE
+> field of a
+struct&nbsp;<A
+HREF="#V4L2-BUFFER"
+>v4l2_buffer</A
+> to the same buffer type as previously struct&nbsp;<A
+HREF="#V4L2-FORMAT"
+>v4l2_format</A
+>
+<CODE
+CLASS="STRUCTFIELD"
+>type</CODE
+> and struct&nbsp;<A
+HREF="#V4L2-REQUESTBUFFERS"
+>v4l2_requestbuffers</A
+>
+<CODE
+CLASS="STRUCTFIELD"
+>type</CODE
+>, the <CODE
+CLASS="STRUCTFIELD"
+>memory</CODE
+>
+field to <CODE
+CLASS="CONSTANT"
+>V4L2_MEMORY_MMAP</CODE
+> and the
+<CODE
+CLASS="STRUCTFIELD"
+>index</CODE
+> field. Valid index numbers range from
+zero to the number of buffers allocated with <A
+HREF="#VIDIOC-REQBUFS"
+><CODE
+CLASS="CONSTANT"
+>VIDIOC_REQBUFS</CODE
+></A
+>
+(struct&nbsp;<A
+HREF="#V4L2-REQUESTBUFFERS"
+>v4l2_requestbuffers</A
+> <CODE
+CLASS="STRUCTFIELD"
+>count</CODE
+>) minus one. The
+contents of the struct <CODE
+CLASS="STRUCTNAME"
+>v4l2_buffer</CODE
+> returned
+by a <A
+HREF="#VIDIOC-QUERYBUF"
+><CODE
+CLASS="CONSTANT"
+>VIDIOC_QUERYBUF</CODE
+></A
+> ioctl will do as well. When the buffer is
+intended for output (<CODE
+CLASS="STRUCTFIELD"
+>type</CODE
+> is
+<CODE
+CLASS="CONSTANT"
+>V4L2_BUF_TYPE_VIDEO_OUTPUT</CODE
+> or
+<CODE
+CLASS="CONSTANT"
+>V4L2_BUF_TYPE_VBI_OUTPUT</CODE
+>) applications must also
+initialize the <CODE
+CLASS="STRUCTFIELD"
+>bytesused</CODE
+>,
+<CODE
+CLASS="STRUCTFIELD"
+>field</CODE
+> and
+<CODE
+CLASS="STRUCTFIELD"
+>timestamp</CODE
+> fields. See <A
+HREF="#BUFFER"
+>Section 3.5</A
+> for details. When
+<CODE
+CLASS="CONSTANT"
+>VIDIOC_QBUF</CODE
+> is called with a pointer to this
+structure the driver sets the
+<CODE
+CLASS="CONSTANT"
+>V4L2_BUF_FLAG_MAPPED</CODE
+> and
+<CODE
+CLASS="CONSTANT"
+>V4L2_BUF_FLAG_QUEUED</CODE
+> flags and clears the
+<CODE
+CLASS="CONSTANT"
+>V4L2_BUF_FLAG_DONE</CODE
+> flag in the
+<CODE
+CLASS="STRUCTFIELD"
+>flags</CODE
+> field, or it returns an
+<SPAN
+CLASS="ERRORCODE"
+>EINVAL</SPAN
+> error code.</P
+><P
+>To enqueue a <A
+HREF="#USERP"
+>user pointer</A
+>
+buffer applications set the <CODE
+CLASS="STRUCTFIELD"
+>type</CODE
+> field of a
+struct&nbsp;<A
+HREF="#V4L2-BUFFER"
+>v4l2_buffer</A
+> to the same buffer type as previously struct&nbsp;<A
+HREF="#V4L2-FORMAT"
+>v4l2_format</A
+>
+<CODE
+CLASS="STRUCTFIELD"
+>type</CODE
+> and struct&nbsp;<A
+HREF="#V4L2-REQUESTBUFFERS"
+>v4l2_requestbuffers</A
+>
+<CODE
+CLASS="STRUCTFIELD"
+>type</CODE
+>, the <CODE
+CLASS="STRUCTFIELD"
+>memory</CODE
+>
+field to <CODE
+CLASS="CONSTANT"
+>V4L2_MEMORY_USERPTR</CODE
+> and the
+<CODE
+CLASS="STRUCTFIELD"
+>m.userptr</CODE
+> field to the address of the
+buffer and <CODE
+CLASS="STRUCTFIELD"
+>length</CODE
+> to its size. When the
+buffer is intended for output additional fields must be set as above.
+When <CODE
+CLASS="CONSTANT"
+>VIDIOC_QBUF</CODE
+> is called with a pointer to this
+structure the driver sets the <CODE
+CLASS="CONSTANT"
+>V4L2_BUF_FLAG_QUEUED</CODE
+>
+flag and clears the <CODE
+CLASS="CONSTANT"
+>V4L2_BUF_FLAG_MAPPED</CODE
+> and
+<CODE
+CLASS="CONSTANT"
+>V4L2_BUF_FLAG_DONE</CODE
+> flags in the
+<CODE
+CLASS="STRUCTFIELD"
+>flags</CODE
+> field, or it returns an error code.
+This ioctl locks the memory pages of the buffer in physical memory,
+they cannot be swapped out to disk. Buffers remain locked until
+dequeued, until the <A
+HREF="#VIDIOC-STREAMON"
+><CODE
+CLASS="CONSTANT"
+>VIDIOC_STREAMOFF</CODE
+></A
+> or <A
+HREF="#VIDIOC-REQBUFS"
+><CODE
+CLASS="CONSTANT"
+>VIDIOC_REQBUFS</CODE
+></A
+> ioctl are
+called, or until the device is closed.</P
+><P
+>Applications call the <CODE
+CLASS="CONSTANT"
+>VIDIOC_DQBUF</CODE
+>
+ioctl to dequeue a filled (capturing) or displayed (output) buffer
+from the driver's outgoing queue. They just set the
+<CODE
+CLASS="STRUCTFIELD"
+>type</CODE
+> and <CODE
+CLASS="STRUCTFIELD"
+>memory</CODE
+>
+fields of a struct&nbsp;<A
+HREF="#V4L2-BUFFER"
+>v4l2_buffer</A
+> as above, when <CODE
+CLASS="CONSTANT"
+>VIDIOC_DQBUF</CODE
+>
+is called with a pointer to this structure the driver fills the
+remaining fields or returns an error code.</P
+><P
+>By default <CODE
+CLASS="CONSTANT"
+>VIDIOC_DQBUF</CODE
+> blocks when no
+buffer is in the outgoing queue. When the
+<CODE
+CLASS="CONSTANT"
+>O_NONBLOCK</CODE
+> flag was given to the <A
+HREF="#FUNC-OPEN"
+><CODE
+CLASS="FUNCTION"
+>open()</CODE
+></A
+>
+function, <CODE
+CLASS="CONSTANT"
+>VIDIOC_DQBUF</CODE
+> returns immediately
+with an <SPAN
+CLASS="ERRORCODE"
+>EAGAIN</SPAN
+> error code when no buffer is available.</P
+><P
+>The <CODE
+CLASS="STRUCTNAME"
+>v4l2_buffer</CODE
+> structure is
+specified in <A
+HREF="#BUFFER"
+>Section 3.5</A
+>.</P
+></DIV
+><DIV
+CLASS="REFSECT1"
+><A
+NAME="AEN8456"
+></A
+><H2
+>Return Value</H2
+><P
+>On success <SPAN
+CLASS="RETURNVALUE"
+>0</SPAN
+> is returned, on
+error <SPAN
+CLASS="RETURNVALUE"
+>-1</SPAN
+> and <VAR
+CLASS="VARNAME"
+>errno</VAR
+> is
+set appropriately:</P
+><P
+></P
+><DIV
+CLASS="VARIABLELIST"
+><DL
+><DT
+><SPAN
+CLASS="ERRORCODE"
+>EAGAIN</SPAN
+></DT
+><DD
+><P
+>Non-blocking I/O has been selected using
+<CODE
+CLASS="CONSTANT"
+>O_NONBLOCK</CODE
+> and no buffer was in the outgoing
+queue.</P
+></DD
+><DT
+><SPAN
+CLASS="ERRORCODE"
+>EINVAL</SPAN
+></DT
+><DD
+><P
+>The buffer <CODE
+CLASS="STRUCTFIELD"
+>type</CODE
+> is not
+supported, or the <CODE
+CLASS="STRUCTFIELD"
+>index</CODE
+> is out of bounds,
+or no buffers have been allocated yet, or the
+<CODE
+CLASS="STRUCTFIELD"
+>userptr</CODE
+> or
+<CODE
+CLASS="STRUCTFIELD"
+>length</CODE
+> are invalid.</P
+></DD
+><DT
+><SPAN
+CLASS="ERRORCODE"
+>ENOMEM</SPAN
+></DT
+><DD
+><P
+>Insufficient memory to enqueue a user pointer buffer.</P
+></DD
+><DT
+><SPAN
+CLASS="ERRORCODE"
+>EIO</SPAN
+></DT
+><DD
+><P
+><CODE
+CLASS="CONSTANT"
+>VIDIOC_DQBUF</CODE
+> failed due to an
+internal error. Can also indicate temporary problems like signal
+loss. Note the driver might dequeue an (empty) buffer despite
+returning an error, or even stop capturing.</P
+></DD
+></DL
+></DIV
+></DIV
+><H1
+><A
+NAME="VIDIOC-QUERYBUF"
+></A
+>ioctl VIDIOC_QUERYBUF</H1
+><DIV
+CLASS="REFNAMEDIV"
+><A
+NAME="AEN8490"
+></A
+><H2
+>Name</H2
+>ioctl VIDIOC_QUERYBUF&nbsp;--&nbsp;Query the status of a buffer</DIV
+><DIV
+CLASS="REFSYNOPSISDIV"
+><A
+NAME="AEN8493"
+></A
+><H2
+>Synopsis</H2
+><DIV
+CLASS="FUNCSYNOPSIS"
+><P
+></P
+><A
+NAME="AEN8494"
+></A
+><P
+><CODE
+><CODE
+CLASS="FUNCDEF"
+>int ioctl</CODE
+>(int fd, int request, struct v4l2_buffer *argp);</CODE
+></P
+><P
+></P
+></DIV
+></DIV
+><DIV
+CLASS="REFSECT1"
+><A
+NAME="AEN8504"
+></A
+><H2
+>Arguments</H2
+><P
+></P
+><DIV
+CLASS="VARIABLELIST"
+><DL
+><DT
+><VAR
+CLASS="PARAMETER"
+>fd</VAR
+></DT
+><DD
+><P
+>File descriptor returned by <A
+HREF="#FUNC-OPEN"
+><CODE
+CLASS="FUNCTION"
+>open()</CODE
+></A
+>.</P
+></DD
+><DT
+><VAR
+CLASS="PARAMETER"
+>request</VAR
+></DT
+><DD
+><P
+>VIDIOC_QUERYBUF</P
+></DD
+><DT
+><VAR
+CLASS="PARAMETER"
+>argp</VAR
+></DT
+><DD
+><P
+></P
+></DD
+></DL
+></DIV
+></DIV
+><DIV
+CLASS="REFSECT1"
+><A
+NAME="AEN8524"
+></A
+><H2
+>Description</H2
+><P
+>This ioctl is part of the <A
+HREF="#MMAP"
+>memory
+mapping</A
+> I/O method. It can be used to query the status of a
+buffer at any time after buffers have been allocated with the
+<A
+HREF="#VIDIOC-REQBUFS"
+><CODE
+CLASS="CONSTANT"
+>VIDIOC_REQBUFS</CODE
+></A
+> ioctl.</P
+><P
+>Applications set the <CODE
+CLASS="STRUCTFIELD"
+>type</CODE
+> field
+ of a struct&nbsp;<A
+HREF="#V4L2-BUFFER"
+>v4l2_buffer</A
+> to the same buffer type as previously
+struct&nbsp;<A
+HREF="#V4L2-FORMAT"
+>v4l2_format</A
+> <CODE
+CLASS="STRUCTFIELD"
+>type</CODE
+> and struct&nbsp;<A
+HREF="#V4L2-REQUESTBUFFERS"
+>v4l2_requestbuffers</A
+>
+<CODE
+CLASS="STRUCTFIELD"
+>type</CODE
+>, and the <CODE
+CLASS="STRUCTFIELD"
+>index</CODE
+>
+ field. Valid index numbers range from zero
+to the number of buffers allocated with <A
+HREF="#VIDIOC-REQBUFS"
+><CODE
+CLASS="CONSTANT"
+>VIDIOC_REQBUFS</CODE
+></A
+>
+ (struct&nbsp;<A
+HREF="#V4L2-REQUESTBUFFERS"
+>v4l2_requestbuffers</A
+> <CODE
+CLASS="STRUCTFIELD"
+>count</CODE
+>) minus one.
+After calling <CODE
+CLASS="CONSTANT"
+>VIDIOC_QUERYBUF</CODE
+> with a pointer to
+ this structure drivers return an error code or fill the rest of
+the structure.</P
+><P
+>In the <CODE
+CLASS="STRUCTFIELD"
+>flags</CODE
+> field the
+<CODE
+CLASS="CONSTANT"
+>V4L2_BUF_FLAG_MAPPED</CODE
+>,
+<CODE
+CLASS="CONSTANT"
+>V4L2_BUF_FLAG_QUEUED</CODE
+> and
+<CODE
+CLASS="CONSTANT"
+>V4L2_BUF_FLAG_DONE</CODE
+> flags will be valid. The
+<CODE
+CLASS="STRUCTFIELD"
+>memory</CODE
+> field will be set to
+<CODE
+CLASS="CONSTANT"
+>V4L2_MEMORY_MMAP</CODE
+>, the <CODE
+CLASS="STRUCTFIELD"
+>m.offset</CODE
+>
+contains the offset of the buffer from the start of the device memory,
+the <CODE
+CLASS="STRUCTFIELD"
+>length</CODE
+> field its size. The driver may
+or may not set the remaining fields and flags, they are meaningless in
+this context.</P
+><P
+>The <CODE
+CLASS="STRUCTNAME"
+>v4l2_buffer</CODE
+> structure is
+ specified in <A
+HREF="#BUFFER"
+>Section 3.5</A
+>.</P
+></DIV
+><DIV
+CLASS="REFSECT1"
+><A
+NAME="AEN8555"
+></A
+><H2
+>Return Value</H2
+><P
+>On success <SPAN
+CLASS="RETURNVALUE"
+>0</SPAN
+> is returned, on
+error <SPAN
+CLASS="RETURNVALUE"
+>-1</SPAN
+> and <VAR
+CLASS="VARNAME"
+>errno</VAR
+> is
+set appropriately:</P
+><P
+></P
+><DIV
+CLASS="VARIABLELIST"
+><DL
+><DT
+><SPAN
+CLASS="ERRORCODE"
+>EINVAL</SPAN
+></DT
+><DD
+><P
+>The buffer <CODE
+CLASS="STRUCTFIELD"
+>type</CODE
+> is not
+supported, or the <CODE
+CLASS="STRUCTFIELD"
+>index</CODE
+> is out of bounds.</P
+></DD
+></DL
+></DIV
+></DIV
+><H1
+><A
+NAME="VIDIOC-QUERYCAP"
+></A
+>ioctl VIDIOC_QUERYCAP</H1
+><DIV
+CLASS="REFNAMEDIV"
+><A
+NAME="AEN8570"
+></A
+><H2
+>Name</H2
+>ioctl VIDIOC_QUERYCAP&nbsp;--&nbsp;Query device capabilities</DIV
+><DIV
+CLASS="REFSYNOPSISDIV"
+><A
+NAME="AEN8573"
+></A
+><H2
+>Synopsis</H2
+><DIV
+CLASS="FUNCSYNOPSIS"
+><P
+></P
+><A
+NAME="AEN8574"
+></A
+><P
+><CODE
+><CODE
+CLASS="FUNCDEF"
+>int ioctl</CODE
+>(int fd, int request, struct v4l2_capability *argp);</CODE
+></P
+><P
+></P
+></DIV
+></DIV
+><DIV
+CLASS="REFSECT1"
+><A
+NAME="AEN8584"
+></A
+><H2
+>Arguments</H2
+><P
+></P
+><DIV
+CLASS="VARIABLELIST"
+><DL
+><DT
+><VAR
+CLASS="PARAMETER"
+>fd</VAR
+></DT
+><DD
+><P
+>File descriptor returned by <A
+HREF="#FUNC-OPEN"
+><CODE
+CLASS="FUNCTION"
+>open()</CODE
+></A
+>.</P
+></DD
+><DT
+><VAR
+CLASS="PARAMETER"
+>request</VAR
+></DT
+><DD
+><P
+>VIDIOC_QUERYCAP</P
+></DD
+><DT
+><VAR
+CLASS="PARAMETER"
+>argp</VAR
+></DT
+><DD
+><P
+></P
+></DD
+></DL
+></DIV
+></DIV
+><DIV
+CLASS="REFSECT1"
+><A
+NAME="AEN8604"
+></A
+><H2
+>Description</H2
+><P
+>All V4L2 devices support the
+<CODE
+CLASS="CONSTANT"
+>VIDIOC_QUERYCAP</CODE
+> ioctl. It is used to identify
+kernel devices compatible with this specification and to obtain
+information about individual hardware capabilities. The ioctl takes a
+pointer to a struct&nbsp;<A
+HREF="#V4L2-CAPABILITY"
+>v4l2_capability</A
+> which is filled by the driver. When the
+driver is not compatible with this specification the ioctl returns the
+<SPAN
+CLASS="ERRORCODE"
+>EINVAL</SPAN
+> error code.</P
+><DIV
+CLASS="TABLE"
+><A
+NAME="V4L2-CAPABILITY"
+></A
+><P
+><B
+>Table 1. struct <CODE
+CLASS="STRUCTNAME"
+>v4l2_capability</CODE
+></B
+></P
+><TABLE
+BORDER="0"
+FRAME="void"
+WIDTH="100%"
+CLASS="CALSTABLE"
+><COL
+WIDTH="25%"
+TITLE="C1"><COL
+WIDTH="25%"
+TITLE="C2"><COL
+WIDTH="50%"
+TITLE="C3"><TBODY
+><TR
+><TD
+>__u8</TD
+><TD
+><CODE
+CLASS="STRUCTFIELD"
+>driver</CODE
+>[16]</TD
+><TD
+><P
+>Name of the driver, a unique NUL-terminated
+ASCII string. For example: "bttv". Driver specific applications shall
+use this information to verify the driver identity. It is also useful
+to work around known bugs, or to print the driver name and version in
+an error report to aid debugging. The driver version is stored in the
+<CODE
+CLASS="STRUCTFIELD"
+>version</CODE
+> field. [do we need a registry?]For
+example: "bttv". Driver specific applications shall use this
+information to verify the driver identity. It is also useful to work
+around known bugs, or to print the driver name and version in an error
+report to aid debugging. The driver version is stored in the
+<CODE
+CLASS="STRUCTFIELD"
+>version</CODE
+> field. [Do we need a
+registry?]</P
+><P
+>Note storing strings in fixed sized arrays is
+bad practice but unavoidable here. Drivers and applications should take
+precautions to never read or write beyond the array end and to
+properly terminate the strings.</P
+></TD
+></TR
+><TR
+><TD
+>__u8</TD
+><TD
+><CODE
+CLASS="STRUCTFIELD"
+>card</CODE
+>[32]</TD
+><TD
+>Name of the device, a NUL-terminated ASCII
+string. For example: "Yoyodyne TV/FM". Remember that one driver may
+support different brands or models of video hardware. This information
+can be used to build a menu of available devices for a device-select
+user interface. Since drivers may support multiple installed devices
+this name should be combined with the
+<CODE
+CLASS="STRUCTFIELD"
+>bus_info</CODE
+> string to avoid
+ambiguities.</TD
+></TR
+><TR
+><TD
+>__u8</TD
+><TD
+><CODE
+CLASS="STRUCTFIELD"
+>bus_info</CODE
+>[32]</TD
+><TD
+>Location of the device in the system, a
+NUL-terminated ASCII string. For example: "PCI Slot 4". This
+information is intended for the user, to distinguish multiple
+identical devices. If no such information is available the field may
+simply count the devices controlled by the driver, or contain the
+empty string (<CODE
+CLASS="STRUCTFIELD"
+>bus_info</CODE
+>[0] = 0). [pci_dev-&#62;slot_name example].</TD
+></TR
+><TR
+><TD
+>__u32</TD
+><TD
+><CODE
+CLASS="STRUCTFIELD"
+>version</CODE
+></TD
+><TD
+><P
+>Version number of the driver. Together with
+the <CODE
+CLASS="STRUCTFIELD"
+>driver</CODE
+> field this identifies a
+particular driver. The version number is formatted using the
+<CODE
+CLASS="CONSTANT"
+>KERNEL_VERSION()</CODE
+> macro:</P
+></TD
+></TR
+><TR
+><TD
+COLSPAN="3"
+><P
+><PRE
+CLASS="PROGRAMLISTING"
+>#define KERNEL_VERSION(a,b,c) (((a) &#60;&#60; 16) + ((b) &#60;&#60; 8) + (c))
+
+__u32 version = KERNEL_VERSION(0, 8, 1);
+
+printf ("Version: %u.%u.%u\n",
+ (version &#62;&#62; 16) &#38; 0xFF,
+ (version &#62;&#62; 8) &#38; 0xFF,
+ version &#38; 0xFF);</PRE
+></P
+></TD
+></TR
+><TR
+><TD
+>__u32</TD
+><TD
+><CODE
+CLASS="STRUCTFIELD"
+>capabilities</CODE
+></TD
+><TD
+>Device capabilities, see <A
+HREF="#DEVICE-CAPABILITIES"
+>Table 2</A
+>.</TD
+></TR
+><TR
+><TD
+>__u32</TD
+><TD
+><CODE
+CLASS="STRUCTFIELD"
+>reserved</CODE
+>[4]</TD
+><TD
+>Reserved for future extensions. Drivers must set
+this array to zero.</TD
+></TR
+></TBODY
+></TABLE
+></DIV
+><DIV
+CLASS="TABLE"
+><A
+NAME="DEVICE-CAPABILITIES"
+></A
+><P
+><B
+>Table 2. Device Capabilities Flags</B
+></P
+><TABLE
+BORDER="0"
+FRAME="void"
+WIDTH="100%"
+CLASS="CALSTABLE"
+><COL
+WIDTH="38%"
+TITLE="C1"><COL
+WIDTH="12%"
+TITLE="C2"><COL
+WIDTH="50%"
+TITLE="C3"><TBODY
+><TR
+><TD
+><CODE
+CLASS="CONSTANT"
+>V4L2_CAP_VIDEO_CAPTURE</CODE
+></TD
+><TD
+>0x00000001</TD
+><TD
+>The device supports the <A
+HREF="#CAPTURE"
+>video capture</A
+> interface.</TD
+></TR
+><TR
+><TD
+><CODE
+CLASS="CONSTANT"
+>V4L2_CAP_VIDEO_OUTPUT</CODE
+></TD
+><TD
+>0x00000002</TD
+><TD
+>The device supports the <A
+HREF="#OUTPUT"
+>video output</A
+> interface.</TD
+></TR
+><TR
+><TD
+><CODE
+CLASS="CONSTANT"
+>V4L2_CAP_VIDEO_OVERLAY</CODE
+></TD
+><TD
+>0x00000004</TD
+><TD
+>The device supports the <A
+HREF="#OVERLAY"
+>video overlay</A
+> interface. Overlay typically
+stores captured images directly in the video memory of a graphics
+card, with support for clipping.</TD
+></TR
+><TR
+><TD
+><CODE
+CLASS="CONSTANT"
+>V4L2_CAP_VBI_CAPTURE</CODE
+></TD
+><TD
+>0x00000010</TD
+><TD
+>The device supports the VBI capture interface, see
+<A
+HREF="#RAW-VBI"
+>Section 4.6</A
+>, <A
+HREF="#SLICED"
+>Section 4.7</A
+>.</TD
+></TR
+><TR
+><TD
+><CODE
+CLASS="CONSTANT"
+>V4L2_CAP_VBI_OUTPUT</CODE
+></TD
+><TD
+>0x00000020</TD
+><TD
+>The device supports the VBI output interface,
+see <A
+HREF="#RAW-VBI"
+>Section 4.6</A
+>, <A
+HREF="#SLICED"
+>Section 4.7</A
+>.</TD
+></TR
+><TR
+><TD
+><CODE
+CLASS="CONSTANT"
+>V4L2_CAP_RDS_CAPTURE</CODE
+></TD
+><TD
+>0x00000100</TD
+><TD
+>[to be defined]</TD
+></TR
+><TR
+><TD
+><CODE
+CLASS="CONSTANT"
+>V4L2_CAP_TUNER</CODE
+></TD
+><TD
+>0x00010000</TD
+><TD
+>The device has some sort of tuner or modulator to
+receive or emit RF-modulated video signals. For more information see
+<A
+HREF="#TUNER"
+>Section 1.6</A
+>.</TD
+></TR
+><TR
+><TD
+><CODE
+CLASS="CONSTANT"
+>V4L2_CAP_AUDIO</CODE
+></TD
+><TD
+>0x00020000</TD
+><TD
+>The device has audio inputs or outputs. For more
+information see <A
+HREF="#AUDIO"
+>Section 1.5</A
+>. It may or may not support PCM
+sampling or output, this function must be implemented as ALSA or OSS
+PCM interface.</TD
+></TR
+><TR
+><TD
+><CODE
+CLASS="CONSTANT"
+>V4L2_CAP_READWRITE</CODE
+></TD
+><TD
+>0x01000000</TD
+><TD
+>The device supports the <A
+HREF="#RW"
+>read()
+and/or write()</A
+> I/O methods.</TD
+></TR
+><TR
+><TD
+><CODE
+CLASS="CONSTANT"
+>V4L2_CAP_ASYNCIO</CODE
+></TD
+><TD
+>0x02000000</TD
+><TD
+>The device supports the <A
+HREF="#ASYNC"
+>asynchronous</A
+> I/O methods.</TD
+></TR
+><TR
+><TD
+><CODE
+CLASS="CONSTANT"
+>V4L2_CAP_STREAMING</CODE
+></TD
+><TD
+>0x04000000</TD
+><TD
+>The device supports the <A
+HREF="#MMAP"
+>streaming</A
+> I/O method.</TD
+></TR
+></TBODY
+></TABLE
+></DIV
+></DIV
+><DIV
+CLASS="REFSECT1"
+><A
+NAME="AEN8738"
+></A
+><H2
+>Return Value</H2
+><P
+>On success <SPAN
+CLASS="RETURNVALUE"
+>0</SPAN
+> is returned, on
+error <SPAN
+CLASS="RETURNVALUE"
+>-1</SPAN
+> and <VAR
+CLASS="VARNAME"
+>errno</VAR
+> is
+set appropriately:</P
+><P
+></P
+><DIV
+CLASS="VARIABLELIST"
+><DL
+><DT
+><SPAN
+CLASS="ERRORCODE"
+>EINVAL</SPAN
+></DT
+><DD
+><P
+>The kernel device is not compatible with this
+specification.</P
+></DD
+></DL
+></DIV
+></DIV
+><H1
+><A
+NAME="VIDIOC-QUERYCTRL"
+></A
+>ioctl VIDIOC_QUERYCTRL, VIDIOC_QUERYMENU</H1
+><DIV
+CLASS="REFNAMEDIV"
+><A
+NAME="AEN8753"
+></A
+><H2
+>Name</H2
+>ioctl VIDIOC_QUERYCTRL, ioctl VIDIOC_QUERYMENU&nbsp;--&nbsp;Enumerate controls and menu control items</DIV
+><DIV
+CLASS="REFSYNOPSISDIV"
+><A
+NAME="AEN8757"
+></A
+><H2
+>Synopsis</H2
+><DIV
+CLASS="FUNCSYNOPSIS"
+><P
+></P
+><A
+NAME="AEN8758"
+></A
+><P
+><CODE
+><CODE
+CLASS="FUNCDEF"
+>int ioctl</CODE
+>(int fd, int request, struct v4l2_queryctrl *argp);</CODE
+></P
+><P
+></P
+></DIV
+><DIV
+CLASS="FUNCSYNOPSIS"
+><P
+></P
+><A
+NAME="AEN8768"
+></A
+><P
+><CODE
+><CODE
+CLASS="FUNCDEF"
+>int ioctl</CODE
+>(int fd, int request, struct v4l2_querymenu *argp);</CODE
+></P
+><P
+></P
+></DIV
+></DIV
+><DIV
+CLASS="REFSECT1"
+><A
+NAME="AEN8778"
+></A
+><H2
+>Arguments</H2
+><P
+></P
+><DIV
+CLASS="VARIABLELIST"
+><DL
+><DT
+><VAR
+CLASS="PARAMETER"
+>fd</VAR
+></DT
+><DD
+><P
+>File descriptor returned by <A
+HREF="#FUNC-OPEN"
+><CODE
+CLASS="FUNCTION"
+>open()</CODE
+></A
+>.</P
+></DD
+><DT
+><VAR
+CLASS="PARAMETER"
+>request</VAR
+></DT
+><DD
+><P
+>VIDIOC_QUERYCTRL, VIDIOC_QUERYMENU</P
+></DD
+><DT
+><VAR
+CLASS="PARAMETER"
+>argp</VAR
+></DT
+><DD
+><P
+></P
+></DD
+></DL
+></DIV
+></DIV
+><DIV
+CLASS="REFSECT1"
+><A
+NAME="AEN8798"
+></A
+><H2
+>Description</H2
+><P
+>To query the attributes of a control applications set the
+<CODE
+CLASS="STRUCTFIELD"
+>id</CODE
+> field of a struct&nbsp;<A
+HREF="#V4L2-QUERYCTRL"
+>v4l2_queryctrl</A
+> and call the
+<CODE
+CLASS="CONSTANT"
+>VIDIOC_QUERYCTRL</CODE
+> ioctl with a pointer to this
+structure. The driver fills the rest of the structure or returns an
+<SPAN
+CLASS="ERRORCODE"
+>EINVAL</SPAN
+> error code when the <CODE
+CLASS="STRUCTFIELD"
+>id</CODE
+> is invalid.</P
+><P
+>It is possible to enumerate controls by calling
+<CODE
+CLASS="CONSTANT"
+>VIDIOC_QUERYCTRL</CODE
+> with successive
+<CODE
+CLASS="STRUCTFIELD"
+>id</CODE
+> values starting from
+<CODE
+CLASS="CONSTANT"
+>V4L2_CID_BASE</CODE
+> up to and exclusive
+<CODE
+CLASS="CONSTANT"
+>V4L2_CID_BASE_LASTP1</CODE
+>, or starting from
+<CODE
+CLASS="CONSTANT"
+>V4L2_CID_PRIVATE_BASE</CODE
+> until the driver returns
+<SPAN
+CLASS="ERRORCODE"
+>EINVAL</SPAN
+>. When the
+<CODE
+CLASS="CONSTANT"
+>V4L2_CTRL_FLAG_DISABLED</CODE
+> flag is set in the
+<CODE
+CLASS="STRUCTFIELD"
+>flags</CODE
+> field, this control is permanently
+disabled and should be ignored by the application.<A
+NAME="AEN8815"
+HREF="#FTN.AEN8815"
+><SPAN
+CLASS="footnote"
+>[25]</SPAN
+></A
+></P
+><P
+>Additional information is required for menu controls, the
+name of menu items. To query them applications set the
+<CODE
+CLASS="STRUCTFIELD"
+>id</CODE
+> and <CODE
+CLASS="STRUCTFIELD"
+>index</CODE
+>
+fields of struct&nbsp;<A
+HREF="#V4L2-QUERYMENU"
+>v4l2_querymenu</A
+> and call the
+<CODE
+CLASS="CONSTANT"
+>VIDIOC_QUERYMENU</CODE
+> ioctl with a pointer to this
+structure. The driver fills the rest of the structure or returns an
+<SPAN
+CLASS="ERRORCODE"
+>EINVAL</SPAN
+> error code when the <CODE
+CLASS="STRUCTFIELD"
+>id</CODE
+> or
+<CODE
+CLASS="STRUCTFIELD"
+>index</CODE
+> is invalid. Menu items are enumerated
+by calling <CODE
+CLASS="CONSTANT"
+>VIDIOC_QUERYMENU</CODE
+> with successive
+<CODE
+CLASS="STRUCTFIELD"
+>index</CODE
+> values from struct&nbsp;<A
+HREF="#V4L2-QUERYCTRL"
+>v4l2_queryctrl</A
+>
+<CODE
+CLASS="STRUCTFIELD"
+>minimum</CODE
+> (0) to
+<CODE
+CLASS="STRUCTFIELD"
+>maximum</CODE
+>, inclusive.</P
+><DIV
+CLASS="TABLE"
+><A
+NAME="V4L2-QUERYCTRL"
+></A
+><P
+><B
+>Table 1. struct <CODE
+CLASS="STRUCTNAME"
+>v4l2_queryctrl</CODE
+></B
+></P
+><TABLE
+BORDER="0"
+FRAME="void"
+WIDTH="100%"
+CLASS="CALSTABLE"
+><COL
+WIDTH="25%"
+TITLE="C1"><COL
+WIDTH="25%"
+TITLE="C2"><COL
+WIDTH="50%"
+TITLE="C3"><TBODY
+><TR
+><TD
+>__u32</TD
+><TD
+><CODE
+CLASS="STRUCTFIELD"
+>id</CODE
+></TD
+><TD
+>Identifies the control, set by the application.
+See <A
+HREF="#CONTROL-ID"
+>Table 1-1</A
+> for predefined IDs.</TD
+></TR
+><TR
+><TD
+>enum&nbsp;<A
+HREF="#V4L2-CTRL-TYPE"
+>v4l2_ctrl_type</A
+></TD
+><TD
+><CODE
+CLASS="STRUCTFIELD"
+>type</CODE
+></TD
+><TD
+>Type of control, see <A
+HREF="#V4L2-CTRL-TYPE"
+>Table 3</A
+>.</TD
+></TR
+><TR
+><TD
+>__u8</TD
+><TD
+><CODE
+CLASS="STRUCTFIELD"
+>name</CODE
+>[32]</TD
+><TD
+>Name of the control, a NUL-terminated ASCII
+string. This information is intended for the user.</TD
+></TR
+><TR
+><TD
+>__s32</TD
+><TD
+><CODE
+CLASS="STRUCTFIELD"
+>minimum</CODE
+></TD
+><TD
+>Minimum value, inclusive. This field is mostly
+useful to define a lower bound for integer controls. Note the value is
+signed.</TD
+></TR
+><TR
+><TD
+>__s32</TD
+><TD
+><CODE
+CLASS="STRUCTFIELD"
+>maximum</CODE
+></TD
+><TD
+>Maximum value, inclusive. Note the value is
+signed.</TD
+></TR
+><TR
+><TD
+>__s32</TD
+><TD
+><CODE
+CLASS="STRUCTFIELD"
+>step</CODE
+></TD
+><TD
+><P
+>Generally drivers should not scale hardware
+control values. It may be necessary for example when the
+<CODE
+CLASS="STRUCTFIELD"
+>name</CODE
+> or <CODE
+CLASS="STRUCTFIELD"
+>id</CODE
+> imply
+a particular unit and the hardware actually accepts only multiples of
+said unit. If so, drivers must take care values are properly rounded
+when scaling, such that errors will not accumulate on repeated
+read-write cycles.</P
+><P
+>This field reports the smallest change
+of an integer control actually affecting hardware. Often the
+information is needed when the user can change controls by keyboard or
+GUI buttons, rather than a slider. When for example a hardware
+register accepts values 0-511 and the driver reports 0-65535, step
+should be 128.</P
+><P
+>Note although signed, the step value is
+supposed to be always positive.</P
+></TD
+></TR
+><TR
+><TD
+>__s32</TD
+><TD
+><CODE
+CLASS="STRUCTFIELD"
+>default_value</CODE
+></TD
+><TD
+>The default value of the control. Drivers reset
+controls only when the driver is loaded, not later, in particular not
+when the <CODE
+CLASS="FUNCTION"
+>open()</CODE
+> is called.</TD
+></TR
+><TR
+><TD
+>__u32</TD
+><TD
+><CODE
+CLASS="STRUCTFIELD"
+>flags</CODE
+></TD
+><TD
+>Control flags, see <A
+HREF="#CONTROL-FLAGS"
+>Table 4</A
+>.</TD
+></TR
+><TR
+><TD
+>__u32</TD
+><TD
+><CODE
+CLASS="STRUCTFIELD"
+>reserved</CODE
+>[2]</TD
+><TD
+>Reserved for future extensions. Drivers must set
+the array to zero.</TD
+></TR
+></TBODY
+></TABLE
+></DIV
+><DIV
+CLASS="TABLE"
+><A
+NAME="V4L2-QUERYMENU"
+></A
+><P
+><B
+>Table 2. struct <CODE
+CLASS="STRUCTNAME"
+>v4l2_querymenu</CODE
+></B
+></P
+><TABLE
+BORDER="0"
+FRAME="void"
+WIDTH="100%"
+CLASS="CALSTABLE"
+><COL
+WIDTH="25%"
+TITLE="C1"><COL
+WIDTH="25%"
+TITLE="C2"><COL
+WIDTH="50%"
+TITLE="C3"><TBODY
+><TR
+><TD
+>__u32</TD
+><TD
+><CODE
+CLASS="STRUCTFIELD"
+>id</CODE
+></TD
+><TD
+>Identifies the control, set by the application
+from the respective struct&nbsp;<A
+HREF="#V4L2-QUERYCTRL"
+>v4l2_queryctrl</A
+>
+<CODE
+CLASS="STRUCTFIELD"
+>id</CODE
+>.</TD
+></TR
+><TR
+><TD
+>__u32</TD
+><TD
+><CODE
+CLASS="STRUCTFIELD"
+>index</CODE
+></TD
+><TD
+>Index of the menu item, starting at zero, set by
+ the application.</TD
+></TR
+><TR
+><TD
+>__u8</TD
+><TD
+><CODE
+CLASS="STRUCTFIELD"
+>name</CODE
+>[32]</TD
+><TD
+>Name of the menu item, a NUL-terminated ASCII
+string. This information is intended for the user.</TD
+></TR
+><TR
+><TD
+>__u32</TD
+><TD
+><CODE
+CLASS="STRUCTFIELD"
+>reserved</CODE
+></TD
+><TD
+>Reserved for future extensions. Drivers must set
+the array to zero.</TD
+></TR
+></TBODY
+></TABLE
+></DIV
+><DIV
+CLASS="TABLE"
+><A
+NAME="V4L2-CTRL-TYPE"
+></A
+><P
+><B
+>Table 3. enum v4l2_ctrl_type</B
+></P
+><TABLE
+BORDER="0"
+FRAME="void"
+WIDTH="100%"
+CLASS="CALSTABLE"
+><COL
+WIDTH="30%"><COL
+WIDTH="5%"
+ALIGN="CENTER"><COL
+WIDTH="5%"
+ALIGN="CENTER"><COL
+WIDTH="5%"
+ALIGN="CENTER"><COL
+WIDTH="55%"><THEAD
+><TR
+><TH
+>Type</TH
+><TH
+><CODE
+CLASS="STRUCTFIELD"
+>minimum</CODE
+></TH
+><TH
+><CODE
+CLASS="STRUCTFIELD"
+>step</CODE
+></TH
+><TH
+><CODE
+CLASS="STRUCTFIELD"
+>maximum</CODE
+></TH
+><TH
+>Description</TH
+></TR
+></THEAD
+><TBODY
+><TR
+><TD
+><CODE
+CLASS="CONSTANT"
+>V4L2_CTRL_TYPE_INTEGER</CODE
+></TD
+><TD
+>low value</TD
+><TD
+>increment (positive) [__u32?]</TD
+><TD
+>high value</TD
+><TD
+>An integer-valued control ranging from minimum to
+maximum inclusive. The step value indicates the increment between
+values which are actually different on the hardware.</TD
+></TR
+><TR
+><TD
+><CODE
+CLASS="CONSTANT"
+>V4L2_CTRL_TYPE_BOOLEAN</CODE
+></TD
+><TD
+>0</TD
+><TD
+>1</TD
+><TD
+>1</TD
+><TD
+>A boolean-valued control. Zero corresponds to
+"disabled", and one means "enabled".</TD
+></TR
+><TR
+><TD
+><CODE
+CLASS="CONSTANT"
+>V4L2_CTRL_TYPE_MENU</CODE
+></TD
+><TD
+>0</TD
+><TD
+>1</TD
+><TD
+>N-1</TD
+><TD
+>The control has a menu of N choices. The names of
+the menu items can be enumerated with the
+<CODE
+CLASS="CONSTANT"
+>VIDIOC_QUERYMENU</CODE
+> ioctl.</TD
+></TR
+><TR
+><TD
+><CODE
+CLASS="CONSTANT"
+>V4L2_CTRL_TYPE_BUTTON</CODE
+></TD
+><TD
+>0</TD
+><TD
+>0</TD
+><TD
+>0</TD
+><TD
+>A control which performs an action when set.
+Drivers must ignore the value passed with
+<CODE
+CLASS="CONSTANT"
+>VIDIOC_S_CTRL</CODE
+> and return an <SPAN
+CLASS="ERRORCODE"
+>EINVAL</SPAN
+> error code on a
+<CODE
+CLASS="CONSTANT"
+>VIDIOC_G_CTRL</CODE
+> attempt.</TD
+></TR
+></TBODY
+></TABLE
+></DIV
+><DIV
+CLASS="TABLE"
+><A
+NAME="CONTROL-FLAGS"
+></A
+><P
+><B
+>Table 4. Control Flags</B
+></P
+><TABLE
+BORDER="0"
+FRAME="void"
+WIDTH="100%"
+CLASS="CALSTABLE"
+><COL
+WIDTH="38%"
+TITLE="C1"><COL
+WIDTH="12%"
+TITLE="C2"><COL
+WIDTH="50%"
+TITLE="C3"><TBODY
+><TR
+><TD
+><CODE
+CLASS="CONSTANT"
+>V4L2_CTRL_FLAG_DISABLED</CODE
+></TD
+><TD
+>0x0001</TD
+><TD
+>This control is permanently disabled and should be ignored by the application. An attempt to change
+this control results in an <SPAN
+CLASS="ERRORCODE"
+>EINVAL</SPAN
+> error code.</TD
+></TR
+><TR
+><TD
+><CODE
+CLASS="CONSTANT"
+>V4L2_CTRL_FLAG_GRABBED</CODE
+></TD
+><TD
+>0x0002</TD
+><TD
+>This control is temporarily unchangeable, for
+example because another application took over control of the
+respective resource. Such controls may be displayed specially in a
+user interface. An attempt to change a "grabbed" control results in an
+<SPAN
+CLASS="ERRORCODE"
+>EBUSY</SPAN
+> error code.</TD
+></TR
+></TBODY
+></TABLE
+></DIV
+></DIV
+><DIV
+CLASS="REFSECT1"
+><A
+NAME="AEN8997"
+></A
+><H2
+>Return Value</H2
+><P
+>On success <SPAN
+CLASS="RETURNVALUE"
+>0</SPAN
+> is returned, on
+error <SPAN
+CLASS="RETURNVALUE"
+>-1</SPAN
+> and <VAR
+CLASS="VARNAME"
+>errno</VAR
+> is
+set appropriately:</P
+><P
+></P
+><DIV
+CLASS="VARIABLELIST"
+><DL
+><DT
+><SPAN
+CLASS="ERRORCODE"
+>EINVAL</SPAN
+></DT
+><DD
+><P
+>The struct&nbsp;<A
+HREF="#V4L2-QUERYCTRL"
+>v4l2_queryctrl</A
+> <CODE
+CLASS="STRUCTFIELD"
+>id</CODE
+>
+is invalid. The struct&nbsp;<A
+HREF="#V4L2-QUERYMENU"
+>v4l2_querymenu</A
+> <CODE
+CLASS="STRUCTFIELD"
+>id</CODE
+> or
+<CODE
+CLASS="STRUCTFIELD"
+>index</CODE
+> is invalid.</P
+></DD
+></DL
+></DIV
+></DIV
+><H1
+><A
+NAME="VIDIOC-QUERYSTD"
+></A
+>ioctl VIDIOC_QUERYSTD</H1
+><DIV
+CLASS="REFNAMEDIV"
+><A
+NAME="AEN9015"
+></A
+><H2
+>Name</H2
+>ioctl VIDIOC_QUERYSTD&nbsp;--&nbsp;Sense the video standard received by the current input</DIV
+><DIV
+CLASS="REFSYNOPSISDIV"
+><A
+NAME="AEN9018"
+></A
+><H2
+>Synopsis</H2
+><DIV
+CLASS="FUNCSYNOPSIS"
+><P
+></P
+><A
+NAME="AEN9019"
+></A
+><P
+><CODE
+><CODE
+CLASS="FUNCDEF"
+>int ioctl</CODE
+>(int fd, int request, v4l2_std_id *argp);</CODE
+></P
+><P
+></P
+></DIV
+></DIV
+><DIV
+CLASS="REFSECT1"
+><A
+NAME="AEN9029"
+></A
+><H2
+>Arguments</H2
+><P
+></P
+><DIV
+CLASS="VARIABLELIST"
+><DL
+><DT
+><VAR
+CLASS="PARAMETER"
+>fd</VAR
+></DT
+><DD
+><P
+>File descriptor returned by <A
+HREF="#FUNC-OPEN"
+><CODE
+CLASS="FUNCTION"
+>open()</CODE
+></A
+>.</P
+></DD
+><DT
+><VAR
+CLASS="PARAMETER"
+>request</VAR
+></DT
+><DD
+><P
+>VIDIOC_QUERYSTD</P
+></DD
+><DT
+><VAR
+CLASS="PARAMETER"
+>argp</VAR
+></DT
+><DD
+><P
+></P
+></DD
+></DL
+></DIV
+></DIV
+><DIV
+CLASS="REFSECT1"
+><A
+NAME="AEN9049"
+></A
+><H2
+>Description</H2
+><P
+>The hardware may be able to detect the current video
+standard automatically. To do so, applications call <CODE
+CLASS="CONSTANT"
+>VIDIOC_QUERYSTD</CODE
+> with a pointer to a <A
+HREF="#V4L2-STD-ID"
+>v4l2_std_id</A
+> type. The
+driver stores here a set of candidates, this can be a single flag or a
+set of supported standards if for example the hardware can only
+distinguish between 50 and 60 Hz systems. When detection is not
+possible or fails, the set must contain all standards supported by the
+current video input or output.</P
+></DIV
+><DIV
+CLASS="REFSECT1"
+><A
+NAME="AEN9054"
+></A
+><H2
+>Return Value</H2
+><P
+>On success <SPAN
+CLASS="RETURNVALUE"
+>0</SPAN
+> is returned, on
+error <SPAN
+CLASS="RETURNVALUE"
+>-1</SPAN
+> and <VAR
+CLASS="VARNAME"
+>errno</VAR
+> is
+set appropriately:</P
+><P
+></P
+><DIV
+CLASS="VARIABLELIST"
+><DL
+><DT
+><SPAN
+CLASS="ERRORCODE"
+>EINVAL</SPAN
+></DT
+><DD
+><P
+>This ioctl is not supported.</P
+></DD
+></DL
+></DIV
+></DIV
+><H1
+><A
+NAME="VIDIOC-REQBUFS"
+></A
+>ioctl VIDIOC_REQBUFS</H1
+><DIV
+CLASS="REFNAMEDIV"
+><A
+NAME="AEN9067"
+></A
+><H2
+>Name</H2
+>ioctl VIDIOC_REQBUFS&nbsp;--&nbsp;Initiate Memory Mapping or User Pointer I/O</DIV
+><DIV
+CLASS="REFSYNOPSISDIV"
+><A
+NAME="AEN9070"
+></A
+><H2
+>Synopsis</H2
+><DIV
+CLASS="FUNCSYNOPSIS"
+><P
+></P
+><A
+NAME="AEN9071"
+></A
+><P
+><CODE
+><CODE
+CLASS="FUNCDEF"
+>int ioctl</CODE
+>(int fd, int request, struct v4l2_requestbuffers *argp);</CODE
+></P
+><P
+></P
+></DIV
+></DIV
+><DIV
+CLASS="REFSECT1"
+><A
+NAME="AEN9081"
+></A
+><H2
+>Arguments</H2
+><P
+></P
+><DIV
+CLASS="VARIABLELIST"
+><DL
+><DT
+><VAR
+CLASS="PARAMETER"
+>fd</VAR
+></DT
+><DD
+><P
+>File descriptor returned by <A
+HREF="#FUNC-OPEN"
+><CODE
+CLASS="FUNCTION"
+>open()</CODE
+></A
+>.</P
+></DD
+><DT
+><VAR
+CLASS="PARAMETER"
+>request</VAR
+></DT
+><DD
+><P
+>VIDIOC_REQBUFS</P
+></DD
+><DT
+><VAR
+CLASS="PARAMETER"
+>argp</VAR
+></DT
+><DD
+><P
+></P
+></DD
+></DL
+></DIV
+></DIV
+><DIV
+CLASS="REFSECT1"
+><A
+NAME="AEN9101"
+></A
+><H2
+>Description</H2
+><P
+>This ioctl is used to initiate <A
+HREF="#MMAP"
+>memory
+mapped</A
+> or <A
+HREF="#USERP"
+>user pointer</A
+>
+I/O. Memory mapped buffers are located in device memory and must be
+allocated with this ioctl before they can be mapped into the
+application's address space. User buffers are allocated by
+applications themselves, and this ioctl is merely used to switch the
+driver into user pointer I/O mode.</P
+><P
+>To allocate device buffers applications initialize three
+fields of a <CODE
+CLASS="STRUCTNAME"
+>v4l2_requestbuffers</CODE
+> structure.
+They set the <CODE
+CLASS="STRUCTFIELD"
+>type</CODE
+> field to the respective
+stream or buffer type, the <CODE
+CLASS="STRUCTFIELD"
+>count</CODE
+> field to
+the desired number of buffers, and <CODE
+CLASS="STRUCTFIELD"
+>memory</CODE
+>
+must be set to <CODE
+CLASS="CONSTANT"
+>V4L2_MEMORY_MMAP</CODE
+>. When the ioctl
+is called with a pointer to this structure the driver attempts to
+allocate the requested number of buffers and stores the actual number
+allocated in the <CODE
+CLASS="STRUCTFIELD"
+>count</CODE
+> field. It can be
+smaller than the number requested, even zero, when the driver runs out
+of free memory. A larger number is possible when the driver requires
+more buffers to function correctly.<A
+NAME="AEN9113"
+HREF="#FTN.AEN9113"
+><SPAN
+CLASS="footnote"
+>[26]</SPAN
+></A
+> When memory mapping I/O is not supported the ioctl
+returns an <SPAN
+CLASS="ERRORCODE"
+>EINVAL</SPAN
+> error code.</P
+><P
+>Applications can call <CODE
+CLASS="CONSTANT"
+>VIDIOC_REQBUFS</CODE
+>
+again to change the number of buffers, however this cannot succeed
+when any buffers are still mapped. A <CODE
+CLASS="STRUCTFIELD"
+>count</CODE
+>
+value of zero frees all buffers, after aborting or finishing any DMA
+in progress, an implicit <A
+HREF="#VIDIOC-STREAMON"
+><CODE
+CLASS="CONSTANT"
+>VIDIOC_STREAMOFF</CODE
+></A
+>. </P
+><P
+>To negotiate user pointer I/O, applications initialize only
+the <CODE
+CLASS="STRUCTFIELD"
+>type</CODE
+> field and set
+<CODE
+CLASS="STRUCTFIELD"
+>memory</CODE
+> to
+<CODE
+CLASS="CONSTANT"
+>V4L2_MEMORY_USERPTR</CODE
+>. When the ioctl is called
+with a pointer to this structure the driver prepares for user pointer
+I/O, when this I/O method is not supported the ioctl returns an
+<SPAN
+CLASS="ERRORCODE"
+>EINVAL</SPAN
+> error code.</P
+><DIV
+CLASS="TABLE"
+><A
+NAME="V4L2-REQUESTBUFFERS"
+></A
+><P
+><B
+>Table 1. struct <CODE
+CLASS="STRUCTNAME"
+>v4l2_requestbuffers</CODE
+></B
+></P
+><TABLE
+BORDER="0"
+FRAME="void"
+WIDTH="100%"
+CLASS="CALSTABLE"
+><COL
+WIDTH="25%"
+TITLE="C1"><COL
+WIDTH="25%"
+TITLE="C2"><COL
+WIDTH="50%"
+TITLE="C3"><TBODY
+><TR
+><TD
+>__u32</TD
+><TD
+><CODE
+CLASS="STRUCTFIELD"
+>count</CODE
+></TD
+><TD
+>The number of buffers requested or granted. This
+field is only used when <CODE
+CLASS="STRUCTFIELD"
+>memory</CODE
+> is set to
+<CODE
+CLASS="CONSTANT"
+>V4L2_MEMORY_MMAP</CODE
+>.</TD
+></TR
+><TR
+><TD
+>enum&nbsp;<A
+HREF="#V4L2-BUF-TYPE"
+>v4l2_buf_type</A
+></TD
+><TD
+><CODE
+CLASS="STRUCTFIELD"
+>type</CODE
+></TD
+><TD
+>Type of the stream or buffers, this is the same
+as the struct&nbsp;<A
+HREF="#V4L2-FORMAT"
+>v4l2_format</A
+> <CODE
+CLASS="STRUCTFIELD"
+>type</CODE
+> field. See <A
+HREF="#V4L2-BUF-TYPE"
+>Table 3-2</A
+> for valid values.</TD
+></TR
+><TR
+><TD
+>enum&nbsp;<A
+HREF="#V4L2-MEMORY"
+>v4l2_memory</A
+></TD
+><TD
+><CODE
+CLASS="STRUCTFIELD"
+>memory</CODE
+></TD
+><TD
+>Applications set this field to
+<CODE
+CLASS="CONSTANT"
+>V4L2_MEMORY_MMAP</CODE
+> or
+<CODE
+CLASS="CONSTANT"
+>V4L2_MEMORY_USERPTR</CODE
+>.</TD
+></TR
+><TR
+><TD
+>__u32</TD
+><TD
+><CODE
+CLASS="STRUCTFIELD"
+>reserved</CODE
+>[32]</TD
+><TD
+>A place holder for future extensions and custom
+(driver defined) buffer types <CODE
+CLASS="CONSTANT"
+>V4L2_BUF_TYPE_PRIVATE</CODE
+> and
+higher.</TD
+></TR
+></TBODY
+></TABLE
+></DIV
+></DIV
+><DIV
+CLASS="REFSECT1"
+><A
+NAME="AEN9165"
+></A
+><H2
+>Return Value</H2
+><P
+>On success <SPAN
+CLASS="RETURNVALUE"
+>0</SPAN
+> is returned, on
+error <SPAN
+CLASS="RETURNVALUE"
+>-1</SPAN
+> and <VAR
+CLASS="VARNAME"
+>errno</VAR
+> is
+set appropriately:</P
+><P
+></P
+><DIV
+CLASS="VARIABLELIST"
+><DL
+><DT
+><SPAN
+CLASS="ERRORCODE"
+>EBUSY</SPAN
+></DT
+><DD
+><P
+>The driver supports multiple opens and I/O is already
+in progress, or reallocation of buffers was attempted although one or
+more are still mapped.</P
+></DD
+><DT
+><SPAN
+CLASS="ERRORCODE"
+>EINVAL</SPAN
+></DT
+><DD
+><P
+>The buffer type (<CODE
+CLASS="STRUCTFIELD"
+>type</CODE
+> field) or the
+requested I/O method (<CODE
+CLASS="STRUCTFIELD"
+>memory</CODE
+>) is not
+supported.</P
+></DD
+></DL
+></DIV
+></DIV
+><H1
+><A
+NAME="VIDIOC-STREAMON"
+></A
+>ioctl VIDIOC_STREAMON, VIDIOC_STREAMOFF</H1
+><DIV
+CLASS="REFNAMEDIV"
+><A
+NAME="AEN9187"
+></A
+><H2
+>Name</H2
+>ioctl VIDIOC_STREAMON, ioctl VIDIOC_STREAMOFF&nbsp;--&nbsp;Start or stop streaming I/O.</DIV
+><DIV
+CLASS="REFSYNOPSISDIV"
+><A
+NAME="AEN9191"
+></A
+><H2
+>Synopsis</H2
+><DIV
+CLASS="FUNCSYNOPSIS"
+><P
+></P
+><A
+NAME="AEN9192"
+></A
+><P
+><CODE
+><CODE
+CLASS="FUNCDEF"
+>int ioctl</CODE
+>(int fd, int request, const int *argp);</CODE
+></P
+><P
+></P
+></DIV
+></DIV
+><DIV
+CLASS="REFSECT1"
+><A
+NAME="AEN9202"
+></A
+><H2
+>Arguments</H2
+><P
+></P
+><DIV
+CLASS="VARIABLELIST"
+><DL
+><DT
+><VAR
+CLASS="PARAMETER"
+>fd</VAR
+></DT
+><DD
+><P
+>File descriptor returned by <A
+HREF="#FUNC-OPEN"
+><CODE
+CLASS="FUNCTION"
+>open()</CODE
+></A
+>.</P
+></DD
+><DT
+><VAR
+CLASS="PARAMETER"
+>request</VAR
+></DT
+><DD
+><P
+>VIDIOC_STREAMON, VIDIOC_STREAMOFF</P
+></DD
+><DT
+><VAR
+CLASS="PARAMETER"
+>argp</VAR
+></DT
+><DD
+><P
+></P
+></DD
+></DL
+></DIV
+></DIV
+><DIV
+CLASS="REFSECT1"
+><A
+NAME="AEN9222"
+></A
+><H2
+>Description</H2
+><P
+>The <CODE
+CLASS="CONSTANT"
+>VIDIOC_STREAMON</CODE
+> and
+<CODE
+CLASS="CONSTANT"
+>VIDIOC_STREAMOFF</CODE
+> ioctl start and stop the capture
+or output process during streaming (<A
+HREF="#MMAP"
+>memory
+mapping</A
+> or <A
+HREF="#USERP"
+>user pointer</A
+>) I/O.</P
+><P
+>Specifically the capture hardware is disabled and no input
+buffers are filled (if there are any empty buffers in the incoming
+queue) until <CODE
+CLASS="CONSTANT"
+>VIDIOC_STREAMON</CODE
+> has been called.
+Accordingly the output hardware is disabled, no video signal is
+produced until <CODE
+CLASS="CONSTANT"
+>VIDIOC_STREAMON</CODE
+> has been called.
+The ioctl will succeed only when at least one output buffer is in the
+incoming queue.</P
+><P
+>The <CODE
+CLASS="CONSTANT"
+>VIDIOC_STREAMOFF</CODE
+> 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
+<A
+HREF="#VIDIOC-REQBUFS"
+><CODE
+CLASS="CONSTANT"
+>VIDIOC_REQBUFS</CODE
+></A
+> and can be restarted accordingly.</P
+><P
+>Both ioctls take a pointer to an integer, the desired buffer or
+stream type. This is the same as struct&nbsp;<A
+HREF="#V4L2-REQUESTBUFFERS"
+>v4l2_requestbuffers</A
+>
+<CODE
+CLASS="STRUCTFIELD"
+>type</CODE
+>.</P
+><P
+>Note applications can be preempted for unknown periods right
+before or after the <CODE
+CLASS="CONSTANT"
+>VIDIOC_STREAMON</CODE
+> or
+<CODE
+CLASS="CONSTANT"
+>VIDIOC_STREAMOFF</CODE
+> calls, there is no notion of
+starting or stopping "now". Buffer timestamps can be used to
+synchronize with other events.</P
+></DIV
+><DIV
+CLASS="REFSECT1"
+><A
+NAME="AEN9242"
+></A
+><H2
+>Return Value</H2
+><P
+>On success <SPAN
+CLASS="RETURNVALUE"
+>0</SPAN
+> is returned, on
+error <SPAN
+CLASS="RETURNVALUE"
+>-1</SPAN
+> and <VAR
+CLASS="VARNAME"
+>errno</VAR
+> is
+set appropriately:</P
+><P
+></P
+><DIV
+CLASS="VARIABLELIST"
+><DL
+><DT
+><SPAN
+CLASS="ERRORCODE"
+>EINVAL</SPAN
+></DT
+><DD
+><P
+>Streaming I/O is not supported, the buffer
+<CODE
+CLASS="STRUCTFIELD"
+>type</CODE
+> is not supported, or no buffers have
+been allocated (memory mapping) or enqueued (output) yet.</P
+></DD
+></DL
+></DIV
+></DIV
+><H1
+><A
+NAME="FUNC-MMAP"
+></A
+>mmap</H1
+><DIV
+CLASS="REFNAMEDIV"
+><A
+NAME="AEN9256"
+></A
+><H2
+>Name</H2
+>mmap&nbsp;--&nbsp;Map device memory into application address space</DIV
+><DIV
+CLASS="REFSYNOPSISDIV"
+><A
+NAME="AEN9259"
+></A
+><H2
+>Synopsis</H2
+><DIV
+CLASS="FUNCSYNOPSIS"
+><P
+></P
+><A
+NAME="AEN9260"
+></A
+><PRE
+CLASS="FUNCSYNOPSISINFO"
+>#include &lt;unistd.h&gt;
+#include &lt;sys/mman.h&gt;</PRE
+><P
+><CODE
+><CODE
+CLASS="FUNCDEF"
+>void *mmap</CODE
+>(void *start, size_t length, int prot, int flags, int fd, off_t offset);</CODE
+></P
+><P
+></P
+></DIV
+></DIV
+><DIV
+CLASS="REFSECT1"
+><A
+NAME="AEN9277"
+></A
+><H2
+>Arguments</H2
+><P
+></P
+><DIV
+CLASS="VARIABLELIST"
+><DL
+><DT
+><VAR
+CLASS="PARAMETER"
+>start</VAR
+></DT
+><DD
+><P
+>Map the buffer to this address in the
+application's address space. When the <CODE
+CLASS="CONSTANT"
+>MAP_FIXED</CODE
+>
+flag is specified, <VAR
+CLASS="PARAMETER"
+>start</VAR
+> must be a multiple of the
+pagesize and mmap will fail when the specified address
+cannot be used. Use of this option is discouraged; applications should
+just specify a <CODE
+CLASS="CONSTANT"
+>NULL</CODE
+> pointer here.</P
+></DD
+><DT
+><VAR
+CLASS="PARAMETER"
+>length</VAR
+></DT
+><DD
+><P
+>Length of the memory area to map. This must be the
+same value as returned by the driver in the struct&nbsp;<A
+HREF="#V4L2-BUFFER"
+>v4l2_buffer</A
+>
+<CODE
+CLASS="STRUCTFIELD"
+>length</CODE
+> field.</P
+></DD
+><DT
+><VAR
+CLASS="PARAMETER"
+>prot</VAR
+></DT
+><DD
+><P
+>The <VAR
+CLASS="PARAMETER"
+>prot</VAR
+> argument describes the
+desired memory protection. It must be set to
+<CODE
+CLASS="CONSTANT"
+>PROT_READ</CODE
+> | <CODE
+CLASS="CONSTANT"
+>PROT_WRITE</CODE
+>,
+indicating pages may be read and written. This is a technicality
+independent of the
+device type and direction of data exchange. Note device memory
+accesses may incur a performance penalty. It can happen when writing
+to capture buffers, when reading from output buffers, or always. When
+the application intends to modify buffers, other I/O methods may be
+more efficient.</P
+></DD
+><DT
+><VAR
+CLASS="PARAMETER"
+>flags</VAR
+></DT
+><DD
+><P
+>The <VAR
+CLASS="PARAMETER"
+>flags</VAR
+> parameter
+specifies the type of the mapped object, mapping options and whether
+modifications made to the mapped copy of the page are private to the
+process or are to be shared with other references.</P
+><P
+><CODE
+CLASS="CONSTANT"
+>MAP_FIXED</CODE
+> requests that the
+driver selects no other address than the one specified. If the
+specified address cannot be used, mmap will fail. If
+<CODE
+CLASS="CONSTANT"
+>MAP_FIXED</CODE
+> is specified,
+<VAR
+CLASS="PARAMETER"
+>start</VAR
+> must be a multiple of the pagesize. Use
+of this option is discouraged.</P
+><P
+>One of the <CODE
+CLASS="CONSTANT"
+>MAP_SHARED</CODE
+> or
+<CODE
+CLASS="CONSTANT"
+>MAP_PRIVATE</CODE
+> flags must be set.
+<CODE
+CLASS="CONSTANT"
+>MAP_SHARED</CODE
+> allows to share this mapping with all
+other processes that map this object. <CODE
+CLASS="CONSTANT"
+>MAP_PRIVATE</CODE
+>
+requests copy-on-write semantics. We recommend to set
+<CODE
+CLASS="CONSTANT"
+>MAP_SHARED</CODE
+>. The <CODE
+CLASS="CONSTANT"
+>MAP_PRIVATE</CODE
+>,
+<CODE
+CLASS="CONSTANT"
+>MAP_DENYWRITE</CODE
+>,
+<CODE
+CLASS="CONSTANT"
+>MAP_EXECUTABLE</CODE
+> and <CODE
+CLASS="CONSTANT"
+>MAP_ANON</CODE
+>
+flags should not be set.</P
+></DD
+><DT
+><VAR
+CLASS="PARAMETER"
+>fd</VAR
+></DT
+><DD
+><P
+>File descriptor returned by <A
+HREF="#FUNC-OPEN"
+><CODE
+CLASS="FUNCTION"
+>open()</CODE
+></A
+>.</P
+></DD
+><DT
+><VAR
+CLASS="PARAMETER"
+>offset</VAR
+></DT
+><DD
+><P
+>Offset of the buffer in device memory. This must be the
+same value as returned by the driver in the struct&nbsp;<A
+HREF="#V4L2-BUFFER"
+>v4l2_buffer</A
+>
+<CODE
+CLASS="STRUCTFIELD"
+>m</CODE
+> union <CODE
+CLASS="STRUCTFIELD"
+>offset</CODE
+> field.</P
+></DD
+></DL
+></DIV
+></DIV
+><DIV
+CLASS="REFSECT1"
+><A
+NAME="AEN9338"
+></A
+><H2
+>Description</H2
+><P
+>The <CODE
+CLASS="FUNCTION"
+>mmap()</CODE
+> function asks to map
+<VAR
+CLASS="PARAMETER"
+>length</VAR
+> bytes starting at
+<VAR
+CLASS="PARAMETER"
+>offset</VAR
+> in the memory of the device specified by
+<VAR
+CLASS="PARAMETER"
+>fd</VAR
+> into the application address space,
+preferably at address <VAR
+CLASS="PARAMETER"
+>start</VAR
+>. This latter
+address is a hint only, and is usually specified as 0.</P
+><P
+>Suitable length and offset parameters are queried with the
+<A
+HREF="#VIDIOC-QUERYBUF"
+><CODE
+CLASS="CONSTANT"
+>VIDIOC_QUERYBUF</CODE
+></A
+> ioctl. Buffers must be allocated with the
+<A
+HREF="#VIDIOC-REQBUFS"
+><CODE
+CLASS="CONSTANT"
+>VIDIOC_REQBUFS</CODE
+></A
+> ioctl before they can be queried.</P
+><P
+>To unmap buffers the <A
+HREF="#FUNC-MUNMAP"
+><CODE
+CLASS="FUNCTION"
+>munmap()</CODE
+></A
+> function is used.</P
+></DIV
+><DIV
+CLASS="REFSECT1"
+><A
+NAME="AEN9354"
+></A
+><H2
+>Return Value</H2
+><P
+>On success, <CODE
+CLASS="FUNCTION"
+>mmap()</CODE
+> returns a pointer to
+the mapped buffer. On error, <CODE
+CLASS="CONSTANT"
+>MAP_FAILED</CODE
+> (-1) is
+returned, and <VAR
+CLASS="VARNAME"
+>errno</VAR
+> is set appropriately. Possible
+error codes:</P
+><P
+></P
+><DIV
+CLASS="VARIABLELIST"
+><DL
+><DT
+><SPAN
+CLASS="ERRORCODE"
+>EBADF</SPAN
+></DT
+><DD
+><P
+><VAR
+CLASS="PARAMETER"
+>fd</VAR
+> is not a valid file
+descriptor.</P
+></DD
+><DT
+><SPAN
+CLASS="ERRORCODE"
+>EACCESS</SPAN
+></DT
+><DD
+><P
+><VAR
+CLASS="PARAMETER"
+>fd</VAR
+> is
+not open for reading and writing.</P
+></DD
+><DT
+><SPAN
+CLASS="ERRORCODE"
+>EINVAL</SPAN
+></DT
+><DD
+><P
+>The <VAR
+CLASS="PARAMETER"
+>start</VAR
+> or
+<VAR
+CLASS="PARAMETER"
+>length</VAR
+> or <VAR
+CLASS="PARAMETER"
+>offset</VAR
+> are not
+suitable. (E.g., they are too large, or not aligned on a
+<CODE
+CLASS="CONSTANT"
+>PAGESIZE</CODE
+> boundary.) Or no buffers have been
+allocated with the <A
+HREF="#VIDIOC-REQBUFS"
+><CODE
+CLASS="CONSTANT"
+>VIDIOC_REQBUFS</CODE
+></A
+> ioctl.</P
+></DD
+><DT
+><SPAN
+CLASS="ERRORCODE"
+>ENOMEM</SPAN
+></DT
+><DD
+><P
+>No memory is available.</P
+></DD
+></DL
+></DIV
+></DIV
+><H1
+><A
+NAME="FUNC-MUNMAP"
+></A
+>munmap</H1
+><DIV
+CLASS="REFNAMEDIV"
+><A
+NAME="AEN9390"
+></A
+><H2
+>Name</H2
+>munmap&nbsp;--&nbsp;Unmap device memory</DIV
+><DIV
+CLASS="REFSYNOPSISDIV"
+><A
+NAME="AEN9393"
+></A
+><H2
+>Synopsis</H2
+><DIV
+CLASS="FUNCSYNOPSIS"
+><P
+></P
+><A
+NAME="AEN9394"
+></A
+><PRE
+CLASS="FUNCSYNOPSISINFO"
+>#include &lt;unistd.h&gt;
+#include &lt;sys/mman.h&gt;</PRE
+><P
+><CODE
+><CODE
+CLASS="FUNCDEF"
+>int munmap</CODE
+>(void *start, size_t length);</CODE
+></P
+><P
+></P
+></DIV
+></DIV
+><DIV
+CLASS="REFSECT1"
+><A
+NAME="AEN9403"
+></A
+><H2
+>Arguments</H2
+><P
+></P
+><DIV
+CLASS="VARIABLELIST"
+><DL
+><DT
+><VAR
+CLASS="PARAMETER"
+>start</VAR
+></DT
+><DD
+><P
+>Address of the mapped buffer as returned by the
+<A
+HREF="#FUNC-MMAP"
+><CODE
+CLASS="FUNCTION"
+>mmap()</CODE
+></A
+> function.</P
+></DD
+><DT
+><VAR
+CLASS="PARAMETER"
+>length</VAR
+></DT
+><DD
+><P
+>Length of the mapped buffer. This must be the same
+value as given to <CODE
+CLASS="FUNCTION"
+>mmap()</CODE
+> and returned by the
+driver in the struct&nbsp;<A
+HREF="#V4L2-BUFFER"
+>v4l2_buffer</A
+> <CODE
+CLASS="STRUCTFIELD"
+>length</CODE
+>
+field.</P
+></DD
+></DL
+></DIV
+></DIV
+><DIV
+CLASS="REFSECT1"
+><A
+NAME="AEN9421"
+></A
+><H2
+>Description</H2
+><P
+>Unmaps a previously with the <A
+HREF="#FUNC-MMAP"
+><CODE
+CLASS="FUNCTION"
+>mmap()</CODE
+></A
+> function mapped
+buffer and frees it, if possible. </P
+></DIV
+><DIV
+CLASS="REFSECT1"
+><A
+NAME="AEN9426"
+></A
+><H2
+>Return Value</H2
+><P
+>On success <CODE
+CLASS="FUNCTION"
+>munmap()</CODE
+> returns 0, on
+failure -1, and errno is set.</P
+><P
+></P
+><DIV
+CLASS="VARIABLELIST"
+><DL
+><DT
+><SPAN
+CLASS="ERRORCODE"
+>EINVAL</SPAN
+></DT
+><DD
+><P
+>The <VAR
+CLASS="PARAMETER"
+>start</VAR
+> or
+<VAR
+CLASS="PARAMETER"
+>length</VAR
+> is incorrect, or no buffers have been
+mapped yet.</P
+></DD
+></DL
+></DIV
+></DIV
+><H1
+><A
+NAME="FUNC-OPEN"
+></A
+>open</H1
+><DIV
+CLASS="REFNAMEDIV"
+><A
+NAME="AEN9439"
+></A
+><H2
+>Name</H2
+>open&nbsp;--&nbsp;Open a V4L2 device</DIV
+><DIV
+CLASS="REFSYNOPSISDIV"
+><A
+NAME="AEN9442"
+></A
+><H2
+>Synopsis</H2
+><DIV
+CLASS="FUNCSYNOPSIS"
+><P
+></P
+><A
+NAME="AEN9443"
+></A
+><PRE
+CLASS="FUNCSYNOPSISINFO"
+>#include &lt;fcntl.h&gt;</PRE
+><P
+><CODE
+><CODE
+CLASS="FUNCDEF"
+>int open</CODE
+>(const char *device_name, int flags);</CODE
+></P
+><P
+></P
+></DIV
+></DIV
+><DIV
+CLASS="REFSECT1"
+><A
+NAME="AEN9452"
+></A
+><H2
+>Arguments</H2
+><P
+></P
+><DIV
+CLASS="VARIABLELIST"
+><DL
+><DT
+><VAR
+CLASS="PARAMETER"
+>device_name</VAR
+></DT
+><DD
+><P
+>Device to be opened.</P
+></DD
+><DT
+><VAR
+CLASS="PARAMETER"
+>flags</VAR
+></DT
+><DD
+><P
+>Open flags. Access mode must be
+<CODE
+CLASS="CONSTANT"
+>O_RDWR</CODE
+>. This is just a technicality, input devices
+still support only reading and output devices only writing.</P
+><P
+>When the <CODE
+CLASS="CONSTANT"
+>O_NONBLOCK</CODE
+> flag is
+given, the read() function and the <A
+HREF="#VIDIOC-QBUF"
+><CODE
+CLASS="CONSTANT"
+>VIDIOC_DQBUF</CODE
+></A
+> ioctl will return
+the <SPAN
+CLASS="ERRORCODE"
+>EAGAIN</SPAN
+> error code when no data is available or no buffer is in the driver
+outgoing queue, otherwise these functions block until data becomes
+available. All V4L2 drivers exchanging data with applications must
+support the <CODE
+CLASS="CONSTANT"
+>O_NONBLOCK</CODE
+> flag.</P
+><P
+>Other flags have no effect.</P
+></DD
+></DL
+></DIV
+></DIV
+><DIV
+CLASS="REFSECT1"
+><A
+NAME="AEN9473"
+></A
+><H2
+>Description</H2
+><P
+>To open a V4L2 device applications call
+<CODE
+CLASS="FUNCTION"
+>open()</CODE
+> with the desired device name. This
+function has no side effects; all data format parameters, current
+input or output, control values or other properties remain unchanged.
+At the first <CODE
+CLASS="FUNCTION"
+>open()</CODE
+> call after loading the driver
+they will be reset to default values, drivers are never in an
+undefined state.</P
+></DIV
+><DIV
+CLASS="REFSECT1"
+><A
+NAME="AEN9478"
+></A
+><H2
+>Return Value</H2
+><P
+>On success <CODE
+CLASS="FUNCTION"
+>open</CODE
+> returns the new
+file descriptor. On error -1 is returned, and <VAR
+CLASS="VARNAME"
+>errno</VAR
+>
+is set appropriately. Possible error codes:</P
+><P
+></P
+><DIV
+CLASS="VARIABLELIST"
+><DL
+><DT
+><SPAN
+CLASS="ERRORCODE"
+>EACCES</SPAN
+></DT
+><DD
+><P
+>The caller has no permission to access the
+device.</P
+></DD
+><DT
+><SPAN
+CLASS="ERRORCODE"
+>EBUSY</SPAN
+></DT
+><DD
+><P
+>The driver does not support multiple opens and the
+device is already in use.</P
+></DD
+><DT
+><SPAN
+CLASS="ERRORCODE"
+>ENXIO</SPAN
+></DT
+><DD
+><P
+>No device corresponding to this device special file
+exists.</P
+></DD
+><DT
+><SPAN
+CLASS="ERRORCODE"
+>ENOMEM</SPAN
+></DT
+><DD
+><P
+>Insufficient kernel memory was available.</P
+></DD
+><DT
+><SPAN
+CLASS="ERRORCODE"
+>EMFILE</SPAN
+></DT
+><DD
+><P
+>The process already has the maximum number of
+files open.</P
+></DD
+><DT
+><SPAN
+CLASS="ERRORCODE"
+>ENFILE</SPAN
+></DT
+><DD
+><P
+>The limit on the total number of files open on the
+system has been reached.</P
+></DD
+></DL
+></DIV
+></DIV
+><H1
+><A
+NAME="FUNC-POLL"
+></A
+>poll</H1
+><DIV
+CLASS="REFNAMEDIV"
+><A
+NAME="AEN9515"
+></A
+><H2
+>Name</H2
+>poll&nbsp;--&nbsp;Wait for some event on a file descriptor</DIV
+><DIV
+CLASS="REFSYNOPSISDIV"
+><A
+NAME="AEN9518"
+></A
+><H2
+>Synopsis</H2
+><DIV
+CLASS="FUNCSYNOPSIS"
+><P
+></P
+><A
+NAME="AEN9519"
+></A
+><PRE
+CLASS="FUNCSYNOPSISINFO"
+>#include &lt;sys/poll.h&gt;</PRE
+><P
+><CODE
+><CODE
+CLASS="FUNCDEF"
+>int poll</CODE
+>(struct pollfd *ufds, unsigned int nfds, int timeout);</CODE
+></P
+><P
+></P
+></DIV
+></DIV
+><DIV
+CLASS="REFSECT1"
+><A
+NAME="AEN9530"
+></A
+><H2
+>Description</H2
+><P
+>All drivers implementing the <CODE
+CLASS="FUNCTION"
+>read()</CODE
+>
+or <CODE
+CLASS="FUNCTION"
+>write()</CODE
+> function or streaming I/O must also support the
+<CODE
+CLASS="FUNCTION"
+>poll()</CODE
+> function. See the
+<CODE
+CLASS="FUNCTION"
+>poll()</CODE
+> manual page for details.</P
+></DIV
+><H1
+><A
+NAME="FUNC-READ"
+></A
+>read</H1
+><DIV
+CLASS="REFNAMEDIV"
+><A
+NAME="AEN9538"
+></A
+><H2
+>Name</H2
+>read&nbsp;--&nbsp;Read from a V4L2 device</DIV
+><DIV
+CLASS="REFSYNOPSISDIV"
+><A
+NAME="AEN9541"
+></A
+><H2
+>Synopsis</H2
+><DIV
+CLASS="FUNCSYNOPSIS"
+><P
+></P
+><A
+NAME="AEN9542"
+></A
+><PRE
+CLASS="FUNCSYNOPSISINFO"
+>#include &lt;unistd.h&gt;</PRE
+><P
+><CODE
+><CODE
+CLASS="FUNCDEF"
+>ssize_t read</CODE
+>(int fd, void *buf, size_t count);</CODE
+></P
+><P
+></P
+></DIV
+></DIV
+><DIV
+CLASS="REFSECT1"
+><A
+NAME="AEN9553"
+></A
+><H2
+>Arguments</H2
+><P
+></P
+><DIV
+CLASS="VARIABLELIST"
+><DL
+><DT
+><VAR
+CLASS="PARAMETER"
+>fd</VAR
+></DT
+><DD
+><P
+>File descriptor returned by <A
+HREF="#FUNC-OPEN"
+><CODE
+CLASS="FUNCTION"
+>open()</CODE
+></A
+>.</P
+></DD
+><DT
+><VAR
+CLASS="PARAMETER"
+>buf</VAR
+></DT
+><DD
+><P
+></P
+></DD
+><DT
+><VAR
+CLASS="PARAMETER"
+>count</VAR
+></DT
+><DD
+><P
+></P
+></DD
+></DL
+></DIV
+></DIV
+><DIV
+CLASS="REFSECT1"
+><A
+NAME="AEN9573"
+></A
+><H2
+>Description</H2
+><P
+><CODE
+CLASS="FUNCTION"
+>read()</CODE
+> attempts to read up to
+<VAR
+CLASS="PARAMETER"
+>count</VAR
+> bytes from file descriptor
+<VAR
+CLASS="PARAMETER"
+>fd</VAR
+> into the buffer starting at
+<VAR
+CLASS="PARAMETER"
+>buf</VAR
+>. The layout of the data in the buffer is
+discussed in the respective device interface section, see ##. If <VAR
+CLASS="PARAMETER"
+>count</VAR
+> is zero,
+<CODE
+CLASS="FUNCTION"
+>read()</CODE
+> returns zero and has no other results. If
+<VAR
+CLASS="PARAMETER"
+>count</VAR
+> is greater than
+<CODE
+CLASS="CONSTANT"
+>SSIZE_MAX</CODE
+>, the result is unspecified. Regardless
+of the <VAR
+CLASS="PARAMETER"
+>count</VAR
+> value each
+<CODE
+CLASS="FUNCTION"
+>read()</CODE
+> call will provide at most one frame (two
+fields) worth of data.</P
+><P
+>By default <CODE
+CLASS="FUNCTION"
+>read()</CODE
+> blocks until data
+becomes available. When the <CODE
+CLASS="CONSTANT"
+>O_NONBLOCK</CODE
+> flag was
+given to the <A
+HREF="#FUNC-OPEN"
+><CODE
+CLASS="FUNCTION"
+>open()</CODE
+></A
+> function it
+returns immediately with an <SPAN
+CLASS="ERRORCODE"
+>EAGAIN</SPAN
+> error code when no data is available. The
+<A
+HREF="#FUNC-SELECT"
+><CODE
+CLASS="FUNCTION"
+>select()</CODE
+></A
+> or <A
+HREF="#FUNC-POLL"
+><CODE
+CLASS="FUNCTION"
+>poll()</CODE
+></A
+> functions
+can always be used to suspend execution until data becomes available. All
+drivers supporting the <CODE
+CLASS="FUNCTION"
+>read()</CODE
+> function must also
+support <CODE
+CLASS="FUNCTION"
+>select()</CODE
+> and
+<CODE
+CLASS="FUNCTION"
+>poll()</CODE
+>.</P
+><P
+>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.</P
+><P
+><CODE
+CLASS="FUNCTION"
+>read()</CODE
+> never returns a "snapshot" of a
+buffer being filled. 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.</P
+><P
+>The behavior of
+<CODE
+CLASS="FUNCTION"
+>read()</CODE
+> when called during the active picture
+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 time of the <CODE
+CLASS="FUNCTION"
+>read()</CODE
+> call as
+soon as it is complete.</P
+><P
+>A driver discarding the newest frames stops capturing until
+the next <CODE
+CLASS="FUNCTION"
+>read()</CODE
+> call. The frame being received at
+<CODE
+CLASS="FUNCTION"
+>read()</CODE
+> 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 the "bttv" driver, initiating a DMA to user
+memory when <CODE
+CLASS="FUNCTION"
+>read()</CODE
+> is called and returning when
+the DMA finished.</P
+><P
+>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.</P
+><P
+>Applications can get and set the number of buffers used
+internally by the driver with the streaming parameter ioctls, see
+##streaming-par. They
+are optional, however. The discarding policy is not reported and
+cannot be changed. For minimum requirements see the respective device
+interface section in ##.</P
+></DIV
+><DIV
+CLASS="REFSECT1"
+><A
+NAME="AEN9611"
+></A
+><H2
+>Return Value</H2
+><P
+>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 <CODE
+CLASS="FUNCTION"
+>read()</CODE
+> was interrupted
+by a signal. On error, -1 is returned, and <VAR
+CLASS="VARNAME"
+>errno</VAR
+>
+is set appropriately. In this case the next read will start at the
+beginning of a new frame. Possible error codes:</P
+><P
+></P
+><DIV
+CLASS="VARIABLELIST"
+><DL
+><DT
+><SPAN
+CLASS="ERRORCODE"
+>EAGAIN</SPAN
+></DT
+><DD
+><P
+>Non-blocking I/O has been selected using
+O_NONBLOCK and no data was immediately available for reading.</P
+></DD
+><DT
+><SPAN
+CLASS="ERRORCODE"
+>EBADF</SPAN
+></DT
+><DD
+><P
+><VAR
+CLASS="PARAMETER"
+>fd</VAR
+> is not a valid file
+descriptor or is not open for reading, or the process already has the
+maximum number of files open.</P
+></DD
+><DT
+><SPAN
+CLASS="ERRORCODE"
+>EBUSY</SPAN
+></DT
+><DD
+><P
+>The driver does not support multiple read streams and the
+device is already in use.</P
+></DD
+><DT
+><SPAN
+CLASS="ERRORCODE"
+>EFAULT</SPAN
+></DT
+><DD
+><P
+><VAR
+CLASS="PARAMETER"
+>buf</VAR
+> is outside your
+accessible address space.</P
+></DD
+><DT
+><SPAN
+CLASS="ERRORCODE"
+>EINTR</SPAN
+></DT
+><DD
+><P
+>The call was interrupted by a signal before any
+data was read.</P
+></DD
+><DT
+><SPAN
+CLASS="ERRORCODE"
+>EIO</SPAN
+></DT
+><DD
+><P
+>I/O error. This indicates some hardware problem or a
+failure to communicate with a remote device (USB camera etc.).</P
+></DD
+><DT
+><SPAN
+CLASS="ERRORCODE"
+>EINVAL</SPAN
+></DT
+><DD
+><P
+>The <CODE
+CLASS="FUNCTION"
+>read()</CODE
+> function is not
+supported by this driver, not on this device, or generally not on this
+type of device.</P
+></DD
+></DL
+></DIV
+></DIV
+><H1
+><A
+NAME="FUNC-SELECT"
+></A
+>select</H1
+><DIV
+CLASS="REFNAMEDIV"
+><A
+NAME="AEN9656"
+></A
+><H2
+>Name</H2
+>select&nbsp;--&nbsp;Synchronous I/O multiplexing</DIV
+><DIV
+CLASS="REFSYNOPSISDIV"
+><A
+NAME="AEN9659"
+></A
+><H2
+>Synopsis</H2
+><DIV
+CLASS="FUNCSYNOPSIS"
+><P
+></P
+><A
+NAME="AEN9660"
+></A
+><PRE
+CLASS="FUNCSYNOPSISINFO"
+>#include &lt;sys/time.h&gt;
+#include &lt;sys/types.h&gt;
+#include &lt;unistd.h&gt;</PRE
+><P
+><CODE
+><CODE
+CLASS="FUNCDEF"
+>int select</CODE
+>(int n, fd_set *readfds, fd_set *writefds, fd_set *exceptfds, struct timeval *timeout);</CODE
+></P
+><P
+></P
+></DIV
+></DIV
+><DIV
+CLASS="REFSECT1"
+><A
+NAME="AEN9675"
+></A
+><H2
+>Description</H2
+><P
+>All drivers implementing the <CODE
+CLASS="FUNCTION"
+>read()</CODE
+>
+or <CODE
+CLASS="FUNCTION"
+>write()</CODE
+> function or streaming I/O must also support the
+<CODE
+CLASS="FUNCTION"
+>select()</CODE
+> function. See the
+<CODE
+CLASS="FUNCTION"
+>select()</CODE
+> manual page for details.</P
+></DIV
+><H1
+><A
+NAME="FUNC-WRITE"
+></A
+>write</H1
+><DIV
+CLASS="REFNAMEDIV"
+><A
+NAME="AEN9683"
+></A
+><H2
+>Name</H2
+>write&nbsp;--&nbsp;Write to a V4L2 device</DIV
+><DIV
+CLASS="REFSYNOPSISDIV"
+><A
+NAME="AEN9686"
+></A
+><H2
+>Synopsis</H2
+><DIV
+CLASS="FUNCSYNOPSIS"
+><P
+></P
+><A
+NAME="AEN9687"
+></A
+><PRE
+CLASS="FUNCSYNOPSISINFO"
+>#include &lt;unistd.h&gt;</PRE
+><P
+><CODE
+><CODE
+CLASS="FUNCDEF"
+>ssize_t write</CODE
+>(int fd, void *buf, size_t count);</CODE
+></P
+><P
+></P
+></DIV
+></DIV
+><DIV
+CLASS="REFSECT1"
+><A
+NAME="AEN9698"
+></A
+><H2
+>Arguments</H2
+><P
+></P
+><DIV
+CLASS="VARIABLELIST"
+><DL
+><DT
+><VAR
+CLASS="PARAMETER"
+>fd</VAR
+></DT
+><DD
+><P
+>File descriptor returned by <A
+HREF="#FUNC-OPEN"
+><CODE
+CLASS="FUNCTION"
+>open()</CODE
+></A
+>.</P
+></DD
+><DT
+><VAR
+CLASS="PARAMETER"
+>buf</VAR
+></DT
+><DD
+><P
+></P
+></DD
+><DT
+><VAR
+CLASS="PARAMETER"
+>count</VAR
+></DT
+><DD
+><P
+></P
+></DD
+></DL
+></DIV
+></DIV
+><DIV
+CLASS="REFSECT1"
+><A
+NAME="AEN9718"
+></A
+><H2
+>Description</H2
+><P
+><CODE
+CLASS="FUNCTION"
+>write()</CODE
+>
+writes up to <VAR
+CLASS="PARAMETER"
+>count</VAR
+> bytes to the device referenced by
+ the file descriptor <VAR
+CLASS="PARAMETER"
+>fd</VAR
+> from the buffer
+starting at <VAR
+CLASS="PARAMETER"
+>buf</VAR
+>.
+If <VAR
+CLASS="PARAMETER"
+>count</VAR
+> is zero, 0 will be returned without
+causing any other effect. [implementation tbd]</P
+><P
+>When the application does not provide more data in time, the
+previous frame is displayed again.</P
+></DIV
+><DIV
+CLASS="REFSECT1"
+><A
+NAME="AEN9727"
+></A
+><H2
+>Return Value</H2
+><P
+>On success, the number of bytes written are returned.
+Zero indicates nothing was written. [tbd] On error, -1 is
+returned, and <VAR
+CLASS="VARNAME"
+>errno</VAR
+> is set appropriately. In this
+case the next write will start at the beginning of a new frame.
+Possible error codes:</P
+><P
+></P
+><DIV
+CLASS="VARIABLELIST"
+><DL
+><DT
+><SPAN
+CLASS="ERRORCODE"
+>EAGAIN</SPAN
+></DT
+><DD
+><P
+>Non-blocking I/O has been selected using
+O_NONBLOCK and no buffer space was available to write the data
+immediately. [tbd]</P
+></DD
+><DT
+><SPAN
+CLASS="ERRORCODE"
+>EBADF</SPAN
+></DT
+><DD
+><P
+><VAR
+CLASS="PARAMETER"
+>fd</VAR
+> is not a valid file
+descriptor or is not open for writing.</P
+></DD
+><DT
+><SPAN
+CLASS="ERRORCODE"
+>EBUSY</SPAN
+></DT
+><DD
+><P
+>The driver does not support multiple write streams and the
+device is already in use.</P
+></DD
+><DT
+><SPAN
+CLASS="ERRORCODE"
+>EFAULT</SPAN
+></DT
+><DD
+><P
+><VAR
+CLASS="PARAMETER"
+>buf</VAR
+> is outside your
+accessible address space.</P
+></DD
+><DT
+><SPAN
+CLASS="ERRORCODE"
+>EINTR</SPAN
+></DT
+><DD
+><P
+>The call was interrupted by a signal before any
+data was written.</P
+></DD
+><DT
+><SPAN
+CLASS="ERRORCODE"
+>EIO</SPAN
+></DT
+><DD
+><P
+>I/O error. This indicates some hardware problem.</P
+></DD
+><DT
+><SPAN
+CLASS="ERRORCODE"
+>EINVAL</SPAN
+></DT
+><DD
+><P
+>The <CODE
+CLASS="FUNCTION"
+>write()</CODE
+> function is not
+supported by this driver, not on this device, or generally not on this
+type of device.</P
+></DD
+></DL
+></DIV
+></DIV
+></DIV
+><DIV
+CLASS="CHAPTER"
+><HR><H1
+><A
+NAME="DRIVER"
+></A
+>Chapter 5. Driver Interface</H1
+><DIV
+CLASS="SECTION"
+><H2
+CLASS="SECTION"
+><A
+NAME="FOO"
+>5.1. to do</A
+></H2
+><DIV
+CLASS="SECTION"
+><H3
+CLASS="SECTION"
+><A
+NAME="AEN9774"
+>5.1.1. to do</A
+></H3
+><P
+>to do</P
+></DIV
+></DIV
+></DIV
+><DIV
+CLASS="CHAPTER"
+><HR><H1
+><A
+NAME="COMPAT"
+></A
+>Chapter 6. History</H1
+><P
+>The following chapters document the evolution of the V4L2 API,
+errata or extensions. They shall also aid application and driver
+writers porting their software to later versions of V4L2.</P
+><DIV
+CLASS="SECTION"
+><HR><H2
+CLASS="SECTION"
+><A
+NAME="DIFF-V4L"
+>6.1. Differences between V4L and V4L2</A
+></H2
+><P
+>The Video For Linux API was first introduced in Linux 2.1 to
+unify and replace various TV and radio device related interfaces,
+developped independently by driver writers in prior years. Starting
+with Linux 2.5 the much improved V4L2 API replaces the V4L API,
+although existing drivers will continue to support V4L in the future,
+either directly or through the V4L2 compatibility layer. For a
+transition period not all drivers will support the V4L2 API.</P
+><DIV
+CLASS="SECTION"
+><HR><H3
+CLASS="SECTION"
+><A
+NAME="AEN9783"
+>6.1.1. Opening and Closing Devices</A
+></H3
+><P
+>For compatibility reasons the character device file names
+recommended for V4L2 video capture, overlay, radio, teletext and raw
+vbi capture devices did not change from those used by V4L. They are
+listed in <A
+HREF="#DEVICES"
+>Chapter 4</A
+> and below in <A
+HREF="#V4L-DEV"
+>Table 6-1</A
+>.</P
+><P
+>The V4L "videodev" module automatically assigns minor
+numbers to drivers in load order, depending on the registered device
+type. We recommend V4L2 drivers by default register devices with the
+same numbers, but in principle the system administrator can assign
+arbitrary minor numbers using driver module options. The major device
+number remains 81.</P
+><DIV
+CLASS="TABLE"
+><A
+NAME="V4L-DEV"
+></A
+><P
+><B
+>Table 6-1. V4L Device Types, Names and Numbers</B
+></P
+><TABLE
+BORDER="1"
+CLASS="CALSTABLE"
+><COL><COL><COL><THEAD
+><TR
+><TH
+>Device Type</TH
+><TH
+>File Name</TH
+><TH
+>Minor Numbers</TH
+></TR
+></THEAD
+><TBODY
+><TR
+><TD
+>Video capture and overlay</TD
+><TD
+><P
+><TT
+CLASS="FILENAME"
+>/dev/video</TT
+> and
+<TT
+CLASS="FILENAME"
+>/dev/bttv0</TT
+><SUP
+>a</SUP
+>, <TT
+CLASS="FILENAME"
+>/dev/video0</TT
+> to
+<TT
+CLASS="FILENAME"
+>/dev/video63</TT
+></P
+></TD
+><TD
+>0-63</TD
+></TR
+><TR
+><TD
+>Radio receiver</TD
+><TD
+><P
+><TT
+CLASS="FILENAME"
+>/dev/radio</TT
+><SUP
+>b</SUP
+>, <TT
+CLASS="FILENAME"
+>/dev/radio0</TT
+> to
+<TT
+CLASS="FILENAME"
+>/dev/radio63</TT
+></P
+></TD
+><TD
+>64-127</TD
+></TR
+><TR
+><TD
+>Teletext decoder</TD
+><TD
+><P
+><TT
+CLASS="FILENAME"
+>/dev/vtx</TT
+>,
+<TT
+CLASS="FILENAME"
+>/dev/vtx0</TT
+> to
+<TT
+CLASS="FILENAME"
+>/dev/vtx31</TT
+></P
+></TD
+><TD
+>192-223</TD
+></TR
+><TR
+><TD
+>Raw VBI capture</TD
+><TD
+><P
+><TT
+CLASS="FILENAME"
+>/dev/vbi</TT
+>,
+<TT
+CLASS="FILENAME"
+>/dev/vbi0</TT
+> to
+<TT
+CLASS="FILENAME"
+>/dev/vbi15</TT
+></P
+></TD
+><TD
+><P
+>224-239<SUP
+>c</SUP
+></P
+></TD
+></TR
+></TBODY
+><TR
+><TD
+COLSPAN="3"
+>Notes:<BR><A
+NAME="FTN.AEN9804"
+>a. </A
+>According to Documentation/devices.txt these
+should be symbolic links to <TT
+CLASS="FILENAME"
+>/dev/video0</TT
+>. Note the original bttv interface is not compatible with V4L or V4L2.<BR><A
+NAME="FTN.AEN9815"
+>b. </A
+>According to
+<TT
+CLASS="FILENAME"
+>Documentation/devices.txt</TT
+> a symbolic link to
+<TT
+CLASS="FILENAME"
+>/dev/radio0</TT
+>.<BR><A
+NAME="FTN.AEN9839"
+>c. </A
+>The range used to be 224-255. More device
+types may be added in the future, so you should expect more range
+splitting in the future.<BR></TD
+></TR
+></TABLE
+></DIV
+><P
+>V4L prohibits (or used to) multiple opens. V4L2 drivers
+<SPAN
+CLASS="emphasis"
+><I
+CLASS="EMPHASIS"
+>may</I
+></SPAN
+> support multiple opens, see <A
+HREF="#OPEN"
+>Section 1.1</A
+> for details and consequences.</P
+><P
+>V4L drivers respond to V4L2 ioctls with the <SPAN
+CLASS="ERRORCODE"
+>EINVAL</SPAN
+> error code. The
+V4L2 "videodev" module backward compatibility layer can translate V4L
+ioctl requests to their V4L2 counterpart, however a V4L2 driver
+usually needs more preparation to become fully V4L compatible. This is
+covered in more detail in <A
+HREF="#DRIVER"
+>Chapter 5</A
+>.</P
+></DIV
+><DIV
+CLASS="SECTION"
+><HR><H3
+CLASS="SECTION"
+><A
+NAME="AEN9847"
+>6.1.2. Querying Capabilities</A
+></H3
+><P
+>The V4L <CODE
+CLASS="CONSTANT"
+>VIDIOCGCAP</CODE
+> ioctl is
+ equivalent to V4L2's <A
+HREF="#VIDIOC-QUERYCAP"
+><CODE
+CLASS="CONSTANT"
+>VIDIOC_QUERYCAP</CODE
+></A
+>.</P
+><P
+>The <CODE
+CLASS="STRUCTFIELD"
+>name</CODE
+> field in struct
+<CODE
+CLASS="STRUCTNAME"
+>video_capability</CODE
+> became
+<CODE
+CLASS="STRUCTFIELD"
+>card</CODE
+> in struct&nbsp;<A
+HREF="#V4L2-CAPABILITY"
+>v4l2_capability</A
+>,
+<CODE
+CLASS="STRUCTFIELD"
+>type</CODE
+> was replaced by
+<CODE
+CLASS="STRUCTFIELD"
+>capabilities</CODE
+>. Note V4L2 does not
+distinguish between device types like this, better think of
+basic video input, video output and radio devices supporting a set
+of related functions like video capturing, video overlay and VBI
+capturing. See <A
+HREF="#OPEN"
+>Section 1.1</A
+> for an introduction.<DIV
+CLASS="INFORMALTABLE"
+><P
+></P
+><A
+NAME="AEN9861"
+></A
+><TABLE
+BORDER="1"
+CLASS="CALSTABLE"
+><COL><COL><COL><THEAD
+><TR
+><TH
+>struct <CODE
+CLASS="STRUCTNAME"
+>video_capability</CODE
+>
+<CODE
+CLASS="STRUCTFIELD"
+>type</CODE
+></TH
+><TH
+>struct&nbsp;<A
+HREF="#V4L2-CAPABILITY"
+>v4l2_capability</A
+>
+<CODE
+CLASS="STRUCTFIELD"
+>capabilities</CODE
+> flags</TH
+><TH
+>Purpose</TH
+></TR
+></THEAD
+><TBODY
+><TR
+><TD
+><CODE
+CLASS="CONSTANT"
+>VID_TYPE_CAPTURE</CODE
+></TD
+><TD
+><CODE
+CLASS="CONSTANT"
+>V4L2_CAP_VIDEO_CAPTURE</CODE
+></TD
+><TD
+>The <A
+HREF="#CAPTURE"
+>video
+capture</A
+> interface is supported.</TD
+></TR
+><TR
+><TD
+><CODE
+CLASS="CONSTANT"
+>VID_TYPE_TUNER</CODE
+></TD
+><TD
+><CODE
+CLASS="CONSTANT"
+>V4L2_CAP_TUNER</CODE
+></TD
+><TD
+>The device has a <A
+HREF="#TUNER"
+>tuner or
+modulator</A
+>.</TD
+></TR
+><TR
+><TD
+><CODE
+CLASS="CONSTANT"
+>VID_TYPE_TELETEXT</CODE
+></TD
+><TD
+><CODE
+CLASS="CONSTANT"
+>V4L2_CAP_VBI_CAPTURE</CODE
+></TD
+><TD
+>The <A
+HREF="#RAW-VBI"
+>raw VBI
+capture</A
+> interface is supported.</TD
+></TR
+><TR
+><TD
+><CODE
+CLASS="CONSTANT"
+>VID_TYPE_OVERLAY</CODE
+></TD
+><TD
+><CODE
+CLASS="CONSTANT"
+>V4L2_CAP_VIDEO_OVERLAY</CODE
+></TD
+><TD
+>The <A
+HREF="#OVERLAY"
+>video overlay</A
+>
+interface is supported.</TD
+></TR
+><TR
+><TD
+><CODE
+CLASS="CONSTANT"
+>VID_TYPE_CHROMAKEY</CODE
+></TD
+><TD
+><CODE
+CLASS="CONSTANT"
+>V4L2_FBUF_CAP_CHROMAKEY</CODE
+> in
+field <CODE
+CLASS="STRUCTFIELD"
+>capability</CODE
+> of
+struct&nbsp;<A
+HREF="#V4L2-FRAMEBUFFER"
+>v4l2_framebuffer</A
+></TD
+><TD
+>Whether chromakey overlay is supported. For
+more information on overlay see
+<A
+HREF="#OVERLAY"
+>Section 4.2</A
+>.</TD
+></TR
+><TR
+><TD
+><CODE
+CLASS="CONSTANT"
+>VID_TYPE_CLIPPING</CODE
+></TD
+><TD
+><CODE
+CLASS="CONSTANT"
+>V4L2_FBUF_CAP_LIST_CLIPPING</CODE
+>
+and <CODE
+CLASS="CONSTANT"
+>V4L2_FBUF_CAP_BITMAP_CLIPPING</CODE
+> in field
+<CODE
+CLASS="STRUCTFIELD"
+>capability</CODE
+> of struct&nbsp;<A
+HREF="#V4L2-FRAMEBUFFER"
+>v4l2_framebuffer</A
+></TD
+><TD
+>Whether clipping the overlaid image is
+supported, see <A
+HREF="#OVERLAY"
+>Section 4.2</A
+>.</TD
+></TR
+><TR
+><TD
+><CODE
+CLASS="CONSTANT"
+>VID_TYPE_FRAMERAM</CODE
+></TD
+><TD
+><CODE
+CLASS="CONSTANT"
+>V4L2_FBUF_CAP_EXTERNOVERLAY</CODE
+>
+<SPAN
+CLASS="emphasis"
+><I
+CLASS="EMPHASIS"
+>not set</I
+></SPAN
+> in field
+<CODE
+CLASS="STRUCTFIELD"
+>capability</CODE
+> of struct&nbsp;<A
+HREF="#V4L2-FRAMEBUFFER"
+>v4l2_framebuffer</A
+></TD
+><TD
+>Whether overlay overwrites frame buffer memory,
+see <A
+HREF="#OVERLAY"
+>Section 4.2</A
+>.</TD
+></TR
+><TR
+><TD
+><CODE
+CLASS="CONSTANT"
+>VID_TYPE_SCALES</CODE
+></TD
+><TD
+><CODE
+CLASS="CONSTANT"
+>-</CODE
+></TD
+><TD
+>This flag indicates if the hardware can scale
+images. The V4L2 API implies the scale factor by setting the cropping
+dimensions and image size with the <A
+HREF="#VIDIOC-G-CROP"
+><CODE
+CLASS="CONSTANT"
+>VIDIOC_S_CROP</CODE
+></A
+> and <A
+HREF="#VIDIOC-G-FMT"
+><CODE
+CLASS="CONSTANT"
+>VIDIOC_S_FMT</CODE
+></A
+>
+ioctl, respectively. The driver returns the closest sizes possible.
+For more information on cropping and scaling see <A
+HREF="#CROP"
+>Section 1.10</A
+>.</TD
+></TR
+><TR
+><TD
+><CODE
+CLASS="CONSTANT"
+>VID_TYPE_MONOCHROME</CODE
+></TD
+><TD
+><CODE
+CLASS="CONSTANT"
+>-</CODE
+></TD
+><TD
+>Applications can enumerate the supported image
+formats with the <A
+HREF="#VIDIOC-ENUM-FMT"
+><CODE
+CLASS="CONSTANT"
+>VIDIOC_ENUM_FMT</CODE
+></A
+> ioctl to determine if the device
+supports grey scale capturing only. For more information on image
+formats see <A
+HREF="#PIXFMT"
+>Chapter 2</A
+>.</TD
+></TR
+><TR
+><TD
+><CODE
+CLASS="CONSTANT"
+>VID_TYPE_SUBCAPTURE</CODE
+></TD
+><TD
+><CODE
+CLASS="CONSTANT"
+>-</CODE
+></TD
+><TD
+>Applications can call the <A
+HREF="#VIDIOC-G-CROP"
+><CODE
+CLASS="CONSTANT"
+>VIDIOC_G_CROP</CODE
+></A
+> ioctl
+to determine if the device supports capturing a subsection of the full
+picture ("cropping" in V4L2). If not, the ioctl returns the <SPAN
+CLASS="ERRORCODE"
+>EINVAL</SPAN
+> error code.
+For more information on cropping and scaling see <A
+HREF="#CROP"
+>Section 1.10</A
+>.</TD
+></TR
+></TBODY
+></TABLE
+><P
+></P
+></DIV
+></P
+><P
+>The <CODE
+CLASS="STRUCTFIELD"
+>audios</CODE
+> field was replaced
+by <CODE
+CLASS="STRUCTFIELD"
+>capabilities</CODE
+> flag
+<CODE
+CLASS="CONSTANT"
+>V4L2_CAP_AUDIO</CODE
+>, indicating
+<SPAN
+CLASS="emphasis"
+><I
+CLASS="EMPHASIS"
+>if</I
+></SPAN
+> the device has any audio inputs or outputs. To
+determine their number applications can enumerate audio inputs with
+the <A
+HREF="#VIDIOC-G-AUDIO"
+><CODE
+CLASS="CONSTANT"
+>VIDIOC_G_AUDIO</CODE
+></A
+> ioctl. The audio ioctls are described in <A
+HREF="#AUDIO"
+>Section 1.5</A
+>.</P
+><P
+>The <CODE
+CLASS="STRUCTFIELD"
+>maxwidth</CODE
+>,
+<CODE
+CLASS="STRUCTFIELD"
+>maxheight</CODE
+>,
+<CODE
+CLASS="STRUCTFIELD"
+>minwidth</CODE
+> and
+<CODE
+CLASS="STRUCTFIELD"
+>minheight</CODE
+> fields were removed. Calling the
+<A
+HREF="#VIDIOC-G-FMT"
+><CODE
+CLASS="CONSTANT"
+>VIDIOC_S_FMT</CODE
+></A
+> or <A
+HREF="#VIDIOC-G-FMT"
+><CODE
+CLASS="CONSTANT"
+>VIDIOC_TRY_FMT</CODE
+></A
+> ioctl with the desired dimensions
+returns the closest size possible, taking into account the current
+video standard, cropping and scaling.</P
+></DIV
+><DIV
+CLASS="SECTION"
+><HR><H3
+CLASS="SECTION"
+><A
+NAME="AEN9977"
+>6.1.3. Video Sources</A
+></H3
+><P
+>V4L provides the <CODE
+CLASS="CONSTANT"
+>VIDIOCGCHAN</CODE
+> and
+<CODE
+CLASS="CONSTANT"
+>VIDIOCSCHAN</CODE
+> ioctl using struct
+<CODE
+CLASS="STRUCTNAME"
+>video_channel</CODE
+> to enumerate
+the video inputs of a V4L device. The equivalent V4L2 ioctls
+are <A
+HREF="#VIDIOC-ENUMINPUT"
+><CODE
+CLASS="CONSTANT"
+>VIDIOC_ENUMINPUT</CODE
+></A
+>, <A
+HREF="#VIDIOC-G-INPUT"
+><CODE
+CLASS="CONSTANT"
+>VIDIOC_G_INPUT</CODE
+></A
+> and <A
+HREF="#VIDIOC-G-INPUT"
+><CODE
+CLASS="CONSTANT"
+>VIDIOC_S_INPUT</CODE
+></A
+>
+using struct&nbsp;<A
+HREF="#V4L2-INPUT"
+>v4l2_input</A
+> as discussed in <A
+HREF="#VIDEO"
+>Section 1.4</A
+>.</P
+><P
+>The <CODE
+CLASS="STRUCTFIELD"
+>channel</CODE
+> field counting
+inputs was renamed to <CODE
+CLASS="STRUCTFIELD"
+>index</CODE
+>, the video
+input types were renamed: <DIV
+CLASS="INFORMALTABLE"
+><P
+></P
+><A
+NAME="AEN9994"
+></A
+><TABLE
+BORDER="1"
+CLASS="CALSTABLE"
+><COL><COL><THEAD
+><TR
+><TH
+>struct <CODE
+CLASS="STRUCTNAME"
+>video_channel</CODE
+>
+<CODE
+CLASS="STRUCTFIELD"
+>type</CODE
+></TH
+><TH
+>struct&nbsp;<A
+HREF="#V4L2-INPUT"
+>v4l2_input</A
+>
+<CODE
+CLASS="STRUCTFIELD"
+>type</CODE
+></TH
+></TR
+></THEAD
+><TBODY
+><TR
+><TD
+><CODE
+CLASS="CONSTANT"
+>VIDEO_TYPE_TV</CODE
+></TD
+><TD
+><CODE
+CLASS="CONSTANT"
+>V4L2_INPUT_TYPE_TUNER</CODE
+></TD
+></TR
+><TR
+><TD
+><CODE
+CLASS="CONSTANT"
+>VIDEO_TYPE_CAMERA</CODE
+></TD
+><TD
+><CODE
+CLASS="CONSTANT"
+>V4L2_INPUT_TYPE_CAMERA</CODE
+></TD
+></TR
+></TBODY
+></TABLE
+><P
+></P
+></DIV
+></P
+><P
+>Unlike the <CODE
+CLASS="STRUCTFIELD"
+>tuners</CODE
+> field
+expressing the number of tuners of this input, V4L2 assumes each
+video input is associated with at most one tuner. On the contrary a
+tuner can have more than one input, i.e. RF connectors, and a device
+can have multiple tuners. The index of the tuner associated with the
+input, if any, is stored in field <CODE
+CLASS="STRUCTFIELD"
+>tuner</CODE
+> of
+struct <CODE
+CLASS="STRUCTNAME"
+>v4l2_input</CODE
+>. Enumeration of tuners is
+discussed in <A
+HREF="#TUNER"
+>Section 1.6</A
+>.</P
+><P
+>The redundant <CODE
+CLASS="CONSTANT"
+>VIDEO_VC_TUNER</CODE
+> flag was
+dropped. Video inputs associated with a tuner are of type
+<CODE
+CLASS="CONSTANT"
+>V4L2_INPUT_TYPE_TUNER</CODE
+>. The
+<CODE
+CLASS="CONSTANT"
+>VIDEO_VC_AUDIO</CODE
+> flag was replaced by the
+<CODE
+CLASS="STRUCTFIELD"
+>audioset</CODE
+> field. V4L2 considers devices with
+up to 32 audio inputs. Each set bit in the
+<CODE
+CLASS="STRUCTFIELD"
+>audioset</CODE
+> field represents one audio input
+this video input combines with. For information about audio inputs and
+how to switch see <A
+HREF="#AUDIO"
+>Section 1.5</A
+>.</P
+><P
+>The <CODE
+CLASS="STRUCTFIELD"
+>norm</CODE
+> field describing the
+supported video standards was replaced by
+<CODE
+CLASS="STRUCTFIELD"
+>std</CODE
+>. The V4L specification mentions a flag
+<CODE
+CLASS="CONSTANT"
+>VIDEO_VC_NORM</CODE
+> indicating whether the standard can
+be changed. This flag was a later addition together with the
+<CODE
+CLASS="STRUCTFIELD"
+>norm</CODE
+> field and has been removed in the
+meantime. V4L2 has a similar, albeit more comprehensive approach
+to video standards, see <A
+HREF="#STANDARD"
+>Section 1.7</A
+> for more
+information.</P
+></DIV
+><DIV
+CLASS="SECTION"
+><HR><H3
+CLASS="SECTION"
+><A
+NAME="AEN10033"
+>6.1.4. Tuning</A
+></H3
+><P
+>The V4L <CODE
+CLASS="CONSTANT"
+>VIDIOCGTUNER</CODE
+> and
+<CODE
+CLASS="CONSTANT"
+>VIDIOCSTUNER</CODE
+> ioctl and struct
+<CODE
+CLASS="STRUCTNAME"
+>video_tuner</CODE
+> can be used to enumerate the
+tuners of a V4L TV or radio device. The equivalent V4L2 ioctls are
+<A
+HREF="#VIDIOC-G-TUNER"
+><CODE
+CLASS="CONSTANT"
+>VIDIOC_G_TUNER</CODE
+></A
+> and <A
+HREF="#VIDIOC-G-TUNER"
+><CODE
+CLASS="CONSTANT"
+>VIDIOC_S_TUNER</CODE
+></A
+> using struct&nbsp;<A
+HREF="#V4L2-TUNER"
+>v4l2_tuner</A
+>. Tuners are
+covered in <A
+HREF="#TUNER"
+>Section 1.6</A
+>.</P
+><P
+>The <CODE
+CLASS="STRUCTFIELD"
+>tuner</CODE
+> field counting tuners
+was renamed to <CODE
+CLASS="STRUCTFIELD"
+>index</CODE
+>. The fields
+<CODE
+CLASS="STRUCTFIELD"
+>name</CODE
+>, <CODE
+CLASS="STRUCTFIELD"
+>rangelow</CODE
+>
+and <CODE
+CLASS="STRUCTFIELD"
+>rangehigh</CODE
+> remained unchanged.</P
+><P
+>The <CODE
+CLASS="CONSTANT"
+>VIDEO_TUNER_PAL</CODE
+>,
+<CODE
+CLASS="CONSTANT"
+>VIDEO_TUNER_NTSC</CODE
+> and
+<CODE
+CLASS="CONSTANT"
+>VIDEO_TUNER_SECAM</CODE
+> flags indicating the supported
+video standards were dropped. This information is now contained in the
+associated struct&nbsp;<A
+HREF="#V4L2-INPUT"
+>v4l2_input</A
+>. No replacement exists for the
+<CODE
+CLASS="CONSTANT"
+>VIDEO_TUNER_NORM</CODE
+> flag indicating whether the
+video standard can be switched. The <CODE
+CLASS="STRUCTFIELD"
+>mode</CODE
+>
+field to select a different video standard was replaced by a whole new
+set of ioctls and structures described in <A
+HREF="#STANDARD"
+>Section 1.7</A
+>.
+Due to its ubiquity it should be mentioned the BTTV driver supports
+several standards in addition to the regular
+<CODE
+CLASS="CONSTANT"
+>VIDEO_MODE_PAL</CODE
+> (0),
+<CODE
+CLASS="CONSTANT"
+>VIDEO_MODE_NTSC</CODE
+>,
+<CODE
+CLASS="CONSTANT"
+>VIDEO_MODE_SECAM</CODE
+> and
+<CODE
+CLASS="CONSTANT"
+>VIDEO_MODE_AUTO</CODE
+> (3). Namely N/PAL Argentina,
+M/PAL, N/PAL, and NTSC Japan with numbers 3-6 (sic).</P
+><P
+>The <CODE
+CLASS="CONSTANT"
+>VIDEO_TUNER_STEREO_ON</CODE
+> flag
+indicating stereo reception became
+<CODE
+CLASS="CONSTANT"
+>V4L2_TUNER_SUB_STEREO</CODE
+> in field
+<CODE
+CLASS="STRUCTFIELD"
+>rxsubchans</CODE
+>. This field also permits the
+detection of monaural and bilingual audio, see the definition of
+struct&nbsp;<A
+HREF="#V4L2-TUNER"
+>v4l2_tuner</A
+> for details. Presently no replacement exists for the
+<CODE
+CLASS="CONSTANT"
+>VIDEO_TUNER_RDS_ON</CODE
+> and
+<CODE
+CLASS="CONSTANT"
+>VIDEO_TUNER_MBS_ON</CODE
+> flags.</P
+><P
+> The <CODE
+CLASS="CONSTANT"
+>VIDEO_TUNER_LOW</CODE
+> flag was renamed
+to <CODE
+CLASS="CONSTANT"
+>V4L2_TUNER_CAP_LOW</CODE
+> in the struct&nbsp;<A
+HREF="#V4L2-TUNER"
+>v4l2_tuner</A
+>
+<CODE
+CLASS="STRUCTFIELD"
+>capability</CODE
+> field.</P
+><P
+>The <CODE
+CLASS="CONSTANT"
+>VIDIOCGFREQ</CODE
+> and
+<CODE
+CLASS="CONSTANT"
+>VIDIOCSFREQ</CODE
+> ioctl to change the tuner frequency
+where renamed to <A
+HREF="#VIDIOC-G-FREQUENCY"
+><CODE
+CLASS="CONSTANT"
+>VIDIOC_G_FREQUENCY</CODE
+></A
+> and <A
+HREF="#VIDIOC-G-FREQUENCY"
+><CODE
+CLASS="CONSTANT"
+>VIDIOC_S_FREQUENCY</CODE
+></A
+>. They
+take a pointer to a struct&nbsp;<A
+HREF="#V4L2-FREQUENCY"
+>v4l2_frequency</A
+> instead of an unsigned long
+integer.</P
+></DIV
+><DIV
+CLASS="SECTION"
+><HR><H3
+CLASS="SECTION"
+><A
+NAME="V4L-IMAGE-PROPERTIES"
+>6.1.5. Image Properties</A
+></H3
+><P
+>V4L2 has no equivalent of the
+<CODE
+CLASS="CONSTANT"
+>VIDIOCGPICT</CODE
+> and <CODE
+CLASS="CONSTANT"
+>VIDIOCSPICT</CODE
+>
+ioctl and struct <CODE
+CLASS="STRUCTNAME"
+>video_picture</CODE
+>. The following
+fields where replaced by V4L2 controls accessible with the
+<A
+HREF="#VIDIOC-QUERYCTRL"
+><CODE
+CLASS="CONSTANT"
+>VIDIOC_QUERYCTRL</CODE
+></A
+>, <A
+HREF="#VIDIOC-G-CTRL"
+><CODE
+CLASS="CONSTANT"
+>VIDIOC_G_CTRL</CODE
+></A
+> and <A
+HREF="#VIDIOC-G-CTRL"
+><CODE
+CLASS="CONSTANT"
+>VIDIOC_S_CTRL</CODE
+></A
+> ioctls:<DIV
+CLASS="INFORMALTABLE"
+><P
+></P
+><A
+NAME="AEN10095"
+></A
+><TABLE
+BORDER="1"
+CLASS="CALSTABLE"
+><COL><COL><THEAD
+><TR
+><TH
+>struct <CODE
+CLASS="STRUCTNAME"
+>video_picture</CODE
+></TH
+><TH
+>V4L2 Control ID</TH
+></TR
+></THEAD
+><TBODY
+><TR
+><TD
+><CODE
+CLASS="STRUCTFIELD"
+>brightness</CODE
+></TD
+><TD
+><CODE
+CLASS="CONSTANT"
+>V4L2_CID_BRIGHTNESS</CODE
+></TD
+></TR
+><TR
+><TD
+><CODE
+CLASS="STRUCTFIELD"
+>hue</CODE
+></TD
+><TD
+><CODE
+CLASS="CONSTANT"
+>V4L2_CID_HUE</CODE
+></TD
+></TR
+><TR
+><TD
+><CODE
+CLASS="STRUCTFIELD"
+>colour</CODE
+></TD
+><TD
+><CODE
+CLASS="CONSTANT"
+>V4L2_CID_SATURATION</CODE
+></TD
+></TR
+><TR
+><TD
+><CODE
+CLASS="STRUCTFIELD"
+>contrast</CODE
+></TD
+><TD
+><CODE
+CLASS="CONSTANT"
+>V4L2_CID_CONTRAST</CODE
+></TD
+></TR
+><TR
+><TD
+><CODE
+CLASS="STRUCTFIELD"
+>whiteness</CODE
+></TD
+><TD
+><CODE
+CLASS="CONSTANT"
+>V4L2_CID_WHITENESS</CODE
+></TD
+></TR
+></TBODY
+></TABLE
+><P
+></P
+></DIV
+></P
+><P
+>The V4L picture controls are assumed to range from 0 to
+65535 with no particular reset value. The V4L2 API permits arbitrary
+limits and defaults which can be queried with the <A
+HREF="#VIDIOC-QUERYCTRL"
+><CODE
+CLASS="CONSTANT"
+>VIDIOC_QUERYCTRL</CODE
+></A
+>
+ioctl. For general information about controls see <A
+HREF="#CONTROL"
+>Section 1.8</A
+>.</P
+><P
+>The <CODE
+CLASS="STRUCTFIELD"
+>depth</CODE
+> (average number of
+bits per pixel) of a video image is implied by the selected image
+format. V4L2 does not explicitely provide such information assuming
+applications recognizing the format are aware of the image depth and
+others need not know. The <CODE
+CLASS="STRUCTFIELD"
+>palette</CODE
+> field
+moved into the struct&nbsp;<A
+HREF="#V4L2-PIX-FORMAT"
+>v4l2_pix_format</A
+>:<DIV
+CLASS="INFORMALTABLE"
+><P
+></P
+><A
+NAME="AEN10136"
+></A
+><TABLE
+BORDER="1"
+CLASS="CALSTABLE"
+><COL><COL><THEAD
+><TR
+><TH
+>struct <CODE
+CLASS="STRUCTNAME"
+>video_picture</CODE
+>
+<CODE
+CLASS="STRUCTFIELD"
+>palette</CODE
+></TH
+><TH
+>struct&nbsp;<A
+HREF="#V4L2-PIX-FORMAT"
+>v4l2_pix_format</A
+>
+<CODE
+CLASS="STRUCTFIELD"
+>pixfmt</CODE
+></TH
+></TR
+></THEAD
+><TBODY
+><TR
+><TD
+><CODE
+CLASS="CONSTANT"
+>VIDEO_PALETTE_GREY</CODE
+></TD
+><TD
+><P
+><A
+HREF="#PIXFMT-GREY"
+><CODE
+CLASS="CONSTANT"
+>V4L2_PIX_FMT_GREY</CODE
+></A
+></P
+></TD
+></TR
+><TR
+><TD
+><CODE
+CLASS="CONSTANT"
+>VIDEO_PALETTE_HI240</CODE
+></TD
+><TD
+><P
+><A
+HREF="#PIXFMT-RESERVED"
+><CODE
+CLASS="CONSTANT"
+>V4L2_PIX_FMT_HI240</CODE
+></A
+><SUP
+>a</SUP
+></P
+></TD
+></TR
+><TR
+><TD
+><CODE
+CLASS="CONSTANT"
+>VIDEO_PALETTE_RGB565</CODE
+></TD
+><TD
+><P
+><A
+HREF="#PIXFMT-RGB"
+><CODE
+CLASS="CONSTANT"
+>V4L2_PIX_FMT_RGB565</CODE
+></A
+></P
+></TD
+></TR
+><TR
+><TD
+><CODE
+CLASS="CONSTANT"
+>VIDEO_PALETTE_RGB555</CODE
+></TD
+><TD
+><P
+><A
+HREF="#PIXFMT-RGB"
+><CODE
+CLASS="CONSTANT"
+>V4L2_PIX_FMT_RGB555</CODE
+></A
+></P
+></TD
+></TR
+><TR
+><TD
+><CODE
+CLASS="CONSTANT"
+>VIDEO_PALETTE_RGB24</CODE
+></TD
+><TD
+><P
+><A
+HREF="#PIXFMT-RGB"
+><CODE
+CLASS="CONSTANT"
+>V4L2_PIX_FMT_BGR24</CODE
+></A
+></P
+></TD
+></TR
+><TR
+><TD
+><CODE
+CLASS="CONSTANT"
+>VIDEO_PALETTE_RGB32</CODE
+></TD
+><TD
+><P
+><A
+HREF="#PIXFMT-RGB"
+><CODE
+CLASS="CONSTANT"
+>V4L2_PIX_FMT_BGR32</CODE
+></A
+><SUP
+>b</SUP
+></P
+></TD
+></TR
+><TR
+><TD
+><CODE
+CLASS="CONSTANT"
+>VIDEO_PALETTE_YUV422</CODE
+></TD
+><TD
+><P
+><A
+HREF="#PIXFMT-YUYV"
+><CODE
+CLASS="CONSTANT"
+>V4L2_PIX_FMT_YUYV</CODE
+></A
+></P
+></TD
+></TR
+><TR
+><TD
+><P
+><CODE
+CLASS="CONSTANT"
+>VIDEO_PALETTE_YUYV</CODE
+><SUP
+>c</SUP
+></P
+></TD
+><TD
+><P
+><A
+HREF="#PIXFMT-YUYV"
+><CODE
+CLASS="CONSTANT"
+>V4L2_PIX_FMT_YUYV</CODE
+></A
+></P
+></TD
+></TR
+><TR
+><TD
+><CODE
+CLASS="CONSTANT"
+>VIDEO_PALETTE_UYVY</CODE
+></TD
+><TD
+><P
+><A
+HREF="#PIXFMT-UYVY"
+><CODE
+CLASS="CONSTANT"
+>V4L2_PIX_FMT_UYVY</CODE
+></A
+></P
+></TD
+></TR
+><TR
+><TD
+><CODE
+CLASS="CONSTANT"
+>VIDEO_PALETTE_YUV420</CODE
+></TD
+><TD
+>None</TD
+></TR
+><TR
+><TD
+><CODE
+CLASS="CONSTANT"
+>VIDEO_PALETTE_YUV411</CODE
+></TD
+><TD
+><P
+><A
+HREF="#PIXFMT-Y41P"
+><CODE
+CLASS="CONSTANT"
+>V4L2_PIX_FMT_Y41P</CODE
+></A
+><SUP
+>d</SUP
+></P
+></TD
+></TR
+><TR
+><TD
+><CODE
+CLASS="CONSTANT"
+>VIDEO_PALETTE_RAW</CODE
+></TD
+><TD
+><P
+>None<SUP
+>e</SUP
+></P
+></TD
+></TR
+><TR
+><TD
+><CODE
+CLASS="CONSTANT"
+>VIDEO_PALETTE_YUV422P</CODE
+></TD
+><TD
+><P
+><A
+HREF="#PIXFMT-YUV422P"
+><CODE
+CLASS="CONSTANT"
+>V4L2_PIX_FMT_YUV422P</CODE
+></A
+></P
+></TD
+></TR
+><TR
+><TD
+><CODE
+CLASS="CONSTANT"
+>VIDEO_PALETTE_YUV411P</CODE
+></TD
+><TD
+><P
+><A
+HREF="#PIXFMT-YUV411P"
+><CODE
+CLASS="CONSTANT"
+>V4L2_PIX_FMT_YUV411P</CODE
+></A
+><SUP
+>f</SUP
+></P
+></TD
+></TR
+><TR
+><TD
+><CODE
+CLASS="CONSTANT"
+>VIDEO_PALETTE_YUV420P</CODE
+></TD
+><TD
+><P
+><A
+HREF="#PIXFMT-YVU420"
+><CODE
+CLASS="CONSTANT"
+>V4L2_PIX_FMT_YVU420</CODE
+></A
+></P
+></TD
+></TR
+><TR
+><TD
+><CODE
+CLASS="CONSTANT"
+>VIDEO_PALETTE_YUV410P</CODE
+></TD
+><TD
+><P
+><A
+HREF="#PIXFMT-YVU410"
+><CODE
+CLASS="CONSTANT"
+>V4L2_PIX_FMT_YVU410</CODE
+></A
+></P
+></TD
+></TR
+></TBODY
+><TR
+><TD
+COLSPAN="2"
+>Notes:<BR><A
+NAME="FTN.AEN10161"
+>a. </A
+>This is a custom format used by the BTTV
+driver, not one of the V4L2 standard formats.<BR><A
+NAME="FTN.AEN10191"
+>b. </A
+>Presumably all V4L RGB formats are
+little-endian, although some drivers might interpret them according to machine endianess. V4L2 defines little-endian, big-endian and red/blue
+swapped variants. For details see <A
+HREF="#PIXFMT-RGB"
+>Section 2.3</A
+>.<BR><A
+NAME="FTN.AEN10205"
+>c. </A
+><CODE
+CLASS="CONSTANT"
+>VIDEO_PALETTE_YUV422</CODE
+>
+and <CODE
+CLASS="CONSTANT"
+>VIDEO_PALETTE_YUYV</CODE
+> are the same formats. Some
+V4L drivers respond to one, some to the other.<BR><A
+NAME="FTN.AEN10231"
+>d. </A
+>Not to be confused with
+<CODE
+CLASS="CONSTANT"
+>V4L2_PIX_FMT_YUV411P</CODE
+>, which is a planar
+format.<BR><A
+NAME="FTN.AEN10239"
+>e. </A
+>V4L explains this
+as: "RAW capture (BT848)"<BR><A
+NAME="FTN.AEN10255"
+>f. </A
+>Not to be confused with
+<CODE
+CLASS="CONSTANT"
+>V4L2_PIX_FMT_Y41P</CODE
+>, which is a packed
+format.<BR></TD
+></TR
+></TABLE
+><P
+></P
+></DIV
+></P
+><P
+>V4L2 image formats are defined in <A
+HREF="#PIXFMT"
+>Chapter 2</A
+>. The image format can be selected with the
+<A
+HREF="#VIDIOC-G-FMT"
+><CODE
+CLASS="CONSTANT"
+>VIDIOC_S_FMT</CODE
+></A
+> ioctl.</P
+></DIV
+><DIV
+CLASS="SECTION"
+><HR><H3
+CLASS="SECTION"
+><A
+NAME="AEN10276"
+>6.1.6. Audio</A
+></H3
+><P
+>The <CODE
+CLASS="CONSTANT"
+>VIDIOCGAUDIO</CODE
+> and
+<CODE
+CLASS="CONSTANT"
+>VIDIOCSAUDIO</CODE
+> ioctl and struct
+<CODE
+CLASS="STRUCTNAME"
+>video_audio</CODE
+> are used to enumerate the
+audio inputs of a V4L device. The equivalent V4L2 ioctls are
+<A
+HREF="#VIDIOC-G-AUDIO"
+><CODE
+CLASS="CONSTANT"
+>VIDIOC_G_AUDIO</CODE
+></A
+> and <A
+HREF="#VIDIOC-G-AUDIO"
+><CODE
+CLASS="CONSTANT"
+>VIDIOC_S_AUDIO</CODE
+></A
+> using struct&nbsp;<A
+HREF="#V4L2-AUDIO"
+>v4l2_audio</A
+> as
+discussed in <A
+HREF="#AUDIO"
+>Section 1.5</A
+>.</P
+><P
+>The <CODE
+CLASS="STRUCTFIELD"
+>audio</CODE
+> "channel number"
+field counting audio inputs was renamed to
+<CODE
+CLASS="STRUCTFIELD"
+>index</CODE
+>.</P
+><P
+>On <CODE
+CLASS="CONSTANT"
+>VIDIOCSAUDIO</CODE
+> the
+<CODE
+CLASS="STRUCTFIELD"
+>mode</CODE
+> field selects <SPAN
+CLASS="emphasis"
+><I
+CLASS="EMPHASIS"
+>one</I
+></SPAN
+>
+of the <CODE
+CLASS="CONSTANT"
+>VIDEO_SOUND_MONO</CODE
+>,
+<CODE
+CLASS="CONSTANT"
+>VIDEO_SOUND_STEREO</CODE
+>,
+<CODE
+CLASS="CONSTANT"
+>VIDEO_SOUND_LANG1</CODE
+> or
+<CODE
+CLASS="CONSTANT"
+>VIDEO_SOUND_LANG2</CODE
+> audio demodulation modes. When
+the current audio standard is BTSC
+<CODE
+CLASS="CONSTANT"
+>VIDEO_SOUND_LANG2</CODE
+> refers to SAP and
+<CODE
+CLASS="CONSTANT"
+>VIDEO_SOUND_LANG1</CODE
+> is meaningless. Also
+undocumented in the V4L specification, there is no way to query the
+selected mode. On <CODE
+CLASS="CONSTANT"
+>VIDIOCGAUDIO</CODE
+> the driver returns
+the <SPAN
+CLASS="emphasis"
+><I
+CLASS="EMPHASIS"
+>actually received</I
+></SPAN
+> audio programmes in this
+field. In the V4L2 API this information is stored in the struct&nbsp;<A
+HREF="#V4L2-TUNER"
+>v4l2_tuner</A
+>
+<CODE
+CLASS="STRUCTFIELD"
+>rxsubchans</CODE
+> and
+<CODE
+CLASS="STRUCTFIELD"
+>audmode</CODE
+> fields, respectively. See <A
+HREF="#TUNER"
+>Section 1.6</A
+> for more information on tuners. Related to audio
+modes struct&nbsp;<A
+HREF="#V4L2-AUDIO"
+>v4l2_audio</A
+> also reports if this is a mono or stereo
+input, regardless if the source is a tuner.</P
+><P
+>The following fields where replaced by V4L2 controls
+accessible with the <A
+HREF="#VIDIOC-QUERYCTRL"
+><CODE
+CLASS="CONSTANT"
+>VIDIOC_QUERYCTRL</CODE
+></A
+>, <A
+HREF="#VIDIOC-G-CTRL"
+><CODE
+CLASS="CONSTANT"
+>VIDIOC_G_CTRL</CODE
+></A
+> and
+<A
+HREF="#VIDIOC-G-CTRL"
+><CODE
+CLASS="CONSTANT"
+>VIDIOC_S_CTRL</CODE
+></A
+> ioctls:<DIV
+CLASS="INFORMALTABLE"
+><P
+></P
+><A
+NAME="AEN10315"
+></A
+><TABLE
+BORDER="1"
+CLASS="CALSTABLE"
+><COL><COL><THEAD
+><TR
+><TH
+>struct
+<CODE
+CLASS="STRUCTNAME"
+>video_audio</CODE
+></TH
+><TH
+>V4L2 Control ID</TH
+></TR
+></THEAD
+><TBODY
+><TR
+><TD
+><CODE
+CLASS="STRUCTFIELD"
+>volume</CODE
+></TD
+><TD
+><CODE
+CLASS="CONSTANT"
+>V4L2_CID_AUDIO_VOLUME</CODE
+></TD
+></TR
+><TR
+><TD
+><CODE
+CLASS="STRUCTFIELD"
+>bass</CODE
+></TD
+><TD
+><CODE
+CLASS="CONSTANT"
+>V4L2_CID_AUDIO_BASS</CODE
+></TD
+></TR
+><TR
+><TD
+><CODE
+CLASS="STRUCTFIELD"
+>treble</CODE
+></TD
+><TD
+><CODE
+CLASS="CONSTANT"
+>V4L2_CID_AUDIO_TREBLE</CODE
+></TD
+></TR
+><TR
+><TD
+><CODE
+CLASS="STRUCTFIELD"
+>balance</CODE
+></TD
+><TD
+><CODE
+CLASS="CONSTANT"
+>V4L2_CID_AUDIO_BALANCE</CODE
+></TD
+></TR
+></TBODY
+></TABLE
+><P
+></P
+></DIV
+></P
+><P
+>To determine which of these controls are supported by a
+driver V4L provides the <CODE
+CLASS="STRUCTFIELD"
+>flags</CODE
+>
+<CODE
+CLASS="CONSTANT"
+>VIDEO_AUDIO_VOLUME</CODE
+>,
+<CODE
+CLASS="CONSTANT"
+>VIDEO_AUDIO_BASS</CODE
+>,
+<CODE
+CLASS="CONSTANT"
+>VIDEO_AUDIO_TREBLE</CODE
+> and
+<CODE
+CLASS="CONSTANT"
+>VIDEO_AUDIO_BALANCE</CODE
+>. In the V4L2 API the
+<A
+HREF="#VIDIOC-QUERYCTRL"
+><CODE
+CLASS="CONSTANT"
+>VIDIOC_QUERYCTRL</CODE
+></A
+> ioctl reports if the respective control is
+supported. Accordingly the <CODE
+CLASS="CONSTANT"
+>VIDEO_AUDIO_MUTABLE</CODE
+>
+and <CODE
+CLASS="CONSTANT"
+>VIDEO_AUDIO_MUTE</CODE
+> flags where replaced by the
+boolean <CODE
+CLASS="CONSTANT"
+>V4L2_CID_AUDIO_MUTE</CODE
+> control.</P
+><P
+>All V4L2 controls have a <CODE
+CLASS="STRUCTFIELD"
+>step</CODE
+>
+attribute replacing the struct <CODE
+CLASS="STRUCTNAME"
+>video_audio</CODE
+>
+<CODE
+CLASS="STRUCTFIELD"
+>step</CODE
+> field. The V4L audio controls are
+assumed to range from 0 to 65535 with no particular reset value. The
+V4L2 API permits arbitrary limits and defaults which can be queried
+with the <A
+HREF="#VIDIOC-QUERYCTRL"
+><CODE
+CLASS="CONSTANT"
+>VIDIOC_QUERYCTRL</CODE
+></A
+> ioctl. For general information about
+controls see <A
+HREF="#CONTROL"
+>Section 1.8</A
+>.</P
+></DIV
+><DIV
+CLASS="SECTION"
+><HR><H3
+CLASS="SECTION"
+><A
+NAME="AEN10361"
+>6.1.7. Frame Buffer Overlay</A
+></H3
+><P
+>The V4L2 ioctls equivalent to
+<CODE
+CLASS="CONSTANT"
+>VIDIOCGFBUF</CODE
+> and <CODE
+CLASS="CONSTANT"
+>VIDIOCSFBUF</CODE
+>
+are <A
+HREF="#VIDIOC-G-FBUF"
+><CODE
+CLASS="CONSTANT"
+>VIDIOC_G_FBUF</CODE
+></A
+> and <A
+HREF="#VIDIOC-G-FBUF"
+><CODE
+CLASS="CONSTANT"
+>VIDIOC_S_FBUF</CODE
+></A
+>. The
+<CODE
+CLASS="STRUCTFIELD"
+>base</CODE
+> field of struct
+<CODE
+CLASS="STRUCTNAME"
+>video_buffer</CODE
+> remained unchanged, except V4L2
+using a flag to indicate non-destructive overlay instead of a
+<CODE
+CLASS="CONSTANT"
+>NULL</CODE
+> pointer. All other fields moved into the
+struct&nbsp;<A
+HREF="#V4L2-PIX-FORMAT"
+>v4l2_pix_format</A
+> substructure <CODE
+CLASS="STRUCTFIELD"
+>fmt</CODE
+> of
+struct&nbsp;<A
+HREF="#V4L2-FRAMEBUFFER"
+>v4l2_framebuffer</A
+>. The <CODE
+CLASS="STRUCTFIELD"
+>depth</CODE
+> field was
+replaced by <CODE
+CLASS="STRUCTFIELD"
+>pixelformat</CODE
+>. A conversion table
+is available in the <A
+HREF="#PIXFMT-RGB"
+>Section 2.3</A
+>.</P
+><P
+>Instead of the special ioctls
+<CODE
+CLASS="CONSTANT"
+>VIDIOCGWIN</CODE
+> and <CODE
+CLASS="CONSTANT"
+>VIDIOCSWIN</CODE
+>
+V4L2 uses the general-purpose data format negotiation ioctls
+<A
+HREF="#VIDIOC-G-FMT"
+><CODE
+CLASS="CONSTANT"
+>VIDIOC_G_FMT</CODE
+></A
+> and <A
+HREF="#VIDIOC-G-FMT"
+><CODE
+CLASS="CONSTANT"
+>VIDIOC_S_FMT</CODE
+></A
+>. They take a pointer to a
+struct&nbsp;<A
+HREF="#V4L2-FORMAT"
+>v4l2_format</A
+> as argument, here the struct&nbsp;<A
+HREF="#V4L2-WINDOW"
+>v4l2_window</A
+> named
+<CODE
+CLASS="STRUCTFIELD"
+>win</CODE
+> of its <CODE
+CLASS="STRUCTFIELD"
+>fmt</CODE
+>
+union is used.</P
+><P
+>The <CODE
+CLASS="STRUCTFIELD"
+>x</CODE
+>,
+<CODE
+CLASS="STRUCTFIELD"
+>y</CODE
+>, <CODE
+CLASS="STRUCTFIELD"
+>width</CODE
+> and
+<CODE
+CLASS="STRUCTFIELD"
+>height</CODE
+> fields of struct
+<CODE
+CLASS="STRUCTNAME"
+>video_window</CODE
+> moved into struct&nbsp;<A
+HREF="#V4L2-RECT"
+>v4l2_rect</A
+>
+substructure <CODE
+CLASS="STRUCTFIELD"
+>w</CODE
+> of struct
+<CODE
+CLASS="STRUCTNAME"
+>v4l2_window</CODE
+>. The
+<CODE
+CLASS="STRUCTFIELD"
+>chromakey</CODE
+>,
+<CODE
+CLASS="STRUCTFIELD"
+>clips</CODE
+>, and
+<CODE
+CLASS="STRUCTFIELD"
+>clipcount</CODE
+> fields remained unchanged. Struct
+<CODE
+CLASS="STRUCTNAME"
+>video_clip</CODE
+> was renamed to struct&nbsp;<A
+HREF="#V4L2-CLIP"
+>v4l2_clip</A
+>, also
+containing a struct <CODE
+CLASS="STRUCTNAME"
+>v4l2_rect</CODE
+>, but the
+semantics are still the same.</P
+><P
+>The <CODE
+CLASS="CONSTANT"
+>VIDEO_WINDOW_INTERLACE</CODE
+> flag was
+dropped, instead applications must set the
+<CODE
+CLASS="STRUCTFIELD"
+>field</CODE
+> field to
+<CODE
+CLASS="CONSTANT"
+>V4L2_FIELD_ANY</CODE
+> or
+<CODE
+CLASS="CONSTANT"
+>V4L2_FIELD_INTERLACED</CODE
+>. The
+<CODE
+CLASS="CONSTANT"
+>VIDEO_WINDOW_CHROMAKEY</CODE
+> flag moved into
+struct&nbsp;<A
+HREF="#V4L2-FRAMEBUFFER"
+>v4l2_framebuffer</A
+>, renamed to
+<CODE
+CLASS="CONSTANT"
+>V4L2_FBUF_FLAG_CHROMAKEY</CODE
+>.</P
+><P
+>In V4L, storing a bitmap pointer in
+<CODE
+CLASS="STRUCTFIELD"
+>clips</CODE
+> and setting
+<CODE
+CLASS="STRUCTFIELD"
+>clipcount</CODE
+> to
+<CODE
+CLASS="CONSTANT"
+>VIDEO_CLIP_BITMAP</CODE
+> (-1) requests bitmap
+clipping, using a fixed size bitmap of 1024 &times; 625 bits. Struct
+<CODE
+CLASS="STRUCTNAME"
+>v4l2_window</CODE
+> has a separate
+<CODE
+CLASS="STRUCTFIELD"
+>bitmap</CODE
+> pointer field for this purpose and
+the bitmap size is determined by <CODE
+CLASS="STRUCTFIELD"
+>w.width</CODE
+> and
+<CODE
+CLASS="STRUCTFIELD"
+>w.height</CODE
+>.</P
+><P
+>The <CODE
+CLASS="CONSTANT"
+>VIDIOCCAPTURE</CODE
+> ioctl to enable or
+disable overlay was renamed to <A
+HREF="#VIDIOC-OVERLAY"
+><CODE
+CLASS="CONSTANT"
+>VIDIOC_OVERLAY</CODE
+></A
+>.</P
+></DIV
+><DIV
+CLASS="SECTION"
+><HR><H3
+CLASS="SECTION"
+><A
+NAME="AEN10425"
+>6.1.8. Cropping</A
+></H3
+><P
+>To capture only a subsection of the full picture V4L
+provides the <CODE
+CLASS="CONSTANT"
+>VIDIOCGCAPTURE</CODE
+> and
+<CODE
+CLASS="CONSTANT"
+>VIDIOCSCAPTURE</CODE
+> ioctl using struct
+<CODE
+CLASS="STRUCTNAME"
+>video_capture</CODE
+>. The equivalent V4L2 ioctls are
+<A
+HREF="#VIDIOC-G-CROP"
+><CODE
+CLASS="CONSTANT"
+>VIDIOC_G_CROP</CODE
+></A
+> and <A
+HREF="#VIDIOC-G-CROP"
+><CODE
+CLASS="CONSTANT"
+>VIDIOC_S_CROP</CODE
+></A
+> using struct&nbsp;<A
+HREF="#V4L2-CROP"
+>v4l2_crop</A
+>, and the related
+<A
+HREF="#VIDIOC-CROPCAP"
+><CODE
+CLASS="CONSTANT"
+>VIDIOC_CROPCAP</CODE
+></A
+> ioctl. This is a rather complex matter, see
+<A
+HREF="#CROP"
+>Section 1.10</A
+> for details.</P
+><P
+>The <CODE
+CLASS="STRUCTFIELD"
+>x</CODE
+>,
+<CODE
+CLASS="STRUCTFIELD"
+>y</CODE
+>, <CODE
+CLASS="STRUCTFIELD"
+>width</CODE
+> and
+<CODE
+CLASS="STRUCTFIELD"
+>height</CODE
+> fields moved into struct&nbsp;<A
+HREF="#V4L2-RECT"
+>v4l2_rect</A
+>
+substructure <CODE
+CLASS="STRUCTFIELD"
+>c</CODE
+> of struct
+<CODE
+CLASS="STRUCTNAME"
+>v4l2_crop</CODE
+>. The
+<CODE
+CLASS="STRUCTFIELD"
+>decimation</CODE
+> field was dropped. The scaling factor is
+implied by the size of the cropping rectangle and the size of the
+captured or overlaid image.</P
+><P
+>The <CODE
+CLASS="CONSTANT"
+>VIDEO_CAPTURE_ODD</CODE
+>
+and <CODE
+CLASS="CONSTANT"
+>VIDEO_CAPTURE_EVEN</CODE
+> flags to capture only the
+odd or even field, respectively, were replaced by
+<CODE
+CLASS="CONSTANT"
+>V4L2_FIELD_TOP</CODE
+> and
+<CODE
+CLASS="CONSTANT"
+>V4L2_FIELD_BOTTOM</CODE
+> in the field named
+<CODE
+CLASS="STRUCTFIELD"
+>field</CODE
+> of struct&nbsp;<A
+HREF="#V4L2-PIX-FORMAT"
+>v4l2_pix_format</A
+> and
+struct&nbsp;<A
+HREF="#V4L2-WINDOW"
+>v4l2_window</A
+>. These structures are used to determine the capture or
+overlay format with the <A
+HREF="#VIDIOC-G-FMT"
+><CODE
+CLASS="CONSTANT"
+>VIDIOC_S_FMT</CODE
+></A
+> ioctl.</P
+></DIV
+><DIV
+CLASS="SECTION"
+><HR><H3
+CLASS="SECTION"
+><A
+NAME="AEN10458"
+>6.1.9. Reading Images, Memory Mapping</A
+></H3
+><DIV
+CLASS="SECTION"
+><H4
+CLASS="SECTION"
+><A
+NAME="AEN10460"
+>6.1.9.1. Capturing using the read method</A
+></H4
+><P
+>There is no essential difference between reading images
+from a V4L or V4L2 device using the <A
+HREF="#FUNC-READ"
+><CODE
+CLASS="FUNCTION"
+>read()</CODE
+></A
+> function. Supporting
+this method is optional for V4L2 devices. Whether the function is
+available can be determined with the <A
+HREF="#VIDIOC-QUERYCAP"
+><CODE
+CLASS="CONSTANT"
+>VIDIOC_QUERYCAP</CODE
+></A
+> ioctl. All V4L2
+devices exchanging data with applications must support the
+<A
+HREF="#FUNC-SELECT"
+><CODE
+CLASS="FUNCTION"
+>select()</CODE
+></A
+> and <A
+HREF="#FUNC-POLL"
+><CODE
+CLASS="FUNCTION"
+>poll()</CODE
+></A
+> function.</P
+><P
+>To select an image format and size, V4L provides the
+<CODE
+CLASS="CONSTANT"
+>VIDIOCSPICT</CODE
+> and <CODE
+CLASS="CONSTANT"
+>VIDIOCSWIN</CODE
+>
+ioctls. V4L2 uses the general-purpose data format negotiation ioctls
+<A
+HREF="#VIDIOC-G-FMT"
+><CODE
+CLASS="CONSTANT"
+>VIDIOC_G_FMT</CODE
+></A
+> and <A
+HREF="#VIDIOC-G-FMT"
+><CODE
+CLASS="CONSTANT"
+>VIDIOC_S_FMT</CODE
+></A
+>. They take a pointer to a
+struct&nbsp;<A
+HREF="#V4L2-FORMAT"
+>v4l2_format</A
+> as argument, here the struct&nbsp;<A
+HREF="#V4L2-PIX-FORMAT"
+>v4l2_pix_format</A
+> named
+<CODE
+CLASS="STRUCTFIELD"
+>pix</CODE
+> of its <CODE
+CLASS="STRUCTFIELD"
+>fmt</CODE
+>
+union is used.</P
+><P
+>For more information about the V4L2 read interface see
+<A
+HREF="#RW"
+>Section 3.1</A
+>.</P
+></DIV
+><DIV
+CLASS="SECTION"
+><HR><H4
+CLASS="SECTION"
+><A
+NAME="AEN10484"
+>6.1.9.2. Capturing using memory mapping</A
+></H4
+><P
+>Applications can read from V4L devices by mapping
+buffers in device memory, or more often just buffers allocated in
+DMA-able system memory, into their address space. This avoids the data
+copy overhead of the read method. V4L2 supports memory mapping as
+well, with a few differences.</P
+><DIV
+CLASS="INFORMALTABLE"
+><P
+></P
+><A
+NAME="AEN10487"
+></A
+><TABLE
+BORDER="1"
+CLASS="CALSTABLE"
+><COL><COL><THEAD
+><TR
+><TH
+>V4L</TH
+><TH
+>V4L2</TH
+></TR
+></THEAD
+><TBODY
+><TR
+><TD
+>&nbsp;</TD
+><TD
+>The image format must be selected before
+buffers are allocated, with the <A
+HREF="#VIDIOC-G-FMT"
+><CODE
+CLASS="CONSTANT"
+>VIDIOC_S_FMT</CODE
+></A
+> ioctl. When no format
+is selected the driver may use the last, possibly by another
+application requested format.</TD
+></TR
+><TR
+><TD
+><P
+>Applications cannot change the number of
+buffers allocated. The number is built into the driver, unless it
+has a module option to change the number when the driver module is
+loaded.</P
+></TD
+><TD
+><P
+>The <A
+HREF="#VIDIOC-REQBUFS"
+><CODE
+CLASS="CONSTANT"
+>VIDIOC_REQBUFS</CODE
+></A
+> ioctl allocates the
+desired number of buffers, this is a required step in the initialization
+sequence.</P
+></TD
+></TR
+><TR
+><TD
+><P
+>Drivers map all buffers as one contiguous range
+ of memory. The <CODE
+CLASS="CONSTANT"
+>VIDIOCGMBUF</CODE
+> ioctl is
+ available to query the number of buffers, the offset of
+ each buffer from the start of the virtual file, and the
+overall amount of memory used, which can be used as arguments to the
+ <A
+HREF="#FUNC-MMAP"
+><CODE
+CLASS="FUNCTION"
+>mmap()</CODE
+></A
+> function.</P
+></TD
+><TD
+><P
+>Buffers are individually mapped. The offset and size of each buffer can be determined with the <A
+HREF="#VIDIOC-QUERYBUF"
+><CODE
+CLASS="CONSTANT"
+>VIDIOC_QUERYBUF</CODE
+></A
+> ioctl.</P
+></TD
+></TR
+><TR
+><TD
+><P
+>The <CODE
+CLASS="CONSTANT"
+>VIDIOCMCAPTURE</CODE
+>
+ioctl prepares a buffer for capturing. It also determines the image
+format for this buffer. The ioctl returns immediately, eventually with
+an <SPAN
+CLASS="ERRORCODE"
+>EAGAIN</SPAN
+> error code if no video signal had been detected. When the driver
+supports more than one buffer applications can call the ioctl multiple
+times and thus have multiple outstanding capture
+requests.</P
+><P
+>The <CODE
+CLASS="CONSTANT"
+>VIDIOCSYNC</CODE
+> ioctl
+suspends execution until a particular buffer has been
+filled.</P
+></TD
+><TD
+><P
+>Drivers maintain an incoming and outgoing
+queue. <A
+HREF="#VIDIOC-QBUF"
+><CODE
+CLASS="CONSTANT"
+>VIDIOC_QBUF</CODE
+></A
+> enqueues any empty buffer into the incoming
+queue. Filled buffers are dequeued from the outgoing queue with the
+<A
+HREF="#VIDIOC-QBUF"
+><CODE
+CLASS="CONSTANT"
+>VIDIOC_DQBUF</CODE
+></A
+> ioctl. To wait until filled buffers become available this
+function, <A
+HREF="#FUNC-SELECT"
+><CODE
+CLASS="FUNCTION"
+>select()</CODE
+></A
+> or <A
+HREF="#FUNC-POLL"
+><CODE
+CLASS="FUNCTION"
+>poll()</CODE
+></A
+> can be used. The
+<A
+HREF="#VIDIOC-STREAMON"
+><CODE
+CLASS="CONSTANT"
+>VIDIOC_STREAMON</CODE
+></A
+> ioctl must be called once after enqueuing one or
+more buffers to start capturing. Its counterpart
+<A
+HREF="#VIDIOC-STREAMON"
+><CODE
+CLASS="CONSTANT"
+>VIDIOC_STREAMOFF</CODE
+></A
+> stops capturing and dequeues all buffers from both
+queues. Applications can query the signal status, if known, with the
+<A
+HREF="#VIDIOC-ENUMINPUT"
+><CODE
+CLASS="CONSTANT"
+>VIDIOC_ENUMINPUT</CODE
+></A
+> ioctl.</P
+></TD
+></TR
+></TBODY
+></TABLE
+><P
+></P
+></DIV
+><P
+>For a more in-depth discussion of memory mapping and
+examples, see <A
+HREF="#MMAP"
+>Section 3.2</A
+>.</P
+></DIV
+></DIV
+><DIV
+CLASS="SECTION"
+><HR><H3
+CLASS="SECTION"
+><A
+NAME="AEN10541"
+>6.1.10. Reading Raw VBI Data</A
+></H3
+><P
+>Originally the V4L API did not specify a raw VBI capture
+interface, merely the device file <TT
+CLASS="FILENAME"
+>/dev/vbi</TT
+> was
+reserved for this purpose. The only driver supporting this interface
+was the BTTV driver, de-facto defining the V4L VBI interface. Reading
+from the device yields a raw VBI image with the following
+parameters:<DIV
+CLASS="INFORMALTABLE"
+><P
+></P
+><A
+NAME="AEN10545"
+></A
+><TABLE
+BORDER="1"
+CLASS="CALSTABLE"
+><COL><COL><THEAD
+><TR
+><TH
+>struct&nbsp;<A
+HREF="#V4L2-VBI-FORMAT"
+>v4l2_vbi_format</A
+></TH
+><TH
+>V4L, BTTV driver</TH
+></TR
+></THEAD
+><TBODY
+><TR
+><TD
+>sampling_rate</TD
+><TD
+>28636363&nbsp;Hz NTSC (precisely all 525-line
+standards); 35468950&nbsp;Hz PAL and SECAM (625-line)</TD
+></TR
+><TR
+><TD
+>offset</TD
+><TD
+>?</TD
+></TR
+><TR
+><TD
+>samples_per_line</TD
+><TD
+>2048</TD
+></TR
+><TR
+><TD
+>sample_format</TD
+><TD
+>V4L2_PIX_FMT_GREY. The last four bytes
+(machine endianess integer) contain a frame counter.</TD
+></TR
+><TR
+><TD
+>start[]</TD
+><TD
+>10, 273 NTSC; 22, 335 PAL and SECAM</TD
+></TR
+><TR
+><TD
+>count[]</TD
+><TD
+><P
+>16, 16<SUP
+>a</SUP
+></P
+></TD
+></TR
+><TR
+><TD
+>flags</TD
+><TD
+>0</TD
+></TR
+></TBODY
+><TR
+><TD
+COLSPAN="2"
+>Notes:<BR><A
+NAME="FTN.AEN10572"
+>a. </A
+>Old driver
+versions used different values, eventually the custom
+<CODE
+CLASS="CONSTANT"
+>BTTV_VBISIZE</CODE
+> ioctl was added to query the
+correct values.<BR></TD
+></TR
+></TABLE
+><P
+></P
+></DIV
+></P
+><P
+>Undocumented in the V4L specification, in Linux 2.3 the
+<CODE
+CLASS="CONSTANT"
+>VIDIOCGVBIFMT</CODE
+> and
+<CODE
+CLASS="CONSTANT"
+>VIDIOCSVBIFMT</CODE
+> ioctls using struct
+<CODE
+CLASS="STRUCTNAME"
+>vbi_format</CODE
+> were added to determine the VBI
+image parameters. These ioctls are only partially compatible with the
+V4L2 VBI interface specified in <A
+HREF="#RAW-VBI"
+>Section 4.6</A
+>.</P
+><P
+>An <CODE
+CLASS="STRUCTFIELD"
+>offset</CODE
+> field does not
+exist, <CODE
+CLASS="STRUCTFIELD"
+>sample_format</CODE
+> is supposed to be
+<CODE
+CLASS="CONSTANT"
+>VIDEO_PALETTE_RAW</CODE
+>, here equivalent to
+<CODE
+CLASS="CONSTANT"
+>V4L2_PIX_FMT_GREY</CODE
+>. The remaining fields are
+probably equivalent to struct&nbsp;<A
+HREF="#V4L2-VBI-FORMAT"
+>v4l2_vbi_format</A
+>.</P
+><P
+>Apparently only the Zoran (ZR 36120) driver implements
+these ioctls. The semantics differ from those specified for V4L2 in two
+ways. The parameters are reset on <A
+HREF="#FUNC-OPEN"
+><CODE
+CLASS="FUNCTION"
+>open()</CODE
+></A
+> and
+<CODE
+CLASS="CONSTANT"
+>VIDIOCSVBIFMT</CODE
+> always returns the <SPAN
+CLASS="ERRORCODE"
+>EINVAL</SPAN
+> error code if the
+parameters are invalid.</P
+></DIV
+><DIV
+CLASS="SECTION"
+><HR><H3
+CLASS="SECTION"
+><A
+NAME="AEN10594"
+>6.1.11. Miscellaneous</A
+></H3
+><P
+>V4L2 has no equivalent of the
+<CODE
+CLASS="CONSTANT"
+>VIDIOCGUNIT</CODE
+> ioctl. Applications can find the VBI
+device associated with a video capture device (or vice versa) by
+reopening the device and requesting VBI data. For details see
+<A
+HREF="#OPEN"
+>Section 1.1</A
+>.</P
+><P
+>Presently no replacement exists for
+ <CODE
+CLASS="CONSTANT"
+>VIDIOCKEY</CODE
+>, the V4L functions
+regarding MPEG compression and decompression, and microcode
+programming. Drivers may implement the respective V4L ioctls for
+these purposes.</P
+></DIV
+></DIV
+><DIV
+CLASS="SECTION"
+><HR><H2
+CLASS="SECTION"
+><A
+NAME="HIST-V4L2"
+>6.2. History of the V4L2 API</A
+></H2
+><P
+>Soon after the V4L API was added to the kernel it was
+criticised as too inflexible. In August 1998 Bill Dirks proposed a
+number of improvements and began work on documentation, example
+drivers and applications. With the help of other volunteers this
+eventually became the V4L2 API, not just an extension but a
+replacement for the V4L API. However it took another four years and
+two stable kernel releases until the new API was finally accepted for
+inclusion into the kernel in its present form.</P
+><DIV
+CLASS="SECTION"
+><HR><H3
+CLASS="SECTION"
+><A
+NAME="AEN10604"
+>6.2.1. Early Versions</A
+></H3
+><P
+>1998-08-20: First version.</P
+><P
+>1998-08-27: select() function was introduced.</P
+><P
+>1998-09-10: New video standard interface.</P
+><P
+>1998-09-18: The VIDIOC_NONCAP ioctl was replaced by the O_TRUNC open()
+flag (with synonym O_NONCAP/O_NOIO) to indicate a non-capturing open. The
+VIDEO_STD_XXX identifiers are now ordinals rather than bits, and
+video_std_construct helper function takes id and transmission as
+arguments.</P
+><P
+>1998-09-28: Revamped video standard. Made video controls individually
+enumerable.</P
+><P
+>1998-10-02: Removed id from video_standard, renamed color subcarrier
+fields. Renamed VIDIOC_QUERYSTD to VIDIOC_ENUMSTD and VIDIOC_G_INPUT
+to VIDIOC_ENUMINPUT. Added preliminary /proc/videodev file. First
+draft of CODEC driver API spec.</P
+><P
+>1998-11-08: Updating for many minor changes to the V4L2 spec. Most
+symbols have been renamed. Some material changes to
+v4l2_capability.</P
+><P
+>1998-11-12 bugfix: some of the VIDIOC_* symbols were not constructed
+with the right macros, which could lead to errors on what should have
+been valid ioctl() calls.</P
+><P
+>1998-11-14: V4L2_PIX_FMT_RGB24 changed to V4L2_PIX_FMT_BGR24. Same for
+RGB32. Audio UI controls moved to VIDIOC_S_CTRL system and assigned
+V4L2_CID_AUDIO_* symbols. Removed V4L2_MAJOR from videodev.h since it
+is only used at one place in videodev. Added YUV422 and YUV411 planar
+formats.</P
+><P
+>1998-11-28: Changed a few ioctl symbols. Added stuff for codec and
+video output devices.</P
+><P
+>1999-01-14: Added raw VBI interface.</P
+><P
+>1999-01-19: Removed VIDIOC_NEXTBUF ioctl.</P
+></DIV
+><DIV
+CLASS="SECTION"
+><HR><H3
+CLASS="SECTION"
+><A
+NAME="AEN10618"
+>6.2.2. V4L2 Version 0.16 1999-01-31</A
+></H3
+><P
+>1999-01-27: There is now one QBUF ioctl, VIDIOC_QWBUF and VIDIOC_QRBUF
+are gone. VIDIOC_QBUF takes a v4l2_buffer as a parameter. Added
+digital zoom (cropping) controls.</P
+></DIV
+><DIV
+CLASS="SECTION"
+><HR><H3
+CLASS="SECTION"
+><A
+NAME="AEN10621"
+>6.2.3. V4L2 Version 0.18 1999-03-16</A
+></H3
+><P
+>Added a v4l to V4L2 ioctl compatibility layer to
+videodev.c. Driver writers, this changes how you implement your ioctl
+handler. See the Driver Writer's Guide. Added some more control id
+codes.</P
+></DIV
+><DIV
+CLASS="SECTION"
+><HR><H3
+CLASS="SECTION"
+><A
+NAME="AEN10624"
+>6.2.4. V4L2 Version 0.19 1999-06-05</A
+></H3
+><P
+>1999-03-18: Fill in the category and catname fields of
+v4l2_queryctrl objects before passing them to the driver. Required a
+minor change to the VIDIOC_QUERYCTRL handlers in the sample
+drivers.</P
+><P
+>1999-03-31: Better compatibility for v4l memory capture
+ioctls. Requires changes to drivers to fully support new compatibility
+features, see Driver Writer's Guide and v4l2cap.c. Added new control
+IDs: V4L2_CID_HFLIP, _VFLIP. Changed V4L2_PIX_FMT_YUV422P to _YUV422P,
+and _YUV411P to _YUV411P.</P
+><P
+>1999-04-04: Added a few more control IDs.</P
+><P
+>1999-04-07: Added the button control type.</P
+><P
+>1999-05-02: Fixed a typo in videodev.h, and added the
+V4L2_CTRL_FLAG_GRAYED (later V4L2_CTRL_FLAG_GRABBED) flag.</P
+><P
+>1999-05-20: Definition of VIDIOC_G_CTRL was wrong causing
+a malfunction of this ioctl.</P
+><P
+>1999-06-05: Changed the value of
+V4L2_CID_WHITENESS.</P
+></DIV
+><DIV
+CLASS="SECTION"
+><HR><H3
+CLASS="SECTION"
+><A
+NAME="AEN10633"
+>6.2.5. V4L2 Version 0.20 1999-09-10</A
+></H3
+><P
+>Version 0.20 introduced a number of changes not backward
+compatible with 0.19 and earlier. The purpose was to simplify the API,
+while at the same time make it more extensible, and follow common
+Linux driver API conventions.</P
+><P
+></P
+><OL
+TYPE="1"
+><LI
+><P
+>Fixed typos in some V4L2_FMT_FLAG symbols. Changed
+struct&nbsp;<A
+HREF="#V4L2-CLIP"
+>v4l2_clip</A
+> to be compatible with v4l. (1999-08-30)</P
+></LI
+><LI
+><P
+>Added V4L2_TUNER_SUB_LANG1. (1999-09-05)</P
+></LI
+><LI
+><P
+>All ioctl() commands that took an integer argument
+before, will now take a pointer to an integer. Where it makes sense,
+the driver will return the actual value used in the integer pointed to
+by the argument. This is a common convention, and also makes certain
+things easier in libv4l2 and other system code when the parameter to
+ioctl() is always a pointer. The ioctl commands affected are:
+VIDIOC_PREVIEW, VIDIOC_STREAMON, VIDIOC_STREAMOFF, VIDIOC_S_FREQ,
+VIDIOC_S_INPUT, VIDIOC_S_OUTPUT, VIDIOC_S_EFFECT. For example, where
+before you might have had code like: <PRE
+CLASS="PROGRAMLISTING"
+>err = ioctl (fd, VIDIOC_XXX, V4L2_XXX);</PRE
+> that becomes <PRE
+CLASS="PROGRAMLISTING"
+>int a = V4L2_XXX; err = ioctl(fd, VIDIOC_XXX, &amp;a);</PRE
+>
+ </P
+></LI
+><LI
+><P
+>All the different set-format ioctl() commands are
+swept into a single set-format command whose parameter consists of an
+integer value indicating the type of format, followed by the format
+data. The same for the get-format commands, of course. This will
+simplify the API by eliminating several ioctl codes and also make it
+possible to add additional kinds of data streams, or driver-private
+kinds of streams without having to add more set-format ioctls. The
+parameter to VIDIOC_S_FMT is as follows. The first field is a
+V4L2_BUF_TYPE_XXX value that indicates which stream the set-format is
+for, and implicitly, what type of format data. After that is a union
+of the different format structures. More can be added later without
+breaking backward compatibility. Nonstandard driver-private formats
+can be used by casting raw_data.</P
+><P
+><PRE
+CLASS="PROGRAMLISTING"
+>struct&nbsp;<A
+HREF="#V4L2-FORMAT"
+>v4l2_format</A
+> {
+ __u32 type;
+ union {
+ struct&nbsp;<A
+HREF="#V4L2-PIX-FORMAT"
+>v4l2_pix_format</A
+> pix;
+ struct&nbsp;<A
+HREF="#V4L2-VBI-FORMAT"
+>v4l2_vbi_format</A
+> vbi;
+ ... and so on ...
+ __u8 raw_data[200];
+ } fmt;
+};
+ </PRE
+></P
+><P
+>For a get-format, the application fills in the type
+field, and the driver fills in the rest. What was before the image
+format structure, struct&nbsp;<A
+HREF="#V4L2-FORMAT"
+>v4l2_format</A
+>, becomes struct&nbsp;<A
+HREF="#V4L2-PIX-FORMAT"
+>v4l2_pix_format</A
+>. These
+ioctls become obsolete: VIDIOC_S_INFMT, VIDIOC_G_INFMT,
+VIDIOC_S_OUTFMT, VIDIOC_G_OUTFMT, VIDIOC_S_VBIFMT
+VIDIOC_G_VBIFMT.</P
+></LI
+><LI
+><P
+>Similar to item 2, VIDIOC_G/S_PARM and
+VIDIOC_G/S_OUTPARM are merged, along with the corresponding 'get'
+functions. A type field will indicate which stream the parameters are
+for, set to a V4L2_BUF_TYPE_* value.</P
+><P
+><PRE
+CLASS="PROGRAMLISTING"
+>struct&nbsp;<A
+HREF="#V4L2-STREAMPARM"
+>v4l2_streamparm</A
+> {
+ __u32 type;
+ union {
+ struct&nbsp;<A
+HREF="#V4L2-CAPTUREPARM"
+>v4l2_captureparm</A
+> capture;
+ struct&nbsp;<A
+HREF="#V4L2-OUTPUTPARM"
+>v4l2_outputparm</A
+> output;
+ __u8 raw_data[200];
+ } parm;
+};
+ </PRE
+></P
+><P
+>These ioctls become obsolete: VIDIOC_G_OUTPARM,
+VIDIOC_S_OUTPARM.</P
+></LI
+><LI
+><P
+>The way controls are enumerated is simplified.
+Simultaneously, two new control flags are introduced and the existing
+flag is dropped. Also, the catname field is dropped in favor of a
+group name. To enumerate controls call VIDIOC_QUERYCTRL with
+successive id's starting from V4L2_CID_BASE or V4L2_CID_PRIVATE_BASE
+and stop when the driver returns the EINVAL error code. Controls that
+are not supported on the hardware are marked with the
+V4L2_CTRL_FLAG_DISABLED flag.</P
+><P
+>Additionally, controls that are temporarily
+unavailable, or that can only be controlled from another file
+descriptor are marked with the V4L2_CTRL_FLAG_GRABBED flag. Usually, a
+control that is GRABBED, but not DISABLED can be read, but changed.
+The group name indicates a possibly narrower classification than the
+category. In other words, there may be multiple groups within a
+category. Controls within a group would typically be drawn within a
+group box. Controls in different categories might have a greater
+separation, or even be in separate windows.</P
+></LI
+><LI
+><P
+>The v4l2_buffer timestamp field is changed to a 64-bit
+integer, and holds the time of the frame based on the system time, in
+1 nanosecond units. Additionally, timestamps will be in absolute
+system time, not starting from zero at the beginning of a stream as it
+is now. The data type name for timestamps is stamp_t, defined as a
+signed 64-bit integer. Output devices should not send a buffer out
+until the time in the timestamp field has arrived. I would like to
+follow SGI's lead, and adopt a multimedia timestamping system like
+their UST (Unadjusted System Time). See
+http://reality.sgi.com/cpirazzi_engr/lg/time/intro.html. [This link is
+no longer valid.] UST uses timestamps that are 64-bit signed integers
+(not struct timeval's) and given in nanosecond units. The UST clock
+starts at zero when the system is booted and runs continuously and
+uniformly. It takes a little over 292 years for UST to overflow. There
+is no way to set the UST clock. The regular Linux time-of-day clock
+can be changed periodically, which would cause errors if it were being
+used for timestamping a multimedia stream. A real UST style clock will
+require some support in the kernel that is not there yet. But in
+anticipation, I will change the timestamp field to a 64-bit integer,
+and I will change the v4l2_masterclock_gettime() function (used only
+by drivers) to return a 64-bit integer.</P
+></LI
+><LI
+><P
+>The sequence field is added to the struct&nbsp;<A
+HREF="#V4L2-BUFFER"
+>v4l2_buffer</A
+>. The
+sequence field indicates which frame this is in the sequence-- 0, 1,
+2, 3, 4, etc. Set by capturing devices. Ignored by output devices. If
+a capture driver drops a frame, the sequence number of that frame is
+skipped. A break in the sequence will indicate to the application
+which frame was dropped.</P
+></LI
+></OL
+></DIV
+><DIV
+CLASS="SECTION"
+><HR><H3
+CLASS="SECTION"
+><A
+NAME="AEN10672"
+>6.2.6. V4L2 Version 0.20 incremental changes</A
+></H3
+><P
+>1999-12-23: In struct&nbsp;<A
+HREF="#V4L2-VBI-FORMAT"
+>v4l2_vbi_format</A
+> field
+<CODE
+CLASS="STRUCTFIELD"
+>reserved1</CODE
+> became <CODE
+CLASS="STRUCTFIELD"
+>offset</CODE
+>.
+Previously <CODE
+CLASS="STRUCTFIELD"
+>reserved1</CODE
+> was required to always read
+zero.</P
+><P
+>2000-01-13: Added V4L2_FMT_FLAG_NOT_INTERLACED.</P
+><P
+>2000-07-31: Included linux/poll.h in videodev.h for compatibility with
+the original videodev.h.</P
+><P
+>2000-11-20: Added V4L2_TYPE_VBI_OUTPUT. Added V4L2_PIX_FMT_Y41P.</P
+><P
+>2000-11-25: Added V4L2_TYPE_VBI_INPUT.</P
+><P
+>2000-12-04: Fixed a couple typos in symbol names.</P
+><P
+>2001-01-18: Fixed a namespace conflict (the fourcc macro changed to
+v4l2_fourcc).</P
+><P
+>2001-01-25: Fixed a possible driver-level compatibility problem
+between the original 2.4.0 videodev.h and the videodev.h that comes
+with videodevX. If you were using an earlier version of videodevX on
+2.4.0, then you should recompile your v4l and V4L2 drivers to be
+safe.</P
+><P
+>2001-01-26: videodevX: Fixed a possible kernel-level incompatibility
+between the videodevX videodev.h and the 2.2.x videodev.h that had the
+devfs patches applied. videodev: Changed fourcc to v4l2_fourcc to
+avoid namespace pollution. Some other cleanup.</P
+><P
+>2001-03-02: Certain v4l ioctls that really pass data both ways, but
+whose types are read-only, did not work correctly through the backward
+compatibility layer. [Solution?]</P
+><P
+>2001-04-13: Added big endian 16-bit RGB formats.</P
+><P
+>2001-09-17: Added new YUV formats. Added VIDIOC_G_FREQUENCY and
+VIDIOC_S_FREQUENCY. (The VIDIOC_G/S_FREQ ioctls did not take multiple
+tuners into account.)</P
+><P
+>2000-09-18: Added V4L2_BUF_TYPE_VBI. Raw VBI VIDIOC_G_FMT and
+VIDIOC_S_FMT may fail if field <CODE
+CLASS="STRUCTFIELD"
+>type</CODE
+> is not
+V4L2_BUF_TYPE_VBI. Changed the ambiguous phrase "rising edge" to "leading
+edge" in the definition of struct&nbsp;<A
+HREF="#V4L2-VBI-FORMAT"
+>v4l2_vbi_format</A
+> field
+<CODE
+CLASS="STRUCTFIELD"
+>offset</CODE
+>.</P
+></DIV
+><DIV
+CLASS="SECTION"
+><HR><H3
+CLASS="SECTION"
+><A
+NAME="AEN10694"
+>6.2.7. V4L2 Version 0.20 2000-11-23</A
+></H3
+><P
+>A number of changes were made to the raw VBI
+interface.</P
+><P
+></P
+><OL
+TYPE="1"
+><LI
+><P
+>Added figures clarifying the line numbering scheme.
+The description of <CODE
+CLASS="STRUCTFIELD"
+>start</CODE
+>[0] and
+<CODE
+CLASS="STRUCTFIELD"
+>start</CODE
+>[1] as base 0 offset has been dropped.
+Rationale: a) The previous definition was unclear. b) The
+<CODE
+CLASS="STRUCTFIELD"
+>start</CODE
+>[] values are not an offset into anything,
+as a means of identifying scanning lines it can only be
+counterproductive to deviate from common numbering conventions.
+Compatibility: Add one to the start values. Applications depending on
+the previous semantics of start values may not function
+correctly.</P
+></LI
+><LI
+><P
+>The restriction "count[0] &#62; 0 and count[1] &#62; 0" has
+been relaxed to "(count[0] + count[1]) &#62; 0". Rationale: Drivers
+allocating resources at scanning line granularity and first field only
+data services. The comment that both 'count' values will usually be
+equal is misleading and pointless and has been removed. Compatibility:
+Drivers may return EINVAL, applications depending on the previous
+restriction may not function correctly.</P
+></LI
+><LI
+><P
+>Restored description of the driver option to return
+negative start values. Existed in the initial revision of this
+document, not traceable why it disappeared in later versions.
+Compatibility: Applications depending on the returned start values
+being positive may not function correctly. Clarification on the use of
+EBUSY and EINVAL in VIDIOC_S_FMT ioctl. Added EBUSY paragraph to
+section. Added description of reserved2, previously mentioned only in
+videodev.h.</P
+></LI
+><LI
+><P
+>Added V4L2_TYPE_VBI_INPUT and V4L2_TYPE_VBI_OUTPUT
+here and in videodev.h. The first is an alias for the older
+V4L2_TYPE_VBI, the latter was missing in videodev.h.</P
+></LI
+></OL
+></DIV
+><DIV
+CLASS="SECTION"
+><HR><H3
+CLASS="SECTION"
+><A
+NAME="AEN10709"
+>6.2.8. V4L2 Version 0.20 2002-07-25</A
+></H3
+><P
+>Added sliced VBI interface proposal.</P
+></DIV
+><DIV
+CLASS="SECTION"
+><HR><H3
+CLASS="SECTION"
+><A
+NAME="AEN10712"
+>6.2.9. V4L2 in Linux 2.5.46, 2002-10</A
+></H3
+><P
+>Around October-November 2002, prior to an announced
+feature freeze of Linux 2.5, the API was revised, drawing from
+experience with V4L2 0.20. This unnamed version was finally merged
+into Linux 2.5.46.</P
+><P
+></P
+><OL
+TYPE="1"
+><LI
+><P
+>As specified in <A
+HREF="#RELATED"
+>Section 1.1.2</A
+> drivers
+must make related device functions available under all minor device
+numbers.</P
+></LI
+><LI
+><P
+>The <A
+HREF="#FUNC-OPEN"
+><CODE
+CLASS="FUNCTION"
+>open()</CODE
+></A
+> function requires access mode
+<CODE
+CLASS="CONSTANT"
+>O_RDWR</CODE
+> regardless of device type. All V4L2
+drivers exchanging data with applications must support the
+<CODE
+CLASS="CONSTANT"
+>O_NONBLOCK</CODE
+> flag. The <CODE
+CLASS="CONSTANT"
+>O_NOIO</CODE
+>
+flag (alias of meaningless <CODE
+CLASS="CONSTANT"
+>O_TRUNC</CODE
+>) to indicate
+accesses without data exchange (panel applications) was
+dropped. Drivers must assume panel mode until the application attempts
+to initiate data exchange, see <A
+HREF="#OPEN"
+>Section 1.1</A
+>.</P
+></LI
+><LI
+><P
+>The struct&nbsp;<A
+HREF="#V4L2-CAPABILITY"
+>v4l2_capability</A
+> changed dramatically. Note that
+also the size of the structure changed, which is encoded in the ioctl
+request code, thus older V4L2 devices will respond with an <SPAN
+CLASS="ERRORCODE"
+>EINVAL</SPAN
+> error code to
+the new <A
+HREF="#VIDIOC-QUERYCAP"
+><CODE
+CLASS="CONSTANT"
+>VIDIOC_QUERYCAP</CODE
+></A
+> ioctl.</P
+><P
+>There are new fields to identify the driver, a new (as
+of yet unspecified) device function
+<CODE
+CLASS="CONSTANT"
+>V4L2_CAP_RDS_CAPTURE</CODE
+>, the
+<CODE
+CLASS="CONSTANT"
+>V4L2_CAP_AUDIO</CODE
+> flag indicates if the device has
+any audio connectors, another I/O capability
+<CODE
+CLASS="CONSTANT"
+>V4L2_CAP_ASYNCIO</CODE
+> can be flagged. Field
+<CODE
+CLASS="STRUCTFIELD"
+>type</CODE
+> became a set in response to the change
+above and was merged with <CODE
+CLASS="STRUCTFIELD"
+>flags</CODE
+>.
+<CODE
+CLASS="CONSTANT"
+>V4L2_FLAG_TUNER</CODE
+> was renamed to
+<CODE
+CLASS="CONSTANT"
+>V4L2_CAP_TUNER</CODE
+>,
+<CODE
+CLASS="CONSTANT"
+>V4L2_CAP_VIDEO_OVERLAY</CODE
+> replaced
+<CODE
+CLASS="CONSTANT"
+>V4L2_FLAG_PREVIEW</CODE
+> and
+<CODE
+CLASS="CONSTANT"
+>V4L2_CAP_VBI_CAPTURE</CODE
+> and
+<CODE
+CLASS="CONSTANT"
+>V4L2_CAP_VBI_OUTPUT</CODE
+> replaced
+<CODE
+CLASS="CONSTANT"
+>V4L2_FLAG_DATA_SERVICE</CODE
+>.
+<CODE
+CLASS="CONSTANT"
+>V4L2_FLAG_READ</CODE
+> and
+<CODE
+CLASS="CONSTANT"
+>V4L2_FLAG_WRITE</CODE
+> merged to
+<CODE
+CLASS="CONSTANT"
+>V4L2_CAP_READWRITE</CODE
+>.</P
+><P
+>Redundant fields
+<CODE
+CLASS="STRUCTFIELD"
+>inputs</CODE
+>, <CODE
+CLASS="STRUCTFIELD"
+>outputs</CODE
+>,
+<CODE
+CLASS="STRUCTFIELD"
+>audios</CODE
+> were removed, these can be
+determined as described in <A
+HREF="#VIDEO"
+>Section 1.4</A
+> and <A
+HREF="#AUDIO"
+>Section 1.5</A
+>.</P
+><P
+>The somewhat volatile and therefore
+barely useful fields <CODE
+CLASS="STRUCTFIELD"
+>maxwidth</CODE
+>,
+<CODE
+CLASS="STRUCTFIELD"
+>maxheight</CODE
+>,
+<CODE
+CLASS="STRUCTFIELD"
+>minwidth</CODE
+>,
+<CODE
+CLASS="STRUCTFIELD"
+>minheight</CODE
+>,
+<CODE
+CLASS="STRUCTFIELD"
+>maxframerate</CODE
+> were removed, this information
+is available as described in <A
+HREF="#FORMAT"
+>Section 1.9</A
+> and
+<A
+HREF="#STANDARD"
+>Section 1.7</A
+>.</P
+><P
+><CODE
+CLASS="CONSTANT"
+>V4L2_FLAG_SELECT</CODE
+>
+was removed, this function is considered important enough that all
+V4L2 drivers exchanging data with applications must support
+<CODE
+CLASS="FUNCTION"
+>select()</CODE
+>. The redundant flag
+<CODE
+CLASS="CONSTANT"
+>V4L2_FLAG_MONOCHROME</CODE
+> was removed, this
+information is available as described in <A
+HREF="#FORMAT"
+>Section 1.9</A
+>.</P
+></LI
+><LI
+><P
+>In struct&nbsp;<A
+HREF="#V4L2-INPUT"
+>v4l2_input</A
+> the
+ <CODE
+CLASS="STRUCTFIELD"
+>assoc_audio</CODE
+> field and the
+<CODE
+CLASS="STRUCTFIELD"
+>capability</CODE
+> field and its only
+ flag <CODE
+CLASS="CONSTANT"
+>V4L2_INPUT_CAP_AUDIO</CODE
+> was replaced
+ by the new <CODE
+CLASS="STRUCTFIELD"
+>audioset</CODE
+>
+ field. Instead of linking one video input to one audio input
+ this field reports all audio inputs this video input
+ combines with.</P
+><P
+>New fields are <CODE
+CLASS="STRUCTFIELD"
+>tuner</CODE
+>
+(reversing the former link from tuners to video inputs),
+<CODE
+CLASS="STRUCTFIELD"
+>std</CODE
+> and
+<CODE
+CLASS="STRUCTFIELD"
+>status</CODE
+>.</P
+><P
+>Accordingly struct&nbsp;<A
+HREF="#V4L2-OUTPUT"
+>v4l2_output</A
+> lost its
+ <CODE
+CLASS="STRUCTFIELD"
+>capability</CODE
+> and
+ <CODE
+CLASS="STRUCTFIELD"
+>assoc_audio</CODE
+> fields,
+ <CODE
+CLASS="STRUCTFIELD"
+>audioset</CODE
+>,
+ <CODE
+CLASS="STRUCTFIELD"
+>modulator</CODE
+> and
+ <CODE
+CLASS="STRUCTFIELD"
+>std</CODE
+> where added.</P
+></LI
+><LI
+><P
+>The struct&nbsp;<A
+HREF="#V4L2-AUDIO"
+>v4l2_audio</A
+> field
+<CODE
+CLASS="STRUCTFIELD"
+>audio</CODE
+> was renamed to
+<CODE
+CLASS="STRUCTFIELD"
+>index</CODE
+>, consistent with other structures.
+Capability flag <CODE
+CLASS="CONSTANT"
+>V4L2_AUDCAP_STEREO</CODE
+> was added to
+indicated if this is a stereo input.
+<CODE
+CLASS="CONSTANT"
+>V4L2_AUDCAP_EFFECTS</CODE
+> and the corresponding
+<CODE
+CLASS="CONSTANT"
+>V4L2_AUDMODE</CODE
+> flags where removed, this can be
+easily implemented using controls. (However the same applies to AVL
+which is still there.)</P
+><P
+>The struct&nbsp;<A
+HREF="#V4L2-AUDIOOUT"
+>v4l2_audioout</A
+> field
+<CODE
+CLASS="STRUCTFIELD"
+>audio</CODE
+> was renamed to
+<CODE
+CLASS="STRUCTFIELD"
+>index</CODE
+>.</P
+></LI
+><LI
+><P
+>The struct&nbsp;<A
+HREF="#V4L2-TUNER"
+>v4l2_tuner</A
+>
+<CODE
+CLASS="STRUCTFIELD"
+>input</CODE
+> field was replaced by an
+<CODE
+CLASS="STRUCTFIELD"
+>index</CODE
+> field, permitting devices with
+multiple tuners. The link between video inputs and tuners is now
+reversed, inputs point to the tuner they are on. The
+<CODE
+CLASS="STRUCTFIELD"
+>std</CODE
+> substructure became a
+simple set (more about this below) and moved into struct&nbsp;<A
+HREF="#V4L2-INPUT"
+>v4l2_input</A
+>. A
+<CODE
+CLASS="STRUCTFIELD"
+>type</CODE
+> field was added.</P
+><P
+>Accordingly in struct&nbsp;<A
+HREF="#V4L2-MODULATOR"
+>v4l2_modulator</A
+> the
+<CODE
+CLASS="STRUCTFIELD"
+>output</CODE
+> was replaced by an
+<CODE
+CLASS="STRUCTFIELD"
+>index</CODE
+> field.</P
+><P
+>In struct&nbsp;<A
+HREF="#V4L2-FREQUENCY"
+>v4l2_frequency</A
+> the
+<CODE
+CLASS="STRUCTFIELD"
+>port</CODE
+> field was replaced by a
+<CODE
+CLASS="STRUCTFIELD"
+>tuner</CODE
+> field containing the respective tuner
+or modulator index number. A tuner <CODE
+CLASS="STRUCTFIELD"
+>type</CODE
+>
+field was added and the <CODE
+CLASS="STRUCTFIELD"
+>reserved</CODE
+> field
+became larger for future extensions (satellite tuners in
+particular).</P
+></LI
+><LI
+><P
+>The idea of completely transparent video standards was
+dropped. Experience showed that applications must be able to work with
+video standards beyond presenting the user a menu. To this end V4L2
+returned to defined standards as <A
+HREF="#V4L2-STD-ID"
+>v4l2_std_id</A
+>, replacing references
+to standards throughout the API. For details see <A
+HREF="#STANDARD"
+>Section 1.7</A
+>. <A
+HREF="#VIDIOC-G-STD"
+><CODE
+CLASS="CONSTANT"
+>VIDIOC_G_STD</CODE
+></A
+> and <A
+HREF="#VIDIOC-G-STD"
+><CODE
+CLASS="CONSTANT"
+>VIDIOC_S_STD</CODE
+></A
+>
+now take a pointer to this type as argument. <A
+HREF="#VIDIOC-QUERYSTD"
+><CODE
+CLASS="CONSTANT"
+>VIDIOC_QUERYSTD</CODE
+></A
+> was
+added to autodetect the received standard. In struct&nbsp;<A
+HREF="#V4L2-STANDARD"
+>v4l2_standard</A
+> an
+<CODE
+CLASS="STRUCTFIELD"
+>index</CODE
+> field was added for <A
+HREF="#VIDIOC-ENUMSTD"
+><CODE
+CLASS="CONSTANT"
+>VIDIOC_ENUMSTD</CODE
+></A
+>.
+A <A
+HREF="#V4L2-STD-ID"
+>v4l2_std_id</A
+> field named <CODE
+CLASS="STRUCTFIELD"
+>id</CODE
+> was added as
+machine readable identifier, also replacing the
+<CODE
+CLASS="STRUCTFIELD"
+>transmission</CODE
+> field.
+<CODE
+CLASS="STRUCTFIELD"
+>framerate</CODE
+>, which is misleading, was renamed
+to <CODE
+CLASS="STRUCTFIELD"
+>frameperiod</CODE
+>. The now obsolete
+<CODE
+CLASS="STRUCTFIELD"
+>colorstandard</CODE
+> information, originally
+needed to distguish between variations of standards, were
+removed.</P
+><P
+>Struct <CODE
+CLASS="STRUCTNAME"
+>v4l2_enumstd</CODE
+> ceased to
+be. <A
+HREF="#VIDIOC-ENUMSTD"
+><CODE
+CLASS="CONSTANT"
+>VIDIOC_ENUMSTD</CODE
+></A
+> now takes a pointer to a struct&nbsp;<A
+HREF="#V4L2-STANDARD"
+>v4l2_standard</A
+>
+directly. The information which standards are supported by a
+particular video input or output moved into struct&nbsp;<A
+HREF="#V4L2-INPUT"
+>v4l2_input</A
+> and
+struct&nbsp;<A
+HREF="#V4L2-OUTPUT"
+>v4l2_output</A
+> fields named <CODE
+CLASS="STRUCTFIELD"
+>std</CODE
+>,
+respectively.</P
+></LI
+><LI
+><P
+>The struct&nbsp;<A
+HREF="#V4L2-QUERYCTRL"
+>v4l2_queryctrl</A
+> fields
+<CODE
+CLASS="STRUCTFIELD"
+>category</CODE
+> and
+<CODE
+CLASS="STRUCTFIELD"
+>group</CODE
+> did not catch on and/or were not
+implemented as expected and therefore removed.</P
+></LI
+><LI
+><P
+>The <A
+HREF="#VIDIOC-G-FMT"
+><CODE
+CLASS="CONSTANT"
+>VIDIOC_TRY_FMT</CODE
+></A
+> ioctl was added to negotiate data
+formats as with <A
+HREF="#VIDIOC-G-FMT"
+><CODE
+CLASS="CONSTANT"
+>VIDIOC_S_FMT</CODE
+></A
+>, but without the overhead of
+programming the hardware and regardless of I/O in progress.</P
+><P
+>In struct&nbsp;<A
+HREF="#V4L2-FORMAT"
+>v4l2_format</A
+> the <CODE
+CLASS="STRUCTFIELD"
+>fmt</CODE
+>
+ union was extended to contain struct&nbsp;<A
+HREF="#V4L2-WINDOW"
+>v4l2_window</A
+>. As a result
+ all data format negotiation is now possible with
+ <CODE
+CLASS="CONSTANT"
+>VIDIOC_G_FMT</CODE
+>,
+ <CODE
+CLASS="CONSTANT"
+>VIDIOC_S_FMT</CODE
+> and
+ <CODE
+CLASS="CONSTANT"
+>VIDIOC_TRY_FMT</CODE
+>; the
+ <CODE
+CLASS="CONSTANT"
+>VIDIOC_G_WIN</CODE
+>,
+ <CODE
+CLASS="CONSTANT"
+>VIDIOC_S_WIN</CODE
+> and ioctl to prepare for
+ overlay were removed. The <CODE
+CLASS="STRUCTFIELD"
+>type</CODE
+>
+ field changed to type enum&nbsp;<A
+HREF="#V4L2-BUF-TYPE"
+>v4l2_buf_type</A
+> and the buffer type
+ names changed as follows.<DIV
+CLASS="INFORMALTABLE"
+><P
+></P
+><A
+NAME="AEN10867"
+></A
+><TABLE
+BORDER="1"
+CLASS="CALSTABLE"
+><COL><COL><THEAD
+><TR
+><TH
+>Old defines</TH
+><TH
+>enum&nbsp;<A
+HREF="#V4L2-BUF-TYPE"
+>v4l2_buf_type</A
+></TH
+></TR
+></THEAD
+><TBODY
+><TR
+><TD
+><CODE
+CLASS="CONSTANT"
+>V4L2_BUF_TYPE_CAPTURE</CODE
+></TD
+><TD
+><CODE
+CLASS="CONSTANT"
+>V4L2_BUF_TYPE_VIDEO_CAPTURE</CODE
+></TD
+></TR
+><TR
+><TD
+><CODE
+CLASS="CONSTANT"
+>V4L2_BUF_TYPE_CODECIN</CODE
+></TD
+><TD
+><CODE
+CLASS="CONSTANT"
+>Preliminary omitted</CODE
+></TD
+></TR
+><TR
+><TD
+><CODE
+CLASS="CONSTANT"
+>V4L2_BUF_TYPE_CODECOUT</CODE
+></TD
+><TD
+><CODE
+CLASS="CONSTANT"
+>Preliminary omitted</CODE
+></TD
+></TR
+><TR
+><TD
+><CODE
+CLASS="CONSTANT"
+>V4L2_BUF_TYPE_EFFECTSIN</CODE
+></TD
+><TD
+><CODE
+CLASS="CONSTANT"
+>Preliminary omitted</CODE
+></TD
+></TR
+><TR
+><TD
+><CODE
+CLASS="CONSTANT"
+>V4L2_BUF_TYPE_EFFECTSIN2</CODE
+></TD
+><TD
+><CODE
+CLASS="CONSTANT"
+>Preliminary omitted</CODE
+></TD
+></TR
+><TR
+><TD
+><CODE
+CLASS="CONSTANT"
+>V4L2_BUF_TYPE_EFFECTSOUT</CODE
+></TD
+><TD
+><CODE
+CLASS="CONSTANT"
+>Preliminary omitted</CODE
+></TD
+></TR
+><TR
+><TD
+><CODE
+CLASS="CONSTANT"
+>V4L2_BUF_TYPE_VIDEOOUT</CODE
+></TD
+><TD
+><CODE
+CLASS="CONSTANT"
+>V4L2_BUF_TYPE_VIDEO_OUTPUT</CODE
+></TD
+></TR
+><TR
+><TD
+><CODE
+CLASS="CONSTANT"
+>-</CODE
+></TD
+><TD
+><CODE
+CLASS="CONSTANT"
+>V4L2_BUF_TYPE_VIDEO_OVERLAY</CODE
+></TD
+></TR
+><TR
+><TD
+><CODE
+CLASS="CONSTANT"
+>-</CODE
+></TD
+><TD
+><CODE
+CLASS="CONSTANT"
+>V4L2_BUF_TYPE_VBI_CAPTURE</CODE
+></TD
+></TR
+><TR
+><TD
+><CODE
+CLASS="CONSTANT"
+>-</CODE
+></TD
+><TD
+><CODE
+CLASS="CONSTANT"
+>V4L2_BUF_TYPE_VBI_OUTPUT</CODE
+></TD
+></TR
+><TR
+><TD
+><CODE
+CLASS="CONSTANT"
+>V4L2_BUF_TYPE_PRIVATE_BASE</CODE
+></TD
+><TD
+><CODE
+CLASS="CONSTANT"
+>V4L2_BUF_TYPE_PRIVATE</CODE
+></TD
+></TR
+></TBODY
+></TABLE
+><P
+></P
+></DIV
+></P
+></LI
+><LI
+><P
+>In struct&nbsp;<A
+HREF="#V4L2-FMTDESC"
+>v4l2_fmtdesc</A
+> a enum&nbsp;<A
+HREF="#V4L2-BUF-TYPE"
+>v4l2_buf_type</A
+> field named
+<CODE
+CLASS="STRUCTFIELD"
+>type</CODE
+> was added as in struct&nbsp;<A
+HREF="#V4L2-FORMAT"
+>v4l2_format</A
+>. As a
+result the <CODE
+CLASS="CONSTANT"
+>VIDIOC_ENUM_FBUFFMT</CODE
+> ioctl is no longer
+needed and was removed. These calls can be replaced by
+<A
+HREF="#VIDIOC-ENUM-FMT"
+><CODE
+CLASS="CONSTANT"
+>VIDIOC_ENUM_FMT</CODE
+></A
+> with type
+<CODE
+CLASS="CONSTANT"
+>V4L2_BUF_TYPE_VIDEO_OVERLAY</CODE
+>.</P
+></LI
+><LI
+><P
+>In struct&nbsp;<A
+HREF="#V4L2-PIX-FORMAT"
+>v4l2_pix_format</A
+> the
+<CODE
+CLASS="STRUCTFIELD"
+>depth</CODE
+> was removed, assuming applications
+recognizing the format are aware of the image depth and others need
+not know. The same rationale lead to the removal of the
+<CODE
+CLASS="CONSTANT"
+>V4L2_FMT_FLAG_COMPRESSED</CODE
+> flag. The
+<CODE
+CLASS="CONSTANT"
+>V4L2_FMT_FLAG_SWCONVECOMPRESSED</CODE
+> flag was removed
+because drivers are not supposed to convert image formats in kernel
+space. The <CODE
+CLASS="CONSTANT"
+>V4L2_FMT_FLAG_BYTESPERLINE</CODE
+> flag was
+redundant, applications can set the
+<CODE
+CLASS="STRUCTFIELD"
+>bytesperline</CODE
+> field to zero to get a
+reasonable default. Since also the remaining flags were replaced, the
+<CODE
+CLASS="STRUCTFIELD"
+>flags</CODE
+> field itself was removed.</P
+><P
+>The interlace flags were replaced by a enum&nbsp;<A
+HREF="#V4L2-FIELD"
+>v4l2_field</A
+>
+value in a newly added <CODE
+CLASS="STRUCTFIELD"
+>field</CODE
+> field.<DIV
+CLASS="INFORMALTABLE"
+><P
+></P
+><A
+NAME="AEN10952"
+></A
+><TABLE
+BORDER="1"
+CLASS="CALSTABLE"
+><COL><COL><THEAD
+><TR
+><TH
+>Old flag</TH
+><TH
+>enum&nbsp;<A
+HREF="#V4L2-FIELD"
+>v4l2_field</A
+></TH
+></TR
+></THEAD
+><TBODY
+><TR
+><TD
+><CODE
+CLASS="CONSTANT"
+>V4L2_FMT_FLAG_NOT_INTERLACED</CODE
+></TD
+><TD
+><CODE
+CLASS="CONSTANT"
+>?</CODE
+></TD
+></TR
+><TR
+><TD
+><CODE
+CLASS="CONSTANT"
+>V4L2_FMT_FLAG_INTERLACED</CODE
+>
+= <CODE
+CLASS="CONSTANT"
+>V4L2_FMT_FLAG_COMBINED</CODE
+></TD
+><TD
+><CODE
+CLASS="CONSTANT"
+>V4L2_FIELD_INTERLACED</CODE
+></TD
+></TR
+><TR
+><TD
+><CODE
+CLASS="CONSTANT"
+>V4L2_FMT_FLAG_TOPFIELD</CODE
+>
+= <CODE
+CLASS="CONSTANT"
+>V4L2_FMT_FLAG_ODDFIELD</CODE
+></TD
+><TD
+><CODE
+CLASS="CONSTANT"
+>V4L2_FIELD_TOP</CODE
+></TD
+></TR
+><TR
+><TD
+><CODE
+CLASS="CONSTANT"
+>V4L2_FMT_FLAG_BOTFIELD</CODE
+>
+= <CODE
+CLASS="CONSTANT"
+>V4L2_FMT_FLAG_EVENFIELD</CODE
+></TD
+><TD
+><CODE
+CLASS="CONSTANT"
+>V4L2_FIELD_BOTTOM</CODE
+></TD
+></TR
+><TR
+><TD
+><CODE
+CLASS="CONSTANT"
+>-</CODE
+></TD
+><TD
+><CODE
+CLASS="CONSTANT"
+>V4L2_FIELD_SEQ_TB</CODE
+></TD
+></TR
+><TR
+><TD
+><CODE
+CLASS="CONSTANT"
+>-</CODE
+></TD
+><TD
+><CODE
+CLASS="CONSTANT"
+>V4L2_FIELD_SEQ_BT</CODE
+></TD
+></TR
+><TR
+><TD
+><CODE
+CLASS="CONSTANT"
+>-</CODE
+></TD
+><TD
+><CODE
+CLASS="CONSTANT"
+>V4L2_FIELD_ALTERNATE</CODE
+></TD
+></TR
+></TBODY
+></TABLE
+><P
+></P
+></DIV
+></P
+><P
+>The color space flags were replaced by a
+enum&nbsp;<A
+HREF="#V4L2-COLORSPACE"
+>v4l2_colorspace</A
+> value in a newly added
+<CODE
+CLASS="STRUCTFIELD"
+>colorspace</CODE
+> field, where one of
+<CODE
+CLASS="CONSTANT"
+>V4L2_COLORSPACE_SMPTE170M</CODE
+>,
+<CODE
+CLASS="CONSTANT"
+>V4L2_COLORSPACE_BT878</CODE
+>,
+<CODE
+CLASS="CONSTANT"
+>V4L2_COLORSPACE_470_SYSTEM_M</CODE
+> or
+<CODE
+CLASS="CONSTANT"
+>V4L2_COLORSPACE_470_SYSTEM_BG</CODE
+> replaces
+<CODE
+CLASS="CONSTANT"
+>V4L2_FMT_CS_601YUV</CODE
+>.</P
+></LI
+><LI
+><P
+>In struct&nbsp;<A
+HREF="#V4L2-REQUESTBUFFERS"
+>v4l2_requestbuffers</A
+> the
+<CODE
+CLASS="STRUCTFIELD"
+>type</CODE
+> field was properly typed as
+enum&nbsp;<A
+HREF="#V4L2-BUF-TYPE"
+>v4l2_buf_type</A
+>. Buffer types changed as mentioned above. A new
+<CODE
+CLASS="STRUCTFIELD"
+>memory</CODE
+> field of type enum&nbsp;<A
+HREF="#V4L2-MEMORY"
+>v4l2_memory</A
+> was
+added to distinguish between mapping methods using buffers allocated
+by the driver or the application. See <A
+HREF="#IO"
+>Chapter 3</A
+> for
+details.</P
+></LI
+><LI
+><P
+>In struct&nbsp;<A
+HREF="#V4L2-BUFFER"
+>v4l2_buffer</A
+> the <CODE
+CLASS="STRUCTFIELD"
+>type</CODE
+>
+field was properly typed as enum&nbsp;<A
+HREF="#V4L2-BUF-TYPE"
+>v4l2_buf_type</A
+>. Buffer types changed as
+mentioned above. A <CODE
+CLASS="STRUCTFIELD"
+>field</CODE
+> field of type
+enum&nbsp;<A
+HREF="#V4L2-FIELD"
+>v4l2_field</A
+> was added to indicate if a buffer contains a top or
+bottom field, the field flags were removed. Realizing the efforts to
+introduce an unadjusted system time clock failed, the
+<CODE
+CLASS="STRUCTFIELD"
+>timestamp</CODE
+> field changed back from type
+stamp_t, an unsigned 64 bit integer expressing time in nanoseconds, to
+struct <CODE
+CLASS="STRUCTNAME"
+>timeval</CODE
+>. With the addition of a second
+memory mapping method the <CODE
+CLASS="STRUCTFIELD"
+>offset</CODE
+> field
+moved into union <CODE
+CLASS="STRUCTFIELD"
+>m</CODE
+>, and a new
+<CODE
+CLASS="STRUCTFIELD"
+>memory</CODE
+> field of type enum&nbsp;<A
+HREF="#V4L2-MEMORY"
+>v4l2_memory</A
+> was
+added to distinguish between mapping methods. See <A
+HREF="#IO"
+>Chapter 3</A
+>
+for details.</P
+><P
+>The <CODE
+CLASS="CONSTANT"
+>V4L2_BUF_REQ_CONTIG</CODE
+>
+flag was used by the V4L compatibility layer, after changes to this
+code it was no longer needed. The
+<CODE
+CLASS="CONSTANT"
+>V4L2_BUF_ATTR_DEVICEMEM</CODE
+> flag would indicate if
+the buffer was indeed allocated in device memory rather than DMA-able
+system memory. It was barely useful and so has been removed.</P
+></LI
+><LI
+><P
+>In struct&nbsp;<A
+HREF="#V4L2-FRAMEBUFFER"
+>v4l2_framebuffer</A
+> the
+<CODE
+CLASS="STRUCTFIELD"
+>base[3]</CODE
+> array anticipating double- and
+triple-buffering in off-screen video memory, however without defining
+ a synchronization mechanism, was replaced by a single
+ pointer. The <CODE
+CLASS="CONSTANT"
+>V4L2_FBUF_CAP_SCALEUP</CODE
+> and
+ <CODE
+CLASS="CONSTANT"
+>V4L2_FBUF_CAP_SCALEDOWN</CODE
+> flags were
+ removed. Applications can determine this capability more
+ accurately using the new cropping and scaling interface. The
+ <CODE
+CLASS="CONSTANT"
+>V4L2_FBUF_CAP_CLIPPING</CODE
+> flag was
+ replaced by <CODE
+CLASS="CONSTANT"
+>V4L2_FBUF_CAP_LIST_CLIPPING</CODE
+>
+ and <CODE
+CLASS="CONSTANT"
+>V4L2_FBUF_CAP_BITMAP_CLIPPING</CODE
+>.</P
+></LI
+><LI
+><P
+>In struct&nbsp;<A
+HREF="#V4L2-CLIP"
+>v4l2_clip</A
+> the <CODE
+CLASS="STRUCTFIELD"
+>x</CODE
+>,
+<CODE
+CLASS="STRUCTFIELD"
+>y</CODE
+>, <CODE
+CLASS="STRUCTFIELD"
+>width</CODE
+> and
+<CODE
+CLASS="STRUCTFIELD"
+>height</CODE
+> field moved into a
+<CODE
+CLASS="STRUCTFIELD"
+>c</CODE
+> substructure of type struct&nbsp;<A
+HREF="#V4L2-RECT"
+>v4l2_rect</A
+>. The
+<CODE
+CLASS="STRUCTFIELD"
+>x</CODE
+> and <CODE
+CLASS="STRUCTFIELD"
+>y</CODE
+> field
+were renamed to <CODE
+CLASS="STRUCTFIELD"
+>left</CODE
+> and
+<CODE
+CLASS="STRUCTFIELD"
+>top</CODE
+>, i.&nbsp;e. offsets to a context dependent
+origin.</P
+></LI
+><LI
+><P
+>In struct&nbsp;<A
+HREF="#V4L2-WINDOW"
+>v4l2_window</A
+> the <CODE
+CLASS="STRUCTFIELD"
+>x</CODE
+>,
+<CODE
+CLASS="STRUCTFIELD"
+>y</CODE
+>, <CODE
+CLASS="STRUCTFIELD"
+>width</CODE
+> and
+<CODE
+CLASS="STRUCTFIELD"
+>height</CODE
+> field moved into a
+<CODE
+CLASS="STRUCTFIELD"
+>w</CODE
+> substructure as above. A
+<CODE
+CLASS="STRUCTFIELD"
+>field</CODE
+> field of type %v4l2-field; was added
+to distinguish between field and frame (interlaced) overlay.</P
+></LI
+><LI
+><P
+>The digital zoom interface, including struct
+<CODE
+CLASS="STRUCTNAME"
+>v4l2_zoomcap</CODE
+>, struct
+<CODE
+CLASS="STRUCTNAME"
+>v4l2_zoom</CODE
+>,
+<CODE
+CLASS="CONSTANT"
+>V4L2_ZOOM_NONCAP</CODE
+> and
+<CODE
+CLASS="CONSTANT"
+>V4L2_ZOOM_WHILESTREAMING</CODE
+> was replaced by a new
+cropping and scaling interface. The previously unused struct
+<CODE
+CLASS="STRUCTNAME"
+>v4l2_cropcap</CODE
+> and
+<CODE
+CLASS="STRUCTNAME"
+>v4l2_crop</CODE
+> where redefined for this purpose.
+See <A
+HREF="#CROP"
+>Section 1.10</A
+> for details.</P
+></LI
+><LI
+><P
+>In struct&nbsp;<A
+HREF="#V4L2-VBI-FORMAT"
+>v4l2_vbi_format</A
+> the
+<CODE
+CLASS="STRUCTFIELD"
+>SAMPLE_FORMAT</CODE
+> field now contains a
+four-character-code as used to identify video image formats.
+<CODE
+CLASS="CONSTANT"
+>V4L2_PIX_FMT_GREY</CODE
+> replaces the
+<CODE
+CLASS="CONSTANT"
+>V4L2_VBI_SF_UBYTE</CODE
+> define. The
+<CODE
+CLASS="STRUCTFIELD"
+>reserved</CODE
+> field was extended.</P
+></LI
+><LI
+><P
+>In struct&nbsp;<A
+HREF="#V4L2-CAPTUREPARM"
+>v4l2_captureparm</A
+> the type of the
+<CODE
+CLASS="STRUCTFIELD"
+>timeperframe</CODE
+> field changed from unsigned
+long to struct&nbsp;<A
+HREF="#V4L2-FRACT"
+>v4l2_fract</A
+>. A new field
+<CODE
+CLASS="STRUCTFIELD"
+>readbuffers</CODE
+> was added to control the driver
+behaviour in read I/O mode.</P
+><P
+>According changes were made to
+struct&nbsp;<A
+HREF="#V4L2-OUTPUTPARM"
+>v4l2_outputparm</A
+>.</P
+></LI
+><LI
+><P
+>The struct <CODE
+CLASS="STRUCTNAME"
+>v4l2_performance</CODE
+>
+and <CODE
+CLASS="CONSTANT"
+>VIDIOC_G_PERF</CODE
+> ioctl were dropped. Except when
+using the <A
+HREF="#RW"
+>read/write I/O method</A
+>, which is
+limited anyway, this information is already available to the
+application.</P
+></LI
+><LI
+><P
+>The example transformation from RGB to YCbCr color
+space in the old V4L2 documentation was inaccurate, this has been
+corrected in <A
+HREF="#PIXFMT"
+>Chapter 2</A
+>.</P
+></LI
+></OL
+></DIV
+><DIV
+CLASS="SECTION"
+><HR><H3
+CLASS="SECTION"
+><A
+NAME="AEN11094"
+>6.2.10. V4L2 2003-06-19</A
+></H3
+><P
+></P
+><OL
+TYPE="1"
+><LI
+><P
+>A new capability flag
+<CODE
+CLASS="CONSTANT"
+>V4L2_CAP_RADIO</CODE
+> was added for radio devices. Prior
+to this change radio devices would identify soley by having exactly one
+tuner whose type field reads <CODE
+CLASS="CONSTANT"
+>V4L2_TUNER_RADIO</CODE
+>.</P
+></LI
+><LI
+><P
+>An optional priority mechanism was added, see <A
+HREF="#APP-PRI"
+>Section 1.3</A
+> for details.</P
+></LI
+><LI
+><P
+>The audio input and output interface was found to be
+incomplete.</P
+><P
+>Previously the <CODE
+CLASS="CONSTANT"
+>VIDIOC_G_AUDIO</CODE
+>
+ioctl would enumerate the available audio inputs. An ioctl to
+determine the current audio input, if more than one combines with the
+current video input, did not exist. So
+<CODE
+CLASS="CONSTANT"
+>VIDIOC_G_AUDIO</CODE
+> was renamed to
+<CODE
+CLASS="CONSTANT"
+>VIDIOC_G_AUDIO_OLD</CODE
+>, this ioctl will be removed in
+the future. The <A
+HREF="#VIDIOC-ENUMAUDIO"
+><CODE
+CLASS="CONSTANT"
+>VIDIOC_ENUMAUDIO</CODE
+></A
+> ioctl was added to enumerate
+audio inputs, while <A
+HREF="#VIDIOC-G-AUDIO"
+><CODE
+CLASS="CONSTANT"
+>VIDIOC_G_AUDIO</CODE
+></A
+> now reports the current audio
+input.</P
+><P
+>The same changes were made to <A
+HREF="#VIDIOC-G-AUDIOOUT"
+><CODE
+CLASS="CONSTANT"
+>VIDIOC_G_AUDOUT</CODE
+></A
+> and
+<A
+HREF="#VIDIOC-ENUMAUDIOOUT"
+><CODE
+CLASS="CONSTANT"
+>VIDIOC_ENUMAUDOUT</CODE
+></A
+>.</P
+><P
+>Until further the "videodev" module will automatically
+translate to the new versions, drivers and applications must be updated
+when they are recompiled.</P
+></LI
+><LI
+><P
+>The <A
+HREF="#VIDIOC-OVERLAY"
+><CODE
+CLASS="CONSTANT"
+>VIDIOC_OVERLAY</CODE
+></A
+> ioctl was incorrectly defined with
+read-write parameter. It was changed to write-only, while the read-write
+version was renamed to <CODE
+CLASS="CONSTANT"
+>VIDIOC_OVERLAY_OLD</CODE
+>. This
+function will be removed in the future. Until further the "videodev"
+module will automatically translate to the new version, so drivers
+must be recompiled, but not applications.</P
+></LI
+><LI
+><P
+><A
+HREF="#OVERLAY"
+>Section 4.2</A
+> incorrectly stated that
+clipping rectangles define regions where the video can be seen.
+Correct is that clipping rectangles define regions where
+<SPAN
+CLASS="emphasis"
+><I
+CLASS="EMPHASIS"
+>no</I
+></SPAN
+> video shall be displayed and so the graphics
+surface can be seen.</P
+></LI
+><LI
+><P
+>The <A
+HREF="#VIDIOC-G-PARM"
+><CODE
+CLASS="CONSTANT"
+>VIDIOC_S_PARM</CODE
+></A
+> and <A
+HREF="#VIDIOC-G-CTRL"
+><CODE
+CLASS="CONSTANT"
+>VIDIOC_S_CTRL</CODE
+></A
+> were defined
+with write-only parameter, inconsistent with other ioctls modifying
+their argument. They were changed to read-write, while a
+<CODE
+CLASS="CONSTANT"
+>_OLD</CODE
+> suffix was added to the write-only version.
+These functions will be removed in the future. Drivers, and
+applications assuming a constant parameter, need an update.</P
+></LI
+></OL
+></DIV
+><DIV
+CLASS="SECTION"
+><HR><H3
+CLASS="SECTION"
+><A
+NAME="AEN11136"
+>6.2.11. V4L2 2003-11-05</A
+></H3
+><P
+></P
+><OL
+TYPE="1"
+><LI
+><P
+>In <A
+HREF="#PIXFMT-RGB"
+>Section 2.3</A
+> the following pixel
+formats were incorrectly transferred from Bill Dirks' V4L2
+specification. Descriptions refer to bytes in memory, in ascending
+address order.<DIV
+CLASS="INFORMALTABLE"
+><P
+></P
+><A
+NAME="AEN11142"
+></A
+><TABLE
+BORDER="1"
+CLASS="CALSTABLE"
+><COL><COL><COL><THEAD
+><TR
+><TH
+>Symbol</TH
+><TH
+>In this document prior to revision 0.5</TH
+><TH
+>Correct</TH
+></TR
+></THEAD
+><TBODY
+><TR
+><TD
+><CODE
+CLASS="CONSTANT"
+>V4L2_PIX_FMT_RGB24</CODE
+></TD
+><TD
+>B, G, R</TD
+><TD
+>R, G, B</TD
+></TR
+><TR
+><TD
+><CODE
+CLASS="CONSTANT"
+>V4L2_PIX_FMT_BGR24</CODE
+></TD
+><TD
+>R, G, B</TD
+><TD
+>B, G, R</TD
+></TR
+><TR
+><TD
+><CODE
+CLASS="CONSTANT"
+>V4L2_PIX_FMT_RGB32</CODE
+></TD
+><TD
+>B, G, R, X</TD
+><TD
+>R, G, B, X</TD
+></TR
+><TR
+><TD
+><CODE
+CLASS="CONSTANT"
+>V4L2_PIX_FMT_BGR32</CODE
+></TD
+><TD
+>R, G, B, X</TD
+><TD
+>B, G, R, X</TD
+></TR
+></TBODY
+></TABLE
+><P
+></P
+></DIV
+> The
+<CODE
+CLASS="CONSTANT"
+>V4L2_PIX_FMT_BGR24</CODE
+> example was always
+correct.</P
+><P
+>In <A
+HREF="#V4L-IMAGE-PROPERTIES"
+>Section 6.1.5</A
+> the mapping of
+<CODE
+CLASS="CONSTANT"
+>VIDEO_PALETTE_RGB24</CODE
+> and
+<CODE
+CLASS="CONSTANT"
+>VIDEO_PALETTE_RGB32</CODE
+> to V4L2 pixel formats was accordingly corrected.</P
+></LI
+><LI
+><P
+>Unrelated to the fixes above, drivers may still interpret some V4L2 RGB pixel formats differently. These issues have yet to be addressed, for details see <A
+HREF="#PIXFMT-RGB"
+>Section 2.3</A
+>.</P
+></LI
+></OL
+></DIV
+><DIV
+CLASS="SECTION"
+><HR><H3
+CLASS="SECTION"
+><A
+NAME="AEN11178"
+>6.2.12. V4L2 in Linux 2.6.6, 2004-05-09</A
+></H3
+><P
+></P
+><OL
+TYPE="1"
+><LI
+><P
+>The <A
+HREF="#VIDIOC-CROPCAP"
+><CODE
+CLASS="CONSTANT"
+>VIDIOC_CROPCAP</CODE
+></A
+> ioctl was incorrectly defined with
+read-only parameter. It was changed to read-write, while the read-only
+version was renamed to <CODE
+CLASS="CONSTANT"
+>VIDIOC_CROPCAP_OLD</CODE
+>. This
+function will be removed in the future.</P
+></LI
+></OL
+></DIV
+><DIV
+CLASS="SECTION"
+><HR><H3
+CLASS="SECTION"
+><A
+NAME="AEN11186"
+>6.2.13. V4L2 in Linux 2.6.8</A
+></H3
+><P
+></P
+><OL
+TYPE="1"
+><LI
+><P
+>A new field <CODE
+CLASS="STRUCTFIELD"
+>input</CODE
+> (former
+<CODE
+CLASS="STRUCTFIELD"
+>reserved[0]</CODE
+>) was added to the
+struct&nbsp;<A
+HREF="#V4L2-BUFFER"
+>v4l2_buffer</A
+> structure. It must be enabled with the new
+<CODE
+CLASS="CONSTANT"
+>V4L2_BUF_FLAG_INPUT</CODE
+> flag. The
+<CODE
+CLASS="STRUCTFIELD"
+>flags</CODE
+> field is no longer read-only.</P
+></LI
+></OL
+></DIV
+><DIV
+CLASS="SECTION"
+><HR><H3
+CLASS="SECTION"
+><A
+NAME="AEN11196"
+>6.2.14. V4L2 spec erratum 2004-08-01</A
+></H3
+><P
+></P
+><OL
+TYPE="1"
+><LI
+><P
+>The return value of the
+<A
+HREF="#FUNC-OPEN"
+>open</A
+> function was incorrect.</P
+></LI
+><LI
+><P
+>Audio output ioctls end in -AUDOUT, not -AUDIOOUT.</P
+></LI
+><LI
+><P
+>In the current audio input example the
+<CODE
+CLASS="CONSTANT"
+>VIDIOC_G_AUDIO</CODE
+> ioctl took the wrong
+argument.</P
+></LI
+><LI
+><P
+>The <A
+HREF="#VIDIOC-QBUF"
+><CODE
+CLASS="CONSTANT"
+>VIDIOC_QBUF</CODE
+></A
+> and <A
+HREF="#VIDIOC-QBUF"
+><CODE
+CLASS="CONSTANT"
+>VIDIOC_DQBUF</CODE
+></A
+> ioctl did not
+mention the struct&nbsp;<A
+HREF="#V4L2-BUFFER"
+>v4l2_buffer</A
+> <CODE
+CLASS="STRUCTFIELD"
+>memory</CODE
+> field, it
+was also missing from examples. Added description of the
+<CODE
+CLASS="CONSTANT"
+>VIDIOC_DQBUF</CODE
+> <CODE
+CLASS="CONSTANT"
+>EIO</CODE
+> error.</P
+></LI
+></OL
+></DIV
+></DIV
+><DIV
+CLASS="SECTION"
+><HR><H2
+CLASS="SECTION"
+><A
+NAME="OTHER"
+>6.3. Relation of V4L2 to other Linux multimedia APIs</A
+></H2
+><DIV
+CLASS="SECTION"
+><H3
+CLASS="SECTION"
+><A
+NAME="XVIDEO"
+>6.3.1. X Video Extension</A
+></H3
+><P
+>The X Video Extension (abbreviated XVideo or just Xv) is
+an extension of the X Window system, implemented for example by the
+XFree86 project. Its scope is similar to V4L2, an API to video capture
+and output devices for X clients. Xv allows applications to display
+live video in a window, send window contents to a TV output, and
+capture or output still images in XPixmaps<A
+NAME="AEN11222"
+HREF="#FTN.AEN11222"
+><SPAN
+CLASS="footnote"
+>[27]</SPAN
+></A
+>. With their implementation XFree86 makes the
+extension available across many operating systems and
+architectures.</P
+><P
+>Because the driver is embedded into the X server Xv has a
+number of advantages over the V4L2 <A
+HREF="#OVERLAY"
+>video
+overlay interface</A
+>. The driver can easily determine the overlay
+target, i.&nbsp;e. visible graphics memory or off-screen buffers for
+non-destructive overlay. It can program the RAMDAC for overlay,
+scaling or color-keying, or the clipping functions of the video
+capture hardware, always in sync with drawing operations or windows
+moving or changing their stacking order.</P
+><P
+>To combine the advantages of Xv and V4L a special Xv
+driver exists in XFree86, just programming any overlay capable
+Video4Linux device it finds. To enable it
+<TT
+CLASS="FILENAME"
+>/etc/X11/XF86Config</TT
+> must contain these lines:</P
+><P
+><PRE
+CLASS="SCREEN"
+>Section "Module"
+ Load "v4l"
+EndSection</PRE
+></P
+><P
+>As of XFree86 4.2 this driver still supports only V4L
+ioctls, however it should work just fine with all V4L2 devices through
+the V4L2 backward-compatibility layer. Since V4L2 permits multiple
+opens it is possible (if supported by the V4L2 driver) to capture
+video while an X client requested video overlay. Restrictions of
+simultaneous capturing and overlay mentioned in <A
+HREF="#OVERLAY"
+>Section 4.2</A
+> apply.</P
+><P
+>Only marginally related to V4L2, XFree86 extended Xv to
+support hardware YUV to RGB conversion and scaling for faster video
+playback, and added an interface to MPEG-2 decoding hardware. This
+can be used to improve displaying captured images.</P
+></DIV
+><DIV
+CLASS="SECTION"
+><HR><H3
+CLASS="SECTION"
+><A
+NAME="AEN11233"
+>6.3.2. Digital Video</A
+></H3
+><P
+>V4L2 does not, at this time and possibly never, support
+digital terrestrial, cable or satellite broadcast. A separate project
+aiming at digital receivers exists. You can find its homepage at
+<A
+HREF="http://linuxtv.org"
+TARGET="_top"
+>http://linuxtv.org</A
+>. This group
+found the requirements sufficiently different from analog television
+to choose independent development of their interfaces.</P
+></DIV
+><DIV
+CLASS="SECTION"
+><HR><H3
+CLASS="SECTION"
+><A
+NAME="AEN11237"
+>6.3.3. Audio Interfaces</A
+></H3
+><P
+>[to do - OSS/ALSA]</P
+></DIV
+></DIV
+></DIV
+><DIV
+CLASS="APPENDIX"
+><HR><H1
+><A
+NAME="VIDEODEV"
+></A
+>Appendix A. Video For Linux Two Header File</H1
+><PRE
+CLASS="PROGRAMLISTING"
+>#ifndef __LINUX_VIDEODEV2_H
+#define __LINUX_VIDEODEV2_H
+/*
+ * Video for Linux Two
+ *
+ * Header file for v4l or V4L2 drivers and applications, for
+ * Linux kernels 2.2.x or 2.4.x.
+ *
+ * See http://bytesex.org/v4l/ for API specs and other
+ * v4l2 documentation.
+ *
+ * Author: Bill Dirks &lt;bdirks@pacbell.net&gt;
+ * Justin Schoeman
+ * et al.
+ */
+#ifdef __KERNEL__
+#include &lt;linux/time.h&gt; /* need struct timeval */
+#endif
+
+/*
+ * M I S C E L L A N E O U S
+ */
+
+/* Four-character-code (FOURCC) */
+#define v4l2_fourcc(a,b,c,d)\
+ (((__u32)(a)&lt;&lt;0)|((__u32)(b)&lt;&lt;8)|((__u32)(c)&lt;&lt;16)|((__u32)(d)&lt;&lt;24))
+
+/*
+ * E N U M S
+ */
+enum <A
+HREF="#V4L2-FIELD"
+>v4l2_field</A
+> {
+ V4L2_FIELD_ANY = 0, /* driver can choose from none,
+ top, bottom, interlaced
+ depending on whatever it thinks
+ is approximate ... */
+ V4L2_FIELD_NONE = 1, /* this device has no fields ... */
+ V4L2_FIELD_TOP = 2, /* top field only */
+ V4L2_FIELD_BOTTOM = 3, /* bottom field only */
+ V4L2_FIELD_INTERLACED = 4, /* both fields interlaced */
+ V4L2_FIELD_SEQ_TB = 5, /* both fields sequential into one
+ buffer, top-bottom order */
+ V4L2_FIELD_SEQ_BT = 6, /* same as above + bottom-top order */
+ V4L2_FIELD_ALTERNATE = 7, /* both fields alternating into
+ separate buffers */
+};
+#define V4L2_FIELD_HAS_TOP(field) \
+ ((field) == V4L2_FIELD_TOP ||\
+ (field) == V4L2_FIELD_INTERLACED ||\
+ (field) == V4L2_FIELD_SEQ_TB ||\
+ (field) == V4L2_FIELD_SEQ_BT)
+#define V4L2_FIELD_HAS_BOTTOM(field) \
+ ((field) == V4L2_FIELD_BOTTOM ||\
+ (field) == V4L2_FIELD_INTERLACED ||\
+ (field) == V4L2_FIELD_SEQ_TB ||\
+ (field) == V4L2_FIELD_SEQ_BT)
+#define V4L2_FIELD_HAS_BOTH(field) \
+ ((field) == V4L2_FIELD_INTERLACED ||\
+ (field) == V4L2_FIELD_SEQ_TB ||\
+ (field) == V4L2_FIELD_SEQ_BT)
+
+enum <A
+HREF="#V4L2-BUF-TYPE"
+>v4l2_buf_type</A
+> {
+ V4L2_BUF_TYPE_VIDEO_CAPTURE = 1,
+ V4L2_BUF_TYPE_VIDEO_OUTPUT = 2,
+ V4L2_BUF_TYPE_VIDEO_OVERLAY = 3,
+ V4L2_BUF_TYPE_VBI_CAPTURE = 4,
+ V4L2_BUF_TYPE_VBI_OUTPUT = 5,
+ V4L2_BUF_TYPE_PRIVATE = 0x80,
+};
+
+enum <A
+HREF="#V4L2-CTRL-TYPE"
+>v4l2_ctrl_type</A
+> {
+ V4L2_CTRL_TYPE_INTEGER = 1,
+ V4L2_CTRL_TYPE_BOOLEAN = 2,
+ V4L2_CTRL_TYPE_MENU = 3,
+ V4L2_CTRL_TYPE_BUTTON = 4,
+};
+
+enum <A
+HREF="#V4L2-TUNER-TYPE"
+>v4l2_tuner_type</A
+> {
+ V4L2_TUNER_RADIO = 1,
+ V4L2_TUNER_ANALOG_TV = 2,
+};
+
+enum <A
+HREF="#V4L2-MEMORY"
+>v4l2_memory</A
+> {
+ V4L2_MEMORY_MMAP = 1,
+ V4L2_MEMORY_USERPTR = 2,
+ V4L2_MEMORY_OVERLAY = 3,
+};
+
+/* see also http://vektor.theorem.ca/graphics/ycbcr/ */
+enum <A
+HREF="#V4L2-COLORSPACE"
+>v4l2_colorspace</A
+> {
+ /* ITU-R 601 -- broadcast NTSC/PAL */
+ V4L2_COLORSPACE_SMPTE170M = 1,
+
+ /* 1125-Line (US) HDTV */
+ V4L2_COLORSPACE_SMPTE240M = 2,
+
+ /* HD and modern captures. */
+ V4L2_COLORSPACE_REC709 = 3,
+
+ /* broken BT878 extents (601, luma range 16-253 instead of 16-235) */
+ V4L2_COLORSPACE_BT878 = 4,
+
+ /* These should be useful. Assume 601 extents. */
+ V4L2_COLORSPACE_470_SYSTEM_M = 5,
+ V4L2_COLORSPACE_470_SYSTEM_BG = 6,
+
+ /* I know there will be cameras that send this. So, this is
+ * unspecified chromaticities and full 0-255 on each of the
+ * Y'CbCr components
+ */
+ V4L2_COLORSPACE_JPEG = 7,
+
+ /* For RGB colourspaces, this is probably a good start. */
+ V4L2_COLORSPACE_SRGB = 8,
+};
+
+enum <A
+HREF="#V4L2-PRIORITY"
+>v4l2_priority</A
+> {
+ V4L2_PRIORITY_UNSET = 0, /* not initialized */
+ V4L2_PRIORITY_BACKGROUND = 1,
+ V4L2_PRIORITY_INTERACTIVE = 2,
+ V4L2_PRIORITY_RECORD = 3,
+ V4L2_PRIORITY_DEFAULT = V4L2_PRIORITY_INTERACTIVE,
+};
+
+struct <A
+HREF="#V4L2-RECT"
+>v4l2_rect</A
+> {
+ __s32 left;
+ __s32 top;
+ __s32 width;
+ __s32 height;
+};
+
+struct <A
+HREF="#V4L2-FRACT"
+>v4l2_fract</A
+> {
+ __u32 numerator;
+ __u32 denominator;
+};
+
+/*
+ * D R I V E R C A P A B I L I T I E S
+ */
+struct <A
+HREF="#V4L2-CAPABILITY"
+>v4l2_capability</A
+>
+{
+ __u8 driver[16]; /* i.e. "bttv" */
+ __u8 card[32]; /* i.e. "Hauppauge WinTV" */
+ __u8 bus_info[32]; /* "PCI:" + pci_name(pci_dev) */
+ __u32 version; /* should use KERNEL_VERSION() */
+ __u32 capabilities; /* Device capabilities */
+ __u32 reserved[4];
+};
+
+/* Values for 'capabilities' field */
+#define V4L2_CAP_VIDEO_CAPTURE 0x00000001 /* Is a video capture device */
+#define V4L2_CAP_VIDEO_OUTPUT 0x00000002 /* Is a video output device */
+#define V4L2_CAP_VIDEO_OVERLAY 0x00000004 /* Can do video overlay */
+#define V4L2_CAP_VBI_CAPTURE 0x00000010 /* Is a VBI capture device */
+#define V4L2_CAP_VBI_OUTPUT 0x00000020 /* Is a VBI output device */
+#define V4L2_CAP_RDS_CAPTURE 0x00000100 /* RDS data capture */
+
+#define V4L2_CAP_TUNER 0x00010000 /* has a tuner */
+#define V4L2_CAP_AUDIO 0x00020000 /* has audio support */
+#define V4L2_CAP_RADIO 0x00040000 /* is a radio device */
+
+#define V4L2_CAP_READWRITE 0x01000000 /* read/write systemcalls */
+#define V4L2_CAP_ASYNCIO 0x02000000 /* async I/O */
+#define V4L2_CAP_STREAMING 0x04000000 /* streaming I/O ioctls */
+
+/*
+ * V I D E O I M A G E F O R M A T
+ */
+
+struct <A
+HREF="#V4L2-PIX-FORMAT"
+>v4l2_pix_format</A
+>
+{
+ __u32 width;
+ __u32 height;
+ __u32 pixelformat;
+ enum <A
+HREF="#V4L2-FIELD"
+>v4l2_field</A
+> field;
+ __u32 bytesperline; /* for padding, zero if unused */
+ __u32 sizeimage;
+ enum <A
+HREF="#V4L2-COLORSPACE"
+>v4l2_colorspace</A
+> colorspace;
+ __u32 priv; /* private data, depends on pixelformat */
+};
+
+/* Pixel format FOURCC depth Description */
+#define V4L2_PIX_FMT_RGB332 v4l2_fourcc('R','G','B','1') /* 8 RGB-3-3-2 */
+#define V4L2_PIX_FMT_RGB555 v4l2_fourcc('R','G','B','O') /* 16 RGB-5-5-5 */
+#define V4L2_PIX_FMT_RGB565 v4l2_fourcc('R','G','B','P') /* 16 RGB-5-6-5 */
+#define V4L2_PIX_FMT_RGB555X v4l2_fourcc('R','G','B','Q') /* 16 RGB-5-5-5 BE */
+#define V4L2_PIX_FMT_RGB565X v4l2_fourcc('R','G','B','R') /* 16 RGB-5-6-5 BE */
+#define V4L2_PIX_FMT_BGR24 v4l2_fourcc('B','G','R','3') /* 24 BGR-8-8-8 */
+#define V4L2_PIX_FMT_RGB24 v4l2_fourcc('R','G','B','3') /* 24 RGB-8-8-8 */
+#define V4L2_PIX_FMT_BGR32 v4l2_fourcc('B','G','R','4') /* 32 BGR-8-8-8-8 */
+#define V4L2_PIX_FMT_RGB32 v4l2_fourcc('R','G','B','4') /* 32 RGB-8-8-8-8 */
+#define V4L2_PIX_FMT_GREY v4l2_fourcc('G','R','E','Y') /* 8 Greyscale */
+#define V4L2_PIX_FMT_YVU410 v4l2_fourcc('Y','V','U','9') /* 9 YVU 4:1:0 */
+#define V4L2_PIX_FMT_YVU420 v4l2_fourcc('Y','V','1','2') /* 12 YVU 4:2:0 */
+#define V4L2_PIX_FMT_YUYV v4l2_fourcc('Y','U','Y','V') /* 16 YUV 4:2:2 */
+#define V4L2_PIX_FMT_UYVY v4l2_fourcc('U','Y','V','Y') /* 16 YUV 4:2:2 */
+#define V4L2_PIX_FMT_YUV422P v4l2_fourcc('4','2','2','P') /* 16 YVU422 planar */
+#define V4L2_PIX_FMT_YUV411P v4l2_fourcc('4','1','1','P') /* 16 YVU411 planar */
+#define V4L2_PIX_FMT_Y41P v4l2_fourcc('Y','4','1','P') /* 12 YUV 4:1:1 */
+
+/* two planes -- one Y, one Cr + Cb interleaved */
+#define V4L2_PIX_FMT_NV12 v4l2_fourcc('N','V','1','2') /* 12 Y/CbCr 4:2:0 */
+#define V4L2_PIX_FMT_NV21 v4l2_fourcc('N','V','2','1') /* 12 Y/CrCb 4:2:0 */
+
+/* The following formats are not defined in the V4L2 specification */
+#define V4L2_PIX_FMT_YUV410 v4l2_fourcc('Y','U','V','9') /* 9 YUV 4:1:0 */
+#define V4L2_PIX_FMT_YUV420 v4l2_fourcc('Y','U','1','2') /* 12 YUV 4:2:0 */
+#define V4L2_PIX_FMT_YYUV v4l2_fourcc('Y','Y','U','V') /* 16 YUV 4:2:2 */
+#define V4L2_PIX_FMT_HI240 v4l2_fourcc('H','I','2','4') /* 8 8-bit color */
+
+/* compressed formats */
+#define V4L2_PIX_FMT_MJPEG v4l2_fourcc('M','J','P','G') /* Motion-JPEG */
+#define V4L2_PIX_FMT_JPEG v4l2_fourcc('J','P','E','G') /* JFIF JPEG */
+#define V4L2_PIX_FMT_DV v4l2_fourcc('d','v','s','d') /* 1394 */
+#define V4L2_PIX_FMT_MPEG v4l2_fourcc('M','P','E','G') /* MPEG */
+
+/* Vendor-specific formats */
+#define V4L2_PIX_FMT_WNVA v4l2_fourcc('W','N','V','A') /* Winnov hw compress */
+
+/*
+ * F O R M A T E N U M E R A T I O N
+ */
+struct <A
+HREF="#V4L2-FMTDESC"
+>v4l2_fmtdesc</A
+>
+{
+ __u32 index; /* Format number */
+ enum <A
+HREF="#V4L2-BUF-TYPE"
+>v4l2_buf_type</A
+> type; /* buffer type */
+ __u32 flags;
+ __u8 description[32]; /* Description string */
+ __u32 pixelformat; /* Format fourcc */
+ __u32 reserved[4];
+};
+
+#define V4L2_FMT_FLAG_COMPRESSED 0x0001
+
+
+/*
+ * T I M E C O D E
+ */
+struct <A
+HREF="#V4L2-TIMECODE"
+>v4l2_timecode</A
+>
+{
+ __u32 type;
+ __u32 flags;
+ __u8 frames;
+ __u8 seconds;
+ __u8 minutes;
+ __u8 hours;
+ __u8 userbits[4];
+};
+
+/* Type */
+#define V4L2_TC_TYPE_24FPS 1
+#define V4L2_TC_TYPE_25FPS 2
+#define V4L2_TC_TYPE_30FPS 3
+#define V4L2_TC_TYPE_50FPS 4
+#define V4L2_TC_TYPE_60FPS 5
+
+/* Flags */
+#define V4L2_TC_FLAG_DROPFRAME 0x0001 /* "drop-frame" mode */
+#define V4L2_TC_FLAG_COLORFRAME 0x0002
+#define V4L2_TC_USERBITS_field 0x000C
+#define V4L2_TC_USERBITS_USERDEFINED 0x0000
+#define V4L2_TC_USERBITS_8BITCHARS 0x0008
+/* The above is based on SMPTE timecodes */
+
+
+/*
+ * C O M P R E S S I O N P A R A M E T E R S
+ */
+#if 0
+/* ### generic compression settings don't work, there is too much
+ * ### codec-specific stuff. Maybe reuse that for MPEG codec settings
+ * ### later ... */
+struct <A
+HREF="#V4L2-COMPRESSION"
+>v4l2_compression</A
+>
+{
+ __u32 quality;
+ __u32 keyframerate;
+ __u32 pframerate;
+ __u32 reserved[5];
+
+/* what we'll need for MPEG, extracted from some postings on
+ the v4l list (Gert Vervoort, PlasmaJohn).
+
+system stream:
+ - type: elementary stream(ES), packatised elementary stream(s) (PES)
+ program stream(PS), transport stream(TS)
+ - system bitrate
+ - PS packet size (DVD: 2048 bytes, VCD: 2324 bytes)
+ - TS video PID
+ - TS audio PID
+ - TS PCR PID
+ - TS system information tables (PAT, PMT, CAT, NIT and SIT)
+ - (MPEG-1 systems stream vs. MPEG-2 program stream (TS not supported
+ by MPEG-1 systems)
+
+audio:
+ - type: MPEG (+Layer I,II,III), AC-3, LPCM
+ - bitrate
+ - sampling frequency (DVD: 48 Khz, VCD: 44.1 KHz, 32 kHz)
+ - Trick Modes? (ff, rew)
+ - Copyright
+ - Inverse Telecine
+
+video:
+ - picturesize (SIF, 1/2 D1, 2/3 D1, D1) and PAL/NTSC norm can be set
+ through excisting V4L2 controls
+ - noise reduction, parameters encoder specific?
+ - MPEG video version: MPEG-1, MPEG-2
+ - GOP (Group Of Pictures) definition:
+ - N: number of frames per GOP
+ - M: distance between reference (I,P) frames
+ - open/closed GOP
+ - quantiser matrix: inter Q matrix (64 bytes) and intra Q matrix (64 bytes)
+ - quantiser scale: linear or logarithmic
+ - scanning: alternate or zigzag
+ - bitrate mode: CBR (constant bitrate) or VBR (variable bitrate).
+ - target video bitrate for CBR
+ - target video bitrate for VBR
+ - maximum video bitrate for VBR - min. quantiser value for VBR
+ - max. quantiser value for VBR
+ - adaptive quantisation value
+ - return the number of bytes per GOP or bitrate for bitrate monitoring
+
+*/
+};
+#endif
+
+struct <A
+HREF="#V4L2-JPEGCOMPRESSION"
+>v4l2_jpegcompression</A
+>
+{
+ int quality;
+
+ int APPn; /* Number of APP segment to be written,
+ * must be 0..15 */
+ int APP_len; /* Length of data in JPEG APPn segment */
+ char APP_data[60]; /* Data in the JPEG APPn segment. */
+
+ int COM_len; /* Length of data in JPEG COM segment */
+ char COM_data[60]; /* Data in JPEG COM segment */
+
+ __u32 jpeg_markers; /* Which markers should go into the JPEG
+ * output. Unless you exactly know what
+ * you do, leave them untouched.
+ * Inluding less markers will make the
+ * resulting code smaller, but there will
+ * be fewer aplications which can read it.
+ * The presence of the APP and COM marker
+ * is influenced by APP_len and COM_len
+ * ONLY, not by this property! */
+
+#define V4L2_JPEG_MARKER_DHT (1&lt;&lt;3) /* Define Huffman Tables */
+#define V4L2_JPEG_MARKER_DQT (1&lt;&lt;4) /* Define Quantization Tables */
+#define V4L2_JPEG_MARKER_DRI (1&lt;&lt;5) /* Define Restart Interval */
+#define V4L2_JPEG_MARKER_COM (1&lt;&lt;6) /* Comment segment */
+#define V4L2_JPEG_MARKER_APP (1&lt;&lt;7) /* App segment, driver will
+ * allways use APP0 */
+};
+
+
+/*
+ * M E M O R Y - M A P P I N G B U F F E R S
+ */
+struct <A
+HREF="#V4L2-REQUESTBUFFERS"
+>v4l2_requestbuffers</A
+>
+{
+ __u32 count;
+ enum <A
+HREF="#V4L2-BUF-TYPE"
+>v4l2_buf_type</A
+> type;
+ enum <A
+HREF="#V4L2-MEMORY"
+>v4l2_memory</A
+> memory;
+ __u32 reserved[2];
+};
+
+struct <A
+HREF="#V4L2-BUFFER"
+>v4l2_buffer</A
+>
+{
+ __u32 index;
+ enum <A
+HREF="#V4L2-BUF-TYPE"
+>v4l2_buf_type</A
+> type;
+ __u32 bytesused;
+ __u32 flags;
+ enum <A
+HREF="#V4L2-FIELD"
+>v4l2_field</A
+> field;
+ struct timeval timestamp;
+ struct <A
+HREF="#V4L2-TIMECODE"
+>v4l2_timecode</A
+> timecode;
+ __u32 sequence;
+
+ /* memory location */
+ enum <A
+HREF="#V4L2-MEMORY"
+>v4l2_memory</A
+> memory;
+ union {
+ __u32 offset;
+ unsigned long userptr;
+ } m;
+ __u32 length;
+ __u32 input;
+ __u32 reserved;
+};
+
+/* Flags for 'flags' field */
+#define V4L2_BUF_FLAG_MAPPED 0x0001 /* Buffer is mapped (flag) */
+#define V4L2_BUF_FLAG_QUEUED 0x0002 /* Buffer is queued for processing */
+#define V4L2_BUF_FLAG_DONE 0x0004 /* Buffer is ready */
+#define V4L2_BUF_FLAG_KEYFRAME 0x0008 /* Image is a keyframe (I-frame) */
+#define V4L2_BUF_FLAG_PFRAME 0x0010 /* Image is a P-frame */
+#define V4L2_BUF_FLAG_BFRAME 0x0020 /* Image is a B-frame */
+#define V4L2_BUF_FLAG_TIMECODE 0x0100 /* timecode field is valid */
+#define V4L2_BUF_FLAG_INPUT 0x0200 /* input field is valid */
+
+/*
+ * O V E R L A Y P R E V I E W
+ */
+struct <A
+HREF="#V4L2-FRAMEBUFFER"
+>v4l2_framebuffer</A
+>
+{
+ __u32 capability;
+ __u32 flags;
+/* FIXME: in theory we should pass something like PCI device + memory
+ * region + offset instead of some physical address */
+ void* base;
+ struct <A
+HREF="#V4L2-PIX-FORMAT"
+>v4l2_pix_format</A
+> fmt;
+};
+/* Flags for the 'capability' field. Read only */
+#define V4L2_FBUF_CAP_EXTERNOVERLAY 0x0001
+#define V4L2_FBUF_CAP_CHROMAKEY 0x0002
+#define V4L2_FBUF_CAP_LIST_CLIPPING 0x0004
+#define V4L2_FBUF_CAP_BITMAP_CLIPPING 0x0008
+/* Flags for the 'flags' field. */
+#define V4L2_FBUF_FLAG_PRIMARY 0x0001
+#define V4L2_FBUF_FLAG_OVERLAY 0x0002
+#define V4L2_FBUF_FLAG_CHROMAKEY 0x0004
+
+struct <A
+HREF="#V4L2-CLIP"
+>v4l2_clip</A
+>
+{
+ struct <A
+HREF="#V4L2-RECT"
+>v4l2_rect</A
+> c;
+ struct <A
+HREF="#V4L2-CLIP"
+>v4l2_clip</A
+> *next;
+};
+
+struct <A
+HREF="#V4L2-WINDOW"
+>v4l2_window</A
+>
+{
+ struct <A
+HREF="#V4L2-RECT"
+>v4l2_rect</A
+> w;
+ enum <A
+HREF="#V4L2-FIELD"
+>v4l2_field</A
+> field;
+ __u32 chromakey;
+ struct <A
+HREF="#V4L2-CLIP"
+>v4l2_clip</A
+> *clips;
+ __u32 clipcount;
+ void *bitmap;
+};
+
+
+/*
+ * C A P T U R E P A R A M E T E R S
+ */
+struct <A
+HREF="#V4L2-CAPTUREPARM"
+>v4l2_captureparm</A
+>
+{
+ __u32 capability; /* Supported modes */
+ __u32 capturemode; /* Current mode */
+ struct <A
+HREF="#V4L2-FRACT"
+>v4l2_fract</A
+> timeperframe; /* Time per frame in .1us units */
+ __u32 extendedmode; /* Driver-specific extensions */
+ __u32 readbuffers; /* # of buffers for read */
+ __u32 reserved[4];
+};
+/* Flags for 'capability' and 'capturemode' fields */
+#define V4L2_MODE_HIGHQUALITY 0x0001 /* High quality imaging mode */
+#define V4L2_CAP_TIMEPERFRAME 0x1000 /* timeperframe field is supported */
+
+struct <A
+HREF="#V4L2-OUTPUTPARM"
+>v4l2_outputparm</A
+>
+{
+ __u32 capability; /* Supported modes */
+ __u32 outputmode; /* Current mode */
+ struct <A
+HREF="#V4L2-FRACT"
+>v4l2_fract</A
+> timeperframe; /* Time per frame in seconds */
+ __u32 extendedmode; /* Driver-specific extensions */
+ __u32 writebuffers; /* # of buffers for write */
+ __u32 reserved[4];
+};
+
+/*
+ * I N P U T I M A G E C R O P P I N G
+ */
+
+struct <A
+HREF="#V4L2-CROPCAP"
+>v4l2_cropcap</A
+> {
+ enum <A
+HREF="#V4L2-BUF-TYPE"
+>v4l2_buf_type</A
+> type;
+ struct <A
+HREF="#V4L2-RECT"
+>v4l2_rect</A
+> bounds;
+ struct <A
+HREF="#V4L2-RECT"
+>v4l2_rect</A
+> defrect;
+ struct <A
+HREF="#V4L2-FRACT"
+>v4l2_fract</A
+> pixelaspect;
+};
+
+struct <A
+HREF="#V4L2-CROP"
+>v4l2_crop</A
+> {
+ enum <A
+HREF="#V4L2-BUF-TYPE"
+>v4l2_buf_type</A
+> type;
+ struct <A
+HREF="#V4L2-RECT"
+>v4l2_rect</A
+> c;
+};
+
+/*
+ * A N A L O G V I D E O S T A N D A R D
+ */
+
+typedef __u64 v4l2_std_id;
+
+/* one bit for each */
+#define V4L2_STD_PAL_B ((v4l2_std_id)0x00000001)
+#define V4L2_STD_PAL_B1 ((v4l2_std_id)0x00000002)
+#define V4L2_STD_PAL_G ((v4l2_std_id)0x00000004)
+#define V4L2_STD_PAL_H ((v4l2_std_id)0x00000008)
+#define V4L2_STD_PAL_I ((v4l2_std_id)0x00000010)
+#define V4L2_STD_PAL_D ((v4l2_std_id)0x00000020)
+#define V4L2_STD_PAL_D1 ((v4l2_std_id)0x00000040)
+#define V4L2_STD_PAL_K ((v4l2_std_id)0x00000080)
+
+#define V4L2_STD_PAL_M ((v4l2_std_id)0x00000100)
+#define V4L2_STD_PAL_N ((v4l2_std_id)0x00000200)
+#define V4L2_STD_PAL_Nc ((v4l2_std_id)0x00000400)
+#define V4L2_STD_PAL_60 ((v4l2_std_id)0x00000800)
+
+#define V4L2_STD_NTSC_M ((v4l2_std_id)0x00001000)
+#define V4L2_STD_NTSC_M_JP ((v4l2_std_id)0x00002000)
+
+#define V4L2_STD_SECAM_B ((v4l2_std_id)0x00010000)
+#define V4L2_STD_SECAM_D ((v4l2_std_id)0x00020000)
+#define V4L2_STD_SECAM_G ((v4l2_std_id)0x00040000)
+#define V4L2_STD_SECAM_H ((v4l2_std_id)0x00080000)
+#define V4L2_STD_SECAM_K ((v4l2_std_id)0x00100000)
+#define V4L2_STD_SECAM_K1 ((v4l2_std_id)0x00200000)
+#define V4L2_STD_SECAM_L ((v4l2_std_id)0x00400000)
+
+/* ATSC/HDTV */
+#define V4L2_STD_ATSC_8_VSB ((v4l2_std_id)0x01000000)
+#define V4L2_STD_ATSC_16_VSB ((v4l2_std_id)0x02000000)
+
+/* some common needed stuff */
+#define V4L2_STD_PAL_BG (V4L2_STD_PAL_B |\
+ V4L2_STD_PAL_B1 |\
+ V4L2_STD_PAL_G)
+#define V4L2_STD_PAL_DK (V4L2_STD_PAL_D |\
+ V4L2_STD_PAL_D1 |\
+ V4L2_STD_PAL_K)
+#define V4L2_STD_PAL (V4L2_STD_PAL_BG |\
+ V4L2_STD_PAL_DK |\
+ V4L2_STD_PAL_H |\
+ V4L2_STD_PAL_I)
+#define V4L2_STD_NTSC (V4L2_STD_NTSC_M |\
+ V4L2_STD_NTSC_M_JP)
+#define V4L2_STD_SECAM (V4L2_STD_SECAM_B |\
+ V4L2_STD_SECAM_D |\
+ V4L2_STD_SECAM_G |\
+ V4L2_STD_SECAM_H |\
+ V4L2_STD_SECAM_K |\
+ V4L2_STD_SECAM_K1 |\
+ V4L2_STD_SECAM_L)
+
+#define V4L2_STD_525_60 (V4L2_STD_PAL_M |\
+ V4L2_STD_PAL_60 |\
+ V4L2_STD_NTSC)
+#define V4L2_STD_625_50 (V4L2_STD_PAL |\
+ V4L2_STD_PAL_N |\
+ V4L2_STD_PAL_Nc |\
+ V4L2_STD_SECAM)
+
+#define V4L2_STD_UNKNOWN 0
+#define V4L2_STD_ALL (V4L2_STD_525_60 |\
+ V4L2_STD_625_50)
+
+struct <A
+HREF="#V4L2-STANDARD"
+>v4l2_standard</A
+>
+{
+ __u32 index;
+ v4l2_std_id id;
+ __u8 name[24];
+ struct <A
+HREF="#V4L2-FRACT"
+>v4l2_fract</A
+> frameperiod; /* Frames, not fields */
+ __u32 framelines;
+ __u32 reserved[4];
+};
+
+
+/*
+ * V I D E O I N P U T S
+ */
+struct <A
+HREF="#V4L2-INPUT"
+>v4l2_input</A
+>
+{
+ __u32 index; /* Which input */
+ __u8 name[32]; /* Label */
+ __u32 type; /* Type of input */
+ __u32 audioset; /* Associated audios (bitfield) */
+ __u32 tuner; /* Associated tuner */
+ v4l2_std_id std;
+ __u32 status;
+ __u32 reserved[4];
+};
+/* Values for the 'type' field */
+#define V4L2_INPUT_TYPE_TUNER 1
+#define V4L2_INPUT_TYPE_CAMERA 2
+
+/* field 'status' - general */
+#define V4L2_IN_ST_NO_POWER 0x00000001 /* Attached device is off */
+#define V4L2_IN_ST_NO_SIGNAL 0x00000002
+#define V4L2_IN_ST_NO_COLOR 0x00000004
+
+/* field 'status' - analog */
+#define V4L2_IN_ST_NO_H_LOCK 0x00000100 /* No horizontal sync lock */
+#define V4L2_IN_ST_COLOR_KILL 0x00000200 /* Color killer is active */
+
+/* field 'status' - digital */
+#define V4L2_IN_ST_NO_SYNC 0x00010000 /* No synchronization lock */
+#define V4L2_IN_ST_NO_EQU 0x00020000 /* No equalizer lock */
+#define V4L2_IN_ST_NO_CARRIER 0x00040000 /* Carrier recovery failed */
+
+/* field 'status' - VCR and set-top box */
+#define V4L2_IN_ST_MACROVISION 0x01000000 /* Macrovision detected */
+#define V4L2_IN_ST_NO_ACCESS 0x02000000 /* Conditional access denied */
+#define V4L2_IN_ST_VTR 0x04000000 /* VTR time constant */
+
+/*
+ * V I D E O O U T P U T S
+ */
+struct <A
+HREF="#V4L2-OUTPUT"
+>v4l2_output</A
+>
+{
+ __u32 index; /* Which output */
+ __u8 name[32]; /* Label */
+ __u32 type; /* Type of output */
+ __u32 audioset; /* Associated audios (bitfield) */
+ __u32 modulator; /* Associated modulator */
+ v4l2_std_id std;
+ __u32 reserved[4];
+};
+/* Values for the 'type' field */
+#define V4L2_OUTPUT_TYPE_MODULATOR 1
+#define V4L2_OUTPUT_TYPE_ANALOG 2
+#define V4L2_OUTPUT_TYPE_ANALOGVGAOVERLAY 3
+
+/*
+ * C O N T R O L S
+ */
+struct <A
+HREF="#V4L2-CONTROL"
+>v4l2_control</A
+>
+{
+ __u32 id;
+ __s32 value;
+};
+
+/* Used in the VIDIOC_QUERYCTRL ioctl for querying controls */
+struct <A
+HREF="#V4L2-QUERYCTRL"
+>v4l2_queryctrl</A
+>
+{
+ __u32 id;
+ enum <A
+HREF="#V4L2-CTRL-TYPE"
+>v4l2_ctrl_type</A
+> type;
+ __u8 name[32]; /* Whatever */
+ __s32 minimum; /* Note signedness */
+ __s32 maximum;
+ __s32 step;
+ __s32 default_value;
+ __u32 flags;
+ __u32 reserved[2];
+};
+
+/* Used in the VIDIOC_QUERYMENU ioctl for querying menu items */
+struct <A
+HREF="#V4L2-QUERYMENU"
+>v4l2_querymenu</A
+>
+{
+ __u32 id;
+ __u32 index;
+ __u8 name[32]; /* Whatever */
+ __u32 reserved;
+};
+
+/* Control flags */
+#define V4L2_CTRL_FLAG_DISABLED 0x0001
+#define V4L2_CTRL_FLAG_GRABBED 0x0002
+
+/* Control IDs defined by V4L2 */
+#define V4L2_CID_BASE 0x00980900
+/* IDs reserved for driver specific controls */
+#define V4L2_CID_PRIVATE_BASE 0x08000000
+
+#define V4L2_CID_BRIGHTNESS (V4L2_CID_BASE+0)
+#define V4L2_CID_CONTRAST (V4L2_CID_BASE+1)
+#define V4L2_CID_SATURATION (V4L2_CID_BASE+2)
+#define V4L2_CID_HUE (V4L2_CID_BASE+3)
+#define V4L2_CID_AUDIO_VOLUME (V4L2_CID_BASE+5)
+#define V4L2_CID_AUDIO_BALANCE (V4L2_CID_BASE+6)
+#define V4L2_CID_AUDIO_BASS (V4L2_CID_BASE+7)
+#define V4L2_CID_AUDIO_TREBLE (V4L2_CID_BASE+8)
+#define V4L2_CID_AUDIO_MUTE (V4L2_CID_BASE+9)
+#define V4L2_CID_AUDIO_LOUDNESS (V4L2_CID_BASE+10)
+#define V4L2_CID_BLACK_LEVEL (V4L2_CID_BASE+11)
+#define V4L2_CID_AUTO_WHITE_BALANCE (V4L2_CID_BASE+12)
+#define V4L2_CID_DO_WHITE_BALANCE (V4L2_CID_BASE+13)
+#define V4L2_CID_RED_BALANCE (V4L2_CID_BASE+14)
+#define V4L2_CID_BLUE_BALANCE (V4L2_CID_BASE+15)
+#define V4L2_CID_GAMMA (V4L2_CID_BASE+16)
+#define V4L2_CID_WHITENESS (V4L2_CID_GAMMA) /* ? Not sure */
+#define V4L2_CID_EXPOSURE (V4L2_CID_BASE+17)
+#define V4L2_CID_AUTOGAIN (V4L2_CID_BASE+18)
+#define V4L2_CID_GAIN (V4L2_CID_BASE+19)
+#define V4L2_CID_HFLIP (V4L2_CID_BASE+20)
+#define V4L2_CID_VFLIP (V4L2_CID_BASE+21)
+#define V4L2_CID_HCENTER (V4L2_CID_BASE+22)
+#define V4L2_CID_VCENTER (V4L2_CID_BASE+23)
+#define V4L2_CID_LASTP1 (V4L2_CID_BASE+24) /* last CID + 1 */
+
+/*
+ * T U N I N G
+ */
+struct <A
+HREF="#V4L2-TUNER"
+>v4l2_tuner</A
+>
+{
+ __u32 index;
+ __u8 name[32];
+ enum <A
+HREF="#V4L2-TUNER-TYPE"
+>v4l2_tuner_type</A
+> type;
+ __u32 capability;
+ __u32 rangelow;
+ __u32 rangehigh;
+ __u32 rxsubchans;
+ __u32 audmode;
+ __s32 signal;
+ __s32 afc;
+ __u32 reserved[4];
+};
+
+struct <A
+HREF="#V4L2-MODULATOR"
+>v4l2_modulator</A
+>
+{
+ __u32 index;
+ __u8 name[32];
+ __u32 capability;
+ __u32 rangelow;
+ __u32 rangehigh;
+ __u32 txsubchans;
+ __u32 reserved[4];
+};
+
+/* Flags for the 'capability' field */
+#define V4L2_TUNER_CAP_LOW 0x0001
+#define V4L2_TUNER_CAP_NORM 0x0002
+#define V4L2_TUNER_CAP_STEREO 0x0010
+#define V4L2_TUNER_CAP_LANG2 0x0020
+#define V4L2_TUNER_CAP_SAP 0x0020
+#define V4L2_TUNER_CAP_LANG1 0x0040
+
+/* Flags for the 'rxsubchans' field */
+#define V4L2_TUNER_SUB_MONO 0x0001
+#define V4L2_TUNER_SUB_STEREO 0x0002
+#define V4L2_TUNER_SUB_LANG2 0x0004
+#define V4L2_TUNER_SUB_SAP 0x0004
+#define V4L2_TUNER_SUB_LANG1 0x0008
+
+/* Values for the 'audmode' field */
+#define V4L2_TUNER_MODE_MONO 0x0000
+#define V4L2_TUNER_MODE_STEREO 0x0001
+#define V4L2_TUNER_MODE_LANG2 0x0002
+#define V4L2_TUNER_MODE_SAP 0x0002
+#define V4L2_TUNER_MODE_LANG1 0x0003
+
+struct <A
+HREF="#V4L2-FREQUENCY"
+>v4l2_frequency</A
+>
+{
+ __u32 tuner;
+ enum <A
+HREF="#V4L2-TUNER-TYPE"
+>v4l2_tuner_type</A
+> type;
+ __u32 frequency;
+ __u32 reserved[8];
+};
+
+/*
+ * A U D I O
+ */
+struct <A
+HREF="#V4L2-AUDIO"
+>v4l2_audio</A
+>
+{
+ __u32 index;
+ __u8 name[32];
+ __u32 capability;
+ __u32 mode;
+ __u32 reserved[2];
+};
+/* Flags for the 'capability' field */
+#define V4L2_AUDCAP_STEREO 0x00001
+#define V4L2_AUDCAP_AVL 0x00002
+
+/* Flags for the 'mode' field */
+#define V4L2_AUDMODE_AVL 0x00001
+
+struct <A
+HREF="#V4L2-AUDIOOUT"
+>v4l2_audioout</A
+>
+{
+ __u32 index;
+ __u8 name[32];
+ __u32 capability;
+ __u32 mode;
+ __u32 reserved[2];
+};
+
+/*
+ * D A T A S E R V I C E S ( V B I )
+ *
+ * Data services API by Michael Schimek
+ */
+
+struct <A
+HREF="#V4L2-VBI-FORMAT"
+>v4l2_vbi_format</A
+>
+{
+ __u32 sampling_rate; /* in 1 Hz */
+ __u32 offset;
+ __u32 samples_per_line;
+ __u32 sample_format; /* V4L2_PIX_FMT_* */
+ __s32 start[2];
+ __u32 count[2];
+ __u32 flags; /* V4L2_VBI_* */
+ __u32 reserved[2]; /* must be zero */
+};
+
+/* VBI flags */
+#define V4L2_VBI_UNSYNC (1&lt;&lt; 0)
+#define V4L2_VBI_INTERLACED (1&lt;&lt; 1)
+
+
+/*
+ * A G G R E G A T E S T R U C T U R E S
+ */
+
+/* Stream data format
+ */
+struct <A
+HREF="#V4L2-FORMAT"
+>v4l2_format</A
+>
+{
+ enum <A
+HREF="#V4L2-BUF-TYPE"
+>v4l2_buf_type</A
+> type;
+ union
+ {
+ struct <A
+HREF="#V4L2-PIX-FORMAT"
+>v4l2_pix_format</A
+> pix; // V4L2_BUF_TYPE_VIDEO_CAPTURE
+ struct <A
+HREF="#V4L2-WINDOW"
+>v4l2_window</A
+> win; // V4L2_BUF_TYPE_VIDEO_OVERLAY
+ struct <A
+HREF="#V4L2-VBI-FORMAT"
+>v4l2_vbi_format</A
+> vbi; // V4L2_BUF_TYPE_VBI_CAPTURE
+ __u8 raw_data[200]; // user-defined
+ } fmt;
+};
+
+
+/* Stream type-dependent parameters
+ */
+struct <A
+HREF="#V4L2-STREAMPARM"
+>v4l2_streamparm</A
+>
+{
+ enum <A
+HREF="#V4L2-BUF-TYPE"
+>v4l2_buf_type</A
+> type;
+ union
+ {
+ struct <A
+HREF="#V4L2-CAPTUREPARM"
+>v4l2_captureparm</A
+> capture;
+ struct <A
+HREF="#V4L2-OUTPUTPARM"
+>v4l2_outputparm</A
+> output;
+ __u8 raw_data[200]; /* user-defined */
+ } parm;
+};
+
+
+
+/*
+ * I O C T L C O D E S F O R V I D E O D E V I C E S
+ *
+ */
+#define VIDIOC_QUERYCAP _IOR ('V', 0, struct <A
+HREF="#V4L2-CAPABILITY"
+>v4l2_capability</A
+>)
+#define VIDIOC_RESERVED _IO ('V', 1)
+#define VIDIOC_ENUM_FMT _IOWR ('V', 2, struct <A
+HREF="#V4L2-FMTDESC"
+>v4l2_fmtdesc</A
+>)
+#define VIDIOC_G_FMT _IOWR ('V', 4, struct <A
+HREF="#V4L2-FORMAT"
+>v4l2_format</A
+>)
+#define VIDIOC_S_FMT _IOWR ('V', 5, struct <A
+HREF="#V4L2-FORMAT"
+>v4l2_format</A
+>)
+#if 0
+#define VIDIOC_G_COMP _IOR ('V', 6, struct <A
+HREF="#V4L2-COMPRESSION"
+>v4l2_compression</A
+>)
+#define VIDIOC_S_COMP _IOW ('V', 7, struct <A
+HREF="#V4L2-COMPRESSION"
+>v4l2_compression</A
+>)
+#endif
+#define VIDIOC_REQBUFS _IOWR ('V', 8, struct <A
+HREF="#V4L2-REQUESTBUFFERS"
+>v4l2_requestbuffers</A
+>)
+#define VIDIOC_QUERYBUF _IOWR ('V', 9, struct <A
+HREF="#V4L2-BUFFER"
+>v4l2_buffer</A
+>)
+#define VIDIOC_G_FBUF _IOR ('V', 10, struct <A
+HREF="#V4L2-FRAMEBUFFER"
+>v4l2_framebuffer</A
+>)
+#define VIDIOC_S_FBUF _IOW ('V', 11, struct <A
+HREF="#V4L2-FRAMEBUFFER"
+>v4l2_framebuffer</A
+>)
+#define VIDIOC_OVERLAY _IOW ('V', 14, int)
+#define VIDIOC_QBUF _IOWR ('V', 15, struct <A
+HREF="#V4L2-BUFFER"
+>v4l2_buffer</A
+>)
+#define VIDIOC_DQBUF _IOWR ('V', 17, struct <A
+HREF="#V4L2-BUFFER"
+>v4l2_buffer</A
+>)
+#define VIDIOC_STREAMON _IOW ('V', 18, int)
+#define VIDIOC_STREAMOFF _IOW ('V', 19, int)
+#define VIDIOC_G_PARM _IOWR ('V', 21, struct <A
+HREF="#V4L2-STREAMPARM"
+>v4l2_streamparm</A
+>)
+#define VIDIOC_S_PARM _IOWR ('V', 22, struct <A
+HREF="#V4L2-STREAMPARM"
+>v4l2_streamparm</A
+>)
+#define VIDIOC_G_STD _IOR ('V', 23, v4l2_std_id)
+#define VIDIOC_S_STD _IOW ('V', 24, v4l2_std_id)
+#define VIDIOC_ENUMSTD _IOWR ('V', 25, struct <A
+HREF="#V4L2-STANDARD"
+>v4l2_standard</A
+>)
+#define VIDIOC_ENUMINPUT _IOWR ('V', 26, struct <A
+HREF="#V4L2-INPUT"
+>v4l2_input</A
+>)
+#define VIDIOC_G_CTRL _IOWR ('V', 27, struct <A
+HREF="#V4L2-CONTROL"
+>v4l2_control</A
+>)
+#define VIDIOC_S_CTRL _IOWR ('V', 28, struct <A
+HREF="#V4L2-CONTROL"
+>v4l2_control</A
+>)
+#define VIDIOC_G_TUNER _IOWR ('V', 29, struct <A
+HREF="#V4L2-TUNER"
+>v4l2_tuner</A
+>)
+#define VIDIOC_S_TUNER _IOW ('V', 30, struct <A
+HREF="#V4L2-TUNER"
+>v4l2_tuner</A
+>)
+#define VIDIOC_G_AUDIO _IOR ('V', 33, struct <A
+HREF="#V4L2-AUDIO"
+>v4l2_audio</A
+>)
+#define VIDIOC_S_AUDIO _IOW ('V', 34, struct <A
+HREF="#V4L2-AUDIO"
+>v4l2_audio</A
+>)
+#define VIDIOC_QUERYCTRL _IOWR ('V', 36, struct <A
+HREF="#V4L2-QUERYCTRL"
+>v4l2_queryctrl</A
+>)
+#define VIDIOC_QUERYMENU _IOWR ('V', 37, struct <A
+HREF="#V4L2-QUERYMENU"
+>v4l2_querymenu</A
+>)
+#define VIDIOC_G_INPUT _IOR ('V', 38, int)
+#define VIDIOC_S_INPUT _IOWR ('V', 39, int)
+#define VIDIOC_G_OUTPUT _IOR ('V', 46, int)
+#define VIDIOC_S_OUTPUT _IOWR ('V', 47, int)
+#define VIDIOC_ENUMOUTPUT _IOWR ('V', 48, struct <A
+HREF="#V4L2-OUTPUT"
+>v4l2_output</A
+>)
+#define VIDIOC_G_AUDOUT _IOR ('V', 49, struct <A
+HREF="#V4L2-AUDIOOUT"
+>v4l2_audioout</A
+>)
+#define VIDIOC_S_AUDOUT _IOW ('V', 50, struct <A
+HREF="#V4L2-AUDIOOUT"
+>v4l2_audioout</A
+>)
+#define VIDIOC_G_MODULATOR _IOWR ('V', 54, struct <A
+HREF="#V4L2-MODULATOR"
+>v4l2_modulator</A
+>)
+#define VIDIOC_S_MODULATOR _IOW ('V', 55, struct <A
+HREF="#V4L2-MODULATOR"
+>v4l2_modulator</A
+>)
+#define VIDIOC_G_FREQUENCY _IOWR ('V', 56, struct <A
+HREF="#V4L2-FREQUENCY"
+>v4l2_frequency</A
+>)
+#define VIDIOC_S_FREQUENCY _IOW ('V', 57, struct <A
+HREF="#V4L2-FREQUENCY"
+>v4l2_frequency</A
+>)
+#define VIDIOC_CROPCAP _IOWR ('V', 58, struct <A
+HREF="#V4L2-CROPCAP"
+>v4l2_cropcap</A
+>)
+#define VIDIOC_G_CROP _IOWR ('V', 59, struct <A
+HREF="#V4L2-CROP"
+>v4l2_crop</A
+>)
+#define VIDIOC_S_CROP _IOW ('V', 60, struct <A
+HREF="#V4L2-CROP"
+>v4l2_crop</A
+>)
+#define VIDIOC_G_JPEGCOMP _IOR ('V', 61, struct <A
+HREF="#V4L2-JPEGCOMPRESSION"
+>v4l2_jpegcompression</A
+>)
+#define VIDIOC_S_JPEGCOMP _IOW ('V', 62, struct <A
+HREF="#V4L2-JPEGCOMPRESSION"
+>v4l2_jpegcompression</A
+>)
+#define VIDIOC_QUERYSTD _IOR ('V', 63, v4l2_std_id)
+#define VIDIOC_TRY_FMT _IOWR ('V', 64, struct <A
+HREF="#V4L2-FORMAT"
+>v4l2_format</A
+>)
+#define VIDIOC_ENUMAUDIO _IOWR ('V', 65, struct <A
+HREF="#V4L2-AUDIO"
+>v4l2_audio</A
+>)
+#define VIDIOC_ENUMAUDOUT _IOWR ('V', 66, struct <A
+HREF="#V4L2-AUDIOOUT"
+>v4l2_audioout</A
+>)
+#define VIDIOC_G_PRIORITY _IOR ('V', 67, enum <A
+HREF="#V4L2-PRIORITY"
+>v4l2_priority</A
+>)
+#define VIDIOC_S_PRIORITY _IOW ('V', 68, enum <A
+HREF="#V4L2-PRIORITY"
+>v4l2_priority</A
+>)
+
+/* for compatibility, will go away some day */
+#define VIDIOC_OVERLAY_OLD _IOWR ('V', 14, int)
+#define VIDIOC_S_PARM_OLD _IOW ('V', 22, struct <A
+HREF="#V4L2-STREAMPARM"
+>v4l2_streamparm</A
+>)
+#define VIDIOC_S_CTRL_OLD _IOW ('V', 28, struct <A
+HREF="#V4L2-CONTROL"
+>v4l2_control</A
+>)
+#define VIDIOC_G_AUDIO_OLD _IOWR ('V', 33, struct <A
+HREF="#V4L2-AUDIO"
+>v4l2_audio</A
+>)
+#define VIDIOC_G_AUDOUT_OLD _IOWR ('V', 49, struct <A
+HREF="#V4L2-AUDIOOUT"
+>v4l2_audioout</A
+>)
+#define VIDIOC_CROPCAP_OLD _IOR ('V', 58, struct <A
+HREF="#V4L2-CROPCAP"
+>v4l2_cropcap</A
+>)
+
+#define BASE_VIDIOC_PRIVATE 192 /* 192-255 are private */
+
+
+#ifdef __KERNEL__
+/*
+ *
+ * V 4 L 2 D R I V E R H E L P E R A P I
+ *
+ * Some commonly needed functions for drivers (v4l2-common.o module)
+ */
+#include &lt;linux/fs.h&gt;
+
+/* Video standard functions */
+extern unsigned int v4l2_video_std_fps(struct <A
+HREF="#V4L2-STANDARD"
+>v4l2_standard</A
+> *vs);
+extern int v4l2_video_std_construct(struct <A
+HREF="#V4L2-STANDARD"
+>v4l2_standard</A
+> *vs,
+ int id, char *name);
+
+/* prority handling */
+struct&nbsp;v4l2_prio_state {
+ atomic_t prios[4];
+};
+int v4l2_prio_init(struct&nbsp;v4l2_prio_state *global);
+int v4l2_prio_change(struct&nbsp;v4l2_prio_state *global, enum <A
+HREF="#V4L2-PRIORITY"
+>v4l2_priority</A
+> *local,
+ enum <A
+HREF="#V4L2-PRIORITY"
+>v4l2_priority</A
+> new);
+int v4l2_prio_open(struct&nbsp;v4l2_prio_state *global, enum <A
+HREF="#V4L2-PRIORITY"
+>v4l2_priority</A
+> *local);
+int v4l2_prio_close(struct&nbsp;v4l2_prio_state *global, enum <A
+HREF="#V4L2-PRIORITY"
+>v4l2_priority</A
+> *local);
+enum <A
+HREF="#V4L2-PRIORITY"
+>v4l2_priority</A
+> v4l2_prio_max(struct&nbsp;v4l2_prio_state *global);
+int v4l2_prio_check(struct&nbsp;v4l2_prio_state *global, enum <A
+HREF="#V4L2-PRIORITY"
+>v4l2_priority</A
+> *local);
+
+/* names for fancy debug output */
+extern char *v4l2_field_names[];
+extern char *v4l2_type_names[];
+extern char *v4l2_ioctl_names[];
+
+/* Compatibility layer interface -- v4l1-compat module */
+typedef int (*v4l2_kioctl)(struct inode *inode, struct file *file,
+ unsigned int cmd, void *arg);
+int v4l_compat_translate_ioctl(struct inode *inode, struct file *file,
+ int cmd, void *arg, v4l2_kioctl driver_ioctl);
+
+#endif /* __KERNEL__ */
+#endif /* __LINUX_VIDEODEV2_H */
+
+/*
+ * Local variables:
+ * c-basic-offset: 8
+ * End:
+ */</PRE
+></DIV
+><DIV
+CLASS="APPENDIX"
+><HR><H1
+><A
+NAME="CAPTURE-EXAMPLE"
+></A
+>Appendix B. Video Capture Example</H1
+><PRE
+CLASS="PROGRAMLISTING"
+>/*
+ * V4L2 video capture example
+ */
+
+#include &lt;stdio.h&gt;
+#include &lt;stdlib.h&gt;
+#include &lt;string.h&gt;
+#include &lt;assert.h&gt;
+
+#include &lt;getopt.h&gt; /* getopt_long() */
+
+#include &lt;fcntl.h&gt; /* low-level i/o */
+#include &lt;unistd.h&gt;
+#include &lt;errno.h&gt;
+#include &lt;sys/stat.h&gt;
+#include &lt;sys/types.h&gt;
+#include &lt;sys/time.h&gt;
+#include &lt;sys/mman.h&gt;
+#include &lt;sys/ioctl.h&gt;
+
+#include &lt;asm/types.h&gt; /* for videodev2.h */
+
+#include &lt;linux/videodev2.h&gt;
+
+#define CLEAR(x) memset (&amp;(x), 0, sizeof (x))
+
+typedef enum {
+ IO_METHOD_READ,
+ IO_METHOD_MMAP,
+ IO_METHOD_USERPTR,
+} io_method;
+
+struct buffer {
+ void * start;
+ size_t length;
+};
+
+static char * dev_name = NULL;
+static io_method io = IO_METHOD_MMAP;
+static int fd = -1;
+struct buffer * buffers = NULL;
+static unsigned int n_buffers = 0;
+
+static void
+errno_exit (const char * s)
+{
+ fprintf (stderr, "%s error %d, %s\n",
+ s, errno, strerror (errno));
+
+ exit (EXIT_FAILURE);
+}
+
+static int
+xioctl (int fd,
+ int request,
+ void * arg)
+{
+ int r;
+
+ do r = ioctl (fd, request, arg);
+ while (-1 == r &amp;&amp; EINTR == errno);
+
+ return r;
+}
+
+static void
+process_image (const void * p)
+{
+ fputc ('.', stdout);
+ fflush (stdout);
+}
+
+static int
+read_frame (void)
+{
+ struct <A
+HREF="#V4L2-BUFFER"
+>v4l2_buffer</A
+> buf;
+ unsigned int i;
+
+ switch (io) {
+ case IO_METHOD_READ:
+ if (-1 == read (fd, buffers[0].start, buffers[0].length)) {
+ switch (errno) {
+ case EAGAIN:
+ return 0;
+
+ case EIO:
+ /* Could ignore EIO, see spec. */
+
+ /* fall through */
+
+ default:
+ errno_exit ("read");
+ }
+ }
+
+ process_image (buffers[0].start);
+
+ break;
+
+ case IO_METHOD_MMAP:
+ CLEAR (buf);
+
+ buf.type = V4L2_BUF_TYPE_VIDEO_CAPTURE;
+ buf.memory = V4L2_MEMORY_MMAP;
+
+ if (-1 == xioctl (fd, VIDIOC_DQBUF, &amp;buf)) {
+ switch (errno) {
+ case EAGAIN:
+ return 0;
+
+ case EIO:
+ /* Could ignore EIO, see spec. */
+
+ /* fall through */
+
+ default:
+ errno_exit ("VIDIOC_DQBUF");
+ }
+ }
+
+ assert (buf.index &lt; n_buffers);
+
+ process_image (buffers[buf.index].start);
+
+ if (-1 == xioctl (fd, VIDIOC_QBUF, &amp;buf))
+ errno_exit ("VIDIOC_QBUF");
+
+ break;
+
+ case IO_METHOD_USERPTR:
+ CLEAR (buf);
+
+ buf.type = V4L2_BUF_TYPE_VIDEO_CAPTURE;
+ buf.memory = V4L2_MEMORY_USERPTR;
+
+ if (-1 == xioctl (fd, VIDIOC_DQBUF, &amp;buf)) {
+ switch (errno) {
+ case EAGAIN:
+ return 0;
+
+ case EIO:
+ /* Could ignore EIO, see spec. */
+
+ /* fall through */
+
+ default:
+ errno_exit ("VIDIOC_DQBUF");
+ }
+ }
+
+ for (i = 0; i &lt; n_buffers; ++i)
+ if (buf.m.userptr == (unsigned long) buffers[i].start
+ &amp;&amp; buf.length == buffers[i].length)
+ break;
+
+ assert (i &lt; n_buffers);
+
+ process_image ((void *) buf.m.userptr);
+
+ if (-1 == xioctl (fd, VIDIOC_QBUF, &amp;buf))
+ errno_exit ("VIDIOC_QBUF");
+
+ break;
+ }
+
+ return 1;
+}
+
+static void
+mainloop (void)
+{
+ unsigned int count;
+
+ count = 100;
+
+ while (count-- &gt; 0) {
+ for (;;) {
+ fd_set fds;
+ struct timeval tv;
+ int r;
+
+ FD_ZERO (&amp;fds);
+ FD_SET (fd, &amp;fds);
+
+ /* Timeout. */
+ tv.tv_sec = 2;
+ tv.tv_usec = 0;
+
+ r = select (fd + 1, &amp;fds, NULL, NULL, &amp;tv);
+
+ if (-1 == r) {
+ if (EINTR == errno)
+ continue;
+
+ errno_exit ("select");
+ }
+
+ if (0 == r) {
+ fprintf (stderr, "select timeout\n");
+ exit (EXIT_FAILURE);
+ }
+
+ if (read_frame ())
+ break;
+
+ /* EAGAIN - continue select loop. */
+ }
+ }
+}
+
+static void
+stop_capturing (void)
+{
+ enum <A
+HREF="#V4L2-BUF-TYPE"
+>v4l2_buf_type</A
+> type;
+
+ switch (io) {
+ case IO_METHOD_READ:
+ /* Nothing to do. */
+ break;
+
+ case IO_METHOD_MMAP:
+ case IO_METHOD_USERPTR:
+ type = V4L2_BUF_TYPE_VIDEO_CAPTURE;
+
+ if (-1 == xioctl (fd, VIDIOC_STREAMOFF, &amp;type))
+ errno_exit ("VIDIOC_STREAMOFF");
+
+ break;
+ }
+}
+
+static void
+start_capturing (void)
+{
+ unsigned int i;
+ enum <A
+HREF="#V4L2-BUF-TYPE"
+>v4l2_buf_type</A
+> type;
+
+ switch (io) {
+ case IO_METHOD_READ:
+ /* Nothing to do. */
+ break;
+
+ case IO_METHOD_MMAP:
+ for (i = 0; i &lt; n_buffers; ++i) {
+ struct <A
+HREF="#V4L2-BUFFER"
+>v4l2_buffer</A
+> buf;
+
+ CLEAR (buf);
+
+ buf.type = V4L2_BUF_TYPE_VIDEO_CAPTURE;
+ buf.memory = V4L2_MEMORY_MMAP;
+ buf.index = i;
+
+ if (-1 == xioctl (fd, VIDIOC_QBUF, &amp;buf))
+ errno_exit ("VIDIOC_QBUF");
+ }
+
+ type = V4L2_BUF_TYPE_VIDEO_CAPTURE;
+
+ if (-1 == xioctl (fd, VIDIOC_STREAMON, &amp;type))
+ errno_exit ("VIDIOC_STREAMON");
+
+ break;
+
+ case IO_METHOD_USERPTR:
+ for (i = 0; i &lt; n_buffers; ++i) {
+ struct <A
+HREF="#V4L2-BUFFER"
+>v4l2_buffer</A
+> buf;
+
+ CLEAR (buf);
+
+ buf.type = V4L2_BUF_TYPE_VIDEO_CAPTURE;
+ buf.memory = V4L2_MEMORY_USERPTR;
+ buf.m.userptr = (unsigned long) buffers[i].start;
+ buf.length = buffers[i].length;
+
+ if (-1 == xioctl (fd, VIDIOC_QBUF, &amp;buf))
+ errno_exit ("VIDIOC_QBUF");
+ }
+
+
+ type = V4L2_BUF_TYPE_VIDEO_CAPTURE;
+
+ if (-1 == xioctl (fd, VIDIOC_STREAMON, &amp;type))
+ errno_exit ("VIDIOC_STREAMON");
+
+ break;
+ }
+}
+
+static void
+uninit_device (void)
+{
+ unsigned int i;
+
+ switch (io) {
+ case IO_METHOD_READ:
+ free (buffers[0].start);
+ break;
+
+ case IO_METHOD_MMAP:
+ for (i = 0; i &lt; n_buffers; ++i)
+ if (-1 == munmap (buffers[i].start, buffers[i].length))
+ errno_exit ("munmap");
+ break;
+
+ case IO_METHOD_USERPTR:
+ for (i = 0; i &lt; n_buffers; ++i)
+ free (buffers[i].start);
+ break;
+ }
+
+ free (buffers);
+}
+
+static void
+init_read (unsigned int buffer_size)
+{
+ buffers = calloc (1, sizeof (*buffers));
+
+ if (!buffers) {
+ fprintf (stderr, "Out of memory\n");
+ exit (EXIT_FAILURE);
+ }
+
+ buffers[0].length = buffer_size;
+ buffers[0].start = malloc (buffer_size);
+
+ if (!buffers[0].start) {
+ fprintf (stderr, "Out of memory\n");
+ exit (EXIT_FAILURE);
+ }
+}
+
+static void
+init_mmap (void)
+{
+ struct <A
+HREF="#V4L2-REQUESTBUFFERS"
+>v4l2_requestbuffers</A
+> req;
+
+ CLEAR (req);
+
+ req.count = 4;
+ req.type = V4L2_BUF_TYPE_VIDEO_CAPTURE;
+ req.memory = V4L2_MEMORY_MMAP;
+
+ if (-1 == xioctl (fd, VIDIOC_REQBUFS, &amp;req)) {
+ if (EINVAL == errno) {
+ fprintf (stderr, "%s does not support "
+ "memory mapping\n", dev_name);
+ exit (EXIT_FAILURE);
+ } else {
+ errno_exit ("VIDIOC_REQBUFS");
+ }
+ }
+
+ if (req.count &lt; 2) {
+ fprintf (stderr, "Insufficient buffer memory on %s\n",
+ dev_name);
+ exit (EXIT_FAILURE);
+ }
+
+ buffers = calloc (req.count, sizeof (*buffers));
+
+ if (!buffers) {
+ fprintf (stderr, "Out of memory\n");
+ exit (EXIT_FAILURE);
+ }
+
+ for (n_buffers = 0; n_buffers &lt; req.count; ++n_buffers) {
+ struct <A
+HREF="#V4L2-BUFFER"
+>v4l2_buffer</A
+> buf;
+
+ CLEAR (buf);
+
+ buf.type = V4L2_BUF_TYPE_VIDEO_CAPTURE;
+ buf.memory = V4L2_MEMORY_MMAP;
+ buf.index = n_buffers;
+
+ if (-1 == xioctl (fd, VIDIOC_QUERYBUF, &amp;buf))
+ errno_exit ("VIDIOC_QUERYBUF");
+
+ buffers[n_buffers].length = buf.length;
+ buffers[n_buffers].start =
+ mmap (NULL /* start anywhere */,
+ buf.length,
+ PROT_READ | PROT_WRITE /* required */,
+ MAP_SHARED /* recommended */,
+ fd, buf.m.offset);
+
+ if (MAP_FAILED == buffers[n_buffers].start)
+ errno_exit ("mmap");
+ }
+}
+
+static void
+init_userp (unsigned int buffer_size)
+{
+ struct <A
+HREF="#V4L2-REQUESTBUFFERS"
+>v4l2_requestbuffers</A
+> req;
+
+ CLEAR (req);
+
+ req.count = 4;
+ req.type = V4L2_BUF_TYPE_VIDEO_CAPTURE;
+ req.memory = V4L2_MEMORY_USERPTR;
+
+ if (-1 == xioctl (fd, VIDIOC_REQBUFS, &amp;req)) {
+ if (EINVAL == errno) {
+ fprintf (stderr, "%s does not support "
+ "user pointer i/o\n", dev_name);
+ exit (EXIT_FAILURE);
+ } else {
+ errno_exit ("VIDIOC_REQBUFS");
+ }
+ }
+
+ buffers = calloc (4, sizeof (*buffers));
+
+ if (!buffers) {
+ fprintf (stderr, "Out of memory\n");
+ exit (EXIT_FAILURE);
+ }
+
+ for (n_buffers = 0; n_buffers &lt; 4; ++n_buffers) {
+ buffers[n_buffers].length = buffer_size;
+ buffers[n_buffers].start = malloc (buffer_size);
+
+ if (!buffers[n_buffers].start) {
+ fprintf (stderr, "Out of memory\n");
+ exit (EXIT_FAILURE);
+ }
+ }
+}
+
+static void
+init_device (void)
+{
+ struct <A
+HREF="#V4L2-CAPABILITY"
+>v4l2_capability</A
+> cap;
+ struct <A
+HREF="#V4L2-CROPCAP"
+>v4l2_cropcap</A
+> cropcap;
+ struct <A
+HREF="#V4L2-CROP"
+>v4l2_crop</A
+> crop;
+ struct <A
+HREF="#V4L2-FORMAT"
+>v4l2_format</A
+> fmt;
+ unsigned int min;
+
+ if (-1 == xioctl (fd, VIDIOC_QUERYCAP, &amp;cap)) {
+ if (EINVAL == errno) {
+ fprintf (stderr, "%s is no V4L2 device\n",
+ dev_name);
+ exit (EXIT_FAILURE);
+ } else {
+ errno_exit ("VIDIOC_QUERYCAP");
+ }
+ }
+
+ if (!(cap.capabilities &amp; V4L2_CAP_VIDEO_CAPTURE)) {
+ fprintf (stderr, "%s is no video capture device\n",
+ dev_name);
+ exit (EXIT_FAILURE);
+ }
+
+ switch (io) {
+ case IO_METHOD_READ:
+ if (!(cap.capabilities &amp; V4L2_CAP_READWRITE)) {
+ fprintf (stderr, "%s does not support read i/o\n",
+ dev_name);
+ exit (EXIT_FAILURE);
+ }
+
+ break;
+
+ case IO_METHOD_MMAP:
+ case IO_METHOD_USERPTR:
+ if (!(cap.capabilities &amp; V4L2_CAP_STREAMING)) {
+ fprintf (stderr, "%s does not support streaming i/o\n",
+ dev_name);
+ exit (EXIT_FAILURE);
+ }
+
+ break;
+ }
+
+ /* Select video input, video standard and tune here. */
+
+ cropcap.type = V4L2_BUF_TYPE_VIDEO_CAPTURE;
+
+ if (-1 == xioctl (fd, VIDIOC_CROPCAP, &amp;cropcap)) {
+ /* Errors ignored. */
+ }
+
+ crop.type = V4L2_BUF_TYPE_VIDEO_CAPTURE;
+ crop.c = cropcap.defrect; /* reset to default */
+
+ if (-1 == xioctl (fd, VIDIOC_S_CROP, &amp;crop)) {
+ switch (errno) {
+ case EINVAL:
+ /* Cropping not supported. */
+ break;
+ default:
+ /* Errors ignored. */
+ break;
+ }
+ }
+
+ CLEAR (fmt);
+
+ fmt.type = V4L2_BUF_TYPE_VIDEO_CAPTURE;
+ fmt.fmt.pix.width = 640;
+ fmt.fmt.pix.height = 480;
+ fmt.fmt.pix.pixelformat = V4L2_PIX_FMT_YUYV;
+ fmt.fmt.pix.field = V4L2_FIELD_INTERLACED;
+
+ if (-1 == xioctl (fd, VIDIOC_S_FMT, &amp;fmt))
+ errno_exit ("VIDIOC_S_FMT");
+
+ /* Note VIDIOC_S_FMT may change width and height. */
+
+ /* Buggy driver paranoia. */
+ min = fmt.fmt.pix.width * 2;
+ if (fmt.fmt.pix.bytesperline &lt; min)
+ fmt.fmt.pix.bytesperline = min;
+ min = fmt.fmt.pix.bytesperline * fmt.fmt.pix.height;
+ if (fmt.fmt.pix.sizeimage &lt; min)
+ fmt.fmt.pix.sizeimage = min;
+
+ switch (io) {
+ case IO_METHOD_READ:
+ init_read (fmt.fmt.pix.sizeimage);
+ break;
+
+ case IO_METHOD_MMAP:
+ init_mmap ();
+ break;
+
+ case IO_METHOD_USERPTR:
+ init_userp (fmt.fmt.pix.sizeimage);
+ break;
+ }
+}
+
+static void
+close_device (void)
+{
+ if (-1 == close (fd))
+ errno_exit ("close");
+
+ fd = -1;
+}
+
+static void
+open_device (void)
+{
+ struct stat st;
+
+ if (-1 == stat (dev_name, &amp;st)) {
+ fprintf (stderr, "Cannot identify '%s': %d, %s\n",
+ dev_name, errno, strerror (errno));
+ exit (EXIT_FAILURE);
+ }
+
+ if (!S_ISCHR (st.st_mode)) {
+ fprintf (stderr, "%s is no device\n", dev_name);
+ exit (EXIT_FAILURE);
+ }
+
+ fd = open (dev_name, O_RDWR /* required */ | O_NONBLOCK, 0);
+
+ if (-1 == fd) {
+ fprintf (stderr, "Cannot open '%s': %d, %s\n",
+ dev_name, errno, strerror (errno));
+ exit (EXIT_FAILURE);
+ }
+}
+
+static void
+usage (FILE * fp,
+ int argc,
+ char ** argv)
+{
+ fprintf (fp,
+ "Usage: %s [options]\n\n"
+ "Options:\n"
+ "-d | --device name Video device name [/dev/video]\n"
+ "-h | --help Print this message\n"
+ "-m | --mmap Use memory mapped buffers\n"
+ "-r | --read Use read() calls\n"
+ "-u | --userp Use application allocated buffers\n"
+ "",
+ argv[0]);
+}
+
+static const char short_options [] = "d:hmru";
+
+static const struct option
+long_options [] = {
+ { "device", required_argument, NULL, 'd' },
+ { "help", no_argument, NULL, 'h' },
+ { "mmap", no_argument, NULL, 'm' },
+ { "read", no_argument, NULL, 'r' },
+ { "userp", no_argument, NULL, 'u' },
+ { 0, 0, 0, 0 }
+};
+
+int
+main (int argc,
+ char ** argv)
+{
+ dev_name = "/dev/video";
+
+ for (;;) {
+ int index;
+ int c;
+
+ c = getopt_long (argc, argv,
+ short_options, long_options,
+ &amp;index);
+
+ if (-1 == c)
+ break;
+
+ switch (c) {
+ case 0: /* getopt_long() flag */
+ break;
+
+ case 'd':
+ dev_name = optarg;
+ break;
+
+ case 'h':
+ usage (stdout, argc, argv);
+ exit (EXIT_SUCCESS);
+
+ case 'm':
+ io = IO_METHOD_MMAP;
+ break;
+
+ case 'r':
+ io = IO_METHOD_READ;
+ break;
+
+ case 'u':
+ io = IO_METHOD_USERPTR;
+ break;
+
+ default:
+ usage (stderr, argc, argv);
+ exit (EXIT_FAILURE);
+ }
+ }
+
+ open_device ();
+
+ init_device ();
+
+ start_capturing ();
+
+ mainloop ();
+
+ stop_capturing ();
+
+ uninit_device ();
+
+ close_device ();
+
+ exit (EXIT_SUCCESS);
+
+ return 0;
+}</PRE
+></DIV
+><DIV
+CLASS="APPENDIX"
+><HR><H1
+><A
+NAME="FDL"
+></A
+>Appendix C. GNU Free Documentation License</H1
+><DIV
+CLASS="SECT1"
+><H2
+CLASS="SECT1"
+><A
+NAME="FDL-PREAMBLE"
+>C.1. 0. PREAMBLE</A
+></H2
+><P
+> The purpose of this License is to make a manual, textbook, or
+ other written document <SPAN
+CLASS="QUOTE"
+>"free"</SPAN
+> in the sense of
+ freedom: to assure everyone the effective freedom to copy and
+ redistribute it, with or without modifying it, either
+ commercially or noncommercially. Secondarily, this License
+ preserves for the author and publisher a way to get credit for
+ their work, while not being considered responsible for
+ modifications made by others.
+ </P
+><P
+> This License is a kind of <SPAN
+CLASS="QUOTE"
+>"copyleft"</SPAN
+>, which means
+ that derivative works of the document must themselves be free in
+ the same sense. It complements the GNU General Public License,
+ which is a copyleft license designed for free software.
+ </P
+><P
+> We have designed this License in order to use it for manuals for
+ free software, because free software needs free documentation: a
+ free program should come with manuals providing the same
+ freedoms that the software does. But this License is not limited
+ to software manuals; it can be used for any textual work,
+ regardless of subject matter or whether it is published as a
+ printed book. We recommend this License principally for works
+ whose purpose is instruction or reference.
+ </P
+></DIV
+><DIV
+CLASS="SECT1"
+><HR><H2
+CLASS="SECT1"
+><A
+NAME="FDL-SECTION1"
+>C.2. 1. APPLICABILITY AND DEFINITIONS</A
+></H2
+><P
+> This License applies to any manual or other work that contains a
+ notice placed by the copyright holder saying it can be
+ distributed under the terms of this License. The
+ <SPAN
+CLASS="QUOTE"
+>"Document"</SPAN
+>, below, refers to any such manual or
+ work. Any member of the public is a licensee, and is addressed
+ as <SPAN
+CLASS="QUOTE"
+>"you"</SPAN
+>.
+ </P
+><P
+> A <SPAN
+CLASS="QUOTE"
+>"Modified Version"</SPAN
+> of the Document means any work
+ containing the Document or a portion of it, either copied
+ verbatim, or with modifications and/or translated into another
+ language.
+ </P
+><P
+> A <SPAN
+CLASS="QUOTE"
+>"Secondary Section"</SPAN
+> is a named appendix or a
+ front-matter section of the <A
+HREF="#FDL-DOCUMENT"
+>Document</A
+> that deals exclusively
+ with the relationship of the publishers or authors of the
+ Document to the Document's overall subject (or to related
+ matters) and contains nothing that could fall directly within
+ that overall subject. (For example, if the Document is in part a
+ textbook of mathematics, a Secondary Section may not explain any
+ mathematics.) The relationship could be a matter of historical
+ connection with the subject or with related matters, or of
+ legal, commercial, philosophical, ethical or political position
+ regarding them.
+ </P
+><P
+> The <SPAN
+CLASS="QUOTE"
+>"Invariant Sections"</SPAN
+> are certain <A
+HREF="#FDL-SECONDARY"
+> Secondary Sections</A
+> whose titles
+ are designated, as being those of Invariant Sections, in the
+ notice that says that the <A
+HREF="#FDL-DOCUMENT"
+>Document</A
+> is released under this
+ License.
+ </P
+><P
+> The <SPAN
+CLASS="QUOTE"
+>"Cover Texts"</SPAN
+> are certain short passages of
+ text that are listed, as Front-Cover Texts or Back-Cover Texts,
+ in the notice that says that the <A
+HREF="#FDL-DOCUMENT"
+>Document</A
+> is released under this
+ License.
+ </P
+><P
+> A <SPAN
+CLASS="QUOTE"
+>"Transparent"</SPAN
+> copy of the <A
+HREF="#FDL-DOCUMENT"
+> Document</A
+> means a machine-readable
+ copy, represented in a format whose specification is available
+ to the general public, whose contents can be viewed and edited
+ directly and straightforwardly with generic text editors or (for
+ images composed of pixels) generic paint programs or (for
+ drawings) some widely available drawing editor, and that is
+ suitable for input to text formatters or for automatic
+ translation to a variety of formats suitable for input to text
+ formatters. A copy made in an otherwise Transparent file format
+ whose markup has been designed to thwart or discourage
+ subsequent modification by readers is not Transparent. A copy
+ that is not <SPAN
+CLASS="QUOTE"
+>"Transparent"</SPAN
+> is called
+ <SPAN
+CLASS="QUOTE"
+>"Opaque"</SPAN
+>.
+ </P
+><P
+> Examples of suitable formats for Transparent copies include
+ plain ASCII without markup, Texinfo input format, LaTeX input
+ format, SGML or XML using a publicly available DTD, and
+ standard-conforming simple HTML designed for human
+ modification. Opaque formats include PostScript, PDF,
+ proprietary formats that can be read and edited only by
+ proprietary word processors, SGML or XML for which the DTD
+ and/or processing tools are not generally available, and the
+ machine-generated HTML produced by some word processors for
+ output purposes only.
+ </P
+><P
+> The <SPAN
+CLASS="QUOTE"
+>"Title Page"</SPAN
+> means, for a printed book, the
+ title page itself, plus such following pages as are needed to
+ hold, legibly, the material this License requires to appear in
+ the title page. For works in formats which do not have any title
+ page as such, <SPAN
+CLASS="QUOTE"
+>"Title Page"</SPAN
+> means the text near the
+ most prominent appearance of the work's title, preceding the
+ beginning of the body of the text.
+ </P
+></DIV
+><DIV
+CLASS="SECT1"
+><HR><H2
+CLASS="SECT1"
+><A
+NAME="FDL-SECTION2"
+>C.3. 2. VERBATIM COPYING</A
+></H2
+><P
+> You may copy and distribute the <A
+HREF="#FDL-DOCUMENT"
+>Document</A
+> in any medium, either
+ commercially or noncommercially, provided that this License, the
+ copyright notices, and the license notice saying this License
+ applies to the Document are reproduced in all copies, and that
+ you add no other conditions whatsoever to those of this
+ License. You may not use technical measures to obstruct or
+ control the reading or further copying of the copies you make or
+ distribute. However, you may accept compensation in exchange for
+ copies. If you distribute a large enough number of copies you
+ must also follow the conditions in <A
+HREF="#FDL-SECTION3"
+>section 3</A
+>.
+ </P
+><P
+> You may also lend copies, under the same conditions stated
+ above, and you may publicly display copies.
+ </P
+></DIV
+><DIV
+CLASS="SECT1"
+><HR><H2
+CLASS="SECT1"
+><A
+NAME="FDL-SECTION3"
+>C.4. 3. COPYING IN QUANTITY</A
+></H2
+><P
+> If you publish printed copies of the <A
+HREF="#FDL-DOCUMENT"
+>Document</A
+> numbering more than 100,
+ and the Document's license notice requires <A
+HREF="#FDL-COVER-TEXTS"
+>Cover Texts</A
+>, you must enclose
+ the copies in covers that carry, clearly and legibly, all these
+ Cover Texts: Front-Cover Texts on the front cover, and
+ Back-Cover Texts on the back cover. Both covers must also
+ clearly and legibly identify you as the publisher of these
+ copies. The front cover must present the full title with all
+ words of the title equally prominent and visible. You may add
+ other material on the covers in addition. Copying with changes
+ limited to the covers, as long as they preserve the title of the
+ <A
+HREF="#FDL-DOCUMENT"
+>Document</A
+> and satisfy these
+ conditions, can be treated as verbatim copying in other
+ respects.
+ </P
+><P
+> If the required texts for either cover are too voluminous to fit
+ legibly, you should put the first ones listed (as many as fit
+ reasonably) on the actual cover, and continue the rest onto
+ adjacent pages.
+ </P
+><P
+> If you publish or distribute <A
+HREF="#FDL-TRANSPARENT"
+>Opaque</A
+> copies of the <A
+HREF="#FDL-DOCUMENT"
+>Document</A
+> numbering more than 100,
+ you must either include a machine-readable <A
+HREF="#FDL-TRANSPARENT"
+>Transparent</A
+> copy along with
+ each Opaque copy, or state in or with each Opaque copy a
+ publicly-accessible computer-network location containing a
+ complete Transparent copy of the Document, free of added
+ material, which the general network-using public has access to
+ download anonymously at no charge using public-standard network
+ protocols. If you use the latter option, you must take
+ reasonably prudent steps, when you begin distribution of Opaque
+ copies in quantity, to ensure that this Transparent copy will
+ remain thus accessible at the stated location until at least one
+ year after the last time you distribute an Opaque copy (directly
+ or through your agents or retailers) of that edition to the
+ public.
+ </P
+><P
+> It is requested, but not required, that you contact the authors
+ of the <A
+HREF="#FDL-DOCUMENT"
+>Document</A
+> well before
+ redistributing any large number of copies, to give them a chance
+ to provide you with an updated version of the Document.
+ </P
+></DIV
+><DIV
+CLASS="SECT1"
+><HR><H2
+CLASS="SECT1"
+><A
+NAME="FDL-SECTION4"
+>C.5. 4. MODIFICATIONS</A
+></H2
+><P
+> You may copy and distribute a <A
+HREF="#FDL-MODIFIED"
+>Modified Version</A
+> of the <A
+HREF="#FDL-DOCUMENT"
+>Document</A
+> under the conditions of
+ sections <A
+HREF="#FDL-SECTION2"
+>2</A
+> and <A
+HREF="#FDL-SECTION3"
+>3</A
+> above, provided that you release
+ the Modified Version under precisely this License, with the
+ Modified Version filling the role of the Document, thus
+ licensing distribution and modification of the Modified Version
+ to whoever possesses a copy of it. In addition, you must do
+ these things in the Modified Version:
+ </P
+><P
+></P
+><UL
+><LI
+STYLE="list-style-type: opencircle"
+><DIV
+CLASS="FORMALPARA"
+><P
+><B
+>A. </B
+> Use in the <A
+HREF="#FDL-TITLE-PAGE"
+>Title
+ Page</A
+> (and on the covers, if any) a title distinct
+ from that of the <A
+HREF="#FDL-DOCUMENT"
+>Document</A
+>, and from those of
+ previous versions (which should, if there were any, be
+ listed in the History section of the Document). You may
+ use the same title as a previous version if the original
+ publisher of that version gives permission.
+ </P
+></DIV
+></LI
+><LI
+STYLE="list-style-type: opencircle"
+><DIV
+CLASS="FORMALPARA"
+><P
+><B
+>B. </B
+> List on the <A
+HREF="#FDL-TITLE-PAGE"
+>Title
+ Page</A
+>, as authors, one or more persons or entities
+ responsible for authorship of the modifications in the
+ <A
+HREF="#FDL-MODIFIED"
+>Modified Version</A
+>,
+ together with at least five of the principal authors of
+ the <A
+HREF="#FDL-DOCUMENT"
+>Document</A
+> (all of
+ its principal authors, if it has less than five).
+ </P
+></DIV
+></LI
+><LI
+STYLE="list-style-type: opencircle"
+><DIV
+CLASS="FORMALPARA"
+><P
+><B
+>C. </B
+> State on the <A
+HREF="#FDL-TITLE-PAGE"
+>Title
+ Page</A
+> the name of the publisher of the <A
+HREF="#FDL-MODIFIED"
+>Modified Version</A
+>, as the
+ publisher.
+ </P
+></DIV
+></LI
+><LI
+STYLE="list-style-type: opencircle"
+><DIV
+CLASS="FORMALPARA"
+><P
+><B
+>D. </B
+> Preserve all the copyright notices of the <A
+HREF="#FDL-DOCUMENT"
+>Document</A
+>.
+ </P
+></DIV
+></LI
+><LI
+STYLE="list-style-type: opencircle"
+><DIV
+CLASS="FORMALPARA"
+><P
+><B
+>E. </B
+> Add an appropriate copyright notice for your modifications
+ adjacent to the other copyright notices.
+ </P
+></DIV
+></LI
+><LI
+STYLE="list-style-type: opencircle"
+><DIV
+CLASS="FORMALPARA"
+><P
+><B
+>F. </B
+> Include, immediately after the copyright notices, a
+ license notice giving the public permission to use the
+ <A
+HREF="#FDL-MODIFIED"
+>Modified Version</A
+> under
+ the terms of this License, in the form shown in the
+ Addendum below.
+ </P
+></DIV
+></LI
+><LI
+STYLE="list-style-type: opencircle"
+><DIV
+CLASS="FORMALPARA"
+><P
+><B
+>G. </B
+> Preserve in that license notice the full lists of <A
+HREF="#FDL-INVARIANT"
+> Invariant Sections</A
+> and
+ required <A
+HREF="#FDL-COVER-TEXTS"
+>Cover
+ Texts</A
+> given in the <A
+HREF="#FDL-DOCUMENT"
+>Document's</A
+> license notice.
+ </P
+></DIV
+></LI
+><LI
+STYLE="list-style-type: opencircle"
+><DIV
+CLASS="FORMALPARA"
+><P
+><B
+>H. </B
+> Include an unaltered copy of this License.
+ </P
+></DIV
+></LI
+><LI
+STYLE="list-style-type: opencircle"
+><DIV
+CLASS="FORMALPARA"
+><P
+><B
+>I. </B
+> Preserve the section entitled <SPAN
+CLASS="QUOTE"
+>"History"</SPAN
+>, and
+ its title, and add to it an item stating at least the
+ title, year, new authors, and publisher of the <A
+HREF="#FDL-MODIFIED"
+>Modified Version </A
+>as given on
+ the <A
+HREF="#FDL-TITLE-PAGE"
+>Title Page</A
+>. If
+ there is no section entitled <SPAN
+CLASS="QUOTE"
+>"History"</SPAN
+> in the
+ <A
+HREF="#FDL-DOCUMENT"
+>Document</A
+>, create one
+ stating the title, year, authors, and publisher of the
+ Document as given on its Title Page, then add an item
+ describing the Modified Version as stated in the previous
+ sentence.
+ </P
+></DIV
+></LI
+><LI
+STYLE="list-style-type: opencircle"
+><DIV
+CLASS="FORMALPARA"
+><P
+><B
+>J. </B
+> Preserve the network location, if any, given in the <A
+HREF="#FDL-DOCUMENT"
+>Document</A
+> for public access
+ to a <A
+HREF="#FDL-TRANSPARENT"
+>Transparent</A
+>
+ copy of the Document, and likewise the network locations
+ given in the Document for previous versions it was based
+ on. These may be placed in the <SPAN
+CLASS="QUOTE"
+>"History"</SPAN
+>
+ section. You may omit a network location for a work that
+ was published at least four years before the Document
+ itself, or if the original publisher of the version it
+ refers to gives permission.
+ </P
+></DIV
+></LI
+><LI
+STYLE="list-style-type: opencircle"
+><DIV
+CLASS="FORMALPARA"
+><P
+><B
+>K. </B
+> In any section entitled <SPAN
+CLASS="QUOTE"
+>"Acknowledgements"</SPAN
+> or
+ <SPAN
+CLASS="QUOTE"
+>"Dedications"</SPAN
+>, preserve the section's title,
+ and preserve in the section all the substance and tone of
+ each of the contributor acknowledgements and/or
+ dedications given therein.
+ </P
+></DIV
+></LI
+><LI
+STYLE="list-style-type: opencircle"
+><DIV
+CLASS="FORMALPARA"
+><P
+><B
+>L. </B
+> Preserve all the <A
+HREF="#FDL-INVARIANT"
+>Invariant
+ Sections</A
+> of the <A
+HREF="#FDL-DOCUMENT"
+>Document</A
+>, unaltered in their
+ text and in their titles. Section numbers or the
+ equivalent are not considered part of the section titles.
+ </P
+></DIV
+></LI
+><LI
+STYLE="list-style-type: opencircle"
+><DIV
+CLASS="FORMALPARA"
+><P
+><B
+>M. </B
+> Delete any section entitled
+ <SPAN
+CLASS="QUOTE"
+>"Endorsements"</SPAN
+>. Such a section may not be
+ included in the <A
+HREF="#FDL-MODIFIED"
+>Modified
+ Version</A
+>.
+ </P
+></DIV
+></LI
+><LI
+STYLE="list-style-type: opencircle"
+><DIV
+CLASS="FORMALPARA"
+><P
+><B
+>N. </B
+> Do not retitle any existing section as
+ <SPAN
+CLASS="QUOTE"
+>"Endorsements"</SPAN
+> or to conflict in title with
+ any <A
+HREF="#FDL-INVARIANT"
+>Invariant
+ Section</A
+>.
+ </P
+></DIV
+></LI
+></UL
+><P
+> If the <A
+HREF="#FDL-MODIFIED"
+>Modified Version</A
+>
+ includes new front-matter sections or appendices that qualify as
+ <A
+HREF="#FDL-SECONDARY"
+>Secondary Sections</A
+> and
+ contain no material copied from the Document, you may at your
+ option designate some or all of these sections as invariant. To
+ do this, add their titles to the list of <A
+HREF="#FDL-INVARIANT"
+>Invariant Sections</A
+> in the
+ Modified Version's license notice. These titles must be
+ distinct from any other section titles.
+ </P
+><P
+> You may add a section entitled <SPAN
+CLASS="QUOTE"
+>"Endorsements"</SPAN
+>,
+ provided it contains nothing but endorsements of your <A
+HREF="#FDL-MODIFIED"
+>Modified Version</A
+> by various
+ parties--for example, statements of peer review or that the text
+ has been approved by an organization as the authoritative
+ definition of a standard.
+ </P
+><P
+> You may add a passage of up to five words as a <A
+HREF="#FDL-COVER-TEXTS"
+>Front-Cover Text</A
+>, and a passage
+ of up to 25 words as a <A
+HREF="#FDL-COVER-TEXTS"
+>Back-Cover Text</A
+>, to the end of
+ the list of <A
+HREF="#FDL-COVER-TEXTS"
+>Cover Texts</A
+>
+ in the <A
+HREF="#FDL-MODIFIED"
+>Modified Version</A
+>.
+ Only one passage of Front-Cover Text and one of Back-Cover Text
+ may be added by (or through arrangements made by) any one
+ entity. If the <A
+HREF="#FDL-DOCUMENT"
+>Document</A
+>
+ already includes a cover text for the same cover, previously
+ added by you or by arrangement made by the same entity you are
+ acting on behalf of, you may not add another; but you may
+ replace the old one, on explicit permission from the previous
+ publisher that added the old one.
+ </P
+><P
+> The author(s) and publisher(s) of the <A
+HREF="#FDL-DOCUMENT"
+>Document</A
+> do not by this License
+ give permission to use their names for publicity for or to
+ assert or imply endorsement of any <A
+HREF="#FDL-MODIFIED"
+>Modified Version </A
+>.
+ </P
+></DIV
+><DIV
+CLASS="SECT1"
+><HR><H2
+CLASS="SECT1"
+><A
+NAME="FDL-SECTION5"
+>C.6. 5. COMBINING DOCUMENTS</A
+></H2
+><P
+> You may combine the <A
+HREF="#FDL-DOCUMENT"
+>Document</A
+>
+ with other documents released under this License, under the
+ terms defined in <A
+HREF="#FDL-SECTION4"
+>section 4</A
+>
+ above for modified versions, provided that you include in the
+ combination all of the <A
+HREF="#FDL-INVARIANT"
+>Invariant
+ Sections</A
+> of all of the original documents, unmodified,
+ and list them all as Invariant Sections of your combined work in
+ its license notice.
+ </P
+><P
+> The combined work need only contain one copy of this License,
+ and multiple identical <A
+HREF="#FDL-INVARIANT"
+>Invariant
+ Sections</A
+> may be replaced with a single copy. If there are
+ multiple Invariant Sections with the same name but different
+ contents, make the title of each such section unique by adding
+ at the end of it, in parentheses, the name of the original
+ author or publisher of that section if known, or else a unique
+ number. Make the same adjustment to the section titles in the
+ list of Invariant Sections in the license notice of the combined
+ work.
+ </P
+><P
+> In the combination, you must combine any sections entitled
+ <SPAN
+CLASS="QUOTE"
+>"History"</SPAN
+> in the various original documents,
+ forming one section entitled <SPAN
+CLASS="QUOTE"
+>"History"</SPAN
+>; likewise
+ combine any sections entitled <SPAN
+CLASS="QUOTE"
+>"Acknowledgements"</SPAN
+>,
+ and any sections entitled <SPAN
+CLASS="QUOTE"
+>"Dedications"</SPAN
+>. You must
+ delete all sections entitled <SPAN
+CLASS="QUOTE"
+>"Endorsements."</SPAN
+>
+ </P
+></DIV
+><DIV
+CLASS="SECT1"
+><HR><H2
+CLASS="SECT1"
+><A
+NAME="FDL-SECTION6"
+>C.7. 6. COLLECTIONS OF DOCUMENTS</A
+></H2
+><P
+> You may make a collection consisting of the <A
+HREF="#FDL-DOCUMENT"
+>Document</A
+> and other documents
+ released under this License, and replace the individual copies
+ of this License in the various documents with a single copy that
+ is included in the collection, provided that you follow the
+ rules of this License for verbatim copying of each of the
+ documents in all other respects.
+ </P
+><P
+> You may extract a single document from such a collection, and
+ dispbibute it individually under this License, provided you
+ insert a copy of this License into the extracted document, and
+ follow this License in all other respects regarding verbatim
+ copying of that document.
+ </P
+></DIV
+><DIV
+CLASS="SECT1"
+><HR><H2
+CLASS="SECT1"
+><A
+NAME="FDL-SECTION7"
+>C.8. 7. AGGREGATION WITH INDEPENDENT WORKS</A
+></H2
+><P
+> A compilation of the <A
+HREF="#FDL-DOCUMENT"
+>Document</A
+> or its derivatives with
+ other separate and independent documents or works, in or on a
+ volume of a storage or distribution medium, does not as a whole
+ count as a <A
+HREF="#FDL-MODIFIED"
+>Modified Version</A
+>
+ of the Document, provided no compilation copyright is claimed
+ for the compilation. Such a compilation is called an
+ <SPAN
+CLASS="QUOTE"
+>"aggregate"</SPAN
+>, and this License does not apply to the
+ other self-contained works thus compiled with the Document , on
+ account of their being thus compiled, if they are not themselves
+ derivative works of the Document. If the <A
+HREF="#FDL-COVER-TEXTS"
+>Cover Text</A
+> requirement of <A
+HREF="#FDL-SECTION3"
+>section 3</A
+> is applicable to these
+ copies of the Document, then if the Document is less than one
+ quarter of the entire aggregate, the Document's Cover Texts may
+ be placed on covers that surround only the Document within the
+ aggregate. Otherwise they must appear on covers around the whole
+ aggregate.
+ </P
+></DIV
+><DIV
+CLASS="SECT1"
+><HR><H2
+CLASS="SECT1"
+><A
+NAME="FDL-SECTION8"
+>C.9. 8. TRANSLATION</A
+></H2
+><P
+> Translation is considered a kind of modification, so you may
+ distribute translations of the <A
+HREF="#FDL-DOCUMENT"
+>Document</A
+> under the terms of <A
+HREF="#FDL-SECTION4"
+>section 4</A
+>. Replacing <A
+HREF="#FDL-INVARIANT"
+> Invariant Sections</A
+> with
+ translations requires special permission from their copyright
+ holders, but you may include translations of some or all
+ Invariant Sections in addition to the original versions of these
+ Invariant Sections. You may include a translation of this
+ License provided that you also include the original English
+ version of this License. In case of a disagreement between the
+ translation and the original English version of this License,
+ the original English version will prevail.
+ </P
+></DIV
+><DIV
+CLASS="SECT1"
+><HR><H2
+CLASS="SECT1"
+><A
+NAME="FDL-SECTION9"
+>C.10. 9. TERMINATION</A
+></H2
+><P
+> You may not copy, modify, sublicense, or distribute the <A
+HREF="#FDL-DOCUMENT"
+>Document</A
+> except as expressly
+ provided for under this License. Any other attempt to copy,
+ modify, sublicense or distribute the Document is void, and will
+ automatically terminate your rights under this License. However,
+ parties who have received copies, or rights, from you under this
+ License will not have their licenses terminated so long as such
+ parties remain in full compliance.
+ </P
+></DIV
+><DIV
+CLASS="SECT1"
+><HR><H2
+CLASS="SECT1"
+><A
+NAME="FDL-SECTION10"
+>C.11. 10. FUTURE REVISIONS OF THIS LICENSE</A
+></H2
+><P
+> The <A
+HREF="http://www.gnu.org/fsf/fsf.html"
+TARGET="_top"
+>Free Software
+ Foundation</A
+> may publish new, revised versions of the GNU
+ Free Documentation License from time to time. Such new versions
+ will be similar in spirit to the present version, but may differ
+ in detail to address new problems or concerns. See <A
+HREF="http://www.gnu.org/copyleft"
+TARGET="_top"
+>http://www.gnu.org/copyleft/</A
+>.
+ </P
+><P
+> Each version of the License is given a distinguishing version
+ number. If the <A
+HREF="#FDL-DOCUMENT"
+>Document</A
+>
+ specifies that a particular numbered version of this License
+ <SPAN
+CLASS="QUOTE"
+>"or any later version"</SPAN
+> applies to it, you have the
+ option of following the terms and conditions either of that
+ specified version or of any later version that has been
+ published (not as a draft) by the Free Software Foundation. If
+ the Document does not specify a version number of this License,
+ you may choose any version ever published (not as a draft) by
+ the Free Software Foundation.
+ </P
+></DIV
+><DIV
+CLASS="SECT1"
+><HR><H2
+CLASS="SECT1"
+><A
+NAME="FDL-USING"
+>C.12. Addendum</A
+></H2
+><P
+> To use this License in a document you have written, include a copy of
+ the License in the document and put the following copyright and
+ license notices just after the title page:
+ </P
+><A
+NAME="AEN11607"
+></A
+><BLOCKQUOTE
+CLASS="BLOCKQUOTE"
+><P
+> Copyright &copy; YEAR YOUR NAME.
+ </P
+><P
+> Permission is granted to copy, distribute and/or modify this
+ document under the terms of the GNU Free Documentation
+ License, Version 1.1 or any later version published by the
+ Free Software Foundation; with the <A
+HREF="#FDL-INVARIANT"
+>Invariant Sections</A
+> being LIST
+ THEIR TITLES, with the <A
+HREF="#FDL-COVER-TEXTS"
+>Front-Cover Texts</A
+> being LIST,
+ and with the <A
+HREF="#FDL-COVER-TEXTS"
+>Back-Cover
+ Texts</A
+> being LIST. A copy of the license is included in
+ the section entitled <SPAN
+CLASS="QUOTE"
+>"GNU Free Documentation
+ License"</SPAN
+>.
+ </P
+></BLOCKQUOTE
+><P
+> If you have no <A
+HREF="#FDL-INVARIANT"
+>Invariant
+ Sections</A
+>, write <SPAN
+CLASS="QUOTE"
+>"with no Invariant Sections"</SPAN
+>
+ instead of saying which ones are invariant. If you have no
+ <A
+HREF="#FDL-COVER-TEXTS"
+>Front-Cover Texts</A
+>, write
+ <SPAN
+CLASS="QUOTE"
+>"no Front-Cover Texts"</SPAN
+> instead of
+ <SPAN
+CLASS="QUOTE"
+>"Front-Cover Texts being LIST"</SPAN
+>; likewise for <A
+HREF="#FDL-COVER-TEXTS"
+>Back-Cover Texts</A
+>.
+ </P
+><P
+> If your document contains nontrivial examples of program code,
+ we recommend releasing these examples in parallel under your
+ choice of free software license, such as the <A
+HREF="http://www.gnu.org/copyleft/gpl.html"
+TARGET="_top"
+> GNU General Public
+ License</A
+>, to permit their use in free software.
+ </P
+></DIV
+></DIV
+><A
+NAME="AEN11623"
+></A
+><HR><H1
+><A
+NAME="AEN11623"
+></A
+>Bibliography</H1
+><DIV
+CLASS="BIBLIOENTRY"
+><A
+NAME="EIA608"
+></A
+><P
+>[EIA608]&nbsp;Electronic Industries Alliance (<A
+HREF="http://www.eia.org"
+TARGET="_top"
+>http://www.eia.org</A
+>), <I
+>EIA 608 "Recommended Practice for Line 21 Data
+Service"</I
+>.</P
+><DIV
+CLASS="BIBLIOENTRYBLOCK"
+STYLE="margin-left: 0.5in"
+></DIV
+></DIV
+><DIV
+CLASS="BIBLIOENTRY"
+><A
+NAME="ITU470"
+></A
+><P
+>[ITU470]&nbsp;International Telecommunication Union (<A
+HREF="http://www.itu.ch"
+TARGET="_top"
+>http://www.itu.ch</A
+>), <I
+>ITU-R Recommendation BT.470-6 "Conventional Television
+Systems"</I
+>.</P
+><DIV
+CLASS="BIBLIOENTRYBLOCK"
+STYLE="margin-left: 0.5in"
+></DIV
+></DIV
+><DIV
+CLASS="BIBLIOENTRY"
+><A
+NAME="ITU601"
+></A
+><P
+>[ITU601]&nbsp;International Telecommunication Union (<A
+HREF="http://www.itu.ch"
+TARGET="_top"
+>http://www.itu.ch</A
+>), <I
+>ITU-R Recommendation BT.601-5 "Studio Encoding Parameters
+of Digital Television for Standard 4:3 and Wide-Screen 16:9 Aspect
+Ratios"</I
+>.</P
+><DIV
+CLASS="BIBLIOENTRYBLOCK"
+STYLE="margin-left: 0.5in"
+></DIV
+></DIV
+><DIV
+CLASS="BIBLIOENTRY"
+><A
+NAME="ITU709"
+></A
+><P
+>[ITU709]&nbsp;International Telecommunication Union (<A
+HREF="http://www.itu.ch"
+TARGET="_top"
+>http://www.itu.ch</A
+>), <I
+>ITU-R Recommendation BT.709-5 "Parameter values for the
+HDTV standards for production and international programme
+exchange"</I
+>.</P
+><DIV
+CLASS="BIBLIOENTRYBLOCK"
+STYLE="margin-left: 0.5in"
+></DIV
+></DIV
+><DIV
+CLASS="BIBLIOENTRY"
+><A
+NAME="JFIF"
+></A
+><P
+>[JFIF]&nbsp;Independent JPEG Group (<A
+HREF="http://www.ijg.org"
+TARGET="_top"
+>http://www.ijg.org</A
+>), <I
+>JPEG File Interchange Format</I
+><I
+>: </I
+><I
+>Version 1.02</I
+>.</P
+><DIV
+CLASS="BIBLIOENTRYBLOCK"
+STYLE="margin-left: 0.5in"
+></DIV
+></DIV
+><DIV
+CLASS="BIBLIOENTRY"
+><A
+NAME="SMPTE12M"
+></A
+><P
+>[SMPTE12M]&nbsp;Society of Motion Picture and Television Engineers
+(<A
+HREF="http://www.smpte.org"
+TARGET="_top"
+>http://www.smpte.org</A
+>), <I
+>SMPTE 12M-1999 "Television, Audio and Film - Time and
+Control Code"</I
+>.</P
+><DIV
+CLASS="BIBLIOENTRYBLOCK"
+STYLE="margin-left: 0.5in"
+></DIV
+></DIV
+><DIV
+CLASS="BIBLIOENTRY"
+><A
+NAME="SMPTE170M"
+></A
+><P
+>[SMPTE170M]&nbsp;Society of Motion Picture and Television Engineers
+(<A
+HREF="http://www.smpte.org"
+TARGET="_top"
+>http://www.smpte.org</A
+>), <I
+>SMPTE 170M-1999 "Television - Composite Analog Video
+Signal - NTSC for Studio Applications"</I
+>.</P
+><DIV
+CLASS="BIBLIOENTRYBLOCK"
+STYLE="margin-left: 0.5in"
+></DIV
+></DIV
+><DIV
+CLASS="BIBLIOENTRY"
+><A
+NAME="SMPTE240M"
+></A
+><P
+>[SMPTE240M]&nbsp;Society of Motion Picture and Television Engineers
+(<A
+HREF="http://www.smpte.org"
+TARGET="_top"
+>http://www.smpte.org</A
+>), <I
+>SMPTE 240M-1999 "Television - Signal Parameters -
+1125-Line High-Definition Production"</I
+>.</P
+><DIV
+CLASS="BIBLIOENTRYBLOCK"
+STYLE="margin-left: 0.5in"
+></DIV
+></DIV
+><DIV
+CLASS="BIBLIOENTRY"
+><A
+NAME="TELETEXT"
+></A
+><P
+>[TELETEXT]&nbsp;European Telecommunication Standards Institute
+(<A
+HREF="http://www.etsi.org"
+TARGET="_top"
+>http://www.etsi.org</A
+>), <I
+>ETS 300 706 "Enhanced Teletext specification"</I
+>.</P
+><DIV
+CLASS="BIBLIOENTRYBLOCK"
+STYLE="margin-left: 0.5in"
+></DIV
+></DIV
+><DIV
+CLASS="BIBLIOENTRY"
+><A
+NAME="V4L"
+></A
+><P
+>[V4L]&nbsp;<SPAN
+CLASS="AUTHOR"
+>Alan Cox</SPAN
+>, <I
+>Video4Linux API Specification</I
+>.</P
+><DIV
+CLASS="BIBLIOENTRYBLOCK"
+STYLE="margin-left: 0.5in"
+><DIV
+CLASS="ABSTRACT"
+><P
+>This file is part of the Linux kernel sources under
+<TT
+CLASS="FILENAME"
+>Documentation/video4linux</TT
+>.</P
+></DIV
+></DIV
+></DIV
+><DIV
+CLASS="BIBLIOENTRY"
+><A
+NAME="V4LPROG"
+></A
+><P
+>[V4LPROG]&nbsp;<SPAN
+CLASS="AUTHOR"
+>Alan Cox</SPAN
+>, <I
+>Video4Linux Programming (a.k.a. The Video4Linux
+Book)</I
+>, 2000.</P
+><DIV
+CLASS="BIBLIOENTRYBLOCK"
+STYLE="margin-left: 0.5in"
+><DIV
+CLASS="ABSTRACT"
+><P
+>About V4L <SPAN
+CLASS="emphasis"
+><I
+CLASS="EMPHASIS"
+>driver</I
+></SPAN
+> programming. This
+book is part of the Linux kernel DocBook documentation, for example at
+<A
+HREF="http://kernelnewbies.org/documents/"
+TARGET="_top"
+>http://kernelnewbies.org/documents/</A
+>. SGML sources are included
+in the kernel sources.</P
+></DIV
+></DIV
+></DIV
+><DIV
+CLASS="BIBLIOENTRY"
+><A
+NAME="VPS"
+></A
+><P
+>[VPS]&nbsp;European Telecommunication Standards Institute
+(<A
+HREF="http://www.etsi.org"
+TARGET="_top"
+>http://www.etsi.org</A
+>), <I
+>ETS 300 231 "Specification of the domestic video
+Programme Delivery Control system (PDC)"</I
+>.</P
+><DIV
+CLASS="BIBLIOENTRYBLOCK"
+STYLE="margin-left: 0.5in"
+></DIV
+></DIV
+><DIV
+CLASS="BIBLIOENTRY"
+><A
+NAME="WSS"
+></A
+><P
+>[WSS]&nbsp;International Telecommunication Union (<A
+HREF="http://www.itu.ch"
+TARGET="_top"
+>http://www.itu.ch</A
+>), European
+Telecommunication Standards Institute (<A
+HREF="http://www.etsi.org"
+TARGET="_top"
+>http://www.etsi.org</A
+>), <I
+>ITU-R Recommendation BT.1119, EN 300 294 "625-line
+television Wide Screen Signalling (WSS)"</I
+>.</P
+><DIV
+CLASS="BIBLIOENTRYBLOCK"
+STYLE="margin-left: 0.5in"
+></DIV
+></DIV
+></DIV
+><H3
+CLASS="FOOTNOTES"
+>Notes</H3
+><TABLE
+BORDER="0"
+CLASS="FOOTNOTES"
+WIDTH="100%"
+><TR
+><TD
+ALIGN="LEFT"
+VALIGN="TOP"
+WIDTH="5%"
+><A
+NAME="FTN.AEN104"
+HREF="#AEN104"
+><SPAN
+CLASS="footnote"
+>[1]</SPAN
+></A
+></TD
+><TD
+ALIGN="LEFT"
+VALIGN="TOP"
+WIDTH="95%"
+><P
+>Access permissions are associated with character
+device special files, we must ensure device numbers cannot change with
+load order. To this end minor numbers are no longer automatically assigned
+by the "videodev" module as in V4L but requested by the driver. The defaults
+will suffice for most people, unless two drivers are used which compete for
+the same minor numbers.</P
+></TD
+></TR
+><TR
+><TD
+ALIGN="LEFT"
+VALIGN="TOP"
+WIDTH="5%"
+><A
+NAME="FTN.AEN107"
+HREF="#AEN107"
+><SPAN
+CLASS="footnote"
+>[2]</SPAN
+></A
+></TD
+><TD
+ALIGN="LEFT"
+VALIGN="TOP"
+WIDTH="95%"
+><P
+>In earlier versions of the V4L2 API the module options
+where named after the device special file with a "unit_" prefix, expressing
+the minor number itself, not an offset. Rationale for this change is unknown.
+Lastly the naming and semantics are just a convention among driver writers,
+the point to note is that minor numbers are not supposed to be hardcoded
+into drivers.</P
+></TD
+></TR
+><TR
+><TD
+ALIGN="LEFT"
+VALIGN="TOP"
+WIDTH="5%"
+><A
+NAME="FTN.AEN135"
+HREF="#AEN135"
+><SPAN
+CLASS="footnote"
+>[3]</SPAN
+></A
+></TD
+><TD
+ALIGN="LEFT"
+VALIGN="TOP"
+WIDTH="95%"
+><P
+>Given a device file name one cannot reliable find
+related devices. For once names are arbitrary, they can be chosen
+freely by the system administrator. Also when there are multiple
+devices and only some support VBI capturing, say,
+<TT
+CLASS="FILENAME"
+>/dev/video2</TT
+> is not necessarily related to
+<TT
+CLASS="FILENAME"
+>/dev/vbi2</TT
+>. We already noted finding devices by
+name or minor number is unreliable, accordingly useful is the ioctl
+offered by V4L to query the minor numbers of related devices.</P
+></TD
+></TR
+><TR
+><TD
+ALIGN="LEFT"
+VALIGN="TOP"
+WIDTH="5%"
+><A
+NAME="FTN.AEN166"
+HREF="#AEN166"
+><SPAN
+CLASS="footnote"
+>[4]</SPAN
+></A
+></TD
+><TD
+ALIGN="LEFT"
+VALIGN="TOP"
+WIDTH="95%"
+><P
+>Drivers could recognize the
+<CODE
+CLASS="CONSTANT"
+>O_EXCL</CODE
+> open flag. Presently this is not required,
+so application cannot know if it really works.</P
+></TD
+></TR
+><TR
+><TD
+ALIGN="LEFT"
+VALIGN="TOP"
+WIDTH="5%"
+><A
+NAME="FTN.AEN245"
+HREF="#AEN245"
+><SPAN
+CLASS="footnote"
+>[5]</SPAN
+></A
+></TD
+><TD
+ALIGN="LEFT"
+VALIGN="TOP"
+WIDTH="95%"
+><P
+>Actually struct&nbsp;<A
+HREF="#V4L2-AUDIO"
+>v4l2_audio</A
+> ought to have a
+<CODE
+CLASS="STRUCTFIELD"
+>tuner</CODE
+> field like struct&nbsp;<A
+HREF="#V4L2-INPUT"
+>v4l2_input</A
+>, not only
+making the API more consistent but also permitting radio devices with
+multiple tuners.</P
+></TD
+></TR
+><TR
+><TD
+ALIGN="LEFT"
+VALIGN="TOP"
+WIDTH="5%"
+><A
+NAME="FTN.AEN363"
+HREF="#AEN363"
+><SPAN
+CLASS="footnote"
+>[6]</SPAN
+></A
+></TD
+><TD
+ALIGN="LEFT"
+VALIGN="TOP"
+WIDTH="95%"
+><P
+>Some users are already confused by technical terms PAL,
+NTSC and SECAM. There is no point asking them to distinguish between
+B, G, D, or K when the software or hardware can do that
+automatically.</P
+></TD
+></TR
+><TR
+><TD
+ALIGN="LEFT"
+VALIGN="TOP"
+WIDTH="5%"
+><A
+NAME="FTN.AEN375"
+HREF="#AEN375"
+><SPAN
+CLASS="footnote"
+>[7]</SPAN
+></A
+></TD
+><TD
+ALIGN="LEFT"
+VALIGN="TOP"
+WIDTH="95%"
+><P
+>An alternative to the current scheme is to use pointers
+to indices as arguments of <CODE
+CLASS="CONSTANT"
+>VIDIOC_G_STD</CODE
+> and
+<CODE
+CLASS="CONSTANT"
+>VIDIOC_S_STD</CODE
+>, the struct&nbsp;<A
+HREF="#V4L2-INPUT"
+>v4l2_input</A
+> and
+struct&nbsp;<A
+HREF="#V4L2-OUTPUT"
+>v4l2_output</A
+> <CODE
+CLASS="STRUCTFIELD"
+>std</CODE
+> field would be a set of
+indices like <CODE
+CLASS="STRUCTFIELD"
+>audioset</CODE
+>.</P
+><P
+>Indices are consistent with the rest of the API
+and identify the standard unambiguously. In the present scheme of
+things an enumerated standard is looked up by <A
+HREF="#V4L2-STD-ID"
+>v4l2_std_id</A
+>. Now the
+standards supported by the inputs of a device can overlap. Just
+assume the tuner and composite input in the example above both
+exist on a device. An enumeration of "PAL-B/G", "PAL-H/I" suggests
+a choice which does not exist. We cannot merge or omit sets, because
+applications would be unable to find the standards reported by
+<CODE
+CLASS="CONSTANT"
+>VIDIOC_G_STD</CODE
+>. That leaves separate enumerations
+for each input. Also selecting a standard by <A
+HREF="#V4L2-STD-ID"
+>v4l2_std_id</A
+> can be
+ambiguous. Advantage of this method is that applications need not
+identify the standard indirectly, after enumerating.</P
+><P
+>So in
+summary, the lookup itself is unavoidable. The difference is only
+whether the lookup is necessary to find an enumerated standard or to
+switch to a standard by <A
+HREF="#V4L2-STD-ID"
+>v4l2_std_id</A
+>.</P
+></TD
+></TR
+><TR
+><TD
+ALIGN="LEFT"
+VALIGN="TOP"
+WIDTH="5%"
+><A
+NAME="FTN.AEN407"
+HREF="#AEN407"
+><SPAN
+CLASS="footnote"
+>[8]</SPAN
+></A
+></TD
+><TD
+ALIGN="LEFT"
+VALIGN="TOP"
+WIDTH="95%"
+><P
+>See <A
+HREF="#BUFFER"
+>Section 3.5</A
+> for a rationale. Probably
+even USB cameras follow some well known video standard. It might have
+been better to explicitly indicate elsewhere if a device cannot live
+up to normal expectations, instead of this exception.</P
+></TD
+></TR
+><TR
+><TD
+ALIGN="LEFT"
+VALIGN="TOP"
+WIDTH="5%"
+><A
+NAME="FTN.AEN451"
+HREF="#AEN451"
+><SPAN
+CLASS="footnote"
+>[9]</SPAN
+></A
+></TD
+><TD
+ALIGN="LEFT"
+VALIGN="TOP"
+WIDTH="95%"
+><P
+>It will be more convenient for applications if drivers
+make use of the <CODE
+CLASS="CONSTANT"
+>V4L2_CTRL_FLAG_DISABLED</CODE
+> flag, but
+that was never required.</P
+></TD
+></TR
+><TR
+><TD
+ALIGN="LEFT"
+VALIGN="TOP"
+WIDTH="5%"
+><A
+NAME="FTN.AEN454"
+HREF="#AEN454"
+><SPAN
+CLASS="footnote"
+>[10]</SPAN
+></A
+></TD
+><TD
+ALIGN="LEFT"
+VALIGN="TOP"
+WIDTH="95%"
+><P
+>Applications could call an ioctl to request events.
+After another process called <A
+HREF="#VIDIOC-G-CTRL"
+><CODE
+CLASS="CONSTANT"
+>VIDIOC_S_CTRL</CODE
+></A
+> or another ioctl changing
+shared properties the <CODE
+CLASS="FUNCTION"
+>select()</CODE
+> function would
+indicate readability until any ioctl (querying the properties) is
+called.</P
+></TD
+></TR
+><TR
+><TD
+ALIGN="LEFT"
+VALIGN="TOP"
+WIDTH="5%"
+><A
+NAME="FTN.AEN692"
+HREF="#AEN692"
+><SPAN
+CLASS="footnote"
+>[11]</SPAN
+></A
+></TD
+><TD
+ALIGN="LEFT"
+VALIGN="TOP"
+WIDTH="95%"
+><P
+>Enumerating formats an application has no a-priori
+knowledge of (otherwise it could explicitely ask for them and need not
+enumerate) seems useless, but there are applications serving as proxy
+between drivers and the actual video applications for which this is
+useful.</P
+></TD
+></TR
+><TR
+><TD
+ALIGN="LEFT"
+VALIGN="TOP"
+WIDTH="5%"
+><A
+NAME="FTN.AEN714"
+HREF="#AEN714"
+><SPAN
+CLASS="footnote"
+>[12]</SPAN
+></A
+></TD
+><TD
+ALIGN="LEFT"
+VALIGN="TOP"
+WIDTH="95%"
+><P
+>It may be desirable to refer to the cropping area in
+terms of sampling frequency and scanning system lines, but in order to
+support a wide range of hardware we better make as few assumptions as
+possible.</P
+></TD
+></TR
+><TR
+><TD
+ALIGN="LEFT"
+VALIGN="TOP"
+WIDTH="5%"
+><A
+NAME="FTN.AEN3273"
+HREF="#AEN3273"
+><SPAN
+CLASS="footnote"
+>[13]</SPAN
+></A
+></TD
+><TD
+ALIGN="LEFT"
+VALIGN="TOP"
+WIDTH="95%"
+><P
+>It would be desirable if applications could depend on
+drivers supporting all I/O interfaces, but as much as the complex
+memory mapping I/O can be inadequate for some devices we have no
+reason to require this interface, which is most useful for simple
+applications capturing still images.</P
+></TD
+></TR
+><TR
+><TD
+ALIGN="LEFT"
+VALIGN="TOP"
+WIDTH="5%"
+><A
+NAME="FTN.AEN3279"
+HREF="#AEN3279"
+><SPAN
+CLASS="footnote"
+>[14]</SPAN
+></A
+></TD
+><TD
+ALIGN="LEFT"
+VALIGN="TOP"
+WIDTH="95%"
+><P
+>At the driver level <CODE
+CLASS="FUNCTION"
+>select()</CODE
+> and
+<CODE
+CLASS="FUNCTION"
+>poll()</CODE
+> are the same, and
+<CODE
+CLASS="FUNCTION"
+>select()</CODE
+> is too important to be optional.</P
+></TD
+></TR
+><TR
+><TD
+ALIGN="LEFT"
+VALIGN="TOP"
+WIDTH="5%"
+><A
+NAME="FTN.AEN3296"
+HREF="#AEN3296"
+><SPAN
+CLASS="footnote"
+>[15]</SPAN
+></A
+></TD
+><TD
+ALIGN="LEFT"
+VALIGN="TOP"
+WIDTH="95%"
+><P
+>One could use one file descriptor and set the buffer
+type field accordingly when calling <A
+HREF="#VIDIOC-QBUF"
+><CODE
+CLASS="CONSTANT"
+>VIDIOC_QBUF</CODE
+></A
+> etc., but it makes
+the <CODE
+CLASS="FUNCTION"
+>select()</CODE
+> function ambiguous. We also like the
+clean approach of one file descriptor per logical stream. Video
+overlay for example is also a logical stream, although the CPU is not
+needed for continuous operation.</P
+></TD
+></TR
+><TR
+><TD
+ALIGN="LEFT"
+VALIGN="TOP"
+WIDTH="5%"
+><A
+NAME="FTN.AEN3329"
+HREF="#AEN3329"
+><SPAN
+CLASS="footnote"
+>[16]</SPAN
+></A
+></TD
+><TD
+ALIGN="LEFT"
+VALIGN="TOP"
+WIDTH="95%"
+><P
+>Random enqueue order permits applications processing
+images out of order (such as video codecs) to return buffers earlier,
+reducing the probability of data loss. Random fill order allows
+drivers to reuse buffers on a LIFO-basis, taking advantage of caches
+holding scatter-gather lists and the like.</P
+></TD
+></TR
+><TR
+><TD
+ALIGN="LEFT"
+VALIGN="TOP"
+WIDTH="5%"
+><A
+NAME="FTN.AEN3371"
+HREF="#AEN3371"
+><SPAN
+CLASS="footnote"
+>[17]</SPAN
+></A
+></TD
+><TD
+ALIGN="LEFT"
+VALIGN="TOP"
+WIDTH="95%"
+><P
+>At the driver level <CODE
+CLASS="FUNCTION"
+>select()</CODE
+> and
+<CODE
+CLASS="FUNCTION"
+>poll()</CODE
+> are the same, and
+<CODE
+CLASS="FUNCTION"
+>select()</CODE
+> is too important to be optional. The
+rest should be evident.</P
+></TD
+></TR
+><TR
+><TD
+ALIGN="LEFT"
+VALIGN="TOP"
+WIDTH="5%"
+><A
+NAME="FTN.AEN3402"
+HREF="#AEN3402"
+><SPAN
+CLASS="footnote"
+>[18]</SPAN
+></A
+></TD
+><TD
+ALIGN="LEFT"
+VALIGN="TOP"
+WIDTH="95%"
+><P
+>We expect that frequently used buffers are typically not
+swapped out. Anyway, the process of swapping, locking or generating
+scatter-gather lists may be time consuming. The delay can be masked by
+the depth of the incoming buffer queue, and perhaps by maintaining
+caches assuming a buffer will be soon enqueued again. On the other
+hand, to optimize memory usage drivers can limit the number of buffers
+locked in advance and recycle the most recently used buffers first. Of
+course, the pages of empty buffers in the incoming queue need not be
+saved to disk. Output buffers must be saved on the incoming and
+outgoing queue because an application may share them with other
+processes.</P
+></TD
+></TR
+><TR
+><TD
+ALIGN="LEFT"
+VALIGN="TOP"
+WIDTH="5%"
+><A
+NAME="FTN.AEN3438"
+HREF="#AEN3438"
+><SPAN
+CLASS="footnote"
+>[19]</SPAN
+></A
+></TD
+><TD
+ALIGN="LEFT"
+VALIGN="TOP"
+WIDTH="95%"
+><P
+>At the driver level <CODE
+CLASS="FUNCTION"
+>select()</CODE
+> and
+<CODE
+CLASS="FUNCTION"
+>poll()</CODE
+> are the same, and
+<CODE
+CLASS="FUNCTION"
+>select()</CODE
+> is too important to be optional. The
+rest should be evident.</P
+></TD
+></TR
+><TR
+><TD
+ALIGN="LEFT"
+VALIGN="TOP"
+WIDTH="5%"
+><A
+NAME="FTN.AEN3460"
+HREF="#AEN3460"
+><SPAN
+CLASS="footnote"
+>[20]</SPAN
+></A
+></TD
+><TD
+ALIGN="LEFT"
+VALIGN="TOP"
+WIDTH="95%"
+><P
+>Since no other Linux multimedia
+API supports unadjusted time it would be foolish to introduce here. We
+must use a universally supported clock to synchronize different media,
+hence time of day.</P
+></TD
+></TR
+><TR
+><TD
+ALIGN="LEFT"
+VALIGN="TOP"
+WIDTH="5%"
+><A
+NAME="FTN.AEN4042"
+HREF="#AEN4042"
+><SPAN
+CLASS="footnote"
+>[21]</SPAN
+></A
+></TD
+><TD
+ALIGN="LEFT"
+VALIGN="TOP"
+WIDTH="95%"
+><P
+>A common application of two file descriptors is the
+XFree86 <A
+HREF="#XVIDEO"
+>Xv/V4L</A
+> interface driver and
+a V4L2 application. While the X server controls video overlay, the
+application can take advantage of memory mapping and DMA.</P
+><P
+>In the opinion of the designers of this API, no driver
+writer taking the efforts to support simultaneous capturing and
+overlay will restrict this ability by requiring a single file
+descriptor, as in V4L and earlier versions of V4L2. Making this
+optional means applications depending on two file descriptors need
+backup routines to be compatible with all drivers, which is
+considerable more work than using two fds in applications which do
+not. Also two fd's fit the general concept of one file descriptor for
+each logical stream. Hence as a complexity trade-off drivers
+<SPAN
+CLASS="emphasis"
+><I
+CLASS="EMPHASIS"
+>must</I
+></SPAN
+> support two file descriptors and
+<SPAN
+CLASS="emphasis"
+><I
+CLASS="EMPHASIS"
+>may</I
+></SPAN
+> support single fd operation.</P
+></TD
+></TR
+><TR
+><TD
+ALIGN="LEFT"
+VALIGN="TOP"
+WIDTH="5%"
+><A
+NAME="FTN.AEN4216"
+HREF="#AEN4216"
+><SPAN
+CLASS="footnote"
+>[22]</SPAN
+></A
+></TD
+><TD
+ALIGN="LEFT"
+VALIGN="TOP"
+WIDTH="95%"
+><P
+>The X Window system defines "regions" which are
+vectors of struct BoxRec { short x1, y1, x2, y2; } with width = x2 -
+x1 and height = y2 - y1, so one cannot pass X11 clip lists
+directly.</P
+></TD
+></TR
+><TR
+><TD
+ALIGN="LEFT"
+VALIGN="TOP"
+WIDTH="5%"
+><A
+NAME="FTN.AEN4369"
+HREF="#AEN4369"
+><SPAN
+CLASS="footnote"
+>[23]</SPAN
+></A
+></TD
+><TD
+ALIGN="LEFT"
+VALIGN="TOP"
+WIDTH="95%"
+><P
+>ASK: Amplitude-Shift Keying. A high signal
+level represents a '1' bit, a low level a '0' bit.</P
+></TD
+></TR
+><TR
+><TD
+ALIGN="LEFT"
+VALIGN="TOP"
+WIDTH="5%"
+><A
+NAME="FTN.AEN5736"
+HREF="#AEN5736"
+><SPAN
+CLASS="footnote"
+>[24]</SPAN
+></A
+></TD
+><TD
+ALIGN="LEFT"
+VALIGN="TOP"
+WIDTH="95%"
+><P
+>The supported standards may overlap and we need an
+unambiguous set to find the current standard returned by
+<CODE
+CLASS="CONSTANT"
+>VIDIOC_G_STD</CODE
+>.</P
+></TD
+></TR
+><TR
+><TD
+ALIGN="LEFT"
+VALIGN="TOP"
+WIDTH="5%"
+><A
+NAME="FTN.AEN8815"
+HREF="#AEN8815"
+><SPAN
+CLASS="footnote"
+>[25]</SPAN
+></A
+></TD
+><TD
+ALIGN="LEFT"
+VALIGN="TOP"
+WIDTH="95%"
+><P
+><CODE
+CLASS="CONSTANT"
+>V4L2_CTRL_FLAG_DISABLED</CODE
+> was intended
+for two purposes: Drivers can skip predefined controls not supported
+by the hardware (although returning EINVAL would do as well), or
+disable predefined and custom controls after hardware detection
+without the trouble of reordering control arrays and indices.</P
+></TD
+></TR
+><TR
+><TD
+ALIGN="LEFT"
+VALIGN="TOP"
+WIDTH="5%"
+><A
+NAME="FTN.AEN9113"
+HREF="#AEN9113"
+><SPAN
+CLASS="footnote"
+>[26]</SPAN
+></A
+></TD
+><TD
+ALIGN="LEFT"
+VALIGN="TOP"
+WIDTH="95%"
+><P
+>For example video output requires at least two buffers,
+one displayed and one filled by the application.</P
+></TD
+></TR
+><TR
+><TD
+ALIGN="LEFT"
+VALIGN="TOP"
+WIDTH="5%"
+><A
+NAME="FTN.AEN11222"
+HREF="#AEN11222"
+><SPAN
+CLASS="footnote"
+>[27]</SPAN
+></A
+></TD
+><TD
+ALIGN="LEFT"
+VALIGN="TOP"
+WIDTH="95%"
+><P
+>This is not implemented in XFree86.</P
+></TD
+></TR
+></TABLE
+></BODY
+></HTML
+> \ No newline at end of file
diff --git a/v4l/ChangeLog b/v4l/ChangeLog
index 96d7f5ea0..d90d195a2 100644
--- a/v4l/ChangeLog
+++ b/v4l/ChangeLog
@@ -1,3 +1,10 @@
+2005-06-06 05:05 mchehab
+ * doc/V4L2_API.html:
+ - Included V4L2 API from http://v4l2spec.bytesex.org
+
+ *doc/V4L1_API.html
+ - Include Obsoleted V4L API from doc on kernel-2.6.12-rc5-mm2
+
2005-06-06 04:52 mchehab
* tuner-core.c:
- temporary debug log removed.
@@ -1179,7 +1186,7 @@
saa7134-reg.h, saa7134-ts.c, saa7134-tvaudio.c, saa7134-vbi.c,
saa7134-video.c, saa7134.h, video-buf.c, video-buf.h:
- - added a bunch of $Id: ChangeLog,v 1.23 2005/06/06 04:59:29 mchehab Exp $ tags.
+ - added a bunch of $Id: ChangeLog,v 1.24 2005/06/06 05:06:27 mchehab Exp $ tags.
2004-09-15 17:35 kraxel