summaryrefslogtreecommitdiff
path: root/v4l
diff options
context:
space:
mode:
Diffstat (limited to 'v4l')
-rw-r--r--v4l/API/V4L1_API.html401
-rw-r--r--v4l/API/V4L2_API.html39683
-rw-r--r--v4l/Makefile3
-rwxr-xr-xv4l/scripts/check.pl4
-rwxr-xr-xv4l/scripts/checkpatch.pl4
-rwxr-xr-xv4l/scripts/do_merge.pl175
-rwxr-xr-xv4l/scripts/make_kconfig.pl17
-rw-r--r--v4l/versions.txt6
8 files changed, 200 insertions, 40093 deletions
diff --git a/v4l/API/V4L1_API.html b/v4l/API/V4L1_API.html
deleted file mode 100644
index 50d282140..000000000
--- a/v4l/API/V4L1_API.html
+++ /dev/null
@@ -1,401 +0,0 @@
-<HTML><HEAD>
-<TITLE>Video4Linux Kernel API Reference v0.1:19990430 - OBSOLETE - USE V4L2 API INSTEAD.</TITLE>
-</HEAD>
-<! Revision History: >
-<! 4/30/1999 - Fred Gleason (fredg@wava.com)>
-<! Documented extensions for the Radio Data System (RDS) extensions >
-<BODY bgcolor="#ffffff">
-<H1>Obsoleted by V4L2 API</H1>
-
-<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
deleted file mode 100644
index f1ef6aed3..000000000
--- a/v4l/API/V4L2_API.html
+++ /dev/null
@@ -1,39683 +0,0 @@
-<!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/Makefile b/v4l/Makefile
index 9d194178f..a5201f31b 100644
--- a/v4l/Makefile
+++ b/v4l/Makefile
@@ -240,7 +240,8 @@ ifneq ($(DIR),)
-e ' elsif (/^PATCHLEVEL\s*=\s*(\d+)/){ $$level=$$1; }' \
-e ' elsif (/^SUBLEVEL\s*=\s*(\d+)/){ $$sublevel=$$1; }' \
-e ' elsif (/^EXTRAVERSION\s*=\s*(\S+)\n/){ $$extra=$$1; }' \
- -e ' elsif (/^KERNELSRC\s*:=\s*(\S.*)\n/){ $$o=$$d; $$d=$$1; goto S; }' \
+ -e ' elsif (/^KERNELSRC\s*:=\s*(\S.*)\n/ || /^MAKEARGS\s*:=\s*-C\s*(\S.*)\n/)' \
+ -e ' { $$o=$$d; $$d=$$1; goto S; }' \
-e '};' \
-e 'printf ("VERSION=%s\nPATCHLEVEL:=%s\nSUBLEVEL:=%s\nKERNELRELEASE:=%s.%s.%s%s\n",' \
-e ' $$version,$$level,$$sublevel,$$version,$$level,$$sublevel,$$extra);' \
diff --git a/v4l/scripts/check.pl b/v4l/scripts/check.pl
index 4958e281b..975041c4a 100755
--- a/v4l/scripts/check.pl
+++ b/v4l/scripts/check.pl
@@ -87,6 +87,10 @@ $pwd =~ s|/[^/]+\n$||;
sub print_err()
{
+ if ($err =~ m/LINUX_VERSION_CODE/) {
+ return;
+ }
+
if ($err) {
printf STDERR "%s/%s: In '%s':\n", $pwd, $file, $errline;
printf STDERR "%s/%s:%d: %s\n", $pwd, $file, $ln_numb, $err;
diff --git a/v4l/scripts/checkpatch.pl b/v4l/scripts/checkpatch.pl
index 2d5ece798..b28d2b0f3 100755
--- a/v4l/scripts/checkpatch.pl
+++ b/v4l/scripts/checkpatch.pl
@@ -1937,13 +1937,13 @@ sub process {
($op eq '>' &&
$ca =~ /<\S+\@\S+$/))
{
- $ok = 1;
+ $ok = 1;
}
# Ignore ?:
if (($opv eq ':O' && $ca =~ /\?$/) ||
($op eq '?' && $cc =~ /^:/)) {
- $ok = 1;
+ $ok = 1;
}
if ($ok == 0) {
diff --git a/v4l/scripts/do_merge.pl b/v4l/scripts/do_merge.pl
new file mode 100755
index 000000000..0a4433a21
--- /dev/null
+++ b/v4l/scripts/do_merge.pl
@@ -0,0 +1,175 @@
+#!/usr/bin/perl
+
+my $merge_tree=shift or die "Should specify the pulled tree";
+
+sub hgrcuser($)
+{
+ my $file = shift;
+ my $ui = 0;
+ open IN, '<', $file;
+ while (<IN>) {
+ $ui = 1 if (/^\s*\[ui\]/);
+ if ($ui && /^\s*username\s*=\s*(\S.*?)\s*$/) {
+ close IN;
+ return($1);
+ }
+ }
+ close IN;
+ return("");
+}
+
+sub check_heads()
+{
+ my $count=0;
+ open IN, 'hg heads|';
+ while (<IN>) {
+ if (m/^[Cc]hangeset:/) {
+ $count++;
+ }
+ }
+ close IN;
+ return $count;
+}
+
+sub curr_changeset()
+{
+ my $changeset = -1;
+
+ open IN, 'hg heads|';
+ while (<IN>) {
+ if (m/^[Cc]hangeset:\s*(\d+)/) {
+ if ($changeset < 0) {
+ $changeset = $1;
+ } else {
+ if ($1 < $changeset) {
+ $changeset = $1;
+ }
+ }
+ }
+ }
+ close IN;
+ return $changeset;
+}
+
+sub check_status()
+{
+ my $count=0;
+ open IN, 'hg status -m -a -d -r|';
+ while (<IN>) {
+ $count++;
+ }
+ close IN;
+ return $count;
+}
+
+sub rollback()
+{
+ print "Rolling back hg pull $merge_tree\n";
+ system("hg rollback");
+ system("hg update -C");
+ exit -1;
+}
+
+####################
+# Determine username
+
+# Get Hg username from environment
+my $user = $ENV{HGUSER};
+
+# Didn't work? Try the repo's .hgrc file
+if ($user eq "") {
+ my $hgroot = `hg root`;
+ chomp($hgroot);
+ $user = hgrcuser("$hgroot/.hg/hgrc");
+}
+# Ok, try ~/.hgrc next
+if ($user eq "") {
+ $user = hgrcuser("$ENV{HOME}/.hgrc");
+}
+
+# Still no luck? Try some other environment variables
+if ($user eq "") {
+ my $name = $ENV{CHANGE_LOG_NAME};
+ my $email = $ENV{CHANGE_LOG_EMAIL_ADDRESS};
+ $user = "$name <$email>" if ($name ne "" || $email ne "");
+}
+
+# Last try to come up with something
+if ($user eq "") {
+ print "User not known. Can't procceed\n";
+ exit -1;
+}
+
+######################
+# Do some sanity tests
+
+print "Checking if everything is ok, before applying the new tree.\n";
+
+my $n_heads = check_heads();
+die "Your tree currently have more than one head (it has $n_heads heads). Can't procceed\n" if ($n_heads > 1);
+
+my $dirty = check_status();
+die "Your tree currently has changes. Can't procceed\n" if ($dirty);
+
+my $curr_cs = curr_changeset();
+
+###########
+# Pull tree
+
+print "hg pull $merge_tree\n";
+
+my $ret = system("hg pull $merge_tree");
+die "Couldn't pull from $merge_tree\n" if ($ret);
+
+#############################
+# Merge and commit, if needed
+
+$n_heads = check_heads();
+if ($n_heads > 2) {
+ print "The merged tree have more than one head (it has $n_heads heads). Can't procceed.\n";
+ rollback();
+}
+
+if ($n_heads == 2) {
+ print "Merging the new changesets\n";
+
+ $ret = system("hg merge");
+ if ($ret) {
+ print "hg merge failed. Can't procceed.\n";
+ rollback();
+ }
+
+ print "Committing the new tree\n";
+ # Write the commit message
+ $msg= "merge: $merge_tree\n\nFrom: $user\n\nSigned-off-by: $user\n";
+ $ret=system("hg commit -m '$msg'");
+ if ($ret) {
+ print "hg commit failed. Can't procceed.\n";
+ rollback();
+ }
+}
+
+#####################
+# Test resulting tree
+
+print "Testing if the build didn't break compilation. Only errors and warnings will be displayed. Please wait.\n";
+$ret = system ('make all|egrep -v "^\s*CC"|egrep -v "^\s*LD"');
+if ($ret) {
+ print "Build failed. Can't procceed.\n";
+
+ # To avoid the risk of doing something really bad, let's ask the user to run hg strip
+ print "Your tree is dirty. Since hg has only one rollback level, you'll need to use, instead:";
+ print "\thg strip $curr_cs; hg update -C";
+ print "You'll need to have hg mq extension enabled for hg strip to work.\n";
+
+ exit -1;
+}
+
+##############################
+# Everything is ok, let's push
+
+print "Pushing the new tree at the remote repository specified at .hg/hgrc\n";
+$ret=system ("hg push");
+if ($ret) {
+ print "hg push failed. Don't forget to do the push later.\n";
+}
diff --git a/v4l/scripts/make_kconfig.pl b/v4l/scripts/make_kconfig.pl
index 57c663c00..cfe53a636 100755
--- a/v4l/scripts/make_kconfig.pl
+++ b/v4l/scripts/make_kconfig.pl
@@ -277,11 +277,13 @@ sub open_kconfig($$) {
my $in_help = 0;
my $default_seen = 0;
my $if;
+ my $line;
print "Opening $file\n" if $debug;
open $in, '<', $file or die "File not found: $file";
push @kconfigfiles, $file;
while (<$in>) {
+ $line = $_;
# In our Kconfig files, the first non-help line after the
# help text always has no indention. Technically, the
# help text is ended by just by the indention decreasing,
@@ -303,7 +305,7 @@ sub open_kconfig($$) {
print OUT "\tdefault n\n";
}
print OUT "\tdepends on VIDEO_KERNEL_VERSION\n";
- $_ = sprintf($disabled_msg, $minver{$key});
+ $line = sprintf($disabled_msg, $minver{$key});
}
next;
}
@@ -319,10 +321,13 @@ sub open_kconfig($$) {
}
next if (/^\s*#/ || /^\s*$/); # skip comments and blank lines
+ # Erase any comments on this line
+ s/(?<!\\)#(.*)$//;
+
if (m|^\s*source\s+"([^"]+)"\s*$| ||
m|^\s*source\s+(\S+)\s*$|) {
open_kconfig($dir, "$dir/$1");
- $_ = ''; # don't print the source line itself
+ $line = ''; # don't print the source line itself
next;
}
@@ -453,13 +458,13 @@ sub open_kconfig($$) {
if ($disabled) {
$default_seen = 1;
- $_ = "\tdefault n\n";
+ $line = "\tdefault n\n";
}
} else {
print "Skipping $file:$. $_" if $debug;
}
} continue {
- print OUT $_;
+ print OUT $line;
}
close $in;
}
@@ -571,8 +576,8 @@ config VIDEO_KERNEL_VERSION
requiring a newer kernel is that no one has tested them with an
older one yet.
- If the driver works, please post a report at V4L mailing list:
- video4linux-list\@redhat.com.
+ If the driver works, please post a report to the V4L mailing list:
+ linux-media\@vger.kernel.org.
Unless you know what you are doing, you should answer N.
diff --git a/v4l/versions.txt b/v4l/versions.txt
index 369cbb15d..eb206b520 100644
--- a/v4l/versions.txt
+++ b/v4l/versions.txt
@@ -20,6 +20,10 @@ SOC_CAMERA
SOC_CAMERA_MT9V022
SOC_CAMERA_MT9M001
+[2.6.23]
+# Needs field intf_assoc in struct usb_host_config
+VIDEO_CX231XX
+
[2.6.22]
#This driver requires I2C probe/remove fields
VIDEO_TCM825X
@@ -41,6 +45,8 @@ USB_GSPCA_FINEPIX
USB_SI470X
# due to INIT_WORK changes
USB_GSPCA_SQ905
+USB_GSPCA_SQ905C
+VIDEO_HDPVR
[2.6.19]
#This driver were developed at kernel 2.6.19, requiring vmalloc_user/remap_vmalloc_range