1 
   2 
   3 
   4 
   5 
   6 
   7 
   8 
   9 
  10 #ifndef __DIB3000MB_PRIV_H_INCLUDED__
  11 #define __DIB3000MB_PRIV_H_INCLUDED__
  12 
  13 
  14 #define rd(reg) dib3000_read_reg(state,reg)
  15 
  16 #define wr(reg,val) if (dib3000_write_reg(state,reg,val)) \
  17         { pr_err("while sending 0x%04x to 0x%04x.", val, reg); return -EREMOTEIO; }
  18 
  19 #define wr_foreach(a,v) { int i; \
  20         if (sizeof(a) != sizeof(v)) \
  21                 pr_err("sizeof: %zu %zu is different", sizeof(a), sizeof(v));\
  22         for (i=0; i < sizeof(a)/sizeof(u16); i++) \
  23                 wr(a[i],v[i]); \
  24         }
  25 
  26 #define set_or(reg,val) wr(reg,rd(reg) | val)
  27 
  28 #define set_and(reg,val) wr(reg,rd(reg) & val)
  29 
  30 
  31 
  32 #define dprintk(level, fmt, arg...) do {                                \
  33         if (debug & level)                                              \
  34                 printk(KERN_DEBUG pr_fmt("%s: " fmt),                   \
  35                        __func__, ##arg);                                \
  36 } while (0)
  37 
  38 
  39 #define DIB3000_ACTIVATE_PID_FILTERING  (0x2000)
  40 
  41 
  42 #define DIB3000_ALPHA_0                                 (     0)
  43 #define DIB3000_ALPHA_1                                 (     1)
  44 #define DIB3000_ALPHA_2                                 (     2)
  45 #define DIB3000_ALPHA_4                                 (     4)
  46 
  47 #define DIB3000_CONSTELLATION_QPSK              (     0)
  48 #define DIB3000_CONSTELLATION_16QAM             (     1)
  49 #define DIB3000_CONSTELLATION_64QAM             (     2)
  50 
  51 #define DIB3000_GUARD_TIME_1_32                 (     0)
  52 #define DIB3000_GUARD_TIME_1_16                 (     1)
  53 #define DIB3000_GUARD_TIME_1_8                  (     2)
  54 #define DIB3000_GUARD_TIME_1_4                  (     3)
  55 
  56 #define DIB3000_TRANSMISSION_MODE_2K    (     0)
  57 #define DIB3000_TRANSMISSION_MODE_8K    (     1)
  58 
  59 #define DIB3000_SELECT_LP                               (     0)
  60 #define DIB3000_SELECT_HP                               (     1)
  61 
  62 #define DIB3000_FEC_1_2                                 (     1)
  63 #define DIB3000_FEC_2_3                                 (     2)
  64 #define DIB3000_FEC_3_4                                 (     3)
  65 #define DIB3000_FEC_5_6                                 (     5)
  66 #define DIB3000_FEC_7_8                                 (     7)
  67 
  68 #define DIB3000_HRCH_OFF                                (     0)
  69 #define DIB3000_HRCH_ON                                 (     1)
  70 
  71 #define DIB3000_DDS_INVERSION_OFF               (     0)
  72 #define DIB3000_DDS_INVERSION_ON                (     1)
  73 
  74 #define DIB3000_TUNER_WRITE_ENABLE(a)   (0xffff & (a << 8))
  75 #define DIB3000_TUNER_WRITE_DISABLE(a)  (0xffff & ((a << 8) | (1 << 7)))
  76 
  77 #define DIB3000_REG_MANUFACTOR_ID               (  1025)
  78 #define DIB3000_I2C_ID_DIBCOM                   (0x01b3)
  79 
  80 #define DIB3000_REG_DEVICE_ID                   (  1026)
  81 #define DIB3000MB_DEVICE_ID                             (0x3000)
  82 #define DIB3000MC_DEVICE_ID                             (0x3001)
  83 #define DIB3000P_DEVICE_ID                              (0x3002)
  84 
  85 
  86 struct dib3000_state {
  87         struct i2c_adapter* i2c;
  88 
  89 
  90         struct dib3000_config config;
  91 
  92         struct dvb_frontend frontend;
  93         int timing_offset;
  94         int timing_offset_comp_done;
  95 
  96         u32 last_tuned_bw;
  97         u32 last_tuned_freq;
  98 };
  99 
 100 
 101 
 102 
 103 #define DIB3000MB_REG_RESTART                   (     0)
 104 
 105 #define DIB3000MB_RESTART_OFF                   (     0)
 106 #define DIB3000MB_RESTART_AUTO_SEARCH           (1 << 1)
 107 #define DIB3000MB_RESTART_CTRL                          (1 << 2)
 108 #define DIB3000MB_RESTART_AGC                           (1 << 3)
 109 
 110 
 111 #define DIB3000MB_REG_FFT                               (     1)
 112 
 113 
 114 #define DIB3000MB_REG_GUARD_TIME                (     2)
 115 
 116 
 117 #define DIB3000MB_REG_QAM                               (     3)
 118 
 119 
 120 #define DIB3000MB_REG_VIT_ALPHA                 (     4)
 121 
 122 
 123 #define DIB3000MB_REG_DDS_INV                   (     5)
 124 
 125 
 126 #define DIB3000MB_REG_DDS_FREQ_MSB              (     6)
 127 #define DIB3000MB_REG_DDS_FREQ_LSB              (     7)
 128 #define DIB3000MB_DDS_FREQ_MSB                          (   178)
 129 #define DIB3000MB_DDS_FREQ_LSB                          (  8990)
 130 
 131 
 132 static u16 dib3000mb_reg_timing_freq[] = { 8,9 };
 133 static u16 dib3000mb_timing_freq[][2] = {
 134         { 126 , 48873 }, 
 135         { 147 , 57019 }, 
 136         { 168 , 65164 }, 
 137 };
 138 
 139 
 140 
 141 
 142 static u16 dib3000mb_reg_impulse_noise[] = { 10,11,12,15,36 };
 143 
 144 enum dib3000mb_impulse_noise_type {
 145         DIB3000MB_IMPNOISE_OFF,
 146         DIB3000MB_IMPNOISE_MOBILE,
 147         DIB3000MB_IMPNOISE_FIXED,
 148         DIB3000MB_IMPNOISE_DEFAULT
 149 };
 150 
 151 static u16 dib3000mb_impulse_noise_values[][5] = {
 152         { 0x0000, 0x0004, 0x0014, 0x01ff, 0x0399 }, 
 153         { 0x0001, 0x0004, 0x0014, 0x01ff, 0x037b }, 
 154         { 0x0001, 0x0004, 0x0020, 0x01bd, 0x0399 }, 
 155         { 0x0000, 0x0002, 0x000a, 0x01ff, 0x0399 }, 
 156 };
 157 
 158 
 159 
 160 
 161 
 162 
 163 
 164 
 165 static u16 dib3000mb_reg_agc_gain[] = {
 166         19,20,21,22,23,24,25,26,27,28,29,30,31,32
 167 };
 168 
 169 static u16 dib3000mb_default_agc_gain[] =
 170         { 0x0001, 52429,   623, 128, 166, 195, 61,   
 171           0x0001, 53766, 38011,   0,  90,  33, 23 }; 
 172 
 173 
 174 
 175 static u16 dib3000mb_reg_phase_noise[] = { 33,34,35,37,38 };
 176 
 177 static u16 dib3000mb_default_noise_phase[] = { 2, 544, 0, 5, 4 };
 178 
 179 
 180 static u16 dib3000mb_reg_lock_duration[] = { 39,40 };
 181 static u16 dib3000mb_default_lock_duration[] = { 135, 135 };
 182 
 183 
 184 static u16 dib3000mb_reg_agc_bandwidth[] = { 43,44,45,46,47,48,49,50 };
 185 
 186 static u16 dib3000mb_agc_bandwidth_low[]  =
 187         { 2088, 10, 2088, 10, 3448, 5, 3448, 5 };
 188 static u16 dib3000mb_agc_bandwidth_high[] =
 189         { 2349,  5, 2349,  5, 2586, 2, 2586, 2 };
 190 
 191 
 192 
 193 
 194 #define DIB3000MB_REG_LOCK0_MASK                (    51)
 195 #define DIB3000MB_LOCK0_DEFAULT                         (     4)
 196 
 197 
 198 
 199 
 200 
 201 
 202 #define DIB3000MB_REG_LOCK1_MASK                (    52)
 203 #define DIB3000MB_LOCK1_SEARCH_4                        (0x0004)
 204 #define DIB3000MB_LOCK1_SEARCH_2048                     (0x0800)
 205 #define DIB3000MB_LOCK1_DEFAULT                         (0x0001)
 206 
 207 
 208 
 209 #define DIB3000MB_REG_LOCK2_MASK                (    53)
 210 #define DIB3000MB_LOCK2_DEFAULT                         (0x0080)
 211 
 212 
 213 
 214 
 215 
 216 
 217 #define DIB3000MB_REG_SEQ                               (    54)
 218 
 219 
 220 static u16 dib3000mb_reg_bandwidth[] = { 55,56,57,58,59,60,61,62,63,64,65,66,67 };
 221 static u16 dib3000mb_bandwidth_6mhz[] =
 222         { 0, 33, 53312, 112, 46635, 563, 36565, 0, 1000, 0, 1010, 1, 45264 };
 223 
 224 static u16 dib3000mb_bandwidth_7mhz[] =
 225         { 0, 28, 64421,  96, 39973, 483,  3255, 0, 1000, 0, 1010, 1, 45264 };
 226 
 227 static u16 dib3000mb_bandwidth_8mhz[] =
 228         { 0, 25, 23600,  84, 34976, 422, 43808, 0, 1000, 0, 1010, 1, 45264 };
 229 
 230 #define DIB3000MB_REG_UNK_68                            (    68)
 231 #define DIB3000MB_UNK_68                                                (     0)
 232 
 233 #define DIB3000MB_REG_UNK_69                            (    69)
 234 #define DIB3000MB_UNK_69                                                (     0)
 235 
 236 #define DIB3000MB_REG_UNK_71                            (    71)
 237 #define DIB3000MB_UNK_71                                                (     0)
 238 
 239 #define DIB3000MB_REG_UNK_77                            (    77)
 240 #define DIB3000MB_UNK_77                                                (     6)
 241 
 242 #define DIB3000MB_REG_UNK_78                            (    78)
 243 #define DIB3000MB_UNK_78                                                (0x0080)
 244 
 245 
 246 #define DIB3000MB_REG_ISI                               (    79)
 247 #define DIB3000MB_ISI_ACTIVATE                          (     0)
 248 #define DIB3000MB_ISI_INHIBIT                           (     1)
 249 
 250 
 251 #define DIB3000MB_REG_SYNC_IMPROVEMENT  (    84)
 252 #define DIB3000MB_SYNC_IMPROVE_2K_1_8           (     3)
 253 #define DIB3000MB_SYNC_IMPROVE_DEFAULT          (     0)
 254 
 255 
 256 #define DIB3000MB_REG_PHASE_NOISE               (    87)
 257 #define DIB3000MB_PHASE_NOISE_DEFAULT   (     0)
 258 
 259 #define DIB3000MB_REG_UNK_92                            (    92)
 260 #define DIB3000MB_UNK_92                                                (0x0080)
 261 
 262 #define DIB3000MB_REG_UNK_96                            (    96)
 263 #define DIB3000MB_UNK_96                                                (0x0010)
 264 
 265 #define DIB3000MB_REG_UNK_97                            (    97)
 266 #define DIB3000MB_UNK_97                                                (0x0009)
 267 
 268 
 269 #define DIB3000MB_REG_MOBILE_MODE               (   101)
 270 #define DIB3000MB_MOBILE_MODE_ON                        (     1)
 271 #define DIB3000MB_MOBILE_MODE_OFF                       (     0)
 272 
 273 #define DIB3000MB_REG_UNK_106                   (   106)
 274 #define DIB3000MB_UNK_106                                       (0x0080)
 275 
 276 #define DIB3000MB_REG_UNK_107                   (   107)
 277 #define DIB3000MB_UNK_107                                       (0x0080)
 278 
 279 #define DIB3000MB_REG_UNK_108                   (   108)
 280 #define DIB3000MB_UNK_108                                       (0x0080)
 281 
 282 
 283 #define DIB3000MB_REG_UNK_121                   (   121)
 284 #define DIB3000MB_UNK_121_2K                            (     7)
 285 #define DIB3000MB_UNK_121_DEFAULT                       (     5)
 286 
 287 #define DIB3000MB_REG_UNK_122                   (   122)
 288 #define DIB3000MB_UNK_122                                       (  2867)
 289 
 290 
 291 #define DIB3000MB_REG_MOBILE_MODE_QAM   (   126)
 292 #define DIB3000MB_MOBILE_MODE_QAM_64            (     3)
 293 #define DIB3000MB_MOBILE_MODE_QAM_QPSK_16       (     1)
 294 #define DIB3000MB_MOBILE_MODE_QAM_OFF           (     0)
 295 
 296 
 297 
 298 
 299 
 300 #define DIB3000MB_REG_DATA_IN_DIVERSITY         (   127)
 301 #define DIB3000MB_DATA_DIVERSITY_IN_OFF                 (     0)
 302 #define DIB3000MB_DATA_DIVERSITY_IN_ON                  (     2)
 303 
 304 
 305 #define DIB3000MB_REG_VIT_HRCH                  (   128)
 306 
 307 
 308 #define DIB3000MB_REG_VIT_CODE_RATE             (   129)
 309 
 310 
 311 #define DIB3000MB_REG_VIT_HP                    (   130)
 312 
 313 
 314 #define DIB3000MB_REG_BERLEN                    (   135)
 315 #define DIB3000MB_BERLEN_LONG                           (     0)
 316 #define DIB3000MB_BERLEN_DEFAULT                        (     1)
 317 #define DIB3000MB_BERLEN_MEDIUM                         (     2)
 318 #define DIB3000MB_BERLEN_SHORT                          (     3)
 319 
 320 
 321 
 322 
 323 
 324 #define DIB3000MB_REG_FIFO_142                  (   142)
 325 #define DIB3000MB_FIFO_142                                      (     0)
 326 
 327 
 328 #define DIB3000MB_REG_MPEG2_OUT_MODE    (   143)
 329 #define DIB3000MB_MPEG2_OUT_MODE_204            (     0)
 330 #define DIB3000MB_MPEG2_OUT_MODE_188            (     1)
 331 
 332 #define DIB3000MB_REG_PID_PARSE                 (   144)
 333 #define DIB3000MB_PID_PARSE_INHIBIT             (     0)
 334 #define DIB3000MB_PID_PARSE_ACTIVATE    (     1)
 335 
 336 #define DIB3000MB_REG_FIFO                              (   145)
 337 #define DIB3000MB_FIFO_INHIBIT                          (     1)
 338 #define DIB3000MB_FIFO_ACTIVATE                         (     0)
 339 
 340 #define DIB3000MB_REG_FIFO_146                  (   146)
 341 #define DIB3000MB_FIFO_146                                      (     3)
 342 
 343 #define DIB3000MB_REG_FIFO_147                  (   147)
 344 #define DIB3000MB_FIFO_147                                      (0x0100)
 345 
 346 
 347 
 348 
 349 
 350 
 351 
 352 
 353 #define DIB3000MB_REG_FIRST_PID                 (   153)
 354 #define DIB3000MB_NUM_PIDS                              (    16)
 355 
 356 
 357 
 358 
 359 
 360 
 361 #define DIB3000MB_REG_OUTPUT_MODE               (   169)
 362 #define DIB3000MB_OUTPUT_MODE_GATED_CLK         (     0)
 363 #define DIB3000MB_OUTPUT_MODE_CONT_CLK          (     1)
 364 #define DIB3000MB_OUTPUT_MODE_SERIAL            (     2)
 365 #define DIB3000MB_OUTPUT_MODE_DATA_DIVERSITY    (     5)
 366 #define DIB3000MB_OUTPUT_MODE_SLAVE                     (     6)
 367 
 368 
 369 #define DIB3000MB_REG_IRQ_EVENT_MASK            (   170)
 370 #define DIB3000MB_IRQ_EVENT_MASK                                (     0)
 371 
 372 
 373 static u16 dib3000mb_reg_filter_coeffs[] = {
 374         171, 172, 173, 174, 175, 176, 177, 178,
 375         179, 180, 181, 182, 183, 184, 185, 186,
 376         188, 189, 190, 191, 192, 194
 377 };
 378 
 379 static u16 dib3000mb_filter_coeffs[] = {
 380          226,  160,   29,
 381          979,  998,   19,
 382           22, 1019, 1006,
 383         1022,   12,    6,
 384         1017, 1017,    3,
 385            6,       1019,
 386         1021,    2,    3,
 387            1,          0,
 388 };
 389 
 390 
 391 
 392 
 393 
 394 #define DIB3000MB_REG_MOBILE_ALGO               (   195)
 395 #define DIB3000MB_MOBILE_ALGO_ON                        (     0)
 396 #define DIB3000MB_MOBILE_ALGO_OFF                       (     1)
 397 
 398 
 399 #define DIB3000MB_REG_MULTI_DEMOD_MSB   (   206)
 400 #define DIB3000MB_REG_MULTI_DEMOD_LSB   (   207)
 401 
 402 
 403 #define DIB3000MB_MULTI_DEMOD_MSB                       ( 32767)
 404 #define DIB3000MB_MULTI_DEMOD_LSB                       (  4095)
 405 
 406 
 407 #define DIB3000MB_REG_RESET_DEVICE              (  1024)
 408 #define DIB3000MB_RESET_DEVICE                          (0x812c)
 409 #define DIB3000MB_RESET_DEVICE_RST                      (     0)
 410 
 411 
 412 #define DIB3000MB_REG_CLOCK                             (  1027)
 413 #define DIB3000MB_CLOCK_DEFAULT                         (0x9000)
 414 #define DIB3000MB_CLOCK_DIVERSITY                       (0x92b0)
 415 
 416 
 417 #define DIB3000MB_REG_POWER_CONTROL             (  1028)
 418 #define DIB3000MB_POWER_DOWN                            (     1)
 419 #define DIB3000MB_POWER_UP                                      (     0)
 420 
 421 
 422 #define DIB3000MB_REG_ELECT_OUT_MODE    (  1029)
 423 #define DIB3000MB_ELECT_OUT_MODE_OFF            (     0)
 424 #define DIB3000MB_ELECT_OUT_MODE_ON                     (     1)
 425 
 426 
 427 #define DIB3000MB_REG_TUNER                             (  1089)
 428 
 429 
 430 
 431 
 432 #define DIB3000MB_REG_AGC_LOCK                  (   324)
 433 
 434 
 435 #define DIB3000MB_REG_AGC_POWER                 (   325)
 436 
 437 
 438 #define DIB3000MB_REG_AGC1_VALUE                (   326)
 439 
 440 
 441 #define DIB3000MB_REG_AGC2_VALUE                (   327)
 442 
 443 
 444 #define DIB3000MB_REG_RF_POWER                  (   328)
 445 
 446 
 447 #define DIB3000MB_REG_DDS_VALUE_MSB             (   339)
 448 #define DIB3000MB_REG_DDS_VALUE_LSB             (   340)
 449 
 450 
 451 #define DIB3000MB_REG_TIMING_OFFSET_MSB (   341)
 452 #define DIB3000MB_REG_TIMING_OFFSET_LSB (   342)
 453 
 454 
 455 #define DIB3000MB_REG_FFT_WINDOW_POS    (   353)
 456 
 457 
 458 #define DIB3000MB_REG_CARRIER_LOCK              (   355)
 459 
 460 
 461 #define DIB3000MB_REG_NOISE_POWER_MSB   (   372)
 462 #define DIB3000MB_REG_NOISE_POWER_LSB   (   373)
 463 
 464 #define DIB3000MB_REG_MOBILE_NOISE_MSB  (   374)
 465 #define DIB3000MB_REG_MOBILE_NOISE_LSB  (   375)
 466 
 467 
 468 
 469 
 470 
 471 #define DIB3000MB_REG_SIGNAL_POWER              (   380)
 472 
 473 
 474 #define DIB3000MB_REG_MER_MSB                   (   381)
 475 #define DIB3000MB_REG_MER_LSB                   (   382)
 476 
 477 
 478 
 479 
 480 
 481 
 482 
 483 
 484 #define DIB3000MB_REG_TPS_LOCK                  (   394)
 485 
 486 
 487 #define DIB3000MB_REG_TPS_QAM                   (   398)
 488 
 489 
 490 #define DIB3000MB_REG_TPS_HRCH                  (   399)
 491 
 492 
 493 #define DIB3000MB_REG_TPS_VIT_ALPHA             (   400)
 494 
 495 
 496 #define DIB3000MB_REG_TPS_CODE_RATE_HP  (   401)
 497 
 498 
 499 #define DIB3000MB_REG_TPS_CODE_RATE_LP  (   402)
 500 
 501 
 502 #define DIB3000MB_REG_TPS_GUARD_TIME    (   403)
 503 
 504 
 505 #define DIB3000MB_REG_TPS_FFT                   (   404)
 506 
 507 
 508 #define DIB3000MB_REG_TPS_CELL_ID               (   406)
 509 
 510 
 511 #define DIB3000MB_REG_TPS_1                             (   408)
 512 #define DIB3000MB_REG_TPS_2                             (   409)
 513 #define DIB3000MB_REG_TPS_3                             (   410)
 514 #define DIB3000MB_REG_TPS_4                             (   411)
 515 #define DIB3000MB_REG_TPS_5                             (   412)
 516 
 517 
 518 #define DIB3000MB_REG_BER_MSB                   (   414)
 519 #define DIB3000MB_REG_BER_LSB                   (   415)
 520 
 521 
 522 #define DIB3000MB_REG_PACKET_ERROR_RATE (   417)
 523 
 524 
 525 #define DIB3000MB_REG_UNC                               (   420)
 526 
 527 
 528 #define DIB3000MB_REG_VIT_LCK                   (   421)
 529 
 530 
 531 #define DIB3000MB_REG_VIT_INDICATOR             (   422)
 532 
 533 
 534 #define DIB3000MB_REG_TS_SYNC_LOCK              (   423)
 535 
 536 
 537 #define DIB3000MB_REG_TS_RS_LOCK                (   424)
 538 
 539 
 540 #define DIB3000MB_REG_LOCK0_VALUE               (   425)
 541 
 542 
 543 #define DIB3000MB_REG_LOCK1_VALUE               (   426)
 544 
 545 
 546 #define DIB3000MB_REG_LOCK2_VALUE               (   427)
 547 
 548 
 549 #define DIB3000MB_REG_AS_IRQ_PENDING    (   434)
 550 
 551 #endif