2 * drxk_hard: DRX-K DVB-C/T demodulator driver
4 * Copyright (C) 2010-2011 Digital Devices GmbH
6 * This program is free software; you can redistribute it and/or
7 * modify it under the terms of the GNU General Public License
8 * version 2 only, as published by the Free Software Foundation.
11 * This program is distributed in the hope that it will be useful,
12 * but WITHOUT ANY WARRANTY; without even the implied warranty of
13 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
14 * GNU General Public License for more details.
17 * You should have received a copy of the GNU General Public License
18 * along with this program; if not, write to the Free Software
19 * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA
21 * Or, point your browser to http://www.gnu.org/copyleft/gpl.html
24 #include <linux/kernel.h>
25 #include <linux/module.h>
26 #include <linux/moduleparam.h>
27 #include <linux/init.h>
28 #include <linux/delay.h>
29 #include <linux/firmware.h>
30 #include <linux/i2c.h>
31 #include <linux/hardirq.h>
32 #include <asm/div64.h>
34 #include "dvb_frontend.h"
36 #include "drxk_hard.h"
39 static int power_down_dvbt(struct drxk_state *state, bool set_power_mode);
40 static int power_down_qam(struct drxk_state *state);
41 static int set_dvbt_standard(struct drxk_state *state,
42 enum operation_mode o_mode);
43 static int set_qam_standard(struct drxk_state *state,
44 enum operation_mode o_mode);
45 static int set_qam(struct drxk_state *state, u16 intermediate_freqk_hz,
46 s32 tuner_freq_offset);
47 static int set_dvbt_standard(struct drxk_state *state,
48 enum operation_mode o_mode);
49 static int dvbt_start(struct drxk_state *state);
50 static int set_dvbt(struct drxk_state *state, u16 intermediate_freqk_hz,
51 s32 tuner_freq_offset);
52 static int get_qam_lock_status(struct drxk_state *state, u32 *p_lock_status);
53 static int get_dvbt_lock_status(struct drxk_state *state, u32 *p_lock_status);
54 static int switch_antenna_to_qam(struct drxk_state *state);
55 static int switch_antenna_to_dvbt(struct drxk_state *state);
57 static bool is_dvbt(struct drxk_state *state)
59 return state->m_operation_mode == OM_DVBT;
62 static bool is_qam(struct drxk_state *state)
64 return state->m_operation_mode == OM_QAM_ITU_A ||
65 state->m_operation_mode == OM_QAM_ITU_B ||
66 state->m_operation_mode == OM_QAM_ITU_C;
71 #define DRXDAP_FASI_SHORT_FORMAT(addr) (((addr) & 0xFC30FF80) == 0)
72 #define DRXDAP_FASI_LONG_FORMAT(addr) (((addr) & 0xFC30FF80) != 0)
74 #define DEFAULT_MER_83 165
75 #define DEFAULT_MER_93 250
77 #ifndef DRXK_MPEG_SERIAL_OUTPUT_PIN_DRIVE_STRENGTH
78 #define DRXK_MPEG_SERIAL_OUTPUT_PIN_DRIVE_STRENGTH (0x02)
81 #ifndef DRXK_MPEG_PARALLEL_OUTPUT_PIN_DRIVE_STRENGTH
82 #define DRXK_MPEG_PARALLEL_OUTPUT_PIN_DRIVE_STRENGTH (0x03)
85 #define DEFAULT_DRXK_MPEG_LOCK_TIMEOUT 700
86 #define DEFAULT_DRXK_DEMOD_LOCK_TIMEOUT 500
88 #ifndef DRXK_KI_RAGC_ATV
89 #define DRXK_KI_RAGC_ATV 4
91 #ifndef DRXK_KI_IAGC_ATV
92 #define DRXK_KI_IAGC_ATV 6
94 #ifndef DRXK_KI_DAGC_ATV
95 #define DRXK_KI_DAGC_ATV 7
98 #ifndef DRXK_KI_RAGC_QAM
99 #define DRXK_KI_RAGC_QAM 3
101 #ifndef DRXK_KI_IAGC_QAM
102 #define DRXK_KI_IAGC_QAM 4
104 #ifndef DRXK_KI_DAGC_QAM
105 #define DRXK_KI_DAGC_QAM 7
107 #ifndef DRXK_KI_RAGC_DVBT
108 #define DRXK_KI_RAGC_DVBT (IsA1WithPatchCode(state) ? 3 : 2)
110 #ifndef DRXK_KI_IAGC_DVBT
111 #define DRXK_KI_IAGC_DVBT (IsA1WithPatchCode(state) ? 4 : 2)
113 #ifndef DRXK_KI_DAGC_DVBT
114 #define DRXK_KI_DAGC_DVBT (IsA1WithPatchCode(state) ? 10 : 7)
117 #ifndef DRXK_AGC_DAC_OFFSET
118 #define DRXK_AGC_DAC_OFFSET (0x800)
121 #ifndef DRXK_BANDWIDTH_8MHZ_IN_HZ
122 #define DRXK_BANDWIDTH_8MHZ_IN_HZ (0x8B8249L)
125 #ifndef DRXK_BANDWIDTH_7MHZ_IN_HZ
126 #define DRXK_BANDWIDTH_7MHZ_IN_HZ (0x7A1200L)
129 #ifndef DRXK_BANDWIDTH_6MHZ_IN_HZ
130 #define DRXK_BANDWIDTH_6MHZ_IN_HZ (0x68A1B6L)
133 #ifndef DRXK_QAM_SYMBOLRATE_MAX
134 #define DRXK_QAM_SYMBOLRATE_MAX (7233000)
137 #define DRXK_BL_ROM_OFFSET_TAPS_DVBT 56
138 #define DRXK_BL_ROM_OFFSET_TAPS_ITU_A 64
139 #define DRXK_BL_ROM_OFFSET_TAPS_ITU_C 0x5FE0
140 #define DRXK_BL_ROM_OFFSET_TAPS_BG 24
141 #define DRXK_BL_ROM_OFFSET_TAPS_DKILLP 32
142 #define DRXK_BL_ROM_OFFSET_TAPS_NTSC 40
143 #define DRXK_BL_ROM_OFFSET_TAPS_FM 48
144 #define DRXK_BL_ROM_OFFSET_UCODE 0
146 #define DRXK_BLC_TIMEOUT 100
148 #define DRXK_BLCC_NR_ELEMENTS_TAPS 2
149 #define DRXK_BLCC_NR_ELEMENTS_UCODE 6
151 #define DRXK_BLDC_NR_ELEMENTS_TAPS 28
153 #ifndef DRXK_OFDM_NE_NOTCH_WIDTH
154 #define DRXK_OFDM_NE_NOTCH_WIDTH (4)
157 #define DRXK_QAM_SL_SIG_POWER_QAM16 (40960)
158 #define DRXK_QAM_SL_SIG_POWER_QAM32 (20480)
159 #define DRXK_QAM_SL_SIG_POWER_QAM64 (43008)
160 #define DRXK_QAM_SL_SIG_POWER_QAM128 (20992)
161 #define DRXK_QAM_SL_SIG_POWER_QAM256 (43520)
163 static unsigned int debug;
164 module_param(debug, int, 0644);
165 MODULE_PARM_DESC(debug, "enable debug messages");
167 #define dprintk(level, fmt, arg...) do { \
168 if (debug >= level) \
169 printk(KERN_DEBUG "drxk: %s" fmt, __func__, ## arg); \
173 static inline u32 MulDiv32(u32 a, u32 b, u32 c)
177 tmp64 = (u64) a * (u64) b;
183 static inline u32 Frac28a(u32 a, u32 c)
189 R0 = (a % c) << 4; /* 32-28 == 4 shifts possible at max */
190 Q1 = a / c; /* integer part, only the 4 least significant bits
191 will be visible in the result */
193 /* division using radix 16, 7 nibbles in the result */
194 for (i = 0; i < 7; i++) {
195 Q1 = (Q1 << 4) | (R0 / c);
205 static inline u32 log10times100(u32 value)
207 return (100L * intlog10(value)) >> 24;
210 /****************************************************************************/
211 /* I2C **********************************************************************/
212 /****************************************************************************/
214 static int drxk_i2c_lock(struct drxk_state *state)
216 i2c_lock_adapter(state->i2c);
217 state->drxk_i2c_exclusive_lock = true;
222 static void drxk_i2c_unlock(struct drxk_state *state)
224 if (!state->drxk_i2c_exclusive_lock)
227 i2c_unlock_adapter(state->i2c);
228 state->drxk_i2c_exclusive_lock = false;
231 static int drxk_i2c_transfer(struct drxk_state *state, struct i2c_msg *msgs,
234 if (state->drxk_i2c_exclusive_lock)
235 return __i2c_transfer(state->i2c, msgs, len);
237 return i2c_transfer(state->i2c, msgs, len);
240 static int i2c_read1(struct drxk_state *state, u8 adr, u8 *val)
242 struct i2c_msg msgs[1] = { {.addr = adr, .flags = I2C_M_RD,
243 .buf = val, .len = 1}
246 return drxk_i2c_transfer(state, msgs, 1);
249 static int i2c_write(struct drxk_state *state, u8 adr, u8 *data, int len)
252 struct i2c_msg msg = {
253 .addr = adr, .flags = 0, .buf = data, .len = len };
258 for (i = 0; i < len; i++)
259 printk(KERN_CONT " %02x", data[i]);
260 printk(KERN_CONT "\n");
262 status = drxk_i2c_transfer(state, &msg, 1);
263 if (status >= 0 && status != 1)
267 printk(KERN_ERR "drxk: i2c write error at addr 0x%02x\n", adr);
272 static int i2c_read(struct drxk_state *state,
273 u8 adr, u8 *msg, int len, u8 *answ, int alen)
276 struct i2c_msg msgs[2] = {
277 {.addr = adr, .flags = 0,
278 .buf = msg, .len = len},
279 {.addr = adr, .flags = I2C_M_RD,
280 .buf = answ, .len = alen}
283 status = drxk_i2c_transfer(state, msgs, 2);
286 printk(KERN_CONT ": ERROR!\n");
290 printk(KERN_ERR "drxk: i2c read error at addr 0x%02x\n", adr);
295 dprintk(2, ": read from");
296 for (i = 0; i < len; i++)
297 printk(KERN_CONT " %02x", msg[i]);
298 printk(KERN_CONT ", value = ");
299 for (i = 0; i < alen; i++)
300 printk(KERN_CONT " %02x", answ[i]);
301 printk(KERN_CONT "\n");
306 static int read16_flags(struct drxk_state *state, u32 reg, u16 *data, u8 flags)
309 u8 adr = state->demod_address, mm1[4], mm2[2], len;
311 if (state->single_master)
314 if (DRXDAP_FASI_LONG_FORMAT(reg) || (flags != 0)) {
315 mm1[0] = (((reg << 1) & 0xFF) | 0x01);
316 mm1[1] = ((reg >> 16) & 0xFF);
317 mm1[2] = ((reg >> 24) & 0xFF) | flags;
318 mm1[3] = ((reg >> 7) & 0xFF);
321 mm1[0] = ((reg << 1) & 0xFF);
322 mm1[1] = (((reg >> 16) & 0x0F) | ((reg >> 18) & 0xF0));
325 dprintk(2, "(0x%08x, 0x%02x)\n", reg, flags);
326 status = i2c_read(state, adr, mm1, len, mm2, 2);
330 *data = mm2[0] | (mm2[1] << 8);
335 static int read16(struct drxk_state *state, u32 reg, u16 *data)
337 return read16_flags(state, reg, data, 0);
340 static int read32_flags(struct drxk_state *state, u32 reg, u32 *data, u8 flags)
343 u8 adr = state->demod_address, mm1[4], mm2[4], len;
345 if (state->single_master)
348 if (DRXDAP_FASI_LONG_FORMAT(reg) || (flags != 0)) {
349 mm1[0] = (((reg << 1) & 0xFF) | 0x01);
350 mm1[1] = ((reg >> 16) & 0xFF);
351 mm1[2] = ((reg >> 24) & 0xFF) | flags;
352 mm1[3] = ((reg >> 7) & 0xFF);
355 mm1[0] = ((reg << 1) & 0xFF);
356 mm1[1] = (((reg >> 16) & 0x0F) | ((reg >> 18) & 0xF0));
359 dprintk(2, "(0x%08x, 0x%02x)\n", reg, flags);
360 status = i2c_read(state, adr, mm1, len, mm2, 4);
364 *data = mm2[0] | (mm2[1] << 8) |
365 (mm2[2] << 16) | (mm2[3] << 24);
370 static int read32(struct drxk_state *state, u32 reg, u32 *data)
372 return read32_flags(state, reg, data, 0);
375 static int write16_flags(struct drxk_state *state, u32 reg, u16 data, u8 flags)
377 u8 adr = state->demod_address, mm[6], len;
379 if (state->single_master)
381 if (DRXDAP_FASI_LONG_FORMAT(reg) || (flags != 0)) {
382 mm[0] = (((reg << 1) & 0xFF) | 0x01);
383 mm[1] = ((reg >> 16) & 0xFF);
384 mm[2] = ((reg >> 24) & 0xFF) | flags;
385 mm[3] = ((reg >> 7) & 0xFF);
388 mm[0] = ((reg << 1) & 0xFF);
389 mm[1] = (((reg >> 16) & 0x0F) | ((reg >> 18) & 0xF0));
392 mm[len] = data & 0xff;
393 mm[len + 1] = (data >> 8) & 0xff;
395 dprintk(2, "(0x%08x, 0x%04x, 0x%02x)\n", reg, data, flags);
396 return i2c_write(state, adr, mm, len + 2);
399 static int write16(struct drxk_state *state, u32 reg, u16 data)
401 return write16_flags(state, reg, data, 0);
404 static int write32_flags(struct drxk_state *state, u32 reg, u32 data, u8 flags)
406 u8 adr = state->demod_address, mm[8], len;
408 if (state->single_master)
410 if (DRXDAP_FASI_LONG_FORMAT(reg) || (flags != 0)) {
411 mm[0] = (((reg << 1) & 0xFF) | 0x01);
412 mm[1] = ((reg >> 16) & 0xFF);
413 mm[2] = ((reg >> 24) & 0xFF) | flags;
414 mm[3] = ((reg >> 7) & 0xFF);
417 mm[0] = ((reg << 1) & 0xFF);
418 mm[1] = (((reg >> 16) & 0x0F) | ((reg >> 18) & 0xF0));
421 mm[len] = data & 0xff;
422 mm[len + 1] = (data >> 8) & 0xff;
423 mm[len + 2] = (data >> 16) & 0xff;
424 mm[len + 3] = (data >> 24) & 0xff;
425 dprintk(2, "(0x%08x, 0x%08x, 0x%02x)\n", reg, data, flags);
427 return i2c_write(state, adr, mm, len + 4);
430 static int write32(struct drxk_state *state, u32 reg, u32 data)
432 return write32_flags(state, reg, data, 0);
435 static int write_block(struct drxk_state *state, u32 address,
436 const int block_size, const u8 p_block[])
438 int status = 0, blk_size = block_size;
441 if (state->single_master)
444 while (blk_size > 0) {
445 int chunk = blk_size > state->m_chunk_size ?
446 state->m_chunk_size : blk_size;
447 u8 *adr_buf = &state->chunk[0];
450 if (DRXDAP_FASI_LONG_FORMAT(address) || (flags != 0)) {
451 adr_buf[0] = (((address << 1) & 0xFF) | 0x01);
452 adr_buf[1] = ((address >> 16) & 0xFF);
453 adr_buf[2] = ((address >> 24) & 0xFF);
454 adr_buf[3] = ((address >> 7) & 0xFF);
457 if (chunk == state->m_chunk_size)
460 adr_buf[0] = ((address << 1) & 0xFF);
461 adr_buf[1] = (((address >> 16) & 0x0F) |
462 ((address >> 18) & 0xF0));
465 memcpy(&state->chunk[adr_length], p_block, chunk);
466 dprintk(2, "(0x%08x, 0x%02x)\n", address, flags);
470 for (i = 0; i < chunk; i++)
471 printk(KERN_CONT " %02x", p_block[i]);
472 printk(KERN_CONT "\n");
474 status = i2c_write(state, state->demod_address,
475 &state->chunk[0], chunk + adr_length);
477 printk(KERN_ERR "drxk: %s: i2c write error at addr 0x%02x\n",
482 address += (chunk >> 1);
488 #ifndef DRXK_MAX_RETRIES_POWERUP
489 #define DRXK_MAX_RETRIES_POWERUP 20
492 static int power_up_device(struct drxk_state *state)
500 status = i2c_read1(state, state->demod_address, &data);
504 status = i2c_write(state, state->demod_address,
510 status = i2c_read1(state, state->demod_address,
512 } while (status < 0 &&
513 (retry_count < DRXK_MAX_RETRIES_POWERUP));
514 if (status < 0 && retry_count >= DRXK_MAX_RETRIES_POWERUP)
518 /* Make sure all clk domains are active */
519 status = write16(state, SIO_CC_PWD_MODE__A, SIO_CC_PWD_MODE_LEVEL_NONE);
522 status = write16(state, SIO_CC_UPDATE__A, SIO_CC_UPDATE_KEY);
525 /* Enable pll lock tests */
526 status = write16(state, SIO_CC_PLL_LOCK__A, 1);
530 state->m_current_power_mode = DRX_POWER_UP;
534 printk(KERN_ERR "drxk: Error %d on %s\n", status, __func__);
540 static int init_state(struct drxk_state *state)
543 * FIXME: most (all?) of the values bellow should be moved into
544 * struct drxk_config, as they are probably board-specific
546 u32 ul_vsb_if_agc_mode = DRXK_AGC_CTRL_AUTO;
547 u32 ul_vsb_if_agc_output_level = 0;
548 u32 ul_vsb_if_agc_min_level = 0;
549 u32 ul_vsb_if_agc_max_level = 0x7FFF;
550 u32 ul_vsb_if_agc_speed = 3;
552 u32 ul_vsb_rf_agc_mode = DRXK_AGC_CTRL_AUTO;
553 u32 ul_vsb_rf_agc_output_level = 0;
554 u32 ul_vsb_rf_agc_min_level = 0;
555 u32 ul_vsb_rf_agc_max_level = 0x7FFF;
556 u32 ul_vsb_rf_agc_speed = 3;
557 u32 ul_vsb_rf_agc_top = 9500;
558 u32 ul_vsb_rf_agc_cut_off_current = 4000;
560 u32 ul_atv_if_agc_mode = DRXK_AGC_CTRL_AUTO;
561 u32 ul_atv_if_agc_output_level = 0;
562 u32 ul_atv_if_agc_min_level = 0;
563 u32 ul_atv_if_agc_max_level = 0;
564 u32 ul_atv_if_agc_speed = 3;
566 u32 ul_atv_rf_agc_mode = DRXK_AGC_CTRL_OFF;
567 u32 ul_atv_rf_agc_output_level = 0;
568 u32 ul_atv_rf_agc_min_level = 0;
569 u32 ul_atv_rf_agc_max_level = 0;
570 u32 ul_atv_rf_agc_top = 9500;
571 u32 ul_atv_rf_agc_cut_off_current = 4000;
572 u32 ul_atv_rf_agc_speed = 3;
574 u32 ulQual83 = DEFAULT_MER_83;
575 u32 ulQual93 = DEFAULT_MER_93;
577 u32 ul_mpeg_lock_time_out = DEFAULT_DRXK_MPEG_LOCK_TIMEOUT;
578 u32 ul_demod_lock_time_out = DEFAULT_DRXK_DEMOD_LOCK_TIMEOUT;
580 /* io_pad_cfg register (8 bit reg.) MSB bit is 1 (default value) */
581 /* io_pad_cfg_mode output mode is drive always */
582 /* io_pad_cfg_drive is set to power 2 (23 mA) */
583 u32 ul_gpio_cfg = 0x0113;
584 u32 ul_invert_ts_clock = 0;
585 u32 ul_ts_data_strength = DRXK_MPEG_SERIAL_OUTPUT_PIN_DRIVE_STRENGTH;
586 u32 ul_dvbt_bitrate = 50000000;
587 u32 ul_dvbc_bitrate = DRXK_QAM_SYMBOLRATE_MAX * 8;
589 u32 ul_insert_rs_byte = 0;
591 u32 ul_rf_mirror = 1;
592 u32 ul_power_down = 0;
596 state->m_has_lna = false;
597 state->m_has_dvbt = false;
598 state->m_has_dvbc = false;
599 state->m_has_atv = false;
600 state->m_has_oob = false;
601 state->m_has_audio = false;
603 if (!state->m_chunk_size)
604 state->m_chunk_size = 124;
606 state->m_osc_clock_freq = 0;
607 state->m_smart_ant_inverted = false;
608 state->m_b_p_down_open_bridge = false;
610 /* real system clock frequency in kHz */
611 state->m_sys_clock_freq = 151875;
612 /* Timing div, 250ns/Psys */
613 /* Timing div, = (delay (nano seconds) * sysclk (kHz))/ 1000 */
614 state->m_hi_cfg_timing_div = ((state->m_sys_clock_freq / 1000) *
615 HI_I2C_DELAY) / 1000;
617 if (state->m_hi_cfg_timing_div > SIO_HI_RA_RAM_PAR_2_CFG_DIV__M)
618 state->m_hi_cfg_timing_div = SIO_HI_RA_RAM_PAR_2_CFG_DIV__M;
619 state->m_hi_cfg_wake_up_key = (state->demod_address << 1);
620 /* port/bridge/power down ctrl */
621 state->m_hi_cfg_ctrl = SIO_HI_RA_RAM_PAR_5_CFG_SLV0_SLAVE;
623 state->m_b_power_down = (ul_power_down != 0);
625 state->m_drxk_a3_patch_code = false;
627 /* Init AGC and PGA parameters */
629 state->m_vsb_if_agc_cfg.ctrl_mode = (ul_vsb_if_agc_mode);
630 state->m_vsb_if_agc_cfg.output_level = (ul_vsb_if_agc_output_level);
631 state->m_vsb_if_agc_cfg.min_output_level = (ul_vsb_if_agc_min_level);
632 state->m_vsb_if_agc_cfg.max_output_level = (ul_vsb_if_agc_max_level);
633 state->m_vsb_if_agc_cfg.speed = (ul_vsb_if_agc_speed);
634 state->m_vsb_pga_cfg = 140;
637 state->m_vsb_rf_agc_cfg.ctrl_mode = (ul_vsb_rf_agc_mode);
638 state->m_vsb_rf_agc_cfg.output_level = (ul_vsb_rf_agc_output_level);
639 state->m_vsb_rf_agc_cfg.min_output_level = (ul_vsb_rf_agc_min_level);
640 state->m_vsb_rf_agc_cfg.max_output_level = (ul_vsb_rf_agc_max_level);
641 state->m_vsb_rf_agc_cfg.speed = (ul_vsb_rf_agc_speed);
642 state->m_vsb_rf_agc_cfg.top = (ul_vsb_rf_agc_top);
643 state->m_vsb_rf_agc_cfg.cut_off_current = (ul_vsb_rf_agc_cut_off_current);
644 state->m_vsb_pre_saw_cfg.reference = 0x07;
645 state->m_vsb_pre_saw_cfg.use_pre_saw = true;
647 state->m_Quality83percent = DEFAULT_MER_83;
648 state->m_Quality93percent = DEFAULT_MER_93;
649 if (ulQual93 <= 500 && ulQual83 < ulQual93) {
650 state->m_Quality83percent = ulQual83;
651 state->m_Quality93percent = ulQual93;
655 state->m_atv_if_agc_cfg.ctrl_mode = (ul_atv_if_agc_mode);
656 state->m_atv_if_agc_cfg.output_level = (ul_atv_if_agc_output_level);
657 state->m_atv_if_agc_cfg.min_output_level = (ul_atv_if_agc_min_level);
658 state->m_atv_if_agc_cfg.max_output_level = (ul_atv_if_agc_max_level);
659 state->m_atv_if_agc_cfg.speed = (ul_atv_if_agc_speed);
662 state->m_atv_rf_agc_cfg.ctrl_mode = (ul_atv_rf_agc_mode);
663 state->m_atv_rf_agc_cfg.output_level = (ul_atv_rf_agc_output_level);
664 state->m_atv_rf_agc_cfg.min_output_level = (ul_atv_rf_agc_min_level);
665 state->m_atv_rf_agc_cfg.max_output_level = (ul_atv_rf_agc_max_level);
666 state->m_atv_rf_agc_cfg.speed = (ul_atv_rf_agc_speed);
667 state->m_atv_rf_agc_cfg.top = (ul_atv_rf_agc_top);
668 state->m_atv_rf_agc_cfg.cut_off_current = (ul_atv_rf_agc_cut_off_current);
669 state->m_atv_pre_saw_cfg.reference = 0x04;
670 state->m_atv_pre_saw_cfg.use_pre_saw = true;
674 state->m_dvbt_rf_agc_cfg.ctrl_mode = DRXK_AGC_CTRL_OFF;
675 state->m_dvbt_rf_agc_cfg.output_level = 0;
676 state->m_dvbt_rf_agc_cfg.min_output_level = 0;
677 state->m_dvbt_rf_agc_cfg.max_output_level = 0xFFFF;
678 state->m_dvbt_rf_agc_cfg.top = 0x2100;
679 state->m_dvbt_rf_agc_cfg.cut_off_current = 4000;
680 state->m_dvbt_rf_agc_cfg.speed = 1;
684 state->m_dvbt_if_agc_cfg.ctrl_mode = DRXK_AGC_CTRL_AUTO;
685 state->m_dvbt_if_agc_cfg.output_level = 0;
686 state->m_dvbt_if_agc_cfg.min_output_level = 0;
687 state->m_dvbt_if_agc_cfg.max_output_level = 9000;
688 state->m_dvbt_if_agc_cfg.top = 13424;
689 state->m_dvbt_if_agc_cfg.cut_off_current = 0;
690 state->m_dvbt_if_agc_cfg.speed = 3;
691 state->m_dvbt_if_agc_cfg.fast_clip_ctrl_delay = 30;
692 state->m_dvbt_if_agc_cfg.ingain_tgt_max = 30000;
693 /* state->m_dvbtPgaCfg = 140; */
695 state->m_dvbt_pre_saw_cfg.reference = 4;
696 state->m_dvbt_pre_saw_cfg.use_pre_saw = false;
699 state->m_qam_rf_agc_cfg.ctrl_mode = DRXK_AGC_CTRL_OFF;
700 state->m_qam_rf_agc_cfg.output_level = 0;
701 state->m_qam_rf_agc_cfg.min_output_level = 6023;
702 state->m_qam_rf_agc_cfg.max_output_level = 27000;
703 state->m_qam_rf_agc_cfg.top = 0x2380;
704 state->m_qam_rf_agc_cfg.cut_off_current = 4000;
705 state->m_qam_rf_agc_cfg.speed = 3;
708 state->m_qam_if_agc_cfg.ctrl_mode = DRXK_AGC_CTRL_AUTO;
709 state->m_qam_if_agc_cfg.output_level = 0;
710 state->m_qam_if_agc_cfg.min_output_level = 0;
711 state->m_qam_if_agc_cfg.max_output_level = 9000;
712 state->m_qam_if_agc_cfg.top = 0x0511;
713 state->m_qam_if_agc_cfg.cut_off_current = 0;
714 state->m_qam_if_agc_cfg.speed = 3;
715 state->m_qam_if_agc_cfg.ingain_tgt_max = 5119;
716 state->m_qam_if_agc_cfg.fast_clip_ctrl_delay = 50;
718 state->m_qam_pga_cfg = 140;
719 state->m_qam_pre_saw_cfg.reference = 4;
720 state->m_qam_pre_saw_cfg.use_pre_saw = false;
722 state->m_operation_mode = OM_NONE;
723 state->m_drxk_state = DRXK_UNINITIALIZED;
725 /* MPEG output configuration */
726 state->m_enable_mpeg_output = true; /* If TRUE; enable MPEG ouput */
727 state->m_insert_rs_byte = false; /* If TRUE; insert RS byte */
728 state->m_invert_data = false; /* If TRUE; invert DATA signals */
729 state->m_invert_err = false; /* If TRUE; invert ERR signal */
730 state->m_invert_str = false; /* If TRUE; invert STR signals */
731 state->m_invert_val = false; /* If TRUE; invert VAL signals */
732 state->m_invert_clk = (ul_invert_ts_clock != 0); /* If TRUE; invert CLK signals */
734 /* If TRUE; static MPEG clockrate will be used;
735 otherwise clockrate will adapt to the bitrate of the TS */
737 state->m_dvbt_bitrate = ul_dvbt_bitrate;
738 state->m_dvbc_bitrate = ul_dvbc_bitrate;
740 state->m_ts_data_strength = (ul_ts_data_strength & 0x07);
742 /* Maximum bitrate in b/s in case static clockrate is selected */
743 state->m_mpeg_ts_static_bitrate = 19392658;
744 state->m_disable_te_ihandling = false;
746 if (ul_insert_rs_byte)
747 state->m_insert_rs_byte = true;
749 state->m_mpeg_lock_time_out = DEFAULT_DRXK_MPEG_LOCK_TIMEOUT;
750 if (ul_mpeg_lock_time_out < 10000)
751 state->m_mpeg_lock_time_out = ul_mpeg_lock_time_out;
752 state->m_demod_lock_time_out = DEFAULT_DRXK_DEMOD_LOCK_TIMEOUT;
753 if (ul_demod_lock_time_out < 10000)
754 state->m_demod_lock_time_out = ul_demod_lock_time_out;
757 state->m_constellation = DRX_CONSTELLATION_AUTO;
758 state->m_qam_interleave_mode = DRXK_QAM_I12_J17;
759 state->m_fec_rs_plen = 204 * 8; /* fecRsPlen annex A */
760 state->m_fec_rs_prescale = 1;
762 state->m_sqi_speed = DRXK_DVBT_SQI_SPEED_MEDIUM;
763 state->m_agcfast_clip_ctrl_delay = 0;
765 state->m_gpio_cfg = (ul_gpio_cfg);
767 state->m_b_power_down = false;
768 state->m_current_power_mode = DRX_POWER_DOWN;
770 state->m_rfmirror = (ul_rf_mirror == 0);
771 state->m_if_agc_pol = false;
775 static int drxx_open(struct drxk_state *state)
783 /* stop lock indicator process */
784 status = write16(state, SCU_RAM_GPIO__A, SCU_RAM_GPIO_HW_LOCK_IND_DISABLE);
787 /* Check device id */
788 status = read16(state, SIO_TOP_COMM_KEY__A, &key);
791 status = write16(state, SIO_TOP_COMM_KEY__A, SIO_TOP_COMM_KEY_KEY);
794 status = read32(state, SIO_TOP_JTAGID_LO__A, &jtag);
797 status = read16(state, SIO_PDR_UIO_IN_HI__A, &bid);
800 status = write16(state, SIO_TOP_COMM_KEY__A, key);
803 printk(KERN_ERR "drxk: Error %d on %s\n", status, __func__);
807 static int get_device_capabilities(struct drxk_state *state)
809 u16 sio_pdr_ohw_cfg = 0;
810 u32 sio_top_jtagid_lo = 0;
812 const char *spin = "";
817 /* stop lock indicator process */
818 status = write16(state, SCU_RAM_GPIO__A, SCU_RAM_GPIO_HW_LOCK_IND_DISABLE);
821 status = write16(state, SIO_TOP_COMM_KEY__A, SIO_TOP_COMM_KEY_KEY);
824 status = read16(state, SIO_PDR_OHW_CFG__A, &sio_pdr_ohw_cfg);
827 status = write16(state, SIO_TOP_COMM_KEY__A, 0x0000);
831 switch ((sio_pdr_ohw_cfg & SIO_PDR_OHW_CFG_FREF_SEL__M)) {
833 /* ignore (bypass ?) */
837 state->m_osc_clock_freq = 27000;
841 state->m_osc_clock_freq = 20250;
845 state->m_osc_clock_freq = 20250;
848 printk(KERN_ERR "drxk: Clock Frequency is unknown\n");
852 Determine device capabilities
855 status = read32(state, SIO_TOP_JTAGID_LO__A, &sio_top_jtagid_lo);
859 printk(KERN_INFO "drxk: status = 0x%08x\n", sio_top_jtagid_lo);
862 switch ((sio_top_jtagid_lo >> 29) & 0xF) {
864 state->m_device_spin = DRXK_SPIN_A1;
868 state->m_device_spin = DRXK_SPIN_A2;
872 state->m_device_spin = DRXK_SPIN_A3;
876 state->m_device_spin = DRXK_SPIN_UNKNOWN;
878 printk(KERN_ERR "drxk: Spin %d unknown\n",
879 (sio_top_jtagid_lo >> 29) & 0xF);
882 switch ((sio_top_jtagid_lo >> 12) & 0xFF) {
884 /* typeId = DRX3913K_TYPE_ID */
885 state->m_has_lna = false;
886 state->m_has_oob = false;
887 state->m_has_atv = false;
888 state->m_has_audio = false;
889 state->m_has_dvbt = true;
890 state->m_has_dvbc = true;
891 state->m_has_sawsw = true;
892 state->m_has_gpio2 = false;
893 state->m_has_gpio1 = false;
894 state->m_has_irqn = false;
897 /* typeId = DRX3915K_TYPE_ID */
898 state->m_has_lna = false;
899 state->m_has_oob = false;
900 state->m_has_atv = true;
901 state->m_has_audio = false;
902 state->m_has_dvbt = true;
903 state->m_has_dvbc = false;
904 state->m_has_sawsw = true;
905 state->m_has_gpio2 = true;
906 state->m_has_gpio1 = true;
907 state->m_has_irqn = false;
910 /* typeId = DRX3916K_TYPE_ID */
911 state->m_has_lna = false;
912 state->m_has_oob = false;
913 state->m_has_atv = true;
914 state->m_has_audio = false;
915 state->m_has_dvbt = true;
916 state->m_has_dvbc = false;
917 state->m_has_sawsw = true;
918 state->m_has_gpio2 = true;
919 state->m_has_gpio1 = true;
920 state->m_has_irqn = false;
923 /* typeId = DRX3918K_TYPE_ID */
924 state->m_has_lna = false;
925 state->m_has_oob = false;
926 state->m_has_atv = true;
927 state->m_has_audio = true;
928 state->m_has_dvbt = true;
929 state->m_has_dvbc = false;
930 state->m_has_sawsw = true;
931 state->m_has_gpio2 = true;
932 state->m_has_gpio1 = true;
933 state->m_has_irqn = false;
936 /* typeId = DRX3921K_TYPE_ID */
937 state->m_has_lna = false;
938 state->m_has_oob = false;
939 state->m_has_atv = true;
940 state->m_has_audio = true;
941 state->m_has_dvbt = true;
942 state->m_has_dvbc = true;
943 state->m_has_sawsw = true;
944 state->m_has_gpio2 = true;
945 state->m_has_gpio1 = true;
946 state->m_has_irqn = false;
949 /* typeId = DRX3923K_TYPE_ID */
950 state->m_has_lna = false;
951 state->m_has_oob = false;
952 state->m_has_atv = true;
953 state->m_has_audio = true;
954 state->m_has_dvbt = true;
955 state->m_has_dvbc = true;
956 state->m_has_sawsw = true;
957 state->m_has_gpio2 = true;
958 state->m_has_gpio1 = true;
959 state->m_has_irqn = false;
962 /* typeId = DRX3925K_TYPE_ID */
963 state->m_has_lna = false;
964 state->m_has_oob = false;
965 state->m_has_atv = true;
966 state->m_has_audio = true;
967 state->m_has_dvbt = true;
968 state->m_has_dvbc = true;
969 state->m_has_sawsw = true;
970 state->m_has_gpio2 = true;
971 state->m_has_gpio1 = true;
972 state->m_has_irqn = false;
975 /* typeId = DRX3926K_TYPE_ID */
976 state->m_has_lna = false;
977 state->m_has_oob = false;
978 state->m_has_atv = true;
979 state->m_has_audio = false;
980 state->m_has_dvbt = true;
981 state->m_has_dvbc = true;
982 state->m_has_sawsw = true;
983 state->m_has_gpio2 = true;
984 state->m_has_gpio1 = true;
985 state->m_has_irqn = false;
988 printk(KERN_ERR "drxk: DeviceID 0x%02x not supported\n",
989 ((sio_top_jtagid_lo >> 12) & 0xFF));
995 "drxk: detected a drx-39%02xk, spin %s, xtal %d.%03d MHz\n",
996 ((sio_top_jtagid_lo >> 12) & 0xFF), spin,
997 state->m_osc_clock_freq / 1000,
998 state->m_osc_clock_freq % 1000);
1002 printk(KERN_ERR "drxk: Error %d on %s\n", status, __func__);
1008 static int hi_command(struct drxk_state *state, u16 cmd, u16 *p_result)
1016 status = write16(state, SIO_HI_RA_RAM_CMD__A, cmd);
1019 if (cmd == SIO_HI_RA_RAM_CMD_RESET)
1023 (bool) ((cmd == SIO_HI_RA_RAM_CMD_CONFIG) &&
1024 ((state->m_hi_cfg_ctrl) &
1025 SIO_HI_RA_RAM_PAR_5_CFG_SLEEP__M) ==
1026 SIO_HI_RA_RAM_PAR_5_CFG_SLEEP_ZZZ);
1027 if (powerdown_cmd == false) {
1028 /* Wait until command rdy */
1029 u32 retry_count = 0;
1035 status = read16(state, SIO_HI_RA_RAM_CMD__A,
1037 } while ((status < 0) && (retry_count < DRXK_MAX_RETRIES)
1038 && (wait_cmd != 0));
1041 status = read16(state, SIO_HI_RA_RAM_RES__A, p_result);
1045 printk(KERN_ERR "drxk: Error %d on %s\n", status, __func__);
1050 static int hi_cfg_command(struct drxk_state *state)
1056 mutex_lock(&state->mutex);
1058 status = write16(state, SIO_HI_RA_RAM_PAR_6__A, state->m_hi_cfg_timeout);
1061 status = write16(state, SIO_HI_RA_RAM_PAR_5__A, state->m_hi_cfg_ctrl);
1064 status = write16(state, SIO_HI_RA_RAM_PAR_4__A, state->m_hi_cfg_wake_up_key);
1067 status = write16(state, SIO_HI_RA_RAM_PAR_3__A, state->m_hi_cfg_bridge_delay);
1070 status = write16(state, SIO_HI_RA_RAM_PAR_2__A, state->m_hi_cfg_timing_div);
1073 status = write16(state, SIO_HI_RA_RAM_PAR_1__A, SIO_HI_RA_RAM_PAR_1_PAR1_SEC_KEY);
1076 status = hi_command(state, SIO_HI_RA_RAM_CMD_CONFIG, 0);
1080 state->m_hi_cfg_ctrl &= ~SIO_HI_RA_RAM_PAR_5_CFG_SLEEP_ZZZ;
1082 mutex_unlock(&state->mutex);
1084 printk(KERN_ERR "drxk: Error %d on %s\n", status, __func__);
1088 static int init_hi(struct drxk_state *state)
1092 state->m_hi_cfg_wake_up_key = (state->demod_address << 1);
1093 state->m_hi_cfg_timeout = 0x96FF;
1094 /* port/bridge/power down ctrl */
1095 state->m_hi_cfg_ctrl = SIO_HI_RA_RAM_PAR_5_CFG_SLV0_SLAVE;
1097 return hi_cfg_command(state);
1100 static int mpegts_configure_pins(struct drxk_state *state, bool mpeg_enable)
1103 u16 sio_pdr_mclk_cfg = 0;
1104 u16 sio_pdr_mdx_cfg = 0;
1107 dprintk(1, ": mpeg %s, %s mode\n",
1108 mpeg_enable ? "enable" : "disable",
1109 state->m_enable_parallel ? "parallel" : "serial");
1111 /* stop lock indicator process */
1112 status = write16(state, SCU_RAM_GPIO__A, SCU_RAM_GPIO_HW_LOCK_IND_DISABLE);
1116 /* MPEG TS pad configuration */
1117 status = write16(state, SIO_TOP_COMM_KEY__A, SIO_TOP_COMM_KEY_KEY);
1121 if (mpeg_enable == false) {
1122 /* Set MPEG TS pads to inputmode */
1123 status = write16(state, SIO_PDR_MSTRT_CFG__A, 0x0000);
1126 status = write16(state, SIO_PDR_MERR_CFG__A, 0x0000);
1129 status = write16(state, SIO_PDR_MCLK_CFG__A, 0x0000);
1132 status = write16(state, SIO_PDR_MVAL_CFG__A, 0x0000);
1135 status = write16(state, SIO_PDR_MD0_CFG__A, 0x0000);
1138 status = write16(state, SIO_PDR_MD1_CFG__A, 0x0000);
1141 status = write16(state, SIO_PDR_MD2_CFG__A, 0x0000);
1144 status = write16(state, SIO_PDR_MD3_CFG__A, 0x0000);
1147 status = write16(state, SIO_PDR_MD4_CFG__A, 0x0000);
1150 status = write16(state, SIO_PDR_MD5_CFG__A, 0x0000);
1153 status = write16(state, SIO_PDR_MD6_CFG__A, 0x0000);
1156 status = write16(state, SIO_PDR_MD7_CFG__A, 0x0000);
1160 /* Enable MPEG output */
1162 ((state->m_ts_data_strength <<
1163 SIO_PDR_MD0_CFG_DRIVE__B) | 0x0003);
1164 sio_pdr_mclk_cfg = ((state->m_ts_clockk_strength <<
1165 SIO_PDR_MCLK_CFG_DRIVE__B) |
1168 status = write16(state, SIO_PDR_MSTRT_CFG__A, sio_pdr_mdx_cfg);
1172 if (state->enable_merr_cfg)
1173 err_cfg = sio_pdr_mdx_cfg;
1175 status = write16(state, SIO_PDR_MERR_CFG__A, err_cfg);
1178 status = write16(state, SIO_PDR_MVAL_CFG__A, err_cfg);
1182 if (state->m_enable_parallel == true) {
1183 /* paralel -> enable MD1 to MD7 */
1184 status = write16(state, SIO_PDR_MD1_CFG__A, sio_pdr_mdx_cfg);
1187 status = write16(state, SIO_PDR_MD2_CFG__A, sio_pdr_mdx_cfg);
1190 status = write16(state, SIO_PDR_MD3_CFG__A, sio_pdr_mdx_cfg);
1193 status = write16(state, SIO_PDR_MD4_CFG__A, sio_pdr_mdx_cfg);
1196 status = write16(state, SIO_PDR_MD5_CFG__A, sio_pdr_mdx_cfg);
1199 status = write16(state, SIO_PDR_MD6_CFG__A, sio_pdr_mdx_cfg);
1202 status = write16(state, SIO_PDR_MD7_CFG__A, sio_pdr_mdx_cfg);
1206 sio_pdr_mdx_cfg = ((state->m_ts_data_strength <<
1207 SIO_PDR_MD0_CFG_DRIVE__B)
1209 /* serial -> disable MD1 to MD7 */
1210 status = write16(state, SIO_PDR_MD1_CFG__A, 0x0000);
1213 status = write16(state, SIO_PDR_MD2_CFG__A, 0x0000);
1216 status = write16(state, SIO_PDR_MD3_CFG__A, 0x0000);
1219 status = write16(state, SIO_PDR_MD4_CFG__A, 0x0000);
1222 status = write16(state, SIO_PDR_MD5_CFG__A, 0x0000);
1225 status = write16(state, SIO_PDR_MD6_CFG__A, 0x0000);
1228 status = write16(state, SIO_PDR_MD7_CFG__A, 0x0000);
1232 status = write16(state, SIO_PDR_MCLK_CFG__A, sio_pdr_mclk_cfg);
1235 status = write16(state, SIO_PDR_MD0_CFG__A, sio_pdr_mdx_cfg);
1239 /* Enable MB output over MPEG pads and ctl input */
1240 status = write16(state, SIO_PDR_MON_CFG__A, 0x0000);
1243 /* Write nomagic word to enable pdr reg write */
1244 status = write16(state, SIO_TOP_COMM_KEY__A, 0x0000);
1247 printk(KERN_ERR "drxk: Error %d on %s\n", status, __func__);
1251 static int mpegts_disable(struct drxk_state *state)
1255 return mpegts_configure_pins(state, false);
1258 static int bl_chain_cmd(struct drxk_state *state,
1259 u16 rom_offset, u16 nr_of_elements, u32 time_out)
1266 mutex_lock(&state->mutex);
1267 status = write16(state, SIO_BL_MODE__A, SIO_BL_MODE_CHAIN);
1270 status = write16(state, SIO_BL_CHAIN_ADDR__A, rom_offset);
1273 status = write16(state, SIO_BL_CHAIN_LEN__A, nr_of_elements);
1276 status = write16(state, SIO_BL_ENABLE__A, SIO_BL_ENABLE_ON);
1280 end = jiffies + msecs_to_jiffies(time_out);
1283 status = read16(state, SIO_BL_STATUS__A, &bl_status);
1286 } while ((bl_status == 0x1) &&
1287 ((time_is_after_jiffies(end))));
1289 if (bl_status == 0x1) {
1290 printk(KERN_ERR "drxk: SIO not ready\n");
1296 printk(KERN_ERR "drxk: Error %d on %s\n", status, __func__);
1298 mutex_unlock(&state->mutex);
1303 static int download_microcode(struct drxk_state *state,
1304 const u8 p_mc_image[], u32 length)
1306 const u8 *p_src = p_mc_image;
1316 /* down the drain (we don't care about MAGIC_WORD) */
1318 /* For future reference */
1319 drain = (p_src[0] << 8) | p_src[1];
1321 p_src += sizeof(u16);
1322 offset += sizeof(u16);
1323 n_blocks = (p_src[0] << 8) | p_src[1];
1324 p_src += sizeof(u16);
1325 offset += sizeof(u16);
1327 for (i = 0; i < n_blocks; i += 1) {
1328 address = (p_src[0] << 24) | (p_src[1] << 16) |
1329 (p_src[2] << 8) | p_src[3];
1330 p_src += sizeof(u32);
1331 offset += sizeof(u32);
1333 block_size = ((p_src[0] << 8) | p_src[1]) * sizeof(u16);
1334 p_src += sizeof(u16);
1335 offset += sizeof(u16);
1338 /* For future reference */
1339 flags = (p_src[0] << 8) | p_src[1];
1341 p_src += sizeof(u16);
1342 offset += sizeof(u16);
1345 /* For future reference */
1346 block_crc = (p_src[0] << 8) | p_src[1];
1348 p_src += sizeof(u16);
1349 offset += sizeof(u16);
1351 if (offset + block_size > length) {
1352 printk(KERN_ERR "drxk: Firmware is corrupted.\n");
1356 status = write_block(state, address, block_size, p_src);
1358 printk(KERN_ERR "drxk: Error %d while loading firmware\n", status);
1361 p_src += block_size;
1362 offset += block_size;
1367 static int dvbt_enable_ofdm_token_ring(struct drxk_state *state, bool enable)
1371 u16 desired_ctrl = SIO_OFDM_SH_OFDM_RING_ENABLE_ON;
1372 u16 desired_status = SIO_OFDM_SH_OFDM_RING_STATUS_ENABLED;
1377 if (enable == false) {
1378 desired_ctrl = SIO_OFDM_SH_OFDM_RING_ENABLE_OFF;
1379 desired_status = SIO_OFDM_SH_OFDM_RING_STATUS_DOWN;
1382 status = read16(state, SIO_OFDM_SH_OFDM_RING_STATUS__A, &data);
1383 if (status >= 0 && data == desired_status) {
1384 /* tokenring already has correct status */
1387 /* Disable/enable dvbt tokenring bridge */
1388 status = write16(state, SIO_OFDM_SH_OFDM_RING_ENABLE__A, desired_ctrl);
1390 end = jiffies + msecs_to_jiffies(DRXK_OFDM_TR_SHUTDOWN_TIMEOUT);
1392 status = read16(state, SIO_OFDM_SH_OFDM_RING_STATUS__A, &data);
1393 if ((status >= 0 && data == desired_status) || time_is_after_jiffies(end))
1397 if (data != desired_status) {
1398 printk(KERN_ERR "drxk: SIO not ready\n");
1404 static int mpegts_stop(struct drxk_state *state)
1407 u16 fec_oc_snc_mode = 0;
1408 u16 fec_oc_ipr_mode = 0;
1412 /* Gracefull shutdown (byte boundaries) */
1413 status = read16(state, FEC_OC_SNC_MODE__A, &fec_oc_snc_mode);
1416 fec_oc_snc_mode |= FEC_OC_SNC_MODE_SHUTDOWN__M;
1417 status = write16(state, FEC_OC_SNC_MODE__A, fec_oc_snc_mode);
1421 /* Suppress MCLK during absence of data */
1422 status = read16(state, FEC_OC_IPR_MODE__A, &fec_oc_ipr_mode);
1425 fec_oc_ipr_mode |= FEC_OC_IPR_MODE_MCLK_DIS_DAT_ABS__M;
1426 status = write16(state, FEC_OC_IPR_MODE__A, fec_oc_ipr_mode);
1430 printk(KERN_ERR "drxk: Error %d on %s\n", status, __func__);
1435 static int scu_command(struct drxk_state *state,
1436 u16 cmd, u8 parameter_len,
1437 u16 *parameter, u8 result_len, u16 *result)
1439 #if (SCU_RAM_PARAM_0__A - SCU_RAM_PARAM_15__A) != 15
1440 #error DRXK register mapping no longer compatible with this routine!
1443 int status = -EINVAL;
1452 if ((cmd == 0) || ((parameter_len > 0) && (parameter == NULL)) ||
1453 ((result_len > 0) && (result == NULL))) {
1454 printk(KERN_ERR "drxk: Error %d on %s\n", status, __func__);
1458 mutex_lock(&state->mutex);
1460 /* assume that the command register is ready
1461 since it is checked afterwards */
1462 for (ii = parameter_len - 1; ii >= 0; ii -= 1) {
1463 buffer[cnt++] = (parameter[ii] & 0xFF);
1464 buffer[cnt++] = ((parameter[ii] >> 8) & 0xFF);
1466 buffer[cnt++] = (cmd & 0xFF);
1467 buffer[cnt++] = ((cmd >> 8) & 0xFF);
1469 write_block(state, SCU_RAM_PARAM_0__A -
1470 (parameter_len - 1), cnt, buffer);
1471 /* Wait until SCU has processed command */
1472 end = jiffies + msecs_to_jiffies(DRXK_MAX_WAITTIME);
1475 status = read16(state, SCU_RAM_COMMAND__A, &cur_cmd);
1478 } while (!(cur_cmd == DRX_SCU_READY) && (time_is_after_jiffies(end)));
1479 if (cur_cmd != DRX_SCU_READY) {
1480 printk(KERN_ERR "drxk: SCU not ready\n");
1485 if ((result_len > 0) && (result != NULL)) {
1489 for (ii = result_len - 1; ii >= 0; ii -= 1) {
1490 status = read16(state, SCU_RAM_PARAM_0__A - ii, &result[ii]);
1495 /* Check if an error was reported by SCU */
1496 err = (s16)result[0];
1500 /* check for the known error codes */
1502 case SCU_RESULT_UNKCMD:
1503 p = "SCU_RESULT_UNKCMD";
1505 case SCU_RESULT_UNKSTD:
1506 p = "SCU_RESULT_UNKSTD";
1508 case SCU_RESULT_SIZE:
1509 p = "SCU_RESULT_SIZE";
1511 case SCU_RESULT_INVPAR:
1512 p = "SCU_RESULT_INVPAR";
1514 default: /* Other negative values are errors */
1515 sprintf(errname, "ERROR: %d\n", err);
1518 printk(KERN_ERR "drxk: %s while sending cmd 0x%04x with params:", p, cmd);
1519 print_hex_dump_bytes("drxk: ", DUMP_PREFIX_NONE, buffer, cnt);
1526 printk(KERN_ERR "drxk: Error %d on %s\n", status, __func__);
1528 mutex_unlock(&state->mutex);
1532 static int set_iqm_af(struct drxk_state *state, bool active)
1540 status = read16(state, IQM_AF_STDBY__A, &data);
1545 data |= (IQM_AF_STDBY_STDBY_ADC_STANDBY
1546 | IQM_AF_STDBY_STDBY_AMP_STANDBY
1547 | IQM_AF_STDBY_STDBY_PD_STANDBY
1548 | IQM_AF_STDBY_STDBY_TAGC_IF_STANDBY
1549 | IQM_AF_STDBY_STDBY_TAGC_RF_STANDBY);
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)
1558 status = write16(state, IQM_AF_STDBY__A, data);
1562 printk(KERN_ERR "drxk: Error %d on %s\n", status, __func__);
1566 static int ctrl_power_mode(struct drxk_state *state, enum drx_power_mode *mode)
1569 u16 sio_cc_pwd_mode = 0;
1573 /* Check arguments */
1579 sio_cc_pwd_mode = SIO_CC_PWD_MODE_LEVEL_NONE;
1581 case DRXK_POWER_DOWN_OFDM:
1582 sio_cc_pwd_mode = SIO_CC_PWD_MODE_LEVEL_OFDM;
1584 case DRXK_POWER_DOWN_CORE:
1585 sio_cc_pwd_mode = SIO_CC_PWD_MODE_LEVEL_CLOCK;
1587 case DRXK_POWER_DOWN_PLL:
1588 sio_cc_pwd_mode = SIO_CC_PWD_MODE_LEVEL_PLL;
1590 case DRX_POWER_DOWN:
1591 sio_cc_pwd_mode = SIO_CC_PWD_MODE_LEVEL_OSC;
1594 /* Unknow sleep mode */
1598 /* If already in requested power mode, do nothing */
1599 if (state->m_current_power_mode == *mode)
1602 /* For next steps make sure to start from DRX_POWER_UP mode */
1603 if (state->m_current_power_mode != DRX_POWER_UP) {
1604 status = power_up_device(state);
1607 status = dvbt_enable_ofdm_token_ring(state, true);
1612 if (*mode == DRX_POWER_UP) {
1613 /* Restore analog & pin configuartion */
1615 /* Power down to requested mode */
1616 /* Backup some register settings */
1617 /* Set pins with possible pull-ups connected
1618 to them in input mode */
1619 /* Analog power down */
1620 /* ADC power down */
1621 /* Power down device */
1622 /* stop all comm_exec */
1623 /* Stop and power down previous standard */
1624 switch (state->m_operation_mode) {
1626 status = mpegts_stop(state);
1629 status = power_down_dvbt(state, false);
1635 status = mpegts_stop(state);
1638 status = power_down_qam(state);
1645 status = dvbt_enable_ofdm_token_ring(state, false);
1648 status = write16(state, SIO_CC_PWD_MODE__A, sio_cc_pwd_mode);
1651 status = write16(state, SIO_CC_UPDATE__A, SIO_CC_UPDATE_KEY);
1655 if (*mode != DRXK_POWER_DOWN_OFDM) {
1656 state->m_hi_cfg_ctrl |=
1657 SIO_HI_RA_RAM_PAR_5_CFG_SLEEP_ZZZ;
1658 status = hi_cfg_command(state);
1663 state->m_current_power_mode = *mode;
1667 printk(KERN_ERR "drxk: Error %d on %s\n", status, __func__);
1672 static int power_down_dvbt(struct drxk_state *state, bool set_power_mode)
1674 enum drx_power_mode power_mode = DRXK_POWER_DOWN_OFDM;
1681 status = read16(state, SCU_COMM_EXEC__A, &data);
1684 if (data == SCU_COMM_EXEC_ACTIVE) {
1685 /* Send OFDM stop command */
1686 status = scu_command(state, SCU_RAM_COMMAND_STANDARD_OFDM | SCU_RAM_COMMAND_CMD_DEMOD_STOP, 0, NULL, 1, &cmd_result);
1689 /* Send OFDM reset command */
1690 status = scu_command(state, SCU_RAM_COMMAND_STANDARD_OFDM | SCU_RAM_COMMAND_CMD_DEMOD_RESET, 0, NULL, 1, &cmd_result);
1695 /* Reset datapath for OFDM, processors first */
1696 status = write16(state, OFDM_SC_COMM_EXEC__A, OFDM_SC_COMM_EXEC_STOP);
1699 status = write16(state, OFDM_LC_COMM_EXEC__A, OFDM_LC_COMM_EXEC_STOP);
1702 status = write16(state, IQM_COMM_EXEC__A, IQM_COMM_EXEC_B_STOP);
1707 status = set_iqm_af(state, false);
1711 /* powerdown to OFDM mode */
1712 if (set_power_mode) {
1713 status = ctrl_power_mode(state, &power_mode);
1719 printk(KERN_ERR "drxk: Error %d on %s\n", status, __func__);
1723 static int setoperation_mode(struct drxk_state *state,
1724 enum operation_mode o_mode)
1730 Stop and power down previous standard
1731 TODO investigate total power down instead of partial
1732 power down depending on "previous" standard.
1735 /* disable HW lock indicator */
1736 status = write16(state, SCU_RAM_GPIO__A, SCU_RAM_GPIO_HW_LOCK_IND_DISABLE);
1740 /* Device is already at the required mode */
1741 if (state->m_operation_mode == o_mode)
1744 switch (state->m_operation_mode) {
1745 /* OM_NONE was added for start up */
1749 status = mpegts_stop(state);
1752 status = power_down_dvbt(state, true);
1755 state->m_operation_mode = OM_NONE;
1757 case OM_QAM_ITU_A: /* fallthrough */
1759 status = mpegts_stop(state);
1762 status = power_down_qam(state);
1765 state->m_operation_mode = OM_NONE;
1774 Power up new standard
1778 dprintk(1, ": DVB-T\n");
1779 state->m_operation_mode = o_mode;
1780 status = set_dvbt_standard(state, o_mode);
1784 case OM_QAM_ITU_A: /* fallthrough */
1786 dprintk(1, ": DVB-C Annex %c\n",
1787 (state->m_operation_mode == OM_QAM_ITU_A) ? 'A' : 'C');
1788 state->m_operation_mode = o_mode;
1789 status = set_qam_standard(state, o_mode);
1799 printk(KERN_ERR "drxk: Error %d on %s\n", status, __func__);
1803 static int start(struct drxk_state *state, s32 offset_freq,
1804 s32 intermediate_frequency)
1806 int status = -EINVAL;
1809 s32 offsetk_hz = offset_freq / 1000;
1812 if (state->m_drxk_state != DRXK_STOPPED &&
1813 state->m_drxk_state != DRXK_DTV_STARTED)
1816 state->m_b_mirror_freq_spect = (state->props.inversion == INVERSION_ON);
1818 if (intermediate_frequency < 0) {
1819 state->m_b_mirror_freq_spect = !state->m_b_mirror_freq_spect;
1820 intermediate_frequency = -intermediate_frequency;
1823 switch (state->m_operation_mode) {
1826 i_freqk_hz = (intermediate_frequency / 1000);
1827 status = set_qam(state, i_freqk_hz, offsetk_hz);
1830 state->m_drxk_state = DRXK_DTV_STARTED;
1833 i_freqk_hz = (intermediate_frequency / 1000);
1834 status = mpegts_stop(state);
1837 status = set_dvbt(state, i_freqk_hz, offsetk_hz);
1840 status = dvbt_start(state);
1843 state->m_drxk_state = DRXK_DTV_STARTED;
1850 printk(KERN_ERR "drxk: Error %d on %s\n", status, __func__);
1854 static int shut_down(struct drxk_state *state)
1862 static int get_lock_status(struct drxk_state *state, u32 *p_lock_status)
1864 int status = -EINVAL;
1868 if (p_lock_status == NULL)
1871 *p_lock_status = NOT_LOCKED;
1873 /* define the SCU command code */
1874 switch (state->m_operation_mode) {
1878 status = get_qam_lock_status(state, p_lock_status);
1881 status = get_dvbt_lock_status(state, p_lock_status);
1888 printk(KERN_ERR "drxk: Error %d on %s\n", status, __func__);
1892 static int mpegts_start(struct drxk_state *state)
1896 u16 fec_oc_snc_mode = 0;
1898 /* Allow OC to sync again */
1899 status = read16(state, FEC_OC_SNC_MODE__A, &fec_oc_snc_mode);
1902 fec_oc_snc_mode &= ~FEC_OC_SNC_MODE_SHUTDOWN__M;
1903 status = write16(state, FEC_OC_SNC_MODE__A, fec_oc_snc_mode);
1906 status = write16(state, FEC_OC_SNC_UNLOCK__A, 1);
1909 printk(KERN_ERR "drxk: Error %d on %s\n", status, __func__);
1913 static int mpegts_dto_init(struct drxk_state *state)
1919 /* Rate integration settings */
1920 status = write16(state, FEC_OC_RCN_CTL_STEP_LO__A, 0x0000);
1923 status = write16(state, FEC_OC_RCN_CTL_STEP_HI__A, 0x000C);
1926 status = write16(state, FEC_OC_RCN_GAIN__A, 0x000A);
1929 status = write16(state, FEC_OC_AVR_PARM_A__A, 0x0008);
1932 status = write16(state, FEC_OC_AVR_PARM_B__A, 0x0006);
1935 status = write16(state, FEC_OC_TMD_HI_MARGIN__A, 0x0680);
1938 status = write16(state, FEC_OC_TMD_LO_MARGIN__A, 0x0080);
1941 status = write16(state, FEC_OC_TMD_COUNT__A, 0x03F4);
1945 /* Additional configuration */
1946 status = write16(state, FEC_OC_OCR_INVERT__A, 0);
1949 status = write16(state, FEC_OC_SNC_LWM__A, 2);
1952 status = write16(state, FEC_OC_SNC_HWM__A, 12);
1955 printk(KERN_ERR "drxk: Error %d on %s\n", status, __func__);
1960 static int mpegts_dto_setup(struct drxk_state *state,
1961 enum operation_mode o_mode)
1965 u16 fec_oc_reg_mode = 0; /* FEC_OC_MODE register value */
1966 u16 fec_oc_reg_ipr_mode = 0; /* FEC_OC_IPR_MODE register value */
1967 u16 fec_oc_dto_mode = 0; /* FEC_OC_IPR_INVERT register value */
1968 u16 fec_oc_fct_mode = 0; /* FEC_OC_IPR_INVERT register value */
1969 u16 fec_oc_dto_period = 2; /* FEC_OC_IPR_INVERT register value */
1970 u16 fec_oc_dto_burst_len = 188; /* FEC_OC_IPR_INVERT register value */
1971 u32 fec_oc_rcn_ctl_rate = 0; /* FEC_OC_IPR_INVERT register value */
1972 u16 fec_oc_tmd_mode = 0;
1973 u16 fec_oc_tmd_int_upd_rate = 0;
1974 u32 max_bit_rate = 0;
1975 bool static_clk = false;
1979 /* Check insertion of the Reed-Solomon parity bytes */
1980 status = read16(state, FEC_OC_MODE__A, &fec_oc_reg_mode);
1983 status = read16(state, FEC_OC_IPR_MODE__A, &fec_oc_reg_ipr_mode);
1986 fec_oc_reg_mode &= (~FEC_OC_MODE_PARITY__M);
1987 fec_oc_reg_ipr_mode &= (~FEC_OC_IPR_MODE_MVAL_DIS_PAR__M);
1988 if (state->m_insert_rs_byte == true) {
1989 /* enable parity symbol forward */
1990 fec_oc_reg_mode |= FEC_OC_MODE_PARITY__M;
1991 /* MVAL disable during parity bytes */
1992 fec_oc_reg_ipr_mode |= FEC_OC_IPR_MODE_MVAL_DIS_PAR__M;
1993 /* TS burst length to 204 */
1994 fec_oc_dto_burst_len = 204;
1997 /* Check serial or parrallel output */
1998 fec_oc_reg_ipr_mode &= (~(FEC_OC_IPR_MODE_SERIAL__M));
1999 if (state->m_enable_parallel == false) {
2000 /* MPEG data output is serial -> set ipr_mode[0] */
2001 fec_oc_reg_ipr_mode |= FEC_OC_IPR_MODE_SERIAL__M;
2006 max_bit_rate = state->m_dvbt_bitrate;
2007 fec_oc_tmd_mode = 3;
2008 fec_oc_rcn_ctl_rate = 0xC00000;
2009 static_clk = state->m_dvbt_static_clk;
2011 case OM_QAM_ITU_A: /* fallthrough */
2013 fec_oc_tmd_mode = 0x0004;
2014 fec_oc_rcn_ctl_rate = 0xD2B4EE; /* good for >63 Mb/s */
2015 max_bit_rate = state->m_dvbc_bitrate;
2016 static_clk = state->m_dvbc_static_clk;
2020 } /* switch (standard) */
2024 /* Configure DTO's */
2028 /* Rational DTO for MCLK source (static MCLK rate),
2029 Dynamic DTO for optimal grouping
2030 (avoid intra-packet gaps),
2031 DTO offset enable to sync TS burst with MSTRT */
2032 fec_oc_dto_mode = (FEC_OC_DTO_MODE_DYNAMIC__M |
2033 FEC_OC_DTO_MODE_OFFSET_ENABLE__M);
2034 fec_oc_fct_mode = (FEC_OC_FCT_MODE_RAT_ENA__M |
2035 FEC_OC_FCT_MODE_VIRT_ENA__M);
2037 /* Check user defined bitrate */
2038 bit_rate = max_bit_rate;
2039 if (bit_rate > 75900000UL) { /* max is 75.9 Mb/s */
2040 bit_rate = 75900000UL;
2042 /* Rational DTO period:
2043 dto_period = (Fsys / bitrate) - 2
2045 result should be floored,
2046 to make sure >= requested bitrate
2048 fec_oc_dto_period = (u16) (((state->m_sys_clock_freq)
2049 * 1000) / bit_rate);
2050 if (fec_oc_dto_period <= 2)
2051 fec_oc_dto_period = 0;
2053 fec_oc_dto_period -= 2;
2054 fec_oc_tmd_int_upd_rate = 8;
2056 /* (commonAttr->static_clk == false) => dynamic mode */
2057 fec_oc_dto_mode = FEC_OC_DTO_MODE_DYNAMIC__M;
2058 fec_oc_fct_mode = FEC_OC_FCT_MODE__PRE;
2059 fec_oc_tmd_int_upd_rate = 5;
2062 /* Write appropriate registers with requested configuration */
2063 status = write16(state, FEC_OC_DTO_BURST_LEN__A, fec_oc_dto_burst_len);
2066 status = write16(state, FEC_OC_DTO_PERIOD__A, fec_oc_dto_period);
2069 status = write16(state, FEC_OC_DTO_MODE__A, fec_oc_dto_mode);
2072 status = write16(state, FEC_OC_FCT_MODE__A, fec_oc_fct_mode);
2075 status = write16(state, FEC_OC_MODE__A, fec_oc_reg_mode);
2078 status = write16(state, FEC_OC_IPR_MODE__A, fec_oc_reg_ipr_mode);
2082 /* Rate integration settings */
2083 status = write32(state, FEC_OC_RCN_CTL_RATE_LO__A, fec_oc_rcn_ctl_rate);
2086 status = write16(state, FEC_OC_TMD_INT_UPD_RATE__A, fec_oc_tmd_int_upd_rate);
2089 status = write16(state, FEC_OC_TMD_MODE__A, fec_oc_tmd_mode);
2092 printk(KERN_ERR "drxk: Error %d on %s\n", status, __func__);
2096 static int mpegts_configure_polarity(struct drxk_state *state)
2098 u16 fec_oc_reg_ipr_invert = 0;
2100 /* Data mask for the output data byte */
2101 u16 invert_data_mask =
2102 FEC_OC_IPR_INVERT_MD7__M | FEC_OC_IPR_INVERT_MD6__M |
2103 FEC_OC_IPR_INVERT_MD5__M | FEC_OC_IPR_INVERT_MD4__M |
2104 FEC_OC_IPR_INVERT_MD3__M | FEC_OC_IPR_INVERT_MD2__M |
2105 FEC_OC_IPR_INVERT_MD1__M | FEC_OC_IPR_INVERT_MD0__M;
2109 /* Control selective inversion of output bits */
2110 fec_oc_reg_ipr_invert &= (~(invert_data_mask));
2111 if (state->m_invert_data == true)
2112 fec_oc_reg_ipr_invert |= invert_data_mask;
2113 fec_oc_reg_ipr_invert &= (~(FEC_OC_IPR_INVERT_MERR__M));
2114 if (state->m_invert_err == true)
2115 fec_oc_reg_ipr_invert |= FEC_OC_IPR_INVERT_MERR__M;
2116 fec_oc_reg_ipr_invert &= (~(FEC_OC_IPR_INVERT_MSTRT__M));
2117 if (state->m_invert_str == true)
2118 fec_oc_reg_ipr_invert |= FEC_OC_IPR_INVERT_MSTRT__M;
2119 fec_oc_reg_ipr_invert &= (~(FEC_OC_IPR_INVERT_MVAL__M));
2120 if (state->m_invert_val == true)
2121 fec_oc_reg_ipr_invert |= FEC_OC_IPR_INVERT_MVAL__M;
2122 fec_oc_reg_ipr_invert &= (~(FEC_OC_IPR_INVERT_MCLK__M));
2123 if (state->m_invert_clk == true)
2124 fec_oc_reg_ipr_invert |= FEC_OC_IPR_INVERT_MCLK__M;
2126 return write16(state, FEC_OC_IPR_INVERT__A, fec_oc_reg_ipr_invert);
2129 #define SCU_RAM_AGC_KI_INV_RF_POL__M 0x4000
2131 static int set_agc_rf(struct drxk_state *state,
2132 struct s_cfg_agc *p_agc_cfg, bool is_dtv)
2134 int status = -EINVAL;
2136 struct s_cfg_agc *p_if_agc_settings;
2140 if (p_agc_cfg == NULL)
2143 switch (p_agc_cfg->ctrl_mode) {
2144 case DRXK_AGC_CTRL_AUTO:
2145 /* Enable RF AGC DAC */
2146 status = read16(state, IQM_AF_STDBY__A, &data);
2149 data &= ~IQM_AF_STDBY_STDBY_TAGC_RF_STANDBY;
2150 status = write16(state, IQM_AF_STDBY__A, data);
2153 status = read16(state, SCU_RAM_AGC_CONFIG__A, &data);
2157 /* Enable SCU RF AGC loop */
2158 data &= ~SCU_RAM_AGC_CONFIG_DISABLE_RF_AGC__M;
2161 if (state->m_rf_agc_pol)
2162 data |= SCU_RAM_AGC_CONFIG_INV_RF_POL__M;
2164 data &= ~SCU_RAM_AGC_CONFIG_INV_RF_POL__M;
2165 status = write16(state, SCU_RAM_AGC_CONFIG__A, data);
2169 /* Set speed (using complementary reduction value) */
2170 status = read16(state, SCU_RAM_AGC_KI_RED__A, &data);
2174 data &= ~SCU_RAM_AGC_KI_RED_RAGC_RED__M;
2175 data |= (~(p_agc_cfg->speed <<
2176 SCU_RAM_AGC_KI_RED_RAGC_RED__B)
2177 & SCU_RAM_AGC_KI_RED_RAGC_RED__M);
2179 status = write16(state, SCU_RAM_AGC_KI_RED__A, data);
2184 p_if_agc_settings = &state->m_dvbt_if_agc_cfg;
2185 else if (is_qam(state))
2186 p_if_agc_settings = &state->m_qam_if_agc_cfg;
2188 p_if_agc_settings = &state->m_atv_if_agc_cfg;
2189 if (p_if_agc_settings == NULL) {
2194 /* Set TOP, only if IF-AGC is in AUTO mode */
2195 if (p_if_agc_settings->ctrl_mode == DRXK_AGC_CTRL_AUTO)
2196 status = write16(state, SCU_RAM_AGC_IF_IACCU_HI_TGT_MAX__A, p_agc_cfg->top);
2200 /* Cut-Off current */
2201 status = write16(state, SCU_RAM_AGC_RF_IACCU_HI_CO__A, p_agc_cfg->cut_off_current);
2205 /* Max. output level */
2206 status = write16(state, SCU_RAM_AGC_RF_MAX__A, p_agc_cfg->max_output_level);
2212 case DRXK_AGC_CTRL_USER:
2213 /* Enable RF AGC DAC */
2214 status = read16(state, IQM_AF_STDBY__A, &data);
2217 data &= ~IQM_AF_STDBY_STDBY_TAGC_RF_STANDBY;
2218 status = write16(state, IQM_AF_STDBY__A, data);
2222 /* Disable SCU RF AGC loop */
2223 status = read16(state, SCU_RAM_AGC_CONFIG__A, &data);
2226 data |= SCU_RAM_AGC_CONFIG_DISABLE_RF_AGC__M;
2227 if (state->m_rf_agc_pol)
2228 data |= SCU_RAM_AGC_CONFIG_INV_RF_POL__M;
2230 data &= ~SCU_RAM_AGC_CONFIG_INV_RF_POL__M;
2231 status = write16(state, SCU_RAM_AGC_CONFIG__A, data);
2235 /* SCU c.o.c. to 0, enabling full control range */
2236 status = write16(state, SCU_RAM_AGC_RF_IACCU_HI_CO__A, 0);
2240 /* Write value to output pin */
2241 status = write16(state, SCU_RAM_AGC_RF_IACCU_HI__A, p_agc_cfg->output_level);
2246 case DRXK_AGC_CTRL_OFF:
2247 /* Disable RF AGC DAC */
2248 status = read16(state, IQM_AF_STDBY__A, &data);
2251 data |= IQM_AF_STDBY_STDBY_TAGC_RF_STANDBY;
2252 status = write16(state, IQM_AF_STDBY__A, data);
2256 /* Disable SCU RF AGC loop */
2257 status = read16(state, SCU_RAM_AGC_CONFIG__A, &data);
2260 data |= SCU_RAM_AGC_CONFIG_DISABLE_RF_AGC__M;
2261 status = write16(state, SCU_RAM_AGC_CONFIG__A, data);
2272 printk(KERN_ERR "drxk: Error %d on %s\n", status, __func__);
2276 #define SCU_RAM_AGC_KI_INV_IF_POL__M 0x2000
2278 static int set_agc_if(struct drxk_state *state,
2279 struct s_cfg_agc *p_agc_cfg, bool is_dtv)
2283 struct s_cfg_agc *p_rf_agc_settings;
2287 switch (p_agc_cfg->ctrl_mode) {
2288 case DRXK_AGC_CTRL_AUTO:
2290 /* Enable IF AGC DAC */
2291 status = read16(state, IQM_AF_STDBY__A, &data);
2294 data &= ~IQM_AF_STDBY_STDBY_TAGC_IF_STANDBY;
2295 status = write16(state, IQM_AF_STDBY__A, data);
2299 status = read16(state, SCU_RAM_AGC_CONFIG__A, &data);
2303 /* Enable SCU IF AGC loop */
2304 data &= ~SCU_RAM_AGC_CONFIG_DISABLE_IF_AGC__M;
2307 if (state->m_if_agc_pol)
2308 data |= SCU_RAM_AGC_CONFIG_INV_IF_POL__M;
2310 data &= ~SCU_RAM_AGC_CONFIG_INV_IF_POL__M;
2311 status = write16(state, SCU_RAM_AGC_CONFIG__A, data);
2315 /* Set speed (using complementary reduction value) */
2316 status = read16(state, SCU_RAM_AGC_KI_RED__A, &data);
2319 data &= ~SCU_RAM_AGC_KI_RED_IAGC_RED__M;
2320 data |= (~(p_agc_cfg->speed <<
2321 SCU_RAM_AGC_KI_RED_IAGC_RED__B)
2322 & SCU_RAM_AGC_KI_RED_IAGC_RED__M);
2324 status = write16(state, SCU_RAM_AGC_KI_RED__A, data);
2329 p_rf_agc_settings = &state->m_qam_rf_agc_cfg;
2331 p_rf_agc_settings = &state->m_atv_rf_agc_cfg;
2332 if (p_rf_agc_settings == NULL)
2335 status = write16(state, SCU_RAM_AGC_IF_IACCU_HI_TGT_MAX__A, p_rf_agc_settings->top);
2340 case DRXK_AGC_CTRL_USER:
2342 /* Enable IF AGC DAC */
2343 status = read16(state, IQM_AF_STDBY__A, &data);
2346 data &= ~IQM_AF_STDBY_STDBY_TAGC_IF_STANDBY;
2347 status = write16(state, IQM_AF_STDBY__A, data);
2351 status = read16(state, SCU_RAM_AGC_CONFIG__A, &data);
2355 /* Disable SCU IF AGC loop */
2356 data |= SCU_RAM_AGC_CONFIG_DISABLE_IF_AGC__M;
2359 if (state->m_if_agc_pol)
2360 data |= SCU_RAM_AGC_CONFIG_INV_IF_POL__M;
2362 data &= ~SCU_RAM_AGC_CONFIG_INV_IF_POL__M;
2363 status = write16(state, SCU_RAM_AGC_CONFIG__A, data);
2367 /* Write value to output pin */
2368 status = write16(state, SCU_RAM_AGC_IF_IACCU_HI_TGT_MAX__A, p_agc_cfg->output_level);
2373 case DRXK_AGC_CTRL_OFF:
2375 /* Disable If AGC DAC */
2376 status = read16(state, IQM_AF_STDBY__A, &data);
2379 data |= IQM_AF_STDBY_STDBY_TAGC_IF_STANDBY;
2380 status = write16(state, IQM_AF_STDBY__A, data);
2384 /* Disable SCU IF AGC loop */
2385 status = read16(state, SCU_RAM_AGC_CONFIG__A, &data);
2388 data |= SCU_RAM_AGC_CONFIG_DISABLE_IF_AGC__M;
2389 status = write16(state, SCU_RAM_AGC_CONFIG__A, data);
2393 } /* switch (agcSettingsIf->ctrl_mode) */
2395 /* always set the top to support
2396 configurations without if-loop */
2397 status = write16(state, SCU_RAM_AGC_INGAIN_TGT_MIN__A, p_agc_cfg->top);
2400 printk(KERN_ERR "drxk: Error %d on %s\n", status, __func__);
2404 static int get_qam_signal_to_noise(struct drxk_state *state,
2405 s32 *p_signal_to_noise)
2408 u16 qam_sl_err_power = 0; /* accum. error between
2409 raw and sliced symbols */
2410 u32 qam_sl_sig_power = 0; /* used for MER, depends of
2412 u32 qam_sl_mer = 0; /* QAM MER */
2416 /* MER calculation */
2418 /* get the register value needed for MER */
2419 status = read16(state, QAM_SL_ERR_POWER__A, &qam_sl_err_power);
2421 printk(KERN_ERR "drxk: Error %d on %s\n", status, __func__);
2425 switch (state->props.modulation) {
2427 qam_sl_sig_power = DRXK_QAM_SL_SIG_POWER_QAM16 << 2;
2430 qam_sl_sig_power = DRXK_QAM_SL_SIG_POWER_QAM32 << 2;
2433 qam_sl_sig_power = DRXK_QAM_SL_SIG_POWER_QAM64 << 2;
2436 qam_sl_sig_power = DRXK_QAM_SL_SIG_POWER_QAM128 << 2;
2440 qam_sl_sig_power = DRXK_QAM_SL_SIG_POWER_QAM256 << 2;
2444 if (qam_sl_err_power > 0) {
2445 qam_sl_mer = log10times100(qam_sl_sig_power) -
2446 log10times100((u32) qam_sl_err_power);
2448 *p_signal_to_noise = qam_sl_mer;
2453 static int get_dvbt_signal_to_noise(struct drxk_state *state,
2454 s32 *p_signal_to_noise)
2458 u32 eq_reg_td_sqr_err_i = 0;
2459 u32 eq_reg_td_sqr_err_q = 0;
2460 u16 eq_reg_td_sqr_err_exp = 0;
2461 u16 eq_reg_td_tps_pwr_ofs = 0;
2462 u16 eq_reg_td_req_smb_cnt = 0;
2469 u16 transmission_params = 0;
2473 status = read16(state, OFDM_EQ_TOP_TD_TPS_PWR_OFS__A, &eq_reg_td_tps_pwr_ofs);
2476 status = read16(state, OFDM_EQ_TOP_TD_REQ_SMB_CNT__A, &eq_reg_td_req_smb_cnt);
2479 status = read16(state, OFDM_EQ_TOP_TD_SQR_ERR_EXP__A, &eq_reg_td_sqr_err_exp);
2482 status = read16(state, OFDM_EQ_TOP_TD_SQR_ERR_I__A, ®_data);
2485 /* Extend SQR_ERR_I operational range */
2486 eq_reg_td_sqr_err_i = (u32) reg_data;
2487 if ((eq_reg_td_sqr_err_exp > 11) &&
2488 (eq_reg_td_sqr_err_i < 0x00000FFFUL)) {
2489 eq_reg_td_sqr_err_i += 0x00010000UL;
2491 status = read16(state, OFDM_EQ_TOP_TD_SQR_ERR_Q__A, ®_data);
2494 /* Extend SQR_ERR_Q operational range */
2495 eq_reg_td_sqr_err_q = (u32) reg_data;
2496 if ((eq_reg_td_sqr_err_exp > 11) &&
2497 (eq_reg_td_sqr_err_q < 0x00000FFFUL))
2498 eq_reg_td_sqr_err_q += 0x00010000UL;
2500 status = read16(state, OFDM_SC_RA_RAM_OP_PARAM__A, &transmission_params);
2504 /* Check input data for MER */
2506 /* MER calculation (in 0.1 dB) without math.h */
2507 if ((eq_reg_td_tps_pwr_ofs == 0) || (eq_reg_td_req_smb_cnt == 0))
2509 else if ((eq_reg_td_sqr_err_i + eq_reg_td_sqr_err_q) == 0) {
2510 /* No error at all, this must be the HW reset value
2511 * Apparently no first measurement yet
2515 sqr_err_iq = (eq_reg_td_sqr_err_i + eq_reg_td_sqr_err_q) <<
2516 eq_reg_td_sqr_err_exp;
2517 if ((transmission_params &
2518 OFDM_SC_RA_RAM_OP_PARAM_MODE__M)
2519 == OFDM_SC_RA_RAM_OP_PARAM_MODE_2K)
2524 /* IMER = 100 * log10 (x)
2525 where x = (eq_reg_td_tps_pwr_ofs^2 *
2526 eq_reg_td_req_smb_cnt * tps_cnt)/sqr_err_iq
2529 where a = 100 * log10 (eq_reg_td_tps_pwr_ofs^2)
2530 b = 100 * log10 (eq_reg_td_req_smb_cnt * tps_cnt)
2531 c = 100 * log10 (sqr_err_iq)
2534 /* log(x) x = 9bits * 9bits->18 bits */
2535 a = log10times100(eq_reg_td_tps_pwr_ofs *
2536 eq_reg_td_tps_pwr_ofs);
2537 /* log(x) x = 16bits * 7bits->23 bits */
2538 b = log10times100(eq_reg_td_req_smb_cnt * tps_cnt);
2539 /* log(x) x = (16bits + 16bits) << 15 ->32 bits */
2540 c = log10times100(sqr_err_iq);
2544 *p_signal_to_noise = i_mer;
2548 printk(KERN_ERR "drxk: Error %d on %s\n", status, __func__);
2552 static int get_signal_to_noise(struct drxk_state *state, s32 *p_signal_to_noise)
2556 *p_signal_to_noise = 0;
2557 switch (state->m_operation_mode) {
2559 return get_dvbt_signal_to_noise(state, p_signal_to_noise);
2562 return get_qam_signal_to_noise(state, p_signal_to_noise);
2570 static int get_dvbt_quality(struct drxk_state *state, s32 *p_quality)
2572 /* SNR Values for quasi errorfree reception rom Nordig 2.2 */
2577 static s32 QE_SN[] = {
2583 108, /* 16-QAM 1/2 */
2584 131, /* 16-QAM 2/3 */
2585 146, /* 16-QAM 3/4 */
2586 156, /* 16-QAM 5/6 */
2587 160, /* 16-QAM 7/8 */
2588 165, /* 64-QAM 1/2 */
2589 187, /* 64-QAM 2/3 */
2590 202, /* 64-QAM 3/4 */
2591 216, /* 64-QAM 5/6 */
2592 225, /* 64-QAM 7/8 */
2598 s32 signal_to_noise = 0;
2599 u16 constellation = 0;
2601 u32 signal_to_noise_rel;
2604 status = get_dvbt_signal_to_noise(state, &signal_to_noise);
2607 status = read16(state, OFDM_EQ_TOP_TD_TPS_CONST__A, &constellation);
2610 constellation &= OFDM_EQ_TOP_TD_TPS_CONST__M;
2612 status = read16(state, OFDM_EQ_TOP_TD_TPS_CODE_HP__A, &code_rate);
2615 code_rate &= OFDM_EQ_TOP_TD_TPS_CODE_HP__M;
2617 if (constellation > OFDM_EQ_TOP_TD_TPS_CONST_64QAM ||
2618 code_rate > OFDM_EQ_TOP_TD_TPS_CODE_LP_7_8)
2620 signal_to_noise_rel = signal_to_noise -
2621 QE_SN[constellation * 5 + code_rate];
2624 if (signal_to_noise_rel < -70)
2626 else if (signal_to_noise_rel < 30)
2627 *p_quality = ((signal_to_noise_rel + 70) *
2630 *p_quality = ber_quality;
2635 static int get_dvbc_quality(struct drxk_state *state, s32 *p_quality)
2643 u32 signal_to_noise = 0;
2644 u32 ber_quality = 100;
2645 u32 signal_to_noise_rel = 0;
2647 status = get_qam_signal_to_noise(state, &signal_to_noise);
2651 switch (state->props.modulation) {
2653 signal_to_noise_rel = signal_to_noise - 200;
2656 signal_to_noise_rel = signal_to_noise - 230;
2657 break; /* Not in NorDig */
2659 signal_to_noise_rel = signal_to_noise - 260;
2662 signal_to_noise_rel = signal_to_noise - 290;
2666 signal_to_noise_rel = signal_to_noise - 320;
2670 if (signal_to_noise_rel < -70)
2672 else if (signal_to_noise_rel < 30)
2673 *p_quality = ((signal_to_noise_rel + 70) *
2676 *p_quality = ber_quality;
2682 static int get_quality(struct drxk_state *state, s32 *p_quality)
2686 switch (state->m_operation_mode) {
2688 return get_dvbt_quality(state, p_quality);
2690 return get_dvbc_quality(state, p_quality);
2699 /* Free data ram in SIO HI */
2700 #define SIO_HI_RA_RAM_USR_BEGIN__A 0x420040
2701 #define SIO_HI_RA_RAM_USR_END__A 0x420060
2703 #define DRXK_HI_ATOMIC_BUF_START (SIO_HI_RA_RAM_USR_BEGIN__A)
2704 #define DRXK_HI_ATOMIC_BUF_END (SIO_HI_RA_RAM_USR_BEGIN__A + 7)
2705 #define DRXK_HI_ATOMIC_READ SIO_HI_RA_RAM_PAR_3_ACP_RW_READ
2706 #define DRXK_HI_ATOMIC_WRITE SIO_HI_RA_RAM_PAR_3_ACP_RW_WRITE
2708 #define DRXDAP_FASI_ADDR2BLOCK(addr) (((addr) >> 22) & 0x3F)
2709 #define DRXDAP_FASI_ADDR2BANK(addr) (((addr) >> 16) & 0x3F)
2710 #define DRXDAP_FASI_ADDR2OFFSET(addr) ((addr) & 0x7FFF)
2712 static int ConfigureI2CBridge(struct drxk_state *state, bool b_enable_bridge)
2714 int status = -EINVAL;
2718 if (state->m_drxk_state == DRXK_UNINITIALIZED)
2720 if (state->m_drxk_state == DRXK_POWERED_DOWN)
2723 if (state->no_i2c_bridge)
2726 status = write16(state, SIO_HI_RA_RAM_PAR_1__A, SIO_HI_RA_RAM_PAR_1_PAR1_SEC_KEY);
2729 if (b_enable_bridge) {
2730 status = write16(state, SIO_HI_RA_RAM_PAR_2__A, SIO_HI_RA_RAM_PAR_2_BRD_CFG_CLOSED);
2734 status = write16(state, SIO_HI_RA_RAM_PAR_2__A, SIO_HI_RA_RAM_PAR_2_BRD_CFG_OPEN);
2739 status = hi_command(state, SIO_HI_RA_RAM_CMD_BRDCTRL, 0);
2743 printk(KERN_ERR "drxk: Error %d on %s\n", status, __func__);
2747 static int set_pre_saw(struct drxk_state *state,
2748 struct s_cfg_pre_saw *p_pre_saw_cfg)
2750 int status = -EINVAL;
2754 if ((p_pre_saw_cfg == NULL)
2755 || (p_pre_saw_cfg->reference > IQM_AF_PDREF__M))
2758 status = write16(state, IQM_AF_PDREF__A, p_pre_saw_cfg->reference);
2761 printk(KERN_ERR "drxk: Error %d on %s\n", status, __func__);
2765 static int bl_direct_cmd(struct drxk_state *state, u32 target_addr,
2766 u16 rom_offset, u16 nr_of_elements, u32 time_out)
2769 u16 offset = (u16) ((target_addr >> 0) & 0x00FFFF);
2770 u16 blockbank = (u16) ((target_addr >> 16) & 0x000FFF);
2776 mutex_lock(&state->mutex);
2777 status = write16(state, SIO_BL_MODE__A, SIO_BL_MODE_DIRECT);
2780 status = write16(state, SIO_BL_TGT_HDR__A, blockbank);
2783 status = write16(state, SIO_BL_TGT_ADDR__A, offset);
2786 status = write16(state, SIO_BL_SRC_ADDR__A, rom_offset);
2789 status = write16(state, SIO_BL_SRC_LEN__A, nr_of_elements);
2792 status = write16(state, SIO_BL_ENABLE__A, SIO_BL_ENABLE_ON);
2796 end = jiffies + msecs_to_jiffies(time_out);
2798 status = read16(state, SIO_BL_STATUS__A, &bl_status);
2801 } while ((bl_status == 0x1) && time_is_after_jiffies(end));
2802 if (bl_status == 0x1) {
2803 printk(KERN_ERR "drxk: SIO not ready\n");
2809 printk(KERN_ERR "drxk: Error %d on %s\n", status, __func__);
2811 mutex_unlock(&state->mutex);
2816 static int adc_sync_measurement(struct drxk_state *state, u16 *count)
2823 /* start measurement */
2824 status = write16(state, IQM_AF_COMM_EXEC__A, IQM_AF_COMM_EXEC_ACTIVE);
2827 status = write16(state, IQM_AF_START_LOCK__A, 1);
2832 status = read16(state, IQM_AF_PHASE0__A, &data);
2836 *count = *count + 1;
2837 status = read16(state, IQM_AF_PHASE1__A, &data);
2841 *count = *count + 1;
2842 status = read16(state, IQM_AF_PHASE2__A, &data);
2846 *count = *count + 1;
2850 printk(KERN_ERR "drxk: Error %d on %s\n", status, __func__);
2854 static int adc_synchronization(struct drxk_state *state)
2861 status = adc_sync_measurement(state, &count);
2866 /* Try sampling on a diffrent edge */
2869 status = read16(state, IQM_AF_CLKNEG__A, &clk_neg);
2872 if ((clk_neg & IQM_AF_CLKNEG_CLKNEGDATA__M) ==
2873 IQM_AF_CLKNEG_CLKNEGDATA_CLK_ADC_DATA_POS) {
2874 clk_neg &= (~(IQM_AF_CLKNEG_CLKNEGDATA__M));
2876 IQM_AF_CLKNEG_CLKNEGDATA_CLK_ADC_DATA_NEG;
2878 clk_neg &= (~(IQM_AF_CLKNEG_CLKNEGDATA__M));
2880 IQM_AF_CLKNEG_CLKNEGDATA_CLK_ADC_DATA_POS;
2882 status = write16(state, IQM_AF_CLKNEG__A, clk_neg);
2885 status = adc_sync_measurement(state, &count);
2894 printk(KERN_ERR "drxk: Error %d on %s\n", status, __func__);
2898 static int set_frequency_shifter(struct drxk_state *state,
2899 u16 intermediate_freqk_hz,
2900 s32 tuner_freq_offset, bool is_dtv)
2902 bool select_pos_image = false;
2903 u32 rf_freq_residual = tuner_freq_offset;
2904 u32 fm_frequency_shift = 0;
2905 bool tuner_mirror = !state->m_b_mirror_freq_spect;
2910 u32 sampling_frequency = (u32) (state->m_sys_clock_freq / 3);
2911 u32 frequency_shift;
2912 bool image_to_select;
2917 Program frequency shifter
2918 No need to account for mirroring on RF
2921 if ((state->m_operation_mode == OM_QAM_ITU_A) ||
2922 (state->m_operation_mode == OM_QAM_ITU_C) ||
2923 (state->m_operation_mode == OM_DVBT))
2924 select_pos_image = true;
2926 select_pos_image = false;
2929 /* tuner doesn't mirror */
2930 if_freq_actual = intermediate_freqk_hz +
2931 rf_freq_residual + fm_frequency_shift;
2934 if_freq_actual = intermediate_freqk_hz -
2935 rf_freq_residual - fm_frequency_shift;
2936 if (if_freq_actual > sampling_frequency / 2) {
2938 adc_freq = sampling_frequency - if_freq_actual;
2941 /* adc doesn't mirror */
2942 adc_freq = if_freq_actual;
2946 frequency_shift = adc_freq;
2947 image_to_select = state->m_rfmirror ^ tuner_mirror ^
2948 adc_flip ^ select_pos_image;
2949 state->m_iqm_fs_rate_ofs =
2950 Frac28a((frequency_shift), sampling_frequency);
2952 if (image_to_select)
2953 state->m_iqm_fs_rate_ofs = ~state->m_iqm_fs_rate_ofs + 1;
2955 /* Program frequency shifter with tuner offset compensation */
2956 /* frequency_shift += tuner_freq_offset; TODO */
2957 status = write32(state, IQM_FS_RATE_OFS_LO__A,
2958 state->m_iqm_fs_rate_ofs);
2960 printk(KERN_ERR "drxk: Error %d on %s\n", status, __func__);
2964 static int init_agc(struct drxk_state *state, bool is_dtv)
2967 u16 ingain_tgt_min = 0;
2968 u16 ingain_tgt_max = 0;
2970 u16 clp_sum_min = 0;
2972 u16 sns_sum_min = 0;
2973 u16 sns_sum_max = 0;
2974 u16 clp_sum_max = 0;
2976 u16 ki_innergain_min = 0;
2977 u16 if_iaccu_hi_tgt = 0;
2978 u16 if_iaccu_hi_tgt_min = 0;
2979 u16 if_iaccu_hi_tgt_max = 0;
2981 u16 fast_clp_ctrl_delay = 0;
2982 u16 clp_ctrl_mode = 0;
2987 /* Common settings */
2989 if_iaccu_hi_tgt_min = 2047;
2993 /* AGCInit() not available for DVBT; init done in microcode */
2994 if (!is_qam(state)) {
2995 printk(KERN_ERR "drxk: %s: mode %d is not DVB-C\n", __func__, state->m_operation_mode);
2999 /* FIXME: Analog TV AGC require different settings */
3001 /* Standard specific settings */
3003 clp_dir_to = (u16) -9;
3006 sns_dir_to = (u16) -9;
3007 ki_innergain_min = (u16) -1030;
3008 if_iaccu_hi_tgt_max = 0x2380;
3009 if_iaccu_hi_tgt = 0x2380;
3010 ingain_tgt_min = 0x0511;
3011 ingain_tgt = 0x0511;
3012 ingain_tgt_max = 5119;
3013 fast_clp_ctrl_delay = state->m_qam_if_agc_cfg.fast_clip_ctrl_delay;
3015 status = write16(state, SCU_RAM_AGC_FAST_CLP_CTRL_DELAY__A, fast_clp_ctrl_delay);
3019 status = write16(state, SCU_RAM_AGC_CLP_CTRL_MODE__A, clp_ctrl_mode);
3022 status = write16(state, SCU_RAM_AGC_INGAIN_TGT__A, ingain_tgt);
3025 status = write16(state, SCU_RAM_AGC_INGAIN_TGT_MIN__A, ingain_tgt_min);
3028 status = write16(state, SCU_RAM_AGC_INGAIN_TGT_MAX__A, ingain_tgt_max);
3031 status = write16(state, SCU_RAM_AGC_IF_IACCU_HI_TGT_MIN__A, if_iaccu_hi_tgt_min);
3034 status = write16(state, SCU_RAM_AGC_IF_IACCU_HI_TGT_MAX__A, if_iaccu_hi_tgt_max);
3037 status = write16(state, SCU_RAM_AGC_IF_IACCU_HI__A, 0);
3040 status = write16(state, SCU_RAM_AGC_IF_IACCU_LO__A, 0);
3043 status = write16(state, SCU_RAM_AGC_RF_IACCU_HI__A, 0);
3046 status = write16(state, SCU_RAM_AGC_RF_IACCU_LO__A, 0);
3049 status = write16(state, SCU_RAM_AGC_CLP_SUM_MAX__A, clp_sum_max);
3052 status = write16(state, SCU_RAM_AGC_SNS_SUM_MAX__A, sns_sum_max);
3056 status = write16(state, SCU_RAM_AGC_KI_INNERGAIN_MIN__A, ki_innergain_min);
3059 status = write16(state, SCU_RAM_AGC_IF_IACCU_HI_TGT__A, if_iaccu_hi_tgt);
3062 status = write16(state, SCU_RAM_AGC_CLP_CYCLEN__A, clp_cyclen);
3066 status = write16(state, SCU_RAM_AGC_RF_SNS_DEV_MAX__A, 1023);
3069 status = write16(state, SCU_RAM_AGC_RF_SNS_DEV_MIN__A, (u16) -1023);
3072 status = write16(state, SCU_RAM_AGC_FAST_SNS_CTRL_DELAY__A, 50);
3076 status = write16(state, SCU_RAM_AGC_KI_MAXMINGAIN_TH__A, 20);
3079 status = write16(state, SCU_RAM_AGC_CLP_SUM_MIN__A, clp_sum_min);
3082 status = write16(state, SCU_RAM_AGC_SNS_SUM_MIN__A, sns_sum_min);
3085 status = write16(state, SCU_RAM_AGC_CLP_DIR_TO__A, clp_dir_to);
3088 status = write16(state, SCU_RAM_AGC_SNS_DIR_TO__A, sns_dir_to);
3091 status = write16(state, SCU_RAM_AGC_KI_MINGAIN__A, 0x7fff);
3094 status = write16(state, SCU_RAM_AGC_KI_MAXGAIN__A, 0x0);
3097 status = write16(state, SCU_RAM_AGC_KI_MIN__A, 0x0117);
3100 status = write16(state, SCU_RAM_AGC_KI_MAX__A, 0x0657);
3103 status = write16(state, SCU_RAM_AGC_CLP_SUM__A, 0);
3106 status = write16(state, SCU_RAM_AGC_CLP_CYCCNT__A, 0);
3109 status = write16(state, SCU_RAM_AGC_CLP_DIR_WD__A, 0);
3112 status = write16(state, SCU_RAM_AGC_CLP_DIR_STP__A, 1);
3115 status = write16(state, SCU_RAM_AGC_SNS_SUM__A, 0);
3118 status = write16(state, SCU_RAM_AGC_SNS_CYCCNT__A, 0);
3121 status = write16(state, SCU_RAM_AGC_SNS_DIR_WD__A, 0);
3124 status = write16(state, SCU_RAM_AGC_SNS_DIR_STP__A, 1);
3127 status = write16(state, SCU_RAM_AGC_SNS_CYCLEN__A, 500);
3130 status = write16(state, SCU_RAM_AGC_KI_CYCLEN__A, 500);
3134 /* Initialize inner-loop KI gain factors */
3135 status = read16(state, SCU_RAM_AGC_KI__A, &data);
3140 data &= ~SCU_RAM_AGC_KI_RF__M;
3141 data |= (DRXK_KI_RAGC_QAM << SCU_RAM_AGC_KI_RF__B);
3142 data &= ~SCU_RAM_AGC_KI_IF__M;
3143 data |= (DRXK_KI_IAGC_QAM << SCU_RAM_AGC_KI_IF__B);
3145 status = write16(state, SCU_RAM_AGC_KI__A, data);
3148 printk(KERN_ERR "drxk: Error %d on %s\n", status, __func__);
3152 static int dvbtqam_get_acc_pkt_err(struct drxk_state *state, u16 *packet_err)
3157 if (packet_err == NULL)
3158 status = write16(state, SCU_RAM_FEC_ACCUM_PKT_FAILURES__A, 0);
3160 status = read16(state, SCU_RAM_FEC_ACCUM_PKT_FAILURES__A, packet_err);
3162 printk(KERN_ERR "drxk: Error %d on %s\n", status, __func__);
3166 static int dvbt_sc_command(struct drxk_state *state,
3167 u16 cmd, u16 subcmd,
3168 u16 param0, u16 param1, u16 param2,
3169 u16 param3, u16 param4)
3178 status = read16(state, OFDM_SC_COMM_EXEC__A, &sc_exec);
3180 /* SC is not running */
3186 /* Wait until sc is ready to receive command */
3190 status = read16(state, OFDM_SC_RA_RAM_CMD__A, &cur_cmd);
3192 } while ((cur_cmd != 0) && (retry_cnt < DRXK_MAX_RETRIES));
3193 if (retry_cnt >= DRXK_MAX_RETRIES && (status < 0))
3196 /* Write sub-command */
3198 /* All commands using sub-cmd */
3199 case OFDM_SC_RA_RAM_CMD_PROC_START:
3200 case OFDM_SC_RA_RAM_CMD_SET_PREF_PARAM:
3201 case OFDM_SC_RA_RAM_CMD_PROGRAM_PARAM:
3202 status = write16(state, OFDM_SC_RA_RAM_CMD_ADDR__A, subcmd);
3211 /* Write needed parameters and the command */
3213 /* All commands using 5 parameters */
3214 /* All commands using 4 parameters */
3215 /* All commands using 3 parameters */
3216 /* All commands using 2 parameters */
3217 case OFDM_SC_RA_RAM_CMD_PROC_START:
3218 case OFDM_SC_RA_RAM_CMD_SET_PREF_PARAM:
3219 case OFDM_SC_RA_RAM_CMD_PROGRAM_PARAM:
3220 status = write16(state, OFDM_SC_RA_RAM_PARAM1__A, param1);
3221 /* All commands using 1 parameters */
3222 case OFDM_SC_RA_RAM_CMD_SET_ECHO_TIMING:
3223 case OFDM_SC_RA_RAM_CMD_USER_IO:
3224 status = write16(state, OFDM_SC_RA_RAM_PARAM0__A, param0);
3225 /* All commands using 0 parameters */
3226 case OFDM_SC_RA_RAM_CMD_GET_OP_PARAM:
3227 case OFDM_SC_RA_RAM_CMD_NULL:
3229 status = write16(state, OFDM_SC_RA_RAM_CMD__A, cmd);
3232 /* Unknown command */
3238 /* Wait until sc is ready processing command */
3242 status = read16(state, OFDM_SC_RA_RAM_CMD__A, &cur_cmd);
3244 } while ((cur_cmd != 0) && (retry_cnt < DRXK_MAX_RETRIES));
3245 if (retry_cnt >= DRXK_MAX_RETRIES && (status < 0))
3248 /* Check for illegal cmd */
3249 status = read16(state, OFDM_SC_RA_RAM_CMD_ADDR__A, &err_code);
3250 if (err_code == 0xFFFF) {
3251 /* illegal command */
3257 /* Retreive results parameters from SC */
3259 /* All commands yielding 5 results */
3260 /* All commands yielding 4 results */
3261 /* All commands yielding 3 results */
3262 /* All commands yielding 2 results */
3263 /* All commands yielding 1 result */
3264 case OFDM_SC_RA_RAM_CMD_USER_IO:
3265 case OFDM_SC_RA_RAM_CMD_GET_OP_PARAM:
3266 status = read16(state, OFDM_SC_RA_RAM_PARAM0__A, &(param0));
3267 /* All commands yielding 0 results */
3268 case OFDM_SC_RA_RAM_CMD_SET_ECHO_TIMING:
3269 case OFDM_SC_RA_RAM_CMD_SET_TIMER:
3270 case OFDM_SC_RA_RAM_CMD_PROC_START:
3271 case OFDM_SC_RA_RAM_CMD_SET_PREF_PARAM:
3272 case OFDM_SC_RA_RAM_CMD_PROGRAM_PARAM:
3273 case OFDM_SC_RA_RAM_CMD_NULL:
3276 /* Unknown command */
3279 } /* switch (cmd->cmd) */
3282 printk(KERN_ERR "drxk: Error %d on %s\n", status, __func__);
3286 static int power_up_dvbt(struct drxk_state *state)
3288 enum drx_power_mode power_mode = DRX_POWER_UP;
3292 status = ctrl_power_mode(state, &power_mode);
3294 printk(KERN_ERR "drxk: Error %d on %s\n", status, __func__);
3298 static int dvbt_ctrl_set_inc_enable(struct drxk_state *state, bool *enabled)
3303 if (*enabled == true)
3304 status = write16(state, IQM_CF_BYPASSDET__A, 0);
3306 status = write16(state, IQM_CF_BYPASSDET__A, 1);
3308 printk(KERN_ERR "drxk: Error %d on %s\n", status, __func__);
3312 #define DEFAULT_FR_THRES_8K 4000
3313 static int dvbt_ctrl_set_fr_enable(struct drxk_state *state, bool *enabled)
3319 if (*enabled == true) {
3320 /* write mask to 1 */
3321 status = write16(state, OFDM_SC_RA_RAM_FR_THRES_8K__A,
3322 DEFAULT_FR_THRES_8K);
3324 /* write mask to 0 */
3325 status = write16(state, OFDM_SC_RA_RAM_FR_THRES_8K__A, 0);
3328 printk(KERN_ERR "drxk: Error %d on %s\n", status, __func__);
3333 static int dvbt_ctrl_set_echo_threshold(struct drxk_state *state,
3334 struct drxk_cfg_dvbt_echo_thres_t *echo_thres)
3340 status = read16(state, OFDM_SC_RA_RAM_ECHO_THRES__A, &data);
3344 switch (echo_thres->fft_mode) {
3345 case DRX_FFTMODE_2K:
3346 data &= ~OFDM_SC_RA_RAM_ECHO_THRES_2K__M;
3347 data |= ((echo_thres->threshold <<
3348 OFDM_SC_RA_RAM_ECHO_THRES_2K__B)
3349 & (OFDM_SC_RA_RAM_ECHO_THRES_2K__M));
3351 case DRX_FFTMODE_8K:
3352 data &= ~OFDM_SC_RA_RAM_ECHO_THRES_8K__M;
3353 data |= ((echo_thres->threshold <<
3354 OFDM_SC_RA_RAM_ECHO_THRES_8K__B)
3355 & (OFDM_SC_RA_RAM_ECHO_THRES_8K__M));
3361 status = write16(state, OFDM_SC_RA_RAM_ECHO_THRES__A, data);
3364 printk(KERN_ERR "drxk: Error %d on %s\n", status, __func__);
3368 static int dvbt_ctrl_set_sqi_speed(struct drxk_state *state,
3369 enum drxk_cfg_dvbt_sqi_speed *speed)
3371 int status = -EINVAL;
3376 case DRXK_DVBT_SQI_SPEED_FAST:
3377 case DRXK_DVBT_SQI_SPEED_MEDIUM:
3378 case DRXK_DVBT_SQI_SPEED_SLOW:
3383 status = write16(state, SCU_RAM_FEC_PRE_RS_BER_FILTER_SH__A,
3387 printk(KERN_ERR "drxk: Error %d on %s\n", status, __func__);
3391 /*============================================================================*/
3394 * \brief Activate DVBT specific presets
3395 * \param demod instance of demodulator.
3396 * \return DRXStatus_t.
3398 * Called in DVBTSetStandard
3401 static int dvbt_activate_presets(struct drxk_state *state)
3404 bool setincenable = false;
3405 bool setfrenable = true;
3407 struct drxk_cfg_dvbt_echo_thres_t echo_thres2k = { 0, DRX_FFTMODE_2K };
3408 struct drxk_cfg_dvbt_echo_thres_t echo_thres8k = { 0, DRX_FFTMODE_8K };
3411 status = dvbt_ctrl_set_inc_enable(state, &setincenable);
3414 status = dvbt_ctrl_set_fr_enable(state, &setfrenable);
3417 status = dvbt_ctrl_set_echo_threshold(state, &echo_thres2k);
3420 status = dvbt_ctrl_set_echo_threshold(state, &echo_thres8k);
3423 status = write16(state, SCU_RAM_AGC_INGAIN_TGT_MAX__A, state->m_dvbt_if_agc_cfg.ingain_tgt_max);
3426 printk(KERN_ERR "drxk: Error %d on %s\n", status, __func__);
3430 /*============================================================================*/
3433 * \brief Initialize channelswitch-independent settings for DVBT.
3434 * \param demod instance of demodulator.
3435 * \return DRXStatus_t.
3437 * For ROM code channel filter taps are loaded from the bootloader. For microcode
3438 * the DVB-T taps from the drxk_filters.h are used.
3440 static int set_dvbt_standard(struct drxk_state *state,
3441 enum operation_mode o_mode)
3449 power_up_dvbt(state);
3450 /* added antenna switch */
3451 switch_antenna_to_dvbt(state);
3452 /* send OFDM reset command */
3453 status = scu_command(state, SCU_RAM_COMMAND_STANDARD_OFDM | SCU_RAM_COMMAND_CMD_DEMOD_RESET, 0, NULL, 1, &cmd_result);
3457 /* send OFDM setenv command */
3458 status = scu_command(state, SCU_RAM_COMMAND_STANDARD_OFDM | SCU_RAM_COMMAND_CMD_DEMOD_SET_ENV, 0, NULL, 1, &cmd_result);
3462 /* reset datapath for OFDM, processors first */
3463 status = write16(state, OFDM_SC_COMM_EXEC__A, OFDM_SC_COMM_EXEC_STOP);
3466 status = write16(state, OFDM_LC_COMM_EXEC__A, OFDM_LC_COMM_EXEC_STOP);
3469 status = write16(state, IQM_COMM_EXEC__A, IQM_COMM_EXEC_B_STOP);
3474 /* synchronize on ofdstate->m_festart */
3475 status = write16(state, IQM_AF_UPD_SEL__A, 1);
3478 /* window size for clipping ADC detection */
3479 status = write16(state, IQM_AF_CLP_LEN__A, 0);
3482 /* window size for for sense pre-SAW detection */
3483 status = write16(state, IQM_AF_SNS_LEN__A, 0);
3486 /* sense threshold for sense pre-SAW detection */
3487 status = write16(state, IQM_AF_AMUX__A, IQM_AF_AMUX_SIGNAL2ADC);
3490 status = set_iqm_af(state, true);
3494 status = write16(state, IQM_AF_AGC_RF__A, 0);
3498 /* Impulse noise cruncher setup */
3499 status = write16(state, IQM_AF_INC_LCT__A, 0); /* crunch in IQM_CF */
3502 status = write16(state, IQM_CF_DET_LCT__A, 0); /* detect in IQM_CF */
3505 status = write16(state, IQM_CF_WND_LEN__A, 3); /* peak detector window length */
3509 status = write16(state, IQM_RC_STRETCH__A, 16);
3512 status = write16(state, IQM_CF_OUT_ENA__A, 0x4); /* enable output 2 */
3515 status = write16(state, IQM_CF_DS_ENA__A, 0x4); /* decimate output 2 */
3518 status = write16(state, IQM_CF_SCALE__A, 1600);
3521 status = write16(state, IQM_CF_SCALE_SH__A, 0);
3525 /* virtual clipping threshold for clipping ADC detection */
3526 status = write16(state, IQM_AF_CLP_TH__A, 448);
3529 status = write16(state, IQM_CF_DATATH__A, 495); /* crunching threshold */
3533 status = bl_chain_cmd(state, DRXK_BL_ROM_OFFSET_TAPS_DVBT, DRXK_BLCC_NR_ELEMENTS_TAPS, DRXK_BLC_TIMEOUT);
3537 status = write16(state, IQM_CF_PKDTH__A, 2); /* peak detector threshold */
3540 status = write16(state, IQM_CF_POW_MEAS_LEN__A, 2);
3543 /* enable power measurement interrupt */
3544 status = write16(state, IQM_CF_COMM_INT_MSK__A, 1);
3547 status = write16(state, IQM_COMM_EXEC__A, IQM_COMM_EXEC_B_ACTIVE);
3551 /* IQM will not be reset from here, sync ADC and update/init AGC */
3552 status = adc_synchronization(state);
3555 status = set_pre_saw(state, &state->m_dvbt_pre_saw_cfg);
3559 /* Halt SCU to enable safe non-atomic accesses */
3560 status = write16(state, SCU_COMM_EXEC__A, SCU_COMM_EXEC_HOLD);
3564 status = set_agc_rf(state, &state->m_dvbt_rf_agc_cfg, true);
3567 status = set_agc_if(state, &state->m_dvbt_if_agc_cfg, true);
3571 /* Set Noise Estimation notch width and enable DC fix */
3572 status = read16(state, OFDM_SC_RA_RAM_CONFIG__A, &data);
3575 data |= OFDM_SC_RA_RAM_CONFIG_NE_FIX_ENABLE__M;
3576 status = write16(state, OFDM_SC_RA_RAM_CONFIG__A, data);
3580 /* Activate SCU to enable SCU commands */
3581 status = write16(state, SCU_COMM_EXEC__A, SCU_COMM_EXEC_ACTIVE);
3585 if (!state->m_drxk_a3_rom_code) {
3586 /* AGCInit() is not done for DVBT, so set agcfast_clip_ctrl_delay */
3587 status = write16(state, SCU_RAM_AGC_FAST_CLP_CTRL_DELAY__A, state->m_dvbt_if_agc_cfg.fast_clip_ctrl_delay);
3593 #ifdef COMPILE_FOR_NONRT
3594 status = write16(state, OFDM_SC_RA_RAM_BE_OPT_DELAY__A, 1);
3597 status = write16(state, OFDM_SC_RA_RAM_BE_OPT_INIT_DELAY__A, 2);
3603 status = write16(state, FEC_DI_INPUT_CTL__A, 1); /* OFDM input */
3608 #ifdef COMPILE_FOR_NONRT
3609 status = write16(state, FEC_RS_MEASUREMENT_PERIOD__A, 0x400);
3613 status = write16(state, FEC_RS_MEASUREMENT_PERIOD__A, 0x1000);
3617 status = write16(state, FEC_RS_MEASUREMENT_PRESCALE__A, 0x0001);
3621 /* Setup MPEG bus */
3622 status = mpegts_dto_setup(state, OM_DVBT);
3625 /* Set DVBT Presets */
3626 status = dvbt_activate_presets(state);
3632 printk(KERN_ERR "drxk: Error %d on %s\n", status, __func__);
3636 /*============================================================================*/
3638 * \brief start dvbt demodulating for channel.
3639 * \param demod instance of demodulator.
3640 * \return DRXStatus_t.
3642 static int dvbt_start(struct drxk_state *state)
3646 /* drxk_ofdm_sc_cmd_t scCmd; */
3649 /* start correct processes to get in lock */
3650 /* DRXK: OFDM_SC_RA_RAM_PROC_LOCKTRACK is no longer in mapfile! */
3651 param1 = OFDM_SC_RA_RAM_LOCKTRACK_MIN;
3652 status = dvbt_sc_command(state, OFDM_SC_RA_RAM_CMD_PROC_START, 0, OFDM_SC_RA_RAM_SW_EVENT_RUN_NMASK__M, param1, 0, 0, 0);
3656 status = mpegts_start(state);
3659 status = write16(state, FEC_COMM_EXEC__A, FEC_COMM_EXEC_ACTIVE);
3664 printk(KERN_ERR "drxk: Error %d on %s\n", status, __func__);
3669 /*============================================================================*/
3672 * \brief Set up dvbt demodulator for channel.
3673 * \param demod instance of demodulator.
3674 * \return DRXStatus_t.
3675 * // original DVBTSetChannel()
3677 static int set_dvbt(struct drxk_state *state, u16 intermediate_freqk_hz,
3678 s32 tuner_freq_offset)
3681 u16 transmission_params = 0;
3682 u16 operation_mode = 0;
3683 u32 iqm_rc_rate_ofs = 0;
3688 dprintk(1, "IF =%d, TFO = %d\n", intermediate_freqk_hz, tuner_freq_offset);
3690 status = scu_command(state, SCU_RAM_COMMAND_STANDARD_OFDM | SCU_RAM_COMMAND_CMD_DEMOD_STOP, 0, NULL, 1, &cmd_result);
3694 /* Halt SCU to enable safe non-atomic accesses */
3695 status = write16(state, SCU_COMM_EXEC__A, SCU_COMM_EXEC_HOLD);
3699 /* Stop processors */
3700 status = write16(state, OFDM_SC_COMM_EXEC__A, OFDM_SC_COMM_EXEC_STOP);
3703 status = write16(state, OFDM_LC_COMM_EXEC__A, OFDM_LC_COMM_EXEC_STOP);
3707 /* Mandatory fix, always stop CP, required to set spl offset back to
3708 hardware default (is set to 0 by ucode during pilot detection */
3709 status = write16(state, OFDM_CP_COMM_EXEC__A, OFDM_CP_COMM_EXEC_STOP);
3713 /*== Write channel settings to device =====================================*/
3716 switch (state->props.transmission_mode) {
3717 case TRANSMISSION_MODE_AUTO:
3719 operation_mode |= OFDM_SC_RA_RAM_OP_AUTO_MODE__M;
3720 /* fall through , try first guess DRX_FFTMODE_8K */
3721 case TRANSMISSION_MODE_8K:
3722 transmission_params |= OFDM_SC_RA_RAM_OP_PARAM_MODE_8K;
3724 case TRANSMISSION_MODE_2K:
3725 transmission_params |= OFDM_SC_RA_RAM_OP_PARAM_MODE_2K;
3730 switch (state->props.guard_interval) {
3732 case GUARD_INTERVAL_AUTO:
3733 operation_mode |= OFDM_SC_RA_RAM_OP_AUTO_GUARD__M;
3734 /* fall through , try first guess DRX_GUARD_1DIV4 */
3735 case GUARD_INTERVAL_1_4:
3736 transmission_params |= OFDM_SC_RA_RAM_OP_PARAM_GUARD_4;
3738 case GUARD_INTERVAL_1_32:
3739 transmission_params |= OFDM_SC_RA_RAM_OP_PARAM_GUARD_32;
3741 case GUARD_INTERVAL_1_16:
3742 transmission_params |= OFDM_SC_RA_RAM_OP_PARAM_GUARD_16;
3744 case GUARD_INTERVAL_1_8:
3745 transmission_params |= OFDM_SC_RA_RAM_OP_PARAM_GUARD_8;
3750 switch (state->props.hierarchy) {
3751 case HIERARCHY_AUTO:
3752 case HIERARCHY_NONE:
3754 operation_mode |= OFDM_SC_RA_RAM_OP_AUTO_HIER__M;
3755 /* fall through , try first guess SC_RA_RAM_OP_PARAM_HIER_NO */
3756 /* transmission_params |= OFDM_SC_RA_RAM_OP_PARAM_HIER_NO; */
3759 transmission_params |= OFDM_SC_RA_RAM_OP_PARAM_HIER_A1;
3762 transmission_params |= OFDM_SC_RA_RAM_OP_PARAM_HIER_A2;
3765 transmission_params |= OFDM_SC_RA_RAM_OP_PARAM_HIER_A4;
3771 switch (state->props.modulation) {
3774 operation_mode |= OFDM_SC_RA_RAM_OP_AUTO_CONST__M;
3775 /* fall through , try first guess DRX_CONSTELLATION_QAM64 */
3777 transmission_params |= OFDM_SC_RA_RAM_OP_PARAM_CONST_QAM64;
3780 transmission_params |= OFDM_SC_RA_RAM_OP_PARAM_CONST_QPSK;
3783 transmission_params |= OFDM_SC_RA_RAM_OP_PARAM_CONST_QAM16;
3787 /* No hierachical channels support in BDA */
3788 /* Priority (only for hierarchical channels) */
3789 switch (channel->priority) {
3790 case DRX_PRIORITY_LOW:
3791 transmission_params |= OFDM_SC_RA_RAM_OP_PARAM_PRIO_LO;
3792 WR16(dev_addr, OFDM_EC_SB_PRIOR__A,
3793 OFDM_EC_SB_PRIOR_LO);
3795 case DRX_PRIORITY_HIGH:
3796 transmission_params |= OFDM_SC_RA_RAM_OP_PARAM_PRIO_HI;
3797 WR16(dev_addr, OFDM_EC_SB_PRIOR__A,
3798 OFDM_EC_SB_PRIOR_HI));
3800 case DRX_PRIORITY_UNKNOWN: /* fall through */
3806 /* Set Priorty high */
3807 transmission_params |= OFDM_SC_RA_RAM_OP_PARAM_PRIO_HI;
3808 status = write16(state, OFDM_EC_SB_PRIOR__A, OFDM_EC_SB_PRIOR_HI);
3814 switch (state->props.code_rate_HP) {
3817 operation_mode |= OFDM_SC_RA_RAM_OP_AUTO_RATE__M;
3818 /* fall through , try first guess DRX_CODERATE_2DIV3 */
3820 transmission_params |= OFDM_SC_RA_RAM_OP_PARAM_RATE_2_3;
3823 transmission_params |= OFDM_SC_RA_RAM_OP_PARAM_RATE_1_2;
3826 transmission_params |= OFDM_SC_RA_RAM_OP_PARAM_RATE_3_4;
3829 transmission_params |= OFDM_SC_RA_RAM_OP_PARAM_RATE_5_6;
3832 transmission_params |= OFDM_SC_RA_RAM_OP_PARAM_RATE_7_8;
3836 /* SAW filter selection: normaly not necesarry, but if wanted
3837 the application can select a SAW filter via the driver by using UIOs */
3838 /* First determine real bandwidth (Hz) */
3839 /* Also set delay for impulse noise cruncher */
3840 /* Also set parameters for EC_OC fix, note EC_OC_REG_TMD_HIL_MAR is changed
3841 by SC for fix for some 8K,1/8 guard but is restored by InitEC and ResetEC
3843 switch (state->props.bandwidth_hz) {
3845 state->props.bandwidth_hz = 8000000;
3848 bandwidth = DRXK_BANDWIDTH_8MHZ_IN_HZ;
3849 status = write16(state, OFDM_SC_RA_RAM_SRMM_FIX_FACT_8K__A, 3052);
3852 /* cochannel protection for PAL 8 MHz */
3853 status = write16(state, OFDM_SC_RA_RAM_NI_INIT_8K_PER_LEFT__A, 7);
3856 status = write16(state, OFDM_SC_RA_RAM_NI_INIT_8K_PER_RIGHT__A, 7);
3859 status = write16(state, OFDM_SC_RA_RAM_NI_INIT_2K_PER_LEFT__A, 7);
3862 status = write16(state, OFDM_SC_RA_RAM_NI_INIT_2K_PER_RIGHT__A, 1);
3867 bandwidth = DRXK_BANDWIDTH_7MHZ_IN_HZ;
3868 status = write16(state, OFDM_SC_RA_RAM_SRMM_FIX_FACT_8K__A, 3491);
3871 /* cochannel protection for PAL 7 MHz */
3872 status = write16(state, OFDM_SC_RA_RAM_NI_INIT_8K_PER_LEFT__A, 8);
3875 status = write16(state, OFDM_SC_RA_RAM_NI_INIT_8K_PER_RIGHT__A, 8);
3878 status = write16(state, OFDM_SC_RA_RAM_NI_INIT_2K_PER_LEFT__A, 4);
3881 status = write16(state, OFDM_SC_RA_RAM_NI_INIT_2K_PER_RIGHT__A, 1);
3886 bandwidth = DRXK_BANDWIDTH_6MHZ_IN_HZ;
3887 status = write16(state, OFDM_SC_RA_RAM_SRMM_FIX_FACT_8K__A, 4073);
3890 /* cochannel protection for NTSC 6 MHz */
3891 status = write16(state, OFDM_SC_RA_RAM_NI_INIT_8K_PER_LEFT__A, 19);
3894 status = write16(state, OFDM_SC_RA_RAM_NI_INIT_8K_PER_RIGHT__A, 19);
3897 status = write16(state, OFDM_SC_RA_RAM_NI_INIT_2K_PER_LEFT__A, 14);
3900 status = write16(state, OFDM_SC_RA_RAM_NI_INIT_2K_PER_RIGHT__A, 1);
3909 if (iqm_rc_rate_ofs == 0) {
3910 /* Now compute IQM_RC_RATE_OFS
3911 (((SysFreq/BandWidth)/2)/2) -1) * 2^23)
3913 ((SysFreq / BandWidth) * (2^21)) - (2^23)
3915 /* (SysFreq / BandWidth) * (2^28) */
3916 /* assert (MAX(sysClk)/MIN(bandwidth) < 16)
3917 => assert(MAX(sysClk) < 16*MIN(bandwidth))
3918 => assert(109714272 > 48000000) = true so Frac 28 can be used */
3919 iqm_rc_rate_ofs = Frac28a((u32)
3920 ((state->m_sys_clock_freq *
3921 1000) / 3), bandwidth);
3922 /* (SysFreq / BandWidth) * (2^21), rounding before truncating */
3923 if ((iqm_rc_rate_ofs & 0x7fL) >= 0x40)
3924 iqm_rc_rate_ofs += 0x80L;
3925 iqm_rc_rate_ofs = iqm_rc_rate_ofs >> 7;
3926 /* ((SysFreq / BandWidth) * (2^21)) - (2^23) */
3927 iqm_rc_rate_ofs = iqm_rc_rate_ofs - (1 << 23);
3931 ((((u32) IQM_RC_RATE_OFS_HI__M) <<
3932 IQM_RC_RATE_OFS_LO__W) | IQM_RC_RATE_OFS_LO__M);
3933 status = write32(state, IQM_RC_RATE_OFS_LO__A, iqm_rc_rate_ofs);
3937 /* Bandwidth setting done */
3940 status = dvbt_set_frequency_shift(demod, channel, tuner_offset);
3944 status = set_frequency_shifter(state, intermediate_freqk_hz, tuner_freq_offset, true);
3948 /*== start SC, write channel settings to SC ===============================*/
3950 /* Activate SCU to enable SCU commands */
3951 status = write16(state, SCU_COMM_EXEC__A, SCU_COMM_EXEC_ACTIVE);
3955 /* Enable SC after setting all other parameters */
3956 status = write16(state, OFDM_SC_COMM_STATE__A, 0);
3959 status = write16(state, OFDM_SC_COMM_EXEC__A, 1);
3964 status = scu_command(state, SCU_RAM_COMMAND_STANDARD_OFDM | SCU_RAM_COMMAND_CMD_DEMOD_START, 0, NULL, 1, &cmd_result);
3968 /* Write SC parameter registers, set all AUTO flags in operation mode */
3969 param1 = (OFDM_SC_RA_RAM_OP_AUTO_MODE__M |
3970 OFDM_SC_RA_RAM_OP_AUTO_GUARD__M |
3971 OFDM_SC_RA_RAM_OP_AUTO_CONST__M |
3972 OFDM_SC_RA_RAM_OP_AUTO_HIER__M |
3973 OFDM_SC_RA_RAM_OP_AUTO_RATE__M);
3974 status = dvbt_sc_command(state, OFDM_SC_RA_RAM_CMD_SET_PREF_PARAM,
3975 0, transmission_params, param1, 0, 0, 0);
3979 if (!state->m_drxk_a3_rom_code)
3980 status = dvbt_ctrl_set_sqi_speed(state, &state->m_sqi_speed);
3983 printk(KERN_ERR "drxk: Error %d on %s\n", status, __func__);
3989 /*============================================================================*/
3992 * \brief Retreive lock status .
3993 * \param demod Pointer to demodulator instance.
3994 * \param lockStat Pointer to lock status structure.
3995 * \return DRXStatus_t.
3998 static int get_dvbt_lock_status(struct drxk_state *state, u32 *p_lock_status)
4001 const u16 mpeg_lock_mask = (OFDM_SC_RA_RAM_LOCK_MPEG__M |
4002 OFDM_SC_RA_RAM_LOCK_FEC__M);
4003 const u16 fec_lock_mask = (OFDM_SC_RA_RAM_LOCK_FEC__M);
4004 const u16 demod_lock_mask = OFDM_SC_RA_RAM_LOCK_DEMOD__M;
4006 u16 sc_ra_ram_lock = 0;
4007 u16 sc_comm_exec = 0;
4011 *p_lock_status = NOT_LOCKED;
4013 /* Check if SC is running */
4014 status = read16(state, OFDM_SC_COMM_EXEC__A, &sc_comm_exec);
4017 if (sc_comm_exec == OFDM_SC_COMM_EXEC_STOP)
4020 status = read16(state, OFDM_SC_RA_RAM_LOCK__A, &sc_ra_ram_lock);
4024 if ((sc_ra_ram_lock & mpeg_lock_mask) == mpeg_lock_mask)
4025 *p_lock_status = MPEG_LOCK;
4026 else if ((sc_ra_ram_lock & fec_lock_mask) == fec_lock_mask)
4027 *p_lock_status = FEC_LOCK;
4028 else if ((sc_ra_ram_lock & demod_lock_mask) == demod_lock_mask)
4029 *p_lock_status = DEMOD_LOCK;
4030 else if (sc_ra_ram_lock & OFDM_SC_RA_RAM_LOCK_NODVBT__M)
4031 *p_lock_status = NEVER_LOCK;
4034 printk(KERN_ERR "drxk: Error %d on %s\n", status, __func__);
4039 static int power_up_qam(struct drxk_state *state)
4041 enum drx_power_mode power_mode = DRXK_POWER_DOWN_OFDM;
4045 status = ctrl_power_mode(state, &power_mode);
4047 printk(KERN_ERR "drxk: Error %d on %s\n", status, __func__);
4053 /** Power Down QAM */
4054 static int power_down_qam(struct drxk_state *state)
4061 status = read16(state, SCU_COMM_EXEC__A, &data);
4064 if (data == SCU_COMM_EXEC_ACTIVE) {
4069 /* stop all comstate->m_exec */
4070 status = write16(state, QAM_COMM_EXEC__A, QAM_COMM_EXEC_STOP);
4073 status = scu_command(state, SCU_RAM_COMMAND_STANDARD_QAM | SCU_RAM_COMMAND_CMD_DEMOD_STOP, 0, NULL, 1, &cmd_result);
4078 status = set_iqm_af(state, false);
4082 printk(KERN_ERR "drxk: Error %d on %s\n", status, __func__);
4087 /*============================================================================*/
4090 * \brief Setup of the QAM Measurement intervals for signal quality
4091 * \param demod instance of demod.
4092 * \param modulation current modulation.
4093 * \return DRXStatus_t.
4096 * Take into account that for certain settings the errorcounters can overflow.
4097 * The implementation does not check this.
4100 static int set_qam_measurement(struct drxk_state *state,
4101 enum e_drxk_constellation modulation,
4104 u32 fec_bits_desired = 0; /* BER accounting period */
4105 u32 fec_rs_period_total = 0; /* Total period */
4106 u16 fec_rs_prescale = 0; /* ReedSolomon Measurement Prescale */
4107 u16 fec_rs_period = 0; /* Value for corresponding I2C register */
4112 fec_rs_prescale = 1;
4113 /* fec_bits_desired = symbol_rate [kHz] *
4119 switch (modulation) {
4120 case DRX_CONSTELLATION_QAM16:
4121 fec_bits_desired = 4 * symbol_rate;
4123 case DRX_CONSTELLATION_QAM32:
4124 fec_bits_desired = 5 * symbol_rate;
4126 case DRX_CONSTELLATION_QAM64:
4127 fec_bits_desired = 6 * symbol_rate;
4129 case DRX_CONSTELLATION_QAM128:
4130 fec_bits_desired = 7 * symbol_rate;
4132 case DRX_CONSTELLATION_QAM256:
4133 fec_bits_desired = 8 * symbol_rate;
4141 fec_bits_desired /= 1000; /* symbol_rate [Hz] -> symbol_rate [kHz] */
4142 fec_bits_desired *= 500; /* meas. period [ms] */
4144 /* Annex A/C: bits/RsPeriod = 204 * 8 = 1632 */
4145 /* fec_rs_period_total = fec_bits_desired / 1632 */
4146 fec_rs_period_total = (fec_bits_desired / 1632UL) + 1; /* roughly ceil */
4148 /* fec_rs_period_total = fec_rs_prescale * fec_rs_period */
4149 fec_rs_prescale = 1 + (u16) (fec_rs_period_total >> 16);
4150 if (fec_rs_prescale == 0) {
4151 /* Divide by zero (though impossible) */
4157 ((u16) fec_rs_period_total +
4158 (fec_rs_prescale >> 1)) / fec_rs_prescale;
4160 /* write corresponding registers */
4161 status = write16(state, FEC_RS_MEASUREMENT_PERIOD__A, fec_rs_period);
4164 status = write16(state, FEC_RS_MEASUREMENT_PRESCALE__A, fec_rs_prescale);
4167 status = write16(state, FEC_OC_SNC_FAIL_PERIOD__A, fec_rs_period);
4170 printk(KERN_ERR "drxk: Error %d on %s\n", status, __func__);
4174 static int set_qam16(struct drxk_state *state)
4179 /* QAM Equalizer Setup */
4181 status = write16(state, SCU_RAM_QAM_EQ_CMA_RAD0__A, 13517);
4184 status = write16(state, SCU_RAM_QAM_EQ_CMA_RAD1__A, 13517);
4187 status = write16(state, SCU_RAM_QAM_EQ_CMA_RAD2__A, 13517);
4190 status = write16(state, SCU_RAM_QAM_EQ_CMA_RAD3__A, 13517);
4193 status = write16(state, SCU_RAM_QAM_EQ_CMA_RAD4__A, 13517);
4196 status = write16(state, SCU_RAM_QAM_EQ_CMA_RAD5__A, 13517);
4199 /* Decision Feedback Equalizer */
4200 status = write16(state, QAM_DQ_QUAL_FUN0__A, 2);
4203 status = write16(state, QAM_DQ_QUAL_FUN1__A, 2);
4206 status = write16(state, QAM_DQ_QUAL_FUN2__A, 2);
4209 status = write16(state, QAM_DQ_QUAL_FUN3__A, 2);
4212 status = write16(state, QAM_DQ_QUAL_FUN4__A, 2);
4215 status = write16(state, QAM_DQ_QUAL_FUN5__A, 0);
4219 status = write16(state, QAM_SY_SYNC_HWM__A, 5);
4222 status = write16(state, QAM_SY_SYNC_AWM__A, 4);
4225 status = write16(state, QAM_SY_SYNC_LWM__A, 3);
4229 /* QAM Slicer Settings */
4230 status = write16(state, SCU_RAM_QAM_SL_SIG_POWER__A, DRXK_QAM_SL_SIG_POWER_QAM16);
4234 /* QAM Loop Controller Coeficients */
4235 status = write16(state, SCU_RAM_QAM_LC_CA_FINE__A, 15);
4238 status = write16(state, SCU_RAM_QAM_LC_CA_COARSE__A, 40);
4241 status = write16(state, SCU_RAM_QAM_LC_EP_FINE__A, 12);
4244 status = write16(state, SCU_RAM_QAM_LC_EP_MEDIUM__A, 24);
4247 status = write16(state, SCU_RAM_QAM_LC_EP_COARSE__A, 24);
4250 status = write16(state, SCU_RAM_QAM_LC_EI_FINE__A, 12);
4253 status = write16(state, SCU_RAM_QAM_LC_EI_MEDIUM__A, 16);
4256 status = write16(state, SCU_RAM_QAM_LC_EI_COARSE__A, 16);
4260 status = write16(state, SCU_RAM_QAM_LC_CP_FINE__A, 5);
4263 status = write16(state, SCU_RAM_QAM_LC_CP_MEDIUM__A, 20);
4266 status = write16(state, SCU_RAM_QAM_LC_CP_COARSE__A, 80);
4269 status = write16(state, SCU_RAM_QAM_LC_CI_FINE__A, 5);
4272 status = write16(state, SCU_RAM_QAM_LC_CI_MEDIUM__A, 20);
4275 status = write16(state, SCU_RAM_QAM_LC_CI_COARSE__A, 50);
4278 status = write16(state, SCU_RAM_QAM_LC_CF_FINE__A, 16);
4281 status = write16(state, SCU_RAM_QAM_LC_CF_MEDIUM__A, 16);
4284 status = write16(state, SCU_RAM_QAM_LC_CF_COARSE__A, 32);
4287 status = write16(state, SCU_RAM_QAM_LC_CF1_FINE__A, 5);
4290 status = write16(state, SCU_RAM_QAM_LC_CF1_MEDIUM__A, 10);
4293 status = write16(state, SCU_RAM_QAM_LC_CF1_COARSE__A, 10);
4298 /* QAM State Machine (FSM) Thresholds */
4300 status = write16(state, SCU_RAM_QAM_FSM_RTH__A, 140);
4303 status = write16(state, SCU_RAM_QAM_FSM_FTH__A, 50);
4306 status = write16(state, SCU_RAM_QAM_FSM_CTH__A, 95);
4309 status = write16(state, SCU_RAM_QAM_FSM_PTH__A, 120);
4312 status = write16(state, SCU_RAM_QAM_FSM_QTH__A, 230);
4315 status = write16(state, SCU_RAM_QAM_FSM_MTH__A, 105);
4319 status = write16(state, SCU_RAM_QAM_FSM_RATE_LIM__A, 40);
4322 status = write16(state, SCU_RAM_QAM_FSM_COUNT_LIM__A, 4);
4325 status = write16(state, SCU_RAM_QAM_FSM_FREQ_LIM__A, 24);
4330 /* QAM FSM Tracking Parameters */
4332 status = write16(state, SCU_RAM_QAM_FSM_MEDIAN_AV_MULT__A, (u16) 16);
4335 status = write16(state, SCU_RAM_QAM_FSM_RADIUS_AV_LIMIT__A, (u16) 220);
4338 status = write16(state, SCU_RAM_QAM_FSM_LCAVG_OFFSET1__A, (u16) 25);
4341 status = write16(state, SCU_RAM_QAM_FSM_LCAVG_OFFSET2__A, (u16) 6);
4344 status = write16(state, SCU_RAM_QAM_FSM_LCAVG_OFFSET3__A, (u16) -24);
4347 status = write16(state, SCU_RAM_QAM_FSM_LCAVG_OFFSET4__A, (u16) -65);
4350 status = write16(state, SCU_RAM_QAM_FSM_LCAVG_OFFSET5__A, (u16) -127);
4356 printk(KERN_ERR "drxk: Error %d on %s\n", status, __func__);
4360 /*============================================================================*/
4363 * \brief QAM32 specific setup
4364 * \param demod instance of demod.
4365 * \return DRXStatus_t.
4367 static int set_qam32(struct drxk_state *state)
4373 /* QAM Equalizer Setup */
4375 status = write16(state, SCU_RAM_QAM_EQ_CMA_RAD0__A, 6707);
4378 status = write16(state, SCU_RAM_QAM_EQ_CMA_RAD1__A, 6707);
4381 status = write16(state, SCU_RAM_QAM_EQ_CMA_RAD2__A, 6707);
4384 status = write16(state, SCU_RAM_QAM_EQ_CMA_RAD3__A, 6707);
4387 status = write16(state, SCU_RAM_QAM_EQ_CMA_RAD4__A, 6707);
4390 status = write16(state, SCU_RAM_QAM_EQ_CMA_RAD5__A, 6707);
4394 /* Decision Feedback Equalizer */
4395 status = write16(state, QAM_DQ_QUAL_FUN0__A, 3);
4398 status = write16(state, QAM_DQ_QUAL_FUN1__A, 3);
4401 status = write16(state, QAM_DQ_QUAL_FUN2__A, 3);
4404 status = write16(state, QAM_DQ_QUAL_FUN3__A, 3);
4407 status = write16(state, QAM_DQ_QUAL_FUN4__A, 3);
4410 status = write16(state, QAM_DQ_QUAL_FUN5__A, 0);
4414 status = write16(state, QAM_SY_SYNC_HWM__A, 6);
4417 status = write16(state, QAM_SY_SYNC_AWM__A, 5);
4420 status = write16(state, QAM_SY_SYNC_LWM__A, 3);
4424 /* QAM Slicer Settings */
4426 status = write16(state, SCU_RAM_QAM_SL_SIG_POWER__A, DRXK_QAM_SL_SIG_POWER_QAM32);
4431 /* QAM Loop Controller Coeficients */
4433 status = write16(state, SCU_RAM_QAM_LC_CA_FINE__A, 15);
4436 status = write16(state, SCU_RAM_QAM_LC_CA_COARSE__A, 40);
4439 status = write16(state, SCU_RAM_QAM_LC_EP_FINE__A, 12);
4442 status = write16(state, SCU_RAM_QAM_LC_EP_MEDIUM__A, 24);
4445 status = write16(state, SCU_RAM_QAM_LC_EP_COARSE__A, 24);
4448 status = write16(state, SCU_RAM_QAM_LC_EI_FINE__A, 12);
4451 status = write16(state, SCU_RAM_QAM_LC_EI_MEDIUM__A, 16);
4454 status = write16(state, SCU_RAM_QAM_LC_EI_COARSE__A, 16);
4458 status = write16(state, SCU_RAM_QAM_LC_CP_FINE__A, 5);
4461 status = write16(state, SCU_RAM_QAM_LC_CP_MEDIUM__A, 20);
4464 status = write16(state, SCU_RAM_QAM_LC_CP_COARSE__A, 80);
4467 status = write16(state, SCU_RAM_QAM_LC_CI_FINE__A, 5);
4470 status = write16(state, SCU_RAM_QAM_LC_CI_MEDIUM__A, 20);
4473 status = write16(state, SCU_RAM_QAM_LC_CI_COARSE__A, 50);
4476 status = write16(state, SCU_RAM_QAM_LC_CF_FINE__A, 16);
4479 status = write16(state, SCU_RAM_QAM_LC_CF_MEDIUM__A, 16);
4482 status = write16(state, SCU_RAM_QAM_LC_CF_COARSE__A, 16);
4485 status = write16(state, SCU_RAM_QAM_LC_CF1_FINE__A, 5);
4488 status = write16(state, SCU_RAM_QAM_LC_CF1_MEDIUM__A, 10);
4491 status = write16(state, SCU_RAM_QAM_LC_CF1_COARSE__A, 0);
4496 /* QAM State Machine (FSM) Thresholds */
4498 status = write16(state, SCU_RAM_QAM_FSM_RTH__A, 90);
4501 status = write16(state, SCU_RAM_QAM_FSM_FTH__A, 50);
4504 status = write16(state, SCU_RAM_QAM_FSM_CTH__A, 80);
4507 status = write16(state, SCU_RAM_QAM_FSM_PTH__A, 100);
4510 status = write16(state, SCU_RAM_QAM_FSM_QTH__A, 170);
4513 status = write16(state, SCU_RAM_QAM_FSM_MTH__A, 100);
4517 status = write16(state, SCU_RAM_QAM_FSM_RATE_LIM__A, 40);
4520 status = write16(state, SCU_RAM_QAM_FSM_COUNT_LIM__A, 4);
4523 status = write16(state, SCU_RAM_QAM_FSM_FREQ_LIM__A, 10);
4528 /* QAM FSM Tracking Parameters */
4530 status = write16(state, SCU_RAM_QAM_FSM_MEDIAN_AV_MULT__A, (u16) 12);
4533 status = write16(state, SCU_RAM_QAM_FSM_RADIUS_AV_LIMIT__A, (u16) 140);
4536 status = write16(state, SCU_RAM_QAM_FSM_LCAVG_OFFSET1__A, (u16) -8);
4539 status = write16(state, SCU_RAM_QAM_FSM_LCAVG_OFFSET2__A, (u16) -16);
4542 status = write16(state, SCU_RAM_QAM_FSM_LCAVG_OFFSET3__A, (u16) -26);
4545 status = write16(state, SCU_RAM_QAM_FSM_LCAVG_OFFSET4__A, (u16) -56);
4548 status = write16(state, SCU_RAM_QAM_FSM_LCAVG_OFFSET5__A, (u16) -86);
4551 printk(KERN_ERR "drxk: Error %d on %s\n", status, __func__);
4555 /*============================================================================*/
4558 * \brief QAM64 specific setup
4559 * \param demod instance of demod.
4560 * \return DRXStatus_t.
4562 static int set_qam64(struct drxk_state *state)
4567 /* QAM Equalizer Setup */
4569 status = write16(state, SCU_RAM_QAM_EQ_CMA_RAD0__A, 13336);
4572 status = write16(state, SCU_RAM_QAM_EQ_CMA_RAD1__A, 12618);
4575 status = write16(state, SCU_RAM_QAM_EQ_CMA_RAD2__A, 11988);
4578 status = write16(state, SCU_RAM_QAM_EQ_CMA_RAD3__A, 13809);
4581 status = write16(state, SCU_RAM_QAM_EQ_CMA_RAD4__A, 13809);
4584 status = write16(state, SCU_RAM_QAM_EQ_CMA_RAD5__A, 15609);
4588 /* Decision Feedback Equalizer */
4589 status = write16(state, QAM_DQ_QUAL_FUN0__A, 4);
4592 status = write16(state, QAM_DQ_QUAL_FUN1__A, 4);
4595 status = write16(state, QAM_DQ_QUAL_FUN2__A, 4);
4598 status = write16(state, QAM_DQ_QUAL_FUN3__A, 4);
4601 status = write16(state, QAM_DQ_QUAL_FUN4__A, 3);
4604 status = write16(state, QAM_DQ_QUAL_FUN5__A, 0);
4608 status = write16(state, QAM_SY_SYNC_HWM__A, 5);
4611 status = write16(state, QAM_SY_SYNC_AWM__A, 4);
4614 status = write16(state, QAM_SY_SYNC_LWM__A, 3);
4618 /* QAM Slicer Settings */
4619 status = write16(state, SCU_RAM_QAM_SL_SIG_POWER__A, DRXK_QAM_SL_SIG_POWER_QAM64);
4624 /* QAM Loop Controller Coeficients */
4626 status = write16(state, SCU_RAM_QAM_LC_CA_FINE__A, 15);
4629 status = write16(state, SCU_RAM_QAM_LC_CA_COARSE__A, 40);
4632 status = write16(state, SCU_RAM_QAM_LC_EP_FINE__A, 12);
4635 status = write16(state, SCU_RAM_QAM_LC_EP_MEDIUM__A, 24);
4638 status = write16(state, SCU_RAM_QAM_LC_EP_COARSE__A, 24);
4641 status = write16(state, SCU_RAM_QAM_LC_EI_FINE__A, 12);
4644 status = write16(state, SCU_RAM_QAM_LC_EI_MEDIUM__A, 16);
4647 status = write16(state, SCU_RAM_QAM_LC_EI_COARSE__A, 16);
4651 status = write16(state, SCU_RAM_QAM_LC_CP_FINE__A, 5);
4654 status = write16(state, SCU_RAM_QAM_LC_CP_MEDIUM__A, 30);
4657 status = write16(state, SCU_RAM_QAM_LC_CP_COARSE__A, 100);
4660 status = write16(state, SCU_RAM_QAM_LC_CI_FINE__A, 5);
4663 status = write16(state, SCU_RAM_QAM_LC_CI_MEDIUM__A, 30);
4666 status = write16(state, SCU_RAM_QAM_LC_CI_COARSE__A, 50);
4669 status = write16(state, SCU_RAM_QAM_LC_CF_FINE__A, 16);
4672 status = write16(state, SCU_RAM_QAM_LC_CF_MEDIUM__A, 25);
4675 status = write16(state, SCU_RAM_QAM_LC_CF_COARSE__A, 48);
4678 status = write16(state, SCU_RAM_QAM_LC_CF1_FINE__A, 5);
4681 status = write16(state, SCU_RAM_QAM_LC_CF1_MEDIUM__A, 10);
4684 status = write16(state, SCU_RAM_QAM_LC_CF1_COARSE__A, 10);
4689 /* QAM State Machine (FSM) Thresholds */
4691 status = write16(state, SCU_RAM_QAM_FSM_RTH__A, 100);
4694 status = write16(state, SCU_RAM_QAM_FSM_FTH__A, 60);
4697 status = write16(state, SCU_RAM_QAM_FSM_CTH__A, 80);
4700 status = write16(state, SCU_RAM_QAM_FSM_PTH__A, 110);
4703 status = write16(state, SCU_RAM_QAM_FSM_QTH__A, 200);
4706 status = write16(state, SCU_RAM_QAM_FSM_MTH__A, 95);
4710 status = write16(state, SCU_RAM_QAM_FSM_RATE_LIM__A, 40);
4713 status = write16(state, SCU_RAM_QAM_FSM_COUNT_LIM__A, 4);
4716 status = write16(state, SCU_RAM_QAM_FSM_FREQ_LIM__A, 15);
4721 /* QAM FSM Tracking Parameters */
4723 status = write16(state, SCU_RAM_QAM_FSM_MEDIAN_AV_MULT__A, (u16) 12);
4726 status = write16(state, SCU_RAM_QAM_FSM_RADIUS_AV_LIMIT__A, (u16) 141);
4729 status = write16(state, SCU_RAM_QAM_FSM_LCAVG_OFFSET1__A, (u16) 7);
4732 status = write16(state, SCU_RAM_QAM_FSM_LCAVG_OFFSET2__A, (u16) 0);
4735 status = write16(state, SCU_RAM_QAM_FSM_LCAVG_OFFSET3__A, (u16) -15);
4738 status = write16(state, SCU_RAM_QAM_FSM_LCAVG_OFFSET4__A, (u16) -45);
4741 status = write16(state, SCU_RAM_QAM_FSM_LCAVG_OFFSET5__A, (u16) -80);
4744 printk(KERN_ERR "drxk: Error %d on %s\n", status, __func__);
4749 /*============================================================================*/
4752 * \brief QAM128 specific setup
4753 * \param demod: instance of demod.
4754 * \return DRXStatus_t.
4756 static int set_qam128(struct drxk_state *state)
4761 /* QAM Equalizer Setup */
4763 status = write16(state, SCU_RAM_QAM_EQ_CMA_RAD0__A, 6564);
4766 status = write16(state, SCU_RAM_QAM_EQ_CMA_RAD1__A, 6598);
4769 status = write16(state, SCU_RAM_QAM_EQ_CMA_RAD2__A, 6394);
4772 status = write16(state, SCU_RAM_QAM_EQ_CMA_RAD3__A, 6409);
4775 status = write16(state, SCU_RAM_QAM_EQ_CMA_RAD4__A, 6656);
4778 status = write16(state, SCU_RAM_QAM_EQ_CMA_RAD5__A, 7238);
4782 /* Decision Feedback Equalizer */
4783 status = write16(state, QAM_DQ_QUAL_FUN0__A, 6);
4786 status = write16(state, QAM_DQ_QUAL_FUN1__A, 6);
4789 status = write16(state, QAM_DQ_QUAL_FUN2__A, 6);
4792 status = write16(state, QAM_DQ_QUAL_FUN3__A, 6);
4795 status = write16(state, QAM_DQ_QUAL_FUN4__A, 5);
4798 status = write16(state, QAM_DQ_QUAL_FUN5__A, 0);
4802 status = write16(state, QAM_SY_SYNC_HWM__A, 6);
4805 status = write16(state, QAM_SY_SYNC_AWM__A, 5);
4808 status = write16(state, QAM_SY_SYNC_LWM__A, 3);
4813 /* QAM Slicer Settings */
4815 status = write16(state, SCU_RAM_QAM_SL_SIG_POWER__A, DRXK_QAM_SL_SIG_POWER_QAM128);
4820 /* QAM Loop Controller Coeficients */
4822 status = write16(state, SCU_RAM_QAM_LC_CA_FINE__A, 15);
4825 status = write16(state, SCU_RAM_QAM_LC_CA_COARSE__A, 40);
4828 status = write16(state, SCU_RAM_QAM_LC_EP_FINE__A, 12);
4831 status = write16(state, SCU_RAM_QAM_LC_EP_MEDIUM__A, 24);
4834 status = write16(state, SCU_RAM_QAM_LC_EP_COARSE__A, 24);
4837 status = write16(state, SCU_RAM_QAM_LC_EI_FINE__A, 12);
4840 status = write16(state, SCU_RAM_QAM_LC_EI_MEDIUM__A, 16);
4843 status = write16(state, SCU_RAM_QAM_LC_EI_COARSE__A, 16);
4847 status = write16(state, SCU_RAM_QAM_LC_CP_FINE__A, 5);
4850 status = write16(state, SCU_RAM_QAM_LC_CP_MEDIUM__A, 40);
4853 status = write16(state, SCU_RAM_QAM_LC_CP_COARSE__A, 120);
4856 status = write16(state, SCU_RAM_QAM_LC_CI_FINE__A, 5);
4859 status = write16(state, SCU_RAM_QAM_LC_CI_MEDIUM__A, 40);
4862 status = write16(state, SCU_RAM_QAM_LC_CI_COARSE__A, 60);
4865 status = write16(state, SCU_RAM_QAM_LC_CF_FINE__A, 16);
4868 status = write16(state, SCU_RAM_QAM_LC_CF_MEDIUM__A, 25);
4871 status = write16(state, SCU_RAM_QAM_LC_CF_COARSE__A, 64);
4874 status = write16(state, SCU_RAM_QAM_LC_CF1_FINE__A, 5);
4877 status = write16(state, SCU_RAM_QAM_LC_CF1_MEDIUM__A, 10);
4880 status = write16(state, SCU_RAM_QAM_LC_CF1_COARSE__A, 0);
4885 /* QAM State Machine (FSM) Thresholds */
4887 status = write16(state, SCU_RAM_QAM_FSM_RTH__A, 50);
4890 status = write16(state, SCU_RAM_QAM_FSM_FTH__A, 60);
4893 status = write16(state, SCU_RAM_QAM_FSM_CTH__A, 80);
4896 status = write16(state, SCU_RAM_QAM_FSM_PTH__A, 100);
4899 status = write16(state, SCU_RAM_QAM_FSM_QTH__A, 140);
4902 status = write16(state, SCU_RAM_QAM_FSM_MTH__A, 100);
4906 status = write16(state, SCU_RAM_QAM_FSM_RATE_LIM__A, 40);
4909 status = write16(state, SCU_RAM_QAM_FSM_COUNT_LIM__A, 5);
4913 status = write16(state, SCU_RAM_QAM_FSM_FREQ_LIM__A, 12);
4917 /* QAM FSM Tracking Parameters */
4919 status = write16(state, SCU_RAM_QAM_FSM_MEDIAN_AV_MULT__A, (u16) 8);
4922 status = write16(state, SCU_RAM_QAM_FSM_RADIUS_AV_LIMIT__A, (u16) 65);
4925 status = write16(state, SCU_RAM_QAM_FSM_LCAVG_OFFSET1__A, (u16) 5);
4928 status = write16(state, SCU_RAM_QAM_FSM_LCAVG_OFFSET2__A, (u16) 3);
4931 status = write16(state, SCU_RAM_QAM_FSM_LCAVG_OFFSET3__A, (u16) -1);
4934 status = write16(state, SCU_RAM_QAM_FSM_LCAVG_OFFSET4__A, (u16) -12);
4937 status = write16(state, SCU_RAM_QAM_FSM_LCAVG_OFFSET5__A, (u16) -23);
4940 printk(KERN_ERR "drxk: Error %d on %s\n", status, __func__);
4945 /*============================================================================*/
4948 * \brief QAM256 specific setup
4949 * \param demod: instance of demod.
4950 * \return DRXStatus_t.
4952 static int set_qam256(struct drxk_state *state)
4957 /* QAM Equalizer Setup */
4959 status = write16(state, SCU_RAM_QAM_EQ_CMA_RAD0__A, 11502);
4962 status = write16(state, SCU_RAM_QAM_EQ_CMA_RAD1__A, 12084);
4965 status = write16(state, SCU_RAM_QAM_EQ_CMA_RAD2__A, 12543);
4968 status = write16(state, SCU_RAM_QAM_EQ_CMA_RAD3__A, 12931);
4971 status = write16(state, SCU_RAM_QAM_EQ_CMA_RAD4__A, 13629);
4974 status = write16(state, SCU_RAM_QAM_EQ_CMA_RAD5__A, 15385);
4978 /* Decision Feedback Equalizer */
4979 status = write16(state, QAM_DQ_QUAL_FUN0__A, 8);
4982 status = write16(state, QAM_DQ_QUAL_FUN1__A, 8);
4985 status = write16(state, QAM_DQ_QUAL_FUN2__A, 8);
4988 status = write16(state, QAM_DQ_QUAL_FUN3__A, 8);
4991 status = write16(state, QAM_DQ_QUAL_FUN4__A, 6);
4994 status = write16(state, QAM_DQ_QUAL_FUN5__A, 0);
4998 status = write16(state, QAM_SY_SYNC_HWM__A, 5);
5001 status = write16(state, QAM_SY_SYNC_AWM__A, 4);
5004 status = write16(state, QAM_SY_SYNC_LWM__A, 3);
5008 /* QAM Slicer Settings */
5010 status = write16(state, SCU_RAM_QAM_SL_SIG_POWER__A, DRXK_QAM_SL_SIG_POWER_QAM256);
5015 /* QAM Loop Controller Coeficients */
5017 status = write16(state, SCU_RAM_QAM_LC_CA_FINE__A, 15);
5020 status = write16(state, SCU_RAM_QAM_LC_CA_COARSE__A, 40);
5023 status = write16(state, SCU_RAM_QAM_LC_EP_FINE__A, 12);
5026 status = write16(state, SCU_RAM_QAM_LC_EP_MEDIUM__A, 24);
5029 status = write16(state, SCU_RAM_QAM_LC_EP_COARSE__A, 24);
5032 status = write16(state, SCU_RAM_QAM_LC_EI_FINE__A, 12);
5035 status = write16(state, SCU_RAM_QAM_LC_EI_MEDIUM__A, 16);
5038 status = write16(state, SCU_RAM_QAM_LC_EI_COARSE__A, 16);
5042 status = write16(state, SCU_RAM_QAM_LC_CP_FINE__A, 5);
5045 status = write16(state, SCU_RAM_QAM_LC_CP_MEDIUM__A, 50);
5048 status = write16(state, SCU_RAM_QAM_LC_CP_COARSE__A, 250);
5051 status = write16(state, SCU_RAM_QAM_LC_CI_FINE__A, 5);
5054 status = write16(state, SCU_RAM_QAM_LC_CI_MEDIUM__A, 50);
5057 status = write16(state, SCU_RAM_QAM_LC_CI_COARSE__A, 125);
5060 status = write16(state, SCU_RAM_QAM_LC_CF_FINE__A, 16);
5063 status = write16(state, SCU_RAM_QAM_LC_CF_MEDIUM__A, 25);
5066 status = write16(state, SCU_RAM_QAM_LC_CF_COARSE__A, 48);
5069 status = write16(state, SCU_RAM_QAM_LC_CF1_FINE__A, 5);
5072 status = write16(state, SCU_RAM_QAM_LC_CF1_MEDIUM__A, 10);
5075 status = write16(state, SCU_RAM_QAM_LC_CF1_COARSE__A, 10);
5080 /* QAM State Machine (FSM) Thresholds */
5082 status = write16(state, SCU_RAM_QAM_FSM_RTH__A, 50);
5085 status = write16(state, SCU_RAM_QAM_FSM_FTH__A, 60);
5088 status = write16(state, SCU_RAM_QAM_FSM_CTH__A, 80);
5091 status = write16(state, SCU_RAM_QAM_FSM_PTH__A, 100);
5094 status = write16(state, SCU_RAM_QAM_FSM_QTH__A, 150);
5097 status = write16(state, SCU_RAM_QAM_FSM_MTH__A, 110);
5101 status = write16(state, SCU_RAM_QAM_FSM_RATE_LIM__A, 40);
5104 status = write16(state, SCU_RAM_QAM_FSM_COUNT_LIM__A, 4);
5107 status = write16(state, SCU_RAM_QAM_FSM_FREQ_LIM__A, 12);
5112 /* QAM FSM Tracking Parameters */
5114 status = write16(state, SCU_RAM_QAM_FSM_MEDIAN_AV_MULT__A, (u16) 8);
5117 status = write16(state, SCU_RAM_QAM_FSM_RADIUS_AV_LIMIT__A, (u16) 74);
5120 status = write16(state, SCU_RAM_QAM_FSM_LCAVG_OFFSET1__A, (u16) 18);
5123 status = write16(state, SCU_RAM_QAM_FSM_LCAVG_OFFSET2__A, (u16) 13);
5126 status = write16(state, SCU_RAM_QAM_FSM_LCAVG_OFFSET3__A, (u16) 7);
5129 status = write16(state, SCU_RAM_QAM_FSM_LCAVG_OFFSET4__A, (u16) 0);
5132 status = write16(state, SCU_RAM_QAM_FSM_LCAVG_OFFSET5__A, (u16) -8);
5135 printk(KERN_ERR "drxk: Error %d on %s\n", status, __func__);
5140 /*============================================================================*/
5142 * \brief Reset QAM block.
5143 * \param demod: instance of demod.
5144 * \param channel: pointer to channel data.
5145 * \return DRXStatus_t.
5147 static int qam_reset_qam(struct drxk_state *state)
5153 /* Stop QAM comstate->m_exec */
5154 status = write16(state, QAM_COMM_EXEC__A, QAM_COMM_EXEC_STOP);
5158 status = scu_command(state, SCU_RAM_COMMAND_STANDARD_QAM | SCU_RAM_COMMAND_CMD_DEMOD_RESET, 0, NULL, 1, &cmd_result);
5161 printk(KERN_ERR "drxk: Error %d on %s\n", status, __func__);
5165 /*============================================================================*/
5168 * \brief Set QAM symbolrate.
5169 * \param demod: instance of demod.
5170 * \param channel: pointer to channel data.
5171 * \return DRXStatus_t.
5173 static int qam_set_symbolrate(struct drxk_state *state)
5175 u32 adc_frequency = 0;
5177 u32 iqm_rc_rate = 0;
5179 u32 lc_symb_rate = 0;
5183 /* Select & calculate correct IQM rate */
5184 adc_frequency = (state->m_sys_clock_freq * 1000) / 3;
5186 /* printk(KERN_DEBUG "drxk: SR %d\n", state->props.symbol_rate); */
5187 if (state->props.symbol_rate <= 1188750)
5189 else if (state->props.symbol_rate <= 2377500)
5191 else if (state->props.symbol_rate <= 4755000)
5193 status = write16(state, IQM_FD_RATESEL__A, ratesel);
5198 IqmRcRate = ((Fadc / (symbolrate * (4<<ratesel))) - 1) * (1<<23)
5200 symb_freq = state->props.symbol_rate * (1 << ratesel);
5201 if (symb_freq == 0) {
5202 /* Divide by zero */
5206 iqm_rc_rate = (adc_frequency / symb_freq) * (1 << 21) +
5207 (Frac28a((adc_frequency % symb_freq), symb_freq) >> 7) -
5209 status = write32(state, IQM_RC_RATE_OFS_LO__A, iqm_rc_rate);
5212 state->m_iqm_rc_rate = iqm_rc_rate;
5214 LcSymbFreq = round (.125 * symbolrate / adc_freq * (1<<15))
5216 symb_freq = state->props.symbol_rate;
5217 if (adc_frequency == 0) {
5218 /* Divide by zero */
5222 lc_symb_rate = (symb_freq / adc_frequency) * (1 << 12) +
5223 (Frac28a((symb_freq % adc_frequency), adc_frequency) >>
5225 if (lc_symb_rate > 511)
5227 status = write16(state, QAM_LC_SYMBOL_FREQ__A, (u16) lc_symb_rate);
5231 printk(KERN_ERR "drxk: Error %d on %s\n", status, __func__);
5235 /*============================================================================*/
5238 * \brief Get QAM lock status.
5239 * \param demod: instance of demod.
5240 * \param channel: pointer to channel data.
5241 * \return DRXStatus_t.
5244 static int get_qam_lock_status(struct drxk_state *state, u32 *p_lock_status)
5247 u16 result[2] = { 0, 0 };
5250 *p_lock_status = NOT_LOCKED;
5251 status = scu_command(state,
5252 SCU_RAM_COMMAND_STANDARD_QAM |
5253 SCU_RAM_COMMAND_CMD_DEMOD_GET_LOCK, 0, NULL, 2,
5256 printk(KERN_ERR "drxk: Error %d on %s\n", status, __func__);
5258 if (result[1] < SCU_RAM_QAM_LOCKED_LOCKED_DEMOD_LOCKED) {
5259 /* 0x0000 NOT LOCKED */
5260 } else if (result[1] < SCU_RAM_QAM_LOCKED_LOCKED_LOCKED) {
5261 /* 0x4000 DEMOD LOCKED */
5262 *p_lock_status = DEMOD_LOCK;
5263 } else if (result[1] < SCU_RAM_QAM_LOCKED_LOCKED_NEVER_LOCK) {
5264 /* 0x8000 DEMOD + FEC LOCKED (system lock) */
5265 *p_lock_status = MPEG_LOCK;
5267 /* 0xC000 NEVER LOCKED */
5268 /* (system will never be able to lock to the signal) */
5269 /* TODO: check this, intermediate & standard specific lock states are not
5270 taken into account here */
5271 *p_lock_status = NEVER_LOCK;
5276 #define QAM_MIRROR__M 0x03
5277 #define QAM_MIRROR_NORMAL 0x00
5278 #define QAM_MIRRORED 0x01
5279 #define QAM_MIRROR_AUTO_ON 0x02
5280 #define QAM_LOCKRANGE__M 0x10
5281 #define QAM_LOCKRANGE_NORMAL 0x10
5283 static int qam_demodulator_command(struct drxk_state *state,
5284 int number_of_parameters)
5288 u16 set_param_parameters[4] = { 0, 0, 0, 0 };
5290 set_param_parameters[0] = state->m_constellation; /* modulation */
5291 set_param_parameters[1] = DRXK_QAM_I12_J17; /* interleave mode */
5293 if (number_of_parameters == 2) {
5294 u16 set_env_parameters[1] = { 0 };
5296 if (state->m_operation_mode == OM_QAM_ITU_C)
5297 set_env_parameters[0] = QAM_TOP_ANNEX_C;
5299 set_env_parameters[0] = QAM_TOP_ANNEX_A;
5301 status = scu_command(state,
5302 SCU_RAM_COMMAND_STANDARD_QAM | SCU_RAM_COMMAND_CMD_DEMOD_SET_ENV,
5303 1, set_env_parameters, 1, &cmd_result);
5307 status = scu_command(state,
5308 SCU_RAM_COMMAND_STANDARD_QAM | SCU_RAM_COMMAND_CMD_DEMOD_SET_PARAM,
5309 number_of_parameters, set_param_parameters,
5311 } else if (number_of_parameters == 4) {
5312 if (state->m_operation_mode == OM_QAM_ITU_C)
5313 set_param_parameters[2] = QAM_TOP_ANNEX_C;
5315 set_param_parameters[2] = QAM_TOP_ANNEX_A;
5317 set_param_parameters[3] |= (QAM_MIRROR_AUTO_ON);
5318 /* Env parameters */
5319 /* check for LOCKRANGE Extented */
5320 /* set_param_parameters[3] |= QAM_LOCKRANGE_NORMAL; */
5322 status = scu_command(state,
5323 SCU_RAM_COMMAND_STANDARD_QAM | SCU_RAM_COMMAND_CMD_DEMOD_SET_PARAM,
5324 number_of_parameters, set_param_parameters,
5327 printk(KERN_WARNING "drxk: Unknown QAM demodulator parameter "
5328 "count %d\n", number_of_parameters);
5334 printk(KERN_WARNING "drxk: Warning %d on %s\n",
5339 static int set_qam(struct drxk_state *state, u16 intermediate_freqk_hz,
5340 s32 tuner_freq_offset)
5344 int qam_demod_param_count = state->qam_demod_parameter_count;
5348 * STEP 1: reset demodulator
5349 * resets FEC DI and FEC RS
5351 * resets SCU variables
5353 status = write16(state, FEC_DI_COMM_EXEC__A, FEC_DI_COMM_EXEC_STOP);
5356 status = write16(state, FEC_RS_COMM_EXEC__A, FEC_RS_COMM_EXEC_STOP);
5359 status = qam_reset_qam(state);
5364 * STEP 2: configure demodulator
5365 * -set params; resets IQM,QAM,FEC HW; initializes some
5368 status = qam_set_symbolrate(state);
5373 switch (state->props.modulation) {
5375 state->m_constellation = DRX_CONSTELLATION_QAM256;
5379 state->m_constellation = DRX_CONSTELLATION_QAM64;
5382 state->m_constellation = DRX_CONSTELLATION_QAM16;
5385 state->m_constellation = DRX_CONSTELLATION_QAM32;
5388 state->m_constellation = DRX_CONSTELLATION_QAM128;
5397 /* Use the 4-parameter if it's requested or we're probing for
5398 * the correct command. */
5399 if (state->qam_demod_parameter_count == 4
5400 || !state->qam_demod_parameter_count) {
5401 qam_demod_param_count = 4;
5402 status = qam_demodulator_command(state, qam_demod_param_count);
5405 /* Use the 2-parameter command if it was requested or if we're
5406 * probing for the correct command and the 4-parameter command
5408 if (state->qam_demod_parameter_count == 2
5409 || (!state->qam_demod_parameter_count && status < 0)) {
5410 qam_demod_param_count = 2;
5411 status = qam_demodulator_command(state, qam_demod_param_count);
5415 dprintk(1, "Could not set demodulator parameters. Make "
5416 "sure qam_demod_parameter_count (%d) is correct for "
5417 "your firmware (%s).\n",
5418 state->qam_demod_parameter_count,
5419 state->microcode_name);
5421 } else if (!state->qam_demod_parameter_count) {
5422 dprintk(1, "Auto-probing the correct QAM demodulator command "
5423 "parameters was successful - using %d parameters.\n",
5424 qam_demod_param_count);
5427 * One of our commands was successful. We don't need to
5428 * auto-probe anymore, now that we got the correct command.
5430 state->qam_demod_parameter_count = qam_demod_param_count;
5434 * STEP 3: enable the system in a mode where the ADC provides valid
5435 * signal setup modulation independent registers
5438 status = set_frequency(channel, tuner_freq_offset));
5442 status = set_frequency_shifter(state, intermediate_freqk_hz, tuner_freq_offset, true);
5446 /* Setup BER measurement */
5447 status = set_qam_measurement(state, state->m_constellation, state->props.symbol_rate);
5451 /* Reset default values */
5452 status = write16(state, IQM_CF_SCALE_SH__A, IQM_CF_SCALE_SH__PRE);
5455 status = write16(state, QAM_SY_TIMEOUT__A, QAM_SY_TIMEOUT__PRE);
5459 /* Reset default LC values */
5460 status = write16(state, QAM_LC_RATE_LIMIT__A, 3);
5463 status = write16(state, QAM_LC_LPF_FACTORP__A, 4);
5466 status = write16(state, QAM_LC_LPF_FACTORI__A, 4);
5469 status = write16(state, QAM_LC_MODE__A, 7);
5473 status = write16(state, QAM_LC_QUAL_TAB0__A, 1);
5476 status = write16(state, QAM_LC_QUAL_TAB1__A, 1);
5479 status = write16(state, QAM_LC_QUAL_TAB2__A, 1);
5482 status = write16(state, QAM_LC_QUAL_TAB3__A, 1);
5485 status = write16(state, QAM_LC_QUAL_TAB4__A, 2);
5488 status = write16(state, QAM_LC_QUAL_TAB5__A, 2);
5491 status = write16(state, QAM_LC_QUAL_TAB6__A, 2);
5494 status = write16(state, QAM_LC_QUAL_TAB8__A, 2);
5497 status = write16(state, QAM_LC_QUAL_TAB9__A, 2);
5500 status = write16(state, QAM_LC_QUAL_TAB10__A, 2);
5503 status = write16(state, QAM_LC_QUAL_TAB12__A, 2);
5506 status = write16(state, QAM_LC_QUAL_TAB15__A, 3);
5509 status = write16(state, QAM_LC_QUAL_TAB16__A, 3);
5512 status = write16(state, QAM_LC_QUAL_TAB20__A, 4);
5515 status = write16(state, QAM_LC_QUAL_TAB25__A, 4);
5519 /* Mirroring, QAM-block starting point not inverted */
5520 status = write16(state, QAM_SY_SP_INV__A, QAM_SY_SP_INV_SPECTRUM_INV_DIS);
5524 /* Halt SCU to enable safe non-atomic accesses */
5525 status = write16(state, SCU_COMM_EXEC__A, SCU_COMM_EXEC_HOLD);
5529 /* STEP 4: modulation specific setup */
5530 switch (state->props.modulation) {
5532 status = set_qam16(state);
5535 status = set_qam32(state);
5539 status = set_qam64(state);
5542 status = set_qam128(state);
5545 status = set_qam256(state);
5554 /* Activate SCU to enable SCU commands */
5555 status = write16(state, SCU_COMM_EXEC__A, SCU_COMM_EXEC_ACTIVE);
5559 /* Re-configure MPEG output, requires knowledge of channel bitrate */
5560 /* extAttr->currentChannel.modulation = channel->modulation; */
5561 /* extAttr->currentChannel.symbolrate = channel->symbolrate; */
5562 status = mpegts_dto_setup(state, state->m_operation_mode);
5566 /* start processes */
5567 status = mpegts_start(state);
5570 status = write16(state, FEC_COMM_EXEC__A, FEC_COMM_EXEC_ACTIVE);
5573 status = write16(state, QAM_COMM_EXEC__A, QAM_COMM_EXEC_ACTIVE);
5576 status = write16(state, IQM_COMM_EXEC__A, IQM_COMM_EXEC_B_ACTIVE);
5580 /* STEP 5: start QAM demodulator (starts FEC, QAM and IQM HW) */
5581 status = scu_command(state, SCU_RAM_COMMAND_STANDARD_QAM | SCU_RAM_COMMAND_CMD_DEMOD_START, 0, NULL, 1, &cmd_result);
5585 /* update global DRXK data container */
5586 /*? extAttr->qamInterleaveMode = DRXK_QAM_I12_J17; */
5590 printk(KERN_ERR "drxk: Error %d on %s\n", status, __func__);
5594 static int set_qam_standard(struct drxk_state *state,
5595 enum operation_mode o_mode)
5598 #ifdef DRXK_QAM_TAPS
5599 #define DRXK_QAMA_TAPS_SELECT
5600 #include "drxk_filters.h"
5601 #undef DRXK_QAMA_TAPS_SELECT
5606 /* added antenna switch */
5607 switch_antenna_to_qam(state);
5609 /* Ensure correct power-up mode */
5610 status = power_up_qam(state);
5613 /* Reset QAM block */
5614 status = qam_reset_qam(state);
5620 status = write16(state, IQM_COMM_EXEC__A, IQM_COMM_EXEC_B_STOP);
5623 status = write16(state, IQM_AF_AMUX__A, IQM_AF_AMUX_SIGNAL2ADC);
5627 /* Upload IQM Channel Filter settings by
5628 boot loader from ROM table */
5631 status = bl_chain_cmd(state, DRXK_BL_ROM_OFFSET_TAPS_ITU_A, DRXK_BLCC_NR_ELEMENTS_TAPS, DRXK_BLC_TIMEOUT);
5634 status = bl_direct_cmd(state, IQM_CF_TAP_RE0__A, DRXK_BL_ROM_OFFSET_TAPS_ITU_C, DRXK_BLDC_NR_ELEMENTS_TAPS, DRXK_BLC_TIMEOUT);
5637 status = bl_direct_cmd(state, IQM_CF_TAP_IM0__A, DRXK_BL_ROM_OFFSET_TAPS_ITU_C, DRXK_BLDC_NR_ELEMENTS_TAPS, DRXK_BLC_TIMEOUT);
5645 status = write16(state, IQM_CF_OUT_ENA__A, (1 << IQM_CF_OUT_ENA_QAM__B));
5648 status = write16(state, IQM_CF_SYMMETRIC__A, 0);
5651 status = write16(state, IQM_CF_MIDTAP__A, ((1 << IQM_CF_MIDTAP_RE__B) | (1 << IQM_CF_MIDTAP_IM__B)));
5655 status = write16(state, IQM_RC_STRETCH__A, 21);
5658 status = write16(state, IQM_AF_CLP_LEN__A, 0);
5661 status = write16(state, IQM_AF_CLP_TH__A, 448);
5664 status = write16(state, IQM_AF_SNS_LEN__A, 0);
5667 status = write16(state, IQM_CF_POW_MEAS_LEN__A, 0);
5671 status = write16(state, IQM_FS_ADJ_SEL__A, 1);
5674 status = write16(state, IQM_RC_ADJ_SEL__A, 1);
5677 status = write16(state, IQM_CF_ADJ_SEL__A, 1);
5680 status = write16(state, IQM_AF_UPD_SEL__A, 0);
5684 /* IQM Impulse Noise Processing Unit */
5685 status = write16(state, IQM_CF_CLP_VAL__A, 500);
5688 status = write16(state, IQM_CF_DATATH__A, 1000);
5691 status = write16(state, IQM_CF_BYPASSDET__A, 1);
5694 status = write16(state, IQM_CF_DET_LCT__A, 0);
5697 status = write16(state, IQM_CF_WND_LEN__A, 1);
5700 status = write16(state, IQM_CF_PKDTH__A, 1);
5703 status = write16(state, IQM_AF_INC_BYPASS__A, 1);
5707 /* turn on IQMAF. Must be done before setAgc**() */
5708 status = set_iqm_af(state, true);
5711 status = write16(state, IQM_AF_START_LOCK__A, 0x01);
5715 /* IQM will not be reset from here, sync ADC and update/init AGC */
5716 status = adc_synchronization(state);
5720 /* Set the FSM step period */
5721 status = write16(state, SCU_RAM_QAM_FSM_STEP_PERIOD__A, 2000);
5725 /* Halt SCU to enable safe non-atomic accesses */
5726 status = write16(state, SCU_COMM_EXEC__A, SCU_COMM_EXEC_HOLD);
5730 /* No more resets of the IQM, current standard correctly set =>
5731 now AGCs can be configured. */
5733 status = init_agc(state, true);
5736 status = set_pre_saw(state, &(state->m_qam_pre_saw_cfg));
5740 /* Configure AGC's */
5741 status = set_agc_rf(state, &(state->m_qam_rf_agc_cfg), true);
5744 status = set_agc_if(state, &(state->m_qam_if_agc_cfg), true);
5748 /* Activate SCU to enable SCU commands */
5749 status = write16(state, SCU_COMM_EXEC__A, SCU_COMM_EXEC_ACTIVE);
5752 printk(KERN_ERR "drxk: Error %d on %s\n", status, __func__);
5756 static int write_gpio(struct drxk_state *state)
5762 /* stop lock indicator process */
5763 status = write16(state, SCU_RAM_GPIO__A, SCU_RAM_GPIO_HW_LOCK_IND_DISABLE);
5767 /* Write magic word to enable pdr reg write */
5768 status = write16(state, SIO_TOP_COMM_KEY__A, SIO_TOP_COMM_KEY_KEY);
5772 if (state->m_has_sawsw) {
5773 if (state->uio_mask & 0x0001) { /* UIO-1 */
5774 /* write to io pad configuration register - output mode */
5775 status = write16(state, SIO_PDR_SMA_TX_CFG__A, state->m_gpio_cfg);
5779 /* use corresponding bit in io data output registar */
5780 status = read16(state, SIO_PDR_UIO_OUT_LO__A, &value);
5783 if ((state->m_gpio & 0x0001) == 0)
5784 value &= 0x7FFF; /* write zero to 15th bit - 1st UIO */
5786 value |= 0x8000; /* write one to 15th bit - 1st UIO */
5787 /* write back to io data output register */
5788 status = write16(state, SIO_PDR_UIO_OUT_LO__A, value);
5792 if (state->uio_mask & 0x0002) { /* UIO-2 */
5793 /* write to io pad configuration register - output mode */
5794 status = write16(state, SIO_PDR_SMA_RX_CFG__A, state->m_gpio_cfg);
5798 /* use corresponding bit in io data output registar */
5799 status = read16(state, SIO_PDR_UIO_OUT_LO__A, &value);
5802 if ((state->m_gpio & 0x0002) == 0)
5803 value &= 0xBFFF; /* write zero to 14th bit - 2st UIO */
5805 value |= 0x4000; /* write one to 14th bit - 2st UIO */
5806 /* write back to io data output register */
5807 status = write16(state, SIO_PDR_UIO_OUT_LO__A, value);
5811 if (state->uio_mask & 0x0004) { /* UIO-3 */
5812 /* write to io pad configuration register - output mode */
5813 status = write16(state, SIO_PDR_GPIO_CFG__A, state->m_gpio_cfg);
5817 /* use corresponding bit in io data output registar */
5818 status = read16(state, SIO_PDR_UIO_OUT_LO__A, &value);
5821 if ((state->m_gpio & 0x0004) == 0)
5822 value &= 0xFFFB; /* write zero to 2nd bit - 3rd UIO */
5824 value |= 0x0004; /* write one to 2nd bit - 3rd UIO */
5825 /* write back to io data output register */
5826 status = write16(state, SIO_PDR_UIO_OUT_LO__A, value);
5831 /* Write magic word to disable pdr reg write */
5832 status = write16(state, SIO_TOP_COMM_KEY__A, 0x0000);
5835 printk(KERN_ERR "drxk: Error %d on %s\n", status, __func__);
5839 static int switch_antenna_to_qam(struct drxk_state *state)
5846 if (!state->antenna_gpio)
5849 gpio_state = state->m_gpio & state->antenna_gpio;
5851 if (state->antenna_dvbt ^ gpio_state) {
5852 /* Antenna is on DVB-T mode. Switch */
5853 if (state->antenna_dvbt)
5854 state->m_gpio &= ~state->antenna_gpio;
5856 state->m_gpio |= state->antenna_gpio;
5857 status = write_gpio(state);
5860 printk(KERN_ERR "drxk: Error %d on %s\n", status, __func__);
5864 static int switch_antenna_to_dvbt(struct drxk_state *state)
5871 if (!state->antenna_gpio)
5874 gpio_state = state->m_gpio & state->antenna_gpio;
5876 if (!(state->antenna_dvbt ^ gpio_state)) {
5877 /* Antenna is on DVB-C mode. Switch */
5878 if (state->antenna_dvbt)
5879 state->m_gpio |= state->antenna_gpio;
5881 state->m_gpio &= ~state->antenna_gpio;
5882 status = write_gpio(state);
5885 printk(KERN_ERR "drxk: Error %d on %s\n", status, __func__);
5890 static int power_down_device(struct drxk_state *state)
5892 /* Power down to requested mode */
5893 /* Backup some register settings */
5894 /* Set pins with possible pull-ups connected to them in input mode */
5895 /* Analog power down */
5896 /* ADC power down */
5897 /* Power down device */
5901 if (state->m_b_p_down_open_bridge) {
5902 /* Open I2C bridge before power down of DRXK */
5903 status = ConfigureI2CBridge(state, true);
5908 status = dvbt_enable_ofdm_token_ring(state, false);
5912 status = write16(state, SIO_CC_PWD_MODE__A, SIO_CC_PWD_MODE_LEVEL_CLOCK);
5915 status = write16(state, SIO_CC_UPDATE__A, SIO_CC_UPDATE_KEY);
5918 state->m_hi_cfg_ctrl |= SIO_HI_RA_RAM_PAR_5_CFG_SLEEP_ZZZ;
5919 status = hi_cfg_command(state);
5922 printk(KERN_ERR "drxk: Error %d on %s\n", status, __func__);
5927 static int init_drxk(struct drxk_state *state)
5929 int status = 0, n = 0;
5930 enum drx_power_mode power_mode = DRXK_POWER_DOWN_OFDM;
5934 if ((state->m_drxk_state == DRXK_UNINITIALIZED)) {
5935 drxk_i2c_lock(state);
5936 status = power_up_device(state);
5939 status = drxx_open(state);
5942 /* Soft reset of OFDM-, sys- and osc-clockdomain */
5943 status = write16(state, SIO_CC_SOFT_RST__A, SIO_CC_SOFT_RST_OFDM__M | SIO_CC_SOFT_RST_SYS__M | SIO_CC_SOFT_RST_OSC__M);
5946 status = write16(state, SIO_CC_UPDATE__A, SIO_CC_UPDATE_KEY);
5949 /* TODO is this needed, if yes how much delay in worst case scenario */
5951 state->m_drxk_a3_patch_code = true;
5952 status = get_device_capabilities(state);
5956 /* Bridge delay, uses oscilator clock */
5957 /* Delay = (delay (nano seconds) * oscclk (kHz))/ 1000 */
5958 /* SDA brdige delay */
5959 state->m_hi_cfg_bridge_delay =
5960 (u16) ((state->m_osc_clock_freq / 1000) *
5961 HI_I2C_BRIDGE_DELAY) / 1000;
5963 if (state->m_hi_cfg_bridge_delay >
5964 SIO_HI_RA_RAM_PAR_3_CFG_DBL_SDA__M) {
5965 state->m_hi_cfg_bridge_delay =
5966 SIO_HI_RA_RAM_PAR_3_CFG_DBL_SDA__M;
5968 /* SCL bridge delay, same as SDA for now */
5969 state->m_hi_cfg_bridge_delay +=
5970 state->m_hi_cfg_bridge_delay <<
5971 SIO_HI_RA_RAM_PAR_3_CFG_DBL_SCL__B;
5973 status = init_hi(state);
5976 /* disable various processes */
5978 if (!(state->m_DRXK_A1_ROM_CODE)
5979 && !(state->m_DRXK_A2_ROM_CODE))
5982 status = write16(state, SCU_RAM_GPIO__A, SCU_RAM_GPIO_HW_LOCK_IND_DISABLE);
5987 /* disable MPEG port */
5988 status = mpegts_disable(state);
5992 /* Stop AUD and SCU */
5993 status = write16(state, AUD_COMM_EXEC__A, AUD_COMM_EXEC_STOP);
5996 status = write16(state, SCU_COMM_EXEC__A, SCU_COMM_EXEC_STOP);
6000 /* enable token-ring bus through OFDM block for possible ucode upload */
6001 status = write16(state, SIO_OFDM_SH_OFDM_RING_ENABLE__A, SIO_OFDM_SH_OFDM_RING_ENABLE_ON);
6005 /* include boot loader section */
6006 status = write16(state, SIO_BL_COMM_EXEC__A, SIO_BL_COMM_EXEC_ACTIVE);
6009 status = bl_chain_cmd(state, 0, 6, 100);
6014 status = download_microcode(state, state->fw->data,
6020 /* disable token-ring bus through OFDM block for possible ucode upload */
6021 status = write16(state, SIO_OFDM_SH_OFDM_RING_ENABLE__A, SIO_OFDM_SH_OFDM_RING_ENABLE_OFF);
6025 /* Run SCU for a little while to initialize microcode version numbers */
6026 status = write16(state, SCU_COMM_EXEC__A, SCU_COMM_EXEC_ACTIVE);
6029 status = drxx_open(state);
6032 /* added for test */
6035 power_mode = DRXK_POWER_DOWN_OFDM;
6036 status = ctrl_power_mode(state, &power_mode);
6040 /* Stamp driver version number in SCU data RAM in BCD code
6041 Done to enable field application engineers to retreive drxdriver version
6042 via I2C from SCU RAM.
6043 Not using SCU command interface for SCU register access since no
6044 microcode may be present.
6047 (((DRXK_VERSION_MAJOR / 100) % 10) << 12) +
6048 (((DRXK_VERSION_MAJOR / 10) % 10) << 8) +
6049 ((DRXK_VERSION_MAJOR % 10) << 4) +
6050 (DRXK_VERSION_MINOR % 10);
6051 status = write16(state, SCU_RAM_DRIVER_VER_HI__A, driver_version);
6055 (((DRXK_VERSION_PATCH / 1000) % 10) << 12) +
6056 (((DRXK_VERSION_PATCH / 100) % 10) << 8) +
6057 (((DRXK_VERSION_PATCH / 10) % 10) << 4) +
6058 (DRXK_VERSION_PATCH % 10);
6059 status = write16(state, SCU_RAM_DRIVER_VER_LO__A, driver_version);
6063 printk(KERN_INFO "DRXK driver version %d.%d.%d\n",
6064 DRXK_VERSION_MAJOR, DRXK_VERSION_MINOR,
6065 DRXK_VERSION_PATCH);
6067 /* Dirty fix of default values for ROM/PATCH microcode
6068 Dirty because this fix makes it impossible to setup suitable values
6069 before calling DRX_Open. This solution requires changes to RF AGC speed
6070 to be done via the CTRL function after calling DRX_Open */
6072 /* m_dvbt_rf_agc_cfg.speed = 3; */
6074 /* Reset driver debug flags to 0 */
6075 status = write16(state, SCU_RAM_DRIVER_DEBUG__A, 0);
6080 NOTE: No more full FEC resets allowed afterwards!! */
6081 status = write16(state, FEC_COMM_EXEC__A, FEC_COMM_EXEC_STOP);
6084 /* MPEGTS functions are still the same */
6085 status = mpegts_dto_init(state);
6088 status = mpegts_stop(state);
6091 status = mpegts_configure_polarity(state);
6094 status = mpegts_configure_pins(state, state->m_enable_mpeg_output);
6097 /* added: configure GPIO */
6098 status = write_gpio(state);
6102 state->m_drxk_state = DRXK_STOPPED;
6104 if (state->m_b_power_down) {
6105 status = power_down_device(state);
6108 state->m_drxk_state = DRXK_POWERED_DOWN;
6110 state->m_drxk_state = DRXK_STOPPED;
6112 /* Initialize the supported delivery systems */
6114 if (state->m_has_dvbc) {
6115 state->frontend.ops.delsys[n++] = SYS_DVBC_ANNEX_A;
6116 state->frontend.ops.delsys[n++] = SYS_DVBC_ANNEX_C;
6117 strlcat(state->frontend.ops.info.name, " DVB-C",
6118 sizeof(state->frontend.ops.info.name));
6120 if (state->m_has_dvbt) {
6121 state->frontend.ops.delsys[n++] = SYS_DVBT;
6122 strlcat(state->frontend.ops.info.name, " DVB-T",
6123 sizeof(state->frontend.ops.info.name));
6125 drxk_i2c_unlock(state);
6129 state->m_drxk_state = DRXK_NO_DEV;
6130 drxk_i2c_unlock(state);
6131 printk(KERN_ERR "drxk: Error %d on %s\n", status, __func__);
6137 static void load_firmware_cb(const struct firmware *fw,
6140 struct drxk_state *state = context;
6142 dprintk(1, ": %s\n", fw ? "firmware loaded" : "firmware not loaded");
6145 "drxk: Could not load firmware file %s.\n",
6146 state->microcode_name);
6148 "drxk: Copy %s to your hotplug directory!\n",
6149 state->microcode_name);
6150 state->microcode_name = NULL;
6153 * As firmware is now load asynchronous, it is not possible
6154 * anymore to fail at frontend attach. We might silently
6155 * return here, and hope that the driver won't crash.
6156 * We might also change all DVB callbacks to return -ENODEV
6157 * if the device is not initialized.
6158 * As the DRX-K devices have their own internal firmware,
6159 * let's just hope that it will match a firmware revision
6160 * compatible with this driver and proceed.
6168 static void drxk_release(struct dvb_frontend *fe)
6170 struct drxk_state *state = fe->demodulator_priv;
6174 release_firmware(state->fw);
6179 static int drxk_sleep(struct dvb_frontend *fe)
6181 struct drxk_state *state = fe->demodulator_priv;
6185 if (state->m_drxk_state == DRXK_NO_DEV)
6187 if (state->m_drxk_state == DRXK_UNINITIALIZED)
6194 static int drxk_gate_ctrl(struct dvb_frontend *fe, int enable)
6196 struct drxk_state *state = fe->demodulator_priv;
6198 dprintk(1, ": %s\n", enable ? "enable" : "disable");
6200 if (state->m_drxk_state == DRXK_NO_DEV)
6203 return ConfigureI2CBridge(state, enable ? true : false);
6206 static int drxk_set_parameters(struct dvb_frontend *fe)
6208 struct dtv_frontend_properties *p = &fe->dtv_property_cache;
6209 u32 delsys = p->delivery_system, old_delsys;
6210 struct drxk_state *state = fe->demodulator_priv;
6215 if (state->m_drxk_state == DRXK_NO_DEV)
6218 if (state->m_drxk_state == DRXK_UNINITIALIZED)
6221 if (!fe->ops.tuner_ops.get_if_frequency) {
6223 "drxk: Error: get_if_frequency() not defined at tuner. Can't work without it!\n");
6227 if (fe->ops.i2c_gate_ctrl)
6228 fe->ops.i2c_gate_ctrl(fe, 1);
6229 if (fe->ops.tuner_ops.set_params)
6230 fe->ops.tuner_ops.set_params(fe);
6231 if (fe->ops.i2c_gate_ctrl)
6232 fe->ops.i2c_gate_ctrl(fe, 0);
6234 old_delsys = state->props.delivery_system;
6237 if (old_delsys != delsys) {
6240 case SYS_DVBC_ANNEX_A:
6241 case SYS_DVBC_ANNEX_C:
6242 if (!state->m_has_dvbc)
6244 state->m_itut_annex_c = (delsys == SYS_DVBC_ANNEX_C) ? true : false;
6245 if (state->m_itut_annex_c)
6246 setoperation_mode(state, OM_QAM_ITU_C);
6248 setoperation_mode(state, OM_QAM_ITU_A);
6251 if (!state->m_has_dvbt)
6253 setoperation_mode(state, OM_DVBT);
6260 fe->ops.tuner_ops.get_if_frequency(fe, &IF);
6261 start(state, 0, IF);
6263 /* After set_frontend, stats aren't avaliable */
6264 p->strength.stat[0].scale = FE_SCALE_RELATIVE;
6265 p->cnr.stat[0].scale = FE_SCALE_NOT_AVAILABLE;
6266 p->block_error.stat[0].scale = FE_SCALE_NOT_AVAILABLE;
6267 p->block_count.stat[0].scale = FE_SCALE_NOT_AVAILABLE;
6268 p->pre_bit_error.stat[0].scale = FE_SCALE_NOT_AVAILABLE;
6269 p->pre_bit_count.stat[0].scale = FE_SCALE_NOT_AVAILABLE;
6270 p->post_bit_error.stat[0].scale = FE_SCALE_NOT_AVAILABLE;
6271 p->post_bit_count.stat[0].scale = FE_SCALE_NOT_AVAILABLE;
6273 /* printk(KERN_DEBUG "drxk: %s IF=%d done\n", __func__, IF); */
6278 static int get_strength(struct drxk_state *state, u64 *strength)
6281 struct s_cfg_agc rf_agc, if_agc;
6287 /* FIXME: those are part of the tuner presets */
6288 u16 tuner_rf_gain = 50; /* Default value on az6007 driver */
6289 u16 tuner_if_gain = 40; /* Default value on az6007 driver */
6293 if (is_dvbt(state)) {
6294 rf_agc = state->m_dvbt_rf_agc_cfg;
6295 if_agc = state->m_dvbt_if_agc_cfg;
6296 } else if (is_qam(state)) {
6297 rf_agc = state->m_qam_rf_agc_cfg;
6298 if_agc = state->m_qam_if_agc_cfg;
6300 rf_agc = state->m_atv_rf_agc_cfg;
6301 if_agc = state->m_atv_if_agc_cfg;
6304 if (rf_agc.ctrl_mode == DRXK_AGC_CTRL_AUTO) {
6305 /* SCU output_level */
6306 status = read16(state, SCU_RAM_AGC_RF_IACCU_HI__A, &scu_lvl);
6311 read16(state, SCU_RAM_AGC_RF_IACCU_HI_CO__A, &scu_coc);
6315 if (((u32) scu_lvl + (u32) scu_coc) < 0xffff)
6316 rf_agc.output_level = scu_lvl + scu_coc;
6318 rf_agc.output_level = 0xffff;
6320 /* Take RF gain into account */
6321 total_gain += tuner_rf_gain;
6323 /* clip output value */
6324 if (rf_agc.output_level < rf_agc.min_output_level)
6325 rf_agc.output_level = rf_agc.min_output_level;
6326 if (rf_agc.output_level > rf_agc.max_output_level)
6327 rf_agc.output_level = rf_agc.max_output_level;
6329 agc_range = (u32) (rf_agc.max_output_level - rf_agc.min_output_level);
6330 if (agc_range > 0) {
6332 ((u32)(tuner_rf_gain)) *
6333 ((u32)(rf_agc.output_level - rf_agc.min_output_level))
6338 if (if_agc.ctrl_mode == DRXK_AGC_CTRL_AUTO) {
6339 status = read16(state, SCU_RAM_AGC_IF_IACCU_HI__A,
6340 &if_agc.output_level);
6344 status = read16(state, SCU_RAM_AGC_INGAIN_TGT_MIN__A,
6349 /* Take IF gain into account */
6350 total_gain += (u32) tuner_if_gain;
6352 /* clip output value */
6353 if (if_agc.output_level < if_agc.min_output_level)
6354 if_agc.output_level = if_agc.min_output_level;
6355 if (if_agc.output_level > if_agc.max_output_level)
6356 if_agc.output_level = if_agc.max_output_level;
6358 agc_range = (u32) (if_agc.max_output_level - if_agc.min_output_level);
6359 if (agc_range > 0) {
6361 ((u32)(tuner_if_gain)) *
6362 ((u32)(if_agc.output_level - if_agc.min_output_level))
6368 * Convert to 0..65535 scale.
6369 * If it can't be measured (AGC is disabled), just show 100%.
6372 *strength = (65535UL * atten / total_gain / 100);
6379 static int drxk_get_stats(struct dvb_frontend *fe)
6381 struct dtv_frontend_properties *c = &fe->dtv_property_cache;
6382 struct drxk_state *state = fe->demodulator_priv;
6387 u32 post_bit_err_count;
6388 u32 post_bit_error_scale;
6389 u32 pre_bit_err_count;
6392 u32 pkt_error_count;
6395 if (state->m_drxk_state == DRXK_NO_DEV)
6397 if (state->m_drxk_state == DRXK_UNINITIALIZED)
6401 state->fe_status = 0;
6402 get_lock_status(state, &stat);
6403 if (stat == MPEG_LOCK)
6404 state->fe_status |= 0x1f;
6405 if (stat == FEC_LOCK)
6406 state->fe_status |= 0x0f;
6407 if (stat == DEMOD_LOCK)
6408 state->fe_status |= 0x07;
6411 * Estimate signal strength from AGC
6413 get_strength(state, &c->strength.stat[0].uvalue);
6414 c->strength.stat[0].scale = FE_SCALE_RELATIVE;
6417 if (stat >= DEMOD_LOCK) {
6418 get_signal_to_noise(state, &cnr);
6419 c->cnr.stat[0].svalue = cnr * 100;
6420 c->cnr.stat[0].scale = FE_SCALE_DECIBEL;
6422 c->cnr.stat[0].scale = FE_SCALE_NOT_AVAILABLE;
6425 if (stat < FEC_LOCK) {
6426 c->block_error.stat[0].scale = FE_SCALE_NOT_AVAILABLE;
6427 c->block_count.stat[0].scale = FE_SCALE_NOT_AVAILABLE;
6428 c->pre_bit_error.stat[0].scale = FE_SCALE_NOT_AVAILABLE;
6429 c->pre_bit_count.stat[0].scale = FE_SCALE_NOT_AVAILABLE;
6430 c->post_bit_error.stat[0].scale = FE_SCALE_NOT_AVAILABLE;
6431 c->post_bit_count.stat[0].scale = FE_SCALE_NOT_AVAILABLE;
6437 /* BER measurement is valid if at least FEC lock is achieved */
6439 /* OFDM_EC_VD_REQ_SMB_CNT__A and/or OFDM_EC_VD_REQ_BIT_CNT can be written
6440 to set nr of symbols or bits over which
6441 to measure EC_VD_REG_ERR_BIT_CNT__A . See CtrlSetCfg(). */
6443 /* Read registers for post/preViterbi BER calculation */
6444 status = read16(state, OFDM_EC_VD_ERR_BIT_CNT__A, ®16);
6447 pre_bit_err_count = reg16;
6449 status = read16(state, OFDM_EC_VD_IN_BIT_CNT__A , ®16);
6452 pre_bit_count = reg16;
6454 /* Number of bit-errors */
6455 status = read16(state, FEC_RS_NR_BIT_ERRORS__A, ®16);
6458 post_bit_err_count = reg16;
6460 status = read16(state, FEC_RS_MEASUREMENT_PRESCALE__A, ®16);
6463 post_bit_error_scale = reg16;
6465 status = read16(state, FEC_RS_MEASUREMENT_PERIOD__A, ®16);
6470 status = read16(state, SCU_RAM_FEC_ACCUM_PKT_FAILURES__A, ®16);
6473 pkt_error_count = reg16;
6474 write16(state, SCU_RAM_FEC_ACCUM_PKT_FAILURES__A, 0);
6476 post_bit_err_count *= post_bit_error_scale;
6478 post_bit_count = pkt_count * 204 * 8;
6480 /* Store the results */
6481 c->block_error.stat[0].scale = FE_SCALE_COUNTER;
6482 c->block_error.stat[0].uvalue += pkt_error_count;
6483 c->block_count.stat[0].scale = FE_SCALE_COUNTER;
6484 c->block_count.stat[0].uvalue += pkt_count;
6486 c->pre_bit_error.stat[0].scale = FE_SCALE_COUNTER;
6487 c->pre_bit_error.stat[0].uvalue += pre_bit_err_count;
6488 c->pre_bit_count.stat[0].scale = FE_SCALE_COUNTER;
6489 c->pre_bit_count.stat[0].uvalue += pre_bit_count;
6491 c->post_bit_error.stat[0].scale = FE_SCALE_COUNTER;
6492 c->post_bit_error.stat[0].uvalue += post_bit_err_count;
6493 c->post_bit_count.stat[0].scale = FE_SCALE_COUNTER;
6494 c->post_bit_count.stat[0].uvalue += post_bit_count;
6501 static int drxk_read_status(struct dvb_frontend *fe, fe_status_t *status)
6503 struct drxk_state *state = fe->demodulator_priv;
6508 rc = drxk_get_stats(fe);
6512 *status = state->fe_status;
6517 static int drxk_read_signal_strength(struct dvb_frontend *fe,
6520 struct drxk_state *state = fe->demodulator_priv;
6521 struct dtv_frontend_properties *c = &fe->dtv_property_cache;
6525 if (state->m_drxk_state == DRXK_NO_DEV)
6527 if (state->m_drxk_state == DRXK_UNINITIALIZED)
6530 *strength = c->strength.stat[0].uvalue;
6534 static int drxk_read_snr(struct dvb_frontend *fe, u16 *snr)
6536 struct drxk_state *state = fe->demodulator_priv;
6541 if (state->m_drxk_state == DRXK_NO_DEV)
6543 if (state->m_drxk_state == DRXK_UNINITIALIZED)
6546 get_signal_to_noise(state, &snr2);
6548 /* No negative SNR, clip to zero */
6551 *snr = snr2 & 0xffff;
6555 static int drxk_read_ucblocks(struct dvb_frontend *fe, u32 *ucblocks)
6557 struct drxk_state *state = fe->demodulator_priv;
6562 if (state->m_drxk_state == DRXK_NO_DEV)
6564 if (state->m_drxk_state == DRXK_UNINITIALIZED)
6567 dvbtqam_get_acc_pkt_err(state, &err);
6568 *ucblocks = (u32) err;
6572 static int drxk_get_tune_settings(struct dvb_frontend *fe, struct dvb_frontend_tune_settings
6575 struct drxk_state *state = fe->demodulator_priv;
6576 struct dtv_frontend_properties *p = &fe->dtv_property_cache;
6580 if (state->m_drxk_state == DRXK_NO_DEV)
6582 if (state->m_drxk_state == DRXK_UNINITIALIZED)
6585 switch (p->delivery_system) {
6586 case SYS_DVBC_ANNEX_A:
6587 case SYS_DVBC_ANNEX_C:
6589 sets->min_delay_ms = 3000;
6590 sets->max_drift = 0;
6591 sets->step_size = 0;
6598 static struct dvb_frontend_ops drxk_ops = {
6599 /* .delsys will be filled dynamically */
6602 .frequency_min = 47000000,
6603 .frequency_max = 865000000,
6605 .symbol_rate_min = 870000,
6606 .symbol_rate_max = 11700000,
6608 .frequency_stepsize = 166667,
6610 .caps = FE_CAN_QAM_16 | FE_CAN_QAM_32 | FE_CAN_QAM_64 |
6611 FE_CAN_QAM_128 | FE_CAN_QAM_256 | FE_CAN_FEC_AUTO |
6612 FE_CAN_FEC_1_2 | FE_CAN_FEC_2_3 | FE_CAN_FEC_3_4 |
6613 FE_CAN_FEC_5_6 | FE_CAN_FEC_7_8 | FE_CAN_MUTE_TS |
6614 FE_CAN_TRANSMISSION_MODE_AUTO | FE_CAN_RECOVER |
6615 FE_CAN_GUARD_INTERVAL_AUTO | FE_CAN_HIERARCHY_AUTO
6618 .release = drxk_release,
6619 .sleep = drxk_sleep,
6620 .i2c_gate_ctrl = drxk_gate_ctrl,
6622 .set_frontend = drxk_set_parameters,
6623 .get_tune_settings = drxk_get_tune_settings,
6625 .read_status = drxk_read_status,
6626 .read_signal_strength = drxk_read_signal_strength,
6627 .read_snr = drxk_read_snr,
6628 .read_ucblocks = drxk_read_ucblocks,
6631 struct dvb_frontend *drxk_attach(const struct drxk_config *config,
6632 struct i2c_adapter *i2c)
6634 struct dtv_frontend_properties *p;
6635 struct drxk_state *state = NULL;
6636 u8 adr = config->adr;
6640 state = kzalloc(sizeof(struct drxk_state), GFP_KERNEL);
6645 state->demod_address = adr;
6646 state->single_master = config->single_master;
6647 state->microcode_name = config->microcode_name;
6648 state->qam_demod_parameter_count = config->qam_demod_parameter_count;
6649 state->no_i2c_bridge = config->no_i2c_bridge;
6650 state->antenna_gpio = config->antenna_gpio;
6651 state->antenna_dvbt = config->antenna_dvbt;
6652 state->m_chunk_size = config->chunk_size;
6653 state->enable_merr_cfg = config->enable_merr_cfg;
6655 if (config->dynamic_clk) {
6656 state->m_dvbt_static_clk = 0;
6657 state->m_dvbc_static_clk = 0;
6659 state->m_dvbt_static_clk = 1;
6660 state->m_dvbc_static_clk = 1;
6664 if (config->mpeg_out_clk_strength)
6665 state->m_ts_clockk_strength = config->mpeg_out_clk_strength & 0x07;
6667 state->m_ts_clockk_strength = 0x06;
6669 if (config->parallel_ts)
6670 state->m_enable_parallel = true;
6672 state->m_enable_parallel = false;
6674 /* NOTE: as more UIO bits will be used, add them to the mask */
6675 state->uio_mask = config->antenna_gpio;
6677 /* Default gpio to DVB-C */
6678 if (!state->antenna_dvbt && state->antenna_gpio)
6679 state->m_gpio |= state->antenna_gpio;
6681 state->m_gpio &= ~state->antenna_gpio;
6683 mutex_init(&state->mutex);
6685 memcpy(&state->frontend.ops, &drxk_ops, sizeof(drxk_ops));
6686 state->frontend.demodulator_priv = state;
6690 /* Load firmware and initialize DRX-K */
6691 if (state->microcode_name) {
6692 if (config->load_firmware_sync) {
6693 const struct firmware *fw = NULL;
6695 status = request_firmware(&fw, state->microcode_name,
6696 state->i2c->dev.parent);
6699 load_firmware_cb(fw, state);
6701 status = request_firmware_nowait(THIS_MODULE, 1,
6702 state->microcode_name,
6703 state->i2c->dev.parent,
6705 state, load_firmware_cb);
6708 "drxk: failed to request a firmware\n");
6712 } else if (init_drxk(state) < 0)
6716 /* Initialize stats */
6717 p = &state->frontend.dtv_property_cache;
6718 p->strength.len = 1;
6720 p->block_error.len = 1;
6721 p->block_count.len = 1;
6722 p->pre_bit_error.len = 1;
6723 p->pre_bit_count.len = 1;
6724 p->post_bit_error.len = 1;
6725 p->post_bit_count.len = 1;
6727 p->strength.stat[0].scale = FE_SCALE_RELATIVE;
6728 p->cnr.stat[0].scale = FE_SCALE_NOT_AVAILABLE;
6729 p->block_error.stat[0].scale = FE_SCALE_NOT_AVAILABLE;
6730 p->block_count.stat[0].scale = FE_SCALE_NOT_AVAILABLE;
6731 p->pre_bit_error.stat[0].scale = FE_SCALE_NOT_AVAILABLE;
6732 p->pre_bit_count.stat[0].scale = FE_SCALE_NOT_AVAILABLE;
6733 p->post_bit_error.stat[0].scale = FE_SCALE_NOT_AVAILABLE;
6734 p->post_bit_count.stat[0].scale = FE_SCALE_NOT_AVAILABLE;
6736 printk(KERN_INFO "drxk: frontend initialized.\n");
6737 return &state->frontend;
6740 printk(KERN_ERR "drxk: not found\n");
6744 EXPORT_SYMBOL(drxk_attach);
6746 MODULE_DESCRIPTION("DRX-K driver");
6747 MODULE_AUTHOR("Ralph Metzler");
6748 MODULE_LICENSE("GPL");