cachepc-linux

Fork of AMDESE/linux with modifications for CachePC side-channel attack
git clone https://git.sinitax.com/sinitax/cachepc-linux
Log | Files | Refs | README | LICENSE | sfeed.txt

dtv-frontend.rst (15598B)


      1.. SPDX-License-Identifier: GPL-2.0
      2
      3Digital TV Frontend kABI
      4------------------------
      5
      6Digital TV Frontend
      7~~~~~~~~~~~~~~~~~~~
      8
      9The Digital TV Frontend kABI defines a driver-internal interface for
     10registering low-level, hardware specific driver to a hardware independent
     11frontend layer. It is only of interest for Digital TV device driver writers.
     12The header file for this API is named ``dvb_frontend.h`` and located in
     13``include/media/``.
     14
     15Demodulator driver
     16^^^^^^^^^^^^^^^^^^
     17
     18The demodulator driver is responsible for talking with the decoding part of the
     19hardware. Such driver should implement :c:type:`dvb_frontend_ops`, which
     20tells what type of digital TV standards are supported, and points to a
     21series of functions that allow the DVB core to command the hardware via
     22the code under ``include/media/dvb_frontend.c``.
     23
     24A typical example of such struct in a driver ``foo`` is::
     25
     26	static struct dvb_frontend_ops foo_ops = {
     27		.delsys = { SYS_DVBT, SYS_DVBT2, SYS_DVBC_ANNEX_A },
     28		.info = {
     29			.name	= "foo DVB-T/T2/C driver",
     30			.caps = FE_CAN_FEC_1_2 |
     31				FE_CAN_FEC_2_3 |
     32				FE_CAN_FEC_3_4 |
     33				FE_CAN_FEC_5_6 |
     34				FE_CAN_FEC_7_8 |
     35				FE_CAN_FEC_AUTO |
     36				FE_CAN_QPSK |
     37				FE_CAN_QAM_16 |
     38				FE_CAN_QAM_32 |
     39				FE_CAN_QAM_64 |
     40				FE_CAN_QAM_128 |
     41				FE_CAN_QAM_256 |
     42				FE_CAN_QAM_AUTO |
     43				FE_CAN_TRANSMISSION_MODE_AUTO |
     44				FE_CAN_GUARD_INTERVAL_AUTO |
     45				FE_CAN_HIERARCHY_AUTO |
     46				FE_CAN_MUTE_TS |
     47				FE_CAN_2G_MODULATION,
     48			.frequency_min = 42000000, /* Hz */
     49			.frequency_max = 1002000000, /* Hz */
     50			.symbol_rate_min = 870000,
     51			.symbol_rate_max = 11700000
     52		},
     53		.init = foo_init,
     54		.sleep = foo_sleep,
     55		.release = foo_release,
     56		.set_frontend = foo_set_frontend,
     57		.get_frontend = foo_get_frontend,
     58		.read_status = foo_get_status_and_stats,
     59		.tune = foo_tune,
     60		.i2c_gate_ctrl = foo_i2c_gate_ctrl,
     61		.get_frontend_algo = foo_get_algo,
     62	};
     63
     64A typical example of such struct in a driver ``bar`` meant to be used on
     65Satellite TV reception is::
     66
     67	static const struct dvb_frontend_ops bar_ops = {
     68		.delsys = { SYS_DVBS, SYS_DVBS2 },
     69		.info = {
     70			.name		= "Bar DVB-S/S2 demodulator",
     71			.frequency_min	= 500000, /* KHz */
     72			.frequency_max	= 2500000, /* KHz */
     73			.frequency_stepsize	= 0,
     74			.symbol_rate_min = 1000000,
     75			.symbol_rate_max = 45000000,
     76			.symbol_rate_tolerance = 500,
     77			.caps = FE_CAN_INVERSION_AUTO |
     78				FE_CAN_FEC_AUTO |
     79				FE_CAN_QPSK,
     80		},
     81		.init = bar_init,
     82		.sleep = bar_sleep,
     83		.release = bar_release,
     84		.set_frontend = bar_set_frontend,
     85		.get_frontend = bar_get_frontend,
     86		.read_status = bar_get_status_and_stats,
     87		.i2c_gate_ctrl = bar_i2c_gate_ctrl,
     88		.get_frontend_algo = bar_get_algo,
     89		.tune = bar_tune,
     90
     91		/* Satellite-specific */
     92		.diseqc_send_master_cmd = bar_send_diseqc_msg,
     93		.diseqc_send_burst = bar_send_burst,
     94		.set_tone = bar_set_tone,
     95		.set_voltage = bar_set_voltage,
     96	};
     97
     98.. note::
     99
    100   #) For satellite digital TV standards (DVB-S, DVB-S2, ISDB-S), the
    101      frequencies are specified in kHz, while, for terrestrial and cable
    102      standards, they're specified in Hz. Due to that, if the same frontend
    103      supports both types, you'll need to have two separate
    104      :c:type:`dvb_frontend_ops` structures, one for each standard.
    105   #) The ``.i2c_gate_ctrl`` field is present only when the hardware has
    106      allows controlling an I2C gate (either directly of via some GPIO pin),
    107      in order to remove the tuner from the I2C bus after a channel is
    108      tuned.
    109   #) All new drivers should implement the
    110      :ref:`DVBv5 statistics <dvbv5_stats>` via ``.read_status``.
    111      Yet, there are a number of callbacks meant to get statistics for
    112      signal strength, S/N and UCB. Those are there to provide backward
    113      compatibility with legacy applications that don't support the DVBv5
    114      API. Implementing those callbacks are optional. Those callbacks may be
    115      removed in the future, after we have all existing drivers supporting
    116      DVBv5 stats.
    117   #) Other callbacks are required for satellite TV standards, in order to
    118      control LNBf and DiSEqC: ``.diseqc_send_master_cmd``,
    119      ``.diseqc_send_burst``, ``.set_tone``, ``.set_voltage``.
    120
    121.. |delta|   unicode:: U+00394
    122
    123The ``include/media/dvb_frontend.c`` has a kernel thread which is
    124responsible for tuning the device. It supports multiple algorithms to
    125detect a channel, as defined at enum :c:func:`dvbfe_algo`.
    126
    127The algorithm to be used is obtained via ``.get_frontend_algo``. If the driver
    128doesn't fill its field at struct dvb_frontend_ops, it will default to
    129``DVBFE_ALGO_SW``, meaning that the dvb-core will do a zigzag when tuning,
    130e. g. it will try first to use the specified center frequency ``f``,
    131then, it will do ``f`` + |delta|, ``f`` - |delta|, ``f`` + 2 x |delta|,
    132``f`` - 2 x |delta| and so on.
    133
    134If the hardware has internally a some sort of zigzag algorithm, you should
    135define a ``.get_frontend_algo`` function that would return ``DVBFE_ALGO_HW``.
    136
    137.. note::
    138
    139   The core frontend support also supports
    140   a third type (``DVBFE_ALGO_CUSTOM``), in order to allow the driver to
    141   define its own hardware-assisted algorithm. Very few hardware need to
    142   use it nowadays. Using ``DVBFE_ALGO_CUSTOM`` require to provide other
    143   function callbacks at struct dvb_frontend_ops.
    144
    145Attaching frontend driver to the bridge driver
    146^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
    147
    148Before using the Digital TV frontend core, the bridge driver should attach
    149the frontend demod, tuner and SEC devices and call
    150:c:func:`dvb_register_frontend()`,
    151in order to register the new frontend at the subsystem. At device
    152detach/removal, the bridge driver should call
    153:c:func:`dvb_unregister_frontend()` to
    154remove the frontend from the core and then :c:func:`dvb_frontend_detach()`
    155to free the memory allocated by the frontend drivers.
    156
    157The drivers should also call :c:func:`dvb_frontend_suspend()` as part of
    158their handler for the :c:type:`device_driver`.\ ``suspend()``, and
    159:c:func:`dvb_frontend_resume()` as
    160part of their handler for :c:type:`device_driver`.\ ``resume()``.
    161
    162A few other optional functions are provided to handle some special cases.
    163
    164.. _dvbv5_stats:
    165
    166Digital TV Frontend statistics
    167~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
    168
    169Introduction
    170^^^^^^^^^^^^
    171
    172Digital TV frontends provide a range of
    173:ref:`statistics <frontend-stat-properties>` meant to help tuning the device
    174and measuring the quality of service.
    175
    176For each statistics measurement, the driver should set the type of scale used,
    177or ``FE_SCALE_NOT_AVAILABLE`` if the statistics is not available on a given
    178time. Drivers should also provide the number of statistics for each type.
    179that's usually 1 for most video standards [#f2]_.
    180
    181Drivers should initialize each statistic counters with length and
    182scale at its init code. For example, if the frontend provides signal
    183strength, it should have, on its init code::
    184
    185	struct dtv_frontend_properties *c = &state->fe.dtv_property_cache;
    186
    187	c->strength.len = 1;
    188	c->strength.stat[0].scale = FE_SCALE_NOT_AVAILABLE;
    189
    190And, when the statistics got updated, set the scale::
    191
    192	c->strength.stat[0].scale = FE_SCALE_DECIBEL;
    193	c->strength.stat[0].uvalue = strength;
    194
    195.. [#f2] For ISDB-T, it may provide both a global statistics and a per-layer
    196   set of statistics. On such cases, len should be equal to 4. The first
    197   value corresponds to the global stat; the other ones to each layer, e. g.:
    198
    199   - c->cnr.stat[0] for global S/N carrier ratio,
    200   - c->cnr.stat[1] for Layer A S/N carrier ratio,
    201   - c->cnr.stat[2] for layer B S/N carrier ratio,
    202   - c->cnr.stat[3] for layer C S/N carrier ratio.
    203
    204.. note:: Please prefer to use ``FE_SCALE_DECIBEL`` instead of
    205   ``FE_SCALE_RELATIVE`` for signal strength and CNR measurements.
    206
    207Groups of statistics
    208^^^^^^^^^^^^^^^^^^^^
    209
    210There are several groups of statistics currently supported:
    211
    212Signal strength (:ref:`DTV-STAT-SIGNAL-STRENGTH`)
    213  - Measures the signal strength level at the analog part of the tuner or
    214    demod.
    215
    216  - Typically obtained from the gain applied to the tuner and/or frontend
    217    in order to detect the carrier. When no carrier is detected, the gain is
    218    at the maximum value (so, strength is on its minimal).
    219
    220  - As the gain is visible through the set of registers that adjust the gain,
    221    typically, this statistics is always available [#f3]_.
    222
    223  - Drivers should try to make it available all the times, as these statistics
    224    can be used when adjusting an antenna position and to check for troubles
    225    at the cabling.
    226
    227  .. [#f3] On a few devices, the gain keeps floating if there is no carrier.
    228     On such devices, strength report should check first if carrier is
    229     detected at the tuner (``FE_HAS_CARRIER``, see :c:type:`fe_status`),
    230     and otherwise return the lowest possible value.
    231
    232Carrier Signal to Noise ratio (:ref:`DTV-STAT-CNR`)
    233  - Signal to Noise ratio for the main carrier.
    234
    235  - Signal to Noise measurement depends on the device. On some hardware, it is
    236    available when the main carrier is detected. On those hardware, CNR
    237    measurement usually comes from the tuner (e. g. after ``FE_HAS_CARRIER``,
    238    see :c:type:`fe_status`).
    239
    240    On other devices, it requires inner FEC decoding,
    241    as the frontend measures it indirectly from other parameters (e. g. after
    242    ``FE_HAS_VITERBI``, see :c:type:`fe_status`).
    243
    244    Having it available after inner FEC is more common.
    245
    246Bit counts post-FEC (:ref:`DTV-STAT-POST-ERROR-BIT-COUNT` and :ref:`DTV-STAT-POST-TOTAL-BIT-COUNT`)
    247  - Those counters measure the number of bits and bit errors after
    248    the forward error correction (FEC) on the inner coding block
    249    (after Viterbi, LDPC or other inner code).
    250
    251  - Due to its nature, those statistics depend on full coding lock
    252    (e. g. after ``FE_HAS_SYNC`` or after ``FE_HAS_LOCK``,
    253    see :c:type:`fe_status`).
    254
    255Bit counts pre-FEC (:ref:`DTV-STAT-PRE-ERROR-BIT-COUNT` and :ref:`DTV-STAT-PRE-TOTAL-BIT-COUNT`)
    256  - Those counters measure the number of bits and bit errors before
    257    the forward error correction (FEC) on the inner coding block
    258    (before Viterbi, LDPC or other inner code).
    259
    260  - Not all frontends provide this kind of statistics.
    261
    262  - Due to its nature, those statistics depend on inner coding lock (e. g.
    263    after ``FE_HAS_VITERBI``, see :c:type:`fe_status`).
    264
    265Block counts (:ref:`DTV-STAT-ERROR-BLOCK-COUNT` and :ref:`DTV-STAT-TOTAL-BLOCK-COUNT`)
    266  - Those counters measure the number of blocks and block errors after
    267    the forward error correction (FEC) on the inner coding block
    268    (before Viterbi, LDPC or other inner code).
    269
    270  - Due to its nature, those statistics depend on full coding lock
    271    (e. g. after ``FE_HAS_SYNC`` or after
    272    ``FE_HAS_LOCK``, see :c:type:`fe_status`).
    273
    274.. note:: All counters should be monotonically increased as they're
    275   collected from the hardware.
    276
    277A typical example of the logic that handle status and statistics is::
    278
    279	static int foo_get_status_and_stats(struct dvb_frontend *fe)
    280	{
    281		struct foo_state *state = fe->demodulator_priv;
    282		struct dtv_frontend_properties *c = &fe->dtv_property_cache;
    283
    284		int rc;
    285		enum fe_status *status;
    286
    287		/* Both status and strength are always available */
    288		rc = foo_read_status(fe, &status);
    289		if (rc < 0)
    290			return rc;
    291
    292		rc = foo_read_strength(fe);
    293		if (rc < 0)
    294			return rc;
    295
    296		/* Check if CNR is available */
    297		if (!(fe->status & FE_HAS_CARRIER))
    298			return 0;
    299
    300		rc = foo_read_cnr(fe);
    301		if (rc < 0)
    302			return rc;
    303
    304		/* Check if pre-BER stats are available */
    305		if (!(fe->status & FE_HAS_VITERBI))
    306			return 0;
    307
    308		rc = foo_get_pre_ber(fe);
    309		if (rc < 0)
    310			return rc;
    311
    312		/* Check if post-BER stats are available */
    313		if (!(fe->status & FE_HAS_SYNC))
    314			return 0;
    315
    316		rc = foo_get_post_ber(fe);
    317		if (rc < 0)
    318			return rc;
    319	}
    320
    321	static const struct dvb_frontend_ops ops = {
    322		/* ... */
    323		.read_status = foo_get_status_and_stats,
    324	};
    325
    326Statistics collection
    327^^^^^^^^^^^^^^^^^^^^^
    328
    329On almost all frontend hardware, the bit and byte counts are stored by
    330the hardware after a certain amount of time or after the total bit/block
    331counter reaches a certain value (usually programmable), for example, on
    332every 1000 ms or after receiving 1,000,000 bits.
    333
    334So, if you read the registers too soon, you'll end by reading the same
    335value as in the previous reading, causing the monotonic value to be
    336incremented too often.
    337
    338Drivers should take the responsibility to avoid too often reads. That
    339can be done using two approaches:
    340
    341if the driver have a bit that indicates when a collected data is ready
    342%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
    343
    344Driver should check such bit before making the statistics available.
    345
    346An example of such behavior can be found at this code snippet (adapted
    347from mb86a20s driver's logic)::
    348
    349	static int foo_get_pre_ber(struct dvb_frontend *fe)
    350	{
    351		struct foo_state *state = fe->demodulator_priv;
    352		struct dtv_frontend_properties *c = &fe->dtv_property_cache;
    353		int rc, bit_error;
    354
    355		/* Check if the BER measures are already available */
    356		rc = foo_read_u8(state, 0x54);
    357		if (rc < 0)
    358			return rc;
    359
    360		if (!rc)
    361			return 0;
    362
    363		/* Read Bit Error Count */
    364		bit_error = foo_read_u32(state, 0x55);
    365		if (bit_error < 0)
    366			return bit_error;
    367
    368		/* Read Total Bit Count */
    369		rc = foo_read_u32(state, 0x51);
    370		if (rc < 0)
    371			return rc;
    372
    373		c->pre_bit_error.stat[0].scale = FE_SCALE_COUNTER;
    374		c->pre_bit_error.stat[0].uvalue += bit_error;
    375		c->pre_bit_count.stat[0].scale = FE_SCALE_COUNTER;
    376		c->pre_bit_count.stat[0].uvalue += rc;
    377
    378		return 0;
    379	}
    380
    381If the driver doesn't provide a statistics available check bit
    382%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
    383
    384A few devices, however, may not provide a way to check if the stats are
    385available (or the way to check it is unknown). They may not even provide
    386a way to directly read the total number of bits or blocks.
    387
    388On those devices, the driver need to ensure that it won't be reading from
    389the register too often and/or estimate the total number of bits/blocks.
    390
    391On such drivers, a typical routine to get statistics would be like
    392(adapted from dib8000 driver's logic)::
    393
    394	struct foo_state {
    395		/* ... */
    396
    397		unsigned long per_jiffies_stats;
    398	}
    399
    400	static int foo_get_pre_ber(struct dvb_frontend *fe)
    401	{
    402		struct foo_state *state = fe->demodulator_priv;
    403		struct dtv_frontend_properties *c = &fe->dtv_property_cache;
    404		int rc, bit_error;
    405		u64 bits;
    406
    407		/* Check if time for stats was elapsed */
    408		if (!time_after(jiffies, state->per_jiffies_stats))
    409			return 0;
    410
    411		/* Next stat should be collected in 1000 ms */
    412		state->per_jiffies_stats = jiffies + msecs_to_jiffies(1000);
    413
    414		/* Read Bit Error Count */
    415		bit_error = foo_read_u32(state, 0x55);
    416		if (bit_error < 0)
    417			return bit_error;
    418
    419		/*
    420		 * On this particular frontend, there's no register that
    421		 * would provide the number of bits per 1000ms sample. So,
    422		 * some function would calculate it based on DTV properties
    423		 */
    424		bits = get_number_of_bits_per_1000ms(fe);
    425
    426		c->pre_bit_error.stat[0].scale = FE_SCALE_COUNTER;
    427		c->pre_bit_error.stat[0].uvalue += bit_error;
    428		c->pre_bit_count.stat[0].scale = FE_SCALE_COUNTER;
    429		c->pre_bit_count.stat[0].uvalue += bits;
    430
    431		return 0;
    432	}
    433
    434Please notice that, on both cases, we're getting the statistics using the
    435:c:type:`dvb_frontend_ops` ``.read_status`` callback. The rationale is that
    436the frontend core will automatically call this function periodically
    437(usually, 3 times per second, when the frontend is locked).
    438
    439That warrants that we won't miss to collect a counter and increment the
    440monotonic stats at the right time.
    441
    442Digital TV Frontend functions and types
    443~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
    444
    445.. kernel-doc:: include/media/dvb_frontend.h