root/drivers/media/pci/ddbridge/ddbridge-mci.h

/* [<][>][^][v][top][bottom][index][help] */

INCLUDED FROM


   1 /* SPDX-License-Identifier: GPL-2.0 */
   2 /*
   3  * ddbridge-mci.h: Digital Devices micro code interface
   4  *
   5  * Copyright (C) 2017-2018 Digital Devices GmbH
   6  *                         Marcus Metzler <mocm@metzlerbros.de>
   7  *                         Ralph Metzler <rjkm@metzlerbros.de>
   8  *
   9  * This program is free software; you can redistribute it and/or
  10  * modify it under the terms of the GNU General Public License
  11  * version 2 only, as published by the Free Software Foundation.
  12  *
  13  * This program is distributed in the hope that it will be useful,
  14  * but WITHOUT ANY WARRANTY; without even the implied warranty of
  15  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  16  * GNU General Public License for more details.
  17  */
  18 
  19 #ifndef _DDBRIDGE_MCI_H_
  20 #define _DDBRIDGE_MCI_H_
  21 
  22 #define MCI_DEMOD_MAX                       8
  23 #define MCI_TUNER_MAX                       4
  24 #define DEMOD_UNUSED                        (0xFF)
  25 
  26 #define MCI_CONTROL                         (0x500)
  27 #define MCI_COMMAND                         (0x600)
  28 #define MCI_RESULT                          (0x680)
  29 
  30 #define MCI_COMMAND_SIZE                    (0x80)
  31 #define MCI_RESULT_SIZE                     (0x80)
  32 
  33 #define MCI_CONTROL_START_COMMAND           (0x00000001)
  34 #define MCI_CONTROL_ENABLE_DONE_INTERRUPT   (0x00000002)
  35 #define MCI_CONTROL_RESET                   (0x00008000)
  36 #define MCI_CONTROL_READY                   (0x00010000)
  37 
  38 #define SX8_TSCONFIG                        (0x280)
  39 
  40 #define SX8_TSCONFIG_MODE_MASK              (0x00000003)
  41 #define SX8_TSCONFIG_MODE_OFF               (0x00000000)
  42 #define SX8_TSCONFIG_MODE_NORMAL            (0x00000001)
  43 #define SX8_TSCONFIG_MODE_IQ                (0x00000003)
  44 
  45 /*
  46  * IQMode is only available on MaxSX8 on a single tuner
  47  *
  48  * IQ_MODE_SAMPLES
  49  *       sampling rate is 1550/24 MHz (64.583 MHz)
  50  *       channel agc is frozen, to allow stitching the FFT results together
  51  *
  52  * IQ_MODE_VTM
  53  *       sampling rate is the supplied symbolrate
  54  *       channel agc is active
  55  *
  56  * in both cases down sampling is done with a RRC Filter (currently fixed to
  57  * alpha = 0.05) which causes some (ca 5%) aliasing at the edges from
  58  * outside the spectrum
  59  */
  60 
  61 #define SX8_TSCONFIG_TSHEADER               (0x00000004)
  62 #define SX8_TSCONFIG_BURST                  (0x00000008)
  63 
  64 #define SX8_TSCONFIG_BURSTSIZE_MASK         (0x00000030)
  65 #define SX8_TSCONFIG_BURSTSIZE_2K           (0x00000000)
  66 #define SX8_TSCONFIG_BURSTSIZE_4K           (0x00000010)
  67 #define SX8_TSCONFIG_BURSTSIZE_8K           (0x00000020)
  68 #define SX8_TSCONFIG_BURSTSIZE_16K          (0x00000030)
  69 
  70 #define SX8_DEMOD_STOPPED        (0)
  71 #define SX8_DEMOD_IQ_MODE        (1)
  72 #define SX8_DEMOD_WAIT_SIGNAL    (2)
  73 #define SX8_DEMOD_WAIT_MATYPE    (3)
  74 #define SX8_DEMOD_TIMEOUT        (14)
  75 #define SX8_DEMOD_LOCKED         (15)
  76 
  77 #define MCI_CMD_STOP             (0x01)
  78 #define MCI_CMD_GETSTATUS        (0x02)
  79 #define MCI_CMD_GETSIGNALINFO    (0x03)
  80 #define MCI_CMD_RFPOWER          (0x04)
  81 
  82 #define MCI_CMD_SEARCH_DVBS      (0x10)
  83 
  84 #define MCI_CMD_GET_IQSYMBOL     (0x30)
  85 
  86 #define SX8_CMD_INPUT_ENABLE     (0x40)
  87 #define SX8_CMD_INPUT_DISABLE    (0x41)
  88 #define SX8_CMD_START_IQ         (0x42)
  89 #define SX8_CMD_STOP_IQ          (0x43)
  90 #define SX8_CMD_ENABLE_IQOUTPUT  (0x44)
  91 #define SX8_CMD_DISABLE_IQOUTPUT (0x45)
  92 
  93 #define MCI_STATUS_OK            (0x00)
  94 #define MCI_STATUS_UNSUPPORTED   (0x80)
  95 #define MCI_STATUS_RETRY         (0xFD)
  96 #define MCI_STATUS_NOT_READY     (0xFE)
  97 #define MCI_STATUS_ERROR         (0xFF)
  98 
  99 #define MCI_SUCCESS(status)      ((status & MCI_STATUS_UNSUPPORTED) == 0)
 100 
 101 struct mci_command {
 102         union {
 103                 u32 command_word;
 104                 struct {
 105                         u8  command;
 106                         u8  tuner;
 107                         u8  demod;
 108                         u8  output;
 109                 };
 110         };
 111         union {
 112                 u32 params[31];
 113                 struct {
 114                         /*
 115                          * Bit 0: DVB-S Enabled
 116                          * Bit 1: DVB-S2 Enabled
 117                          * Bit 7: InputStreamID
 118                          */
 119                         u8  flags;
 120                         /*
 121                          * Bit 0: QPSK,
 122                          * Bit 1: 8PSK/8APSK
 123                          * Bit 2: 16APSK
 124                          * Bit 3: 32APSK
 125                          * Bit 4: 64APSK
 126                          * Bit 5: 128APSK
 127                          * Bit 6: 256APSK
 128                          */
 129                         u8  s2_modulation_mask;
 130                         u8  rsvd1;
 131                         u8  retry;
 132                         u32 frequency;
 133                         u32 symbol_rate;
 134                         u8  input_stream_id;
 135                         u8  rsvd2[3];
 136                         u32 scrambling_sequence_index;
 137                         u32 frequency_range;
 138                 } dvbs2_search;
 139 
 140                 struct {
 141                         u8  tap;
 142                         u8  rsvd;
 143                         u16 point;
 144                 } get_iq_symbol;
 145 
 146                 struct {
 147                         /*
 148                          * Bit 0: 0=VTM/1=SCAN
 149                          * Bit 1: Set Gain
 150                          */
 151                         u8  flags;
 152                         u8  roll_off;
 153                         u8  rsvd1;
 154                         u8  rsvd2;
 155                         u32 frequency;
 156                         u32 symbol_rate; /* Only in VTM mode */
 157                         u16 gain;
 158                 } sx8_start_iq;
 159 
 160                 struct {
 161                         /*
 162                          * Bit 1:0 = STVVGLNA Gain.
 163                          *   0 = AGC, 1 = 0dB, 2 = Minimum, 3 = Maximum
 164                          */
 165                         u8  flags;
 166                 } sx8_input_enable;
 167         };
 168 };
 169 
 170 struct mci_result {
 171         union {
 172                 u32 status_word;
 173                 struct {
 174                         u8  status;
 175                         u8  mode;
 176                         u16 time;
 177                 };
 178         };
 179         union {
 180                 u32 result[27];
 181                 struct {
 182                         /* 1 = DVB-S, 2 = DVB-S2X */
 183                         u8  standard;
 184                         /* puncture rate for DVB-S */
 185                         u8  pls_code;
 186                         /* 2-0: rolloff */
 187                         u8  roll_off;
 188                         u8  rsvd;
 189                         /* actual frequency in Hz */
 190                         u32 frequency;
 191                         /* actual symbolrate in Hz */
 192                         u32 symbol_rate;
 193                         /* channel power in dBm x 100 */
 194                         s16 channel_power;
 195                         /* band power in dBm x 100 */
 196                         s16 band_power;
 197                         /*
 198                          * SNR in dB x 100
 199                          * Note: negative values are valid in DVB-S2
 200                          */
 201                         s16 signal_to_noise;
 202                         s16 rsvd2;
 203                         /*
 204                          * Counter for packet errors
 205                          * (set to 0 on start command)
 206                          */
 207                         u32 packet_errors;
 208                         /* Bit error rate: PreRS in DVB-S, PreBCH in DVB-S2X */
 209                         u32 ber_numerator;
 210                         u32 ber_denominator;
 211                 } dvbs2_signal_info;
 212 
 213                 struct {
 214                         s16 i;
 215                         s16 q;
 216                 } iq_symbol;
 217         };
 218         u32 version[4];
 219 };
 220 
 221 struct mci_base {
 222         struct list_head     mci_list;
 223         void                *key;
 224         struct ddb_link     *link;
 225         struct completion    completion;
 226         struct device       *dev;
 227         struct mutex         tuner_lock; /* concurrent tuner access lock */
 228         struct mutex         mci_lock; /* concurrent MCI access lock */
 229         int                  count;
 230         int                  type;
 231 };
 232 
 233 struct mci {
 234         struct mci_base     *base;
 235         struct dvb_frontend  fe;
 236         int                  nr;
 237         int                  demod;
 238         int                  tuner;
 239 };
 240 
 241 struct mci_cfg {
 242         int                  type;
 243         struct dvb_frontend_ops *fe_ops;
 244         u32                  base_size;
 245         u32                  state_size;
 246         int (*init)(struct mci *mci);
 247         int (*base_init)(struct mci_base *mci_base);
 248         int (*set_input)(struct dvb_frontend *fe, int input);
 249 };
 250 
 251 /* defined in ddbridge-sx8.c */
 252 extern const struct mci_cfg ddb_max_sx8_cfg;
 253 
 254 int ddb_mci_cmd(struct mci *state, struct mci_command *command,
 255                 struct mci_result *result);
 256 int ddb_mci_config(struct mci *state, u32 config);
 257 
 258 struct dvb_frontend
 259 *ddb_mci_attach(struct ddb_input *input, struct mci_cfg *cfg, int nr,
 260                 int (**fn_set_input)(struct dvb_frontend *fe, int input));
 261 
 262 #endif /* _DDBRIDGE_MCI_H_ */

/* [<][>][^][v][top][bottom][index][help] */