WIP FPC-III support
[linux/fpc-iii.git] / Documentation / userspace-api / media / dvb / frontend-stat-properties.rst
blob223c1c56c9d3a1d56f64655870c32870f1872c78
1 .. SPDX-License-Identifier: GFDL-1.1-no-invariants-or-later
3 .. _frontend-stat-properties:
5 ******************************
6 Frontend statistics indicators
7 ******************************
9 The values are returned via ``dtv_property.stat``. If the property is
10 supported, ``dtv_property.stat.len`` is bigger than zero.
12 For most delivery systems, ``dtv_property.stat.len`` will be 1 if the
13 stats is supported, and the properties will return a single value for
14 each parameter.
16 It should be noted, however, that new OFDM delivery systems like ISDB
17 can use different modulation types for each group of carriers. On such
18 standards, up to 3 groups of statistics can be provided, and
19 ``dtv_property.stat.len`` is updated to reflect the "global" metrics,
20 plus one metric per each carrier group (called "layer" on ISDB).
22 So, in order to be consistent with other delivery systems, the first
23 value at :c:type:`dtv_property.stat.dtv_stats <dtv_stats>` array refers
24 to the global metric. The other elements of the array represent each
25 layer, starting from layer A(index 1), layer B (index 2) and so on.
27 The number of filled elements are stored at ``dtv_property.stat.len``.
29 Each element of the ``dtv_property.stat.dtv_stats`` array consists on
30 two elements:
32 -  ``svalue`` or ``uvalue``, where ``svalue`` is for signed values of
33    the measure (dB measures) and ``uvalue`` is for unsigned values
34    (counters, relative scale)
36 -  ``scale`` - Scale for the value. It can be:
38    -  ``FE_SCALE_NOT_AVAILABLE`` - The parameter is supported by the
39       frontend, but it was not possible to collect it (could be a
40       transitory or permanent condition)
42    -  ``FE_SCALE_DECIBEL`` - parameter is a signed value, measured in
43       1/1000 dB
45    -  ``FE_SCALE_RELATIVE`` - parameter is a unsigned value, where 0
46       means 0% and 65535 means 100%.
48    -  ``FE_SCALE_COUNTER`` - parameter is a unsigned value that counts
49       the occurrence of an event, like bit error, block error, or lapsed
50       time.
53 .. _DTV-STAT-SIGNAL-STRENGTH:
55 DTV_STAT_SIGNAL_STRENGTH
56 ========================
58 Indicates the signal strength level at the analog part of the tuner or
59 of the demod.
61 Possible scales for this metric are:
63 -  ``FE_SCALE_NOT_AVAILABLE`` - it failed to measure it, or the
64    measurement was not complete yet.
66 -  ``FE_SCALE_DECIBEL`` - signal strength is in 0.001 dBm units, power
67    measured in miliwatts. This value is generally negative.
69 -  ``FE_SCALE_RELATIVE`` - The frontend provides a 0% to 100%
70    measurement for power (actually, 0 to 65535).
73 .. _DTV-STAT-CNR:
75 DTV_STAT_CNR
76 ============
78 Indicates the Signal to Noise ratio for the main carrier.
80 Possible scales for this metric are:
82 -  ``FE_SCALE_NOT_AVAILABLE`` - it failed to measure it, or the
83    measurement was not complete yet.
85 -  ``FE_SCALE_DECIBEL`` - Signal/Noise ratio is in 0.001 dB units.
87 -  ``FE_SCALE_RELATIVE`` - The frontend provides a 0% to 100%
88    measurement for Signal/Noise (actually, 0 to 65535).
91 .. _DTV-STAT-PRE-ERROR-BIT-COUNT:
93 DTV_STAT_PRE_ERROR_BIT_COUNT
94 ============================
96 Measures the number of bit errors before the forward error correction
97 (FEC) on the inner coding block (before Viterbi, LDPC or other inner
98 code).
100 This measure is taken during the same interval as
101 ``DTV_STAT_PRE_TOTAL_BIT_COUNT``.
103 In order to get the BER (Bit Error Rate) measurement, it should be
104 divided by
105 :ref:`DTV_STAT_PRE_TOTAL_BIT_COUNT <DTV-STAT-PRE-TOTAL-BIT-COUNT>`.
107 This measurement is monotonically increased, as the frontend gets more
108 bit count measurements. The frontend may reset it when a
109 channel/transponder is tuned.
111 Possible scales for this metric are:
113 -  ``FE_SCALE_NOT_AVAILABLE`` - it failed to measure it, or the
114    measurement was not complete yet.
116 -  ``FE_SCALE_COUNTER`` - Number of error bits counted before the inner
117    coding.
120 .. _DTV-STAT-PRE-TOTAL-BIT-COUNT:
122 DTV_STAT_PRE_TOTAL_BIT_COUNT
123 ============================
125 Measures the amount of bits received before the inner code block, during
126 the same period as
127 :ref:`DTV_STAT_PRE_ERROR_BIT_COUNT <DTV-STAT-PRE-ERROR-BIT-COUNT>`
128 measurement was taken.
130 It should be noted that this measurement can be smaller than the total
131 amount of bits on the transport stream, as the frontend may need to
132 manually restart the measurement, losing some data between each
133 measurement interval.
135 This measurement is monotonically increased, as the frontend gets more
136 bit count measurements. The frontend may reset it when a
137 channel/transponder is tuned.
139 Possible scales for this metric are:
141 -  ``FE_SCALE_NOT_AVAILABLE`` - it failed to measure it, or the
142    measurement was not complete yet.
144 -  ``FE_SCALE_COUNTER`` - Number of bits counted while measuring
145    :ref:`DTV_STAT_PRE_ERROR_BIT_COUNT <DTV-STAT-PRE-ERROR-BIT-COUNT>`.
148 .. _DTV-STAT-POST-ERROR-BIT-COUNT:
150 DTV_STAT_POST_ERROR_BIT_COUNT
151 =============================
153 Measures the number of bit errors after the forward error correction
154 (FEC) done by inner code block (after Viterbi, LDPC or other inner
155 code).
157 This measure is taken during the same interval as
158 ``DTV_STAT_POST_TOTAL_BIT_COUNT``.
160 In order to get the BER (Bit Error Rate) measurement, it should be
161 divided by
162 :ref:`DTV_STAT_POST_TOTAL_BIT_COUNT <DTV-STAT-POST-TOTAL-BIT-COUNT>`.
164 This measurement is monotonically increased, as the frontend gets more
165 bit count measurements. The frontend may reset it when a
166 channel/transponder is tuned.
168 Possible scales for this metric are:
170 -  ``FE_SCALE_NOT_AVAILABLE`` - it failed to measure it, or the
171    measurement was not complete yet.
173 -  ``FE_SCALE_COUNTER`` - Number of error bits counted after the inner
174    coding.
177 .. _DTV-STAT-POST-TOTAL-BIT-COUNT:
179 DTV_STAT_POST_TOTAL_BIT_COUNT
180 =============================
182 Measures the amount of bits received after the inner coding, during the
183 same period as
184 :ref:`DTV_STAT_POST_ERROR_BIT_COUNT <DTV-STAT-POST-ERROR-BIT-COUNT>`
185 measurement was taken.
187 It should be noted that this measurement can be smaller than the total
188 amount of bits on the transport stream, as the frontend may need to
189 manually restart the measurement, losing some data between each
190 measurement interval.
192 This measurement is monotonically increased, as the frontend gets more
193 bit count measurements. The frontend may reset it when a
194 channel/transponder is tuned.
196 Possible scales for this metric are:
198 -  ``FE_SCALE_NOT_AVAILABLE`` - it failed to measure it, or the
199    measurement was not complete yet.
201 -  ``FE_SCALE_COUNTER`` - Number of bits counted while measuring
202    :ref:`DTV_STAT_POST_ERROR_BIT_COUNT <DTV-STAT-POST-ERROR-BIT-COUNT>`.
205 .. _DTV-STAT-ERROR-BLOCK-COUNT:
207 DTV_STAT_ERROR_BLOCK_COUNT
208 ==========================
210 Measures the number of block errors after the outer forward error
211 correction coding (after Reed-Solomon or other outer code).
213 This measurement is monotonically increased, as the frontend gets more
214 bit count measurements. The frontend may reset it when a
215 channel/transponder is tuned.
217 Possible scales for this metric are:
219 -  ``FE_SCALE_NOT_AVAILABLE`` - it failed to measure it, or the
220    measurement was not complete yet.
222 -  ``FE_SCALE_COUNTER`` - Number of error blocks counted after the outer
223    coding.
226 .. _DTV-STAT-TOTAL-BLOCK-COUNT:
228 DTV-STAT_TOTAL_BLOCK_COUNT
229 ==========================
231 Measures the total number of blocks received during the same period as
232 :ref:`DTV_STAT_ERROR_BLOCK_COUNT <DTV-STAT-ERROR-BLOCK-COUNT>`
233 measurement was taken.
235 It can be used to calculate the PER indicator, by dividing
236 :ref:`DTV_STAT_ERROR_BLOCK_COUNT <DTV-STAT-ERROR-BLOCK-COUNT>` by
237 :ref:`DTV-STAT-TOTAL-BLOCK-COUNT`.
239 Possible scales for this metric are:
241 -  ``FE_SCALE_NOT_AVAILABLE`` - it failed to measure it, or the
242    measurement was not complete yet.
244 -  ``FE_SCALE_COUNTER`` - Number of blocks counted while measuring
245    :ref:`DTV_STAT_ERROR_BLOCK_COUNT <DTV-STAT-ERROR-BLOCK-COUNT>`.