1 .. Permission is granted to copy, distribute and/or modify this
2 .. document under the terms of the GNU Free Documentation License,
3 .. Version 1.1 or any later version published by the Free Software
4 .. Foundation, with no Invariant Sections, no Front-Cover Texts
5 .. and no Back-Cover Texts. A copy of the license is included at
6 .. Documentation/media/uapi/fdl-appendix.rst.
8 .. TODO: replace it to GFDL-1.1-or-later WITH no-invariant-sections
22 The reader of this document is required to have some knowledge in the
23 area of digital video broadcasting (Digital TV) and should be familiar with
24 part I of the MPEG2 specification ISO/IEC 13818 (aka ITU-T H.222), i.e
25 you should know what a program/transport stream (PS/TS) is and what is
26 meant by a packetized elementary stream (PES) or an I-frame.
28 Various Digital TV standards documents are available for download at:
30 - European standards (DVB): http://www.dvb.org and/or http://www.etsi.org.
31 - American standards (ATSC): https://www.atsc.org/standards/
32 - Japanese standards (ISDB): http://www.dibeg.org/
34 It is also necessary to know how to access Linux devices and how to
35 use ioctl calls. This also includes the knowledge of C or C++.
43 The first API for Digital TV cards we used at Convergence in late 1999 was an
44 extension of the Video4Linux API which was primarily developed for frame
45 grabber cards. As such it was not really well suited to be used for Digital
46 TV cards and their new features like recording MPEG streams and filtering
47 several section and PES data streams at the same time.
49 In early 2000, Convergence was approached by Nokia with a proposal for a new
50 standard Linux Digital TV API. As a commitment to the development of terminals
51 based on open standards, Nokia and Convergence made it available to all
52 Linux developers and published it on https://linuxtv.org in September
53 2000. With the Linux driver for the Siemens/Hauppauge DVB PCI card,
54 Convergence provided a first implementation of the Linux Digital TV API.
55 Convergence was the maintainer of the Linux Digital TV API in the early
58 Now, the API is maintained by the LinuxTV community (i.e. you, the reader
59 of this document). The Linux Digital TV API is constantly reviewed and
60 improved together with the improvements at the subsystem's core at the
72 .. kernel-figure:: dvbstb.svg
76 Components of a Digital TV card/STB
78 A Digital TV card or set-top-box (STB) usually consists of the
79 following main hardware components:
81 Frontend consisting of tuner and digital TV demodulator
82 Here the raw signal reaches the digital TV hardware from a satellite dish or
83 antenna or directly from cable. The frontend down-converts and
84 demodulates this signal into an MPEG transport stream (TS). In case
85 of a satellite frontend, this includes a facility for satellite
86 equipment control (SEC), which allows control of LNB polarization,
87 multi feed switches or dish rotors.
89 Conditional Access (CA) hardware like CI adapters and smartcard slots
90 The complete TS is passed through the CA hardware. Programs to which
91 the user has access (controlled by the smart card) are decoded in
92 real time and re-inserted into the TS.
96 Not every digital TV hardware provides conditional access hardware.
98 Demultiplexer which filters the incoming Digital TV MPEG-TS stream
99 The demultiplexer splits the TS into its components like audio and
100 video streams. Besides usually several of such audio and video
101 streams it also contains data streams with information about the
102 programs offered in this or other streams of the same provider.
104 Audio and video decoder
105 The main targets of the demultiplexer are audio and video
106 decoders. After decoding, they pass on the uncompressed audio and
107 video to the computer screen or to a TV set.
111 Modern hardware usually doesn't have a separate decoder hardware, as
112 such functionality can be provided by the main CPU, by the graphics
113 adapter of the system or by a signal processing hardware embedded on
114 a Systems on a Chip (SoC) integrated circuit.
116 It may also not be needed for certain usages (e.g. for data-only
117 uses like “internet over satellite”).
119 :ref:`stb_components` shows a crude schematic of the control and data
120 flow between those components.
126 Linux Digital TV Devices
127 ========================
129 The Linux Digital TV API lets you control these hardware components through
130 currently six Unix-style character devices for video, audio, frontend,
131 demux, CA and IP-over-DVB networking. The video and audio devices
132 control the MPEG2 decoder hardware, the frontend device the tuner and
133 the Digital TV demodulator. The demux device gives you control over the PES
134 and section filters of the hardware. If the hardware does not support
135 filtering these filters can be implemented in software. Finally, the CA
136 device controls all the conditional access capabilities of the hardware.
137 It can depend on the individual security requirements of the platform,
138 if and how many of the CA functions are made available to the
139 application through this device.
141 All devices can be found in the ``/dev`` tree under ``/dev/dvb``. The
142 individual devices are called:
144 - ``/dev/dvb/adapterN/audioM``,
146 - ``/dev/dvb/adapterN/videoM``,
148 - ``/dev/dvb/adapterN/frontendM``,
150 - ``/dev/dvb/adapterN/netM``,
152 - ``/dev/dvb/adapterN/demuxM``,
154 - ``/dev/dvb/adapterN/dvrM``,
156 - ``/dev/dvb/adapterN/caM``,
158 where ``N`` enumerates the Digital TV cards in a system starting from 0, and
159 ``M`` enumerates the devices of each type within each adapter, starting
160 from 0, too. We will omit the “``/dev/dvb/adapterN/``\ ” in the further
161 discussion of these devices.
163 More details about the data structures and function calls of all the
164 devices are described in the following chapters.
172 For each of the Digital TV devices a corresponding include file exists. The
173 Digital TV API include files should be included in application sources with a
179 #include <linux/dvb/ca.h>
181 #include <linux/dvb/dmx.h>
183 #include <linux/dvb/frontend.h>
185 #include <linux/dvb/net.h>
188 To enable applications to support different API version, an additional
189 include file ``linux/dvb/version.h`` exists, which defines the constant
190 ``DVB_API_VERSION``. This document describes ``DVB_API_VERSION 5.10``.