root/drivers/media/dvb-frontends/drxk_hard.c

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

DEFINITIONS

This source file includes following definitions.
  1. is_dvbt
  2. is_qam
  3. MulDiv32
  4. Frac28a
  5. log10times100
  6. drxk_i2c_lock
  7. drxk_i2c_unlock
  8. drxk_i2c_transfer
  9. i2c_read1
  10. i2c_write
  11. i2c_read
  12. read16_flags
  13. read16
  14. read32_flags
  15. read32
  16. write16_flags
  17. write16
  18. write32_flags
  19. write32
  20. write_block
  21. power_up_device
  22. init_state
  23. drxx_open
  24. get_device_capabilities
  25. hi_command
  26. hi_cfg_command
  27. init_hi
  28. mpegts_configure_pins
  29. mpegts_disable
  30. bl_chain_cmd
  31. download_microcode
  32. dvbt_enable_ofdm_token_ring
  33. mpegts_stop
  34. scu_command
  35. set_iqm_af
  36. ctrl_power_mode
  37. power_down_dvbt
  38. setoperation_mode
  39. start
  40. shut_down
  41. get_lock_status
  42. mpegts_start
  43. mpegts_dto_init
  44. mpegts_dto_setup
  45. mpegts_configure_polarity
  46. set_agc_rf
  47. set_agc_if
  48. get_qam_signal_to_noise
  49. get_dvbt_signal_to_noise
  50. get_signal_to_noise
  51. get_dvbt_quality
  52. get_dvbc_quality
  53. get_quality
  54. ConfigureI2CBridge
  55. set_pre_saw
  56. bl_direct_cmd
  57. adc_sync_measurement
  58. adc_synchronization
  59. set_frequency_shifter
  60. init_agc
  61. dvbtqam_get_acc_pkt_err
  62. dvbt_sc_command
  63. power_up_dvbt
  64. dvbt_ctrl_set_inc_enable
  65. dvbt_ctrl_set_fr_enable
  66. dvbt_ctrl_set_echo_threshold
  67. dvbt_ctrl_set_sqi_speed
  68. dvbt_activate_presets
  69. set_dvbt_standard
  70. dvbt_start
  71. set_dvbt
  72. get_dvbt_lock_status
  73. power_up_qam
  74. power_down_qam
  75. set_qam_measurement
  76. set_qam16
  77. set_qam32
  78. set_qam64
  79. set_qam128
  80. set_qam256
  81. qam_reset_qam
  82. qam_set_symbolrate
  83. get_qam_lock_status
  84. qam_demodulator_command
  85. set_qam
  86. set_qam_standard
  87. write_gpio
  88. switch_antenna_to_qam
  89. switch_antenna_to_dvbt
  90. power_down_device
  91. init_drxk
  92. load_firmware_cb
  93. drxk_release
  94. drxk_sleep
  95. drxk_gate_ctrl
  96. drxk_set_parameters
  97. get_strength
  98. drxk_get_stats
  99. drxk_read_status
  100. drxk_read_signal_strength
  101. drxk_read_snr
  102. drxk_read_ucblocks
  103. drxk_get_tune_settings
  104. drxk_attach

   1 // SPDX-License-Identifier: GPL-2.0-only
   2 /*
   3  * drxk_hard: DRX-K DVB-C/T demodulator driver
   4  *
   5  * Copyright (C) 2010-2011 Digital Devices GmbH
   6  */
   7 
   8 #define pr_fmt(fmt) KBUILD_MODNAME ": " fmt
   9 
  10 #include <linux/kernel.h>
  11 #include <linux/module.h>
  12 #include <linux/moduleparam.h>
  13 #include <linux/init.h>
  14 #include <linux/delay.h>
  15 #include <linux/firmware.h>
  16 #include <linux/i2c.h>
  17 #include <linux/hardirq.h>
  18 #include <asm/div64.h>
  19 
  20 #include <media/dvb_frontend.h>
  21 #include "drxk.h"
  22 #include "drxk_hard.h"
  23 #include <media/dvb_math.h>
  24 
  25 static int power_down_dvbt(struct drxk_state *state, bool set_power_mode);
  26 static int power_down_qam(struct drxk_state *state);
  27 static int set_dvbt_standard(struct drxk_state *state,
  28                            enum operation_mode o_mode);
  29 static int set_qam_standard(struct drxk_state *state,
  30                           enum operation_mode o_mode);
  31 static int set_qam(struct drxk_state *state, u16 intermediate_freqk_hz,
  32                   s32 tuner_freq_offset);
  33 static int set_dvbt_standard(struct drxk_state *state,
  34                            enum operation_mode o_mode);
  35 static int dvbt_start(struct drxk_state *state);
  36 static int set_dvbt(struct drxk_state *state, u16 intermediate_freqk_hz,
  37                    s32 tuner_freq_offset);
  38 static int get_qam_lock_status(struct drxk_state *state, u32 *p_lock_status);
  39 static int get_dvbt_lock_status(struct drxk_state *state, u32 *p_lock_status);
  40 static int switch_antenna_to_qam(struct drxk_state *state);
  41 static int switch_antenna_to_dvbt(struct drxk_state *state);
  42 
  43 static bool is_dvbt(struct drxk_state *state)
  44 {
  45         return state->m_operation_mode == OM_DVBT;
  46 }
  47 
  48 static bool is_qam(struct drxk_state *state)
  49 {
  50         return state->m_operation_mode == OM_QAM_ITU_A ||
  51             state->m_operation_mode == OM_QAM_ITU_B ||
  52             state->m_operation_mode == OM_QAM_ITU_C;
  53 }
  54 
  55 #define NOA1ROM 0
  56 
  57 #define DRXDAP_FASI_SHORT_FORMAT(addr) (((addr) & 0xFC30FF80) == 0)
  58 #define DRXDAP_FASI_LONG_FORMAT(addr)  (((addr) & 0xFC30FF80) != 0)
  59 
  60 #define DEFAULT_MER_83  165
  61 #define DEFAULT_MER_93  250
  62 
  63 #ifndef DRXK_MPEG_SERIAL_OUTPUT_PIN_DRIVE_STRENGTH
  64 #define DRXK_MPEG_SERIAL_OUTPUT_PIN_DRIVE_STRENGTH (0x02)
  65 #endif
  66 
  67 #ifndef DRXK_MPEG_PARALLEL_OUTPUT_PIN_DRIVE_STRENGTH
  68 #define DRXK_MPEG_PARALLEL_OUTPUT_PIN_DRIVE_STRENGTH (0x03)
  69 #endif
  70 
  71 #define DEFAULT_DRXK_MPEG_LOCK_TIMEOUT 700
  72 #define DEFAULT_DRXK_DEMOD_LOCK_TIMEOUT 500
  73 
  74 #ifndef DRXK_KI_RAGC_ATV
  75 #define DRXK_KI_RAGC_ATV   4
  76 #endif
  77 #ifndef DRXK_KI_IAGC_ATV
  78 #define DRXK_KI_IAGC_ATV   6
  79 #endif
  80 #ifndef DRXK_KI_DAGC_ATV
  81 #define DRXK_KI_DAGC_ATV   7
  82 #endif
  83 
  84 #ifndef DRXK_KI_RAGC_QAM
  85 #define DRXK_KI_RAGC_QAM   3
  86 #endif
  87 #ifndef DRXK_KI_IAGC_QAM
  88 #define DRXK_KI_IAGC_QAM   4
  89 #endif
  90 #ifndef DRXK_KI_DAGC_QAM
  91 #define DRXK_KI_DAGC_QAM   7
  92 #endif
  93 #ifndef DRXK_KI_RAGC_DVBT
  94 #define DRXK_KI_RAGC_DVBT  (IsA1WithPatchCode(state) ? 3 : 2)
  95 #endif
  96 #ifndef DRXK_KI_IAGC_DVBT
  97 #define DRXK_KI_IAGC_DVBT  (IsA1WithPatchCode(state) ? 4 : 2)
  98 #endif
  99 #ifndef DRXK_KI_DAGC_DVBT
 100 #define DRXK_KI_DAGC_DVBT  (IsA1WithPatchCode(state) ? 10 : 7)
 101 #endif
 102 
 103 #ifndef DRXK_AGC_DAC_OFFSET
 104 #define DRXK_AGC_DAC_OFFSET (0x800)
 105 #endif
 106 
 107 #ifndef DRXK_BANDWIDTH_8MHZ_IN_HZ
 108 #define DRXK_BANDWIDTH_8MHZ_IN_HZ  (0x8B8249L)
 109 #endif
 110 
 111 #ifndef DRXK_BANDWIDTH_7MHZ_IN_HZ
 112 #define DRXK_BANDWIDTH_7MHZ_IN_HZ  (0x7A1200L)
 113 #endif
 114 
 115 #ifndef DRXK_BANDWIDTH_6MHZ_IN_HZ
 116 #define DRXK_BANDWIDTH_6MHZ_IN_HZ  (0x68A1B6L)
 117 #endif
 118 
 119 #ifndef DRXK_QAM_SYMBOLRATE_MAX
 120 #define DRXK_QAM_SYMBOLRATE_MAX         (7233000)
 121 #endif
 122 
 123 #define DRXK_BL_ROM_OFFSET_TAPS_DVBT    56
 124 #define DRXK_BL_ROM_OFFSET_TAPS_ITU_A   64
 125 #define DRXK_BL_ROM_OFFSET_TAPS_ITU_C   0x5FE0
 126 #define DRXK_BL_ROM_OFFSET_TAPS_BG      24
 127 #define DRXK_BL_ROM_OFFSET_TAPS_DKILLP  32
 128 #define DRXK_BL_ROM_OFFSET_TAPS_NTSC    40
 129 #define DRXK_BL_ROM_OFFSET_TAPS_FM      48
 130 #define DRXK_BL_ROM_OFFSET_UCODE        0
 131 
 132 #define DRXK_BLC_TIMEOUT                100
 133 
 134 #define DRXK_BLCC_NR_ELEMENTS_TAPS      2
 135 #define DRXK_BLCC_NR_ELEMENTS_UCODE     6
 136 
 137 #define DRXK_BLDC_NR_ELEMENTS_TAPS      28
 138 
 139 #ifndef DRXK_OFDM_NE_NOTCH_WIDTH
 140 #define DRXK_OFDM_NE_NOTCH_WIDTH             (4)
 141 #endif
 142 
 143 #define DRXK_QAM_SL_SIG_POWER_QAM16       (40960)
 144 #define DRXK_QAM_SL_SIG_POWER_QAM32       (20480)
 145 #define DRXK_QAM_SL_SIG_POWER_QAM64       (43008)
 146 #define DRXK_QAM_SL_SIG_POWER_QAM128      (20992)
 147 #define DRXK_QAM_SL_SIG_POWER_QAM256      (43520)
 148 
 149 static unsigned int debug;
 150 module_param(debug, int, 0644);
 151 MODULE_PARM_DESC(debug, "enable debug messages");
 152 
 153 #define dprintk(level, fmt, arg...) do {                                \
 154 if (debug >= level)                                                     \
 155         printk(KERN_DEBUG KBUILD_MODNAME ": %s " fmt, __func__, ##arg); \
 156 } while (0)
 157 
 158 
 159 static inline u32 MulDiv32(u32 a, u32 b, u32 c)
 160 {
 161         u64 tmp64;
 162 
 163         tmp64 = (u64) a * (u64) b;
 164         do_div(tmp64, c);
 165 
 166         return (u32) tmp64;
 167 }
 168 
 169 static inline u32 Frac28a(u32 a, u32 c)
 170 {
 171         int i = 0;
 172         u32 Q1 = 0;
 173         u32 R0 = 0;
 174 
 175         R0 = (a % c) << 4;      /* 32-28 == 4 shifts possible at max */
 176         Q1 = a / c;             /*
 177                                  * integer part, only the 4 least significant
 178                                  * bits will be visible in the result
 179                                  */
 180 
 181         /* division using radix 16, 7 nibbles in the result */
 182         for (i = 0; i < 7; i++) {
 183                 Q1 = (Q1 << 4) | (R0 / c);
 184                 R0 = (R0 % c) << 4;
 185         }
 186         /* rounding */
 187         if ((R0 >> 3) >= c)
 188                 Q1++;
 189 
 190         return Q1;
 191 }
 192 
 193 static inline u32 log10times100(u32 value)
 194 {
 195         return (100L * intlog10(value)) >> 24;
 196 }
 197 
 198 /***************************************************************************/
 199 /* I2C **********************************************************************/
 200 /***************************************************************************/
 201 
 202 static int drxk_i2c_lock(struct drxk_state *state)
 203 {
 204         i2c_lock_bus(state->i2c, I2C_LOCK_SEGMENT);
 205         state->drxk_i2c_exclusive_lock = true;
 206 
 207         return 0;
 208 }
 209 
 210 static void drxk_i2c_unlock(struct drxk_state *state)
 211 {
 212         if (!state->drxk_i2c_exclusive_lock)
 213                 return;
 214 
 215         i2c_unlock_bus(state->i2c, I2C_LOCK_SEGMENT);
 216         state->drxk_i2c_exclusive_lock = false;
 217 }
 218 
 219 static int drxk_i2c_transfer(struct drxk_state *state, struct i2c_msg *msgs,
 220                              unsigned len)
 221 {
 222         if (state->drxk_i2c_exclusive_lock)
 223                 return __i2c_transfer(state->i2c, msgs, len);
 224         else
 225                 return i2c_transfer(state->i2c, msgs, len);
 226 }
 227 
 228 static int i2c_read1(struct drxk_state *state, u8 adr, u8 *val)
 229 {
 230         struct i2c_msg msgs[1] = { {.addr = adr, .flags = I2C_M_RD,
 231                                     .buf = val, .len = 1}
 232         };
 233 
 234         return drxk_i2c_transfer(state, msgs, 1);
 235 }
 236 
 237 static int i2c_write(struct drxk_state *state, u8 adr, u8 *data, int len)
 238 {
 239         int status;
 240         struct i2c_msg msg = {
 241             .addr = adr, .flags = 0, .buf = data, .len = len };
 242 
 243         dprintk(3, ":");
 244         if (debug > 2) {
 245                 int i;
 246                 for (i = 0; i < len; i++)
 247                         pr_cont(" %02x", data[i]);
 248                 pr_cont("\n");
 249         }
 250         status = drxk_i2c_transfer(state, &msg, 1);
 251         if (status >= 0 && status != 1)
 252                 status = -EIO;
 253 
 254         if (status < 0)
 255                 pr_err("i2c write error at addr 0x%02x\n", adr);
 256 
 257         return status;
 258 }
 259 
 260 static int i2c_read(struct drxk_state *state,
 261                     u8 adr, u8 *msg, int len, u8 *answ, int alen)
 262 {
 263         int status;
 264         struct i2c_msg msgs[2] = {
 265                 {.addr = adr, .flags = 0,
 266                                     .buf = msg, .len = len},
 267                 {.addr = adr, .flags = I2C_M_RD,
 268                  .buf = answ, .len = alen}
 269         };
 270 
 271         status = drxk_i2c_transfer(state, msgs, 2);
 272         if (status != 2) {
 273                 if (debug > 2)
 274                         pr_cont(": ERROR!\n");
 275                 if (status >= 0)
 276                         status = -EIO;
 277 
 278                 pr_err("i2c read error at addr 0x%02x\n", adr);
 279                 return status;
 280         }
 281         if (debug > 2) {
 282                 int i;
 283                 dprintk(2, ": read from");
 284                 for (i = 0; i < len; i++)
 285                         pr_cont(" %02x", msg[i]);
 286                 pr_cont(", value = ");
 287                 for (i = 0; i < alen; i++)
 288                         pr_cont(" %02x", answ[i]);
 289                 pr_cont("\n");
 290         }
 291         return 0;
 292 }
 293 
 294 static int read16_flags(struct drxk_state *state, u32 reg, u16 *data, u8 flags)
 295 {
 296         int status;
 297         u8 adr = state->demod_address, mm1[4], mm2[2], len;
 298 
 299         if (state->single_master)
 300                 flags |= 0xC0;
 301 
 302         if (DRXDAP_FASI_LONG_FORMAT(reg) || (flags != 0)) {
 303                 mm1[0] = (((reg << 1) & 0xFF) | 0x01);
 304                 mm1[1] = ((reg >> 16) & 0xFF);
 305                 mm1[2] = ((reg >> 24) & 0xFF) | flags;
 306                 mm1[3] = ((reg >> 7) & 0xFF);
 307                 len = 4;
 308         } else {
 309                 mm1[0] = ((reg << 1) & 0xFF);
 310                 mm1[1] = (((reg >> 16) & 0x0F) | ((reg >> 18) & 0xF0));
 311                 len = 2;
 312         }
 313         dprintk(2, "(0x%08x, 0x%02x)\n", reg, flags);
 314         status = i2c_read(state, adr, mm1, len, mm2, 2);
 315         if (status < 0)
 316                 return status;
 317         if (data)
 318                 *data = mm2[0] | (mm2[1] << 8);
 319 
 320         return 0;
 321 }
 322 
 323 static int read16(struct drxk_state *state, u32 reg, u16 *data)
 324 {
 325         return read16_flags(state, reg, data, 0);
 326 }
 327 
 328 static int read32_flags(struct drxk_state *state, u32 reg, u32 *data, u8 flags)
 329 {
 330         int status;
 331         u8 adr = state->demod_address, mm1[4], mm2[4], len;
 332 
 333         if (state->single_master)
 334                 flags |= 0xC0;
 335 
 336         if (DRXDAP_FASI_LONG_FORMAT(reg) || (flags != 0)) {
 337                 mm1[0] = (((reg << 1) & 0xFF) | 0x01);
 338                 mm1[1] = ((reg >> 16) & 0xFF);
 339                 mm1[2] = ((reg >> 24) & 0xFF) | flags;
 340                 mm1[3] = ((reg >> 7) & 0xFF);
 341                 len = 4;
 342         } else {
 343                 mm1[0] = ((reg << 1) & 0xFF);
 344                 mm1[1] = (((reg >> 16) & 0x0F) | ((reg >> 18) & 0xF0));
 345                 len = 2;
 346         }
 347         dprintk(2, "(0x%08x, 0x%02x)\n", reg, flags);
 348         status = i2c_read(state, adr, mm1, len, mm2, 4);
 349         if (status < 0)
 350                 return status;
 351         if (data)
 352                 *data = mm2[0] | (mm2[1] << 8) |
 353                     (mm2[2] << 16) | (mm2[3] << 24);
 354 
 355         return 0;
 356 }
 357 
 358 static int read32(struct drxk_state *state, u32 reg, u32 *data)
 359 {
 360         return read32_flags(state, reg, data, 0);
 361 }
 362 
 363 static int write16_flags(struct drxk_state *state, u32 reg, u16 data, u8 flags)
 364 {
 365         u8 adr = state->demod_address, mm[6], len;
 366 
 367         if (state->single_master)
 368                 flags |= 0xC0;
 369         if (DRXDAP_FASI_LONG_FORMAT(reg) || (flags != 0)) {
 370                 mm[0] = (((reg << 1) & 0xFF) | 0x01);
 371                 mm[1] = ((reg >> 16) & 0xFF);
 372                 mm[2] = ((reg >> 24) & 0xFF) | flags;
 373                 mm[3] = ((reg >> 7) & 0xFF);
 374                 len = 4;
 375         } else {
 376                 mm[0] = ((reg << 1) & 0xFF);
 377                 mm[1] = (((reg >> 16) & 0x0F) | ((reg >> 18) & 0xF0));
 378                 len = 2;
 379         }
 380         mm[len] = data & 0xff;
 381         mm[len + 1] = (data >> 8) & 0xff;
 382 
 383         dprintk(2, "(0x%08x, 0x%04x, 0x%02x)\n", reg, data, flags);
 384         return i2c_write(state, adr, mm, len + 2);
 385 }
 386 
 387 static int write16(struct drxk_state *state, u32 reg, u16 data)
 388 {
 389         return write16_flags(state, reg, data, 0);
 390 }
 391 
 392 static int write32_flags(struct drxk_state *state, u32 reg, u32 data, u8 flags)
 393 {
 394         u8 adr = state->demod_address, mm[8], len;
 395 
 396         if (state->single_master)
 397                 flags |= 0xC0;
 398         if (DRXDAP_FASI_LONG_FORMAT(reg) || (flags != 0)) {
 399                 mm[0] = (((reg << 1) & 0xFF) | 0x01);
 400                 mm[1] = ((reg >> 16) & 0xFF);
 401                 mm[2] = ((reg >> 24) & 0xFF) | flags;
 402                 mm[3] = ((reg >> 7) & 0xFF);
 403                 len = 4;
 404         } else {
 405                 mm[0] = ((reg << 1) & 0xFF);
 406                 mm[1] = (((reg >> 16) & 0x0F) | ((reg >> 18) & 0xF0));
 407                 len = 2;
 408         }
 409         mm[len] = data & 0xff;
 410         mm[len + 1] = (data >> 8) & 0xff;
 411         mm[len + 2] = (data >> 16) & 0xff;
 412         mm[len + 3] = (data >> 24) & 0xff;
 413         dprintk(2, "(0x%08x, 0x%08x, 0x%02x)\n", reg, data, flags);
 414 
 415         return i2c_write(state, adr, mm, len + 4);
 416 }
 417 
 418 static int write32(struct drxk_state *state, u32 reg, u32 data)
 419 {
 420         return write32_flags(state, reg, data, 0);
 421 }
 422 
 423 static int write_block(struct drxk_state *state, u32 address,
 424                       const int block_size, const u8 p_block[])
 425 {
 426         int status = 0, blk_size = block_size;
 427         u8 flags = 0;
 428 
 429         if (state->single_master)
 430                 flags |= 0xC0;
 431 
 432         while (blk_size > 0) {
 433                 int chunk = blk_size > state->m_chunk_size ?
 434                     state->m_chunk_size : blk_size;
 435                 u8 *adr_buf = &state->chunk[0];
 436                 u32 adr_length = 0;
 437 
 438                 if (DRXDAP_FASI_LONG_FORMAT(address) || (flags != 0)) {
 439                         adr_buf[0] = (((address << 1) & 0xFF) | 0x01);
 440                         adr_buf[1] = ((address >> 16) & 0xFF);
 441                         adr_buf[2] = ((address >> 24) & 0xFF);
 442                         adr_buf[3] = ((address >> 7) & 0xFF);
 443                         adr_buf[2] |= flags;
 444                         adr_length = 4;
 445                         if (chunk == state->m_chunk_size)
 446                                 chunk -= 2;
 447                 } else {
 448                         adr_buf[0] = ((address << 1) & 0xFF);
 449                         adr_buf[1] = (((address >> 16) & 0x0F) |
 450                                      ((address >> 18) & 0xF0));
 451                         adr_length = 2;
 452                 }
 453                 memcpy(&state->chunk[adr_length], p_block, chunk);
 454                 dprintk(2, "(0x%08x, 0x%02x)\n", address, flags);
 455                 if (debug > 1) {
 456                         int i;
 457                         if (p_block)
 458                                 for (i = 0; i < chunk; i++)
 459                                         pr_cont(" %02x", p_block[i]);
 460                         pr_cont("\n");
 461                 }
 462                 status = i2c_write(state, state->demod_address,
 463                                    &state->chunk[0], chunk + adr_length);
 464                 if (status < 0) {
 465                         pr_err("%s: i2c write error at addr 0x%02x\n",
 466                                __func__, address);
 467                         break;
 468                 }
 469                 p_block += chunk;
 470                 address += (chunk >> 1);
 471                 blk_size -= chunk;
 472         }
 473         return status;
 474 }
 475 
 476 #ifndef DRXK_MAX_RETRIES_POWERUP
 477 #define DRXK_MAX_RETRIES_POWERUP 20
 478 #endif
 479 
 480 static int power_up_device(struct drxk_state *state)
 481 {
 482         int status;
 483         u8 data = 0;
 484         u16 retry_count = 0;
 485 
 486         dprintk(1, "\n");
 487 
 488         status = i2c_read1(state, state->demod_address, &data);
 489         if (status < 0) {
 490                 do {
 491                         data = 0;
 492                         status = i2c_write(state, state->demod_address,
 493                                            &data, 1);
 494                         usleep_range(10000, 11000);
 495                         retry_count++;
 496                         if (status < 0)
 497                                 continue;
 498                         status = i2c_read1(state, state->demod_address,
 499                                            &data);
 500                 } while (status < 0 &&
 501                          (retry_count < DRXK_MAX_RETRIES_POWERUP));
 502                 if (status < 0 && retry_count >= DRXK_MAX_RETRIES_POWERUP)
 503                         goto error;
 504         }
 505 
 506         /* Make sure all clk domains are active */
 507         status = write16(state, SIO_CC_PWD_MODE__A, SIO_CC_PWD_MODE_LEVEL_NONE);
 508         if (status < 0)
 509                 goto error;
 510         status = write16(state, SIO_CC_UPDATE__A, SIO_CC_UPDATE_KEY);
 511         if (status < 0)
 512                 goto error;
 513         /* Enable pll lock tests */
 514         status = write16(state, SIO_CC_PLL_LOCK__A, 1);
 515         if (status < 0)
 516                 goto error;
 517 
 518         state->m_current_power_mode = DRX_POWER_UP;
 519 
 520 error:
 521         if (status < 0)
 522                 pr_err("Error %d on %s\n", status, __func__);
 523 
 524         return status;
 525 }
 526 
 527 
 528 static int init_state(struct drxk_state *state)
 529 {
 530         /*
 531          * FIXME: most (all?) of the values below should be moved into
 532          * struct drxk_config, as they are probably board-specific
 533          */
 534         u32 ul_vsb_if_agc_mode = DRXK_AGC_CTRL_AUTO;
 535         u32 ul_vsb_if_agc_output_level = 0;
 536         u32 ul_vsb_if_agc_min_level = 0;
 537         u32 ul_vsb_if_agc_max_level = 0x7FFF;
 538         u32 ul_vsb_if_agc_speed = 3;
 539 
 540         u32 ul_vsb_rf_agc_mode = DRXK_AGC_CTRL_AUTO;
 541         u32 ul_vsb_rf_agc_output_level = 0;
 542         u32 ul_vsb_rf_agc_min_level = 0;
 543         u32 ul_vsb_rf_agc_max_level = 0x7FFF;
 544         u32 ul_vsb_rf_agc_speed = 3;
 545         u32 ul_vsb_rf_agc_top = 9500;
 546         u32 ul_vsb_rf_agc_cut_off_current = 4000;
 547 
 548         u32 ul_atv_if_agc_mode = DRXK_AGC_CTRL_AUTO;
 549         u32 ul_atv_if_agc_output_level = 0;
 550         u32 ul_atv_if_agc_min_level = 0;
 551         u32 ul_atv_if_agc_max_level = 0;
 552         u32 ul_atv_if_agc_speed = 3;
 553 
 554         u32 ul_atv_rf_agc_mode = DRXK_AGC_CTRL_OFF;
 555         u32 ul_atv_rf_agc_output_level = 0;
 556         u32 ul_atv_rf_agc_min_level = 0;
 557         u32 ul_atv_rf_agc_max_level = 0;
 558         u32 ul_atv_rf_agc_top = 9500;
 559         u32 ul_atv_rf_agc_cut_off_current = 4000;
 560         u32 ul_atv_rf_agc_speed = 3;
 561 
 562         u32 ulQual83 = DEFAULT_MER_83;
 563         u32 ulQual93 = DEFAULT_MER_93;
 564 
 565         u32 ul_mpeg_lock_time_out = DEFAULT_DRXK_MPEG_LOCK_TIMEOUT;
 566         u32 ul_demod_lock_time_out = DEFAULT_DRXK_DEMOD_LOCK_TIMEOUT;
 567 
 568         /* io_pad_cfg register (8 bit reg.) MSB bit is 1 (default value) */
 569         /* io_pad_cfg_mode output mode is drive always */
 570         /* io_pad_cfg_drive is set to power 2 (23 mA) */
 571         u32 ul_gpio_cfg = 0x0113;
 572         u32 ul_invert_ts_clock = 0;
 573         u32 ul_ts_data_strength = DRXK_MPEG_SERIAL_OUTPUT_PIN_DRIVE_STRENGTH;
 574         u32 ul_dvbt_bitrate = 50000000;
 575         u32 ul_dvbc_bitrate = DRXK_QAM_SYMBOLRATE_MAX * 8;
 576 
 577         u32 ul_insert_rs_byte = 0;
 578 
 579         u32 ul_rf_mirror = 1;
 580         u32 ul_power_down = 0;
 581 
 582         dprintk(1, "\n");
 583 
 584         state->m_has_lna = false;
 585         state->m_has_dvbt = false;
 586         state->m_has_dvbc = false;
 587         state->m_has_atv = false;
 588         state->m_has_oob = false;
 589         state->m_has_audio = false;
 590 
 591         if (!state->m_chunk_size)
 592                 state->m_chunk_size = 124;
 593 
 594         state->m_osc_clock_freq = 0;
 595         state->m_smart_ant_inverted = false;
 596         state->m_b_p_down_open_bridge = false;
 597 
 598         /* real system clock frequency in kHz */
 599         state->m_sys_clock_freq = 151875;
 600         /* Timing div, 250ns/Psys */
 601         /* Timing div, = (delay (nano seconds) * sysclk (kHz))/ 1000 */
 602         state->m_hi_cfg_timing_div = ((state->m_sys_clock_freq / 1000) *
 603                                    HI_I2C_DELAY) / 1000;
 604         /* Clipping */
 605         if (state->m_hi_cfg_timing_div > SIO_HI_RA_RAM_PAR_2_CFG_DIV__M)
 606                 state->m_hi_cfg_timing_div = SIO_HI_RA_RAM_PAR_2_CFG_DIV__M;
 607         state->m_hi_cfg_wake_up_key = (state->demod_address << 1);
 608         /* port/bridge/power down ctrl */
 609         state->m_hi_cfg_ctrl = SIO_HI_RA_RAM_PAR_5_CFG_SLV0_SLAVE;
 610 
 611         state->m_b_power_down = (ul_power_down != 0);
 612 
 613         state->m_drxk_a3_patch_code = false;
 614 
 615         /* Init AGC and PGA parameters */
 616         /* VSB IF */
 617         state->m_vsb_if_agc_cfg.ctrl_mode = ul_vsb_if_agc_mode;
 618         state->m_vsb_if_agc_cfg.output_level = ul_vsb_if_agc_output_level;
 619         state->m_vsb_if_agc_cfg.min_output_level = ul_vsb_if_agc_min_level;
 620         state->m_vsb_if_agc_cfg.max_output_level = ul_vsb_if_agc_max_level;
 621         state->m_vsb_if_agc_cfg.speed = ul_vsb_if_agc_speed;
 622         state->m_vsb_pga_cfg = 140;
 623 
 624         /* VSB RF */
 625         state->m_vsb_rf_agc_cfg.ctrl_mode = ul_vsb_rf_agc_mode;
 626         state->m_vsb_rf_agc_cfg.output_level = ul_vsb_rf_agc_output_level;
 627         state->m_vsb_rf_agc_cfg.min_output_level = ul_vsb_rf_agc_min_level;
 628         state->m_vsb_rf_agc_cfg.max_output_level = ul_vsb_rf_agc_max_level;
 629         state->m_vsb_rf_agc_cfg.speed = ul_vsb_rf_agc_speed;
 630         state->m_vsb_rf_agc_cfg.top = ul_vsb_rf_agc_top;
 631         state->m_vsb_rf_agc_cfg.cut_off_current = ul_vsb_rf_agc_cut_off_current;
 632         state->m_vsb_pre_saw_cfg.reference = 0x07;
 633         state->m_vsb_pre_saw_cfg.use_pre_saw = true;
 634 
 635         state->m_Quality83percent = DEFAULT_MER_83;
 636         state->m_Quality93percent = DEFAULT_MER_93;
 637         if (ulQual93 <= 500 && ulQual83 < ulQual93) {
 638                 state->m_Quality83percent = ulQual83;
 639                 state->m_Quality93percent = ulQual93;
 640         }
 641 
 642         /* ATV IF */
 643         state->m_atv_if_agc_cfg.ctrl_mode = ul_atv_if_agc_mode;
 644         state->m_atv_if_agc_cfg.output_level = ul_atv_if_agc_output_level;
 645         state->m_atv_if_agc_cfg.min_output_level = ul_atv_if_agc_min_level;
 646         state->m_atv_if_agc_cfg.max_output_level = ul_atv_if_agc_max_level;
 647         state->m_atv_if_agc_cfg.speed = ul_atv_if_agc_speed;
 648 
 649         /* ATV RF */
 650         state->m_atv_rf_agc_cfg.ctrl_mode = ul_atv_rf_agc_mode;
 651         state->m_atv_rf_agc_cfg.output_level = ul_atv_rf_agc_output_level;
 652         state->m_atv_rf_agc_cfg.min_output_level = ul_atv_rf_agc_min_level;
 653         state->m_atv_rf_agc_cfg.max_output_level = ul_atv_rf_agc_max_level;
 654         state->m_atv_rf_agc_cfg.speed = ul_atv_rf_agc_speed;
 655         state->m_atv_rf_agc_cfg.top = ul_atv_rf_agc_top;
 656         state->m_atv_rf_agc_cfg.cut_off_current = ul_atv_rf_agc_cut_off_current;
 657         state->m_atv_pre_saw_cfg.reference = 0x04;
 658         state->m_atv_pre_saw_cfg.use_pre_saw = true;
 659 
 660 
 661         /* DVBT RF */
 662         state->m_dvbt_rf_agc_cfg.ctrl_mode = DRXK_AGC_CTRL_OFF;
 663         state->m_dvbt_rf_agc_cfg.output_level = 0;
 664         state->m_dvbt_rf_agc_cfg.min_output_level = 0;
 665         state->m_dvbt_rf_agc_cfg.max_output_level = 0xFFFF;
 666         state->m_dvbt_rf_agc_cfg.top = 0x2100;
 667         state->m_dvbt_rf_agc_cfg.cut_off_current = 4000;
 668         state->m_dvbt_rf_agc_cfg.speed = 1;
 669 
 670 
 671         /* DVBT IF */
 672         state->m_dvbt_if_agc_cfg.ctrl_mode = DRXK_AGC_CTRL_AUTO;
 673         state->m_dvbt_if_agc_cfg.output_level = 0;
 674         state->m_dvbt_if_agc_cfg.min_output_level = 0;
 675         state->m_dvbt_if_agc_cfg.max_output_level = 9000;
 676         state->m_dvbt_if_agc_cfg.top = 13424;
 677         state->m_dvbt_if_agc_cfg.cut_off_current = 0;
 678         state->m_dvbt_if_agc_cfg.speed = 3;
 679         state->m_dvbt_if_agc_cfg.fast_clip_ctrl_delay = 30;
 680         state->m_dvbt_if_agc_cfg.ingain_tgt_max = 30000;
 681         /* state->m_dvbtPgaCfg = 140; */
 682 
 683         state->m_dvbt_pre_saw_cfg.reference = 4;
 684         state->m_dvbt_pre_saw_cfg.use_pre_saw = false;
 685 
 686         /* QAM RF */
 687         state->m_qam_rf_agc_cfg.ctrl_mode = DRXK_AGC_CTRL_OFF;
 688         state->m_qam_rf_agc_cfg.output_level = 0;
 689         state->m_qam_rf_agc_cfg.min_output_level = 6023;
 690         state->m_qam_rf_agc_cfg.max_output_level = 27000;
 691         state->m_qam_rf_agc_cfg.top = 0x2380;
 692         state->m_qam_rf_agc_cfg.cut_off_current = 4000;
 693         state->m_qam_rf_agc_cfg.speed = 3;
 694 
 695         /* QAM IF */
 696         state->m_qam_if_agc_cfg.ctrl_mode = DRXK_AGC_CTRL_AUTO;
 697         state->m_qam_if_agc_cfg.output_level = 0;
 698         state->m_qam_if_agc_cfg.min_output_level = 0;
 699         state->m_qam_if_agc_cfg.max_output_level = 9000;
 700         state->m_qam_if_agc_cfg.top = 0x0511;
 701         state->m_qam_if_agc_cfg.cut_off_current = 0;
 702         state->m_qam_if_agc_cfg.speed = 3;
 703         state->m_qam_if_agc_cfg.ingain_tgt_max = 5119;
 704         state->m_qam_if_agc_cfg.fast_clip_ctrl_delay = 50;
 705 
 706         state->m_qam_pga_cfg = 140;
 707         state->m_qam_pre_saw_cfg.reference = 4;
 708         state->m_qam_pre_saw_cfg.use_pre_saw = false;
 709 
 710         state->m_operation_mode = OM_NONE;
 711         state->m_drxk_state = DRXK_UNINITIALIZED;
 712 
 713         /* MPEG output configuration */
 714         state->m_enable_mpeg_output = true;     /* If TRUE; enable MPEG output */
 715         state->m_insert_rs_byte = false;        /* If TRUE; insert RS byte */
 716         state->m_invert_data = false;   /* If TRUE; invert DATA signals */
 717         state->m_invert_err = false;    /* If TRUE; invert ERR signal */
 718         state->m_invert_str = false;    /* If TRUE; invert STR signals */
 719         state->m_invert_val = false;    /* If TRUE; invert VAL signals */
 720         state->m_invert_clk = (ul_invert_ts_clock != 0);        /* If TRUE; invert CLK signals */
 721 
 722         /* If TRUE; static MPEG clockrate will be used;
 723            otherwise clockrate will adapt to the bitrate of the TS */
 724 
 725         state->m_dvbt_bitrate = ul_dvbt_bitrate;
 726         state->m_dvbc_bitrate = ul_dvbc_bitrate;
 727 
 728         state->m_ts_data_strength = (ul_ts_data_strength & 0x07);
 729 
 730         /* Maximum bitrate in b/s in case static clockrate is selected */
 731         state->m_mpeg_ts_static_bitrate = 19392658;
 732         state->m_disable_te_ihandling = false;
 733 
 734         if (ul_insert_rs_byte)
 735                 state->m_insert_rs_byte = true;
 736 
 737         state->m_mpeg_lock_time_out = DEFAULT_DRXK_MPEG_LOCK_TIMEOUT;
 738         if (ul_mpeg_lock_time_out < 10000)
 739                 state->m_mpeg_lock_time_out = ul_mpeg_lock_time_out;
 740         state->m_demod_lock_time_out = DEFAULT_DRXK_DEMOD_LOCK_TIMEOUT;
 741         if (ul_demod_lock_time_out < 10000)
 742                 state->m_demod_lock_time_out = ul_demod_lock_time_out;
 743 
 744         /* QAM defaults */
 745         state->m_constellation = DRX_CONSTELLATION_AUTO;
 746         state->m_qam_interleave_mode = DRXK_QAM_I12_J17;
 747         state->m_fec_rs_plen = 204 * 8; /* fecRsPlen  annex A */
 748         state->m_fec_rs_prescale = 1;
 749 
 750         state->m_sqi_speed = DRXK_DVBT_SQI_SPEED_MEDIUM;
 751         state->m_agcfast_clip_ctrl_delay = 0;
 752 
 753         state->m_gpio_cfg = ul_gpio_cfg;
 754 
 755         state->m_b_power_down = false;
 756         state->m_current_power_mode = DRX_POWER_DOWN;
 757 
 758         state->m_rfmirror = (ul_rf_mirror == 0);
 759         state->m_if_agc_pol = false;
 760         return 0;
 761 }
 762 
 763 static int drxx_open(struct drxk_state *state)
 764 {
 765         int status = 0;
 766         u32 jtag = 0;
 767         u16 bid = 0;
 768         u16 key = 0;
 769 
 770         dprintk(1, "\n");
 771         /* stop lock indicator process */
 772         status = write16(state, SCU_RAM_GPIO__A,
 773                          SCU_RAM_GPIO_HW_LOCK_IND_DISABLE);
 774         if (status < 0)
 775                 goto error;
 776         /* Check device id */
 777         status = read16(state, SIO_TOP_COMM_KEY__A, &key);
 778         if (status < 0)
 779                 goto error;
 780         status = write16(state, SIO_TOP_COMM_KEY__A, SIO_TOP_COMM_KEY_KEY);
 781         if (status < 0)
 782                 goto error;
 783         status = read32(state, SIO_TOP_JTAGID_LO__A, &jtag);
 784         if (status < 0)
 785                 goto error;
 786         status = read16(state, SIO_PDR_UIO_IN_HI__A, &bid);
 787         if (status < 0)
 788                 goto error;
 789         status = write16(state, SIO_TOP_COMM_KEY__A, key);
 790 error:
 791         if (status < 0)
 792                 pr_err("Error %d on %s\n", status, __func__);
 793         return status;
 794 }
 795 
 796 static int get_device_capabilities(struct drxk_state *state)
 797 {
 798         u16 sio_pdr_ohw_cfg = 0;
 799         u32 sio_top_jtagid_lo = 0;
 800         int status;
 801         const char *spin = "";
 802 
 803         dprintk(1, "\n");
 804 
 805         /* driver 0.9.0 */
 806         /* stop lock indicator process */
 807         status = write16(state, SCU_RAM_GPIO__A,
 808                          SCU_RAM_GPIO_HW_LOCK_IND_DISABLE);
 809         if (status < 0)
 810                 goto error;
 811         status = write16(state, SIO_TOP_COMM_KEY__A, SIO_TOP_COMM_KEY_KEY);
 812         if (status < 0)
 813                 goto error;
 814         status = read16(state, SIO_PDR_OHW_CFG__A, &sio_pdr_ohw_cfg);
 815         if (status < 0)
 816                 goto error;
 817         status = write16(state, SIO_TOP_COMM_KEY__A, 0x0000);
 818         if (status < 0)
 819                 goto error;
 820 
 821         switch ((sio_pdr_ohw_cfg & SIO_PDR_OHW_CFG_FREF_SEL__M)) {
 822         case 0:
 823                 /* ignore (bypass ?) */
 824                 break;
 825         case 1:
 826                 /* 27 MHz */
 827                 state->m_osc_clock_freq = 27000;
 828                 break;
 829         case 2:
 830                 /* 20.25 MHz */
 831                 state->m_osc_clock_freq = 20250;
 832                 break;
 833         case 3:
 834                 /* 4 MHz */
 835                 state->m_osc_clock_freq = 20250;
 836                 break;
 837         default:
 838                 pr_err("Clock Frequency is unknown\n");
 839                 return -EINVAL;
 840         }
 841         /*
 842                 Determine device capabilities
 843                 Based on pinning v14
 844                 */
 845         status = read32(state, SIO_TOP_JTAGID_LO__A, &sio_top_jtagid_lo);
 846         if (status < 0)
 847                 goto error;
 848 
 849         pr_info("status = 0x%08x\n", sio_top_jtagid_lo);
 850 
 851         /* driver 0.9.0 */
 852         switch ((sio_top_jtagid_lo >> 29) & 0xF) {
 853         case 0:
 854                 state->m_device_spin = DRXK_SPIN_A1;
 855                 spin = "A1";
 856                 break;
 857         case 2:
 858                 state->m_device_spin = DRXK_SPIN_A2;
 859                 spin = "A2";
 860                 break;
 861         case 3:
 862                 state->m_device_spin = DRXK_SPIN_A3;
 863                 spin = "A3";
 864                 break;
 865         default:
 866                 state->m_device_spin = DRXK_SPIN_UNKNOWN;
 867                 status = -EINVAL;
 868                 pr_err("Spin %d unknown\n", (sio_top_jtagid_lo >> 29) & 0xF);
 869                 goto error2;
 870         }
 871         switch ((sio_top_jtagid_lo >> 12) & 0xFF) {
 872         case 0x13:
 873                 /* typeId = DRX3913K_TYPE_ID */
 874                 state->m_has_lna = false;
 875                 state->m_has_oob = false;
 876                 state->m_has_atv = false;
 877                 state->m_has_audio = false;
 878                 state->m_has_dvbt = true;
 879                 state->m_has_dvbc = true;
 880                 state->m_has_sawsw = true;
 881                 state->m_has_gpio2 = false;
 882                 state->m_has_gpio1 = false;
 883                 state->m_has_irqn = false;
 884                 break;
 885         case 0x15:
 886                 /* typeId = DRX3915K_TYPE_ID */
 887                 state->m_has_lna = false;
 888                 state->m_has_oob = false;
 889                 state->m_has_atv = true;
 890                 state->m_has_audio = false;
 891                 state->m_has_dvbt = true;
 892                 state->m_has_dvbc = false;
 893                 state->m_has_sawsw = true;
 894                 state->m_has_gpio2 = true;
 895                 state->m_has_gpio1 = true;
 896                 state->m_has_irqn = false;
 897                 break;
 898         case 0x16:
 899                 /* typeId = DRX3916K_TYPE_ID */
 900                 state->m_has_lna = false;
 901                 state->m_has_oob = false;
 902                 state->m_has_atv = true;
 903                 state->m_has_audio = false;
 904                 state->m_has_dvbt = true;
 905                 state->m_has_dvbc = false;
 906                 state->m_has_sawsw = true;
 907                 state->m_has_gpio2 = true;
 908                 state->m_has_gpio1 = true;
 909                 state->m_has_irqn = false;
 910                 break;
 911         case 0x18:
 912                 /* typeId = DRX3918K_TYPE_ID */
 913                 state->m_has_lna = false;
 914                 state->m_has_oob = false;
 915                 state->m_has_atv = true;
 916                 state->m_has_audio = true;
 917                 state->m_has_dvbt = true;
 918                 state->m_has_dvbc = false;
 919                 state->m_has_sawsw = true;
 920                 state->m_has_gpio2 = true;
 921                 state->m_has_gpio1 = true;
 922                 state->m_has_irqn = false;
 923                 break;
 924         case 0x21:
 925                 /* typeId = DRX3921K_TYPE_ID */
 926                 state->m_has_lna = false;
 927                 state->m_has_oob = false;
 928                 state->m_has_atv = true;
 929                 state->m_has_audio = true;
 930                 state->m_has_dvbt = true;
 931                 state->m_has_dvbc = true;
 932                 state->m_has_sawsw = true;
 933                 state->m_has_gpio2 = true;
 934                 state->m_has_gpio1 = true;
 935                 state->m_has_irqn = false;
 936                 break;
 937         case 0x23:
 938                 /* typeId = DRX3923K_TYPE_ID */
 939                 state->m_has_lna = false;
 940                 state->m_has_oob = false;
 941                 state->m_has_atv = true;
 942                 state->m_has_audio = true;
 943                 state->m_has_dvbt = true;
 944                 state->m_has_dvbc = true;
 945                 state->m_has_sawsw = true;
 946                 state->m_has_gpio2 = true;
 947                 state->m_has_gpio1 = true;
 948                 state->m_has_irqn = false;
 949                 break;
 950         case 0x25:
 951                 /* typeId = DRX3925K_TYPE_ID */
 952                 state->m_has_lna = false;
 953                 state->m_has_oob = false;
 954                 state->m_has_atv = true;
 955                 state->m_has_audio = true;
 956                 state->m_has_dvbt = true;
 957                 state->m_has_dvbc = true;
 958                 state->m_has_sawsw = true;
 959                 state->m_has_gpio2 = true;
 960                 state->m_has_gpio1 = true;
 961                 state->m_has_irqn = false;
 962                 break;
 963         case 0x26:
 964                 /* typeId = DRX3926K_TYPE_ID */
 965                 state->m_has_lna = false;
 966                 state->m_has_oob = false;
 967                 state->m_has_atv = true;
 968                 state->m_has_audio = false;
 969                 state->m_has_dvbt = true;
 970                 state->m_has_dvbc = true;
 971                 state->m_has_sawsw = true;
 972                 state->m_has_gpio2 = true;
 973                 state->m_has_gpio1 = true;
 974                 state->m_has_irqn = false;
 975                 break;
 976         default:
 977                 pr_err("DeviceID 0x%02x not supported\n",
 978                         ((sio_top_jtagid_lo >> 12) & 0xFF));
 979                 status = -EINVAL;
 980                 goto error2;
 981         }
 982 
 983         pr_info("detected a drx-39%02xk, spin %s, xtal %d.%03d MHz\n",
 984                ((sio_top_jtagid_lo >> 12) & 0xFF), spin,
 985                state->m_osc_clock_freq / 1000,
 986                state->m_osc_clock_freq % 1000);
 987 
 988 error:
 989         if (status < 0)
 990                 pr_err("Error %d on %s\n", status, __func__);
 991 
 992 error2:
 993         return status;
 994 }
 995 
 996 static int hi_command(struct drxk_state *state, u16 cmd, u16 *p_result)
 997 {
 998         int status;
 999         bool powerdown_cmd;
1000 
1001         dprintk(1, "\n");
1002 
1003         /* Write command */
1004         status = write16(state, SIO_HI_RA_RAM_CMD__A, cmd);
1005         if (status < 0)
1006                 goto error;
1007         if (cmd == SIO_HI_RA_RAM_CMD_RESET)
1008                 usleep_range(1000, 2000);
1009 
1010         powerdown_cmd =
1011             (bool) ((cmd == SIO_HI_RA_RAM_CMD_CONFIG) &&
1012                     ((state->m_hi_cfg_ctrl) &
1013                      SIO_HI_RA_RAM_PAR_5_CFG_SLEEP__M) ==
1014                     SIO_HI_RA_RAM_PAR_5_CFG_SLEEP_ZZZ);
1015         if (!powerdown_cmd) {
1016                 /* Wait until command rdy */
1017                 u32 retry_count = 0;
1018                 u16 wait_cmd;
1019 
1020                 do {
1021                         usleep_range(1000, 2000);
1022                         retry_count += 1;
1023                         status = read16(state, SIO_HI_RA_RAM_CMD__A,
1024                                           &wait_cmd);
1025                 } while ((status < 0) && (retry_count < DRXK_MAX_RETRIES)
1026                          && (wait_cmd != 0));
1027                 if (status < 0)
1028                         goto error;
1029                 status = read16(state, SIO_HI_RA_RAM_RES__A, p_result);
1030         }
1031 error:
1032         if (status < 0)
1033                 pr_err("Error %d on %s\n", status, __func__);
1034 
1035         return status;
1036 }
1037 
1038 static int hi_cfg_command(struct drxk_state *state)
1039 {
1040         int status;
1041 
1042         dprintk(1, "\n");
1043 
1044         mutex_lock(&state->mutex);
1045 
1046         status = write16(state, SIO_HI_RA_RAM_PAR_6__A,
1047                          state->m_hi_cfg_timeout);
1048         if (status < 0)
1049                 goto error;
1050         status = write16(state, SIO_HI_RA_RAM_PAR_5__A,
1051                          state->m_hi_cfg_ctrl);
1052         if (status < 0)
1053                 goto error;
1054         status = write16(state, SIO_HI_RA_RAM_PAR_4__A,
1055                          state->m_hi_cfg_wake_up_key);
1056         if (status < 0)
1057                 goto error;
1058         status = write16(state, SIO_HI_RA_RAM_PAR_3__A,
1059                          state->m_hi_cfg_bridge_delay);
1060         if (status < 0)
1061                 goto error;
1062         status = write16(state, SIO_HI_RA_RAM_PAR_2__A,
1063                          state->m_hi_cfg_timing_div);
1064         if (status < 0)
1065                 goto error;
1066         status = write16(state, SIO_HI_RA_RAM_PAR_1__A,
1067                          SIO_HI_RA_RAM_PAR_1_PAR1_SEC_KEY);
1068         if (status < 0)
1069                 goto error;
1070         status = hi_command(state, SIO_HI_RA_RAM_CMD_CONFIG, NULL);
1071         if (status < 0)
1072                 goto error;
1073 
1074         state->m_hi_cfg_ctrl &= ~SIO_HI_RA_RAM_PAR_5_CFG_SLEEP_ZZZ;
1075 error:
1076         mutex_unlock(&state->mutex);
1077         if (status < 0)
1078                 pr_err("Error %d on %s\n", status, __func__);
1079         return status;
1080 }
1081 
1082 static int init_hi(struct drxk_state *state)
1083 {
1084         dprintk(1, "\n");
1085 
1086         state->m_hi_cfg_wake_up_key = (state->demod_address << 1);
1087         state->m_hi_cfg_timeout = 0x96FF;
1088         /* port/bridge/power down ctrl */
1089         state->m_hi_cfg_ctrl = SIO_HI_RA_RAM_PAR_5_CFG_SLV0_SLAVE;
1090 
1091         return hi_cfg_command(state);
1092 }
1093 
1094 static int mpegts_configure_pins(struct drxk_state *state, bool mpeg_enable)
1095 {
1096         int status = -1;
1097         u16 sio_pdr_mclk_cfg = 0;
1098         u16 sio_pdr_mdx_cfg = 0;
1099         u16 err_cfg = 0;
1100 
1101         dprintk(1, ": mpeg %s, %s mode\n",
1102                 mpeg_enable ? "enable" : "disable",
1103                 state->m_enable_parallel ? "parallel" : "serial");
1104 
1105         /* stop lock indicator process */
1106         status = write16(state, SCU_RAM_GPIO__A,
1107                          SCU_RAM_GPIO_HW_LOCK_IND_DISABLE);
1108         if (status < 0)
1109                 goto error;
1110 
1111         /*  MPEG TS pad configuration */
1112         status = write16(state, SIO_TOP_COMM_KEY__A, SIO_TOP_COMM_KEY_KEY);
1113         if (status < 0)
1114                 goto error;
1115 
1116         if (!mpeg_enable) {
1117                 /*  Set MPEG TS pads to inputmode */
1118                 status = write16(state, SIO_PDR_MSTRT_CFG__A, 0x0000);
1119                 if (status < 0)
1120                         goto error;
1121                 status = write16(state, SIO_PDR_MERR_CFG__A, 0x0000);
1122                 if (status < 0)
1123                         goto error;
1124                 status = write16(state, SIO_PDR_MCLK_CFG__A, 0x0000);
1125                 if (status < 0)
1126                         goto error;
1127                 status = write16(state, SIO_PDR_MVAL_CFG__A, 0x0000);
1128                 if (status < 0)
1129                         goto error;
1130                 status = write16(state, SIO_PDR_MD0_CFG__A, 0x0000);
1131                 if (status < 0)
1132                         goto error;
1133                 status = write16(state, SIO_PDR_MD1_CFG__A, 0x0000);
1134                 if (status < 0)
1135                         goto error;
1136                 status = write16(state, SIO_PDR_MD2_CFG__A, 0x0000);
1137                 if (status < 0)
1138                         goto error;
1139                 status = write16(state, SIO_PDR_MD3_CFG__A, 0x0000);
1140                 if (status < 0)
1141                         goto error;
1142                 status = write16(state, SIO_PDR_MD4_CFG__A, 0x0000);
1143                 if (status < 0)
1144                         goto error;
1145                 status = write16(state, SIO_PDR_MD5_CFG__A, 0x0000);
1146                 if (status < 0)
1147                         goto error;
1148                 status = write16(state, SIO_PDR_MD6_CFG__A, 0x0000);
1149                 if (status < 0)
1150                         goto error;
1151                 status = write16(state, SIO_PDR_MD7_CFG__A, 0x0000);
1152                 if (status < 0)
1153                         goto error;
1154         } else {
1155                 /* Enable MPEG output */
1156                 sio_pdr_mdx_cfg =
1157                         ((state->m_ts_data_strength <<
1158                         SIO_PDR_MD0_CFG_DRIVE__B) | 0x0003);
1159                 sio_pdr_mclk_cfg = ((state->m_ts_clockk_strength <<
1160                                         SIO_PDR_MCLK_CFG_DRIVE__B) |
1161                                         0x0003);
1162 
1163                 status = write16(state, SIO_PDR_MSTRT_CFG__A, sio_pdr_mdx_cfg);
1164                 if (status < 0)
1165                         goto error;
1166 
1167                 if (state->enable_merr_cfg)
1168                         err_cfg = sio_pdr_mdx_cfg;
1169 
1170                 status = write16(state, SIO_PDR_MERR_CFG__A, err_cfg);
1171                 if (status < 0)
1172                         goto error;
1173                 status = write16(state, SIO_PDR_MVAL_CFG__A, err_cfg);
1174                 if (status < 0)
1175                         goto error;
1176 
1177                 if (state->m_enable_parallel) {
1178                         /* parallel -> enable MD1 to MD7 */
1179                         status = write16(state, SIO_PDR_MD1_CFG__A,
1180                                          sio_pdr_mdx_cfg);
1181                         if (status < 0)
1182                                 goto error;
1183                         status = write16(state, SIO_PDR_MD2_CFG__A,
1184                                          sio_pdr_mdx_cfg);
1185                         if (status < 0)
1186                                 goto error;
1187                         status = write16(state, SIO_PDR_MD3_CFG__A,
1188                                          sio_pdr_mdx_cfg);
1189                         if (status < 0)
1190                                 goto error;
1191                         status = write16(state, SIO_PDR_MD4_CFG__A,
1192                                          sio_pdr_mdx_cfg);
1193                         if (status < 0)
1194                                 goto error;
1195                         status = write16(state, SIO_PDR_MD5_CFG__A,
1196                                          sio_pdr_mdx_cfg);
1197                         if (status < 0)
1198                                 goto error;
1199                         status = write16(state, SIO_PDR_MD6_CFG__A,
1200                                          sio_pdr_mdx_cfg);
1201                         if (status < 0)
1202                                 goto error;
1203                         status = write16(state, SIO_PDR_MD7_CFG__A,
1204                                          sio_pdr_mdx_cfg);
1205                         if (status < 0)
1206                                 goto error;
1207                 } else {
1208                         sio_pdr_mdx_cfg = ((state->m_ts_data_strength <<
1209                                                 SIO_PDR_MD0_CFG_DRIVE__B)
1210                                         | 0x0003);
1211                         /* serial -> disable MD1 to MD7 */
1212                         status = write16(state, SIO_PDR_MD1_CFG__A, 0x0000);
1213                         if (status < 0)
1214                                 goto error;
1215                         status = write16(state, SIO_PDR_MD2_CFG__A, 0x0000);
1216                         if (status < 0)
1217                                 goto error;
1218                         status = write16(state, SIO_PDR_MD3_CFG__A, 0x0000);
1219                         if (status < 0)
1220                                 goto error;
1221                         status = write16(state, SIO_PDR_MD4_CFG__A, 0x0000);
1222                         if (status < 0)
1223                                 goto error;
1224                         status = write16(state, SIO_PDR_MD5_CFG__A, 0x0000);
1225                         if (status < 0)
1226                                 goto error;
1227                         status = write16(state, SIO_PDR_MD6_CFG__A, 0x0000);
1228                         if (status < 0)
1229                                 goto error;
1230                         status = write16(state, SIO_PDR_MD7_CFG__A, 0x0000);
1231                         if (status < 0)
1232                                 goto error;
1233                 }
1234                 status = write16(state, SIO_PDR_MCLK_CFG__A, sio_pdr_mclk_cfg);
1235                 if (status < 0)
1236                         goto error;
1237                 status = write16(state, SIO_PDR_MD0_CFG__A, sio_pdr_mdx_cfg);
1238                 if (status < 0)
1239                         goto error;
1240         }
1241         /*  Enable MB output over MPEG pads and ctl input */
1242         status = write16(state, SIO_PDR_MON_CFG__A, 0x0000);
1243         if (status < 0)
1244                 goto error;
1245         /*  Write nomagic word to enable pdr reg write */
1246         status = write16(state, SIO_TOP_COMM_KEY__A, 0x0000);
1247 error:
1248         if (status < 0)
1249                 pr_err("Error %d on %s\n", status, __func__);
1250         return status;
1251 }
1252 
1253 static int mpegts_disable(struct drxk_state *state)
1254 {
1255         dprintk(1, "\n");
1256 
1257         return mpegts_configure_pins(state, false);
1258 }
1259 
1260 static int bl_chain_cmd(struct drxk_state *state,
1261                       u16 rom_offset, u16 nr_of_elements, u32 time_out)
1262 {
1263         u16 bl_status = 0;
1264         int status;
1265         unsigned long end;
1266 
1267         dprintk(1, "\n");
1268         mutex_lock(&state->mutex);
1269         status = write16(state, SIO_BL_MODE__A, SIO_BL_MODE_CHAIN);
1270         if (status < 0)
1271                 goto error;
1272         status = write16(state, SIO_BL_CHAIN_ADDR__A, rom_offset);
1273         if (status < 0)
1274                 goto error;
1275         status = write16(state, SIO_BL_CHAIN_LEN__A, nr_of_elements);
1276         if (status < 0)
1277                 goto error;
1278         status = write16(state, SIO_BL_ENABLE__A, SIO_BL_ENABLE_ON);
1279         if (status < 0)
1280                 goto error;
1281 
1282         end = jiffies + msecs_to_jiffies(time_out);
1283         do {
1284                 usleep_range(1000, 2000);
1285                 status = read16(state, SIO_BL_STATUS__A, &bl_status);
1286                 if (status < 0)
1287                         goto error;
1288         } while ((bl_status == 0x1) &&
1289                         ((time_is_after_jiffies(end))));
1290 
1291         if (bl_status == 0x1) {
1292                 pr_err("SIO not ready\n");
1293                 status = -EINVAL;
1294                 goto error2;
1295         }
1296 error:
1297         if (status < 0)
1298                 pr_err("Error %d on %s\n", status, __func__);
1299 error2:
1300         mutex_unlock(&state->mutex);
1301         return status;
1302 }
1303 
1304 
1305 static int download_microcode(struct drxk_state *state,
1306                              const u8 p_mc_image[], u32 length)
1307 {
1308         const u8 *p_src = p_mc_image;
1309         u32 address;
1310         u16 n_blocks;
1311         u16 block_size;
1312         u32 offset = 0;
1313         u32 i;
1314         int status = 0;
1315 
1316         dprintk(1, "\n");
1317 
1318         /* down the drain (we don't care about MAGIC_WORD) */
1319 #if 0
1320         /* For future reference */
1321         drain = (p_src[0] << 8) | p_src[1];
1322 #endif
1323         p_src += sizeof(u16);
1324         offset += sizeof(u16);
1325         n_blocks = (p_src[0] << 8) | p_src[1];
1326         p_src += sizeof(u16);
1327         offset += sizeof(u16);
1328 
1329         for (i = 0; i < n_blocks; i += 1) {
1330                 address = (p_src[0] << 24) | (p_src[1] << 16) |
1331                     (p_src[2] << 8) | p_src[3];
1332                 p_src += sizeof(u32);
1333                 offset += sizeof(u32);
1334 
1335                 block_size = ((p_src[0] << 8) | p_src[1]) * sizeof(u16);
1336                 p_src += sizeof(u16);
1337                 offset += sizeof(u16);
1338 
1339 #if 0
1340                 /* For future reference */
1341                 flags = (p_src[0] << 8) | p_src[1];
1342 #endif
1343                 p_src += sizeof(u16);
1344                 offset += sizeof(u16);
1345 
1346 #if 0
1347                 /* For future reference */
1348                 block_crc = (p_src[0] << 8) | p_src[1];
1349 #endif
1350                 p_src += sizeof(u16);
1351                 offset += sizeof(u16);
1352 
1353                 if (offset + block_size > length) {
1354                         pr_err("Firmware is corrupted.\n");
1355                         return -EINVAL;
1356                 }
1357 
1358                 status = write_block(state, address, block_size, p_src);
1359                 if (status < 0) {
1360                         pr_err("Error %d while loading firmware\n", status);
1361                         break;
1362                 }
1363                 p_src += block_size;
1364                 offset += block_size;
1365         }
1366         return status;
1367 }
1368 
1369 static int dvbt_enable_ofdm_token_ring(struct drxk_state *state, bool enable)
1370 {
1371         int status;
1372         u16 data = 0;
1373         u16 desired_ctrl = SIO_OFDM_SH_OFDM_RING_ENABLE_ON;
1374         u16 desired_status = SIO_OFDM_SH_OFDM_RING_STATUS_ENABLED;
1375         unsigned long end;
1376 
1377         dprintk(1, "\n");
1378 
1379         if (!enable) {
1380                 desired_ctrl = SIO_OFDM_SH_OFDM_RING_ENABLE_OFF;
1381                 desired_status = SIO_OFDM_SH_OFDM_RING_STATUS_DOWN;
1382         }
1383 
1384         status = read16(state, SIO_OFDM_SH_OFDM_RING_STATUS__A, &data);
1385         if (status >= 0 && data == desired_status) {
1386                 /* tokenring already has correct status */
1387                 return status;
1388         }
1389         /* Disable/enable dvbt tokenring bridge   */
1390         status = write16(state, SIO_OFDM_SH_OFDM_RING_ENABLE__A, desired_ctrl);
1391 
1392         end = jiffies + msecs_to_jiffies(DRXK_OFDM_TR_SHUTDOWN_TIMEOUT);
1393         do {
1394                 status = read16(state, SIO_OFDM_SH_OFDM_RING_STATUS__A, &data);
1395                 if ((status >= 0 && data == desired_status)
1396                     || time_is_after_jiffies(end))
1397                         break;
1398                 usleep_range(1000, 2000);
1399         } while (1);
1400         if (data != desired_status) {
1401                 pr_err("SIO not ready\n");
1402                 return -EINVAL;
1403         }
1404         return status;
1405 }
1406 
1407 static int mpegts_stop(struct drxk_state *state)
1408 {
1409         int status = 0;
1410         u16 fec_oc_snc_mode = 0;
1411         u16 fec_oc_ipr_mode = 0;
1412 
1413         dprintk(1, "\n");
1414 
1415         /* Graceful shutdown (byte boundaries) */
1416         status = read16(state, FEC_OC_SNC_MODE__A, &fec_oc_snc_mode);
1417         if (status < 0)
1418                 goto error;
1419         fec_oc_snc_mode |= FEC_OC_SNC_MODE_SHUTDOWN__M;
1420         status = write16(state, FEC_OC_SNC_MODE__A, fec_oc_snc_mode);
1421         if (status < 0)
1422                 goto error;
1423 
1424         /* Suppress MCLK during absence of data */
1425         status = read16(state, FEC_OC_IPR_MODE__A, &fec_oc_ipr_mode);
1426         if (status < 0)
1427                 goto error;
1428         fec_oc_ipr_mode |= FEC_OC_IPR_MODE_MCLK_DIS_DAT_ABS__M;
1429         status = write16(state, FEC_OC_IPR_MODE__A, fec_oc_ipr_mode);
1430 
1431 error:
1432         if (status < 0)
1433                 pr_err("Error %d on %s\n", status, __func__);
1434 
1435         return status;
1436 }
1437 
1438 static int scu_command(struct drxk_state *state,
1439                        u16 cmd, u8 parameter_len,
1440                        u16 *parameter, u8 result_len, u16 *result)
1441 {
1442 #if (SCU_RAM_PARAM_0__A - SCU_RAM_PARAM_15__A) != 15
1443 #error DRXK register mapping no longer compatible with this routine!
1444 #endif
1445         u16 cur_cmd = 0;
1446         int status = -EINVAL;
1447         unsigned long end;
1448         u8 buffer[34];
1449         int cnt = 0, ii;
1450         const char *p;
1451         char errname[30];
1452 
1453         dprintk(1, "\n");
1454 
1455         if ((cmd == 0) || ((parameter_len > 0) && (parameter == NULL)) ||
1456             ((result_len > 0) && (result == NULL))) {
1457                 pr_err("Error %d on %s\n", status, __func__);
1458                 return status;
1459         }
1460 
1461         mutex_lock(&state->mutex);
1462 
1463         /* assume that the command register is ready
1464                 since it is checked afterwards */
1465         if (parameter) {
1466                 for (ii = parameter_len - 1; ii >= 0; ii -= 1) {
1467                         buffer[cnt++] = (parameter[ii] & 0xFF);
1468                         buffer[cnt++] = ((parameter[ii] >> 8) & 0xFF);
1469                 }
1470         }
1471         buffer[cnt++] = (cmd & 0xFF);
1472         buffer[cnt++] = ((cmd >> 8) & 0xFF);
1473 
1474         write_block(state, SCU_RAM_PARAM_0__A -
1475                         (parameter_len - 1), cnt, buffer);
1476         /* Wait until SCU has processed command */
1477         end = jiffies + msecs_to_jiffies(DRXK_MAX_WAITTIME);
1478         do {
1479                 usleep_range(1000, 2000);
1480                 status = read16(state, SCU_RAM_COMMAND__A, &cur_cmd);
1481                 if (status < 0)
1482                         goto error;
1483         } while (!(cur_cmd == DRX_SCU_READY) && (time_is_after_jiffies(end)));
1484         if (cur_cmd != DRX_SCU_READY) {
1485                 pr_err("SCU not ready\n");
1486                 status = -EIO;
1487                 goto error2;
1488         }
1489         /* read results */
1490         if ((result_len > 0) && (result != NULL)) {
1491                 s16 err;
1492                 int ii;
1493 
1494                 for (ii = result_len - 1; ii >= 0; ii -= 1) {
1495                         status = read16(state, SCU_RAM_PARAM_0__A - ii,
1496                                         &result[ii]);
1497                         if (status < 0)
1498                                 goto error;
1499                 }
1500 
1501                 /* Check if an error was reported by SCU */
1502                 err = (s16)result[0];
1503                 if (err >= 0)
1504                         goto error;
1505 
1506                 /* check for the known error codes */
1507                 switch (err) {
1508                 case SCU_RESULT_UNKCMD:
1509                         p = "SCU_RESULT_UNKCMD";
1510                         break;
1511                 case SCU_RESULT_UNKSTD:
1512                         p = "SCU_RESULT_UNKSTD";
1513                         break;
1514                 case SCU_RESULT_SIZE:
1515                         p = "SCU_RESULT_SIZE";
1516                         break;
1517                 case SCU_RESULT_INVPAR:
1518                         p = "SCU_RESULT_INVPAR";
1519                         break;
1520                 default: /* Other negative values are errors */
1521                         sprintf(errname, "ERROR: %d\n", err);
1522                         p = errname;
1523                 }
1524                 pr_err("%s while sending cmd 0x%04x with params:", p, cmd);
1525                 print_hex_dump_bytes("drxk: ", DUMP_PREFIX_NONE, buffer, cnt);
1526                 status = -EINVAL;
1527                 goto error2;
1528         }
1529 
1530 error:
1531         if (status < 0)
1532                 pr_err("Error %d on %s\n", status, __func__);
1533 error2:
1534         mutex_unlock(&state->mutex);
1535         return status;
1536 }
1537 
1538 static int set_iqm_af(struct drxk_state *state, bool active)
1539 {
1540         u16 data = 0;
1541         int status;
1542 
1543         dprintk(1, "\n");
1544 
1545         /* Configure IQM */
1546         status = read16(state, IQM_AF_STDBY__A, &data);
1547         if (status < 0)
1548                 goto error;
1549 
1550         if (!active) {
1551                 data |= (IQM_AF_STDBY_STDBY_ADC_STANDBY
1552                                 | IQM_AF_STDBY_STDBY_AMP_STANDBY
1553                                 | IQM_AF_STDBY_STDBY_PD_STANDBY
1554                                 | IQM_AF_STDBY_STDBY_TAGC_IF_STANDBY
1555                                 | IQM_AF_STDBY_STDBY_TAGC_RF_STANDBY);
1556         } else {
1557                 data &= ((~IQM_AF_STDBY_STDBY_ADC_STANDBY)
1558                                 & (~IQM_AF_STDBY_STDBY_AMP_STANDBY)
1559                                 & (~IQM_AF_STDBY_STDBY_PD_STANDBY)
1560                                 & (~IQM_AF_STDBY_STDBY_TAGC_IF_STANDBY)
1561                                 & (~IQM_AF_STDBY_STDBY_TAGC_RF_STANDBY)
1562                         );
1563         }
1564         status = write16(state, IQM_AF_STDBY__A, data);
1565 
1566 error:
1567         if (status < 0)
1568                 pr_err("Error %d on %s\n", status, __func__);
1569         return status;
1570 }
1571 
1572 static int ctrl_power_mode(struct drxk_state *state, enum drx_power_mode *mode)
1573 {
1574         int status = 0;
1575         u16 sio_cc_pwd_mode = 0;
1576 
1577         dprintk(1, "\n");
1578 
1579         /* Check arguments */
1580         if (mode == NULL)
1581                 return -EINVAL;
1582 
1583         switch (*mode) {
1584         case DRX_POWER_UP:
1585                 sio_cc_pwd_mode = SIO_CC_PWD_MODE_LEVEL_NONE;
1586                 break;
1587         case DRXK_POWER_DOWN_OFDM:
1588                 sio_cc_pwd_mode = SIO_CC_PWD_MODE_LEVEL_OFDM;
1589                 break;
1590         case DRXK_POWER_DOWN_CORE:
1591                 sio_cc_pwd_mode = SIO_CC_PWD_MODE_LEVEL_CLOCK;
1592                 break;
1593         case DRXK_POWER_DOWN_PLL:
1594                 sio_cc_pwd_mode = SIO_CC_PWD_MODE_LEVEL_PLL;
1595                 break;
1596         case DRX_POWER_DOWN:
1597                 sio_cc_pwd_mode = SIO_CC_PWD_MODE_LEVEL_OSC;
1598                 break;
1599         default:
1600                 /* Unknow sleep mode */
1601                 return -EINVAL;
1602         }
1603 
1604         /* If already in requested power mode, do nothing */
1605         if (state->m_current_power_mode == *mode)
1606                 return 0;
1607 
1608         /* For next steps make sure to start from DRX_POWER_UP mode */
1609         if (state->m_current_power_mode != DRX_POWER_UP) {
1610                 status = power_up_device(state);
1611                 if (status < 0)
1612                         goto error;
1613                 status = dvbt_enable_ofdm_token_ring(state, true);
1614                 if (status < 0)
1615                         goto error;
1616         }
1617 
1618         if (*mode == DRX_POWER_UP) {
1619                 /* Restore analog & pin configuration */
1620         } else {
1621                 /* Power down to requested mode */
1622                 /* Backup some register settings */
1623                 /* Set pins with possible pull-ups connected
1624                    to them in input mode */
1625                 /* Analog power down */
1626                 /* ADC power down */
1627                 /* Power down device */
1628                 /* stop all comm_exec */
1629                 /* Stop and power down previous standard */
1630                 switch (state->m_operation_mode) {
1631                 case OM_DVBT:
1632                         status = mpegts_stop(state);
1633                         if (status < 0)
1634                                 goto error;
1635                         status = power_down_dvbt(state, false);
1636                         if (status < 0)
1637                                 goto error;
1638                         break;
1639                 case OM_QAM_ITU_A:
1640                 case OM_QAM_ITU_C:
1641                         status = mpegts_stop(state);
1642                         if (status < 0)
1643                                 goto error;
1644                         status = power_down_qam(state);
1645                         if (status < 0)
1646                                 goto error;
1647                         break;
1648                 default:
1649                         break;
1650                 }
1651                 status = dvbt_enable_ofdm_token_ring(state, false);
1652                 if (status < 0)
1653                         goto error;
1654                 status = write16(state, SIO_CC_PWD_MODE__A, sio_cc_pwd_mode);
1655                 if (status < 0)
1656                         goto error;
1657                 status = write16(state, SIO_CC_UPDATE__A, SIO_CC_UPDATE_KEY);
1658                 if (status < 0)
1659                         goto error;
1660 
1661                 if (*mode != DRXK_POWER_DOWN_OFDM) {
1662                         state->m_hi_cfg_ctrl |=
1663                                 SIO_HI_RA_RAM_PAR_5_CFG_SLEEP_ZZZ;
1664                         status = hi_cfg_command(state);
1665                         if (status < 0)
1666                                 goto error;
1667                 }
1668         }
1669         state->m_current_power_mode = *mode;
1670 
1671 error:
1672         if (status < 0)
1673                 pr_err("Error %d on %s\n", status, __func__);
1674 
1675         return status;
1676 }
1677 
1678 static int power_down_dvbt(struct drxk_state *state, bool set_power_mode)
1679 {
1680         enum drx_power_mode power_mode = DRXK_POWER_DOWN_OFDM;
1681         u16 cmd_result = 0;
1682         u16 data = 0;
1683         int status;
1684 
1685         dprintk(1, "\n");
1686 
1687         status = read16(state, SCU_COMM_EXEC__A, &data);
1688         if (status < 0)
1689                 goto error;
1690         if (data == SCU_COMM_EXEC_ACTIVE) {
1691                 /* Send OFDM stop command */
1692                 status = scu_command(state,
1693                                      SCU_RAM_COMMAND_STANDARD_OFDM
1694                                      | SCU_RAM_COMMAND_CMD_DEMOD_STOP,
1695                                      0, NULL, 1, &cmd_result);
1696                 if (status < 0)
1697                         goto error;
1698                 /* Send OFDM reset command */
1699                 status = scu_command(state,
1700                                      SCU_RAM_COMMAND_STANDARD_OFDM
1701                                      | SCU_RAM_COMMAND_CMD_DEMOD_RESET,
1702                                      0, NULL, 1, &cmd_result);
1703                 if (status < 0)
1704                         goto error;
1705         }
1706 
1707         /* Reset datapath for OFDM, processors first */
1708         status = write16(state, OFDM_SC_COMM_EXEC__A, OFDM_SC_COMM_EXEC_STOP);
1709         if (status < 0)
1710                 goto error;
1711         status = write16(state, OFDM_LC_COMM_EXEC__A, OFDM_LC_COMM_EXEC_STOP);
1712         if (status < 0)
1713                 goto error;
1714         status = write16(state, IQM_COMM_EXEC__A, IQM_COMM_EXEC_B_STOP);
1715         if (status < 0)
1716                 goto error;
1717 
1718         /* powerdown AFE                   */
1719         status = set_iqm_af(state, false);
1720         if (status < 0)
1721                 goto error;
1722 
1723         /* powerdown to OFDM mode          */
1724         if (set_power_mode) {
1725                 status = ctrl_power_mode(state, &power_mode);
1726                 if (status < 0)
1727                         goto error;
1728         }
1729 error:
1730         if (status < 0)
1731                 pr_err("Error %d on %s\n", status, __func__);
1732         return status;
1733 }
1734 
1735 static int setoperation_mode(struct drxk_state *state,
1736                             enum operation_mode o_mode)
1737 {
1738         int status = 0;
1739 
1740         dprintk(1, "\n");
1741         /*
1742            Stop and power down previous standard
1743            TODO investigate total power down instead of partial
1744            power down depending on "previous" standard.
1745          */
1746 
1747         /* disable HW lock indicator */
1748         status = write16(state, SCU_RAM_GPIO__A,
1749                          SCU_RAM_GPIO_HW_LOCK_IND_DISABLE);
1750         if (status < 0)
1751                 goto error;
1752 
1753         /* Device is already at the required mode */
1754         if (state->m_operation_mode == o_mode)
1755                 return 0;
1756 
1757         switch (state->m_operation_mode) {
1758                 /* OM_NONE was added for start up */
1759         case OM_NONE:
1760                 break;
1761         case OM_DVBT:
1762                 status = mpegts_stop(state);
1763                 if (status < 0)
1764                         goto error;
1765                 status = power_down_dvbt(state, true);
1766                 if (status < 0)
1767                         goto error;
1768                 state->m_operation_mode = OM_NONE;
1769                 break;
1770         case OM_QAM_ITU_A:      /* fallthrough */
1771         case OM_QAM_ITU_C:
1772                 status = mpegts_stop(state);
1773                 if (status < 0)
1774                         goto error;
1775                 status = power_down_qam(state);
1776                 if (status < 0)
1777                         goto error;
1778                 state->m_operation_mode = OM_NONE;
1779                 break;
1780         case OM_QAM_ITU_B:
1781         default:
1782                 status = -EINVAL;
1783                 goto error;
1784         }
1785 
1786         /*
1787                 Power up new standard
1788                 */
1789         switch (o_mode) {
1790         case OM_DVBT:
1791                 dprintk(1, ": DVB-T\n");
1792                 state->m_operation_mode = o_mode;
1793                 status = set_dvbt_standard(state, o_mode);
1794                 if (status < 0)
1795                         goto error;
1796                 break;
1797         case OM_QAM_ITU_A:      /* fallthrough */
1798         case OM_QAM_ITU_C:
1799                 dprintk(1, ": DVB-C Annex %c\n",
1800                         (state->m_operation_mode == OM_QAM_ITU_A) ? 'A' : 'C');
1801                 state->m_operation_mode = o_mode;
1802                 status = set_qam_standard(state, o_mode);
1803                 if (status < 0)
1804                         goto error;
1805                 break;
1806         case OM_QAM_ITU_B:
1807         default:
1808                 status = -EINVAL;
1809         }
1810 error:
1811         if (status < 0)
1812                 pr_err("Error %d on %s\n", status, __func__);
1813         return status;
1814 }
1815 
1816 static int start(struct drxk_state *state, s32 offset_freq,
1817                  s32 intermediate_frequency)
1818 {
1819         int status = -EINVAL;
1820 
1821         u16 i_freqk_hz;
1822         s32 offsetk_hz = offset_freq / 1000;
1823 
1824         dprintk(1, "\n");
1825         if (state->m_drxk_state != DRXK_STOPPED &&
1826                 state->m_drxk_state != DRXK_DTV_STARTED)
1827                 goto error;
1828 
1829         state->m_b_mirror_freq_spect = (state->props.inversion == INVERSION_ON);
1830 
1831         if (intermediate_frequency < 0) {
1832                 state->m_b_mirror_freq_spect = !state->m_b_mirror_freq_spect;
1833                 intermediate_frequency = -intermediate_frequency;
1834         }
1835 
1836         switch (state->m_operation_mode) {
1837         case OM_QAM_ITU_A:
1838         case OM_QAM_ITU_C:
1839                 i_freqk_hz = (intermediate_frequency / 1000);
1840                 status = set_qam(state, i_freqk_hz, offsetk_hz);
1841                 if (status < 0)
1842                         goto error;
1843                 state->m_drxk_state = DRXK_DTV_STARTED;
1844                 break;
1845         case OM_DVBT:
1846                 i_freqk_hz = (intermediate_frequency / 1000);
1847                 status = mpegts_stop(state);
1848                 if (status < 0)
1849                         goto error;
1850                 status = set_dvbt(state, i_freqk_hz, offsetk_hz);
1851                 if (status < 0)
1852                         goto error;
1853                 status = dvbt_start(state);
1854                 if (status < 0)
1855                         goto error;
1856                 state->m_drxk_state = DRXK_DTV_STARTED;
1857                 break;
1858         default:
1859                 break;
1860         }
1861 error:
1862         if (status < 0)
1863                 pr_err("Error %d on %s\n", status, __func__);
1864         return status;
1865 }
1866 
1867 static int shut_down(struct drxk_state *state)
1868 {
1869         dprintk(1, "\n");
1870 
1871         mpegts_stop(state);
1872         return 0;
1873 }
1874 
1875 static int get_lock_status(struct drxk_state *state, u32 *p_lock_status)
1876 {
1877         int status = -EINVAL;
1878 
1879         dprintk(1, "\n");
1880 
1881         if (p_lock_status == NULL)
1882                 goto error;
1883 
1884         *p_lock_status = NOT_LOCKED;
1885 
1886         /* define the SCU command code */
1887         switch (state->m_operation_mode) {
1888         case OM_QAM_ITU_A:
1889         case OM_QAM_ITU_B:
1890         case OM_QAM_ITU_C:
1891                 status = get_qam_lock_status(state, p_lock_status);
1892                 break;
1893         case OM_DVBT:
1894                 status = get_dvbt_lock_status(state, p_lock_status);
1895                 break;
1896         default:
1897                 pr_debug("Unsupported operation mode %d in %s\n",
1898                         state->m_operation_mode, __func__);
1899                 return 0;
1900         }
1901 error:
1902         if (status < 0)
1903                 pr_err("Error %d on %s\n", status, __func__);
1904         return status;
1905 }
1906 
1907 static int mpegts_start(struct drxk_state *state)
1908 {
1909         int status;
1910 
1911         u16 fec_oc_snc_mode = 0;
1912 
1913         /* Allow OC to sync again */
1914         status = read16(state, FEC_OC_SNC_MODE__A, &fec_oc_snc_mode);
1915         if (status < 0)
1916                 goto error;
1917         fec_oc_snc_mode &= ~FEC_OC_SNC_MODE_SHUTDOWN__M;
1918         status = write16(state, FEC_OC_SNC_MODE__A, fec_oc_snc_mode);
1919         if (status < 0)
1920                 goto error;
1921         status = write16(state, FEC_OC_SNC_UNLOCK__A, 1);
1922 error:
1923         if (status < 0)
1924                 pr_err("Error %d on %s\n", status, __func__);
1925         return status;
1926 }
1927 
1928 static int mpegts_dto_init(struct drxk_state *state)
1929 {
1930         int status;
1931 
1932         dprintk(1, "\n");
1933 
1934         /* Rate integration settings */
1935         status = write16(state, FEC_OC_RCN_CTL_STEP_LO__A, 0x0000);
1936         if (status < 0)
1937                 goto error;
1938         status = write16(state, FEC_OC_RCN_CTL_STEP_HI__A, 0x000C);
1939         if (status < 0)
1940                 goto error;
1941         status = write16(state, FEC_OC_RCN_GAIN__A, 0x000A);
1942         if (status < 0)
1943                 goto error;
1944         status = write16(state, FEC_OC_AVR_PARM_A__A, 0x0008);
1945         if (status < 0)
1946                 goto error;
1947         status = write16(state, FEC_OC_AVR_PARM_B__A, 0x0006);
1948         if (status < 0)
1949                 goto error;
1950         status = write16(state, FEC_OC_TMD_HI_MARGIN__A, 0x0680);
1951         if (status < 0)
1952                 goto error;
1953         status = write16(state, FEC_OC_TMD_LO_MARGIN__A, 0x0080);
1954         if (status < 0)
1955                 goto error;
1956         status = write16(state, FEC_OC_TMD_COUNT__A, 0x03F4);
1957         if (status < 0)
1958                 goto error;
1959 
1960         /* Additional configuration */
1961         status = write16(state, FEC_OC_OCR_INVERT__A, 0);
1962         if (status < 0)
1963                 goto error;
1964         status = write16(state, FEC_OC_SNC_LWM__A, 2);
1965         if (status < 0)
1966                 goto error;
1967         status = write16(state, FEC_OC_SNC_HWM__A, 12);
1968 error:
1969         if (status < 0)
1970                 pr_err("Error %d on %s\n", status, __func__);
1971 
1972         return status;
1973 }
1974 
1975 static int mpegts_dto_setup(struct drxk_state *state,
1976                           enum operation_mode o_mode)
1977 {
1978         int status;
1979 
1980         u16 fec_oc_reg_mode = 0;        /* FEC_OC_MODE       register value */
1981         u16 fec_oc_reg_ipr_mode = 0;    /* FEC_OC_IPR_MODE   register value */
1982         u16 fec_oc_dto_mode = 0;        /* FEC_OC_IPR_INVERT register value */
1983         u16 fec_oc_fct_mode = 0;        /* FEC_OC_IPR_INVERT register value */
1984         u16 fec_oc_dto_period = 2;      /* FEC_OC_IPR_INVERT register value */
1985         u16 fec_oc_dto_burst_len = 188; /* FEC_OC_IPR_INVERT register value */
1986         u32 fec_oc_rcn_ctl_rate = 0;    /* FEC_OC_IPR_INVERT register value */
1987         u16 fec_oc_tmd_mode = 0;
1988         u16 fec_oc_tmd_int_upd_rate = 0;
1989         u32 max_bit_rate = 0;
1990         bool static_clk = false;
1991 
1992         dprintk(1, "\n");
1993 
1994         /* Check insertion of the Reed-Solomon parity bytes */
1995         status = read16(state, FEC_OC_MODE__A, &fec_oc_reg_mode);
1996         if (status < 0)
1997                 goto error;
1998         status = read16(state, FEC_OC_IPR_MODE__A, &fec_oc_reg_ipr_mode);
1999         if (status < 0)
2000                 goto error;
2001         fec_oc_reg_mode &= (~FEC_OC_MODE_PARITY__M);
2002         fec_oc_reg_ipr_mode &= (~FEC_OC_IPR_MODE_MVAL_DIS_PAR__M);
2003         if (state->m_insert_rs_byte) {
2004                 /* enable parity symbol forward */
2005                 fec_oc_reg_mode |= FEC_OC_MODE_PARITY__M;
2006                 /* MVAL disable during parity bytes */
2007                 fec_oc_reg_ipr_mode |= FEC_OC_IPR_MODE_MVAL_DIS_PAR__M;
2008                 /* TS burst length to 204 */
2009                 fec_oc_dto_burst_len = 204;
2010         }
2011 
2012         /* Check serial or parallel output */
2013         fec_oc_reg_ipr_mode &= (~(FEC_OC_IPR_MODE_SERIAL__M));
2014         if (!state->m_enable_parallel) {
2015                 /* MPEG data output is serial -> set ipr_mode[0] */
2016                 fec_oc_reg_ipr_mode |= FEC_OC_IPR_MODE_SERIAL__M;
2017         }
2018 
2019         switch (o_mode) {
2020         case OM_DVBT:
2021                 max_bit_rate = state->m_dvbt_bitrate;
2022                 fec_oc_tmd_mode = 3;
2023                 fec_oc_rcn_ctl_rate = 0xC00000;
2024                 static_clk = state->m_dvbt_static_clk;
2025                 break;
2026         case OM_QAM_ITU_A:      /* fallthrough */
2027         case OM_QAM_ITU_C:
2028                 fec_oc_tmd_mode = 0x0004;
2029                 fec_oc_rcn_ctl_rate = 0xD2B4EE; /* good for >63 Mb/s */
2030                 max_bit_rate = state->m_dvbc_bitrate;
2031                 static_clk = state->m_dvbc_static_clk;
2032                 break;
2033         default:
2034                 status = -EINVAL;
2035         }               /* switch (standard) */
2036         if (status < 0)
2037                 goto error;
2038 
2039         /* Configure DTO's */
2040         if (static_clk) {
2041                 u32 bit_rate = 0;
2042 
2043                 /* Rational DTO for MCLK source (static MCLK rate),
2044                         Dynamic DTO for optimal grouping
2045                         (avoid intra-packet gaps),
2046                         DTO offset enable to sync TS burst with MSTRT */
2047                 fec_oc_dto_mode = (FEC_OC_DTO_MODE_DYNAMIC__M |
2048                                 FEC_OC_DTO_MODE_OFFSET_ENABLE__M);
2049                 fec_oc_fct_mode = (FEC_OC_FCT_MODE_RAT_ENA__M |
2050                                 FEC_OC_FCT_MODE_VIRT_ENA__M);
2051 
2052                 /* Check user defined bitrate */
2053                 bit_rate = max_bit_rate;
2054                 if (bit_rate > 75900000UL) {    /* max is 75.9 Mb/s */
2055                         bit_rate = 75900000UL;
2056                 }
2057                 /* Rational DTO period:
2058                         dto_period = (Fsys / bitrate) - 2
2059 
2060                         result should be floored,
2061                         to make sure >= requested bitrate
2062                         */
2063                 fec_oc_dto_period = (u16) (((state->m_sys_clock_freq)
2064                                                 * 1000) / bit_rate);
2065                 if (fec_oc_dto_period <= 2)
2066                         fec_oc_dto_period = 0;
2067                 else
2068                         fec_oc_dto_period -= 2;
2069                 fec_oc_tmd_int_upd_rate = 8;
2070         } else {
2071                 /* (commonAttr->static_clk == false) => dynamic mode */
2072                 fec_oc_dto_mode = FEC_OC_DTO_MODE_DYNAMIC__M;
2073                 fec_oc_fct_mode = FEC_OC_FCT_MODE__PRE;
2074                 fec_oc_tmd_int_upd_rate = 5;
2075         }
2076 
2077         /* Write appropriate registers with requested configuration */
2078         status = write16(state, FEC_OC_DTO_BURST_LEN__A, fec_oc_dto_burst_len);
2079         if (status < 0)
2080                 goto error;
2081         status = write16(state, FEC_OC_DTO_PERIOD__A, fec_oc_dto_period);
2082         if (status < 0)
2083                 goto error;
2084         status = write16(state, FEC_OC_DTO_MODE__A, fec_oc_dto_mode);
2085         if (status < 0)
2086                 goto error;
2087         status = write16(state, FEC_OC_FCT_MODE__A, fec_oc_fct_mode);
2088         if (status < 0)
2089                 goto error;
2090         status = write16(state, FEC_OC_MODE__A, fec_oc_reg_mode);
2091         if (status < 0)
2092                 goto error;
2093         status = write16(state, FEC_OC_IPR_MODE__A, fec_oc_reg_ipr_mode);
2094         if (status < 0)
2095                 goto error;
2096 
2097         /* Rate integration settings */
2098         status = write32(state, FEC_OC_RCN_CTL_RATE_LO__A, fec_oc_rcn_ctl_rate);
2099         if (status < 0)
2100                 goto error;
2101         status = write16(state, FEC_OC_TMD_INT_UPD_RATE__A,
2102                          fec_oc_tmd_int_upd_rate);
2103         if (status < 0)
2104                 goto error;
2105         status = write16(state, FEC_OC_TMD_MODE__A, fec_oc_tmd_mode);
2106 error:
2107         if (status < 0)
2108                 pr_err("Error %d on %s\n", status, __func__);
2109         return status;
2110 }
2111 
2112 static int mpegts_configure_polarity(struct drxk_state *state)
2113 {
2114         u16 fec_oc_reg_ipr_invert = 0;
2115 
2116         /* Data mask for the output data byte */
2117         u16 invert_data_mask =
2118             FEC_OC_IPR_INVERT_MD7__M | FEC_OC_IPR_INVERT_MD6__M |
2119             FEC_OC_IPR_INVERT_MD5__M | FEC_OC_IPR_INVERT_MD4__M |
2120             FEC_OC_IPR_INVERT_MD3__M | FEC_OC_IPR_INVERT_MD2__M |
2121             FEC_OC_IPR_INVERT_MD1__M | FEC_OC_IPR_INVERT_MD0__M;
2122 
2123         dprintk(1, "\n");
2124 
2125         /* Control selective inversion of output bits */
2126         fec_oc_reg_ipr_invert &= (~(invert_data_mask));
2127         if (state->m_invert_data)
2128                 fec_oc_reg_ipr_invert |= invert_data_mask;
2129         fec_oc_reg_ipr_invert &= (~(FEC_OC_IPR_INVERT_MERR__M));
2130         if (state->m_invert_err)
2131                 fec_oc_reg_ipr_invert |= FEC_OC_IPR_INVERT_MERR__M;
2132         fec_oc_reg_ipr_invert &= (~(FEC_OC_IPR_INVERT_MSTRT__M));
2133         if (state->m_invert_str)
2134                 fec_oc_reg_ipr_invert |= FEC_OC_IPR_INVERT_MSTRT__M;
2135         fec_oc_reg_ipr_invert &= (~(FEC_OC_IPR_INVERT_MVAL__M));
2136         if (state->m_invert_val)
2137                 fec_oc_reg_ipr_invert |= FEC_OC_IPR_INVERT_MVAL__M;
2138         fec_oc_reg_ipr_invert &= (~(FEC_OC_IPR_INVERT_MCLK__M));
2139         if (state->m_invert_clk)
2140                 fec_oc_reg_ipr_invert |= FEC_OC_IPR_INVERT_MCLK__M;
2141 
2142         return write16(state, FEC_OC_IPR_INVERT__A, fec_oc_reg_ipr_invert);
2143 }
2144 
2145 #define   SCU_RAM_AGC_KI_INV_RF_POL__M 0x4000
2146 
2147 static int set_agc_rf(struct drxk_state *state,
2148                     struct s_cfg_agc *p_agc_cfg, bool is_dtv)
2149 {
2150         int status = -EINVAL;
2151         u16 data = 0;
2152         struct s_cfg_agc *p_if_agc_settings;
2153 
2154         dprintk(1, "\n");
2155 
2156         if (p_agc_cfg == NULL)
2157                 goto error;
2158 
2159         switch (p_agc_cfg->ctrl_mode) {
2160         case DRXK_AGC_CTRL_AUTO:
2161                 /* Enable RF AGC DAC */
2162                 status = read16(state, IQM_AF_STDBY__A, &data);
2163                 if (status < 0)
2164                         goto error;
2165                 data &= ~IQM_AF_STDBY_STDBY_TAGC_RF_STANDBY;
2166                 status = write16(state, IQM_AF_STDBY__A, data);
2167                 if (status < 0)
2168                         goto error;
2169                 status = read16(state, SCU_RAM_AGC_CONFIG__A, &data);
2170                 if (status < 0)
2171                         goto error;
2172 
2173                 /* Enable SCU RF AGC loop */
2174                 data &= ~SCU_RAM_AGC_CONFIG_DISABLE_RF_AGC__M;
2175 
2176                 /* Polarity */
2177                 if (state->m_rf_agc_pol)
2178                         data |= SCU_RAM_AGC_CONFIG_INV_RF_POL__M;
2179                 else
2180                         data &= ~SCU_RAM_AGC_CONFIG_INV_RF_POL__M;
2181                 status = write16(state, SCU_RAM_AGC_CONFIG__A, data);
2182                 if (status < 0)
2183                         goto error;
2184 
2185                 /* Set speed (using complementary reduction value) */
2186                 status = read16(state, SCU_RAM_AGC_KI_RED__A, &data);
2187                 if (status < 0)
2188                         goto error;
2189 
2190                 data &= ~SCU_RAM_AGC_KI_RED_RAGC_RED__M;
2191                 data |= (~(p_agc_cfg->speed <<
2192                                 SCU_RAM_AGC_KI_RED_RAGC_RED__B)
2193                                 & SCU_RAM_AGC_KI_RED_RAGC_RED__M);
2194 
2195                 status = write16(state, SCU_RAM_AGC_KI_RED__A, data);
2196                 if (status < 0)
2197                         goto error;
2198 
2199                 if (is_dvbt(state))
2200                         p_if_agc_settings = &state->m_dvbt_if_agc_cfg;
2201                 else if (is_qam(state))
2202                         p_if_agc_settings = &state->m_qam_if_agc_cfg;
2203                 else
2204                         p_if_agc_settings = &state->m_atv_if_agc_cfg;
2205                 if (p_if_agc_settings == NULL) {
2206                         status = -EINVAL;
2207                         goto error;
2208                 }
2209 
2210                 /* Set TOP, only if IF-AGC is in AUTO mode */
2211                 if (p_if_agc_settings->ctrl_mode == DRXK_AGC_CTRL_AUTO) {
2212                         status = write16(state,
2213                                          SCU_RAM_AGC_IF_IACCU_HI_TGT_MAX__A,
2214                                          p_agc_cfg->top);
2215                         if (status < 0)
2216                                 goto error;
2217                 }
2218 
2219                 /* Cut-Off current */
2220                 status = write16(state, SCU_RAM_AGC_RF_IACCU_HI_CO__A,
2221                                  p_agc_cfg->cut_off_current);
2222                 if (status < 0)
2223                         goto error;
2224 
2225                 /* Max. output level */
2226                 status = write16(state, SCU_RAM_AGC_RF_MAX__A,
2227                                  p_agc_cfg->max_output_level);
2228                 if (status < 0)
2229                         goto error;
2230 
2231                 break;
2232 
2233         case DRXK_AGC_CTRL_USER:
2234                 /* Enable RF AGC DAC */
2235                 status = read16(state, IQM_AF_STDBY__A, &data);
2236                 if (status < 0)
2237                         goto error;
2238                 data &= ~IQM_AF_STDBY_STDBY_TAGC_RF_STANDBY;
2239                 status = write16(state, IQM_AF_STDBY__A, data);
2240                 if (status < 0)
2241                         goto error;
2242 
2243                 /* Disable SCU RF AGC loop */
2244                 status = read16(state, SCU_RAM_AGC_CONFIG__A, &data);
2245                 if (status < 0)
2246                         goto error;
2247                 data |= SCU_RAM_AGC_CONFIG_DISABLE_RF_AGC__M;
2248                 if (state->m_rf_agc_pol)
2249                         data |= SCU_RAM_AGC_CONFIG_INV_RF_POL__M;
2250                 else
2251                         data &= ~SCU_RAM_AGC_CONFIG_INV_RF_POL__M;
2252                 status = write16(state, SCU_RAM_AGC_CONFIG__A, data);
2253                 if (status < 0)
2254                         goto error;
2255 
2256                 /* SCU c.o.c. to 0, enabling full control range */
2257                 status = write16(state, SCU_RAM_AGC_RF_IACCU_HI_CO__A, 0);
2258                 if (status < 0)
2259                         goto error;
2260 
2261                 /* Write value to output pin */
2262                 status = write16(state, SCU_RAM_AGC_RF_IACCU_HI__A,
2263                                  p_agc_cfg->output_level);
2264                 if (status < 0)
2265                         goto error;
2266                 break;
2267 
2268         case DRXK_AGC_CTRL_OFF:
2269                 /* Disable RF AGC DAC */
2270                 status = read16(state, IQM_AF_STDBY__A, &data);
2271                 if (status < 0)
2272                         goto error;
2273                 data |= IQM_AF_STDBY_STDBY_TAGC_RF_STANDBY;
2274                 status = write16(state, IQM_AF_STDBY__A, data);
2275                 if (status < 0)
2276                         goto error;
2277 
2278                 /* Disable SCU RF AGC loop */
2279                 status = read16(state, SCU_RAM_AGC_CONFIG__A, &data);
2280                 if (status < 0)
2281                         goto error;
2282                 data |= SCU_RAM_AGC_CONFIG_DISABLE_RF_AGC__M;
2283                 status = write16(state, SCU_RAM_AGC_CONFIG__A, data);
2284                 if (status < 0)
2285                         goto error;
2286                 break;
2287 
2288         default:
2289                 status = -EINVAL;
2290 
2291         }
2292 error:
2293         if (status < 0)
2294                 pr_err("Error %d on %s\n", status, __func__);
2295         return status;
2296 }
2297 
2298 #define SCU_RAM_AGC_KI_INV_IF_POL__M 0x2000
2299 
2300 static int set_agc_if(struct drxk_state *state,
2301                     struct s_cfg_agc *p_agc_cfg, bool is_dtv)
2302 {
2303         u16 data = 0;
2304         int status = 0;
2305         struct s_cfg_agc *p_rf_agc_settings;
2306 
2307         dprintk(1, "\n");
2308 
2309         switch (p_agc_cfg->ctrl_mode) {
2310         case DRXK_AGC_CTRL_AUTO:
2311 
2312                 /* Enable IF AGC DAC */
2313                 status = read16(state, IQM_AF_STDBY__A, &data);
2314                 if (status < 0)
2315                         goto error;
2316                 data &= ~IQM_AF_STDBY_STDBY_TAGC_IF_STANDBY;
2317                 status = write16(state, IQM_AF_STDBY__A, data);
2318                 if (status < 0)
2319                         goto error;
2320 
2321                 status = read16(state, SCU_RAM_AGC_CONFIG__A, &data);
2322                 if (status < 0)
2323                         goto error;
2324 
2325                 /* Enable SCU IF AGC loop */
2326                 data &= ~SCU_RAM_AGC_CONFIG_DISABLE_IF_AGC__M;
2327 
2328                 /* Polarity */
2329                 if (state->m_if_agc_pol)
2330                         data |= SCU_RAM_AGC_CONFIG_INV_IF_POL__M;
2331                 else
2332                         data &= ~SCU_RAM_AGC_CONFIG_INV_IF_POL__M;
2333                 status = write16(state, SCU_RAM_AGC_CONFIG__A, data);
2334                 if (status < 0)
2335                         goto error;
2336 
2337                 /* Set speed (using complementary reduction value) */
2338                 status = read16(state, SCU_RAM_AGC_KI_RED__A, &data);
2339                 if (status < 0)
2340                         goto error;
2341                 data &= ~SCU_RAM_AGC_KI_RED_IAGC_RED__M;
2342                 data |= (~(p_agc_cfg->speed <<
2343                                 SCU_RAM_AGC_KI_RED_IAGC_RED__B)
2344                                 & SCU_RAM_AGC_KI_RED_IAGC_RED__M);
2345 
2346                 status = write16(state, SCU_RAM_AGC_KI_RED__A, data);
2347                 if (status < 0)
2348                         goto error;
2349 
2350                 if (is_qam(state))
2351                         p_rf_agc_settings = &state->m_qam_rf_agc_cfg;
2352                 else
2353                         p_rf_agc_settings = &state->m_atv_rf_agc_cfg;
2354                 if (p_rf_agc_settings == NULL)
2355                         return -1;
2356                 /* Restore TOP */
2357                 status = write16(state, SCU_RAM_AGC_IF_IACCU_HI_TGT_MAX__A,
2358                                  p_rf_agc_settings->top);
2359                 if (status < 0)
2360                         goto error;
2361                 break;
2362 
2363         case DRXK_AGC_CTRL_USER:
2364 
2365                 /* Enable IF AGC DAC */
2366                 status = read16(state, IQM_AF_STDBY__A, &data);
2367                 if (status < 0)
2368                         goto error;
2369                 data &= ~IQM_AF_STDBY_STDBY_TAGC_IF_STANDBY;
2370                 status = write16(state, IQM_AF_STDBY__A, data);
2371                 if (status < 0)
2372                         goto error;
2373 
2374                 status = read16(state, SCU_RAM_AGC_CONFIG__A, &data);
2375                 if (status < 0)
2376                         goto error;
2377 
2378                 /* Disable SCU IF AGC loop */
2379                 data |= SCU_RAM_AGC_CONFIG_DISABLE_IF_AGC__M;
2380 
2381                 /* Polarity */
2382                 if (state->m_if_agc_pol)
2383                         data |= SCU_RAM_AGC_CONFIG_INV_IF_POL__M;
2384                 else
2385                         data &= ~SCU_RAM_AGC_CONFIG_INV_IF_POL__M;
2386                 status = write16(state, SCU_RAM_AGC_CONFIG__A, data);
2387                 if (status < 0)
2388                         goto error;
2389 
2390                 /* Write value to output pin */
2391                 status = write16(state, SCU_RAM_AGC_IF_IACCU_HI_TGT_MAX__A,
2392                                  p_agc_cfg->output_level);
2393                 if (status < 0)
2394                         goto error;
2395                 break;
2396 
2397         case DRXK_AGC_CTRL_OFF:
2398 
2399                 /* Disable If AGC DAC */
2400                 status = read16(state, IQM_AF_STDBY__A, &data);
2401                 if (status < 0)
2402                         goto error;
2403                 data |= IQM_AF_STDBY_STDBY_TAGC_IF_STANDBY;
2404                 status = write16(state, IQM_AF_STDBY__A, data);
2405                 if (status < 0)
2406                         goto error;
2407 
2408                 /* Disable SCU IF AGC loop */
2409                 status = read16(state, SCU_RAM_AGC_CONFIG__A, &data);
2410                 if (status < 0)
2411                         goto error;
2412                 data |= SCU_RAM_AGC_CONFIG_DISABLE_IF_AGC__M;
2413                 status = write16(state, SCU_RAM_AGC_CONFIG__A, data);
2414                 if (status < 0)
2415                         goto error;
2416                 break;
2417         }               /* switch (agcSettingsIf->ctrl_mode) */
2418 
2419         /* always set the top to support
2420                 configurations without if-loop */
2421         status = write16(state, SCU_RAM_AGC_INGAIN_TGT_MIN__A, p_agc_cfg->top);
2422 error:
2423         if (status < 0)
2424                 pr_err("Error %d on %s\n", status, __func__);
2425         return status;
2426 }
2427 
2428 static int get_qam_signal_to_noise(struct drxk_state *state,
2429                                s32 *p_signal_to_noise)
2430 {
2431         int status = 0;
2432         u16 qam_sl_err_power = 0;       /* accum. error between
2433                                         raw and sliced symbols */
2434         u32 qam_sl_sig_power = 0;       /* used for MER, depends of
2435                                         QAM modulation */
2436         u32 qam_sl_mer = 0;     /* QAM MER */
2437 
2438         dprintk(1, "\n");
2439 
2440         /* MER calculation */
2441 
2442         /* get the register value needed for MER */
2443         status = read16(state, QAM_SL_ERR_POWER__A, &qam_sl_err_power);
2444         if (status < 0) {
2445                 pr_err("Error %d on %s\n", status, __func__);
2446                 return -EINVAL;
2447         }
2448 
2449         switch (state->props.modulation) {
2450         case QAM_16:
2451                 qam_sl_sig_power = DRXK_QAM_SL_SIG_POWER_QAM16 << 2;
2452                 break;
2453         case QAM_32:
2454                 qam_sl_sig_power = DRXK_QAM_SL_SIG_POWER_QAM32 << 2;
2455                 break;
2456         case QAM_64:
2457                 qam_sl_sig_power = DRXK_QAM_SL_SIG_POWER_QAM64 << 2;
2458                 break;
2459         case QAM_128:
2460                 qam_sl_sig_power = DRXK_QAM_SL_SIG_POWER_QAM128 << 2;
2461                 break;
2462         default:
2463         case QAM_256:
2464                 qam_sl_sig_power = DRXK_QAM_SL_SIG_POWER_QAM256 << 2;
2465                 break;
2466         }
2467 
2468         if (qam_sl_err_power > 0) {
2469                 qam_sl_mer = log10times100(qam_sl_sig_power) -
2470                         log10times100((u32) qam_sl_err_power);
2471         }
2472         *p_signal_to_noise = qam_sl_mer;
2473 
2474         return status;
2475 }
2476 
2477 static int get_dvbt_signal_to_noise(struct drxk_state *state,
2478                                 s32 *p_signal_to_noise)
2479 {
2480         int status;
2481         u16 reg_data = 0;
2482         u32 eq_reg_td_sqr_err_i = 0;
2483         u32 eq_reg_td_sqr_err_q = 0;
2484         u16 eq_reg_td_sqr_err_exp = 0;
2485         u16 eq_reg_td_tps_pwr_ofs = 0;
2486         u16 eq_reg_td_req_smb_cnt = 0;
2487         u32 tps_cnt = 0;
2488         u32 sqr_err_iq = 0;
2489         u32 a = 0;
2490         u32 b = 0;
2491         u32 c = 0;
2492         u32 i_mer = 0;
2493         u16 transmission_params = 0;
2494 
2495         dprintk(1, "\n");
2496 
2497         status = read16(state, OFDM_EQ_TOP_TD_TPS_PWR_OFS__A,
2498                         &eq_reg_td_tps_pwr_ofs);
2499         if (status < 0)
2500                 goto error;
2501         status = read16(state, OFDM_EQ_TOP_TD_REQ_SMB_CNT__A,
2502                         &eq_reg_td_req_smb_cnt);
2503         if (status < 0)
2504                 goto error;
2505         status = read16(state, OFDM_EQ_TOP_TD_SQR_ERR_EXP__A,
2506                         &eq_reg_td_sqr_err_exp);
2507         if (status < 0)
2508                 goto error;
2509         status = read16(state, OFDM_EQ_TOP_TD_SQR_ERR_I__A,
2510                         &reg_data);
2511         if (status < 0)
2512                 goto error;
2513         /* Extend SQR_ERR_I operational range */
2514         eq_reg_td_sqr_err_i = (u32) reg_data;
2515         if ((eq_reg_td_sqr_err_exp > 11) &&
2516                 (eq_reg_td_sqr_err_i < 0x00000FFFUL)) {
2517                 eq_reg_td_sqr_err_i += 0x00010000UL;
2518         }
2519         status = read16(state, OFDM_EQ_TOP_TD_SQR_ERR_Q__A, &reg_data);
2520         if (status < 0)
2521                 goto error;
2522         /* Extend SQR_ERR_Q operational range */
2523         eq_reg_td_sqr_err_q = (u32) reg_data;
2524         if ((eq_reg_td_sqr_err_exp > 11) &&
2525                 (eq_reg_td_sqr_err_q < 0x00000FFFUL))
2526                 eq_reg_td_sqr_err_q += 0x00010000UL;
2527 
2528         status = read16(state, OFDM_SC_RA_RAM_OP_PARAM__A,
2529                         &transmission_params);
2530         if (status < 0)
2531                 goto error;
2532 
2533         /* Check input data for MER */
2534 
2535         /* MER calculation (in 0.1 dB) without math.h */
2536         if ((eq_reg_td_tps_pwr_ofs == 0) || (eq_reg_td_req_smb_cnt == 0))
2537                 i_mer = 0;
2538         else if ((eq_reg_td_sqr_err_i + eq_reg_td_sqr_err_q) == 0) {
2539                 /* No error at all, this must be the HW reset value
2540                         * Apparently no first measurement yet
2541                         * Set MER to 0.0 */
2542                 i_mer = 0;
2543         } else {
2544                 sqr_err_iq = (eq_reg_td_sqr_err_i + eq_reg_td_sqr_err_q) <<
2545                         eq_reg_td_sqr_err_exp;
2546                 if ((transmission_params &
2547                         OFDM_SC_RA_RAM_OP_PARAM_MODE__M)
2548                         == OFDM_SC_RA_RAM_OP_PARAM_MODE_2K)
2549                         tps_cnt = 17;
2550                 else
2551                         tps_cnt = 68;
2552 
2553                 /* IMER = 100 * log10 (x)
2554                         where x = (eq_reg_td_tps_pwr_ofs^2 *
2555                         eq_reg_td_req_smb_cnt * tps_cnt)/sqr_err_iq
2556 
2557                         => IMER = a + b -c
2558                         where a = 100 * log10 (eq_reg_td_tps_pwr_ofs^2)
2559                         b = 100 * log10 (eq_reg_td_req_smb_cnt * tps_cnt)
2560                         c = 100 * log10 (sqr_err_iq)
2561                         */
2562 
2563                 /* log(x) x = 9bits * 9bits->18 bits  */
2564                 a = log10times100(eq_reg_td_tps_pwr_ofs *
2565                                         eq_reg_td_tps_pwr_ofs);
2566                 /* log(x) x = 16bits * 7bits->23 bits  */
2567                 b = log10times100(eq_reg_td_req_smb_cnt * tps_cnt);
2568                 /* log(x) x = (16bits + 16bits) << 15 ->32 bits  */
2569                 c = log10times100(sqr_err_iq);
2570 
2571                 i_mer = a + b - c;
2572         }
2573         *p_signal_to_noise = i_mer;
2574 
2575 error:
2576         if (status < 0)
2577                 pr_err("Error %d on %s\n", status, __func__);
2578         return status;
2579 }
2580 
2581 static int get_signal_to_noise(struct drxk_state *state, s32 *p_signal_to_noise)
2582 {
2583         dprintk(1, "\n");
2584 
2585         *p_signal_to_noise = 0;
2586         switch (state->m_operation_mode) {
2587         case OM_DVBT:
2588                 return get_dvbt_signal_to_noise(state, p_signal_to_noise);
2589         case OM_QAM_ITU_A:
2590         case OM_QAM_ITU_C:
2591                 return get_qam_signal_to_noise(state, p_signal_to_noise);
2592         default:
2593                 break;
2594         }
2595         return 0;
2596 }
2597 
2598 #if 0
2599 static int get_dvbt_quality(struct drxk_state *state, s32 *p_quality)
2600 {
2601         /* SNR Values for quasi errorfree reception rom Nordig 2.2 */
2602         int status = 0;
2603 
2604         dprintk(1, "\n");
2605 
2606         static s32 QE_SN[] = {
2607                 51,             /* QPSK 1/2 */
2608                 69,             /* QPSK 2/3 */
2609                 79,             /* QPSK 3/4 */
2610                 89,             /* QPSK 5/6 */
2611                 97,             /* QPSK 7/8 */
2612                 108,            /* 16-QAM 1/2 */
2613                 131,            /* 16-QAM 2/3 */
2614                 146,            /* 16-QAM 3/4 */
2615                 156,            /* 16-QAM 5/6 */
2616                 160,            /* 16-QAM 7/8 */
2617                 165,            /* 64-QAM 1/2 */
2618                 187,            /* 64-QAM 2/3 */
2619                 202,            /* 64-QAM 3/4 */
2620                 216,            /* 64-QAM 5/6 */
2621                 225,            /* 64-QAM 7/8 */
2622         };
2623 
2624         *p_quality = 0;
2625 
2626         do {
2627                 s32 signal_to_noise = 0;
2628                 u16 constellation = 0;
2629                 u16 code_rate = 0;
2630                 u32 signal_to_noise_rel;
2631                 u32 ber_quality;
2632 
2633                 status = get_dvbt_signal_to_noise(state, &signal_to_noise);
2634                 if (status < 0)
2635                         break;
2636                 status = read16(state, OFDM_EQ_TOP_TD_TPS_CONST__A,
2637                                 &constellation);
2638                 if (status < 0)
2639                         break;
2640                 constellation &= OFDM_EQ_TOP_TD_TPS_CONST__M;
2641 
2642                 status = read16(state, OFDM_EQ_TOP_TD_TPS_CODE_HP__A,
2643                                 &code_rate);
2644                 if (status < 0)
2645                         break;
2646                 code_rate &= OFDM_EQ_TOP_TD_TPS_CODE_HP__M;
2647 
2648                 if (constellation > OFDM_EQ_TOP_TD_TPS_CONST_64QAM ||
2649                     code_rate > OFDM_EQ_TOP_TD_TPS_CODE_LP_7_8)
2650                         break;
2651                 signal_to_noise_rel = signal_to_noise -
2652                     QE_SN[constellation * 5 + code_rate];
2653                 ber_quality = 100;
2654 
2655                 if (signal_to_noise_rel < -70)
2656                         *p_quality = 0;
2657                 else if (signal_to_noise_rel < 30)
2658                         *p_quality = ((signal_to_noise_rel + 70) *
2659                                      ber_quality) / 100;
2660                 else
2661                         *p_quality = ber_quality;
2662         } while (0);
2663         return 0;
2664 };
2665 
2666 static int get_dvbc_quality(struct drxk_state *state, s32 *p_quality)
2667 {
2668         int status = 0;
2669         *p_quality = 0;
2670 
2671         dprintk(1, "\n");
2672 
2673         do {
2674                 u32 signal_to_noise = 0;
2675                 u32 ber_quality = 100;
2676                 u32 signal_to_noise_rel = 0;
2677 
2678                 status = get_qam_signal_to_noise(state, &signal_to_noise);
2679                 if (status < 0)
2680                         break;
2681 
2682                 switch (state->props.modulation) {
2683                 case QAM_16:
2684                         signal_to_noise_rel = signal_to_noise - 200;
2685                         break;
2686                 case QAM_32:
2687                         signal_to_noise_rel = signal_to_noise - 230;
2688                         break;  /* Not in NorDig */
2689                 case QAM_64:
2690                         signal_to_noise_rel = signal_to_noise - 260;
2691                         break;
2692                 case QAM_128:
2693                         signal_to_noise_rel = signal_to_noise - 290;
2694                         break;
2695                 default:
2696                 case QAM_256:
2697                         signal_to_noise_rel = signal_to_noise - 320;
2698                         break;
2699                 }
2700 
2701                 if (signal_to_noise_rel < -70)
2702                         *p_quality = 0;
2703                 else if (signal_to_noise_rel < 30)
2704                         *p_quality = ((signal_to_noise_rel + 70) *
2705                                      ber_quality) / 100;
2706                 else
2707                         *p_quality = ber_quality;
2708         } while (0);
2709 
2710         return status;
2711 }
2712 
2713 static int get_quality(struct drxk_state *state, s32 *p_quality)
2714 {
2715         dprintk(1, "\n");
2716 
2717         switch (state->m_operation_mode) {
2718         case OM_DVBT:
2719                 return get_dvbt_quality(state, p_quality);
2720         case OM_QAM_ITU_A:
2721                 return get_dvbc_quality(state, p_quality);
2722         default:
2723                 break;
2724         }
2725 
2726         return 0;
2727 }
2728 #endif
2729 
2730 /* Free data ram in SIO HI */
2731 #define SIO_HI_RA_RAM_USR_BEGIN__A 0x420040
2732 #define SIO_HI_RA_RAM_USR_END__A   0x420060
2733 
2734 #define DRXK_HI_ATOMIC_BUF_START (SIO_HI_RA_RAM_USR_BEGIN__A)
2735 #define DRXK_HI_ATOMIC_BUF_END   (SIO_HI_RA_RAM_USR_BEGIN__A + 7)
2736 #define DRXK_HI_ATOMIC_READ      SIO_HI_RA_RAM_PAR_3_ACP_RW_READ
2737 #define DRXK_HI_ATOMIC_WRITE     SIO_HI_RA_RAM_PAR_3_ACP_RW_WRITE
2738 
2739 #define DRXDAP_FASI_ADDR2BLOCK(addr)  (((addr) >> 22) & 0x3F)
2740 #define DRXDAP_FASI_ADDR2BANK(addr)   (((addr) >> 16) & 0x3F)
2741 #define DRXDAP_FASI_ADDR2OFFSET(addr) ((addr) & 0x7FFF)
2742 
2743 static int ConfigureI2CBridge(struct drxk_state *state, bool b_enable_bridge)
2744 {
2745         int status = -EINVAL;
2746 
2747         dprintk(1, "\n");
2748 
2749         if (state->m_drxk_state == DRXK_UNINITIALIZED)
2750                 return 0;
2751         if (state->m_drxk_state == DRXK_POWERED_DOWN)
2752                 goto error;
2753 
2754         if (state->no_i2c_bridge)
2755                 return 0;
2756 
2757         status = write16(state, SIO_HI_RA_RAM_PAR_1__A,
2758                          SIO_HI_RA_RAM_PAR_1_PAR1_SEC_KEY);
2759         if (status < 0)
2760                 goto error;
2761         if (b_enable_bridge) {
2762                 status = write16(state, SIO_HI_RA_RAM_PAR_2__A,
2763                                  SIO_HI_RA_RAM_PAR_2_BRD_CFG_CLOSED);
2764                 if (status < 0)
2765                         goto error;
2766         } else {
2767                 status = write16(state, SIO_HI_RA_RAM_PAR_2__A,
2768                                  SIO_HI_RA_RAM_PAR_2_BRD_CFG_OPEN);
2769                 if (status < 0)
2770                         goto error;
2771         }
2772 
2773         status = hi_command(state, SIO_HI_RA_RAM_CMD_BRDCTRL, NULL);
2774 
2775 error:
2776         if (status < 0)
2777                 pr_err("Error %d on %s\n", status, __func__);
2778         return status;
2779 }
2780 
2781 static int set_pre_saw(struct drxk_state *state,
2782                      struct s_cfg_pre_saw *p_pre_saw_cfg)
2783 {
2784         int status = -EINVAL;
2785 
2786         dprintk(1, "\n");
2787 
2788         if ((p_pre_saw_cfg == NULL)
2789             || (p_pre_saw_cfg->reference > IQM_AF_PDREF__M))
2790                 goto error;
2791 
2792         status = write16(state, IQM_AF_PDREF__A, p_pre_saw_cfg->reference);
2793 error:
2794         if (status < 0)
2795                 pr_err("Error %d on %s\n", status, __func__);
2796         return status;
2797 }
2798 
2799 static int bl_direct_cmd(struct drxk_state *state, u32 target_addr,
2800                        u16 rom_offset, u16 nr_of_elements, u32 time_out)
2801 {
2802         u16 bl_status = 0;
2803         u16 offset = (u16) ((target_addr >> 0) & 0x00FFFF);
2804         u16 blockbank = (u16) ((target_addr >> 16) & 0x000FFF);
2805         int status;
2806         unsigned long end;
2807 
2808         dprintk(1, "\n");
2809 
2810         mutex_lock(&state->mutex);
2811         status = write16(state, SIO_BL_MODE__A, SIO_BL_MODE_DIRECT);
2812         if (status < 0)
2813                 goto error;
2814         status = write16(state, SIO_BL_TGT_HDR__A, blockbank);
2815         if (status < 0)
2816                 goto error;
2817         status = write16(state, SIO_BL_TGT_ADDR__A, offset);
2818         if (status < 0)
2819                 goto error;
2820         status = write16(state, SIO_BL_SRC_ADDR__A, rom_offset);
2821         if (status < 0)
2822                 goto error;
2823         status = write16(state, SIO_BL_SRC_LEN__A, nr_of_elements);
2824         if (status < 0)
2825                 goto error;
2826         status = write16(state, SIO_BL_ENABLE__A, SIO_BL_ENABLE_ON);
2827         if (status < 0)
2828                 goto error;
2829 
2830         end = jiffies + msecs_to_jiffies(time_out);
2831         do {
2832                 status = read16(state, SIO_BL_STATUS__A, &bl_status);
2833                 if (status < 0)
2834                         goto error;
2835         } while ((bl_status == 0x1) && time_is_after_jiffies(end));
2836         if (bl_status == 0x1) {
2837                 pr_err("SIO not ready\n");
2838                 status = -EINVAL;
2839                 goto error2;
2840         }
2841 error:
2842         if (status < 0)
2843                 pr_err("Error %d on %s\n", status, __func__);
2844 error2:
2845         mutex_unlock(&state->mutex);
2846         return status;
2847 
2848 }
2849 
2850 static int adc_sync_measurement(struct drxk_state *state, u16 *count)
2851 {
2852         u16 data = 0;
2853         int status;
2854 
2855         dprintk(1, "\n");
2856 
2857         /* start measurement */
2858         status = write16(state, IQM_AF_COMM_EXEC__A, IQM_AF_COMM_EXEC_ACTIVE);
2859         if (status < 0)
2860                 goto error;
2861         status = write16(state, IQM_AF_START_LOCK__A, 1);
2862         if (status < 0)
2863                 goto error;
2864 
2865         *count = 0;
2866         status = read16(state, IQM_AF_PHASE0__A, &data);
2867         if (status < 0)
2868                 goto error;
2869         if (data == 127)
2870                 *count = *count + 1;
2871         status = read16(state, IQM_AF_PHASE1__A, &data);
2872         if (status < 0)
2873                 goto error;
2874         if (data == 127)
2875                 *count = *count + 1;
2876         status = read16(state, IQM_AF_PHASE2__A, &data);
2877         if (status < 0)
2878                 goto error;
2879         if (data == 127)
2880                 *count = *count + 1;
2881 
2882 error:
2883         if (status < 0)
2884                 pr_err("Error %d on %s\n", status, __func__);
2885         return status;
2886 }
2887 
2888 static int adc_synchronization(struct drxk_state *state)
2889 {
2890         u16 count = 0;
2891         int status;
2892 
2893         dprintk(1, "\n");
2894 
2895         status = adc_sync_measurement(state, &count);
2896         if (status < 0)
2897                 goto error;
2898 
2899         if (count == 1) {
2900                 /* Try sampling on a different edge */
2901                 u16 clk_neg = 0;
2902 
2903                 status = read16(state, IQM_AF_CLKNEG__A, &clk_neg);
2904                 if (status < 0)
2905                         goto error;
2906                 if ((clk_neg & IQM_AF_CLKNEG_CLKNEGDATA__M) ==
2907                         IQM_AF_CLKNEG_CLKNEGDATA_CLK_ADC_DATA_POS) {
2908                         clk_neg &= (~(IQM_AF_CLKNEG_CLKNEGDATA__M));
2909                         clk_neg |=
2910                                 IQM_AF_CLKNEG_CLKNEGDATA_CLK_ADC_DATA_NEG;
2911                 } else {
2912                         clk_neg &= (~(IQM_AF_CLKNEG_CLKNEGDATA__M));
2913                         clk_neg |=
2914                                 IQM_AF_CLKNEG_CLKNEGDATA_CLK_ADC_DATA_POS;
2915                 }
2916                 status = write16(state, IQM_AF_CLKNEG__A, clk_neg);
2917                 if (status < 0)
2918                         goto error;
2919                 status = adc_sync_measurement(state, &count);
2920                 if (status < 0)
2921                         goto error;
2922         }
2923 
2924         if (count < 2)
2925                 status = -EINVAL;
2926 error:
2927         if (status < 0)
2928                 pr_err("Error %d on %s\n", status, __func__);
2929         return status;
2930 }
2931 
2932 static int set_frequency_shifter(struct drxk_state *state,
2933                                u16 intermediate_freqk_hz,
2934                                s32 tuner_freq_offset, bool is_dtv)
2935 {
2936         bool select_pos_image = false;
2937         u32 rf_freq_residual = tuner_freq_offset;
2938         u32 fm_frequency_shift = 0;
2939         bool tuner_mirror = !state->m_b_mirror_freq_spect;
2940         u32 adc_freq;
2941         bool adc_flip;
2942         int status;
2943         u32 if_freq_actual;
2944         u32 sampling_frequency = (u32) (state->m_sys_clock_freq / 3);
2945         u32 frequency_shift;
2946         bool image_to_select;
2947 
2948         dprintk(1, "\n");
2949 
2950         /*
2951            Program frequency shifter
2952            No need to account for mirroring on RF
2953          */
2954         if (is_dtv) {
2955                 if ((state->m_operation_mode == OM_QAM_ITU_A) ||
2956                     (state->m_operation_mode == OM_QAM_ITU_C) ||
2957                     (state->m_operation_mode == OM_DVBT))
2958                         select_pos_image = true;
2959                 else
2960                         select_pos_image = false;
2961         }
2962         if (tuner_mirror)
2963                 /* tuner doesn't mirror */
2964                 if_freq_actual = intermediate_freqk_hz +
2965                     rf_freq_residual + fm_frequency_shift;
2966         else
2967                 /* tuner mirrors */
2968                 if_freq_actual = intermediate_freqk_hz -
2969                     rf_freq_residual - fm_frequency_shift;
2970         if (if_freq_actual > sampling_frequency / 2) {
2971                 /* adc mirrors */
2972                 adc_freq = sampling_frequency - if_freq_actual;
2973                 adc_flip = true;
2974         } else {
2975                 /* adc doesn't mirror */
2976                 adc_freq = if_freq_actual;
2977                 adc_flip = false;
2978         }
2979 
2980         frequency_shift = adc_freq;
2981         image_to_select = state->m_rfmirror ^ tuner_mirror ^
2982             adc_flip ^ select_pos_image;
2983         state->m_iqm_fs_rate_ofs =
2984             Frac28a((frequency_shift), sampling_frequency);
2985 
2986         if (image_to_select)
2987                 state->m_iqm_fs_rate_ofs = ~state->m_iqm_fs_rate_ofs + 1;
2988 
2989         /* Program frequency shifter with tuner offset compensation */
2990         /* frequency_shift += tuner_freq_offset; TODO */
2991         status = write32(state, IQM_FS_RATE_OFS_LO__A,
2992                          state->m_iqm_fs_rate_ofs);
2993         if (status < 0)
2994                 pr_err("Error %d on %s\n", status, __func__);
2995         return status;
2996 }
2997 
2998 static int init_agc(struct drxk_state *state, bool is_dtv)
2999 {
3000         u16 ingain_tgt = 0;
3001         u16 ingain_tgt_min = 0;
3002         u16 ingain_tgt_max = 0;
3003         u16 clp_cyclen = 0;
3004         u16 clp_sum_min = 0;
3005         u16 clp_dir_to = 0;
3006         u16 sns_sum_min = 0;
3007         u16 sns_sum_max = 0;
3008         u16 clp_sum_max = 0;
3009         u16 sns_dir_to = 0;
3010         u16 ki_innergain_min = 0;
3011         u16 if_iaccu_hi_tgt = 0;
3012         u16 if_iaccu_hi_tgt_min = 0;
3013         u16 if_iaccu_hi_tgt_max = 0;
3014         u16 data = 0;
3015         u16 fast_clp_ctrl_delay = 0;
3016         u16 clp_ctrl_mode = 0;
3017         int status = 0;
3018 
3019         dprintk(1, "\n");
3020 
3021         /* Common settings */
3022         sns_sum_max = 1023;
3023         if_iaccu_hi_tgt_min = 2047;
3024         clp_cyclen = 500;
3025         clp_sum_max = 1023;
3026 
3027         /* AGCInit() not available for DVBT; init done in microcode */
3028         if (!is_qam(state)) {
3029                 pr_err("%s: mode %d is not DVB-C\n",
3030                        __func__, state->m_operation_mode);
3031                 return -EINVAL;
3032         }
3033 
3034         /* FIXME: Analog TV AGC require different settings */
3035 
3036         /* Standard specific settings */
3037         clp_sum_min = 8;
3038         clp_dir_to = (u16) -9;
3039         clp_ctrl_mode = 0;
3040         sns_sum_min = 8;
3041         sns_dir_to = (u16) -9;
3042         ki_innergain_min = (u16) -1030;
3043         if_iaccu_hi_tgt_max = 0x2380;
3044         if_iaccu_hi_tgt = 0x2380;
3045         ingain_tgt_min = 0x0511;
3046         ingain_tgt = 0x0511;
3047         ingain_tgt_max = 5119;
3048         fast_clp_ctrl_delay = state->m_qam_if_agc_cfg.fast_clip_ctrl_delay;
3049 
3050         status = write16(state, SCU_RAM_AGC_FAST_CLP_CTRL_DELAY__A,
3051                          fast_clp_ctrl_delay);
3052         if (status < 0)
3053                 goto error;
3054 
3055         status = write16(state, SCU_RAM_AGC_CLP_CTRL_MODE__A, clp_ctrl_mode);
3056         if (status < 0)
3057                 goto error;
3058         status = write16(state, SCU_RAM_AGC_INGAIN_TGT__A, ingain_tgt);
3059         if (status < 0)
3060                 goto error;
3061         status = write16(state, SCU_RAM_AGC_INGAIN_TGT_MIN__A, ingain_tgt_min);
3062         if (status < 0)
3063                 goto error;
3064         status = write16(state, SCU_RAM_AGC_INGAIN_TGT_MAX__A, ingain_tgt_max);
3065         if (status < 0)
3066                 goto error;
3067         status = write16(state, SCU_RAM_AGC_IF_IACCU_HI_TGT_MIN__A,
3068                          if_iaccu_hi_tgt_min);
3069         if (status < 0)
3070                 goto error;
3071         status = write16(state, SCU_RAM_AGC_IF_IACCU_HI_TGT_MAX__A,
3072                          if_iaccu_hi_tgt_max);
3073         if (status < 0)
3074                 goto error;
3075         status = write16(state, SCU_RAM_AGC_IF_IACCU_HI__A, 0);
3076         if (status < 0)
3077                 goto error;
3078         status = write16(state, SCU_RAM_AGC_IF_IACCU_LO__A, 0);
3079         if (status < 0)
3080                 goto error;
3081         status = write16(state, SCU_RAM_AGC_RF_IACCU_HI__A, 0);
3082         if (status < 0)
3083                 goto error;
3084         status = write16(state, SCU_RAM_AGC_RF_IACCU_LO__A, 0);
3085         if (status < 0)
3086                 goto error;
3087         status = write16(state, SCU_RAM_AGC_CLP_SUM_MAX__A, clp_sum_max);
3088         if (status < 0)
3089                 goto error;
3090         status = write16(state, SCU_RAM_AGC_SNS_SUM_MAX__A, sns_sum_max);
3091         if (status < 0)
3092                 goto error;
3093 
3094         status = write16(state, SCU_RAM_AGC_KI_INNERGAIN_MIN__A,
3095                          ki_innergain_min);
3096         if (status < 0)
3097                 goto error;
3098         status = write16(state, SCU_RAM_AGC_IF_IACCU_HI_TGT__A,
3099                          if_iaccu_hi_tgt);
3100         if (status < 0)
3101                 goto error;
3102         status = write16(state, SCU_RAM_AGC_CLP_CYCLEN__A, clp_cyclen);
3103         if (status < 0)
3104                 goto error;
3105 
3106         status = write16(state, SCU_RAM_AGC_RF_SNS_DEV_MAX__A, 1023);
3107         if (status < 0)
3108                 goto error;
3109         status = write16(state, SCU_RAM_AGC_RF_SNS_DEV_MIN__A, (u16) -1023);
3110         if (status < 0)
3111                 goto error;
3112         status = write16(state, SCU_RAM_AGC_FAST_SNS_CTRL_DELAY__A, 50);
3113         if (status < 0)
3114                 goto error;
3115 
3116         status = write16(state, SCU_RAM_AGC_KI_MAXMINGAIN_TH__A, 20);
3117         if (status < 0)
3118                 goto error;
3119         status = write16(state, SCU_RAM_AGC_CLP_SUM_MIN__A, clp_sum_min);
3120         if (status < 0)
3121                 goto error;
3122         status = write16(state, SCU_RAM_AGC_SNS_SUM_MIN__A, sns_sum_min);
3123         if (status < 0)
3124                 goto error;
3125         status = write16(state, SCU_RAM_AGC_CLP_DIR_TO__A, clp_dir_to);
3126         if (status < 0)
3127                 goto error;
3128         status = write16(state, SCU_RAM_AGC_SNS_DIR_TO__A, sns_dir_to);
3129         if (status < 0)
3130                 goto error;
3131         status = write16(state, SCU_RAM_AGC_KI_MINGAIN__A, 0x7fff);
3132         if (status < 0)
3133                 goto error;
3134         status = write16(state, SCU_RAM_AGC_KI_MAXGAIN__A, 0x0);
3135         if (status < 0)
3136                 goto error;
3137         status = write16(state, SCU_RAM_AGC_KI_MIN__A, 0x0117);
3138         if (status < 0)
3139                 goto error;
3140         status = write16(state, SCU_RAM_AGC_KI_MAX__A, 0x0657);
3141         if (status < 0)
3142                 goto error;
3143         status = write16(state, SCU_RAM_AGC_CLP_SUM__A, 0);
3144         if (status < 0)
3145                 goto error;
3146         status = write16(state, SCU_RAM_AGC_CLP_CYCCNT__A, 0);
3147         if (status < 0)
3148                 goto error;
3149         status = write16(state, SCU_RAM_AGC_CLP_DIR_WD__A, 0);
3150         if (status < 0)
3151                 goto error;
3152         status = write16(state, SCU_RAM_AGC_CLP_DIR_STP__A, 1);
3153         if (status < 0)
3154                 goto error;
3155         status = write16(state, SCU_RAM_AGC_SNS_SUM__A, 0);
3156         if (status < 0)
3157                 goto error;
3158         status = write16(state, SCU_RAM_AGC_SNS_CYCCNT__A, 0);
3159         if (status < 0)
3160                 goto error;
3161         status = write16(state, SCU_RAM_AGC_SNS_DIR_WD__A, 0);
3162         if (status < 0)
3163                 goto error;
3164         status = write16(state, SCU_RAM_AGC_SNS_DIR_STP__A, 1);
3165         if (status < 0)
3166                 goto error;
3167         status = write16(state, SCU_RAM_AGC_SNS_CYCLEN__A, 500);
3168         if (status < 0)
3169                 goto error;
3170         status = write16(state, SCU_RAM_AGC_KI_CYCLEN__A, 500);
3171         if (status < 0)
3172                 goto error;
3173 
3174         /* Initialize inner-loop KI gain factors */
3175         status = read16(state, SCU_RAM_AGC_KI__A, &data);
3176         if (status < 0)
3177                 goto error;
3178 
3179         data = 0x0657;
3180         data &= ~SCU_RAM_AGC_KI_RF__M;
3181         data |= (DRXK_KI_RAGC_QAM << SCU_RAM_AGC_KI_RF__B);
3182         data &= ~SCU_RAM_AGC_KI_IF__M;
3183         data |= (DRXK_KI_IAGC_QAM << SCU_RAM_AGC_KI_IF__B);
3184 
3185         status = write16(state, SCU_RAM_AGC_KI__A, data);
3186 error:
3187         if (status < 0)
3188                 pr_err("Error %d on %s\n", status, __func__);
3189         return status;
3190 }
3191 
3192 static int dvbtqam_get_acc_pkt_err(struct drxk_state *state, u16 *packet_err)
3193 {
3194         int status;
3195 
3196         dprintk(1, "\n");
3197         if (packet_err == NULL)
3198                 status = write16(state, SCU_RAM_FEC_ACCUM_PKT_FAILURES__A, 0);
3199         else
3200                 status = read16(state, SCU_RAM_FEC_ACCUM_PKT_FAILURES__A,
3201                                 packet_err);
3202         if (status < 0)
3203                 pr_err("Error %d on %s\n", status, __func__);
3204         return status;
3205 }
3206 
3207 static int dvbt_sc_command(struct drxk_state *state,
3208                          u16 cmd, u16 subcmd,
3209                          u16 param0, u16 param1, u16 param2,
3210                          u16 param3, u16 param4)
3211 {
3212         u16 cur_cmd = 0;
3213         u16 err_code = 0;
3214         u16 retry_cnt = 0;
3215         u16 sc_exec = 0;
3216         int status;
3217 
3218         dprintk(1, "\n");
3219         status = read16(state, OFDM_SC_COMM_EXEC__A, &sc_exec);
3220         if (sc_exec != 1) {
3221                 /* SC is not running */
3222                 status = -EINVAL;
3223         }
3224         if (status < 0)
3225                 goto error;
3226 
3227         /* Wait until sc is ready to receive command */
3228         retry_cnt = 0;
3229         do {
3230                 usleep_range(1000, 2000);
3231                 status = read16(state, OFDM_SC_RA_RAM_CMD__A, &cur_cmd);
3232                 retry_cnt++;
3233         } while ((cur_cmd != 0) && (retry_cnt < DRXK_MAX_RETRIES));
3234         if (retry_cnt >= DRXK_MAX_RETRIES && (status < 0))
3235                 goto error;
3236 
3237         /* Write sub-command */
3238         switch (cmd) {
3239                 /* All commands using sub-cmd */
3240         case OFDM_SC_RA_RAM_CMD_PROC_START:
3241         case OFDM_SC_RA_RAM_CMD_SET_PREF_PARAM:
3242         case OFDM_SC_RA_RAM_CMD_PROGRAM_PARAM:
3243                 status = write16(state, OFDM_SC_RA_RAM_CMD_ADDR__A, subcmd);
3244                 if (status < 0)
3245                         goto error;
3246                 break;
3247         default:
3248                 /* Do nothing */
3249                 break;
3250         }
3251 
3252         /* Write needed parameters and the command */
3253         status = 0;
3254         switch (cmd) {
3255                 /* All commands using 5 parameters */
3256                 /* All commands using 4 parameters */
3257                 /* All commands using 3 parameters */
3258                 /* All commands using 2 parameters */
3259         case OFDM_SC_RA_RAM_CMD_PROC_START:
3260         case OFDM_SC_RA_RAM_CMD_SET_PREF_PARAM:
3261         case OFDM_SC_RA_RAM_CMD_PROGRAM_PARAM:
3262                 status |= write16(state, OFDM_SC_RA_RAM_PARAM1__A, param1);
3263                 /* fall through - All commands using 1 parameters */
3264         case OFDM_SC_RA_RAM_CMD_SET_ECHO_TIMING:
3265         case OFDM_SC_RA_RAM_CMD_USER_IO:
3266                 status |= write16(state, OFDM_SC_RA_RAM_PARAM0__A, param0);
3267                 /* fall through - All commands using 0 parameters */
3268         case OFDM_SC_RA_RAM_CMD_GET_OP_PARAM:
3269         case OFDM_SC_RA_RAM_CMD_NULL:
3270                 /* Write command */
3271                 status |= write16(state, OFDM_SC_RA_RAM_CMD__A, cmd);
3272                 break;
3273         default:
3274                 /* Unknown command */
3275                 status = -EINVAL;
3276         }
3277         if (status < 0)
3278                 goto error;
3279 
3280         /* Wait until sc is ready processing command */
3281         retry_cnt = 0;
3282         do {
3283                 usleep_range(1000, 2000);
3284                 status = read16(state, OFDM_SC_RA_RAM_CMD__A, &cur_cmd);
3285                 retry_cnt++;
3286         } while ((cur_cmd != 0) && (retry_cnt < DRXK_MAX_RETRIES));
3287         if (retry_cnt >= DRXK_MAX_RETRIES && (status < 0))
3288                 goto error;
3289 
3290         /* Check for illegal cmd */
3291         status = read16(state, OFDM_SC_RA_RAM_CMD_ADDR__A, &err_code);
3292         if (err_code == 0xFFFF) {
3293                 /* illegal command */
3294                 status = -EINVAL;
3295         }
3296         if (status < 0)
3297                 goto error;
3298 
3299         /* Retrieve results parameters from SC */
3300         switch (cmd) {
3301                 /* All commands yielding 5 results */
3302                 /* All commands yielding 4 results */
3303                 /* All commands yielding 3 results */
3304                 /* All commands yielding 2 results */
3305                 /* All commands yielding 1 result */
3306         case OFDM_SC_RA_RAM_CMD_USER_IO:
3307         case OFDM_SC_RA_RAM_CMD_GET_OP_PARAM:
3308                 status = read16(state, OFDM_SC_RA_RAM_PARAM0__A, &(param0));
3309                 /* All commands yielding 0 results */
3310         case OFDM_SC_RA_RAM_CMD_SET_ECHO_TIMING:
3311         case OFDM_SC_RA_RAM_CMD_SET_TIMER:
3312         case OFDM_SC_RA_RAM_CMD_PROC_START:
3313         case OFDM_SC_RA_RAM_CMD_SET_PREF_PARAM:
3314         case OFDM_SC_RA_RAM_CMD_PROGRAM_PARAM:
3315         case OFDM_SC_RA_RAM_CMD_NULL:
3316                 break;
3317         default:
3318                 /* Unknown command */
3319                 status = -EINVAL;
3320                 break;
3321         }                       /* switch (cmd->cmd) */
3322 error:
3323         if (status < 0)
3324                 pr_err("Error %d on %s\n", status, __func__);
3325         return status;
3326 }
3327 
3328 static int power_up_dvbt(struct drxk_state *state)
3329 {
3330         enum drx_power_mode power_mode = DRX_POWER_UP;
3331         int status;
3332 
3333         dprintk(1, "\n");
3334         status = ctrl_power_mode(state, &power_mode);
3335         if (status < 0)
3336                 pr_err("Error %d on %s\n", status, __func__);
3337         return status;
3338 }
3339 
3340 static int dvbt_ctrl_set_inc_enable(struct drxk_state *state, bool *enabled)
3341 {
3342         int status;
3343 
3344         dprintk(1, "\n");
3345         if (*enabled)
3346                 status = write16(state, IQM_CF_BYPASSDET__A, 0);
3347         else
3348                 status = write16(state, IQM_CF_BYPASSDET__A, 1);
3349         if (status < 0)
3350                 pr_err("Error %d on %s\n", status, __func__);
3351         return status;
3352 }
3353 
3354 #define DEFAULT_FR_THRES_8K     4000
3355 static int dvbt_ctrl_set_fr_enable(struct drxk_state *state, bool *enabled)
3356 {
3357 
3358         int status;
3359 
3360         dprintk(1, "\n");
3361         if (*enabled) {
3362                 /* write mask to 1 */
3363                 status = write16(state, OFDM_SC_RA_RAM_FR_THRES_8K__A,
3364                                    DEFAULT_FR_THRES_8K);
3365         } else {
3366                 /* write mask to 0 */
3367                 status = write16(state, OFDM_SC_RA_RAM_FR_THRES_8K__A, 0);
3368         }
3369         if (status < 0)
3370                 pr_err("Error %d on %s\n", status, __func__);
3371 
3372         return status;
3373 }
3374 
3375 static int dvbt_ctrl_set_echo_threshold(struct drxk_state *state,
3376                                 struct drxk_cfg_dvbt_echo_thres_t *echo_thres)
3377 {
3378         u16 data = 0;
3379         int status;
3380 
3381         dprintk(1, "\n");
3382         status = read16(state, OFDM_SC_RA_RAM_ECHO_THRES__A, &data);
3383         if (status < 0)
3384                 goto error;
3385 
3386         switch (echo_thres->fft_mode) {
3387         case DRX_FFTMODE_2K:
3388                 data &= ~OFDM_SC_RA_RAM_ECHO_THRES_2K__M;
3389                 data |= ((echo_thres->threshold <<
3390                         OFDM_SC_RA_RAM_ECHO_THRES_2K__B)
3391                         & (OFDM_SC_RA_RAM_ECHO_THRES_2K__M));
3392                 break;
3393         case DRX_FFTMODE_8K:
3394                 data &= ~OFDM_SC_RA_RAM_ECHO_THRES_8K__M;
3395                 data |= ((echo_thres->threshold <<
3396                         OFDM_SC_RA_RAM_ECHO_THRES_8K__B)
3397                         & (OFDM_SC_RA_RAM_ECHO_THRES_8K__M));
3398                 break;
3399         default:
3400                 return -EINVAL;
3401         }
3402 
3403         status = write16(state, OFDM_SC_RA_RAM_ECHO_THRES__A, data);
3404 error:
3405         if (status < 0)
3406                 pr_err("Error %d on %s\n", status, __func__);
3407         return status;
3408 }
3409 
3410 static int dvbt_ctrl_set_sqi_speed(struct drxk_state *state,
3411                                enum drxk_cfg_dvbt_sqi_speed *speed)
3412 {
3413         int status = -EINVAL;
3414 
3415         dprintk(1, "\n");
3416 
3417         switch (*speed) {
3418         case DRXK_DVBT_SQI_SPEED_FAST:
3419         case DRXK_DVBT_SQI_SPEED_MEDIUM:
3420         case DRXK_DVBT_SQI_SPEED_SLOW:
3421                 break;
3422         default:
3423                 goto error;
3424         }
3425         status = write16(state, SCU_RAM_FEC_PRE_RS_BER_FILTER_SH__A,
3426                            (u16) *speed);
3427 error:
3428         if (status < 0)
3429                 pr_err("Error %d on %s\n", status, __func__);
3430         return status;
3431 }
3432 
3433 /*============================================================================*/
3434 
3435 /*
3436 * \brief Activate DVBT specific presets
3437 * \param demod instance of demodulator.
3438 * \return DRXStatus_t.
3439 *
3440 * Called in DVBTSetStandard
3441 *
3442 */
3443 static int dvbt_activate_presets(struct drxk_state *state)
3444 {
3445         int status;
3446         bool setincenable = false;
3447         bool setfrenable = true;
3448 
3449         struct drxk_cfg_dvbt_echo_thres_t echo_thres2k = { 0, DRX_FFTMODE_2K };
3450         struct drxk_cfg_dvbt_echo_thres_t echo_thres8k = { 0, DRX_FFTMODE_8K };
3451 
3452         dprintk(1, "\n");
3453         status = dvbt_ctrl_set_inc_enable(state, &setincenable);
3454         if (status < 0)
3455                 goto error;
3456         status = dvbt_ctrl_set_fr_enable(state, &setfrenable);
3457         if (status < 0)
3458                 goto error;
3459         status = dvbt_ctrl_set_echo_threshold(state, &echo_thres2k);
3460         if (status < 0)
3461                 goto error;
3462         status = dvbt_ctrl_set_echo_threshold(state, &echo_thres8k);
3463         if (status < 0)
3464                 goto error;
3465         status = write16(state, SCU_RAM_AGC_INGAIN_TGT_MAX__A,
3466                          state->m_dvbt_if_agc_cfg.ingain_tgt_max);
3467 error:
3468         if (status < 0)
3469                 pr_err("Error %d on %s\n", status, __func__);
3470         return status;
3471 }
3472 
3473 /*============================================================================*/
3474 
3475 /*
3476 * \brief Initialize channelswitch-independent settings for DVBT.
3477 * \param demod instance of demodulator.
3478 * \return DRXStatus_t.
3479 *
3480 * For ROM code channel filter taps are loaded from the bootloader. For microcode
3481 * the DVB-T taps from the drxk_filters.h are used.
3482 */
3483 static int set_dvbt_standard(struct drxk_state *state,
3484                            enum operation_mode o_mode)
3485 {
3486         u16 cmd_result = 0;
3487         u16 data = 0;
3488         int status;
3489 
3490         dprintk(1, "\n");
3491 
3492         power_up_dvbt(state);
3493         /* added antenna switch */
3494         switch_antenna_to_dvbt(state);
3495         /* send OFDM reset command */
3496         status = scu_command(state,
3497                              SCU_RAM_COMMAND_STANDARD_OFDM
3498                              | SCU_RAM_COMMAND_CMD_DEMOD_RESET,
3499                              0, NULL, 1, &cmd_result);
3500         if (status < 0)
3501                 goto error;
3502 
3503         /* send OFDM setenv command */
3504         status = scu_command(state, SCU_RAM_COMMAND_STANDARD_OFDM
3505                              | SCU_RAM_COMMAND_CMD_DEMOD_SET_ENV,
3506                              0, NULL, 1, &cmd_result);
3507         if (status < 0)
3508                 goto error;
3509 
3510         /* reset datapath for OFDM, processors first */
3511         status = write16(state, OFDM_SC_COMM_EXEC__A, OFDM_SC_COMM_EXEC_STOP);
3512         if (status < 0)
3513                 goto error;
3514         status = write16(state, OFDM_LC_COMM_EXEC__A, OFDM_LC_COMM_EXEC_STOP);
3515         if (status < 0)
3516                 goto error;
3517         status = write16(state, IQM_COMM_EXEC__A, IQM_COMM_EXEC_B_STOP);
3518         if (status < 0)
3519                 goto error;
3520 
3521         /* IQM setup */
3522         /* synchronize on ofdstate->m_festart */
3523         status = write16(state, IQM_AF_UPD_SEL__A, 1);
3524         if (status < 0)
3525                 goto error;
3526         /* window size for clipping ADC detection */
3527         status = write16(state, IQM_AF_CLP_LEN__A, 0);
3528         if (status < 0)
3529                 goto error;
3530         /* window size for for sense pre-SAW detection */
3531         status = write16(state, IQM_AF_SNS_LEN__A, 0);
3532         if (status < 0)
3533                 goto error;
3534         /* sense threshold for sense pre-SAW detection */
3535         status = write16(state, IQM_AF_AMUX__A, IQM_AF_AMUX_SIGNAL2ADC);
3536         if (status < 0)
3537                 goto error;
3538         status = set_iqm_af(state, true);
3539         if (status < 0)
3540                 goto error;
3541 
3542         status = write16(state, IQM_AF_AGC_RF__A, 0);
3543         if (status < 0)
3544                 goto error;
3545 
3546         /* Impulse noise cruncher setup */
3547         status = write16(state, IQM_AF_INC_LCT__A, 0);  /* crunch in IQM_CF */
3548         if (status < 0)
3549                 goto error;
3550         status = write16(state, IQM_CF_DET_LCT__A, 0);  /* detect in IQM_CF */
3551         if (status < 0)
3552                 goto error;
3553         status = write16(state, IQM_CF_WND_LEN__A, 3);  /* peak detector window length */
3554         if (status < 0)
3555                 goto error;
3556 
3557         status = write16(state, IQM_RC_STRETCH__A, 16);
3558         if (status < 0)
3559                 goto error;
3560         status = write16(state, IQM_CF_OUT_ENA__A, 0x4); /* enable output 2 */
3561         if (status < 0)
3562                 goto error;
3563         status = write16(state, IQM_CF_DS_ENA__A, 0x4); /* decimate output 2 */
3564         if (status < 0)
3565                 goto error;
3566         status = write16(state, IQM_CF_SCALE__A, 1600);
3567         if (status < 0)
3568                 goto error;
3569         status = write16(state, IQM_CF_SCALE_SH__A, 0);
3570         if (status < 0)
3571                 goto error;
3572 
3573         /* virtual clipping threshold for clipping ADC detection */
3574         status = write16(state, IQM_AF_CLP_TH__A, 448);
3575         if (status < 0)
3576                 goto error;
3577         status = write16(state, IQM_CF_DATATH__A, 495); /* crunching threshold */
3578         if (status < 0)
3579                 goto error;
3580 
3581         status = bl_chain_cmd(state, DRXK_BL_ROM_OFFSET_TAPS_DVBT,
3582                               DRXK_BLCC_NR_ELEMENTS_TAPS, DRXK_BLC_TIMEOUT);
3583         if (status < 0)
3584                 goto error;
3585 
3586         status = write16(state, IQM_CF_PKDTH__A, 2);    /* peak detector threshold */
3587         if (status < 0)
3588                 goto error;
3589         status = write16(state, IQM_CF_POW_MEAS_LEN__A, 2);
3590         if (status < 0)
3591                 goto error;
3592         /* enable power measurement interrupt */
3593         status = write16(state, IQM_CF_COMM_INT_MSK__A, 1);
3594         if (status < 0)
3595                 goto error;
3596         status = write16(state, IQM_COMM_EXEC__A, IQM_COMM_EXEC_B_ACTIVE);
3597         if (status < 0)
3598                 goto error;
3599 
3600         /* IQM will not be reset from here, sync ADC and update/init AGC */
3601         status = adc_synchronization(state);
3602         if (status < 0)
3603                 goto error;
3604         status = set_pre_saw(state, &state->m_dvbt_pre_saw_cfg);
3605         if (status < 0)
3606                 goto error;
3607 
3608         /* Halt SCU to enable safe non-atomic accesses */
3609         status = write16(state, SCU_COMM_EXEC__A, SCU_COMM_EXEC_HOLD);
3610         if (status < 0)
3611                 goto error;
3612 
3613         status = set_agc_rf(state, &state->m_dvbt_rf_agc_cfg, true);
3614         if (status < 0)
3615                 goto error;
3616         status = set_agc_if(state, &state->m_dvbt_if_agc_cfg, true);
3617         if (status < 0)
3618                 goto error;
3619 
3620         /* Set Noise Estimation notch width and enable DC fix */
3621         status = read16(state, OFDM_SC_RA_RAM_CONFIG__A, &data);
3622         if (status < 0)
3623                 goto error;
3624         data |= OFDM_SC_RA_RAM_CONFIG_NE_FIX_ENABLE__M;
3625         status = write16(state, OFDM_SC_RA_RAM_CONFIG__A, data);
3626         if (status < 0)
3627                 goto error;
3628 
3629         /* Activate SCU to enable SCU commands */
3630         status = write16(state, SCU_COMM_EXEC__A, SCU_COMM_EXEC_ACTIVE);
3631         if (status < 0)
3632                 goto error;
3633 
3634         if (!state->m_drxk_a3_rom_code) {
3635                 /* AGCInit() is not done for DVBT, so set agcfast_clip_ctrl_delay  */
3636                 status = write16(state, SCU_RAM_AGC_FAST_CLP_CTRL_DELAY__A,
3637                                  state->m_dvbt_if_agc_cfg.fast_clip_ctrl_delay);
3638                 if (status < 0)
3639                         goto error;
3640         }
3641 
3642         /* OFDM_SC setup */
3643 #ifdef COMPILE_FOR_NONRT
3644         status = write16(state, OFDM_SC_RA_RAM_BE_OPT_DELAY__A, 1);
3645         if (status < 0)
3646                 goto error;
3647         status = write16(state, OFDM_SC_RA_RAM_BE_OPT_INIT_DELAY__A, 2);
3648         if (status < 0)
3649                 goto error;
3650 #endif
3651 
3652         /* FEC setup */
3653         status = write16(state, FEC_DI_INPUT_CTL__A, 1);        /* OFDM input */
3654         if (status < 0)
3655                 goto error;
3656 
3657 
3658 #ifdef COMPILE_FOR_NONRT
3659         status = write16(state, FEC_RS_MEASUREMENT_PERIOD__A, 0x400);
3660         if (status < 0)
3661                 goto error;
3662 #else
3663         status = write16(state, FEC_RS_MEASUREMENT_PERIOD__A, 0x1000);
3664         if (status < 0)
3665                 goto error;
3666 #endif
3667         status = write16(state, FEC_RS_MEASUREMENT_PRESCALE__A, 0x0001);
3668         if (status < 0)
3669                 goto error;
3670 
3671         /* Setup MPEG bus */
3672         status = mpegts_dto_setup(state, OM_DVBT);
3673         if (status < 0)
3674                 goto error;
3675         /* Set DVBT Presets */
3676         status = dvbt_activate_presets(state);
3677         if (status < 0)
3678                 goto error;
3679 
3680 error:
3681         if (status < 0)
3682                 pr_err("Error %d on %s\n", status, __func__);
3683         return status;
3684 }
3685 
3686 /*============================================================================*/
3687 /*
3688 * \brief start dvbt demodulating for channel.
3689 * \param demod instance of demodulator.
3690 * \return DRXStatus_t.
3691 */
3692 static int dvbt_start(struct drxk_state *state)
3693 {
3694         u16 param1;
3695         int status;
3696         /* drxk_ofdm_sc_cmd_t scCmd; */
3697 
3698         dprintk(1, "\n");
3699         /* start correct processes to get in lock */
3700         /* DRXK: OFDM_SC_RA_RAM_PROC_LOCKTRACK is no longer in mapfile! */
3701         param1 = OFDM_SC_RA_RAM_LOCKTRACK_MIN;
3702         status = dvbt_sc_command(state, OFDM_SC_RA_RAM_CMD_PROC_START, 0,
3703                                  OFDM_SC_RA_RAM_SW_EVENT_RUN_NMASK__M, param1,
3704                                  0, 0, 0);
3705         if (status < 0)
3706                 goto error;
3707         /* start FEC OC */
3708         status = mpegts_start(state);
3709         if (status < 0)
3710                 goto error;
3711         status = write16(state, FEC_COMM_EXEC__A, FEC_COMM_EXEC_ACTIVE);
3712         if (status < 0)
3713                 goto error;
3714 error:
3715         if (status < 0)
3716                 pr_err("Error %d on %s\n", status, __func__);
3717         return status;
3718 }
3719 
3720 
3721 /*============================================================================*/
3722 
3723 /*
3724 * \brief Set up dvbt demodulator for channel.
3725 * \param demod instance of demodulator.
3726 * \return DRXStatus_t.
3727 * // original DVBTSetChannel()
3728 */
3729 static int set_dvbt(struct drxk_state *state, u16 intermediate_freqk_hz,
3730                    s32 tuner_freq_offset)
3731 {
3732         u16 cmd_result = 0;
3733         u16 transmission_params = 0;
3734         u16 operation_mode = 0;
3735         u32 iqm_rc_rate_ofs = 0;
3736         u32 bandwidth = 0;
3737         u16 param1;
3738         int status;
3739 
3740         dprintk(1, "IF =%d, TFO = %d\n",
3741                 intermediate_freqk_hz, tuner_freq_offset);
3742 
3743         status = scu_command(state, SCU_RAM_COMMAND_STANDARD_OFDM
3744                             | SCU_RAM_COMMAND_CMD_DEMOD_STOP,
3745                             0, NULL, 1, &cmd_result);
3746         if (status < 0)
3747                 goto error;
3748 
3749         /* Halt SCU to enable safe non-atomic accesses */
3750         status = write16(state, SCU_COMM_EXEC__A, SCU_COMM_EXEC_HOLD);
3751         if (status < 0)
3752                 goto error;
3753 
3754         /* Stop processors */
3755         status = write16(state, OFDM_SC_COMM_EXEC__A, OFDM_SC_COMM_EXEC_STOP);
3756         if (status < 0)
3757                 goto error;
3758         status = write16(state, OFDM_LC_COMM_EXEC__A, OFDM_LC_COMM_EXEC_STOP);
3759         if (status < 0)
3760                 goto error;
3761 
3762         /* Mandatory fix, always stop CP, required to set spl offset back to
3763                 hardware default (is set to 0 by ucode during pilot detection */
3764         status = write16(state, OFDM_CP_COMM_EXEC__A, OFDM_CP_COMM_EXEC_STOP);
3765         if (status < 0)
3766                 goto error;
3767 
3768         /*== Write channel settings to device ================================*/
3769 
3770         /* mode */
3771         switch (state->props.transmission_mode) {
3772         case TRANSMISSION_MODE_AUTO:
3773         default:
3774                 operation_mode |= OFDM_SC_RA_RAM_OP_AUTO_MODE__M;
3775                 /* fall through - try first guess DRX_FFTMODE_8K */
3776         case TRANSMISSION_MODE_8K:
3777                 transmission_params |= OFDM_SC_RA_RAM_OP_PARAM_MODE_8K;
3778                 break;
3779         case TRANSMISSION_MODE_2K:
3780                 transmission_params |= OFDM_SC_RA_RAM_OP_PARAM_MODE_2K;
3781                 break;
3782         }
3783 
3784         /* guard */
3785         switch (state->props.guard_interval) {
3786         default:
3787         case GUARD_INTERVAL_AUTO:
3788                 operation_mode |= OFDM_SC_RA_RAM_OP_AUTO_GUARD__M;
3789                 /* fall through - try first guess DRX_GUARD_1DIV4 */
3790         case GUARD_INTERVAL_1_4:
3791                 transmission_params |= OFDM_SC_RA_RAM_OP_PARAM_GUARD_4;
3792                 break;
3793         case GUARD_INTERVAL_1_32:
3794                 transmission_params |= OFDM_SC_RA_RAM_OP_PARAM_GUARD_32;
3795                 break;
3796         case GUARD_INTERVAL_1_16:
3797                 transmission_params |= OFDM_SC_RA_RAM_OP_PARAM_GUARD_16;
3798                 break;
3799         case GUARD_INTERVAL_1_8:
3800                 transmission_params |= OFDM_SC_RA_RAM_OP_PARAM_GUARD_8;
3801                 break;
3802         }
3803 
3804         /* hierarchy */
3805         switch (state->props.hierarchy) {
3806         case HIERARCHY_AUTO:
3807         case HIERARCHY_NONE:
3808         default:
3809                 operation_mode |= OFDM_SC_RA_RAM_OP_AUTO_HIER__M;
3810                 /* try first guess SC_RA_RAM_OP_PARAM_HIER_NO */
3811                 /* transmission_params |= OFDM_SC_RA_RAM_OP_PARAM_HIER_NO; */
3812                 /* fall through */
3813         case HIERARCHY_1:
3814                 transmission_params |= OFDM_SC_RA_RAM_OP_PARAM_HIER_A1;
3815                 break;
3816         case HIERARCHY_2:
3817                 transmission_params |= OFDM_SC_RA_RAM_OP_PARAM_HIER_A2;
3818                 break;
3819         case HIERARCHY_4:
3820                 transmission_params |= OFDM_SC_RA_RAM_OP_PARAM_HIER_A4;
3821                 break;
3822         }
3823 
3824 
3825         /* modulation */
3826         switch (state->props.modulation) {
3827         case QAM_AUTO:
3828         default:
3829                 operation_mode |= OFDM_SC_RA_RAM_OP_AUTO_CONST__M;
3830                 /* fall through - try first guess DRX_CONSTELLATION_QAM64 */
3831         case QAM_64:
3832                 transmission_params |= OFDM_SC_RA_RAM_OP_PARAM_CONST_QAM64;
3833                 break;
3834         case QPSK:
3835                 transmission_params |= OFDM_SC_RA_RAM_OP_PARAM_CONST_QPSK;
3836                 break;
3837         case QAM_16:
3838                 transmission_params |= OFDM_SC_RA_RAM_OP_PARAM_CONST_QAM16;
3839                 break;
3840         }
3841 #if 0
3842         /* No hierarchical channels support in BDA */
3843         /* Priority (only for hierarchical channels) */
3844         switch (channel->priority) {
3845         case DRX_PRIORITY_LOW:
3846                 transmission_params |= OFDM_SC_RA_RAM_OP_PARAM_PRIO_LO;
3847                 WR16(dev_addr, OFDM_EC_SB_PRIOR__A,
3848                         OFDM_EC_SB_PRIOR_LO);
3849                 break;
3850         case DRX_PRIORITY_HIGH:
3851                 transmission_params |= OFDM_SC_RA_RAM_OP_PARAM_PRIO_HI;
3852                 WR16(dev_addr, OFDM_EC_SB_PRIOR__A,
3853                         OFDM_EC_SB_PRIOR_HI));
3854                 break;
3855         case DRX_PRIORITY_UNKNOWN:      /* fall through */
3856         default:
3857                 status = -EINVAL;
3858                 goto error;
3859         }
3860 #else
3861         /* Set Priority high */
3862         transmission_params |= OFDM_SC_RA_RAM_OP_PARAM_PRIO_HI;
3863         status = write16(state, OFDM_EC_SB_PRIOR__A, OFDM_EC_SB_PRIOR_HI);
3864         if (status < 0)
3865                 goto error;
3866 #endif
3867 
3868         /* coderate */
3869         switch (state->props.code_rate_HP) {
3870         case FEC_AUTO:
3871         default:
3872                 operation_mode |= OFDM_SC_RA_RAM_OP_AUTO_RATE__M;
3873                 /* fall through - try first guess DRX_CODERATE_2DIV3 */
3874         case FEC_2_3:
3875                 transmission_params |= OFDM_SC_RA_RAM_OP_PARAM_RATE_2_3;
3876                 break;
3877         case FEC_1_2:
3878                 transmission_params |= OFDM_SC_RA_RAM_OP_PARAM_RATE_1_2;
3879                 break;
3880         case FEC_3_4:
3881                 transmission_params |= OFDM_SC_RA_RAM_OP_PARAM_RATE_3_4;
3882                 break;
3883         case FEC_5_6:
3884                 transmission_params |= OFDM_SC_RA_RAM_OP_PARAM_RATE_5_6;
3885                 break;
3886         case FEC_7_8:
3887                 transmission_params |= OFDM_SC_RA_RAM_OP_PARAM_RATE_7_8;
3888                 break;
3889         }
3890 
3891         /*
3892          * SAW filter selection: normally not necessary, but if wanted
3893          * the application can select a SAW filter via the driver by
3894          * using UIOs
3895          */
3896 
3897         /* First determine real bandwidth (Hz) */
3898         /* Also set delay for impulse noise cruncher */
3899         /*
3900          * Also set parameters for EC_OC fix, note EC_OC_REG_TMD_HIL_MAR is
3901          * changed by SC for fix for some 8K,1/8 guard but is restored by
3902          * InitEC and ResetEC functions
3903          */
3904         switch (state->props.bandwidth_hz) {
3905         case 0:
3906                 state->props.bandwidth_hz = 8000000;
3907                 /* fall through */
3908         case 8000000:
3909                 bandwidth = DRXK_BANDWIDTH_8MHZ_IN_HZ;
3910                 status = write16(state, OFDM_SC_RA_RAM_SRMM_FIX_FACT_8K__A,
3911                                  3052);
3912                 if (status < 0)
3913                         goto error;
3914                 /* cochannel protection for PAL 8 MHz */
3915                 status = write16(state, OFDM_SC_RA_RAM_NI_INIT_8K_PER_LEFT__A,
3916                                  7);
3917                 if (status < 0)
3918                         goto error;
3919                 status = write16(state, OFDM_SC_RA_RAM_NI_INIT_8K_PER_RIGHT__A,
3920                                  7);
3921                 if (status < 0)
3922                         goto error;
3923                 status = write16(state, OFDM_SC_RA_RAM_NI_INIT_2K_PER_LEFT__A,
3924                                  7);
3925                 if (status < 0)
3926                         goto error;
3927                 status = write16(state, OFDM_SC_RA_RAM_NI_INIT_2K_PER_RIGHT__A,
3928                                  1);
3929                 if (status < 0)
3930                         goto error;
3931                 break;
3932         case 7000000:
3933                 bandwidth = DRXK_BANDWIDTH_7MHZ_IN_HZ;
3934                 status = write16(state, OFDM_SC_RA_RAM_SRMM_FIX_FACT_8K__A,
3935                                  3491);
3936                 if (status < 0)
3937                         goto error;
3938                 /* cochannel protection for PAL 7 MHz */
3939                 status = write16(state, OFDM_SC_RA_RAM_NI_INIT_8K_PER_LEFT__A,
3940                                  8);
3941                 if (status < 0)
3942                         goto error;
3943                 status = write16(state, OFDM_SC_RA_RAM_NI_INIT_8K_PER_RIGHT__A,
3944                                  8);
3945                 if (status < 0)
3946                         goto error;
3947                 status = write16(state, OFDM_SC_RA_RAM_NI_INIT_2K_PER_LEFT__A,
3948                                  4);
3949                 if (status < 0)
3950                         goto error;
3951                 status = write16(state, OFDM_SC_RA_RAM_NI_INIT_2K_PER_RIGHT__A,
3952                                  1);
3953                 if (status < 0)
3954                         goto error;
3955                 break;
3956         case 6000000:
3957                 bandwidth = DRXK_BANDWIDTH_6MHZ_IN_HZ;
3958                 status = write16(state, OFDM_SC_RA_RAM_SRMM_FIX_FACT_8K__A,
3959                                  4073);
3960                 if (status < 0)
3961                         goto error;
3962                 /* cochannel protection for NTSC 6 MHz */
3963                 status = write16(state, OFDM_SC_RA_RAM_NI_INIT_8K_PER_LEFT__A,
3964                                  19);
3965                 if (status < 0)
3966                         goto error;
3967                 status = write16(state, OFDM_SC_RA_RAM_NI_INIT_8K_PER_RIGHT__A,
3968                                  19);
3969                 if (status < 0)
3970                         goto error;
3971                 status = write16(state, OFDM_SC_RA_RAM_NI_INIT_2K_PER_LEFT__A,
3972                                  14);
3973                 if (status < 0)
3974                         goto error;
3975                 status = write16(state, OFDM_SC_RA_RAM_NI_INIT_2K_PER_RIGHT__A,
3976                                  1);
3977                 if (status < 0)
3978                         goto error;
3979                 break;
3980         default:
3981                 status = -EINVAL;
3982                 goto error;
3983         }
3984 
3985         if (iqm_rc_rate_ofs == 0) {
3986                 /* Now compute IQM_RC_RATE_OFS
3987                         (((SysFreq/BandWidth)/2)/2) -1) * 2^23)
3988                         =>
3989                         ((SysFreq / BandWidth) * (2^21)) - (2^23)
3990                         */
3991                 /* (SysFreq / BandWidth) * (2^28)  */
3992                 /*
3993                  * assert (MAX(sysClk)/MIN(bandwidth) < 16)
3994                  *      => assert(MAX(sysClk) < 16*MIN(bandwidth))
3995                  *      => assert(109714272 > 48000000) = true
3996                  * so Frac 28 can be used
3997                  */
3998                 iqm_rc_rate_ofs = Frac28a((u32)
3999                                         ((state->m_sys_clock_freq *
4000                                                 1000) / 3), bandwidth);
4001                 /* (SysFreq / BandWidth) * (2^21), rounding before truncating */
4002                 if ((iqm_rc_rate_ofs & 0x7fL) >= 0x40)
4003                         iqm_rc_rate_ofs += 0x80L;
4004                 iqm_rc_rate_ofs = iqm_rc_rate_ofs >> 7;
4005                 /* ((SysFreq / BandWidth) * (2^21)) - (2^23)  */
4006                 iqm_rc_rate_ofs = iqm_rc_rate_ofs - (1 << 23);
4007         }
4008 
4009         iqm_rc_rate_ofs &=
4010                 ((((u32) IQM_RC_RATE_OFS_HI__M) <<
4011                 IQM_RC_RATE_OFS_LO__W) | IQM_RC_RATE_OFS_LO__M);
4012         status = write32(state, IQM_RC_RATE_OFS_LO__A, iqm_rc_rate_ofs);
4013         if (status < 0)
4014                 goto error;
4015 
4016         /* Bandwidth setting done */
4017 
4018 #if 0
4019         status = dvbt_set_frequency_shift(demod, channel, tuner_offset);
4020         if (status < 0)
4021                 goto error;
4022 #endif
4023         status = set_frequency_shifter(state, intermediate_freqk_hz,
4024                                        tuner_freq_offset, true);
4025         if (status < 0)
4026                 goto error;
4027 
4028         /*== start SC, write channel settings to SC ==========================*/
4029 
4030         /* Activate SCU to enable SCU commands */
4031         status = write16(state, SCU_COMM_EXEC__A, SCU_COMM_EXEC_ACTIVE);
4032         if (status < 0)
4033                 goto error;
4034 
4035         /* Enable SC after setting all other parameters */
4036         status = write16(state, OFDM_SC_COMM_STATE__A, 0);
4037         if (status < 0)
4038                 goto error;
4039         status = write16(state, OFDM_SC_COMM_EXEC__A, 1);
4040         if (status < 0)
4041                 goto error;
4042 
4043 
4044         status = scu_command(state, SCU_RAM_COMMAND_STANDARD_OFDM
4045                              | SCU_RAM_COMMAND_CMD_DEMOD_START,
4046                              0, NULL, 1, &cmd_result);
4047         if (status < 0)
4048                 goto error;
4049 
4050         /* Write SC parameter registers, set all AUTO flags in operation mode */
4051         param1 = (OFDM_SC_RA_RAM_OP_AUTO_MODE__M |
4052                         OFDM_SC_RA_RAM_OP_AUTO_GUARD__M |
4053                         OFDM_SC_RA_RAM_OP_AUTO_CONST__M |
4054                         OFDM_SC_RA_RAM_OP_AUTO_HIER__M |
4055                         OFDM_SC_RA_RAM_OP_AUTO_RATE__M);
4056         status = dvbt_sc_command(state, OFDM_SC_RA_RAM_CMD_SET_PREF_PARAM,
4057                                 0, transmission_params, param1, 0, 0, 0);
4058         if (status < 0)
4059                 goto error;
4060 
4061         if (!state->m_drxk_a3_rom_code)
4062                 status = dvbt_ctrl_set_sqi_speed(state, &state->m_sqi_speed);
4063 error:
4064         if (status < 0)
4065                 pr_err("Error %d on %s\n", status, __func__);
4066 
4067         return status;
4068 }
4069 
4070 
4071 /*============================================================================*/
4072 
4073 /*
4074 * \brief Retrieve lock status .
4075 * \param demod    Pointer to demodulator instance.
4076 * \param lockStat Pointer to lock status structure.
4077 * \return DRXStatus_t.
4078 *
4079 */
4080 static int get_dvbt_lock_status(struct drxk_state *state, u32 *p_lock_status)
4081 {
4082         int status;
4083         const u16 mpeg_lock_mask = (OFDM_SC_RA_RAM_LOCK_MPEG__M |
4084                                     OFDM_SC_RA_RAM_LOCK_FEC__M);
4085         const u16 fec_lock_mask = (OFDM_SC_RA_RAM_LOCK_FEC__M);
4086         const u16 demod_lock_mask = OFDM_SC_RA_RAM_LOCK_DEMOD__M;
4087 
4088         u16 sc_ra_ram_lock = 0;
4089         u16 sc_comm_exec = 0;
4090 
4091         dprintk(1, "\n");
4092 
4093         *p_lock_status = NOT_LOCKED;
4094         /* driver 0.9.0 */
4095         /* Check if SC is running */
4096         status = read16(state, OFDM_SC_COMM_EXEC__A, &sc_comm_exec);
4097         if (status < 0)
4098                 goto end;
4099         if (sc_comm_exec == OFDM_SC_COMM_EXEC_STOP)
4100                 goto end;
4101 
4102         status = read16(state, OFDM_SC_RA_RAM_LOCK__A, &sc_ra_ram_lock);
4103         if (status < 0)
4104                 goto end;
4105 
4106         if ((sc_ra_ram_lock & mpeg_lock_mask) == mpeg_lock_mask)
4107                 *p_lock_status = MPEG_LOCK;
4108         else if ((sc_ra_ram_lock & fec_lock_mask) == fec_lock_mask)
4109                 *p_lock_status = FEC_LOCK;
4110         else if ((sc_ra_ram_lock & demod_lock_mask) == demod_lock_mask)
4111                 *p_lock_status = DEMOD_LOCK;
4112         else if (sc_ra_ram_lock & OFDM_SC_RA_RAM_LOCK_NODVBT__M)
4113                 *p_lock_status = NEVER_LOCK;
4114 end:
4115         if (status < 0)
4116                 pr_err("Error %d on %s\n", status, __func__);
4117 
4118         return status;
4119 }
4120 
4121 static int power_up_qam(struct drxk_state *state)
4122 {
4123         enum drx_power_mode power_mode = DRXK_POWER_DOWN_OFDM;
4124         int status;
4125 
4126         dprintk(1, "\n");
4127         status = ctrl_power_mode(state, &power_mode);
4128         if (status < 0)
4129                 pr_err("Error %d on %s\n", status, __func__);
4130 
4131         return status;
4132 }
4133 
4134 
4135 /* Power Down QAM */
4136 static int power_down_qam(struct drxk_state *state)
4137 {
4138         u16 data = 0;
4139         u16 cmd_result;
4140         int status = 0;
4141 
4142         dprintk(1, "\n");
4143         status = read16(state, SCU_COMM_EXEC__A, &data);
4144         if (status < 0)
4145                 goto error;
4146         if (data == SCU_COMM_EXEC_ACTIVE) {
4147                 /*
4148                         STOP demodulator
4149                         QAM and HW blocks
4150                         */
4151                 /* stop all comstate->m_exec */
4152                 status = write16(state, QAM_COMM_EXEC__A, QAM_COMM_EXEC_STOP);
4153                 if (status < 0)
4154                         goto error;
4155                 status = scu_command(state, SCU_RAM_COMMAND_STANDARD_QAM
4156                                      | SCU_RAM_COMMAND_CMD_DEMOD_STOP,
4157                                      0, NULL, 1, &cmd_result);
4158                 if (status < 0)
4159                         goto error;
4160         }
4161         /* powerdown AFE                   */
4162         status = set_iqm_af(state, false);
4163 
4164 error:
4165         if (status < 0)
4166                 pr_err("Error %d on %s\n", status, __func__);
4167 
4168         return status;
4169 }
4170 
4171 /*============================================================================*/
4172 
4173 /*
4174 * \brief Setup of the QAM Measurement intervals for signal quality
4175 * \param demod instance of demod.
4176 * \param modulation current modulation.
4177 * \return DRXStatus_t.
4178 *
4179 *  NOTE:
4180 *  Take into account that for certain settings the errorcounters can overflow.
4181 *  The implementation does not check this.
4182 *
4183 */
4184 static int set_qam_measurement(struct drxk_state *state,
4185                              enum e_drxk_constellation modulation,
4186                              u32 symbol_rate)
4187 {
4188         u32 fec_bits_desired = 0;       /* BER accounting period */
4189         u32 fec_rs_period_total = 0;    /* Total period */
4190         u16 fec_rs_prescale = 0;        /* ReedSolomon Measurement Prescale */
4191         u16 fec_rs_period = 0;  /* Value for corresponding I2C register */
4192         int status = 0;
4193 
4194         dprintk(1, "\n");
4195 
4196         fec_rs_prescale = 1;
4197         /* fec_bits_desired = symbol_rate [kHz] *
4198                 FrameLenght [ms] *
4199                 (modulation + 1) *
4200                 SyncLoss (== 1) *
4201                 ViterbiLoss (==1)
4202                 */
4203         switch (modulation) {
4204         case DRX_CONSTELLATION_QAM16:
4205                 fec_bits_desired = 4 * symbol_rate;
4206                 break;
4207         case DRX_CONSTELLATION_QAM32:
4208                 fec_bits_desired = 5 * symbol_rate;
4209                 break;
4210         case DRX_CONSTELLATION_QAM64:
4211                 fec_bits_desired = 6 * symbol_rate;
4212                 break;
4213         case DRX_CONSTELLATION_QAM128:
4214                 fec_bits_desired = 7 * symbol_rate;
4215                 break;
4216         case DRX_CONSTELLATION_QAM256:
4217                 fec_bits_desired = 8 * symbol_rate;
4218                 break;
4219         default:
4220                 status = -EINVAL;
4221         }
4222         if (status < 0)
4223                 goto error;
4224 
4225         fec_bits_desired /= 1000;       /* symbol_rate [Hz] -> symbol_rate [kHz] */
4226         fec_bits_desired *= 500;        /* meas. period [ms] */
4227 
4228         /* Annex A/C: bits/RsPeriod = 204 * 8 = 1632 */
4229         /* fec_rs_period_total = fec_bits_desired / 1632 */
4230         fec_rs_period_total = (fec_bits_desired / 1632UL) + 1;  /* roughly ceil */
4231 
4232         /* fec_rs_period_total =  fec_rs_prescale * fec_rs_period  */
4233         fec_rs_prescale = 1 + (u16) (fec_rs_period_total >> 16);
4234         if (fec_rs_prescale == 0) {
4235                 /* Divide by zero (though impossible) */
4236                 status = -EINVAL;
4237                 if (status < 0)
4238                         goto error;
4239         }
4240         fec_rs_period =
4241                 ((u16) fec_rs_period_total +
4242                 (fec_rs_prescale >> 1)) / fec_rs_prescale;
4243 
4244         /* write corresponding registers */
4245         status = write16(state, FEC_RS_MEASUREMENT_PERIOD__A, fec_rs_period);
4246         if (status < 0)
4247                 goto error;
4248         status = write16(state, FEC_RS_MEASUREMENT_PRESCALE__A,
4249                          fec_rs_prescale);
4250         if (status < 0)
4251                 goto error;
4252         status = write16(state, FEC_OC_SNC_FAIL_PERIOD__A, fec_rs_period);
4253 error:
4254         if (status < 0)
4255                 pr_err("Error %d on %s\n", status, __func__);
4256         return status;
4257 }
4258 
4259 static int set_qam16(struct drxk_state *state)
4260 {
4261         int status = 0;
4262 
4263         dprintk(1, "\n");
4264         /* QAM Equalizer Setup */
4265         /* Equalizer */
4266         status = write16(state, SCU_RAM_QAM_EQ_CMA_RAD0__A, 13517);
4267         if (status < 0)
4268                 goto error;
4269         status = write16(state, SCU_RAM_QAM_EQ_CMA_RAD1__A, 13517);
4270         if (status < 0)
4271                 goto error;
4272         status = write16(state, SCU_RAM_QAM_EQ_CMA_RAD2__A, 13517);
4273         if (status < 0)
4274                 goto error;
4275         status = write16(state, SCU_RAM_QAM_EQ_CMA_RAD3__A, 13517);
4276         if (status < 0)
4277                 goto error;
4278         status = write16(state, SCU_RAM_QAM_EQ_CMA_RAD4__A, 13517);
4279         if (status < 0)
4280                 goto error;
4281         status = write16(state, SCU_RAM_QAM_EQ_CMA_RAD5__A, 13517);
4282         if (status < 0)
4283                 goto error;
4284         /* Decision Feedback Equalizer */
4285         status = write16(state, QAM_DQ_QUAL_FUN0__A, 2);
4286         if (status < 0)
4287                 goto error;
4288         status = write16(state, QAM_DQ_QUAL_FUN1__A, 2);
4289         if (status < 0)
4290                 goto error;
4291         status = write16(state, QAM_DQ_QUAL_FUN2__A, 2);
4292         if (status < 0)
4293                 goto error;
4294         status = write16(state, QAM_DQ_QUAL_FUN3__A, 2);
4295         if (status < 0)
4296                 goto error;
4297         status = write16(state, QAM_DQ_QUAL_FUN4__A, 2);
4298         if (status < 0)
4299                 goto error;
4300         status = write16(state, QAM_DQ_QUAL_FUN5__A, 0);
4301         if (status < 0)
4302                 goto error;
4303 
4304         status = write16(state, QAM_SY_SYNC_HWM__A, 5);
4305         if (status < 0)
4306                 goto error;
4307         status = write16(state, QAM_SY_SYNC_AWM__A, 4);
4308         if (status < 0)
4309                 goto error;
4310         status = write16(state, QAM_SY_SYNC_LWM__A, 3);
4311         if (status < 0)
4312                 goto error;
4313 
4314         /* QAM Slicer Settings */
4315         status = write16(state, SCU_RAM_QAM_SL_SIG_POWER__A,
4316                          DRXK_QAM_SL_SIG_POWER_QAM16);
4317         if (status < 0)
4318                 goto error;
4319 
4320         /* QAM Loop Controller Coeficients */
4321         status = write16(state, SCU_RAM_QAM_LC_CA_FINE__A, 15);
4322         if (status < 0)
4323                 goto error;
4324         status = write16(state, SCU_RAM_QAM_LC_CA_COARSE__A, 40);
4325         if (status < 0)
4326                 goto error;
4327         status = write16(state, SCU_RAM_QAM_LC_EP_FINE__A, 12);
4328         if (status < 0)
4329                 goto error;
4330         status = write16(state, SCU_RAM_QAM_LC_EP_MEDIUM__A, 24);
4331         if (status < 0)
4332                 goto error;
4333         status = write16(state, SCU_RAM_QAM_LC_EP_COARSE__A, 24);
4334         if (status < 0)
4335                 goto error;
4336         status = write16(state, SCU_RAM_QAM_LC_EI_FINE__A, 12);
4337         if (status < 0)
4338                 goto error;
4339         status = write16(state, SCU_RAM_QAM_LC_EI_MEDIUM__A, 16);
4340         if (status < 0)
4341                 goto error;
4342         status = write16(state, SCU_RAM_QAM_LC_EI_COARSE__A, 16);
4343         if (status < 0)
4344                 goto error;
4345 
4346         status = write16(state, SCU_RAM_QAM_LC_CP_FINE__A, 5);
4347         if (status < 0)
4348                 goto error;
4349         status = write16(state, SCU_RAM_QAM_LC_CP_MEDIUM__A, 20);
4350         if (status < 0)
4351                 goto error;
4352         status = write16(state, SCU_RAM_QAM_LC_CP_COARSE__A, 80);
4353         if (status < 0)
4354                 goto error;
4355         status = write16(state, SCU_RAM_QAM_LC_CI_FINE__A, 5);
4356         if (status < 0)
4357                 goto error;
4358         status = write16(state, SCU_RAM_QAM_LC_CI_MEDIUM__A, 20);
4359         if (status < 0)
4360                 goto error;
4361         status = write16(state, SCU_RAM_QAM_LC_CI_COARSE__A, 50);
4362         if (status < 0)
4363                 goto error;
4364         status = write16(state, SCU_RAM_QAM_LC_CF_FINE__A, 16);
4365         if (status < 0)
4366                 goto error;
4367         status = write16(state, SCU_RAM_QAM_LC_CF_MEDIUM__A, 16);
4368         if (status < 0)
4369                 goto error;
4370         status = write16(state, SCU_RAM_QAM_LC_CF_COARSE__A, 32);
4371         if (status < 0)
4372                 goto error;
4373         status = write16(state, SCU_RAM_QAM_LC_CF1_FINE__A, 5);
4374         if (status < 0)
4375                 goto error;
4376         status = write16(state, SCU_RAM_QAM_LC_CF1_MEDIUM__A, 10);
4377         if (status < 0)
4378                 goto error;
4379         status = write16(state, SCU_RAM_QAM_LC_CF1_COARSE__A, 10);
4380         if (status < 0)
4381                 goto error;
4382 
4383 
4384         /* QAM State Machine (FSM) Thresholds */
4385 
4386         status = write16(state, SCU_RAM_QAM_FSM_RTH__A, 140);
4387         if (status < 0)
4388                 goto error;
4389         status = write16(state, SCU_RAM_QAM_FSM_FTH__A, 50);
4390         if (status < 0)
4391                 goto error;
4392         status = write16(state, SCU_RAM_QAM_FSM_CTH__A, 95);
4393         if (status < 0)
4394                 goto error;
4395         status = write16(state, SCU_RAM_QAM_FSM_PTH__A, 120);
4396         if (status < 0)
4397                 goto error;
4398         status = write16(state, SCU_RAM_QAM_FSM_QTH__A, 230);
4399         if (status < 0)
4400                 goto error;
4401         status = write16(state, SCU_RAM_QAM_FSM_MTH__A, 105);
4402         if (status < 0)
4403                 goto error;
4404 
4405         status = write16(state, SCU_RAM_QAM_FSM_RATE_LIM__A, 40);
4406         if (status < 0)
4407                 goto error;
4408         status = write16(state, SCU_RAM_QAM_FSM_COUNT_LIM__A, 4);
4409         if (status < 0)
4410                 goto error;
4411         status = write16(state, SCU_RAM_QAM_FSM_FREQ_LIM__A, 24);
4412         if (status < 0)
4413                 goto error;
4414 
4415 
4416         /* QAM FSM Tracking Parameters */
4417 
4418         status = write16(state, SCU_RAM_QAM_FSM_MEDIAN_AV_MULT__A, (u16) 16);
4419         if (status < 0)
4420                 goto error;
4421         status = write16(state, SCU_RAM_QAM_FSM_RADIUS_AV_LIMIT__A, (u16) 220);
4422         if (status < 0)
4423                 goto error;
4424         status = write16(state, SCU_RAM_QAM_FSM_LCAVG_OFFSET1__A, (u16) 25);
4425         if (status < 0)
4426                 goto error;
4427         status = write16(state, SCU_RAM_QAM_FSM_LCAVG_OFFSET2__A, (u16) 6);
4428         if (status < 0)
4429                 goto error;
4430         status = write16(state, SCU_RAM_QAM_FSM_LCAVG_OFFSET3__A, (u16) -24);
4431         if (status < 0)
4432                 goto error;
4433         status = write16(state, SCU_RAM_QAM_FSM_LCAVG_OFFSET4__A, (u16) -65);
4434         if (status < 0)
4435                 goto error;
4436         status = write16(state, SCU_RAM_QAM_FSM_LCAVG_OFFSET5__A, (u16) -127);
4437         if (status < 0)
4438                 goto error;
4439 
4440 error:
4441         if (status < 0)
4442                 pr_err("Error %d on %s\n", status, __func__);
4443         return status;
4444 }
4445 
4446 /*============================================================================*/
4447 
4448 /*
4449 * \brief QAM32 specific setup
4450 * \param demod instance of demod.
4451 * \return DRXStatus_t.
4452 */
4453 static int set_qam32(struct drxk_state *state)
4454 {
4455         int status = 0;
4456 
4457         dprintk(1, "\n");
4458 
4459         /* QAM Equalizer Setup */
4460         /* Equalizer */
4461         status = write16(state, SCU_RAM_QAM_EQ_CMA_RAD0__A, 6707);
4462         if (status < 0)
4463                 goto error;
4464         status = write16(state, SCU_RAM_QAM_EQ_CMA_RAD1__A, 6707);
4465         if (status < 0)
4466                 goto error;
4467         status = write16(state, SCU_RAM_QAM_EQ_CMA_RAD2__A, 6707);
4468         if (status < 0)
4469                 goto error;
4470         status = write16(state, SCU_RAM_QAM_EQ_CMA_RAD3__A, 6707);
4471         if (status < 0)
4472                 goto error;
4473         status = write16(state, SCU_RAM_QAM_EQ_CMA_RAD4__A, 6707);
4474         if (status < 0)
4475                 goto error;
4476         status = write16(state, SCU_RAM_QAM_EQ_CMA_RAD5__A, 6707);
4477         if (status < 0)
4478                 goto error;
4479 
4480         /* Decision Feedback Equalizer */
4481         status = write16(state, QAM_DQ_QUAL_FUN0__A, 3);
4482         if (status < 0)
4483                 goto error;
4484         status = write16(state, QAM_DQ_QUAL_FUN1__A, 3);
4485         if (status < 0)
4486                 goto error;
4487         status = write16(state, QAM_DQ_QUAL_FUN2__A, 3);
4488         if (status < 0)
4489                 goto error;
4490         status = write16(state, QAM_DQ_QUAL_FUN3__A, 3);
4491         if (status < 0)
4492                 goto error;
4493         status = write16(state, QAM_DQ_QUAL_FUN4__A, 3);
4494         if (status < 0)
4495                 goto error;
4496         status = write16(state, QAM_DQ_QUAL_FUN5__A, 0);
4497         if (status < 0)
4498                 goto error;
4499 
4500         status = write16(state, QAM_SY_SYNC_HWM__A, 6);
4501         if (status < 0)
4502                 goto error;
4503         status = write16(state, QAM_SY_SYNC_AWM__A, 5);
4504         if (status < 0)
4505                 goto error;
4506         status = write16(state, QAM_SY_SYNC_LWM__A, 3);
4507         if (status < 0)
4508                 goto error;
4509 
4510         /* QAM Slicer Settings */
4511 
4512         status = write16(state, SCU_RAM_QAM_SL_SIG_POWER__A,
4513                          DRXK_QAM_SL_SIG_POWER_QAM32);
4514         if (status < 0)
4515                 goto error;
4516 
4517 
4518         /* QAM Loop Controller Coeficients */
4519 
4520         status = write16(state, SCU_RAM_QAM_LC_CA_FINE__A, 15);
4521         if (status < 0)
4522                 goto error;
4523         status = write16(state, SCU_RAM_QAM_LC_CA_COARSE__A, 40);
4524         if (status < 0)
4525                 goto error;
4526         status = write16(state, SCU_RAM_QAM_LC_EP_FINE__A, 12);
4527         if (status < 0)
4528                 goto error;
4529         status = write16(state, SCU_RAM_QAM_LC_EP_MEDIUM__A, 24);
4530         if (status < 0)
4531                 goto error;
4532         status = write16(state, SCU_RAM_QAM_LC_EP_COARSE__A, 24);
4533         if (status < 0)
4534                 goto error;
4535         status = write16(state, SCU_RAM_QAM_LC_EI_FINE__A, 12);
4536         if (status < 0)
4537                 goto error;
4538         status = write16(state, SCU_RAM_QAM_LC_EI_MEDIUM__A, 16);
4539         if (status < 0)
4540                 goto error;
4541         status = write16(state, SCU_RAM_QAM_LC_EI_COARSE__A, 16);
4542         if (status < 0)
4543                 goto error;
4544 
4545         status = write16(state, SCU_RAM_QAM_LC_CP_FINE__A, 5);
4546         if (status < 0)
4547                 goto error;
4548         status = write16(state, SCU_RAM_QAM_LC_CP_MEDIUM__A, 20);
4549         if (status < 0)
4550                 goto error;
4551         status = write16(state, SCU_RAM_QAM_LC_CP_COARSE__A, 80);
4552         if (status < 0)
4553                 goto error;
4554         status = write16(state, SCU_RAM_QAM_LC_CI_FINE__A, 5);
4555         if (status < 0)
4556                 goto error;
4557         status = write16(state, SCU_RAM_QAM_LC_CI_MEDIUM__A, 20);
4558         if (status < 0)
4559                 goto error;
4560         status = write16(state, SCU_RAM_QAM_LC_CI_COARSE__A, 50);
4561         if (status < 0)
4562                 goto error;
4563         status = write16(state, SCU_RAM_QAM_LC_CF_FINE__A, 16);
4564         if (status < 0)
4565                 goto error;
4566         status = write16(state, SCU_RAM_QAM_LC_CF_MEDIUM__A, 16);
4567         if (status < 0)
4568                 goto error;
4569         status = write16(state, SCU_RAM_QAM_LC_CF_COARSE__A, 16);
4570         if (status < 0)
4571                 goto error;
4572         status = write16(state, SCU_RAM_QAM_LC_CF1_FINE__A, 5);
4573         if (status < 0)
4574                 goto error;
4575         status = write16(state, SCU_RAM_QAM_LC_CF1_MEDIUM__A, 10);
4576         if (status < 0)
4577                 goto error;
4578         status = write16(state, SCU_RAM_QAM_LC_CF1_COARSE__A, 0);
4579         if (status < 0)
4580                 goto error;
4581 
4582 
4583         /* QAM State Machine (FSM) Thresholds */
4584 
4585         status = write16(state, SCU_RAM_QAM_FSM_RTH__A, 90);
4586         if (status < 0)
4587                 goto error;
4588         status = write16(state, SCU_RAM_QAM_FSM_FTH__A, 50);
4589         if (status < 0)
4590                 goto error;
4591         status = write16(state, SCU_RAM_QAM_FSM_CTH__A, 80);
4592         if (status < 0)
4593                 goto error;
4594         status = write16(state, SCU_RAM_QAM_FSM_PTH__A, 100);
4595         if (status < 0)
4596                 goto error;
4597         status = write16(state, SCU_RAM_QAM_FSM_QTH__A, 170);
4598         if (status < 0)
4599                 goto error;
4600         status = write16(state, SCU_RAM_QAM_FSM_MTH__A, 100);
4601         if (status < 0)
4602                 goto error;
4603 
4604         status = write16(state, SCU_RAM_QAM_FSM_RATE_LIM__A, 40);
4605         if (status < 0)
4606                 goto error;
4607         status = write16(state, SCU_RAM_QAM_FSM_COUNT_LIM__A, 4);
4608         if (status < 0)
4609                 goto error;
4610         status = write16(state, SCU_RAM_QAM_FSM_FREQ_LIM__A, 10);
4611         if (status < 0)
4612                 goto error;
4613 
4614 
4615         /* QAM FSM Tracking Parameters */
4616 
4617         status = write16(state, SCU_RAM_QAM_FSM_MEDIAN_AV_MULT__A, (u16) 12);
4618         if (status < 0)
4619                 goto error;
4620         status = write16(state, SCU_RAM_QAM_FSM_RADIUS_AV_LIMIT__A, (u16) 140);
4621         if (status < 0)
4622                 goto error;
4623         status = write16(state, SCU_RAM_QAM_FSM_LCAVG_OFFSET1__A, (u16) -8);
4624         if (status < 0)
4625                 goto error;
4626         status = write16(state, SCU_RAM_QAM_FSM_LCAVG_OFFSET2__A, (u16) -16);
4627         if (status < 0)
4628                 goto error;
4629         status = write16(state, SCU_RAM_QAM_FSM_LCAVG_OFFSET3__A, (u16) -26);
4630         if (status < 0)
4631                 goto error;
4632         status = write16(state, SCU_RAM_QAM_FSM_LCAVG_OFFSET4__A, (u16) -56);
4633         if (status < 0)
4634                 goto error;
4635         status = write16(state, SCU_RAM_QAM_FSM_LCAVG_OFFSET5__A, (u16) -86);
4636 error:
4637         if (status < 0)
4638                 pr_err("Error %d on %s\n", status, __func__);
4639         return status;
4640 }
4641 
4642 /*============================================================================*/
4643 
4644 /*
4645 * \brief QAM64 specific setup
4646 * \param demod instance of demod.
4647 * \return DRXStatus_t.
4648 */
4649 static int set_qam64(struct drxk_state *state)
4650 {
4651         int status = 0;
4652 
4653         dprintk(1, "\n");
4654         /* QAM Equalizer Setup */
4655         /* Equalizer */
4656         status = write16(state, SCU_RAM_QAM_EQ_CMA_RAD0__A, 13336);
4657         if (status < 0)
4658                 goto error;
4659         status = write16(state, SCU_RAM_QAM_EQ_CMA_RAD1__A, 12618);
4660         if (status < 0)
4661                 goto error;
4662         status = write16(state, SCU_RAM_QAM_EQ_CMA_RAD2__A, 11988);
4663         if (status < 0)
4664                 goto error;
4665         status = write16(state, SCU_RAM_QAM_EQ_CMA_RAD3__A, 13809);
4666         if (status < 0)
4667                 goto error;
4668         status = write16(state, SCU_RAM_QAM_EQ_CMA_RAD4__A, 13809);
4669         if (status < 0)
4670                 goto error;
4671         status = write16(state, SCU_RAM_QAM_EQ_CMA_RAD5__A, 15609);
4672         if (status < 0)
4673                 goto error;
4674 
4675         /* Decision Feedback Equalizer */
4676         status = write16(state, QAM_DQ_QUAL_FUN0__A, 4);
4677         if (status < 0)
4678                 goto error;
4679         status = write16(state, QAM_DQ_QUAL_FUN1__A, 4);
4680         if (status < 0)
4681                 goto error;
4682         status = write16(state, QAM_DQ_QUAL_FUN2__A, 4);
4683         if (status < 0)
4684                 goto error;
4685         status = write16(state, QAM_DQ_QUAL_FUN3__A, 4);
4686         if (status < 0)
4687                 goto error;
4688         status = write16(state, QAM_DQ_QUAL_FUN4__A, 3);
4689         if (status < 0)
4690                 goto error;
4691         status = write16(state, QAM_DQ_QUAL_FUN5__A, 0);
4692         if (status < 0)
4693                 goto error;
4694 
4695         status = write16(state, QAM_SY_SYNC_HWM__A, 5);
4696         if (status < 0)
4697                 goto error;
4698         status = write16(state, QAM_SY_SYNC_AWM__A, 4);
4699         if (status < 0)
4700                 goto error;
4701         status = write16(state, QAM_SY_SYNC_LWM__A, 3);
4702         if (status < 0)
4703                 goto error;
4704 
4705         /* QAM Slicer Settings */
4706         status = write16(state, SCU_RAM_QAM_SL_SIG_POWER__A,
4707                          DRXK_QAM_SL_SIG_POWER_QAM64);
4708         if (status < 0)
4709                 goto error;
4710 
4711 
4712         /* QAM Loop Controller Coeficients */
4713 
4714         status = write16(state, SCU_RAM_QAM_LC_CA_FINE__A, 15);
4715         if (status < 0)
4716                 goto error;
4717         status = write16(state, SCU_RAM_QAM_LC_CA_COARSE__A, 40);
4718         if (status < 0)
4719                 goto error;
4720         status = write16(state, SCU_RAM_QAM_LC_EP_FINE__A, 12);
4721         if (status < 0)
4722                 goto error;
4723         status = write16(state, SCU_RAM_QAM_LC_EP_MEDIUM__A, 24);
4724         if (status < 0)
4725                 goto error;
4726         status = write16(state, SCU_RAM_QAM_LC_EP_COARSE__A, 24);
4727         if (status < 0)
4728                 goto error;
4729         status = write16(state, SCU_RAM_QAM_LC_EI_FINE__A, 12);
4730         if (status < 0)
4731                 goto error;
4732         status = write16(state, SCU_RAM_QAM_LC_EI_MEDIUM__A, 16);
4733         if (status < 0)
4734                 goto error;
4735         status = write16(state, SCU_RAM_QAM_LC_EI_COARSE__A, 16);
4736         if (status < 0)
4737                 goto error;
4738 
4739         status = write16(state, SCU_RAM_QAM_LC_CP_FINE__A, 5);
4740         if (status < 0)
4741                 goto error;
4742         status = write16(state, SCU_RAM_QAM_LC_CP_MEDIUM__A, 30);
4743         if (status < 0)
4744                 goto error;
4745         status = write16(state, SCU_RAM_QAM_LC_CP_COARSE__A, 100);
4746         if (status < 0)
4747                 goto error;
4748         status = write16(state, SCU_RAM_QAM_LC_CI_FINE__A, 5);
4749         if (status < 0)
4750                 goto error;
4751         status = write16(state, SCU_RAM_QAM_LC_CI_MEDIUM__A, 30);
4752         if (status < 0)
4753                 goto error;
4754         status = write16(state, SCU_RAM_QAM_LC_CI_COARSE__A, 50);
4755         if (status < 0)
4756                 goto error;
4757         status = write16(state, SCU_RAM_QAM_LC_CF_FINE__A, 16);
4758         if (status < 0)
4759                 goto error;
4760         status = write16(state, SCU_RAM_QAM_LC_CF_MEDIUM__A, 25);
4761         if (status < 0)
4762                 goto error;
4763         status = write16(state, SCU_RAM_QAM_LC_CF_COARSE__A, 48);
4764         if (status < 0)
4765                 goto error;
4766         status = write16(state, SCU_RAM_QAM_LC_CF1_FINE__A, 5);
4767         if (status < 0)
4768                 goto error;
4769         status = write16(state, SCU_RAM_QAM_LC_CF1_MEDIUM__A, 10);
4770         if (status < 0)
4771                 goto error;
4772         status = write16(state, SCU_RAM_QAM_LC_CF1_COARSE__A, 10);
4773         if (status < 0)
4774                 goto error;
4775 
4776 
4777         /* QAM State Machine (FSM) Thresholds */
4778 
4779         status = write16(state, SCU_RAM_QAM_FSM_RTH__A, 100);
4780         if (status < 0)
4781                 goto error;
4782         status = write16(state, SCU_RAM_QAM_FSM_FTH__A, 60);
4783         if (status < 0)
4784                 goto error;
4785         status = write16(state, SCU_RAM_QAM_FSM_CTH__A, 80);
4786         if (status < 0)
4787                 goto error;
4788         status = write16(state, SCU_RAM_QAM_FSM_PTH__A, 110);
4789         if (status < 0)
4790                 goto error;
4791         status = write16(state, SCU_RAM_QAM_FSM_QTH__A, 200);
4792         if (status < 0)
4793                 goto error;
4794         status = write16(state, SCU_RAM_QAM_FSM_MTH__A, 95);
4795         if (status < 0)
4796                 goto error;
4797 
4798         status = write16(state, SCU_RAM_QAM_FSM_RATE_LIM__A, 40);
4799         if (status < 0)
4800                 goto error;
4801         status = write16(state, SCU_RAM_QAM_FSM_COUNT_LIM__A, 4);
4802         if (status < 0)
4803                 goto error;
4804         status = write16(state, SCU_RAM_QAM_FSM_FREQ_LIM__A, 15);
4805         if (status < 0)
4806                 goto error;
4807 
4808 
4809         /* QAM FSM Tracking Parameters */
4810 
4811         status = write16(state, SCU_RAM_QAM_FSM_MEDIAN_AV_MULT__A, (u16) 12);
4812         if (status < 0)
4813                 goto error;
4814         status = write16(state, SCU_RAM_QAM_FSM_RADIUS_AV_LIMIT__A, (u16) 141);
4815         if (status < 0)
4816                 goto error;
4817         status = write16(state, SCU_RAM_QAM_FSM_LCAVG_OFFSET1__A, (u16) 7);
4818         if (status < 0)
4819                 goto error;
4820         status = write16(state, SCU_RAM_QAM_FSM_LCAVG_OFFSET2__A, (u16) 0);
4821         if (status < 0)
4822                 goto error;
4823         status = write16(state, SCU_RAM_QAM_FSM_LCAVG_OFFSET3__A, (u16) -15);
4824         if (status < 0)
4825                 goto error;
4826         status = write16(state, SCU_RAM_QAM_FSM_LCAVG_OFFSET4__A, (u16) -45);
4827         if (status < 0)
4828                 goto error;
4829         status = write16(state, SCU_RAM_QAM_FSM_LCAVG_OFFSET5__A, (u16) -80);
4830 error:
4831         if (status < 0)
4832                 pr_err("Error %d on %s\n", status, __func__);
4833 
4834         return status;
4835 }
4836 
4837 /*============================================================================*/
4838 
4839 /*
4840 * \brief QAM128 specific setup
4841 * \param demod: instance of demod.
4842 * \return DRXStatus_t.
4843 */
4844 static int set_qam128(struct drxk_state *state)
4845 {
4846         int status = 0;
4847 
4848         dprintk(1, "\n");
4849         /* QAM Equalizer Setup */
4850         /* Equalizer */
4851         status = write16(state, SCU_RAM_QAM_EQ_CMA_RAD0__A, 6564);
4852         if (status < 0)
4853                 goto error;
4854         status = write16(state, SCU_RAM_QAM_EQ_CMA_RAD1__A, 6598);
4855         if (status < 0)
4856                 goto error;
4857         status = write16(state, SCU_RAM_QAM_EQ_CMA_RAD2__A, 6394);
4858         if (status < 0)
4859                 goto error;
4860         status = write16(state, SCU_RAM_QAM_EQ_CMA_RAD3__A, 6409);
4861         if (status < 0)
4862                 goto error;
4863         status = write16(state, SCU_RAM_QAM_EQ_CMA_RAD4__A, 6656);
4864         if (status < 0)
4865                 goto error;
4866         status = write16(state, SCU_RAM_QAM_EQ_CMA_RAD5__A, 7238);
4867         if (status < 0)
4868                 goto error;
4869 
4870         /* Decision Feedback Equalizer */
4871         status = write16(state, QAM_DQ_QUAL_FUN0__A, 6);
4872         if (status < 0)
4873                 goto error;
4874         status = write16(state, QAM_DQ_QUAL_FUN1__A, 6);
4875         if (status < 0)
4876                 goto error;
4877         status = write16(state, QAM_DQ_QUAL_FUN2__A, 6);
4878         if (status < 0)
4879                 goto error;
4880         status = write16(state, QAM_DQ_QUAL_FUN3__A, 6);
4881         if (status < 0)
4882                 goto error;
4883         status = write16(state, QAM_DQ_QUAL_FUN4__A, 5);
4884         if (status < 0)
4885                 goto error;
4886         status = write16(state, QAM_DQ_QUAL_FUN5__A, 0);
4887         if (status < 0)
4888                 goto error;
4889 
4890         status = write16(state, QAM_SY_SYNC_HWM__A, 6);
4891         if (status < 0)
4892                 goto error;
4893         status = write16(state, QAM_SY_SYNC_AWM__A, 5);
4894         if (status < 0)
4895                 goto error;
4896         status = write16(state, QAM_SY_SYNC_LWM__A, 3);
4897         if (status < 0)
4898                 goto error;
4899 
4900 
4901         /* QAM Slicer Settings */
4902 
4903         status = write16(state, SCU_RAM_QAM_SL_SIG_POWER__A,
4904                          DRXK_QAM_SL_SIG_POWER_QAM128);
4905         if (status < 0)
4906                 goto error;
4907 
4908 
4909         /* QAM Loop Controller Coeficients */
4910 
4911         status = write16(state, SCU_RAM_QAM_LC_CA_FINE__A, 15);
4912         if (status < 0)
4913                 goto error;
4914         status = write16(state, SCU_RAM_QAM_LC_CA_COARSE__A, 40);
4915         if (status < 0)
4916                 goto error;
4917         status = write16(state, SCU_RAM_QAM_LC_EP_FINE__A, 12);
4918         if (status < 0)
4919                 goto error;
4920         status = write16(state, SCU_RAM_QAM_LC_EP_MEDIUM__A, 24);
4921         if (status < 0)
4922                 goto error;
4923         status = write16(state, SCU_RAM_QAM_LC_EP_COARSE__A, 24);
4924         if (status < 0)
4925                 goto error;
4926         status = write16(state, SCU_RAM_QAM_LC_EI_FINE__A, 12);
4927         if (status < 0)
4928                 goto error;
4929         status = write16(state, SCU_RAM_QAM_LC_EI_MEDIUM__A, 16);
4930         if (status < 0)
4931                 goto error;
4932         status = write16(state, SCU_RAM_QAM_LC_EI_COARSE__A, 16);
4933         if (status < 0)
4934                 goto error;
4935 
4936         status = write16(state, SCU_RAM_QAM_LC_CP_FINE__A, 5);
4937         if (status < 0)
4938                 goto error;
4939         status = write16(state, SCU_RAM_QAM_LC_CP_MEDIUM__A, 40);
4940         if (status < 0)
4941                 goto error;
4942         status = write16(state, SCU_RAM_QAM_LC_CP_COARSE__A, 120);
4943         if (status < 0)
4944                 goto error;
4945         status = write16(state, SCU_RAM_QAM_LC_CI_FINE__A, 5);
4946         if (status < 0)
4947                 goto error;
4948         status = write16(state, SCU_RAM_QAM_LC_CI_MEDIUM__A, 40);
4949         if (status < 0)
4950                 goto error;
4951         status = write16(state, SCU_RAM_QAM_LC_CI_COARSE__A, 60);
4952         if (status < 0)
4953                 goto error;
4954         status = write16(state, SCU_RAM_QAM_LC_CF_FINE__A, 16);
4955         if (status < 0)
4956                 goto error;
4957         status = write16(state, SCU_RAM_QAM_LC_CF_MEDIUM__A, 25);
4958         if (status < 0)
4959                 goto error;
4960         status = write16(state, SCU_RAM_QAM_LC_CF_COARSE__A, 64);
4961         if (status < 0)
4962                 goto error;
4963         status = write16(state, SCU_RAM_QAM_LC_CF1_FINE__A, 5);
4964         if (status < 0)
4965                 goto error;
4966         status = write16(state, SCU_RAM_QAM_LC_CF1_MEDIUM__A, 10);
4967         if (status < 0)
4968                 goto error;
4969         status = write16(state, SCU_RAM_QAM_LC_CF1_COARSE__A, 0);
4970         if (status < 0)
4971                 goto error;
4972 
4973 
4974         /* QAM State Machine (FSM) Thresholds */
4975 
4976         status = write16(state, SCU_RAM_QAM_FSM_RTH__A, 50);
4977         if (status < 0)
4978                 goto error;
4979         status = write16(state, SCU_RAM_QAM_FSM_FTH__A, 60);
4980         if (status < 0)
4981                 goto error;
4982         status = write16(state, SCU_RAM_QAM_FSM_CTH__A, 80);
4983         if (status < 0)
4984                 goto error;
4985         status = write16(state, SCU_RAM_QAM_FSM_PTH__A, 100);
4986         if (status < 0)
4987                 goto error;
4988         status = write16(state, SCU_RAM_QAM_FSM_QTH__A, 140);
4989         if (status < 0)
4990                 goto error;
4991         status = write16(state, SCU_RAM_QAM_FSM_MTH__A, 100);
4992         if (status < 0)
4993                 goto error;
4994 
4995         status = write16(state, SCU_RAM_QAM_FSM_RATE_LIM__A, 40);
4996         if (status < 0)
4997                 goto error;
4998         status = write16(state, SCU_RAM_QAM_FSM_COUNT_LIM__A, 5);
4999         if (status < 0)
5000                 goto error;
5001 
5002         status = write16(state, SCU_RAM_QAM_FSM_FREQ_LIM__A, 12);
5003         if (status < 0)
5004                 goto error;
5005 
5006         /* QAM FSM Tracking Parameters */
5007 
5008         status = write16(state, SCU_RAM_QAM_FSM_MEDIAN_AV_MULT__A, (u16) 8);
5009         if (status < 0)
5010                 goto error;
5011         status = write16(state, SCU_RAM_QAM_FSM_RADIUS_AV_LIMIT__A, (u16) 65);
5012         if (status < 0)
5013                 goto error;
5014         status = write16(state, SCU_RAM_QAM_FSM_LCAVG_OFFSET1__A, (u16) 5);
5015         if (status < 0)
5016                 goto error;
5017         status = write16(state, SCU_RAM_QAM_FSM_LCAVG_OFFSET2__A, (u16) 3);
5018         if (status < 0)
5019                 goto error;
5020         status = write16(state, SCU_RAM_QAM_FSM_LCAVG_OFFSET3__A, (u16) -1);
5021         if (status < 0)
5022                 goto error;
5023         status = write16(state, SCU_RAM_QAM_FSM_LCAVG_OFFSET4__A, (u16) -12);
5024         if (status < 0)
5025                 goto error;
5026         status = write16(state, SCU_RAM_QAM_FSM_LCAVG_OFFSET5__A, (u16) -23);
5027 error:
5028         if (status < 0)
5029                 pr_err("Error %d on %s\n", status, __func__);
5030 
5031         return status;
5032 }
5033 
5034 /*============================================================================*/
5035 
5036 /*
5037 * \brief QAM256 specific setup
5038 * \param demod: instance of demod.
5039 * \return DRXStatus_t.
5040 */
5041 static int set_qam256(struct drxk_state *state)
5042 {
5043         int status = 0;
5044 
5045         dprintk(1, "\n");
5046         /* QAM Equalizer Setup */
5047         /* Equalizer */
5048         status = write16(state, SCU_RAM_QAM_EQ_CMA_RAD0__A, 11502);
5049         if (status < 0)
5050                 goto error;
5051         status = write16(state, SCU_RAM_QAM_EQ_CMA_RAD1__A, 12084);
5052         if (status < 0)
5053                 goto error;
5054         status = write16(state, SCU_RAM_QAM_EQ_CMA_RAD2__A, 12543);
5055         if (status < 0)
5056                 goto error;
5057         status = write16(state, SCU_RAM_QAM_EQ_CMA_RAD3__A, 12931);
5058         if (status < 0)
5059                 goto error;
5060         status = write16(state, SCU_RAM_QAM_EQ_CMA_RAD4__A, 13629);
5061         if (status < 0)
5062                 goto error;
5063         status = write16(state, SCU_RAM_QAM_EQ_CMA_RAD5__A, 15385);
5064         if (status < 0)
5065                 goto error;
5066 
5067         /* Decision Feedback Equalizer */
5068         status = write16(state, QAM_DQ_QUAL_FUN0__A, 8);
5069         if (status < 0)
5070                 goto error;
5071         status = write16(state, QAM_DQ_QUAL_FUN1__A, 8);
5072         if (status < 0)
5073                 goto error;
5074         status = write16(state, QAM_DQ_QUAL_FUN2__A, 8);
5075         if (status < 0)
5076                 goto error;
5077         status = write16(state, QAM_DQ_QUAL_FUN3__A, 8);
5078         if (status < 0)
5079                 goto error;
5080         status = write16(state, QAM_DQ_QUAL_FUN4__A, 6);
5081         if (status < 0)
5082                 goto error;
5083         status = write16(state, QAM_DQ_QUAL_FUN5__A, 0);
5084         if (status < 0)
5085                 goto error;
5086 
5087         status = write16(state, QAM_SY_SYNC_HWM__A, 5);
5088         if (status < 0)
5089                 goto error;
5090         status = write16(state, QAM_SY_SYNC_AWM__A, 4);
5091         if (status < 0)
5092                 goto error;
5093         status = write16(state, QAM_SY_SYNC_LWM__A, 3);
5094         if (status < 0)
5095                 goto error;
5096 
5097         /* QAM Slicer Settings */
5098 
5099         status = write16(state, SCU_RAM_QAM_SL_SIG_POWER__A,
5100                          DRXK_QAM_SL_SIG_POWER_QAM256);
5101         if (status < 0)
5102                 goto error;
5103 
5104 
5105         /* QAM Loop Controller Coeficients */
5106 
5107         status = write16(state, SCU_RAM_QAM_LC_CA_FINE__A, 15);
5108         if (status < 0)
5109                 goto error;
5110         status = write16(state, SCU_RAM_QAM_LC_CA_COARSE__A, 40);
5111         if (status < 0)
5112                 goto error;
5113         status = write16(state, SCU_RAM_QAM_LC_EP_FINE__A, 12);
5114         if (status < 0)
5115                 goto error;
5116         status = write16(state, SCU_RAM_QAM_LC_EP_MEDIUM__A, 24);
5117         if (status < 0)
5118                 goto error;
5119         status = write16(state, SCU_RAM_QAM_LC_EP_COARSE__A, 24);
5120         if (status < 0)
5121                 goto error;
5122         status = write16(state, SCU_RAM_QAM_LC_EI_FINE__A, 12);
5123         if (status < 0)
5124                 goto error;
5125         status = write16(state, SCU_RAM_QAM_LC_EI_MEDIUM__A, 16);
5126         if (status < 0)
5127                 goto error;
5128         status = write16(state, SCU_RAM_QAM_LC_EI_COARSE__A, 16);
5129         if (status < 0)
5130                 goto error;
5131 
5132         status = write16(state, SCU_RAM_QAM_LC_CP_FINE__A, 5);
5133         if (status < 0)
5134                 goto error;
5135         status = write16(state, SCU_RAM_QAM_LC_CP_MEDIUM__A, 50);
5136         if (status < 0)
5137                 goto error;
5138         status = write16(state, SCU_RAM_QAM_LC_CP_COARSE__A, 250);
5139         if (status < 0)
5140                 goto error;
5141         status = write16(state, SCU_RAM_QAM_LC_CI_FINE__A, 5);
5142         if (status < 0)
5143                 goto error;
5144         status = write16(state, SCU_RAM_QAM_LC_CI_MEDIUM__A, 50);
5145         if (status < 0)
5146                 goto error;
5147         status = write16(state, SCU_RAM_QAM_LC_CI_COARSE__A, 125);
5148         if (status < 0)
5149                 goto error;
5150         status = write16(state, SCU_RAM_QAM_LC_CF_FINE__A, 16);
5151         if (status < 0)
5152                 goto error;
5153         status = write16(state, SCU_RAM_QAM_LC_CF_MEDIUM__A, 25);
5154         if (status < 0)
5155                 goto error;
5156         status = write16(state, SCU_RAM_QAM_LC_CF_COARSE__A, 48);
5157         if (status < 0)
5158                 goto error;
5159         status = write16(state, SCU_RAM_QAM_LC_CF1_FINE__A, 5);
5160         if (status < 0)
5161                 goto error;
5162         status = write16(state, SCU_RAM_QAM_LC_CF1_MEDIUM__A, 10);
5163         if (status < 0)
5164                 goto error;
5165         status = write16(state, SCU_RAM_QAM_LC_CF1_COARSE__A, 10);
5166         if (status < 0)
5167                 goto error;
5168 
5169 
5170         /* QAM State Machine (FSM) Thresholds */
5171 
5172         status = write16(state, SCU_RAM_QAM_FSM_RTH__A, 50);
5173         if (status < 0)
5174                 goto error;
5175         status = write16(state, SCU_RAM_QAM_FSM_FTH__A, 60);
5176         if (status < 0)
5177                 goto error;
5178         status = write16(state, SCU_RAM_QAM_FSM_CTH__A, 80);
5179         if (status < 0)
5180                 goto error;
5181         status = write16(state, SCU_RAM_QAM_FSM_PTH__A, 100);
5182         if (status < 0)
5183                 goto error;
5184         status = write16(state, SCU_RAM_QAM_FSM_QTH__A, 150);
5185         if (status < 0)
5186                 goto error;
5187         status = write16(state, SCU_RAM_QAM_FSM_MTH__A, 110);
5188         if (status < 0)
5189                 goto error;
5190 
5191         status = write16(state, SCU_RAM_QAM_FSM_RATE_LIM__A, 40);
5192         if (status < 0)
5193                 goto error;
5194         status = write16(state, SCU_RAM_QAM_FSM_COUNT_LIM__A, 4);
5195         if (status < 0)
5196                 goto error;
5197         status = write16(state, SCU_RAM_QAM_FSM_FREQ_LIM__A, 12);
5198         if (status < 0)
5199                 goto error;
5200 
5201 
5202         /* QAM FSM Tracking Parameters */
5203 
5204         status = write16(state, SCU_RAM_QAM_FSM_MEDIAN_AV_MULT__A, (u16) 8);
5205         if (status < 0)
5206                 goto error;
5207         status = write16(state, SCU_RAM_QAM_FSM_RADIUS_AV_LIMIT__A, (u16) 74);
5208         if (status < 0)
5209                 goto error;
5210         status = write16(state, SCU_RAM_QAM_FSM_LCAVG_OFFSET1__A, (u16) 18);
5211         if (status < 0)
5212                 goto error;
5213         status = write16(state, SCU_RAM_QAM_FSM_LCAVG_OFFSET2__A, (u16) 13);
5214         if (status < 0)
5215                 goto error;
5216         status = write16(state, SCU_RAM_QAM_FSM_LCAVG_OFFSET3__A, (u16) 7);
5217         if (status < 0)
5218                 goto error;
5219         status = write16(state, SCU_RAM_QAM_FSM_LCAVG_OFFSET4__A, (u16) 0);
5220         if (status < 0)
5221                 goto error;
5222         status = write16(state, SCU_RAM_QAM_FSM_LCAVG_OFFSET5__A, (u16) -8);
5223 error:
5224         if (status < 0)
5225                 pr_err("Error %d on %s\n", status, __func__);
5226         return status;
5227 }
5228 
5229 
5230 /*============================================================================*/
5231 /*
5232 * \brief Reset QAM block.
5233 * \param demod:   instance of demod.
5234 * \param channel: pointer to channel data.
5235 * \return DRXStatus_t.
5236 */
5237 static int qam_reset_qam(struct drxk_state *state)
5238 {
5239         int status;
5240         u16 cmd_result;
5241 
5242         dprintk(1, "\n");
5243         /* Stop QAM comstate->m_exec */
5244         status = write16(state, QAM_COMM_EXEC__A, QAM_COMM_EXEC_STOP);
5245         if (status < 0)
5246                 goto error;
5247 
5248         status = scu_command(state, SCU_RAM_COMMAND_STANDARD_QAM
5249                              | SCU_RAM_COMMAND_CMD_DEMOD_RESET,
5250                              0, NULL, 1, &cmd_result);
5251 error:
5252         if (status < 0)
5253                 pr_err("Error %d on %s\n", status, __func__);
5254         return status;
5255 }
5256 
5257 /*============================================================================*/
5258 
5259 /*
5260 * \brief Set QAM symbolrate.
5261 * \param demod:   instance of demod.
5262 * \param channel: pointer to channel data.
5263 * \return DRXStatus_t.
5264 */
5265 static int qam_set_symbolrate(struct drxk_state *state)
5266 {
5267         u32 adc_frequency = 0;
5268         u32 symb_freq = 0;
5269         u32 iqm_rc_rate = 0;
5270         u16 ratesel = 0;
5271         u32 lc_symb_rate = 0;
5272         int status;
5273 
5274         dprintk(1, "\n");
5275         /* Select & calculate correct IQM rate */
5276         adc_frequency = (state->m_sys_clock_freq * 1000) / 3;
5277         ratesel = 0;
5278         if (state->props.symbol_rate <= 1188750)
5279                 ratesel = 3;
5280         else if (state->props.symbol_rate <= 2377500)
5281                 ratesel = 2;
5282         else if (state->props.symbol_rate <= 4755000)
5283                 ratesel = 1;
5284         status = write16(state, IQM_FD_RATESEL__A, ratesel);
5285         if (status < 0)
5286                 goto error;
5287 
5288         /*
5289                 IqmRcRate = ((Fadc / (symbolrate * (4<<ratesel))) - 1) * (1<<23)
5290                 */
5291         symb_freq = state->props.symbol_rate * (1 << ratesel);
5292         if (symb_freq == 0) {
5293                 /* Divide by zero */
5294                 status = -EINVAL;
5295                 goto error;
5296         }
5297         iqm_rc_rate = (adc_frequency / symb_freq) * (1 << 21) +
5298                 (Frac28a((adc_frequency % symb_freq), symb_freq) >> 7) -
5299                 (1 << 23);
5300         status = write32(state, IQM_RC_RATE_OFS_LO__A, iqm_rc_rate);
5301         if (status < 0)
5302                 goto error;
5303         state->m_iqm_rc_rate = iqm_rc_rate;
5304         /*
5305                 LcSymbFreq = round (.125 *  symbolrate / adc_freq * (1<<15))
5306                 */
5307         symb_freq = state->props.symbol_rate;
5308         if (adc_frequency == 0) {
5309                 /* Divide by zero */
5310                 status = -EINVAL;
5311                 goto error;
5312         }
5313         lc_symb_rate = (symb_freq / adc_frequency) * (1 << 12) +
5314                 (Frac28a((symb_freq % adc_frequency), adc_frequency) >>
5315                 16);
5316         if (lc_symb_rate > 511)
5317                 lc_symb_rate = 511;
5318         status = write16(state, QAM_LC_SYMBOL_FREQ__A, (u16) lc_symb_rate);
5319 
5320 error:
5321         if (status < 0)
5322                 pr_err("Error %d on %s\n", status, __func__);
5323         return status;
5324 }
5325 
5326 /*============================================================================*/
5327 
5328 /*
5329 * \brief Get QAM lock status.
5330 * \param demod:   instance of demod.
5331 * \param channel: pointer to channel data.
5332 * \return DRXStatus_t.
5333 */
5334 
5335 static int get_qam_lock_status(struct drxk_state *state, u32 *p_lock_status)
5336 {
5337         int status;
5338         u16 result[2] = { 0, 0 };
5339 
5340         dprintk(1, "\n");
5341         *p_lock_status = NOT_LOCKED;
5342         status = scu_command(state,
5343                         SCU_RAM_COMMAND_STANDARD_QAM |
5344                         SCU_RAM_COMMAND_CMD_DEMOD_GET_LOCK, 0, NULL, 2,
5345                         result);
5346         if (status < 0)
5347                 pr_err("Error %d on %s\n", status, __func__);
5348 
5349         if (result[1] < SCU_RAM_QAM_LOCKED_LOCKED_DEMOD_LOCKED) {
5350                 /* 0x0000 NOT LOCKED */
5351         } else if (result[1] < SCU_RAM_QAM_LOCKED_LOCKED_LOCKED) {
5352                 /* 0x4000 DEMOD LOCKED */
5353                 *p_lock_status = DEMOD_LOCK;
5354         } else if (result[1] < SCU_RAM_QAM_LOCKED_LOCKED_NEVER_LOCK) {
5355                 /* 0x8000 DEMOD + FEC LOCKED (system lock) */
5356                 *p_lock_status = MPEG_LOCK;
5357         } else {
5358                 /* 0xC000 NEVER LOCKED */
5359                 /* (system will never be able to lock to the signal) */
5360                 /*
5361                  * TODO: check this, intermediate & standard specific lock
5362                  * states are not taken into account here
5363                  */
5364                 *p_lock_status = NEVER_LOCK;
5365         }
5366         return status;
5367 }
5368 
5369 #define QAM_MIRROR__M         0x03
5370 #define QAM_MIRROR_NORMAL     0x00
5371 #define QAM_MIRRORED          0x01
5372 #define QAM_MIRROR_AUTO_ON    0x02
5373 #define QAM_LOCKRANGE__M      0x10
5374 #define QAM_LOCKRANGE_NORMAL  0x10
5375 
5376 static int qam_demodulator_command(struct drxk_state *state,
5377                                  int number_of_parameters)
5378 {
5379         int status;
5380         u16 cmd_result;
5381         u16 set_param_parameters[4] = { 0, 0, 0, 0 };
5382 
5383         set_param_parameters[0] = state->m_constellation;       /* modulation     */
5384         set_param_parameters[1] = DRXK_QAM_I12_J17;     /* interleave mode   */
5385 
5386         if (number_of_parameters == 2) {
5387                 u16 set_env_parameters[1] = { 0 };
5388 
5389                 if (state->m_operation_mode == OM_QAM_ITU_C)
5390                         set_env_parameters[0] = QAM_TOP_ANNEX_C;
5391                 else
5392                         set_env_parameters[0] = QAM_TOP_ANNEX_A;
5393 
5394                 status = scu_command(state,
5395                                      SCU_RAM_COMMAND_STANDARD_QAM
5396                                      | SCU_RAM_COMMAND_CMD_DEMOD_SET_ENV,
5397                                      1, set_env_parameters, 1, &cmd_result);
5398                 if (status < 0)
5399                         goto error;
5400 
5401                 status = scu_command(state,
5402                                      SCU_RAM_COMMAND_STANDARD_QAM
5403                                      | SCU_RAM_COMMAND_CMD_DEMOD_SET_PARAM,
5404                                      number_of_parameters, set_param_parameters,
5405                                      1, &cmd_result);
5406         } else if (number_of_parameters == 4) {
5407                 if (state->m_operation_mode == OM_QAM_ITU_C)
5408                         set_param_parameters[2] = QAM_TOP_ANNEX_C;
5409                 else
5410                         set_param_parameters[2] = QAM_TOP_ANNEX_A;
5411 
5412                 set_param_parameters[3] |= (QAM_MIRROR_AUTO_ON);
5413                 /* Env parameters */
5414                 /* check for LOCKRANGE Extended */
5415                 /* set_param_parameters[3] |= QAM_LOCKRANGE_NORMAL; */
5416 
5417                 status = scu_command(state,
5418                                      SCU_RAM_COMMAND_STANDARD_QAM
5419                                      | SCU_RAM_COMMAND_CMD_DEMOD_SET_PARAM,
5420                                      number_of_parameters, set_param_parameters,
5421                                      1, &cmd_result);
5422         } else {
5423                 pr_warn("Unknown QAM demodulator parameter count %d\n",
5424                         number_of_parameters);
5425                 status = -EINVAL;
5426         }
5427 
5428 error:
5429         if (status < 0)
5430                 pr_warn("Warning %d on %s\n", status, __func__);
5431         return status;
5432 }
5433 
5434 static int set_qam(struct drxk_state *state, u16 intermediate_freqk_hz,
5435                   s32 tuner_freq_offset)
5436 {
5437         int status;
5438         u16 cmd_result;
5439         int qam_demod_param_count = state->qam_demod_parameter_count;
5440 
5441         dprintk(1, "\n");
5442         /*
5443          * STEP 1: reset demodulator
5444          *      resets FEC DI and FEC RS
5445          *      resets QAM block
5446          *      resets SCU variables
5447          */
5448         status = write16(state, FEC_DI_COMM_EXEC__A, FEC_DI_COMM_EXEC_STOP);
5449         if (status < 0)
5450                 goto error;
5451         status = write16(state, FEC_RS_COMM_EXEC__A, FEC_RS_COMM_EXEC_STOP);
5452         if (status < 0)
5453                 goto error;
5454         status = qam_reset_qam(state);
5455         if (status < 0)
5456                 goto error;
5457 
5458         /*
5459          * STEP 2: configure demodulator
5460          *      -set params; resets IQM,QAM,FEC HW; initializes some
5461          *       SCU variables
5462          */
5463         status = qam_set_symbolrate(state);
5464         if (status < 0)
5465                 goto error;
5466 
5467         /* Set params */
5468         switch (state->props.modulation) {
5469         case QAM_256:
5470                 state->m_constellation = DRX_CONSTELLATION_QAM256;
5471                 break;
5472         case QAM_AUTO:
5473         case QAM_64:
5474                 state->m_constellation = DRX_CONSTELLATION_QAM64;
5475                 break;
5476         case QAM_16:
5477                 state->m_constellation = DRX_CONSTELLATION_QAM16;
5478                 break;
5479         case QAM_32:
5480                 state->m_constellation = DRX_CONSTELLATION_QAM32;
5481                 break;
5482         case QAM_128:
5483                 state->m_constellation = DRX_CONSTELLATION_QAM128;
5484                 break;
5485         default:
5486                 status = -EINVAL;
5487                 break;
5488         }
5489         if (status < 0)
5490                 goto error;
5491 
5492         /* Use the 4-parameter if it's requested or we're probing for
5493          * the correct command. */
5494         if (state->qam_demod_parameter_count == 4
5495                 || !state->qam_demod_parameter_count) {
5496                 qam_demod_param_count = 4;
5497                 status = qam_demodulator_command(state, qam_demod_param_count);
5498         }
5499 
5500         /* Use the 2-parameter command if it was requested or if we're
5501          * probing for the correct command and the 4-parameter command
5502          * failed. */
5503         if (state->qam_demod_parameter_count == 2
5504                 || (!state->qam_demod_parameter_count && status < 0)) {
5505                 qam_demod_param_count = 2;
5506                 status = qam_demodulator_command(state, qam_demod_param_count);
5507         }
5508 
5509         if (status < 0) {
5510                 dprintk(1, "Could not set demodulator parameters.\n");
5511                 dprintk(1,
5512                         "Make sure qam_demod_parameter_count (%d) is correct for your firmware (%s).\n",
5513                         state->qam_demod_parameter_count,
5514                         state->microcode_name);
5515                 goto error;
5516         } else if (!state->qam_demod_parameter_count) {
5517                 dprintk(1,
5518                         "Auto-probing the QAM command parameters was successful - using %d parameters.\n",
5519                         qam_demod_param_count);
5520 
5521                 /*
5522                  * One of our commands was successful. We don't need to
5523                  * auto-probe anymore, now that we got the correct command.
5524                  */
5525                 state->qam_demod_parameter_count = qam_demod_param_count;
5526         }
5527 
5528         /*
5529          * STEP 3: enable the system in a mode where the ADC provides valid
5530          * signal setup modulation independent registers
5531          */
5532 #if 0
5533         status = set_frequency(channel, tuner_freq_offset));
5534         if (status < 0)
5535                 goto error;
5536 #endif
5537         status = set_frequency_shifter(state, intermediate_freqk_hz,
5538                                        tuner_freq_offset, true);
5539         if (status < 0)
5540                 goto error;
5541 
5542         /* Setup BER measurement */
5543         status = set_qam_measurement(state, state->m_constellation,
5544                                      state->props.symbol_rate);
5545         if (status < 0)
5546                 goto error;
5547 
5548         /* Reset default values */
5549         status = write16(state, IQM_CF_SCALE_SH__A, IQM_CF_SCALE_SH__PRE);
5550         if (status < 0)
5551                 goto error;
5552         status = write16(state, QAM_SY_TIMEOUT__A, QAM_SY_TIMEOUT__PRE);
5553         if (status < 0)
5554                 goto error;
5555 
5556         /* Reset default LC values */
5557         status = write16(state, QAM_LC_RATE_LIMIT__A, 3);
5558         if (status < 0)
5559                 goto error;
5560         status = write16(state, QAM_LC_LPF_FACTORP__A, 4);
5561         if (status < 0)
5562                 goto error;
5563         status = write16(state, QAM_LC_LPF_FACTORI__A, 4);
5564         if (status < 0)
5565                 goto error;
5566         status = write16(state, QAM_LC_MODE__A, 7);
5567         if (status < 0)
5568                 goto error;
5569 
5570         status = write16(state, QAM_LC_QUAL_TAB0__A, 1);
5571         if (status < 0)
5572                 goto error;
5573         status = write16(state, QAM_LC_QUAL_TAB1__A, 1);
5574         if (status < 0)
5575                 goto error;
5576         status = write16(state, QAM_LC_QUAL_TAB2__A, 1);
5577         if (status < 0)
5578                 goto error;
5579         status = write16(state, QAM_LC_QUAL_TAB3__A, 1);
5580         if (status < 0)
5581                 goto error;
5582         status = write16(state, QAM_LC_QUAL_TAB4__A, 2);
5583         if (status < 0)
5584                 goto error;
5585         status = write16(state, QAM_LC_QUAL_TAB5__A, 2);
5586         if (status < 0)
5587                 goto error;
5588         status = write16(state, QAM_LC_QUAL_TAB6__A, 2);
5589         if (status < 0)
5590                 goto error;
5591         status = write16(state, QAM_LC_QUAL_TAB8__A, 2);
5592         if (status < 0)
5593                 goto error;
5594         status = write16(state, QAM_LC_QUAL_TAB9__A, 2);
5595         if (status < 0)
5596                 goto error;
5597         status = write16(state, QAM_LC_QUAL_TAB10__A, 2);
5598         if (status < 0)
5599                 goto error;
5600         status = write16(state, QAM_LC_QUAL_TAB12__A, 2);
5601         if (status < 0)
5602                 goto error;
5603         status = write16(state, QAM_LC_QUAL_TAB15__A, 3);
5604         if (status < 0)
5605                 goto error;
5606         status = write16(state, QAM_LC_QUAL_TAB16__A, 3);
5607         if (status < 0)
5608                 goto error;
5609         status = write16(state, QAM_LC_QUAL_TAB20__A, 4);
5610         if (status < 0)
5611                 goto error;
5612         status = write16(state, QAM_LC_QUAL_TAB25__A, 4);
5613         if (status < 0)
5614                 goto error;
5615 
5616         /* Mirroring, QAM-block starting point not inverted */
5617         status = write16(state, QAM_SY_SP_INV__A,
5618                          QAM_SY_SP_INV_SPECTRUM_INV_DIS);
5619         if (status < 0)
5620                 goto error;
5621 
5622         /* Halt SCU to enable safe non-atomic accesses */
5623         status = write16(state, SCU_COMM_EXEC__A, SCU_COMM_EXEC_HOLD);
5624         if (status < 0)
5625                 goto error;
5626 
5627         /* STEP 4: modulation specific setup */
5628         switch (state->props.modulation) {
5629         case QAM_16:
5630                 status = set_qam16(state);
5631                 break;
5632         case QAM_32:
5633                 status = set_qam32(state);
5634                 break;
5635         case QAM_AUTO:
5636         case QAM_64:
5637                 status = set_qam64(state);
5638                 break;
5639         case QAM_128:
5640                 status = set_qam128(state);
5641                 break;
5642         case QAM_256:
5643                 status = set_qam256(state);
5644                 break;
5645         default:
5646                 status = -EINVAL;
5647                 break;
5648         }
5649         if (status < 0)
5650                 goto error;
5651 
5652         /* Activate SCU to enable SCU commands */
5653         status = write16(state, SCU_COMM_EXEC__A, SCU_COMM_EXEC_ACTIVE);
5654         if (status < 0)
5655                 goto error;
5656 
5657         /* Re-configure MPEG output, requires knowledge of channel bitrate */
5658         /* extAttr->currentChannel.modulation = channel->modulation; */
5659         /* extAttr->currentChannel.symbolrate    = channel->symbolrate; */
5660         status = mpegts_dto_setup(state, state->m_operation_mode);
5661         if (status < 0)
5662                 goto error;
5663 
5664         /* start processes */
5665         status = mpegts_start(state);
5666         if (status < 0)
5667                 goto error;
5668         status = write16(state, FEC_COMM_EXEC__A, FEC_COMM_EXEC_ACTIVE);
5669         if (status < 0)
5670                 goto error;
5671         status = write16(state, QAM_COMM_EXEC__A, QAM_COMM_EXEC_ACTIVE);
5672         if (status < 0)
5673                 goto error;
5674         status = write16(state, IQM_COMM_EXEC__A, IQM_COMM_EXEC_B_ACTIVE);
5675         if (status < 0)
5676                 goto error;
5677 
5678         /* STEP 5: start QAM demodulator (starts FEC, QAM and IQM HW) */
5679         status = scu_command(state, SCU_RAM_COMMAND_STANDARD_QAM
5680                              | SCU_RAM_COMMAND_CMD_DEMOD_START,
5681                              0, NULL, 1, &cmd_result);
5682         if (status < 0)
5683                 goto error;
5684 
5685         /* update global DRXK data container */
5686 /*?     extAttr->qamInterleaveMode = DRXK_QAM_I12_J17; */
5687 
5688 error:
5689         if (status < 0)
5690                 pr_err("Error %d on %s\n", status, __func__);
5691         return status;
5692 }
5693 
5694 static int set_qam_standard(struct drxk_state *state,
5695                           enum operation_mode o_mode)
5696 {
5697         int status;
5698 #ifdef DRXK_QAM_TAPS
5699 #define DRXK_QAMA_TAPS_SELECT
5700 #include "drxk_filters.h"
5701 #undef DRXK_QAMA_TAPS_SELECT
5702 #endif
5703 
5704         dprintk(1, "\n");
5705 
5706         /* added antenna switch */
5707         switch_antenna_to_qam(state);
5708 
5709         /* Ensure correct power-up mode */
5710         status = power_up_qam(state);
5711         if (status < 0)
5712                 goto error;
5713         /* Reset QAM block */
5714         status = qam_reset_qam(state);
5715         if (status < 0)
5716                 goto error;
5717 
5718         /* Setup IQM */
5719 
5720         status = write16(state, IQM_COMM_EXEC__A, IQM_COMM_EXEC_B_STOP);
5721         if (status < 0)
5722                 goto error;
5723         status = write16(state, IQM_AF_AMUX__A, IQM_AF_AMUX_SIGNAL2ADC);
5724         if (status < 0)
5725                 goto error;
5726 
5727         /* Upload IQM Channel Filter settings by
5728                 boot loader from ROM table */
5729         switch (o_mode) {
5730         case OM_QAM_ITU_A:
5731                 status = bl_chain_cmd(state, DRXK_BL_ROM_OFFSET_TAPS_ITU_A,
5732                                       DRXK_BLCC_NR_ELEMENTS_TAPS,
5733                         DRXK_BLC_TIMEOUT);
5734                 break;
5735         case OM_QAM_ITU_C:
5736                 status = bl_direct_cmd(state, IQM_CF_TAP_RE0__A,
5737                                        DRXK_BL_ROM_OFFSET_TAPS_ITU_C,
5738                                        DRXK_BLDC_NR_ELEMENTS_TAPS,
5739                                        DRXK_BLC_TIMEOUT);
5740                 if (status < 0)
5741                         goto error;
5742                 status = bl_direct_cmd(state,
5743                                        IQM_CF_TAP_IM0__A,
5744                                        DRXK_BL_ROM_OFFSET_TAPS_ITU_C,
5745                                        DRXK_BLDC_NR_ELEMENTS_TAPS,
5746                                        DRXK_BLC_TIMEOUT);
5747                 break;
5748         default:
5749                 status = -EINVAL;
5750         }
5751         if (status < 0)
5752                 goto error;
5753 
5754         status = write16(state, IQM_CF_OUT_ENA__A, 1 << IQM_CF_OUT_ENA_QAM__B);
5755         if (status < 0)
5756                 goto error;
5757         status = write16(state, IQM_CF_SYMMETRIC__A, 0);
5758         if (status < 0)
5759                 goto error;
5760         status = write16(state, IQM_CF_MIDTAP__A,
5761                      ((1 << IQM_CF_MIDTAP_RE__B) | (1 << IQM_CF_MIDTAP_IM__B)));
5762         if (status < 0)
5763                 goto error;
5764 
5765         status = write16(state, IQM_RC_STRETCH__A, 21);
5766         if (status < 0)
5767                 goto error;
5768         status = write16(state, IQM_AF_CLP_LEN__A, 0);
5769         if (status < 0)
5770                 goto error;
5771         status = write16(state, IQM_AF_CLP_TH__A, 448);
5772         if (status < 0)
5773                 goto error;
5774         status = write16(state, IQM_AF_SNS_LEN__A, 0);
5775         if (status < 0)
5776                 goto error;
5777         status = write16(state, IQM_CF_POW_MEAS_LEN__A, 0);
5778         if (status < 0)
5779                 goto error;
5780 
5781         status = write16(state, IQM_FS_ADJ_SEL__A, 1);
5782         if (status < 0)
5783                 goto error;
5784         status = write16(state, IQM_RC_ADJ_SEL__A, 1);
5785         if (status < 0)
5786                 goto error;
5787         status = write16(state, IQM_CF_ADJ_SEL__A, 1);
5788         if (status < 0)
5789                 goto error;
5790         status = write16(state, IQM_AF_UPD_SEL__A, 0);
5791         if (status < 0)
5792                 goto error;
5793 
5794         /* IQM Impulse Noise Processing Unit */
5795         status = write16(state, IQM_CF_CLP_VAL__A, 500);
5796         if (status < 0)
5797                 goto error;
5798         status = write16(state, IQM_CF_DATATH__A, 1000);
5799         if (status < 0)
5800                 goto error;
5801         status = write16(state, IQM_CF_BYPASSDET__A, 1);
5802         if (status < 0)
5803                 goto error;
5804         status = write16(state, IQM_CF_DET_LCT__A, 0);
5805         if (status < 0)
5806                 goto error;
5807         status = write16(state, IQM_CF_WND_LEN__A, 1);
5808         if (status < 0)
5809                 goto error;
5810         status = write16(state, IQM_CF_PKDTH__A, 1);
5811         if (status < 0)
5812                 goto error;
5813         status = write16(state, IQM_AF_INC_BYPASS__A, 1);
5814         if (status < 0)
5815                 goto error;
5816 
5817         /* turn on IQMAF. Must be done before setAgc**() */
5818         status = set_iqm_af(state, true);
5819         if (status < 0)
5820                 goto error;
5821         status = write16(state, IQM_AF_START_LOCK__A, 0x01);
5822         if (status < 0)
5823                 goto error;
5824 
5825         /* IQM will not be reset from here, sync ADC and update/init AGC */
5826         status = adc_synchronization(state);
5827         if (status < 0)
5828                 goto error;
5829 
5830         /* Set the FSM step period */
5831         status = write16(state, SCU_RAM_QAM_FSM_STEP_PERIOD__A, 2000);
5832         if (status < 0)
5833                 goto error;
5834 
5835         /* Halt SCU to enable safe non-atomic accesses */
5836         status = write16(state, SCU_COMM_EXEC__A, SCU_COMM_EXEC_HOLD);
5837         if (status < 0)
5838                 goto error;
5839 
5840         /* No more resets of the IQM, current standard correctly set =>
5841                 now AGCs can be configured. */
5842 
5843         status = init_agc(state, true);
5844         if (status < 0)
5845                 goto error;
5846         status = set_pre_saw(state, &(state->m_qam_pre_saw_cfg));
5847         if (status < 0)
5848                 goto error;
5849 
5850         /* Configure AGC's */
5851         status = set_agc_rf(state, &(state->m_qam_rf_agc_cfg), true);
5852         if (status < 0)
5853                 goto error;
5854         status = set_agc_if(state, &(state->m_qam_if_agc_cfg), true);
5855         if (status < 0)
5856                 goto error;
5857 
5858         /* Activate SCU to enable SCU commands */
5859         status = write16(state, SCU_COMM_EXEC__A, SCU_COMM_EXEC_ACTIVE);
5860 error:
5861         if (status < 0)
5862                 pr_err("Error %d on %s\n", status, __func__);
5863         return status;
5864 }
5865 
5866 static int write_gpio(struct drxk_state *state)
5867 {
5868         int status;
5869         u16 value = 0;
5870 
5871         dprintk(1, "\n");
5872         /* stop lock indicator process */
5873         status = write16(state, SCU_RAM_GPIO__A,
5874                          SCU_RAM_GPIO_HW_LOCK_IND_DISABLE);
5875         if (status < 0)
5876                 goto error;
5877 
5878         /*  Write magic word to enable pdr reg write               */
5879         status = write16(state, SIO_TOP_COMM_KEY__A, SIO_TOP_COMM_KEY_KEY);
5880         if (status < 0)
5881                 goto error;
5882 
5883         if (state->m_has_sawsw) {
5884                 if (state->uio_mask & 0x0001) { /* UIO-1 */
5885                         /* write to io pad configuration register - output mode */
5886                         status = write16(state, SIO_PDR_SMA_TX_CFG__A,
5887                                          state->m_gpio_cfg);
5888                         if (status < 0)
5889                                 goto error;
5890 
5891                         /* use corresponding bit in io data output registar */
5892                         status = read16(state, SIO_PDR_UIO_OUT_LO__A, &value);
5893                         if (status < 0)
5894                                 goto error;
5895                         if ((state->m_gpio & 0x0001) == 0)
5896                                 value &= 0x7FFF;        /* write zero to 15th bit - 1st UIO */
5897                         else
5898                                 value |= 0x8000;        /* write one to 15th bit - 1st UIO */
5899                         /* write back to io data output register */
5900                         status = write16(state, SIO_PDR_UIO_OUT_LO__A, value);
5901                         if (status < 0)
5902                                 goto error;
5903                 }
5904                 if (state->uio_mask & 0x0002) { /* UIO-2 */
5905                         /* write to io pad configuration register - output mode */
5906                         status = write16(state, SIO_PDR_SMA_RX_CFG__A,
5907                                          state->m_gpio_cfg);
5908                         if (status < 0)
5909                                 goto error;
5910 
5911                         /* use corresponding bit in io data output registar */
5912                         status = read16(state, SIO_PDR_UIO_OUT_LO__A, &value);
5913                         if (status < 0)
5914                                 goto error;
5915                         if ((state->m_gpio & 0x0002) == 0)
5916                                 value &= 0xBFFF;        /* write zero to 14th bit - 2st UIO */
5917                         else
5918                                 value |= 0x4000;        /* write one to 14th bit - 2st UIO */
5919                         /* write back to io data output register */
5920                         status = write16(state, SIO_PDR_UIO_OUT_LO__A, value);
5921                         if (status < 0)
5922                                 goto error;
5923                 }
5924                 if (state->uio_mask & 0x0004) { /* UIO-3 */
5925                         /* write to io pad configuration register - output mode */
5926                         status = write16(state, SIO_PDR_GPIO_CFG__A,
5927                                          state->m_gpio_cfg);
5928                         if (status < 0)
5929                                 goto error;
5930 
5931                         /* use corresponding bit in io data output registar */
5932                         status = read16(state, SIO_PDR_UIO_OUT_LO__A, &value);
5933                         if (status < 0)
5934                                 goto error;
5935                         if ((state->m_gpio & 0x0004) == 0)
5936                                 value &= 0xFFFB;            /* write zero to 2nd bit - 3rd UIO */
5937                         else
5938                                 value |= 0x0004;            /* write one to 2nd bit - 3rd UIO */
5939                         /* write back to io data output register */
5940                         status = write16(state, SIO_PDR_UIO_OUT_LO__A, value);
5941                         if (status < 0)
5942                                 goto error;
5943                 }
5944         }
5945         /*  Write magic word to disable pdr reg write               */
5946         status = write16(state, SIO_TOP_COMM_KEY__A, 0x0000);
5947 error:
5948         if (status < 0)
5949                 pr_err("Error %d on %s\n", status, __func__);
5950         return status;
5951 }
5952 
5953 static int switch_antenna_to_qam(struct drxk_state *state)
5954 {
5955         int status = 0;
5956         bool gpio_state;
5957 
5958         dprintk(1, "\n");
5959 
5960         if (!state->antenna_gpio)
5961                 return 0;
5962 
5963         gpio_state = state->m_gpio & state->antenna_gpio;
5964 
5965         if (state->antenna_dvbt ^ gpio_state) {
5966                 /* Antenna is on DVB-T mode. Switch */
5967                 if (state->antenna_dvbt)
5968                         state->m_gpio &= ~state->antenna_gpio;
5969                 else
5970                         state->m_gpio |= state->antenna_gpio;
5971                 status = write_gpio(state);
5972         }
5973         if (status < 0)
5974                 pr_err("Error %d on %s\n", status, __func__);
5975         return status;
5976 }
5977 
5978 static int switch_antenna_to_dvbt(struct drxk_state *state)
5979 {
5980         int status = 0;
5981         bool gpio_state;
5982 
5983         dprintk(1, "\n");
5984 
5985         if (!state->antenna_gpio)
5986                 return 0;
5987 
5988         gpio_state = state->m_gpio & state->antenna_gpio;
5989 
5990         if (!(state->antenna_dvbt ^ gpio_state)) {
5991                 /* Antenna is on DVB-C mode. Switch */
5992                 if (state->antenna_dvbt)
5993                         state->m_gpio |= state->antenna_gpio;
5994                 else
5995                         state->m_gpio &= ~state->antenna_gpio;
5996                 status = write_gpio(state);
5997         }
5998         if (status < 0)
5999                 pr_err("Error %d on %s\n", status, __func__);
6000         return status;
6001 }
6002 
6003 
6004 static int power_down_device(struct drxk_state *state)
6005 {
6006         /* Power down to requested mode */
6007         /* Backup some register settings */
6008         /* Set pins with possible pull-ups connected to them in input mode */
6009         /* Analog power down */
6010         /* ADC power down */
6011         /* Power down device */
6012         int status;
6013 
6014         dprintk(1, "\n");
6015         if (state->m_b_p_down_open_bridge) {
6016                 /* Open I2C bridge before power down of DRXK */
6017                 status = ConfigureI2CBridge(state, true);
6018                 if (status < 0)
6019                         goto error;
6020         }
6021         /* driver 0.9.0 */
6022         status = dvbt_enable_ofdm_token_ring(state, false);
6023         if (status < 0)
6024                 goto error;
6025 
6026         status = write16(state, SIO_CC_PWD_MODE__A,
6027                          SIO_CC_PWD_MODE_LEVEL_CLOCK);
6028         if (status < 0)
6029                 goto error;
6030         status = write16(state, SIO_CC_UPDATE__A, SIO_CC_UPDATE_KEY);
6031         if (status < 0)
6032                 goto error;
6033         state->m_hi_cfg_ctrl |= SIO_HI_RA_RAM_PAR_5_CFG_SLEEP_ZZZ;
6034         status = hi_cfg_command(state);
6035 error:
6036         if (status < 0)
6037                 pr_err("Error %d on %s\n", status, __func__);
6038 
6039         return status;
6040 }
6041 
6042 static int init_drxk(struct drxk_state *state)
6043 {
6044         int status = 0, n = 0;
6045         enum drx_power_mode power_mode = DRXK_POWER_DOWN_OFDM;
6046         u16 driver_version;
6047 
6048         dprintk(1, "\n");
6049         if (state->m_drxk_state == DRXK_UNINITIALIZED) {
6050                 drxk_i2c_lock(state);
6051                 status = power_up_device(state);
6052                 if (status < 0)
6053                         goto error;
6054                 status = drxx_open(state);
6055                 if (status < 0)
6056                         goto error;
6057                 /* Soft reset of OFDM-, sys- and osc-clockdomain */
6058                 status = write16(state, SIO_CC_SOFT_RST__A,
6059                                  SIO_CC_SOFT_RST_OFDM__M
6060                                  | SIO_CC_SOFT_RST_SYS__M
6061                                  | SIO_CC_SOFT_RST_OSC__M);
6062                 if (status < 0)
6063                         goto error;
6064                 status = write16(state, SIO_CC_UPDATE__A, SIO_CC_UPDATE_KEY);
6065                 if (status < 0)
6066                         goto error;
6067                 /*
6068                  * TODO is this needed? If yes, how much delay in
6069                  * worst case scenario
6070                  */
6071                 usleep_range(1000, 2000);
6072                 state->m_drxk_a3_patch_code = true;
6073                 status = get_device_capabilities(state);
6074                 if (status < 0)
6075                         goto error;
6076 
6077                 /* Bridge delay, uses oscilator clock */
6078                 /* Delay = (delay (nano seconds) * oscclk (kHz))/ 1000 */
6079                 /* SDA brdige delay */
6080                 state->m_hi_cfg_bridge_delay =
6081                         (u16) ((state->m_osc_clock_freq / 1000) *
6082                                 HI_I2C_BRIDGE_DELAY) / 1000;
6083                 /* Clipping */
6084                 if (state->m_hi_cfg_bridge_delay >
6085                         SIO_HI_RA_RAM_PAR_3_CFG_DBL_SDA__M) {
6086                         state->m_hi_cfg_bridge_delay =
6087                                 SIO_HI_RA_RAM_PAR_3_CFG_DBL_SDA__M;
6088                 }
6089                 /* SCL bridge delay, same as SDA for now */
6090                 state->m_hi_cfg_bridge_delay +=
6091                         state->m_hi_cfg_bridge_delay <<
6092                         SIO_HI_RA_RAM_PAR_3_CFG_DBL_SCL__B;
6093 
6094                 status = init_hi(state);
6095                 if (status < 0)
6096                         goto error;
6097                 /* disable various processes */
6098 #if NOA1ROM
6099                 if (!(state->m_DRXK_A1_ROM_CODE)
6100                         && !(state->m_DRXK_A2_ROM_CODE))
6101 #endif
6102                 {
6103                         status = write16(state, SCU_RAM_GPIO__A,
6104                                          SCU_RAM_GPIO_HW_LOCK_IND_DISABLE);
6105                         if (status < 0)
6106                                 goto error;
6107                 }
6108 
6109                 /* disable MPEG port */
6110                 status = mpegts_disable(state);
6111                 if (status < 0)
6112                         goto error;
6113 
6114                 /* Stop AUD and SCU */
6115                 status = write16(state, AUD_COMM_EXEC__A, AUD_COMM_EXEC_STOP);
6116                 if (status < 0)
6117                         goto error;
6118                 status = write16(state, SCU_COMM_EXEC__A, SCU_COMM_EXEC_STOP);
6119                 if (status < 0)
6120                         goto error;
6121 
6122                 /* enable token-ring bus through OFDM block for possible ucode upload */
6123                 status = write16(state, SIO_OFDM_SH_OFDM_RING_ENABLE__A,
6124                                  SIO_OFDM_SH_OFDM_RING_ENABLE_ON);
6125                 if (status < 0)
6126                         goto error;
6127 
6128                 /* include boot loader section */
6129                 status = write16(state, SIO_BL_COMM_EXEC__A,
6130                                  SIO_BL_COMM_EXEC_ACTIVE);
6131                 if (status < 0)
6132                         goto error;
6133                 status = bl_chain_cmd(state, 0, 6, 100);
6134                 if (status < 0)
6135                         goto error;
6136 
6137                 if (state->fw) {
6138                         status = download_microcode(state, state->fw->data,
6139                                                    state->fw->size);
6140                         if (status < 0)
6141                                 goto error;
6142                 }
6143 
6144                 /* disable token-ring bus through OFDM block for possible ucode upload */
6145                 status = write16(state, SIO_OFDM_SH_OFDM_RING_ENABLE__A,
6146                                  SIO_OFDM_SH_OFDM_RING_ENABLE_OFF);
6147                 if (status < 0)
6148                         goto error;
6149 
6150                 /* Run SCU for a little while to initialize microcode version numbers */
6151                 status = write16(state, SCU_COMM_EXEC__A, SCU_COMM_EXEC_ACTIVE);
6152                 if (status < 0)
6153                         goto error;
6154                 status = drxx_open(state);
6155                 if (status < 0)
6156                         goto error;
6157                 /* added for test */
6158                 msleep(30);
6159 
6160                 power_mode = DRXK_POWER_DOWN_OFDM;
6161                 status = ctrl_power_mode(state, &power_mode);
6162                 if (status < 0)
6163                         goto error;
6164 
6165                 /* Stamp driver version number in SCU data RAM in BCD code
6166                         Done to enable field application engineers to retrieve drxdriver version
6167                         via I2C from SCU RAM.
6168                         Not using SCU command interface for SCU register access since no
6169                         microcode may be present.
6170                         */
6171                 driver_version =
6172                         (((DRXK_VERSION_MAJOR / 100) % 10) << 12) +
6173                         (((DRXK_VERSION_MAJOR / 10) % 10) << 8) +
6174                         ((DRXK_VERSION_MAJOR % 10) << 4) +
6175                         (DRXK_VERSION_MINOR % 10);
6176                 status = write16(state, SCU_RAM_DRIVER_VER_HI__A,
6177                                  driver_version);
6178                 if (status < 0)
6179                         goto error;
6180                 driver_version =
6181                         (((DRXK_VERSION_PATCH / 1000) % 10) << 12) +
6182                         (((DRXK_VERSION_PATCH / 100) % 10) << 8) +
6183                         (((DRXK_VERSION_PATCH / 10) % 10) << 4) +
6184                         (DRXK_VERSION_PATCH % 10);
6185                 status = write16(state, SCU_RAM_DRIVER_VER_LO__A,
6186                                  driver_version);
6187                 if (status < 0)
6188                         goto error;
6189 
6190                 pr_info("DRXK driver version %d.%d.%d\n",
6191                         DRXK_VERSION_MAJOR, DRXK_VERSION_MINOR,
6192                         DRXK_VERSION_PATCH);
6193 
6194                 /*
6195                  * Dirty fix of default values for ROM/PATCH microcode
6196                  * Dirty because this fix makes it impossible to setup
6197                  * suitable values before calling DRX_Open. This solution
6198                  * requires changes to RF AGC speed to be done via the CTRL
6199                  * function after calling DRX_Open
6200                  */
6201 
6202                 /* m_dvbt_rf_agc_cfg.speed = 3; */
6203 
6204                 /* Reset driver debug flags to 0 */
6205                 status = write16(state, SCU_RAM_DRIVER_DEBUG__A, 0);
6206                 if (status < 0)
6207                         goto error;
6208                 /* driver 0.9.0 */
6209                 /* Setup FEC OC:
6210                         NOTE: No more full FEC resets allowed afterwards!! */
6211                 status = write16(state, FEC_COMM_EXEC__A, FEC_COMM_EXEC_STOP);
6212                 if (status < 0)
6213                         goto error;
6214                 /* MPEGTS functions are still the same */
6215                 status = mpegts_dto_init(state);
6216                 if (status < 0)
6217                         goto error;
6218                 status = mpegts_stop(state);
6219                 if (status < 0)
6220                         goto error;
6221                 status = mpegts_configure_polarity(state);
6222                 if (status < 0)
6223                         goto error;
6224                 status = mpegts_configure_pins(state, state->m_enable_mpeg_output);
6225                 if (status < 0)
6226                         goto error;
6227                 /* added: configure GPIO */
6228                 status = write_gpio(state);
6229                 if (status < 0)
6230                         goto error;
6231 
6232                 state->m_drxk_state = DRXK_STOPPED;
6233 
6234                 if (state->m_b_power_down) {
6235                         status = power_down_device(state);
6236                         if (status < 0)
6237                                 goto error;
6238                         state->m_drxk_state = DRXK_POWERED_DOWN;
6239                 } else
6240                         state->m_drxk_state = DRXK_STOPPED;
6241 
6242                 /* Initialize the supported delivery systems */
6243                 n = 0;
6244                 if (state->m_has_dvbc) {
6245                         state->frontend.ops.delsys[n++] = SYS_DVBC_ANNEX_A;
6246                         state->frontend.ops.delsys[n++] = SYS_DVBC_ANNEX_C;
6247                         strlcat(state->frontend.ops.info.name, " DVB-C",
6248                                 sizeof(state->frontend.ops.info.name));
6249                 }
6250                 if (state->m_has_dvbt) {
6251                         state->frontend.ops.delsys[n++] = SYS_DVBT;
6252                         strlcat(state->frontend.ops.info.name, " DVB-T",
6253                                 sizeof(state->frontend.ops.info.name));
6254                 }
6255                 drxk_i2c_unlock(state);
6256         }
6257 error:
6258         if (status < 0) {
6259                 state->m_drxk_state = DRXK_NO_DEV;
6260                 drxk_i2c_unlock(state);
6261                 pr_err("Error %d on %s\n", status, __func__);
6262         }
6263 
6264         return status;
6265 }
6266 
6267 static void load_firmware_cb(const struct firmware *fw,
6268                              void *context)
6269 {
6270         struct drxk_state *state = context;
6271 
6272         dprintk(1, ": %s\n", fw ? "firmware loaded" : "firmware not loaded");
6273         if (!fw) {
6274                 pr_err("Could not load firmware file %s.\n",
6275                         state->microcode_name);
6276                 pr_info("Copy %s to your hotplug directory!\n",
6277                         state->microcode_name);
6278                 state->microcode_name = NULL;
6279 
6280                 /*
6281                  * As firmware is now load asynchronous, it is not possible
6282                  * anymore to fail at frontend attach. We might silently
6283                  * return here, and hope that the driver won't crash.
6284                  * We might also change all DVB callbacks to return -ENODEV
6285                  * if the device is not initialized.
6286                  * As the DRX-K devices have their own internal firmware,
6287                  * let's just hope that it will match a firmware revision
6288                  * compatible with this driver and proceed.
6289                  */
6290         }
6291         state->fw = fw;
6292 
6293         init_drxk(state);
6294 }
6295 
6296 static void drxk_release(struct dvb_frontend *fe)
6297 {
6298         struct drxk_state *state = fe->demodulator_priv;
6299 
6300         dprintk(1, "\n");
6301         release_firmware(state->fw);
6302 
6303         kfree(state);
6304 }
6305 
6306 static int drxk_sleep(struct dvb_frontend *fe)
6307 {
6308         struct drxk_state *state = fe->demodulator_priv;
6309 
6310         dprintk(1, "\n");
6311 
6312         if (state->m_drxk_state == DRXK_NO_DEV)
6313                 return -ENODEV;
6314         if (state->m_drxk_state == DRXK_UNINITIALIZED)
6315                 return 0;
6316 
6317         shut_down(state);
6318         return 0;
6319 }
6320 
6321 static int drxk_gate_ctrl(struct dvb_frontend *fe, int enable)
6322 {
6323         struct drxk_state *state = fe->demodulator_priv;
6324 
6325         dprintk(1, ": %s\n", enable ? "enable" : "disable");
6326 
6327         if (state->m_drxk_state == DRXK_NO_DEV)
6328                 return -ENODEV;
6329 
6330         return ConfigureI2CBridge(state, enable ? true : false);
6331 }
6332 
6333 static int drxk_set_parameters(struct dvb_frontend *fe)
6334 {
6335         struct dtv_frontend_properties *p = &fe->dtv_property_cache;
6336         u32 delsys  = p->delivery_system, old_delsys;
6337         struct drxk_state *state = fe->demodulator_priv;
6338         u32 IF;
6339 
6340         dprintk(1, "\n");
6341 
6342         if (state->m_drxk_state == DRXK_NO_DEV)
6343                 return -ENODEV;
6344 
6345         if (state->m_drxk_state == DRXK_UNINITIALIZED)
6346                 return -EAGAIN;
6347 
6348         if (!fe->ops.tuner_ops.get_if_frequency) {
6349                 pr_err("Error: get_if_frequency() not defined at tuner. Can't work without it!\n");
6350                 return -EINVAL;
6351         }
6352 
6353         if (fe->ops.i2c_gate_ctrl)
6354                 fe->ops.i2c_gate_ctrl(fe, 1);
6355         if (fe->ops.tuner_ops.set_params)
6356                 fe->ops.tuner_ops.set_params(fe);
6357         if (fe->ops.i2c_gate_ctrl)
6358                 fe->ops.i2c_gate_ctrl(fe, 0);
6359 
6360         old_delsys = state->props.delivery_system;
6361         state->props = *p;
6362 
6363         if (old_delsys != delsys) {
6364                 shut_down(state);
6365                 switch (delsys) {
6366                 case SYS_DVBC_ANNEX_A:
6367                 case SYS_DVBC_ANNEX_C:
6368                         if (!state->m_has_dvbc)
6369                                 return -EINVAL;
6370                         state->m_itut_annex_c = (delsys == SYS_DVBC_ANNEX_C) ?
6371                                                 true : false;
6372                         if (state->m_itut_annex_c)
6373                                 setoperation_mode(state, OM_QAM_ITU_C);
6374                         else
6375                                 setoperation_mode(state, OM_QAM_ITU_A);
6376                         break;
6377                 case SYS_DVBT:
6378                         if (!state->m_has_dvbt)
6379                                 return -EINVAL;
6380                         setoperation_mode(state, OM_DVBT);
6381                         break;
6382                 default:
6383                         return -EINVAL;
6384                 }
6385         }
6386 
6387         fe->ops.tuner_ops.get_if_frequency(fe, &IF);
6388         start(state, 0, IF);
6389 
6390         /* After set_frontend, stats aren't available */
6391         p->strength.stat[0].scale = FE_SCALE_RELATIVE;
6392         p->cnr.stat[0].scale = FE_SCALE_NOT_AVAILABLE;
6393         p->block_error.stat[0].scale = FE_SCALE_NOT_AVAILABLE;
6394         p->block_count.stat[0].scale = FE_SCALE_NOT_AVAILABLE;
6395         p->pre_bit_error.stat[0].scale = FE_SCALE_NOT_AVAILABLE;
6396         p->pre_bit_count.stat[0].scale = FE_SCALE_NOT_AVAILABLE;
6397         p->post_bit_error.stat[0].scale = FE_SCALE_NOT_AVAILABLE;
6398         p->post_bit_count.stat[0].scale = FE_SCALE_NOT_AVAILABLE;
6399 
6400         /* printk(KERN_DEBUG "drxk: %s IF=%d done\n", __func__, IF); */
6401 
6402         return 0;
6403 }
6404 
6405 static int get_strength(struct drxk_state *state, u64 *strength)
6406 {
6407         int status;
6408         struct s_cfg_agc   rf_agc, if_agc;
6409         u32          total_gain  = 0;
6410         u32          atten      = 0;
6411         u32          agc_range   = 0;
6412         u16            scu_lvl  = 0;
6413         u16            scu_coc  = 0;
6414         /* FIXME: those are part of the tuner presets */
6415         u16 tuner_rf_gain         = 50; /* Default value on az6007 driver */
6416         u16 tuner_if_gain         = 40; /* Default value on az6007 driver */
6417 
6418         *strength = 0;
6419 
6420         if (is_dvbt(state)) {
6421                 rf_agc = state->m_dvbt_rf_agc_cfg;
6422                 if_agc = state->m_dvbt_if_agc_cfg;
6423         } else if (is_qam(state)) {
6424                 rf_agc = state->m_qam_rf_agc_cfg;
6425                 if_agc = state->m_qam_if_agc_cfg;
6426         } else {
6427                 rf_agc = state->m_atv_rf_agc_cfg;
6428                 if_agc = state->m_atv_if_agc_cfg;
6429         }
6430 
6431         if (rf_agc.ctrl_mode == DRXK_AGC_CTRL_AUTO) {
6432                 /* SCU output_level */
6433                 status = read16(state, SCU_RAM_AGC_RF_IACCU_HI__A, &scu_lvl);
6434                 if (status < 0)
6435                         return status;
6436 
6437                 /* SCU c.o.c. */
6438                 status = read16(state, SCU_RAM_AGC_RF_IACCU_HI_CO__A, &scu_coc);
6439                 if (status < 0)
6440                         return status;
6441 
6442                 if (((u32) scu_lvl + (u32) scu_coc) < 0xffff)
6443                         rf_agc.output_level = scu_lvl + scu_coc;
6444                 else
6445                         rf_agc.output_level = 0xffff;
6446 
6447                 /* Take RF gain into account */
6448                 total_gain += tuner_rf_gain;
6449 
6450                 /* clip output value */
6451                 if (rf_agc.output_level < rf_agc.min_output_level)
6452                         rf_agc.output_level = rf_agc.min_output_level;
6453                 if (rf_agc.output_level > rf_agc.max_output_level)
6454                         rf_agc.output_level = rf_agc.max_output_level;
6455 
6456                 agc_range = (u32) (rf_agc.max_output_level - rf_agc.min_output_level);
6457                 if (agc_range > 0) {
6458                         atten += 100UL *
6459                                 ((u32)(tuner_rf_gain)) *
6460                                 ((u32)(rf_agc.output_level - rf_agc.min_output_level))
6461                                 / agc_range;
6462                 }
6463         }
6464 
6465         if (if_agc.ctrl_mode == DRXK_AGC_CTRL_AUTO) {
6466                 status = read16(state, SCU_RAM_AGC_IF_IACCU_HI__A,
6467                                 &if_agc.output_level);
6468                 if (status < 0)
6469                         return status;
6470 
6471                 status = read16(state, SCU_RAM_AGC_INGAIN_TGT_MIN__A,
6472                                 &if_agc.top);
6473                 if (status < 0)
6474                         return status;
6475 
6476                 /* Take IF gain into account */
6477                 total_gain += (u32) tuner_if_gain;
6478 
6479                 /* clip output value */
6480                 if (if_agc.output_level < if_agc.min_output_level)
6481                         if_agc.output_level = if_agc.min_output_level;
6482                 if (if_agc.output_level > if_agc.max_output_level)
6483                         if_agc.output_level = if_agc.max_output_level;
6484 
6485                 agc_range  = (u32)(if_agc.max_output_level - if_agc.min_output_level);
6486                 if (agc_range > 0) {
6487                         atten += 100UL *
6488                                 ((u32)(tuner_if_gain)) *
6489                                 ((u32)(if_agc.output_level - if_agc.min_output_level))
6490                                 / agc_range;
6491                 }
6492         }
6493 
6494         /*
6495          * Convert to 0..65535 scale.
6496          * If it can't be measured (AGC is disabled), just show 100%.
6497          */
6498         if (total_gain > 0)
6499                 *strength = (65535UL * atten / total_gain / 100);
6500         else
6501                 *strength = 65535;
6502 
6503         return 0;
6504 }
6505 
6506 static int drxk_get_stats(struct dvb_frontend *fe)
6507 {
6508         struct dtv_frontend_properties *c = &fe->dtv_property_cache;
6509         struct drxk_state *state = fe->demodulator_priv;
6510         int status;
6511         u32 stat;
6512         u16 reg16;
6513         u32 post_bit_count;
6514         u32 post_bit_err_count;
6515         u32 post_bit_error_scale;
6516         u32 pre_bit_err_count;
6517         u32 pre_bit_count;
6518         u32 pkt_count;
6519         u32 pkt_error_count;
6520         s32 cnr;
6521 
6522         if (state->m_drxk_state == DRXK_NO_DEV)
6523                 return -ENODEV;
6524         if (state->m_drxk_state == DRXK_UNINITIALIZED)
6525                 return -EAGAIN;
6526 
6527         /* get status */
6528         state->fe_status = 0;
6529         get_lock_status(state, &stat);
6530         if (stat == MPEG_LOCK)
6531                 state->fe_status |= 0x1f;
6532         if (stat == FEC_LOCK)
6533                 state->fe_status |= 0x0f;
6534         if (stat == DEMOD_LOCK)
6535                 state->fe_status |= 0x07;
6536 
6537         /*
6538          * Estimate signal strength from AGC
6539          */
6540         get_strength(state, &c->strength.stat[0].uvalue);
6541         c->strength.stat[0].scale = FE_SCALE_RELATIVE;
6542 
6543 
6544         if (stat >= DEMOD_LOCK) {
6545                 get_signal_to_noise(state, &cnr);
6546                 c->cnr.stat[0].svalue = cnr * 100;
6547                 c->cnr.stat[0].scale = FE_SCALE_DECIBEL;
6548         } else {
6549                 c->cnr.stat[0].scale = FE_SCALE_NOT_AVAILABLE;
6550         }
6551 
6552         if (stat < FEC_LOCK) {
6553                 c->block_error.stat[0].scale = FE_SCALE_NOT_AVAILABLE;
6554                 c->block_count.stat[0].scale = FE_SCALE_NOT_AVAILABLE;
6555                 c->pre_bit_error.stat[0].scale = FE_SCALE_NOT_AVAILABLE;
6556                 c->pre_bit_count.stat[0].scale = FE_SCALE_NOT_AVAILABLE;
6557                 c->post_bit_error.stat[0].scale = FE_SCALE_NOT_AVAILABLE;
6558                 c->post_bit_count.stat[0].scale = FE_SCALE_NOT_AVAILABLE;
6559                 return 0;
6560         }
6561 
6562         /* Get post BER */
6563 
6564         /* BER measurement is valid if at least FEC lock is achieved */
6565 
6566         /*
6567          * OFDM_EC_VD_REQ_SMB_CNT__A and/or OFDM_EC_VD_REQ_BIT_CNT can be
6568          * written to set nr of symbols or bits over which to measure
6569          * EC_VD_REG_ERR_BIT_CNT__A . See CtrlSetCfg().
6570          */
6571 
6572         /* Read registers for post/preViterbi BER calculation */
6573         status = read16(state, OFDM_EC_VD_ERR_BIT_CNT__A, &reg16);
6574         if (status < 0)
6575                 goto error;
6576         pre_bit_err_count = reg16;
6577 
6578         status = read16(state, OFDM_EC_VD_IN_BIT_CNT__A , &reg16);
6579         if (status < 0)
6580                 goto error;
6581         pre_bit_count = reg16;
6582 
6583         /* Number of bit-errors */
6584         status = read16(state, FEC_RS_NR_BIT_ERRORS__A, &reg16);
6585         if (status < 0)
6586                 goto error;
6587         post_bit_err_count = reg16;
6588 
6589         status = read16(state, FEC_RS_MEASUREMENT_PRESCALE__A, &reg16);
6590         if (status < 0)
6591                 goto error;
6592         post_bit_error_scale = reg16;
6593 
6594         status = read16(state, FEC_RS_MEASUREMENT_PERIOD__A, &reg16);
6595         if (status < 0)
6596                 goto error;
6597         pkt_count = reg16;
6598 
6599         status = read16(state, SCU_RAM_FEC_ACCUM_PKT_FAILURES__A, &reg16);
6600         if (status < 0)
6601                 goto error;
6602         pkt_error_count = reg16;
6603         write16(state, SCU_RAM_FEC_ACCUM_PKT_FAILURES__A, 0);
6604 
6605         post_bit_err_count *= post_bit_error_scale;
6606 
6607         post_bit_count = pkt_count * 204 * 8;
6608 
6609         /* Store the results */
6610         c->block_error.stat[0].scale = FE_SCALE_COUNTER;
6611         c->block_error.stat[0].uvalue += pkt_error_count;
6612         c->block_count.stat[0].scale = FE_SCALE_COUNTER;
6613         c->block_count.stat[0].uvalue += pkt_count;
6614 
6615         c->pre_bit_error.stat[0].scale = FE_SCALE_COUNTER;
6616         c->pre_bit_error.stat[0].uvalue += pre_bit_err_count;
6617         c->pre_bit_count.stat[0].scale = FE_SCALE_COUNTER;
6618         c->pre_bit_count.stat[0].uvalue += pre_bit_count;
6619 
6620         c->post_bit_error.stat[0].scale = FE_SCALE_COUNTER;
6621         c->post_bit_error.stat[0].uvalue += post_bit_err_count;
6622         c->post_bit_count.stat[0].scale = FE_SCALE_COUNTER;
6623         c->post_bit_count.stat[0].uvalue += post_bit_count;
6624 
6625 error:
6626         return status;
6627 }
6628 
6629 
6630 static int drxk_read_status(struct dvb_frontend *fe, enum fe_status *status)
6631 {
6632         struct drxk_state *state = fe->demodulator_priv;
6633         int rc;
6634 
6635         dprintk(1, "\n");
6636 
6637         rc = drxk_get_stats(fe);
6638         if (rc < 0)
6639                 return rc;
6640 
6641         *status = state->fe_status;
6642 
6643         return 0;
6644 }
6645 
6646 static int drxk_read_signal_strength(struct dvb_frontend *fe,
6647                                      u16 *strength)
6648 {
6649         struct drxk_state *state = fe->demodulator_priv;
6650         struct dtv_frontend_properties *c = &fe->dtv_property_cache;
6651 
6652         dprintk(1, "\n");
6653 
6654         if (state->m_drxk_state == DRXK_NO_DEV)
6655                 return -ENODEV;
6656         if (state->m_drxk_state == DRXK_UNINITIALIZED)
6657                 return -EAGAIN;
6658 
6659         *strength = c->strength.stat[0].uvalue;
6660         return 0;
6661 }
6662 
6663 static int drxk_read_snr(struct dvb_frontend *fe, u16 *snr)
6664 {
6665         struct drxk_state *state = fe->demodulator_priv;
6666         s32 snr2;
6667 
6668         dprintk(1, "\n");
6669 
6670         if (state->m_drxk_state == DRXK_NO_DEV)
6671                 return -ENODEV;
6672         if (state->m_drxk_state == DRXK_UNINITIALIZED)
6673                 return -EAGAIN;
6674 
6675         get_signal_to_noise(state, &snr2);
6676 
6677         /* No negative SNR, clip to zero */
6678         if (snr2 < 0)
6679                 snr2 = 0;
6680         *snr = snr2 & 0xffff;
6681         return 0;
6682 }
6683 
6684 static int drxk_read_ucblocks(struct dvb_frontend *fe, u32 *ucblocks)
6685 {
6686         struct drxk_state *state = fe->demodulator_priv;
6687         u16 err;
6688 
6689         dprintk(1, "\n");
6690 
6691         if (state->m_drxk_state == DRXK_NO_DEV)
6692                 return -ENODEV;
6693         if (state->m_drxk_state == DRXK_UNINITIALIZED)
6694                 return -EAGAIN;
6695 
6696         dvbtqam_get_acc_pkt_err(state, &err);
6697         *ucblocks = (u32) err;
6698         return 0;
6699 }
6700 
6701 static int drxk_get_tune_settings(struct dvb_frontend *fe,
6702                                   struct dvb_frontend_tune_settings *sets)
6703 {
6704         struct drxk_state *state = fe->demodulator_priv;
6705         struct dtv_frontend_properties *p = &fe->dtv_property_cache;
6706 
6707         dprintk(1, "\n");
6708 
6709         if (state->m_drxk_state == DRXK_NO_DEV)
6710                 return -ENODEV;
6711         if (state->m_drxk_state == DRXK_UNINITIALIZED)
6712                 return -EAGAIN;
6713 
6714         switch (p->delivery_system) {
6715         case SYS_DVBC_ANNEX_A:
6716         case SYS_DVBC_ANNEX_C:
6717         case SYS_DVBT:
6718                 sets->min_delay_ms = 3000;
6719                 sets->max_drift = 0;
6720                 sets->step_size = 0;
6721                 return 0;
6722         default:
6723                 return -EINVAL;
6724         }
6725 }
6726 
6727 static const struct dvb_frontend_ops drxk_ops = {
6728         /* .delsys will be filled dynamically */
6729         .info = {
6730                 .name = "DRXK",
6731                 .frequency_min_hz =  47 * MHz,
6732                 .frequency_max_hz = 865 * MHz,
6733                  /* For DVB-C */
6734                 .symbol_rate_min =   870000,
6735                 .symbol_rate_max = 11700000,
6736                 /* For DVB-T */
6737                 .frequency_stepsize_hz = 166667,
6738 
6739                 .caps = FE_CAN_QAM_16 | FE_CAN_QAM_32 | FE_CAN_QAM_64 |
6740                         FE_CAN_QAM_128 | FE_CAN_QAM_256 | FE_CAN_FEC_AUTO |
6741                         FE_CAN_FEC_1_2 | FE_CAN_FEC_2_3 | FE_CAN_FEC_3_4 |
6742                         FE_CAN_FEC_5_6 | FE_CAN_FEC_7_8 | FE_CAN_MUTE_TS |
6743                         FE_CAN_TRANSMISSION_MODE_AUTO | FE_CAN_RECOVER |
6744                         FE_CAN_GUARD_INTERVAL_AUTO | FE_CAN_HIERARCHY_AUTO
6745         },
6746 
6747         .release = drxk_release,
6748         .sleep = drxk_sleep,
6749         .i2c_gate_ctrl = drxk_gate_ctrl,
6750 
6751         .set_frontend = drxk_set_parameters,
6752         .get_tune_settings = drxk_get_tune_settings,
6753 
6754         .read_status = drxk_read_status,
6755         .read_signal_strength = drxk_read_signal_strength,
6756         .read_snr = drxk_read_snr,
6757         .read_ucblocks = drxk_read_ucblocks,
6758 };
6759 
6760 struct dvb_frontend *drxk_attach(const struct drxk_config *config,
6761                                  struct i2c_adapter *i2c)
6762 {
6763         struct dtv_frontend_properties *p;
6764         struct drxk_state *state = NULL;
6765         u8 adr = config->adr;
6766         int status;
6767 
6768         dprintk(1, "\n");
6769         state = kzalloc(sizeof(struct drxk_state), GFP_KERNEL);
6770         if (!state)
6771                 return NULL;
6772 
6773         state->i2c = i2c;
6774         state->demod_address = adr;
6775         state->single_master = config->single_master;
6776         state->microcode_name = config->microcode_name;
6777         state->qam_demod_parameter_count = config->qam_demod_parameter_count;
6778         state->no_i2c_bridge = config->no_i2c_bridge;
6779         state->antenna_gpio = config->antenna_gpio;
6780         state->antenna_dvbt = config->antenna_dvbt;
6781         state->m_chunk_size = config->chunk_size;
6782         state->enable_merr_cfg = config->enable_merr_cfg;
6783 
6784         if (config->dynamic_clk) {
6785                 state->m_dvbt_static_clk = false;
6786                 state->m_dvbc_static_clk = false;
6787         } else {
6788                 state->m_dvbt_static_clk = true;
6789                 state->m_dvbc_static_clk = true;
6790         }
6791 
6792 
6793         if (config->mpeg_out_clk_strength)
6794                 state->m_ts_clockk_strength = config->mpeg_out_clk_strength & 0x07;
6795         else
6796                 state->m_ts_clockk_strength = 0x06;
6797 
6798         if (config->parallel_ts)
6799                 state->m_enable_parallel = true;
6800         else
6801                 state->m_enable_parallel = false;
6802 
6803         /* NOTE: as more UIO bits will be used, add them to the mask */
6804         state->uio_mask = config->antenna_gpio;
6805 
6806         /* Default gpio to DVB-C */
6807         if (!state->antenna_dvbt && state->antenna_gpio)
6808                 state->m_gpio |= state->antenna_gpio;
6809         else
6810                 state->m_gpio &= ~state->antenna_gpio;
6811 
6812         mutex_init(&state->mutex);
6813 
6814         memcpy(&state->frontend.ops, &drxk_ops, sizeof(drxk_ops));
6815         state->frontend.demodulator_priv = state;
6816 
6817         init_state(state);
6818 
6819         /* Load firmware and initialize DRX-K */
6820         if (state->microcode_name) {
6821                 const struct firmware *fw = NULL;
6822 
6823                 status = request_firmware(&fw, state->microcode_name,
6824                                           state->i2c->dev.parent);
6825                 if (status < 0)
6826                         fw = NULL;
6827                 load_firmware_cb(fw, state);
6828         } else if (init_drxk(state) < 0)
6829                 goto error;
6830 
6831 
6832         /* Initialize stats */
6833         p = &state->frontend.dtv_property_cache;
6834         p->strength.len = 1;
6835         p->cnr.len = 1;
6836         p->block_error.len = 1;
6837         p->block_count.len = 1;
6838         p->pre_bit_error.len = 1;
6839         p->pre_bit_count.len = 1;
6840         p->post_bit_error.len = 1;
6841         p->post_bit_count.len = 1;
6842 
6843         p->strength.stat[0].scale = FE_SCALE_RELATIVE;
6844         p->cnr.stat[0].scale = FE_SCALE_NOT_AVAILABLE;
6845         p->block_error.stat[0].scale = FE_SCALE_NOT_AVAILABLE;
6846         p->block_count.stat[0].scale = FE_SCALE_NOT_AVAILABLE;
6847         p->pre_bit_error.stat[0].scale = FE_SCALE_NOT_AVAILABLE;
6848         p->pre_bit_count.stat[0].scale = FE_SCALE_NOT_AVAILABLE;
6849         p->post_bit_error.stat[0].scale = FE_SCALE_NOT_AVAILABLE;
6850         p->post_bit_count.stat[0].scale = FE_SCALE_NOT_AVAILABLE;
6851 
6852         pr_info("frontend initialized.\n");
6853         return &state->frontend;
6854 
6855 error:
6856         pr_err("not found\n");
6857         kfree(state);
6858         return NULL;
6859 }
6860 EXPORT_SYMBOL(drxk_attach);
6861 
6862 MODULE_DESCRIPTION("DRX-K driver");
6863 MODULE_AUTHOR("Ralph Metzler");
6864 MODULE_LICENSE("GPL");

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