linux/drivers/media/test-drivers/vidtv/vidtv_demod.h
<<
>>
Prefs
   1/* SPDX-License-Identifier: GPL-2.0-or-later */
   2/*
   3 * The Virtual DTV test driver serves as a reference DVB driver and helps
   4 * validate the existing APIs in the media subsystem. It can also aid
   5 * developers working on userspace applications.
   6 *
   7 * Copyright (C) 2020 Daniel W. S. Almeida
   8 * Based on the example driver written by Emard <emard@softhome.net>
   9 */
  10
  11#ifndef VIDTV_DEMOD_H
  12#define VIDTV_DEMOD_H
  13
  14#include <linux/dvb/frontend.h>
  15
  16#include <media/dvb_frontend.h>
  17
  18/**
  19 * struct vidtv_demod_cnr_to_qual_s - Map CNR values to a given combination of
  20 * modulation and fec_inner
  21 * @modulation: see enum fe_modulation
  22 * @fec: see enum fe_fec_rate
  23 * @cnr_ok: S/N threshold to consider the signal as OK. Below that, there's
  24 *          a chance of losing sync.
  25 * @cnr_good: S/N threshold to consider the signal strong.
  26 *
  27 * This struct matches values for 'good' and 'ok' CNRs given the combination
  28 * of modulation and fec_inner in use. We might simulate some noise if the
  29 * signal quality is not too good.
  30 *
  31 * The values were taken from libdvbv5.
  32 */
  33struct vidtv_demod_cnr_to_qual_s {
  34        u32 modulation;
  35        u32 fec;
  36        u32 cnr_ok;
  37        u32 cnr_good;
  38};
  39
  40/**
  41 * struct vidtv_demod_config - Configuration used to init the demod
  42 * @drop_tslock_prob_on_low_snr: probability of losing the lock due to low snr
  43 * @recover_tslock_prob_on_good_snr: probability of recovering when the signal
  44 * improves
  45 *
  46 * The configuration used to init the demodulator module, usually filled
  47 * by a bridge driver. For vidtv, this is filled by vidtv_bridge before the
  48 * demodulator module is probed.
  49 */
  50struct vidtv_demod_config {
  51        u8 drop_tslock_prob_on_low_snr;
  52        u8 recover_tslock_prob_on_good_snr;
  53};
  54
  55/**
  56 * struct vidtv_demod_state - The demodulator state
  57 * @frontend: The frontend structure allocated by the demod.
  58 * @config: The config used to init the demod.
  59 * @status: the demod status.
  60 * @tuner_cnr: current S/N ratio for the signal carrier
  61 */
  62struct vidtv_demod_state {
  63        struct dvb_frontend frontend;
  64        struct vidtv_demod_config config;
  65        enum fe_status status;
  66        u16 tuner_cnr;
  67};
  68#endif // VIDTV_DEMOD_H
  69