[media] doc-rst: Add ivtv documentation

Convert ivtv documentation to rst, update the links there
and add to media/v4l-drivers book.

Signed-off-by: Mauro Carvalho Chehab <mchehab@s-opensource.com>
This commit is contained in:
Mauro Carvalho Chehab 2016-07-17 18:13:46 -03:00
parent f0726e4275
commit 2a744b0d7b
2 changed files with 121 additions and 89 deletions

View File

@ -26,4 +26,5 @@ License".
cx88 cx88
davinci-vpbe davinci-vpbe
fimc fimc
ivtv
zr364xx zr364xx

View File

@ -1,26 +1,32 @@
ivtv release notes The ivtv driver
================== ===============
Author: Hans Verkuil <hverkuil@xs4all.nl>
This is a v4l2 device driver for the Conexant cx23415/6 MPEG encoder/decoder. This is a v4l2 device driver for the Conexant cx23415/6 MPEG encoder/decoder.
The cx23415 can do both encoding and decoding, the cx23416 can only do MPEG The cx23415 can do both encoding and decoding, the cx23416 can only do MPEG
encoding. Currently the only card featuring full decoding support is the encoding. Currently the only card featuring full decoding support is the
Hauppauge PVR-350. Hauppauge PVR-350.
NOTE: this driver requires the latest encoder firmware (version 2.06.039, size .. note::
376836 bytes). Get the firmware from here:
http://dl.ivtvdriver.org/ivtv/firmware/ #) This driver requires the latest encoder firmware (version 2.06.039, size
376836 bytes). Get the firmware from here:
NOTE: 'normal' TV applications do not work with this driver, you need https://linuxtv.org/downloads/firmware/#conexant
an application that can handle MPEG input such as mplayer, xine, MythTV,
etc. #) 'normal' TV applications do not work with this driver, you need
an application that can handle MPEG input such as mplayer, xine, MythTV,
etc.
The primary goal of the IVTV project is to provide a "clean room" Linux The primary goal of the IVTV project is to provide a "clean room" Linux
Open Source driver implementation for video capture cards based on the Open Source driver implementation for video capture cards based on the
iCompression iTVC15 or Conexant CX23415/CX23416 MPEG Codec. iCompression iTVC15 or Conexant CX23415/CX23416 MPEG Codec.
Features: Features
--------
* Hardware mpeg2 capture of broadcast video (and sound) via the tuner or * Hardware mpeg2 capture of broadcast video (and sound) via the tuner or
S-Video/Composite and audio line-in. S-Video/Composite and audio line-in.
* Hardware mpeg2 capture of FM radio where hardware support exists * Hardware mpeg2 capture of FM radio where hardware support exists
@ -31,7 +37,9 @@ Features:
this into the captured MPEG stream. this into the captured MPEG stream.
* Supports raw YUV and PCM input. * Supports raw YUV and PCM input.
Additional features for the PVR-350 (CX23415 based): Additional features for the PVR-350 (CX23415 based)
---------------------------------------------------
* Provides hardware mpeg2 playback * Provides hardware mpeg2 playback
* Provides comprehensive OSD (On Screen Display: ie. graphics overlaying the * Provides comprehensive OSD (On Screen Display: ie. graphics overlaying the
video signal) video signal)
@ -40,20 +48,22 @@ Additional features for the PVR-350 (CX23415 based):
* Supports raw YUV output. * Supports raw YUV output.
IMPORTANT: In case of problems first read this page: IMPORTANT: In case of problems first read this page:
http://www.ivtvdriver.org/index.php/Troubleshooting https://help.ubuntu.com/community/Install_IVTV_Troubleshooting
See also: See also
--------
Homepage + Wiki https://linuxtv.org
http://www.ivtvdriver.org
IRC IRC
irc://irc.freenode.net/ivtv-dev ---
irc://irc.freenode.net/#v4l
---------------------------------------------------------- ----------------------------------------------------------
Devices Devices
======= -------
A maximum of 12 ivtv boards are allowed at the moment. A maximum of 12 ivtv boards are allowed at the moment.
@ -65,25 +75,28 @@ The radio0 device may or may not be present, depending on whether the
card has a radio tuner or not. card has a radio tuner or not.
Here is a list of the base v4l devices: Here is a list of the base v4l devices:
crw-rw---- 1 root video 81, 0 Jun 19 22:22 /dev/video0
crw-rw---- 1 root video 81, 16 Jun 19 22:22 /dev/video16 .. code-block:: none
crw-rw---- 1 root video 81, 24 Jun 19 22:22 /dev/video24
crw-rw---- 1 root video 81, 32 Jun 19 22:22 /dev/video32 crw-rw---- 1 root video 81, 0 Jun 19 22:22 /dev/video0
crw-rw---- 1 root video 81, 48 Jun 19 22:22 /dev/video48 crw-rw---- 1 root video 81, 16 Jun 19 22:22 /dev/video16
crw-rw---- 1 root video 81, 64 Jun 19 22:22 /dev/radio0 crw-rw---- 1 root video 81, 24 Jun 19 22:22 /dev/video24
crw-rw---- 1 root video 81, 224 Jun 19 22:22 /dev/vbi0 crw-rw---- 1 root video 81, 32 Jun 19 22:22 /dev/video32
crw-rw---- 1 root video 81, 228 Jun 19 22:22 /dev/vbi8 crw-rw---- 1 root video 81, 48 Jun 19 22:22 /dev/video48
crw-rw---- 1 root video 81, 232 Jun 19 22:22 /dev/vbi16 crw-rw---- 1 root video 81, 64 Jun 19 22:22 /dev/radio0
crw-rw---- 1 root video 81, 224 Jun 19 22:22 /dev/vbi0
crw-rw---- 1 root video 81, 228 Jun 19 22:22 /dev/vbi8
crw-rw---- 1 root video 81, 232 Jun 19 22:22 /dev/vbi16
Base devices Base devices
============ ------------
For every extra card you have the numbers increased by one. For example, For every extra card you have the numbers increased by one. For example,
/dev/video0 is listed as the 'base' encoding capture device so we have: /dev/video0 is listed as the 'base' encoding capture device so we have:
/dev/video0 is the encoding capture device for the first card (card 0) - /dev/video0 is the encoding capture device for the first card (card 0)
/dev/video1 is the encoding capture device for the second card (card 1) - /dev/video1 is the encoding capture device for the second card (card 1)
/dev/video2 is the encoding capture device for the third card (card 2) - /dev/video2 is the encoding capture device for the third card (card 2)
Note that if the first card doesn't have a feature (eg no decoder, so no Note that if the first card doesn't have a feature (eg no decoder, so no
video16, the second card will still use video17. The simple rule is 'add video16, the second card will still use video17. The simple rule is 'add
@ -94,93 +107,111 @@ whatever). Otherwise the device numbers can get confusing. The ivtv
'ivtv_first_minor' module option can be used for that. 'ivtv_first_minor' module option can be used for that.
/dev/video0 - /dev/video0
The encoding capture device(s).
Read-only.
Reading from this device gets you the MPEG1/2 program stream. The encoding capture device(s).
Example:
cat /dev/video0 > my.mpg (you need to hit ctrl-c to exit) Read-only.
Reading from this device gets you the MPEG1/2 program stream.
Example:
.. code-block:: none
cat /dev/video0 > my.mpg (you need to hit ctrl-c to exit)
/dev/video16 - /dev/video16
The decoder output device(s)
Write-only. Only present if the MPEG decoder (i.e. CX23415) exists.
An mpeg2 stream sent to this device will appear on the selected video The decoder output device(s)
display, audio will appear on the line-out/audio out. It is only
available for cards that support video out. Example:
cat my.mpg >/dev/video16 Write-only. Only present if the MPEG decoder (i.e. CX23415) exists.
An mpeg2 stream sent to this device will appear on the selected video
display, audio will appear on the line-out/audio out. It is only
available for cards that support video out. Example:
.. code-block:: none
cat my.mpg >/dev/video16
/dev/video24 - /dev/video24
The raw audio capture device(s).
Read-only
The raw audio PCM stereo stream from the currently selected The raw audio capture device(s).
tuner or audio line-in. Reading from this device results in a raw
(signed 16 bit Little Endian, 48000 Hz, stereo pcm) capture. Read-only
This device only captures audio. This should be replaced by an ALSA
device in the future. The raw audio PCM stereo stream from the currently selected
Note that there is no corresponding raw audio output device, this is tuner or audio line-in. Reading from this device results in a raw
not supported in the decoder firmware. (signed 16 bit Little Endian, 48000 Hz, stereo pcm) capture.
This device only captures audio. This should be replaced by an ALSA
device in the future.
Note that there is no corresponding raw audio output device, this is
not supported in the decoder firmware.
/dev/video32 - /dev/video32
The raw video capture device(s)
Read-only
The raw YUV video output from the current video input. The YUV format The raw video capture device(s)
is non-standard (V4L2_PIX_FMT_HM12).
Note that the YUV and PCM streams are not synchronized, so they are of Read-only
limited use.
The raw YUV video output from the current video input. The YUV format
is non-standard (V4L2_PIX_FMT_HM12).
Note that the YUV and PCM streams are not synchronized, so they are of
limited use.
/dev/video48 - /dev/video48
The raw video display device(s)
Write-only. Only present if the MPEG decoder (i.e. CX23415) exists.
Writes a YUV stream to the decoder of the card. The raw video display device(s)
Write-only. Only present if the MPEG decoder (i.e. CX23415) exists.
Writes a YUV stream to the decoder of the card.
/dev/radio0 - /dev/radio0
The radio tuner device(s)
Cannot be read or written.
Used to enable the radio tuner and tune to a frequency. You cannot The radio tuner device(s)
read or write audio streams with this device. Once you use this
device to tune the radio, use /dev/video24 to read the raw pcm stream Cannot be read or written.
or /dev/video0 to get an mpeg2 stream with black video.
Used to enable the radio tuner and tune to a frequency. You cannot
read or write audio streams with this device. Once you use this
device to tune the radio, use /dev/video24 to read the raw pcm stream
or /dev/video0 to get an mpeg2 stream with black video.
/dev/vbi0 - /dev/vbi0
The 'vertical blank interval' (Teletext, CC, WSS etc) capture device(s)
Read-only
Captures the raw (or sliced) video data sent during the Vertical Blank The 'vertical blank interval' (Teletext, CC, WSS etc) capture device(s)
Interval. This data is used to encode teletext, closed captions, VPS,
widescreen signalling, electronic program guide information, and other Read-only
services.
Captures the raw (or sliced) video data sent during the Vertical Blank
Interval. This data is used to encode teletext, closed captions, VPS,
widescreen signalling, electronic program guide information, and other
services.
/dev/vbi8 - /dev/vbi8
Processed vbi feedback device(s)
Read-only. Only present if the MPEG decoder (i.e. CX23415) exists.
The sliced VBI data embedded in an MPEG stream is reproduced on this Processed vbi feedback device(s)
device. So while playing back a recording on /dev/video16, you can
read the embedded VBI data from /dev/vbi8. Read-only. Only present if the MPEG decoder (i.e. CX23415) exists.
The sliced VBI data embedded in an MPEG stream is reproduced on this
device. So while playing back a recording on /dev/video16, you can
read the embedded VBI data from /dev/vbi8.
/dev/vbi16 - /dev/vbi16
The vbi 'display' device(s)
Write-only. Only present if the MPEG decoder (i.e. CX23415) exists.
Can be used to send sliced VBI data to the video-out connector. The vbi 'display' device(s)
--------------------------------- Write-only. Only present if the MPEG decoder (i.e. CX23415) exists.
Hans Verkuil <hverkuil@xs4all.nl> Can be used to send sliced VBI data to the video-out connector.