diff options
Diffstat (limited to 'drivers')
-rw-r--r-- | drivers/media/common/tuners/mxl5005s.c | 2496 | ||||
-rw-r--r-- | drivers/media/common/tuners/mxl5005s.h | 4 |
2 files changed, 1029 insertions, 1471 deletions
diff --git a/drivers/media/common/tuners/mxl5005s.c b/drivers/media/common/tuners/mxl5005s.c index 45ac6a9e71a3..21dca5bdca77 100644 --- a/drivers/media/common/tuners/mxl5005s.c +++ b/drivers/media/common/tuners/mxl5005s.c | |||
@@ -86,34 +86,30 @@ static int debug = 2; | |||
86 | #define MASTER_CONTROL_ADDR 9 | 86 | #define MASTER_CONTROL_ADDR 9 |
87 | 87 | ||
88 | /* Enumeration of Master Control Register State */ | 88 | /* Enumeration of Master Control Register State */ |
89 | typedef enum | 89 | enum master_control_state { |
90 | { | ||
91 | MC_LOAD_START = 1, | 90 | MC_LOAD_START = 1, |
92 | MC_POWER_DOWN, | 91 | MC_POWER_DOWN, |
93 | MC_SYNTH_RESET, | 92 | MC_SYNTH_RESET, |
94 | MC_SEQ_OFF | 93 | MC_SEQ_OFF |
95 | } Master_Control_State; | 94 | }; |
96 | 95 | ||
97 | /* Enumeration of MXL5005 Tuner Modulation Type */ | 96 | /* Enumeration of MXL5005 Tuner Modulation Type */ |
98 | typedef enum | 97 | enum { |
99 | { | ||
100 | MXL_DEFAULT_MODULATION = 0, | 98 | MXL_DEFAULT_MODULATION = 0, |
101 | MXL_DVBT, | 99 | MXL_DVBT, |
102 | MXL_ATSC, | 100 | MXL_ATSC, |
103 | MXL_QAM, | 101 | MXL_QAM, |
104 | MXL_ANALOG_CABLE, | 102 | MXL_ANALOG_CABLE, |
105 | MXL_ANALOG_OTA | 103 | MXL_ANALOG_OTA |
106 | } Tuner_Modu_Type; | 104 | } tuner_modu_type; |
107 | 105 | ||
108 | /* MXL5005 Tuner Register Struct */ | 106 | /* MXL5005 Tuner Register Struct */ |
109 | typedef struct _TunerReg_struct | 107 | struct TunerReg { |
110 | { | ||
111 | u16 Reg_Num; /* Tuner Register Address */ | 108 | u16 Reg_Num; /* Tuner Register Address */ |
112 | u16 Reg_Val; /* Current sofware programmed value waiting to be writen */ | 109 | u16 Reg_Val; /* Current sw programmed value waiting to be writen */ |
113 | } TunerReg_struct; | 110 | }; |
114 | 111 | ||
115 | typedef enum | 112 | enum { |
116 | { | ||
117 | /* Initialization Control Names */ | 113 | /* Initialization Control Names */ |
118 | DN_IQTN_AMP_CUT = 1, /* 1 */ | 114 | DN_IQTN_AMP_CUT = 1, /* 1 */ |
119 | BB_MODE, /* 2 */ | 115 | BB_MODE, /* 2 */ |
@@ -219,16 +215,14 @@ typedef enum | |||
219 | #define MXL5005S_BB_DLPF_BANDSEL_LSB 3 | 215 | #define MXL5005S_BB_DLPF_BANDSEL_LSB 3 |
220 | 216 | ||
221 | /* Standard modes */ | 217 | /* Standard modes */ |
222 | enum | 218 | enum { |
223 | { | ||
224 | MXL5005S_STANDARD_DVBT, | 219 | MXL5005S_STANDARD_DVBT, |
225 | MXL5005S_STANDARD_ATSC, | 220 | MXL5005S_STANDARD_ATSC, |
226 | }; | 221 | }; |
227 | #define MXL5005S_STANDARD_MODE_NUM 2 | 222 | #define MXL5005S_STANDARD_MODE_NUM 2 |
228 | 223 | ||
229 | /* Bandwidth modes */ | 224 | /* Bandwidth modes */ |
230 | enum | 225 | enum { |
231 | { | ||
232 | MXL5005S_BANDWIDTH_6MHZ = 6000000, | 226 | MXL5005S_BANDWIDTH_6MHZ = 6000000, |
233 | MXL5005S_BANDWIDTH_7MHZ = 7000000, | 227 | MXL5005S_BANDWIDTH_7MHZ = 7000000, |
234 | MXL5005S_BANDWIDTH_8MHZ = 8000000, | 228 | MXL5005S_BANDWIDTH_8MHZ = 8000000, |
@@ -236,17 +230,16 @@ enum | |||
236 | #define MXL5005S_BANDWIDTH_MODE_NUM 3 | 230 | #define MXL5005S_BANDWIDTH_MODE_NUM 3 |
237 | 231 | ||
238 | /* MXL5005 Tuner Control Struct */ | 232 | /* MXL5005 Tuner Control Struct */ |
239 | typedef struct _TunerControl_struct { | 233 | struct TunerControl { |
240 | u16 Ctrl_Num; /* Control Number */ | 234 | u16 Ctrl_Num; /* Control Number */ |
241 | u16 size; /* Number of bits to represent Value */ | 235 | u16 size; /* Number of bits to represent Value */ |
242 | u16 addr[25]; /* Array of Tuner Register Address for each bit position */ | 236 | u16 addr[25]; /* Array of Tuner Register Address for each bit pos */ |
243 | u16 bit[25]; /* Array of bit position in Register Address for each bit position */ | 237 | u16 bit[25]; /* Array of bit pos in Reg Addr for each bit pos */ |
244 | u16 val[25]; /* Binary representation of Value */ | 238 | u16 val[25]; /* Binary representation of Value */ |
245 | } TunerControl_struct; | 239 | }; |
246 | 240 | ||
247 | /* MXL5005 Tuner Struct */ | 241 | /* MXL5005 Tuner Struct */ |
248 | struct mxl5005s_state | 242 | struct mxl5005s_state { |
249 | { | ||
250 | u8 Mode; /* 0: Analog Mode ; 1: Digital Mode */ | 243 | u8 Mode; /* 0: Analog Mode ; 1: Digital Mode */ |
251 | u8 IF_Mode; /* for Analog Mode, 0: zero IF; 1: low IF */ | 244 | u8 IF_Mode; /* for Analog Mode, 0: zero IF; 1: low IF */ |
252 | u32 Chan_Bandwidth; /* filter channel bandwidth (6, 7, 8) */ | 245 | u32 Chan_Bandwidth; /* filter channel bandwidth (6, 7, 8) */ |
@@ -256,14 +249,18 @@ struct mxl5005s_state | |||
256 | u32 Fxtal; /* XTAL Frequency */ | 249 | u32 Fxtal; /* XTAL Frequency */ |
257 | u8 AGC_Mode; /* AGC Mode 0: Dual AGC; 1: Single AGC */ | 250 | u8 AGC_Mode; /* AGC Mode 0: Dual AGC; 1: Single AGC */ |
258 | u16 TOP; /* Value: take over point */ | 251 | u16 TOP; /* Value: take over point */ |
259 | u8 CLOCK_OUT; /* 0: turn off clock out; 1: turn on clock out */ | 252 | u8 CLOCK_OUT; /* 0: turn off clk out; 1: turn on clock out */ |
260 | u8 DIV_OUT; /* 4MHz or 16MHz */ | 253 | u8 DIV_OUT; /* 4MHz or 16MHz */ |
261 | u8 CAPSELECT; /* 0: disable On-Chip pulling cap; 1: enable */ | 254 | u8 CAPSELECT; /* 0: disable On-Chip pulling cap; 1: enable */ |
262 | u8 EN_RSSI; /* 0: disable RSSI; 1: enable RSSI */ | 255 | u8 EN_RSSI; /* 0: disable RSSI; 1: enable RSSI */ |
263 | u8 Mod_Type; /* Modulation Type; */ | 256 | |
264 | /* 0 - Default; 1 - DVB-T; 2 - ATSC; 3 - QAM; 4 - Analog Cable */ | 257 | /* Modulation Type; */ |
265 | u8 TF_Type; /* Tracking Filter Type */ | 258 | /* 0 - Default; 1 - DVB-T; 2 - ATSC; 3 - QAM; 4 - Analog Cable */ |
266 | /* 0 - Default; 1 - Off; 2 - Type C; 3 - Type C-H */ | 259 | u8 Mod_Type; |
260 | |||
261 | /* Tracking Filter Type */ | ||
262 | /* 0 - Default; 1 - Off; 2 - Type C; 3 - Type C-H */ | ||
263 | u8 TF_Type; | ||
267 | 264 | ||
268 | /* Calculated Settings */ | 265 | /* Calculated Settings */ |
269 | u32 RF_LO; /* Synth RF LO Frequency */ | 266 | u32 RF_LO; /* Synth RF LO Frequency */ |
@@ -271,22 +268,22 @@ struct mxl5005s_state | |||
271 | u32 TG_LO; /* Synth TG_LO Frequency */ | 268 | u32 TG_LO; /* Synth TG_LO Frequency */ |
272 | 269 | ||
273 | /* Pointers to ControlName Arrays */ | 270 | /* Pointers to ControlName Arrays */ |
274 | u16 Init_Ctrl_Num; /* Number of INIT Control Names */ | 271 | u16 Init_Ctrl_Num; /* Number of INIT Control Names */ |
275 | TunerControl_struct | 272 | struct TunerControl |
276 | Init_Ctrl[INITCTRL_NUM]; /* INIT Control Names Array Pointer */ | 273 | Init_Ctrl[INITCTRL_NUM]; /* INIT Control Names Array Pointer */ |
277 | 274 | ||
278 | u16 CH_Ctrl_Num; /* Number of CH Control Names */ | 275 | u16 CH_Ctrl_Num; /* Number of CH Control Names */ |
279 | TunerControl_struct | 276 | struct TunerControl |
280 | CH_Ctrl[CHCTRL_NUM]; /* CH Control Name Array Pointer */ | 277 | CH_Ctrl[CHCTRL_NUM]; /* CH Control Name Array Pointer */ |
281 | 278 | ||
282 | u16 MXL_Ctrl_Num; /* Number of MXL Control Names */ | 279 | u16 MXL_Ctrl_Num; /* Number of MXL Control Names */ |
283 | TunerControl_struct | 280 | struct TunerControl |
284 | MXL_Ctrl[MXLCTRL_NUM]; /* MXL Control Name Array Pointer */ | 281 | MXL_Ctrl[MXLCTRL_NUM]; /* MXL Control Name Array Pointer */ |
285 | 282 | ||
286 | /* Pointer to Tuner Register Array */ | 283 | /* Pointer to Tuner Register Array */ |
287 | u16 TunerRegs_Num; /* Number of Tuner Registers */ | 284 | u16 TunerRegs_Num; /* Number of Tuner Registers */ |
288 | TunerReg_struct | 285 | struct TunerReg |
289 | TunerRegs[TUNER_REGS_NUM]; /* Tuner Register Array Pointer */ | 286 | TunerRegs[TUNER_REGS_NUM]; /* Tuner Register Array Pointer */ |
290 | 287 | ||
291 | /* Linux driver framework specific */ | 288 | /* Linux driver framework specific */ |
292 | struct mxl5005s_config *config; | 289 | struct mxl5005s_config *config; |
@@ -302,21 +299,27 @@ u16 MXL_ControlWrite(struct dvb_frontend *fe, u16 ControlNum, u32 value); | |||
302 | u16 MXL_ControlRead(struct dvb_frontend *fe, u16 controlNum, u32 *value); | 299 | u16 MXL_ControlRead(struct dvb_frontend *fe, u16 controlNum, u32 *value); |
303 | u16 MXL_GetMasterControl(u8 *MasterReg, int state); | 300 | u16 MXL_GetMasterControl(u8 *MasterReg, int state); |
304 | void MXL_RegWriteBit(struct dvb_frontend *fe, u8 address, u8 bit, u8 bitVal); | 301 | void MXL_RegWriteBit(struct dvb_frontend *fe, u8 address, u8 bit, u8 bitVal); |
305 | u16 MXL_GetCHRegister(struct dvb_frontend *fe, u8 *RegNum, u8 *RegVal, int *count); | 302 | u16 MXL_GetCHRegister(struct dvb_frontend *fe, u8 *RegNum, |
303 | u8 *RegVal, int *count); | ||
306 | u32 MXL_Ceiling(u32 value, u32 resolution); | 304 | u32 MXL_Ceiling(u32 value, u32 resolution); |
307 | u16 MXL_RegRead(struct dvb_frontend *fe, u8 RegNum, u8 *RegVal); | 305 | u16 MXL_RegRead(struct dvb_frontend *fe, u8 RegNum, u8 *RegVal); |
308 | u16 MXL_RegWrite(struct dvb_frontend *fe, u8 RegNum, u8 RegVal); | 306 | u16 MXL_RegWrite(struct dvb_frontend *fe, u8 RegNum, u8 RegVal); |
309 | u16 MXL_ControlWrite_Group(struct dvb_frontend *fe, u16 controlNum, u32 value, u16 controlGroup); | 307 | u16 MXL_ControlWrite_Group(struct dvb_frontend *fe, u16 controlNum, |
308 | u32 value, u16 controlGroup); | ||
310 | u16 MXL_SetGPIO(struct dvb_frontend *fe, u8 GPIO_Num, u8 GPIO_Val); | 309 | u16 MXL_SetGPIO(struct dvb_frontend *fe, u8 GPIO_Num, u8 GPIO_Val); |
311 | u16 MXL_GetInitRegister(struct dvb_frontend *fe, u8 * RegNum, u8 *RegVal, int *count); | 310 | u16 MXL_GetInitRegister(struct dvb_frontend *fe, u8 *RegNum, |
311 | u8 *RegVal, int *count); | ||
312 | u32 MXL_GetXtalInt(u32 Xtal_Freq); | 312 | u32 MXL_GetXtalInt(u32 Xtal_Freq); |
313 | u16 MXL_TuneRF(struct dvb_frontend *fe, u32 RF_Freq); | 313 | u16 MXL_TuneRF(struct dvb_frontend *fe, u32 RF_Freq); |
314 | void MXL_SynthIFLO_Calc(struct dvb_frontend *fe); | 314 | void MXL_SynthIFLO_Calc(struct dvb_frontend *fe); |
315 | void MXL_SynthRFTGLO_Calc(struct dvb_frontend *fe); | 315 | void MXL_SynthRFTGLO_Calc(struct dvb_frontend *fe); |
316 | u16 MXL_GetCHRegister_ZeroIF(struct dvb_frontend *fe, u8 *RegNum, u8 *RegVal, int *count); | 316 | u16 MXL_GetCHRegister_ZeroIF(struct dvb_frontend *fe, u8 *RegNum, |
317 | int mxl5005s_writeregs(struct dvb_frontend *fe, u8 *addrtable, u8 *datatable, u8 len); | 317 | u8 *RegVal, int *count); |
318 | int mxl5005s_writeregs(struct dvb_frontend *fe, u8 *addrtable, | ||
319 | u8 *datatable, u8 len); | ||
318 | u16 MXL_IFSynthInit(struct dvb_frontend *fe); | 320 | u16 MXL_IFSynthInit(struct dvb_frontend *fe); |
319 | int mxl5005s_AssignTunerMode(struct dvb_frontend *fe, u32 mod_type, u32 bandwidth); | 321 | int mxl5005s_AssignTunerMode(struct dvb_frontend *fe, u32 mod_type, |
322 | u32 bandwidth); | ||
320 | int mxl5005s_reconfigure(struct dvb_frontend *fe, u32 mod_type, u32 bandwidth); | 323 | int mxl5005s_reconfigure(struct dvb_frontend *fe, u32 mod_type, u32 bandwidth); |
321 | 324 | ||
322 | /* ---------------------------------------------------------------- | 325 | /* ---------------------------------------------------------------- |
@@ -343,16 +346,16 @@ int mxl5005s_SetRfFreqHz(struct dvb_frontend *fe, unsigned long RfFreqHz) | |||
343 | 346 | ||
344 | dprintk(1, "%s() freq=%ld\n", __func__, RfFreqHz); | 347 | dprintk(1, "%s() freq=%ld\n", __func__, RfFreqHz); |
345 | 348 | ||
346 | // Set MxL5005S tuner RF frequency according to MxL5005S tuner example code. | 349 | /* Set MxL5005S tuner RF frequency according to example code. */ |
347 | 350 | ||
348 | // Tuner RF frequency setting stage 0 | 351 | /* Tuner RF frequency setting stage 0 */ |
349 | MXL_GetMasterControl(ByteTable, MC_SYNTH_RESET) ; | 352 | MXL_GetMasterControl(ByteTable, MC_SYNTH_RESET); |
350 | AddrTable[0] = MASTER_CONTROL_ADDR; | 353 | AddrTable[0] = MASTER_CONTROL_ADDR; |
351 | ByteTable[0] |= state->config->AgcMasterByte; | 354 | ByteTable[0] |= state->config->AgcMasterByte; |
352 | 355 | ||
353 | mxl5005s_writeregs(fe, AddrTable, ByteTable, 1); | 356 | mxl5005s_writeregs(fe, AddrTable, ByteTable, 1); |
354 | 357 | ||
355 | // Tuner RF frequency setting stage 1 | 358 | /* Tuner RF frequency setting stage 1 */ |
356 | MXL_TuneRF(fe, RfFreqHz); | 359 | MXL_TuneRF(fe, RfFreqHz); |
357 | 360 | ||
358 | MXL_ControlRead(fe, IF_DIVVAL, &IfDivval); | 361 | MXL_ControlRead(fe, IF_DIVVAL, &IfDivval); |
@@ -360,26 +363,28 @@ int mxl5005s_SetRfFreqHz(struct dvb_frontend *fe, unsigned long RfFreqHz) | |||
360 | MXL_ControlWrite(fe, SEQ_FSM_PULSE, 0); | 363 | MXL_ControlWrite(fe, SEQ_FSM_PULSE, 0); |
361 | MXL_ControlWrite(fe, SEQ_EXTPOWERUP, 1); | 364 | MXL_ControlWrite(fe, SEQ_EXTPOWERUP, 1); |
362 | MXL_ControlWrite(fe, IF_DIVVAL, 8); | 365 | MXL_ControlWrite(fe, IF_DIVVAL, 8); |
363 | MXL_GetCHRegister(fe, AddrTable, ByteTable, &TableLen) ; | 366 | MXL_GetCHRegister(fe, AddrTable, ByteTable, &TableLen); |
364 | 367 | ||
365 | MXL_GetMasterControl(&MasterControlByte, MC_LOAD_START) ; | 368 | MXL_GetMasterControl(&MasterControlByte, MC_LOAD_START); |
366 | AddrTable[TableLen] = MASTER_CONTROL_ADDR ; | 369 | AddrTable[TableLen] = MASTER_CONTROL_ADDR ; |
367 | ByteTable[TableLen] = MasterControlByte | state->config->AgcMasterByte; | 370 | ByteTable[TableLen] = MasterControlByte | |
371 | state->config->AgcMasterByte; | ||
368 | TableLen += 1; | 372 | TableLen += 1; |
369 | 373 | ||
370 | mxl5005s_writeregs(fe, AddrTable, ByteTable, TableLen); | 374 | mxl5005s_writeregs(fe, AddrTable, ByteTable, TableLen); |
371 | 375 | ||
372 | // Wait 30 ms. | 376 | /* Wait 30 ms. */ |
373 | msleep(150); | 377 | msleep(150); |
374 | 378 | ||
375 | // Tuner RF frequency setting stage 2 | 379 | /* Tuner RF frequency setting stage 2 */ |
376 | MXL_ControlWrite(fe, SEQ_FSM_PULSE, 1) ; | 380 | MXL_ControlWrite(fe, SEQ_FSM_PULSE, 1); |
377 | MXL_ControlWrite(fe, IF_DIVVAL, IfDivval) ; | 381 | MXL_ControlWrite(fe, IF_DIVVAL, IfDivval); |
378 | MXL_GetCHRegister_ZeroIF(fe, AddrTable, ByteTable, &TableLen) ; | 382 | MXL_GetCHRegister_ZeroIF(fe, AddrTable, ByteTable, &TableLen); |
379 | 383 | ||
380 | MXL_GetMasterControl(&MasterControlByte, MC_LOAD_START) ; | 384 | MXL_GetMasterControl(&MasterControlByte, MC_LOAD_START); |
381 | AddrTable[TableLen] = MASTER_CONTROL_ADDR ; | 385 | AddrTable[TableLen] = MASTER_CONTROL_ADDR ; |
382 | ByteTable[TableLen] = MasterControlByte | state->config->AgcMasterByte ; | 386 | ByteTable[TableLen] = MasterControlByte | |
387 | state->config->AgcMasterByte ; | ||
383 | TableLen += 1; | 388 | TableLen += 1; |
384 | 389 | ||
385 | mxl5005s_writeregs(fe, AddrTable, ByteTable, TableLen); | 390 | mxl5005s_writeregs(fe, AddrTable, ByteTable, TableLen); |
@@ -398,7 +403,6 @@ u16 MXL5005_RegisterInit(struct dvb_frontend *fe) | |||
398 | { | 403 | { |
399 | struct mxl5005s_state *state = fe->tuner_priv; | 404 | struct mxl5005s_state *state = fe->tuner_priv; |
400 | state->TunerRegs_Num = TUNER_REGS_NUM ; | 405 | state->TunerRegs_Num = TUNER_REGS_NUM ; |
401 | // state->TunerRegs = (TunerReg_struct *) calloc( TUNER_REGS_NUM, sizeof(TunerReg_struct) ) ; | ||
402 | 406 | ||
403 | state->TunerRegs[0].Reg_Num = 9 ; | 407 | state->TunerRegs[0].Reg_Num = 9 ; |
404 | state->TunerRegs[0].Reg_Val = 0x40 ; | 408 | state->TunerRegs[0].Reg_Val = 0x40 ; |
@@ -1655,9 +1659,6 @@ u16 MXL5005_ControlInit(struct dvb_frontend *fe) | |||
1655 | return 0 ; | 1659 | return 0 ; |
1656 | } | 1660 | } |
1657 | 1661 | ||
1658 | // MaxLinear source code - MXL5005_c.cpp | ||
1659 | // MXL5005.cpp : Defines the initialization routines for the DLL. | ||
1660 | // 2.6.12 | ||
1661 | void InitTunerControls(struct dvb_frontend *fe) | 1662 | void InitTunerControls(struct dvb_frontend *fe) |
1662 | { | 1663 | { |
1663 | MXL5005_RegisterInit(fe); | 1664 | MXL5005_RegisterInit(fe); |
@@ -1667,57 +1668,28 @@ void InitTunerControls(struct dvb_frontend *fe) | |||
1667 | #endif | 1668 | #endif |
1668 | } | 1669 | } |
1669 | 1670 | ||
1670 | /////////////////////////////////////////////////////////////////////////////// | ||
1671 | // // | ||
1672 | // Function: MXL_ConfigTuner // | ||
1673 | // // | ||
1674 | // Description: Configure MXL5005Tuner structure for desired // | ||
1675 | // Channel Bandwidth/Channel Frequency // | ||
1676 | // // | ||
1677 | // // | ||
1678 | // Functions used: // | ||
1679 | // MXL_SynthIFLO_Calc // | ||
1680 | // // | ||
1681 | // Inputs: // | ||
1682 | // Tuner_struct: structure defined at higher level // | ||
1683 | // Mode: Tuner Mode (Analog/Digital) // | ||
1684 | // IF_Mode: IF Mode ( Zero/Low ) // | ||
1685 | // Bandwidth: Filter Channel Bandwidth (in Hz) // | ||
1686 | // IF_out: Desired IF out Frequency (in Hz) // | ||
1687 | // Fxtal: Crystal Frerquency (in Hz) // | ||
1688 | // TOP: 0: Dual AGC; Value: take over point // | ||
1689 | // IF_OUT_LOAD: IF out load resistor (200/300 Ohms) // | ||
1690 | // CLOCK_OUT: 0: Turn off clock out; 1: turn on clock out // | ||
1691 | // DIV_OUT: 0: Div-1; 1: Div-4 // | ||
1692 | // CAPSELECT: 0: Disable On-chip pulling cap; 1: Enable // | ||
1693 | // EN_RSSI: 0: Disable RSSI; 1: Enable RSSI // | ||
1694 | // // | ||
1695 | // Outputs: // | ||
1696 | // Tuner // | ||
1697 | // // | ||
1698 | // Return: // | ||
1699 | // 0 : Successful // | ||
1700 | // > 0 : Failed // | ||
1701 | // // | ||
1702 | /////////////////////////////////////////////////////////////////////////////// | ||
1703 | u16 MXL5005_TunerConfig(struct dvb_frontend *fe, | 1671 | u16 MXL5005_TunerConfig(struct dvb_frontend *fe, |
1704 | u8 Mode, /* 0: Analog Mode ; 1: Digital Mode */ | 1672 | u8 Mode, /* 0: Analog Mode ; 1: Digital Mode */ |
1705 | u8 IF_mode, /* for Analog Mode, 0: zero IF; 1: low IF */ | 1673 | u8 IF_mode, /* for Analog Mode, 0: zero IF; 1: low IF */ |
1706 | u32 Bandwidth, /* filter channel bandwidth (6, 7, 8) */ | 1674 | u32 Bandwidth, /* filter channel bandwidth (6, 7, 8) */ |
1707 | u32 IF_out, /* Desired IF Out Frequency */ | 1675 | u32 IF_out, /* Desired IF Out Frequency */ |
1708 | u32 Fxtal, /* XTAL Frequency */ | 1676 | u32 Fxtal, /* XTAL Frequency */ |
1709 | u8 AGC_Mode, /* AGC Mode - Dual AGC: 0, Single AGC: 1 */ | 1677 | u8 AGC_Mode, /* AGC Mode - Dual AGC: 0, Single AGC: 1 */ |
1710 | u16 TOP, /* 0: Dual AGC; Value: take over point */ | 1678 | u16 TOP, /* 0: Dual AGC; Value: take over point */ |
1711 | u16 IF_OUT_LOAD, /* IF Out Load Resistor (200 / 300 Ohms) */ | 1679 | u16 IF_OUT_LOAD, /* IF Out Load Resistor (200 / 300 Ohms) */ |
1712 | u8 CLOCK_OUT, /* 0: turn off clock out; 1: turn on clock out */ | 1680 | u8 CLOCK_OUT, /* 0: turn off clk out; 1: turn on clock out */ |
1713 | u8 DIV_OUT, /* 0: Div-1; 1: Div-4 */ | 1681 | u8 DIV_OUT, /* 0: Div-1; 1: Div-4 */ |
1714 | u8 CAPSELECT, /* 0: disable On-Chip pulling cap; 1: enable */ | 1682 | u8 CAPSELECT, /* 0: disable On-Chip pulling cap; 1: enable */ |
1715 | u8 EN_RSSI, /* 0: disable RSSI; 1: enable RSSI */ | 1683 | u8 EN_RSSI, /* 0: disable RSSI; 1: enable RSSI */ |
1716 | u8 Mod_Type, /* Modulation Type; */ | 1684 | |
1717 | /* 0 - Default; 1 - DVB-T; 2 - ATSC; 3 - QAM; 4 - Analog Cable */ | 1685 | /* Modulation Type; */ |
1718 | u8 TF_Type /* Tracking Filter */ | 1686 | /* 0 - Default; 1 - DVB-T; 2 - ATSC; 3 - QAM; 4 - Analog Cable */ |
1719 | /* 0 - Default; 1 - Off; 2 - Type C; 3 - Type C-H */ | 1687 | u8 Mod_Type, |
1720 | ) | 1688 | |
1689 | /* Tracking Filter */ | ||
1690 | /* 0 - Default; 1 - Off; 2 - Type C; 3 - Type C-H */ | ||
1691 | u8 TF_Type | ||
1692 | ) | ||
1721 | { | 1693 | { |
1722 | struct mxl5005s_state *state = fe->tuner_priv; | 1694 | struct mxl5005s_state *state = fe->tuner_priv; |
1723 | u16 status = 0; | 1695 | u16 status = 0; |
@@ -1746,105 +1718,40 @@ u16 MXL5005_TunerConfig(struct dvb_frontend *fe, | |||
1746 | return status; | 1718 | return status; |
1747 | } | 1719 | } |
1748 | 1720 | ||
1749 | /////////////////////////////////////////////////////////////////////////////// | ||
1750 | // // | ||
1751 | // Function: MXL_SynthIFLO_Calc // | ||
1752 | // // | ||
1753 | // Description: Calculate Internal IF-LO Frequency // | ||
1754 | // // | ||
1755 | // Globals: // | ||
1756 | // NONE // | ||
1757 | // // | ||
1758 | // Functions used: // | ||
1759 | // NONE // | ||
1760 | // // | ||
1761 | // Inputs: // | ||
1762 | // Tuner_struct: structure defined at higher level // | ||
1763 | // // | ||
1764 | // Outputs: // | ||
1765 | // Tuner // | ||
1766 | // // | ||
1767 | // Return: // | ||
1768 | // 0 : Successful // | ||
1769 | // > 0 : Failed // | ||
1770 | // // | ||
1771 | /////////////////////////////////////////////////////////////////////////////// | ||
1772 | void MXL_SynthIFLO_Calc(struct dvb_frontend *fe) | 1721 | void MXL_SynthIFLO_Calc(struct dvb_frontend *fe) |
1773 | { | 1722 | { |
1774 | struct mxl5005s_state *state = fe->tuner_priv; | 1723 | struct mxl5005s_state *state = fe->tuner_priv; |
1775 | if (state->Mode == 1) /* Digital Mode */ | 1724 | if (state->Mode == 1) /* Digital Mode */ |
1776 | state->IF_LO = state->IF_OUT; | 1725 | state->IF_LO = state->IF_OUT; |
1777 | else /* Analog Mode */ | 1726 | else /* Analog Mode */ { |
1778 | { | 1727 | if (state->IF_Mode == 0) /* Analog Zero IF mode */ |
1779 | if(state->IF_Mode == 0) /* Analog Zero IF mode */ | ||
1780 | state->IF_LO = state->IF_OUT + 400000; | 1728 | state->IF_LO = state->IF_OUT + 400000; |
1781 | else /* Analog Low IF mode */ | 1729 | else /* Analog Low IF mode */ |
1782 | state->IF_LO = state->IF_OUT + state->Chan_Bandwidth/2; | 1730 | state->IF_LO = state->IF_OUT + state->Chan_Bandwidth/2; |
1783 | } | 1731 | } |
1784 | } | 1732 | } |
1785 | 1733 | ||
1786 | /////////////////////////////////////////////////////////////////////////////// | ||
1787 | // // | ||
1788 | // Function: MXL_SynthRFTGLO_Calc // | ||
1789 | // // | ||
1790 | // Description: Calculate Internal RF-LO frequency and // | ||
1791 | // internal Tone-Gen(TG)-LO frequency // | ||
1792 | // // | ||
1793 | // Globals: // | ||
1794 | // NONE // | ||
1795 | // // | ||
1796 | // Functions used: // | ||
1797 | // NONE // | ||
1798 | // // | ||
1799 | // Inputs: // | ||
1800 | // Tuner_struct: structure defined at higher level // | ||
1801 | // // | ||
1802 | // Outputs: // | ||
1803 | // Tuner // | ||
1804 | // // | ||
1805 | // Return: // | ||
1806 | // 0 : Successful // | ||
1807 | // > 0 : Failed // | ||
1808 | // // | ||
1809 | /////////////////////////////////////////////////////////////////////////////// | ||
1810 | void MXL_SynthRFTGLO_Calc(struct dvb_frontend *fe) | 1734 | void MXL_SynthRFTGLO_Calc(struct dvb_frontend *fe) |
1811 | { | 1735 | { |
1812 | struct mxl5005s_state *state = fe->tuner_priv; | 1736 | struct mxl5005s_state *state = fe->tuner_priv; |
1813 | 1737 | ||
1814 | if (state->Mode == 1) /* Digital Mode */ { | 1738 | if (state->Mode == 1) /* Digital Mode */ { |
1815 | //remove 20.48MHz setting for 2.6.10 | 1739 | /* remove 20.48MHz setting for 2.6.10 */ |
1816 | state->RF_LO = state->RF_IN; | 1740 | state->RF_LO = state->RF_IN; |
1817 | state->TG_LO = state->RF_IN - 750000; //change for 2.6.6 | 1741 | /* change for 2.6.6 */ |
1742 | state->TG_LO = state->RF_IN - 750000; | ||
1818 | } else /* Analog Mode */ { | 1743 | } else /* Analog Mode */ { |
1819 | if(state->IF_Mode == 0) /* Analog Zero IF mode */ { | 1744 | if (state->IF_Mode == 0) /* Analog Zero IF mode */ { |
1820 | state->RF_LO = state->RF_IN - 400000; | 1745 | state->RF_LO = state->RF_IN - 400000; |
1821 | state->TG_LO = state->RF_IN - 1750000; | 1746 | state->TG_LO = state->RF_IN - 1750000; |
1822 | } else /* Analog Low IF mode */ { | 1747 | } else /* Analog Low IF mode */ { |
1823 | state->RF_LO = state->RF_IN - state->Chan_Bandwidth/2; | 1748 | state->RF_LO = state->RF_IN - state->Chan_Bandwidth/2; |
1824 | state->TG_LO = state->RF_IN - state->Chan_Bandwidth + 500000; | 1749 | state->TG_LO = state->RF_IN - |
1750 | state->Chan_Bandwidth + 500000; | ||
1825 | } | 1751 | } |
1826 | } | 1752 | } |
1827 | } | 1753 | } |
1828 | 1754 | ||
1829 | /////////////////////////////////////////////////////////////////////////////// | ||
1830 | // // | ||
1831 | // Function: MXL_OverwriteICDefault // | ||
1832 | // // | ||
1833 | // Description: Overwrite the Default Register Setting // | ||
1834 | // // | ||
1835 | // // | ||
1836 | // Functions used: // | ||
1837 | // // | ||
1838 | // Inputs: // | ||
1839 | // Tuner_struct: structure defined at higher level // | ||
1840 | // Outputs: // | ||
1841 | // Tuner // | ||
1842 | // // | ||
1843 | // Return: // | ||
1844 | // 0 : Successful // | ||
1845 | // > 0 : Failed // | ||
1846 | // // | ||
1847 | /////////////////////////////////////////////////////////////////////////////// | ||
1848 | u16 MXL_OverwriteICDefault(struct dvb_frontend *fe) | 1755 | u16 MXL_OverwriteICDefault(struct dvb_frontend *fe) |
1849 | { | 1756 | { |
1850 | u16 status = 0; | 1757 | u16 status = 0; |
@@ -1857,31 +1764,6 @@ u16 MXL_OverwriteICDefault(struct dvb_frontend *fe) | |||
1857 | return status; | 1764 | return status; |
1858 | } | 1765 | } |
1859 | 1766 | ||
1860 | /////////////////////////////////////////////////////////////////////////////// | ||
1861 | // // | ||
1862 | // Function: MXL_BlockInit // | ||
1863 | // // | ||
1864 | // Description: Tuner Initialization as a function of 'User Settings' // | ||
1865 | // * User settings in Tuner strcuture must be assigned // | ||
1866 | // first // | ||
1867 | // // | ||
1868 | // Globals: // | ||
1869 | // NONE // | ||
1870 | // // | ||
1871 | // Functions used: // | ||
1872 | // Tuner_struct: structure defined at higher level // | ||
1873 | // // | ||
1874 | // Inputs: // | ||
1875 | // Tuner : Tuner structure defined at higher level // | ||
1876 | // // | ||
1877 | // Outputs: // | ||
1878 | // Tuner // | ||
1879 | // // | ||
1880 | // Return: // | ||
1881 | // 0 : Successful // | ||
1882 | // > 0 : Failed // | ||
1883 | // // | ||
1884 | /////////////////////////////////////////////////////////////////////////////// | ||
1885 | u16 MXL_BlockInit(struct dvb_frontend *fe) | 1767 | u16 MXL_BlockInit(struct dvb_frontend *fe) |
1886 | { | 1768 | { |
1887 | struct mxl5005s_state *state = fe->tuner_priv; | 1769 | struct mxl5005s_state *state = fe->tuner_priv; |
@@ -1902,42 +1784,45 @@ u16 MXL_BlockInit(struct dvb_frontend *fe) | |||
1902 | /* Initialize Low-Pass Filter */ | 1784 | /* Initialize Low-Pass Filter */ |
1903 | if (state->Mode) { /* Digital Mode */ | 1785 | if (state->Mode) { /* Digital Mode */ |
1904 | switch (state->Chan_Bandwidth) { | 1786 | switch (state->Chan_Bandwidth) { |
1905 | case 8000000: | 1787 | case 8000000: |
1906 | status += MXL_ControlWrite(fe, BB_DLPF_BANDSEL, 0); | 1788 | status += MXL_ControlWrite(fe, BB_DLPF_BANDSEL, 0); |
1907 | break; | 1789 | break; |
1908 | case 7000000: | 1790 | case 7000000: |
1909 | status += MXL_ControlWrite(fe, BB_DLPF_BANDSEL, 2); | 1791 | status += MXL_ControlWrite(fe, BB_DLPF_BANDSEL, 2); |
1910 | break; | 1792 | break; |
1911 | case 6000000: | 1793 | case 6000000: |
1912 | printk("%s() doing 6MHz digital\n", __func__); | 1794 | status += MXL_ControlWrite(fe, |
1913 | status += MXL_ControlWrite(fe, BB_DLPF_BANDSEL, 3); | 1795 | BB_DLPF_BANDSEL, 3); |
1914 | break; | 1796 | break; |
1915 | } | 1797 | } |
1916 | } else { /* Analog Mode */ | 1798 | } else { /* Analog Mode */ |
1917 | switch (state->Chan_Bandwidth) { | 1799 | switch (state->Chan_Bandwidth) { |
1918 | case 8000000: /* Low Zero */ | 1800 | case 8000000: /* Low Zero */ |
1919 | status += MXL_ControlWrite(fe, BB_ALPF_BANDSELECT, (state->IF_Mode ? 0 : 3)); | 1801 | status += MXL_ControlWrite(fe, BB_ALPF_BANDSELECT, |
1920 | break; | 1802 | (state->IF_Mode ? 0 : 3)); |
1921 | case 7000000: | 1803 | break; |
1922 | status += MXL_ControlWrite(fe, BB_ALPF_BANDSELECT, (state->IF_Mode ? 1 : 4)); | 1804 | case 7000000: |
1923 | break; | 1805 | status += MXL_ControlWrite(fe, BB_ALPF_BANDSELECT, |
1924 | case 6000000: | 1806 | (state->IF_Mode ? 1 : 4)); |
1925 | status += MXL_ControlWrite(fe, BB_ALPF_BANDSELECT, (state->IF_Mode ? 2 : 5)); | 1807 | break; |
1926 | break; | 1808 | case 6000000: |
1809 | status += MXL_ControlWrite(fe, BB_ALPF_BANDSELECT, | ||
1810 | (state->IF_Mode ? 2 : 5)); | ||
1811 | break; | ||
1927 | } | 1812 | } |
1928 | } | 1813 | } |
1929 | 1814 | ||
1930 | /* Charge Pump Control Dig Ana */ | 1815 | /* Charge Pump Control Dig Ana */ |
1931 | status += MXL_ControlWrite(fe, RFSYN_CHP_GAIN, state->Mode ? 5 : 8); | 1816 | status += MXL_ControlWrite(fe, RFSYN_CHP_GAIN, state->Mode ? 5 : 8); |
1932 | status += MXL_ControlWrite(fe, RFSYN_EN_CHP_HIGAIN, state->Mode ? 1 : 1); | 1817 | status += MXL_ControlWrite(fe, |
1818 | RFSYN_EN_CHP_HIGAIN, state->Mode ? 1 : 1); | ||
1933 | status += MXL_ControlWrite(fe, EN_CHP_LIN_B, state->Mode ? 0 : 0); | 1819 | status += MXL_ControlWrite(fe, EN_CHP_LIN_B, state->Mode ? 0 : 0); |
1934 | 1820 | ||
1935 | /* AGC TOP Control */ | 1821 | /* AGC TOP Control */ |
1936 | if (state->AGC_Mode == 0) /* Dual AGC */ { | 1822 | if (state->AGC_Mode == 0) /* Dual AGC */ { |
1937 | status += MXL_ControlWrite(fe, AGC_IF, 15); | 1823 | status += MXL_ControlWrite(fe, AGC_IF, 15); |
1938 | status += MXL_ControlWrite(fe, AGC_RF, 15); | 1824 | status += MXL_ControlWrite(fe, AGC_RF, 15); |
1939 | } | 1825 | } else /* Single AGC Mode Dig Ana */ |
1940 | else /* Single AGC Mode Dig Ana */ | ||
1941 | status += MXL_ControlWrite(fe, AGC_RF, state->Mode ? 15 : 12); | 1826 | status += MXL_ControlWrite(fe, AGC_RF, state->Mode ? 15 : 12); |
1942 | 1827 | ||
1943 | if (state->TOP == 55) /* TOP == 5.5 */ | 1828 | if (state->TOP == 55) /* TOP == 5.5 */ |
@@ -2008,7 +1893,8 @@ u16 MXL_BlockInit(struct dvb_frontend *fe) | |||
2008 | status += MXL_ControlWrite(fe, EN_AUX_3P, 1); | 1893 | status += MXL_ControlWrite(fe, EN_AUX_3P, 1); |
2009 | status += MXL_ControlWrite(fe, SEL_AAF_BAND, 0); | 1894 | status += MXL_ControlWrite(fe, SEL_AAF_BAND, 0); |
2010 | } | 1895 | } |
2011 | if ((state->IF_OUT == 36125000UL) || (state->IF_OUT == 36150000UL)) { | 1896 | if ((state->IF_OUT == 36125000UL) || |
1897 | (state->IF_OUT == 36150000UL)) { | ||
2012 | status += MXL_ControlWrite(fe, EN_AAF, 1); | 1898 | status += MXL_ControlWrite(fe, EN_AAF, 1); |
2013 | status += MXL_ControlWrite(fe, EN_3P, 1); | 1899 | status += MXL_ControlWrite(fe, EN_3P, 1); |
2014 | status += MXL_ControlWrite(fe, EN_AUX_3P, 1); | 1900 | status += MXL_ControlWrite(fe, EN_AUX_3P, 1); |
@@ -2021,15 +1907,13 @@ u16 MXL_BlockInit(struct dvb_frontend *fe) | |||
2021 | status += MXL_ControlWrite(fe, SEL_AAF_BAND, 1); | 1907 | status += MXL_ControlWrite(fe, SEL_AAF_BAND, 1); |
2022 | } | 1908 | } |
2023 | } else { /* Analog Mode */ | 1909 | } else { /* Analog Mode */ |
2024 | if (state->IF_OUT >= 4000000UL && state->IF_OUT <= 5000000UL) | 1910 | if (state->IF_OUT >= 4000000UL && state->IF_OUT <= 5000000UL) { |
2025 | { | ||
2026 | status += MXL_ControlWrite(fe, EN_AAF, 1); | 1911 | status += MXL_ControlWrite(fe, EN_AAF, 1); |
2027 | status += MXL_ControlWrite(fe, EN_3P, 1); | 1912 | status += MXL_ControlWrite(fe, EN_3P, 1); |
2028 | status += MXL_ControlWrite(fe, EN_AUX_3P, 1); | 1913 | status += MXL_ControlWrite(fe, EN_AUX_3P, 1); |
2029 | status += MXL_ControlWrite(fe, SEL_AAF_BAND, 0); | 1914 | status += MXL_ControlWrite(fe, SEL_AAF_BAND, 0); |
2030 | } | 1915 | } |
2031 | if (state->IF_OUT > 5000000UL) | 1916 | if (state->IF_OUT > 5000000UL) { |
2032 | { | ||
2033 | status += MXL_ControlWrite(fe, EN_AAF, 0); | 1917 | status += MXL_ControlWrite(fe, EN_AAF, 0); |
2034 | status += MXL_ControlWrite(fe, EN_3P, 0); | 1918 | status += MXL_ControlWrite(fe, EN_3P, 0); |
2035 | status += MXL_ControlWrite(fe, EN_AUX_3P, 0); | 1919 | status += MXL_ControlWrite(fe, EN_AUX_3P, 0); |
@@ -2073,13 +1957,13 @@ u16 MXL_BlockInit(struct dvb_frontend *fe) | |||
2073 | /* status += MXL_ControlRead(fe, IF_DIVVAL, &IF_DIVVAL_Val); */ | 1957 | /* status += MXL_ControlRead(fe, IF_DIVVAL, &IF_DIVVAL_Val); */ |
2074 | 1958 | ||
2075 | /* Set TG_R_DIV */ | 1959 | /* Set TG_R_DIV */ |
2076 | status += MXL_ControlWrite(fe, TG_R_DIV, MXL_Ceiling(state->Fxtal, 1000000)); | 1960 | status += MXL_ControlWrite(fe, TG_R_DIV, |
1961 | MXL_Ceiling(state->Fxtal, 1000000)); | ||
2077 | 1962 | ||
2078 | /* Apply Default value to BB_INITSTATE_DLPF_TUNE */ | 1963 | /* Apply Default value to BB_INITSTATE_DLPF_TUNE */ |
2079 | 1964 | ||
2080 | /* RSSI Control */ | 1965 | /* RSSI Control */ |
2081 | if (state->EN_RSSI) | 1966 | if (state->EN_RSSI) { |
2082 | { | ||
2083 | status += MXL_ControlWrite(fe, SEQ_EXTSYNTHCALIF, 1); | 1967 | status += MXL_ControlWrite(fe, SEQ_EXTSYNTHCALIF, 1); |
2084 | status += MXL_ControlWrite(fe, SEQ_EXTDCCAL, 1); | 1968 | status += MXL_ControlWrite(fe, SEQ_EXTDCCAL, 1); |
2085 | status += MXL_ControlWrite(fe, AGC_EN_RSSI, 1); | 1969 | status += MXL_ControlWrite(fe, AGC_EN_RSSI, 1); |
@@ -2098,8 +1982,7 @@ u16 MXL_BlockInit(struct dvb_frontend *fe) | |||
2098 | /* Modulation type bit settings | 1982 | /* Modulation type bit settings |
2099 | * Override the control values preset | 1983 | * Override the control values preset |
2100 | */ | 1984 | */ |
2101 | if (state->Mod_Type == MXL_DVBT) /* DVB-T Mode */ | 1985 | if (state->Mod_Type == MXL_DVBT) /* DVB-T Mode */ { |
2102 | { | ||
2103 | state->AGC_Mode = 1; /* Single AGC Mode */ | 1986 | state->AGC_Mode = 1; /* Single AGC Mode */ |
2104 | 1987 | ||
2105 | /* Enable RSSI */ | 1988 | /* Enable RSSI */ |
@@ -2122,8 +2005,7 @@ u16 MXL_BlockInit(struct dvb_frontend *fe) | |||
2122 | status += MXL_ControlWrite(fe, BB_IQSWAP, 1); | 2005 | status += MXL_ControlWrite(fe, BB_IQSWAP, 1); |
2123 | 2006 | ||
2124 | } | 2007 | } |
2125 | if (state->Mod_Type == MXL_ATSC) /* ATSC Mode */ | 2008 | if (state->Mod_Type == MXL_ATSC) /* ATSC Mode */ { |
2126 | { | ||
2127 | state->AGC_Mode = 1; /* Single AGC Mode */ | 2009 | state->AGC_Mode = 1; /* Single AGC Mode */ |
2128 | 2010 | ||
2129 | /* Enable RSSI */ | 2011 | /* Enable RSSI */ |
@@ -2141,14 +2023,15 @@ u16 MXL_BlockInit(struct dvb_frontend *fe) | |||
2141 | status += MXL_ControlWrite(fe, RFA_FLR, 2); | 2023 | status += MXL_ControlWrite(fe, RFA_FLR, 2); |
2142 | status += MXL_ControlWrite(fe, RFA_CEIL, 13); | 2024 | status += MXL_ControlWrite(fe, RFA_CEIL, 13); |
2143 | status += MXL_ControlWrite(fe, BB_INITSTATE_DLPF_TUNE, 1); | 2025 | status += MXL_ControlWrite(fe, BB_INITSTATE_DLPF_TUNE, 1); |
2144 | status += MXL_ControlWrite(fe, RFSYN_CHP_GAIN, 5); /* Low Zero */ | 2026 | /* Low Zero */ |
2027 | status += MXL_ControlWrite(fe, RFSYN_CHP_GAIN, 5); | ||
2028 | |||
2145 | if (state->IF_OUT <= 6280000UL) /* Low IF */ | 2029 | if (state->IF_OUT <= 6280000UL) /* Low IF */ |
2146 | status += MXL_ControlWrite(fe, BB_IQSWAP, 0); | 2030 | status += MXL_ControlWrite(fe, BB_IQSWAP, 0); |
2147 | else /* High IF */ | 2031 | else /* High IF */ |
2148 | status += MXL_ControlWrite(fe, BB_IQSWAP, 1); | 2032 | status += MXL_ControlWrite(fe, BB_IQSWAP, 1); |
2149 | } | 2033 | } |
2150 | if (state->Mod_Type == MXL_QAM) /* QAM Mode */ | 2034 | if (state->Mod_Type == MXL_QAM) /* QAM Mode */ { |
2151 | { | ||
2152 | state->Mode = MXL_DIGITAL_MODE; | 2035 | state->Mode = MXL_DIGITAL_MODE; |
2153 | 2036 | ||
2154 | /* state->AGC_Mode = 1; */ /* Single AGC Mode */ | 2037 | /* state->AGC_Mode = 1; */ /* Single AGC Mode */ |
@@ -2163,7 +2046,8 @@ u16 MXL_BlockInit(struct dvb_frontend *fe) | |||
2163 | status += MXL_ControlWrite(fe, RFA_RSSI_REFH, 5); | 2046 | status += MXL_ControlWrite(fe, RFA_RSSI_REFH, 5); |
2164 | status += MXL_ControlWrite(fe, RFA_RSSI_REF, 3); | 2047 | status += MXL_ControlWrite(fe, RFA_RSSI_REF, 3); |
2165 | status += MXL_ControlWrite(fe, RFA_RSSI_REFL, 2); | 2048 | status += MXL_ControlWrite(fe, RFA_RSSI_REFL, 2); |
2166 | status += MXL_ControlWrite(fe, RFSYN_CHP_GAIN, 3); /* change here for v2.6.5 */ | 2049 | /* change here for v2.6.5 */ |
2050 | status += MXL_ControlWrite(fe, RFSYN_CHP_GAIN, 3); | ||
2167 | 2051 | ||
2168 | if (state->IF_OUT <= 6280000UL) /* Low IF */ | 2052 | if (state->IF_OUT <= 6280000UL) /* Low IF */ |
2169 | status += MXL_ControlWrite(fe, BB_IQSWAP, 0); | 2053 | status += MXL_ControlWrite(fe, BB_IQSWAP, 0); |
@@ -2183,7 +2067,8 @@ u16 MXL_BlockInit(struct dvb_frontend *fe) | |||
2183 | status += MXL_ControlWrite(fe, SEQ_EXTDCCAL, 1); | 2067 | status += MXL_ControlWrite(fe, SEQ_EXTDCCAL, 1); |
2184 | status += MXL_ControlWrite(fe, AGC_EN_RSSI, 0); | 2068 | status += MXL_ControlWrite(fe, AGC_EN_RSSI, 0); |
2185 | status += MXL_ControlWrite(fe, RFA_ENCLKRFAGC, 1); | 2069 | status += MXL_ControlWrite(fe, RFA_ENCLKRFAGC, 1); |
2186 | status += MXL_ControlWrite(fe, AGC_IF, 1); /* change for 2.6.3 */ | 2070 | /* change for 2.6.3 */ |
2071 | status += MXL_ControlWrite(fe, AGC_IF, 1); | ||
2187 | status += MXL_ControlWrite(fe, AGC_RF, 15); | 2072 | status += MXL_ControlWrite(fe, AGC_RF, 15); |
2188 | status += MXL_ControlWrite(fe, BB_IQSWAP, 1); | 2073 | status += MXL_ControlWrite(fe, BB_IQSWAP, 1); |
2189 | } | 2074 | } |
@@ -2207,7 +2092,7 @@ u16 MXL_BlockInit(struct dvb_frontend *fe) | |||
2207 | } | 2092 | } |
2208 | 2093 | ||
2209 | /* RSSI disable */ | 2094 | /* RSSI disable */ |
2210 | if(state->EN_RSSI == 0) { | 2095 | if (state->EN_RSSI == 0) { |
2211 | status += MXL_ControlWrite(fe, SEQ_EXTSYNTHCALIF, 1); | 2096 | status += MXL_ControlWrite(fe, SEQ_EXTSYNTHCALIF, 1); |
2212 | status += MXL_ControlWrite(fe, SEQ_EXTDCCAL, 1); | 2097 | status += MXL_ControlWrite(fe, SEQ_EXTDCCAL, 1); |
2213 | status += MXL_ControlWrite(fe, AGC_EN_RSSI, 0); | 2098 | status += MXL_ControlWrite(fe, AGC_EN_RSSI, 0); |
@@ -2217,34 +2102,10 @@ u16 MXL_BlockInit(struct dvb_frontend *fe) | |||
2217 | return status; | 2102 | return status; |
2218 | } | 2103 | } |
2219 | 2104 | ||
2220 | /////////////////////////////////////////////////////////////////////////////// | ||
2221 | // // | ||
2222 | // Function: MXL_IFSynthInit // | ||
2223 | // // | ||
2224 | // Description: Tuner IF Synthesizer related register initialization // | ||
2225 | // // | ||
2226 | // Globals: // | ||
2227 | // NONE // | ||
2228 | // // | ||
2229 | // Functions used: // | ||
2230 | // Tuner_struct: structure defined at higher level // | ||
2231 | // // | ||
2232 | // Inputs: // | ||
2233 | // Tuner : Tuner structure defined at higher level // | ||
2234 | // // | ||
2235 | // Outputs: // | ||
2236 | // Tuner // | ||
2237 | // // | ||
2238 | // Return: // | ||
2239 | // 0 : Successful // | ||
2240 | // > 0 : Failed // | ||
2241 | // // | ||
2242 | /////////////////////////////////////////////////////////////////////////////// | ||
2243 | u16 MXL_IFSynthInit(struct dvb_frontend *fe) | 2105 | u16 MXL_IFSynthInit(struct dvb_frontend *fe) |
2244 | { | 2106 | { |
2245 | struct mxl5005s_state *state = fe->tuner_priv; | 2107 | struct mxl5005s_state *state = fe->tuner_priv; |
2246 | u16 status = 0 ; | 2108 | u16 status = 0 ; |
2247 | // Declare Local Variables | ||
2248 | u32 Fref = 0 ; | 2109 | u32 Fref = 0 ; |
2249 | u32 Kdbl, intModVal ; | 2110 | u32 Kdbl, intModVal ; |
2250 | u32 fracModVal ; | 2111 | u32 fracModVal ; |
@@ -2255,268 +2116,207 @@ u16 MXL_IFSynthInit(struct dvb_frontend *fe) | |||
2255 | if (state->Fxtal > 16000000UL && state->Fxtal <= 32000000UL) | 2116 | if (state->Fxtal > 16000000UL && state->Fxtal <= 32000000UL) |
2256 | Kdbl = 1 ; | 2117 | Kdbl = 1 ; |
2257 | 2118 | ||
2258 | // | 2119 | /* IF Synthesizer Control */ |
2259 | // IF Synthesizer Control | 2120 | if (state->Mode == 0 && state->IF_Mode == 1) /* Analog Low IF mode */ { |
2260 | // | ||
2261 | if (state->Mode == 0 && state->IF_Mode == 1) // Analog Low IF mode | ||
2262 | { | ||
2263 | if (state->IF_LO == 41000000UL) { | 2121 | if (state->IF_LO == 41000000UL) { |
2264 | status += MXL_ControlWrite(fe, IF_DIVVAL, 0x08) ; | 2122 | status += MXL_ControlWrite(fe, IF_DIVVAL, 0x08); |
2265 | status += MXL_ControlWrite(fe, IF_VCO_BIAS, 0x0C) ; | 2123 | status += MXL_ControlWrite(fe, IF_VCO_BIAS, 0x0C); |
2266 | Fref = 328000000UL ; | 2124 | Fref = 328000000UL ; |
2267 | } | 2125 | } |
2268 | if (state->IF_LO == 47000000UL) { | 2126 | if (state->IF_LO == 47000000UL) { |
2269 | status += MXL_ControlWrite(fe, IF_DIVVAL, 0x08) ; | 2127 | status += MXL_ControlWrite(fe, IF_DIVVAL, 0x08); |
2270 | status += MXL_ControlWrite(fe, IF_VCO_BIAS, 0x08) ; | 2128 | status += MXL_ControlWrite(fe, IF_VCO_BIAS, 0x08); |
2271 | Fref = 376000000UL ; | 2129 | Fref = 376000000UL ; |
2272 | } | 2130 | } |
2273 | if (state->IF_LO == 54000000UL) { | 2131 | if (state->IF_LO == 54000000UL) { |
2274 | status += MXL_ControlWrite(fe, IF_DIVVAL, 0x10) ; | 2132 | status += MXL_ControlWrite(fe, IF_DIVVAL, 0x10); |
2275 | status += MXL_ControlWrite(fe, IF_VCO_BIAS, 0x0C) ; | 2133 | status += MXL_ControlWrite(fe, IF_VCO_BIAS, 0x0C); |
2276 | Fref = 324000000UL ; | 2134 | Fref = 324000000UL ; |
2277 | } | 2135 | } |
2278 | if (state->IF_LO == 60000000UL) { | 2136 | if (state->IF_LO == 60000000UL) { |
2279 | status += MXL_ControlWrite(fe, IF_DIVVAL, 0x10) ; | 2137 | status += MXL_ControlWrite(fe, IF_DIVVAL, 0x10); |
2280 | status += MXL_ControlWrite(fe, IF_VCO_BIAS, 0x08) ; | 2138 | status += MXL_ControlWrite(fe, IF_VCO_BIAS, 0x08); |
2281 | Fref = 360000000UL ; | 2139 | Fref = 360000000UL ; |
2282 | } | 2140 | } |
2283 | if (state->IF_LO == 39250000UL) { | 2141 | if (state->IF_LO == 39250000UL) { |
2284 | status += MXL_ControlWrite(fe, IF_DIVVAL, 0x08) ; | 2142 | status += MXL_ControlWrite(fe, IF_DIVVAL, 0x08); |
2285 | status += MXL_ControlWrite(fe, IF_VCO_BIAS, 0x0C) ; | 2143 | status += MXL_ControlWrite(fe, IF_VCO_BIAS, 0x0C); |
2286 | Fref = 314000000UL ; | 2144 | Fref = 314000000UL ; |
2287 | } | 2145 | } |
2288 | if (state->IF_LO == 39650000UL) { | 2146 | if (state->IF_LO == 39650000UL) { |
2289 | status += MXL_ControlWrite(fe, IF_DIVVAL, 0x08) ; | 2147 | status += MXL_ControlWrite(fe, IF_DIVVAL, 0x08); |
2290 | status += MXL_ControlWrite(fe, IF_VCO_BIAS, 0x0C) ; | 2148 | status += MXL_ControlWrite(fe, IF_VCO_BIAS, 0x0C); |
2291 | Fref = 317200000UL ; | 2149 | Fref = 317200000UL ; |
2292 | } | 2150 | } |
2293 | if (state->IF_LO == 40150000UL) { | 2151 | if (state->IF_LO == 40150000UL) { |
2294 | status += MXL_ControlWrite(fe, IF_DIVVAL, 0x08) ; | 2152 | status += MXL_ControlWrite(fe, IF_DIVVAL, 0x08); |
2295 | status += MXL_ControlWrite(fe, IF_VCO_BIAS, 0x0C) ; | 2153 | status += MXL_ControlWrite(fe, IF_VCO_BIAS, 0x0C); |
2296 | Fref = 321200000UL ; | 2154 | Fref = 321200000UL ; |
2297 | } | 2155 | } |
2298 | if (state->IF_LO == 40650000UL) { | 2156 | if (state->IF_LO == 40650000UL) { |
2299 | status += MXL_ControlWrite(fe, IF_DIVVAL, 0x08) ; | 2157 | status += MXL_ControlWrite(fe, IF_DIVVAL, 0x08); |
2300 | status += MXL_ControlWrite(fe, IF_VCO_BIAS, 0x0C) ; | 2158 | status += MXL_ControlWrite(fe, IF_VCO_BIAS, 0x0C); |
2301 | Fref = 325200000UL ; | 2159 | Fref = 325200000UL ; |
2302 | } | 2160 | } |
2303 | } | 2161 | } |
2304 | 2162 | ||
2305 | if (state->Mode || (state->Mode == 0 && state->IF_Mode == 0)) | 2163 | if (state->Mode || (state->Mode == 0 && state->IF_Mode == 0)) { |
2306 | { | ||
2307 | if (state->IF_LO == 57000000UL) { | 2164 | if (state->IF_LO == 57000000UL) { |
2308 | status += MXL_ControlWrite(fe, IF_DIVVAL, 0x10) ; | 2165 | status += MXL_ControlWrite(fe, IF_DIVVAL, 0x10); |
2309 | status += MXL_ControlWrite(fe, IF_VCO_BIAS, 0x08) ; | 2166 | status += MXL_ControlWrite(fe, IF_VCO_BIAS, 0x08); |
2310 | Fref = 342000000UL ; | 2167 | Fref = 342000000UL ; |
2311 | } | 2168 | } |
2312 | if (state->IF_LO == 44000000UL) { | 2169 | if (state->IF_LO == 44000000UL) { |
2313 | status += MXL_ControlWrite(fe, IF_DIVVAL, 0x08) ; | 2170 | status += MXL_ControlWrite(fe, IF_DIVVAL, 0x08); |
2314 | status += MXL_ControlWrite(fe, IF_VCO_BIAS, 0x08) ; | 2171 | status += MXL_ControlWrite(fe, IF_VCO_BIAS, 0x08); |
2315 | Fref = 352000000UL ; | 2172 | Fref = 352000000UL ; |
2316 | } | 2173 | } |
2317 | if (state->IF_LO == 43750000UL) { | 2174 | if (state->IF_LO == 43750000UL) { |
2318 | status += MXL_ControlWrite(fe, IF_DIVVAL, 0x08) ; | 2175 | status += MXL_ControlWrite(fe, IF_DIVVAL, 0x08); |
2319 | status += MXL_ControlWrite(fe, IF_VCO_BIAS, 0x08) ; | 2176 | status += MXL_ControlWrite(fe, IF_VCO_BIAS, 0x08); |
2320 | Fref = 350000000UL ; | 2177 | Fref = 350000000UL ; |
2321 | } | 2178 | } |
2322 | if (state->IF_LO == 36650000UL) { | 2179 | if (state->IF_LO == 36650000UL) { |
2323 | status += MXL_ControlWrite(fe, IF_DIVVAL, 0x04) ; | 2180 | status += MXL_ControlWrite(fe, IF_DIVVAL, 0x04); |
2324 | status += MXL_ControlWrite(fe, IF_VCO_BIAS, 0x08) ; | 2181 | status += MXL_ControlWrite(fe, IF_VCO_BIAS, 0x08); |
2325 | Fref = 366500000UL ; | 2182 | Fref = 366500000UL ; |
2326 | } | 2183 | } |
2327 | if (state->IF_LO == 36150000UL) { | 2184 | if (state->IF_LO == 36150000UL) { |
2328 | status += MXL_ControlWrite(fe, IF_DIVVAL, 0x04) ; | 2185 | status += MXL_ControlWrite(fe, IF_DIVVAL, 0x04); |
2329 | status += MXL_ControlWrite(fe, IF_VCO_BIAS, 0x08) ; | 2186 | status += MXL_ControlWrite(fe, IF_VCO_BIAS, 0x08); |
2330 | Fref = 361500000UL ; | 2187 | Fref = 361500000UL ; |
2331 | } | 2188 | } |
2332 | if (state->IF_LO == 36000000UL) { | 2189 | if (state->IF_LO == 36000000UL) { |
2333 | status += MXL_ControlWrite(fe, IF_DIVVAL, 0x04) ; | 2190 | status += MXL_ControlWrite(fe, IF_DIVVAL, 0x04); |
2334 | status += MXL_ControlWrite(fe, IF_VCO_BIAS, 0x08) ; | 2191 | status += MXL_ControlWrite(fe, IF_VCO_BIAS, 0x08); |
2335 | Fref = 360000000UL ; | 2192 | Fref = 360000000UL ; |
2336 | } | 2193 | } |
2337 | if (state->IF_LO == 35250000UL) { | 2194 | if (state->IF_LO == 35250000UL) { |
2338 | status += MXL_ControlWrite(fe, IF_DIVVAL, 0x04) ; | 2195 | status += MXL_ControlWrite(fe, IF_DIVVAL, 0x04); |
2339 | status += MXL_ControlWrite(fe, IF_VCO_BIAS, 0x08) ; | 2196 | status += MXL_ControlWrite(fe, IF_VCO_BIAS, 0x08); |
2340 | Fref = 352500000UL ; | 2197 | Fref = 352500000UL ; |
2341 | } | 2198 | } |
2342 | if (state->IF_LO == 34750000UL) { | 2199 | if (state->IF_LO == 34750000UL) { |
2343 | status += MXL_ControlWrite(fe, IF_DIVVAL, 0x04) ; | 2200 | status += MXL_ControlWrite(fe, IF_DIVVAL, 0x04); |
2344 | status += MXL_ControlWrite(fe, IF_VCO_BIAS, 0x08) ; | 2201 | status += MXL_ControlWrite(fe, IF_VCO_BIAS, 0x08); |
2345 | Fref = 347500000UL ; | 2202 | Fref = 347500000UL ; |
2346 | } | 2203 | } |
2347 | if (state->IF_LO == 6280000UL) { | 2204 | if (state->IF_LO == 6280000UL) { |
2348 | status += MXL_ControlWrite(fe, IF_DIVVAL, 0x07) ; | 2205 | status += MXL_ControlWrite(fe, IF_DIVVAL, 0x07); |
2349 | status += MXL_ControlWrite(fe, IF_VCO_BIAS, 0x08) ; | 2206 | status += MXL_ControlWrite(fe, IF_VCO_BIAS, 0x08); |
2350 | Fref = 376800000UL ; | 2207 | Fref = 376800000UL ; |
2351 | } | 2208 | } |
2352 | if (state->IF_LO == 5000000UL) { | 2209 | if (state->IF_LO == 5000000UL) { |
2353 | status += MXL_ControlWrite(fe, IF_DIVVAL, 0x09) ; | 2210 | status += MXL_ControlWrite(fe, IF_DIVVAL, 0x09); |
2354 | status += MXL_ControlWrite(fe, IF_VCO_BIAS, 0x08) ; | 2211 | status += MXL_ControlWrite(fe, IF_VCO_BIAS, 0x08); |
2355 | Fref = 360000000UL ; | 2212 | Fref = 360000000UL ; |
2356 | } | 2213 | } |
2357 | if (state->IF_LO == 4500000UL) { | 2214 | if (state->IF_LO == 4500000UL) { |
2358 | status += MXL_ControlWrite(fe, IF_DIVVAL, 0x06) ; | 2215 | status += MXL_ControlWrite(fe, IF_DIVVAL, 0x06); |
2359 | status += MXL_ControlWrite(fe, IF_VCO_BIAS, 0x08) ; | 2216 | status += MXL_ControlWrite(fe, IF_VCO_BIAS, 0x08); |
2360 | Fref = 360000000UL ; | 2217 | Fref = 360000000UL ; |
2361 | } | 2218 | } |
2362 | if (state->IF_LO == 4570000UL) { | 2219 | if (state->IF_LO == 4570000UL) { |
2363 | status += MXL_ControlWrite(fe, IF_DIVVAL, 0x06) ; | 2220 | status += MXL_ControlWrite(fe, IF_DIVVAL, 0x06); |
2364 | status += MXL_ControlWrite(fe, IF_VCO_BIAS, 0x08) ; | 2221 | status += MXL_ControlWrite(fe, IF_VCO_BIAS, 0x08); |
2365 | Fref = 365600000UL ; | 2222 | Fref = 365600000UL ; |
2366 | } | 2223 | } |
2367 | if (state->IF_LO == 4000000UL) { | 2224 | if (state->IF_LO == 4000000UL) { |
2368 | status += MXL_ControlWrite(fe, IF_DIVVAL, 0x05) ; | 2225 | status += MXL_ControlWrite(fe, IF_DIVVAL, 0x05); |
2369 | status += MXL_ControlWrite(fe, IF_VCO_BIAS, 0x08) ; | 2226 | status += MXL_ControlWrite(fe, IF_VCO_BIAS, 0x08); |
2370 | Fref = 360000000UL ; | 2227 | Fref = 360000000UL ; |
2371 | } | 2228 | } |
2372 | if (state->IF_LO == 57400000UL) | 2229 | if (state->IF_LO == 57400000UL) { |
2373 | { | 2230 | status += MXL_ControlWrite(fe, IF_DIVVAL, 0x10); |
2374 | status += MXL_ControlWrite(fe, IF_DIVVAL, 0x10) ; | 2231 | status += MXL_ControlWrite(fe, IF_VCO_BIAS, 0x08); |
2375 | status += MXL_ControlWrite(fe, IF_VCO_BIAS, 0x08) ; | ||
2376 | Fref = 344400000UL ; | 2232 | Fref = 344400000UL ; |
2377 | } | 2233 | } |
2378 | if (state->IF_LO == 44400000UL) | 2234 | if (state->IF_LO == 44400000UL) { |
2379 | { | 2235 | status += MXL_ControlWrite(fe, IF_DIVVAL, 0x08); |
2380 | status += MXL_ControlWrite(fe, IF_DIVVAL, 0x08) ; | 2236 | status += MXL_ControlWrite(fe, IF_VCO_BIAS, 0x08); |
2381 | status += MXL_ControlWrite(fe, IF_VCO_BIAS, 0x08) ; | ||
2382 | Fref = 355200000UL ; | 2237 | Fref = 355200000UL ; |
2383 | } | 2238 | } |
2384 | if (state->IF_LO == 44150000UL) | 2239 | if (state->IF_LO == 44150000UL) { |
2385 | { | 2240 | status += MXL_ControlWrite(fe, IF_DIVVAL, 0x08); |
2386 | status += MXL_ControlWrite(fe, IF_DIVVAL, 0x08) ; | 2241 | status += MXL_ControlWrite(fe, IF_VCO_BIAS, 0x08); |
2387 | status += MXL_ControlWrite(fe, IF_VCO_BIAS, 0x08) ; | ||
2388 | Fref = 353200000UL ; | 2242 | Fref = 353200000UL ; |
2389 | } | 2243 | } |
2390 | if (state->IF_LO == 37050000UL) | 2244 | if (state->IF_LO == 37050000UL) { |
2391 | { | 2245 | status += MXL_ControlWrite(fe, IF_DIVVAL, 0x04); |
2392 | status += MXL_ControlWrite(fe, IF_DIVVAL, 0x04) ; | 2246 | status += MXL_ControlWrite(fe, IF_VCO_BIAS, 0x08); |
2393 | status += MXL_ControlWrite(fe, IF_VCO_BIAS, 0x08) ; | ||
2394 | Fref = 370500000UL ; | 2247 | Fref = 370500000UL ; |
2395 | } | 2248 | } |
2396 | if (state->IF_LO == 36550000UL) | 2249 | if (state->IF_LO == 36550000UL) { |
2397 | { | 2250 | status += MXL_ControlWrite(fe, IF_DIVVAL, 0x04); |
2398 | status += MXL_ControlWrite(fe, IF_DIVVAL, 0x04) ; | 2251 | status += MXL_ControlWrite(fe, IF_VCO_BIAS, 0x08); |
2399 | status += MXL_ControlWrite(fe, IF_VCO_BIAS, 0x08) ; | ||
2400 | Fref = 365500000UL ; | 2252 | Fref = 365500000UL ; |
2401 | } | 2253 | } |
2402 | if (state->IF_LO == 36125000UL) { | 2254 | if (state->IF_LO == 36125000UL) { |
2403 | status += MXL_ControlWrite(fe, IF_DIVVAL, 0x04) ; | 2255 | status += MXL_ControlWrite(fe, IF_DIVVAL, 0x04); |
2404 | status += MXL_ControlWrite(fe, IF_VCO_BIAS, 0x08) ; | 2256 | status += MXL_ControlWrite(fe, IF_VCO_BIAS, 0x08); |
2405 | Fref = 361250000UL ; | 2257 | Fref = 361250000UL ; |
2406 | } | 2258 | } |
2407 | if (state->IF_LO == 6000000UL) { | 2259 | if (state->IF_LO == 6000000UL) { |
2408 | status += MXL_ControlWrite(fe, IF_DIVVAL, 0x07) ; | 2260 | status += MXL_ControlWrite(fe, IF_DIVVAL, 0x07); |
2409 | status += MXL_ControlWrite(fe, IF_VCO_BIAS, 0x08) ; | 2261 | status += MXL_ControlWrite(fe, IF_VCO_BIAS, 0x08); |
2410 | Fref = 360000000UL ; | 2262 | Fref = 360000000UL ; |
2411 | } | 2263 | } |
2412 | if (state->IF_LO == 5400000UL) | 2264 | if (state->IF_LO == 5400000UL) { |
2413 | { | 2265 | status += MXL_ControlWrite(fe, IF_DIVVAL, 0x07); |
2414 | status += MXL_ControlWrite(fe, IF_DIVVAL, 0x07) ; | 2266 | status += MXL_ControlWrite(fe, IF_VCO_BIAS, 0x0C); |
2415 | status += MXL_ControlWrite(fe, IF_VCO_BIAS, 0x0C) ; | ||
2416 | Fref = 324000000UL ; | 2267 | Fref = 324000000UL ; |
2417 | } | 2268 | } |
2418 | if (state->IF_LO == 5380000UL) { | 2269 | if (state->IF_LO == 5380000UL) { |
2419 | printk("%s() doing 5.38\n", __func__); | 2270 | status += MXL_ControlWrite(fe, IF_DIVVAL, 0x07); |
2420 | status += MXL_ControlWrite(fe, IF_DIVVAL, 0x07) ; | 2271 | status += MXL_ControlWrite(fe, IF_VCO_BIAS, 0x0C); |
2421 | status += MXL_ControlWrite(fe, IF_VCO_BIAS, 0x0C) ; | ||
2422 | Fref = 322800000UL ; | 2272 | Fref = 322800000UL ; |
2423 | } | 2273 | } |
2424 | if (state->IF_LO == 5200000UL) { | 2274 | if (state->IF_LO == 5200000UL) { |
2425 | status += MXL_ControlWrite(fe, IF_DIVVAL, 0x09) ; | 2275 | status += MXL_ControlWrite(fe, IF_DIVVAL, 0x09); |
2426 | status += MXL_ControlWrite(fe, IF_VCO_BIAS, 0x08) ; | 2276 | status += MXL_ControlWrite(fe, IF_VCO_BIAS, 0x08); |
2427 | Fref = 374400000UL ; | 2277 | Fref = 374400000UL ; |
2428 | } | 2278 | } |
2429 | if (state->IF_LO == 4900000UL) | 2279 | if (state->IF_LO == 4900000UL) { |
2430 | { | 2280 | status += MXL_ControlWrite(fe, IF_DIVVAL, 0x09); |
2431 | status += MXL_ControlWrite(fe, IF_DIVVAL, 0x09) ; | 2281 | status += MXL_ControlWrite(fe, IF_VCO_BIAS, 0x08); |
2432 | status += MXL_ControlWrite(fe, IF_VCO_BIAS, 0x08) ; | ||
2433 | Fref = 352800000UL ; | 2282 | Fref = 352800000UL ; |
2434 | } | 2283 | } |
2435 | if (state->IF_LO == 4400000UL) | 2284 | if (state->IF_LO == 4400000UL) { |
2436 | { | 2285 | status += MXL_ControlWrite(fe, IF_DIVVAL, 0x06); |
2437 | status += MXL_ControlWrite(fe, IF_DIVVAL, 0x06) ; | 2286 | status += MXL_ControlWrite(fe, IF_VCO_BIAS, 0x08); |
2438 | status += MXL_ControlWrite(fe, IF_VCO_BIAS, 0x08) ; | ||
2439 | Fref = 352000000UL ; | 2287 | Fref = 352000000UL ; |
2440 | } | 2288 | } |
2441 | if (state->IF_LO == 4063000UL) //add for 2.6.8 | 2289 | if (state->IF_LO == 4063000UL) /* add for 2.6.8 */ { |
2442 | { | 2290 | status += MXL_ControlWrite(fe, IF_DIVVAL, 0x05); |
2443 | status += MXL_ControlWrite(fe, IF_DIVVAL, 0x05) ; | 2291 | status += MXL_ControlWrite(fe, IF_VCO_BIAS, 0x08); |
2444 | status += MXL_ControlWrite(fe, IF_VCO_BIAS, 0x08) ; | ||
2445 | Fref = 365670000UL ; | 2292 | Fref = 365670000UL ; |
2446 | } | 2293 | } |
2447 | } | 2294 | } |
2448 | // CHCAL_INT_MOD_IF | 2295 | /* CHCAL_INT_MOD_IF */ |
2449 | // CHCAL_FRAC_MOD_IF | 2296 | /* CHCAL_FRAC_MOD_IF */ |
2450 | intModVal = Fref / (state->Fxtal * Kdbl/2) ; | 2297 | intModVal = Fref / (state->Fxtal * Kdbl/2); |
2451 | status += MXL_ControlWrite(fe, CHCAL_INT_MOD_IF, intModVal ) ; | 2298 | status += MXL_ControlWrite(fe, CHCAL_INT_MOD_IF, intModVal); |
2299 | |||
2300 | fracModVal = (2<<15)*(Fref/1000 - (state->Fxtal/1000 * Kdbl/2) * | ||
2301 | intModVal); | ||
2452 | 2302 | ||
2453 | fracModVal = (2<<15)*(Fref/1000 - (state->Fxtal/1000 * Kdbl/2) * intModVal); | 2303 | fracModVal = fracModVal / ((state->Fxtal * Kdbl/2)/1000); |
2454 | fracModVal = fracModVal / ((state->Fxtal * Kdbl/2)/1000) ; | 2304 | status += MXL_ControlWrite(fe, CHCAL_FRAC_MOD_IF, fracModVal); |
2455 | status += MXL_ControlWrite(fe, CHCAL_FRAC_MOD_IF, fracModVal) ; | ||
2456 | 2305 | ||
2457 | return status ; | 2306 | return status ; |
2458 | } | 2307 | } |
2459 | 2308 | ||
2460 | /////////////////////////////////////////////////////////////////////////////// | ||
2461 | // // | ||
2462 | // Function: MXL_GetXtalInt // | ||
2463 | // // | ||
2464 | // Description: return the Crystal Integration Value for // | ||
2465 | // TG_VCO_BIAS calculation // | ||
2466 | // // | ||
2467 | // Globals: // | ||
2468 | // NONE // | ||
2469 | // // | ||
2470 | // Functions used: // | ||
2471 | // NONE // | ||
2472 | // // | ||
2473 | // Inputs: // | ||
2474 | // Crystal Frequency Value in Hz // | ||
2475 | // // | ||
2476 | // Outputs: // | ||
2477 | // Calculated Crystal Frequency Integration Value // | ||
2478 | // // | ||
2479 | // Return: // | ||
2480 | // 0 : Successful // | ||
2481 | // > 0 : Failed // | ||
2482 | // // | ||
2483 | /////////////////////////////////////////////////////////////////////////////// | ||
2484 | u32 MXL_GetXtalInt(u32 Xtal_Freq) | 2309 | u32 MXL_GetXtalInt(u32 Xtal_Freq) |
2485 | { | 2310 | { |
2486 | if ((Xtal_Freq % 1000000) == 0) | 2311 | if ((Xtal_Freq % 1000000) == 0) |
2487 | return (Xtal_Freq / 10000) ; | 2312 | return (Xtal_Freq / 10000); |
2488 | else | 2313 | else |
2489 | return (((Xtal_Freq / 1000000) + 1)*100) ; | 2314 | return (((Xtal_Freq / 1000000) + 1)*100); |
2490 | } | 2315 | } |
2491 | 2316 | ||
2492 | /////////////////////////////////////////////////////////////////////////////// | ||
2493 | // // | ||
2494 | // Function: MXL5005_TuneRF // | ||
2495 | // // | ||
2496 | // Description: Set control names to tune to requested RF_IN frequency // | ||
2497 | // // | ||
2498 | // Globals: // | ||
2499 | // None // | ||
2500 | // // | ||
2501 | // Functions used: // | ||
2502 | // MXL_SynthRFTGLO_Calc // | ||
2503 | // MXL5005_ControlWrite // | ||
2504 | // MXL_GetXtalInt // | ||
2505 | // // | ||
2506 | // Inputs: // | ||
2507 | // Tuner : Tuner structure defined at higher level // | ||
2508 | // // | ||
2509 | // Outputs: // | ||
2510 | // Tuner // | ||
2511 | // // | ||
2512 | // Return: // | ||
2513 | // 0 : Successful // | ||
2514 | // 1 : Unsuccessful // | ||
2515 | /////////////////////////////////////////////////////////////////////////////// | ||
2516 | u16 MXL_TuneRF(struct dvb_frontend *fe, u32 RF_Freq) | 2317 | u16 MXL_TuneRF(struct dvb_frontend *fe, u32 RF_Freq) |
2517 | { | 2318 | { |
2518 | struct mxl5005s_state *state = fe->tuner_priv; | 2319 | struct mxl5005s_state *state = fe->tuner_priv; |
2519 | // Declare Local Variables | ||
2520 | u16 status = 0; | 2320 | u16 status = 0; |
2521 | u32 divider_val, E3, E4, E5, E5A; | 2321 | u32 divider_val, E3, E4, E5, E5A; |
2522 | u32 Fmax, Fmin, FmaxBin, FminBin; | 2322 | u32 Fmax, Fmin, FmaxBin, FminBin; |
@@ -2527,8 +2327,6 @@ u16 MXL_TuneRF(struct dvb_frontend *fe, u32 RF_Freq) | |||
2527 | 2327 | ||
2528 | u32 Fref_TG; | 2328 | u32 Fref_TG; |
2529 | u32 Fvco; | 2329 | u32 Fvco; |
2530 | // u32 temp; | ||
2531 | |||
2532 | 2330 | ||
2533 | Xtal_Int = MXL_GetXtalInt(state->Fxtal); | 2331 | Xtal_Int = MXL_GetXtalInt(state->Fxtal); |
2534 | 2332 | ||
@@ -2541,21 +2339,19 @@ u16 MXL_TuneRF(struct dvb_frontend *fe, u32 RF_Freq) | |||
2541 | if (state->Fxtal > 22000000 && state->Fxtal <= 32000000) | 2339 | if (state->Fxtal > 22000000 && state->Fxtal <= 32000000) |
2542 | Kdbl_RF = 1; | 2340 | Kdbl_RF = 1; |
2543 | 2341 | ||
2544 | // | 2342 | /* Downconverter Controls |
2545 | // Downconverter Controls | 2343 | * Look-Up Table Implementation for: |
2546 | // | 2344 | * DN_POLY |
2547 | // Look-Up Table Implementation for: | 2345 | * DN_RFGAIN |
2548 | // DN_POLY | 2346 | * DN_CAP_RFLPF |
2549 | // DN_RFGAIN | 2347 | * DN_EN_VHFUHFBAR |
2550 | // DN_CAP_RFLPF | 2348 | * DN_GAIN_ADJUST |
2551 | // DN_EN_VHFUHFBAR | 2349 | * Change the boundary reference from RF_IN to RF_LO |
2552 | // DN_GAIN_ADJUST | 2350 | */ |
2553 | // Change the boundary reference from RF_IN to RF_LO | 2351 | if (state->RF_LO < 40000000UL) |
2554 | if (state->RF_LO < 40000000UL) { | ||
2555 | return -1; | 2352 | return -1; |
2556 | } | 2353 | |
2557 | if (state->RF_LO >= 40000000UL && state->RF_LO <= 75000000UL) { | 2354 | if (state->RF_LO >= 40000000UL && state->RF_LO <= 75000000UL) { |
2558 | // Look-Up Table implementation | ||
2559 | status += MXL_ControlWrite(fe, DN_POLY, 2); | 2355 | status += MXL_ControlWrite(fe, DN_POLY, 2); |
2560 | status += MXL_ControlWrite(fe, DN_RFGAIN, 3); | 2356 | status += MXL_ControlWrite(fe, DN_RFGAIN, 3); |
2561 | status += MXL_ControlWrite(fe, DN_CAP_RFLPF, 423); | 2357 | status += MXL_ControlWrite(fe, DN_CAP_RFLPF, 423); |
@@ -2563,7 +2359,6 @@ u16 MXL_TuneRF(struct dvb_frontend *fe, u32 RF_Freq) | |||
2563 | status += MXL_ControlWrite(fe, DN_GAIN_ADJUST, 1); | 2359 | status += MXL_ControlWrite(fe, DN_GAIN_ADJUST, 1); |
2564 | } | 2360 | } |
2565 | if (state->RF_LO > 75000000UL && state->RF_LO <= 100000000UL) { | 2361 | if (state->RF_LO > 75000000UL && state->RF_LO <= 100000000UL) { |
2566 | // Look-Up Table implementation | ||
2567 | status += MXL_ControlWrite(fe, DN_POLY, 3); | 2362 | status += MXL_ControlWrite(fe, DN_POLY, 3); |
2568 | status += MXL_ControlWrite(fe, DN_RFGAIN, 3); | 2363 | status += MXL_ControlWrite(fe, DN_RFGAIN, 3); |
2569 | status += MXL_ControlWrite(fe, DN_CAP_RFLPF, 222); | 2364 | status += MXL_ControlWrite(fe, DN_CAP_RFLPF, 222); |
@@ -2571,7 +2366,6 @@ u16 MXL_TuneRF(struct dvb_frontend *fe, u32 RF_Freq) | |||
2571 | status += MXL_ControlWrite(fe, DN_GAIN_ADJUST, 1); | 2366 | status += MXL_ControlWrite(fe, DN_GAIN_ADJUST, 1); |
2572 | } | 2367 | } |
2573 | if (state->RF_LO > 100000000UL && state->RF_LO <= 150000000UL) { | 2368 | if (state->RF_LO > 100000000UL && state->RF_LO <= 150000000UL) { |
2574 | // Look-Up Table implementation | ||
2575 | status += MXL_ControlWrite(fe, DN_POLY, 3); | 2369 | status += MXL_ControlWrite(fe, DN_POLY, 3); |
2576 | status += MXL_ControlWrite(fe, DN_RFGAIN, 3); | 2370 | status += MXL_ControlWrite(fe, DN_RFGAIN, 3); |
2577 | status += MXL_ControlWrite(fe, DN_CAP_RFLPF, 147); | 2371 | status += MXL_ControlWrite(fe, DN_CAP_RFLPF, 147); |
@@ -2579,7 +2373,6 @@ u16 MXL_TuneRF(struct dvb_frontend *fe, u32 RF_Freq) | |||
2579 | status += MXL_ControlWrite(fe, DN_GAIN_ADJUST, 2); | 2373 | status += MXL_ControlWrite(fe, DN_GAIN_ADJUST, 2); |
2580 | } | 2374 | } |
2581 | if (state->RF_LO > 150000000UL && state->RF_LO <= 200000000UL) { | 2375 | if (state->RF_LO > 150000000UL && state->RF_LO <= 200000000UL) { |
2582 | // Look-Up Table implementation | ||
2583 | status += MXL_ControlWrite(fe, DN_POLY, 3); | 2376 | status += MXL_ControlWrite(fe, DN_POLY, 3); |
2584 | status += MXL_ControlWrite(fe, DN_RFGAIN, 3); | 2377 | status += MXL_ControlWrite(fe, DN_RFGAIN, 3); |
2585 | status += MXL_ControlWrite(fe, DN_CAP_RFLPF, 9); | 2378 | status += MXL_ControlWrite(fe, DN_CAP_RFLPF, 9); |
@@ -2587,34 +2380,31 @@ u16 MXL_TuneRF(struct dvb_frontend *fe, u32 RF_Freq) | |||
2587 | status += MXL_ControlWrite(fe, DN_GAIN_ADJUST, 2); | 2380 | status += MXL_ControlWrite(fe, DN_GAIN_ADJUST, 2); |
2588 | } | 2381 | } |
2589 | if (state->RF_LO > 200000000UL && state->RF_LO <= 300000000UL) { | 2382 | if (state->RF_LO > 200000000UL && state->RF_LO <= 300000000UL) { |
2590 | // Look-Up Table implementation | 2383 | status += MXL_ControlWrite(fe, DN_POLY, 3); |
2591 | status += MXL_ControlWrite(fe, DN_POLY, 3) ; | 2384 | status += MXL_ControlWrite(fe, DN_RFGAIN, 3); |
2592 | status += MXL_ControlWrite(fe, DN_RFGAIN, 3) ; | 2385 | status += MXL_ControlWrite(fe, DN_CAP_RFLPF, 0); |
2593 | status += MXL_ControlWrite(fe, DN_CAP_RFLPF, 0) ; | 2386 | status += MXL_ControlWrite(fe, DN_EN_VHFUHFBAR, 1); |
2594 | status += MXL_ControlWrite(fe, DN_EN_VHFUHFBAR, 1) ; | 2387 | status += MXL_ControlWrite(fe, DN_GAIN_ADJUST, 3); |
2595 | status += MXL_ControlWrite(fe, DN_GAIN_ADJUST, 3) ; | ||
2596 | } | 2388 | } |
2597 | if (state->RF_LO > 300000000UL && state->RF_LO <= 650000000UL) { | 2389 | if (state->RF_LO > 300000000UL && state->RF_LO <= 650000000UL) { |
2598 | // Look-Up Table implementation | 2390 | status += MXL_ControlWrite(fe, DN_POLY, 3); |
2599 | status += MXL_ControlWrite(fe, DN_POLY, 3) ; | 2391 | status += MXL_ControlWrite(fe, DN_RFGAIN, 1); |
2600 | status += MXL_ControlWrite(fe, DN_RFGAIN, 1) ; | 2392 | status += MXL_ControlWrite(fe, DN_CAP_RFLPF, 0); |
2601 | status += MXL_ControlWrite(fe, DN_CAP_RFLPF, 0) ; | 2393 | status += MXL_ControlWrite(fe, DN_EN_VHFUHFBAR, 0); |
2602 | status += MXL_ControlWrite(fe, DN_EN_VHFUHFBAR, 0) ; | 2394 | status += MXL_ControlWrite(fe, DN_GAIN_ADJUST, 3); |
2603 | status += MXL_ControlWrite(fe, DN_GAIN_ADJUST, 3) ; | ||
2604 | } | 2395 | } |
2605 | if (state->RF_LO > 650000000UL && state->RF_LO <= 900000000UL) { | 2396 | if (state->RF_LO > 650000000UL && state->RF_LO <= 900000000UL) { |
2606 | // Look-Up Table implementation | 2397 | status += MXL_ControlWrite(fe, DN_POLY, 3); |
2607 | status += MXL_ControlWrite(fe, DN_POLY, 3) ; | 2398 | status += MXL_ControlWrite(fe, DN_RFGAIN, 2); |
2608 | status += MXL_ControlWrite(fe, DN_RFGAIN, 2) ; | 2399 | status += MXL_ControlWrite(fe, DN_CAP_RFLPF, 0); |
2609 | status += MXL_ControlWrite(fe, DN_CAP_RFLPF, 0) ; | 2400 | status += MXL_ControlWrite(fe, DN_EN_VHFUHFBAR, 0); |
2610 | status += MXL_ControlWrite(fe, DN_EN_VHFUHFBAR, 0) ; | 2401 | status += MXL_ControlWrite(fe, DN_GAIN_ADJUST, 3); |
2611 | status += MXL_ControlWrite(fe, DN_GAIN_ADJUST, 3) ; | ||
2612 | } | 2402 | } |
2613 | if (state->RF_LO > 900000000UL) { | 2403 | if (state->RF_LO > 900000000UL) |
2614 | return -1; | 2404 | return -1; |
2615 | } | 2405 | |
2616 | // DN_IQTNBUF_AMP | 2406 | /* DN_IQTNBUF_AMP */ |
2617 | // DN_IQTNGNBFBIAS_BST | 2407 | /* DN_IQTNGNBFBIAS_BST */ |
2618 | if (state->RF_LO >= 40000000UL && state->RF_LO <= 75000000UL) { | 2408 | if (state->RF_LO >= 40000000UL && state->RF_LO <= 75000000UL) { |
2619 | status += MXL_ControlWrite(fe, DN_IQTNBUF_AMP, 1); | 2409 | status += MXL_ControlWrite(fe, DN_IQTNBUF_AMP, 1); |
2620 | status += MXL_ControlWrite(fe, DN_IQTNGNBFBIAS_BST, 0); | 2410 | status += MXL_ControlWrite(fe, DN_IQTNGNBFBIAS_BST, 0); |
@@ -2680,18 +2470,19 @@ u16 MXL_TuneRF(struct dvb_frontend *fe, u32 RF_Freq) | |||
2680 | status += MXL_ControlWrite(fe, DN_IQTNGNBFBIAS_BST, 1); | 2470 | status += MXL_ControlWrite(fe, DN_IQTNGNBFBIAS_BST, 1); |
2681 | } | 2471 | } |
2682 | 2472 | ||
2683 | // | 2473 | /* |
2684 | // Set RF Synth and LO Path Control | 2474 | * Set RF Synth and LO Path Control |
2685 | // | 2475 | * |
2686 | // Look-Up table implementation for: | 2476 | * Look-Up table implementation for: |
2687 | // RFSYN_EN_OUTMUX | 2477 | * RFSYN_EN_OUTMUX |
2688 | // RFSYN_SEL_VCO_OUT | 2478 | * RFSYN_SEL_VCO_OUT |
2689 | // RFSYN_SEL_VCO_HI | 2479 | * RFSYN_SEL_VCO_HI |
2690 | // RFSYN_SEL_DIVM | 2480 | * RFSYN_SEL_DIVM |
2691 | // RFSYN_RF_DIV_BIAS | 2481 | * RFSYN_RF_DIV_BIAS |
2692 | // DN_SEL_FREQ | 2482 | * DN_SEL_FREQ |
2693 | // | 2483 | * |
2694 | // Set divider_val, Fmax, Fmix to use in Equations | 2484 | * Set divider_val, Fmax, Fmix to use in Equations |
2485 | */ | ||
2695 | FminBin = 28000000UL ; | 2486 | FminBin = 28000000UL ; |
2696 | FmaxBin = 42500000UL ; | 2487 | FmaxBin = 42500000UL ; |
2697 | if (state->RF_LO >= 40000000UL && state->RF_LO <= FmaxBin) { | 2488 | if (state->RF_LO >= 40000000UL && state->RF_LO <= FmaxBin) { |
@@ -2721,12 +2512,12 @@ u16 MXL_TuneRF(struct dvb_frontend *fe, u32 RF_Freq) | |||
2721 | FminBin = 56000000UL ; | 2512 | FminBin = 56000000UL ; |
2722 | FmaxBin = 85000000UL ; | 2513 | FmaxBin = 85000000UL ; |
2723 | if (state->RF_LO > FminBin && state->RF_LO <= FmaxBin) { | 2514 | if (state->RF_LO > FminBin && state->RF_LO <= FmaxBin) { |
2724 | status += MXL_ControlWrite(fe, RFSYN_EN_OUTMUX, 0) ; | 2515 | status += MXL_ControlWrite(fe, RFSYN_EN_OUTMUX, 0); |
2725 | status += MXL_ControlWrite(fe, RFSYN_SEL_VCO_OUT, 1) ; | 2516 | status += MXL_ControlWrite(fe, RFSYN_SEL_VCO_OUT, 1); |
2726 | status += MXL_ControlWrite(fe, RFSYN_SEL_VCO_HI, 0) ; | 2517 | status += MXL_ControlWrite(fe, RFSYN_SEL_VCO_HI, 0); |
2727 | status += MXL_ControlWrite(fe, RFSYN_SEL_DIVM, 0) ; | 2518 | status += MXL_ControlWrite(fe, RFSYN_SEL_DIVM, 0); |
2728 | status += MXL_ControlWrite(fe, RFSYN_RF_DIV_BIAS, 1) ; | 2519 | status += MXL_ControlWrite(fe, RFSYN_RF_DIV_BIAS, 1); |
2729 | status += MXL_ControlWrite(fe, DN_SEL_FREQ, 1) ; | 2520 | status += MXL_ControlWrite(fe, DN_SEL_FREQ, 1); |
2730 | divider_val = 32 ; | 2521 | divider_val = 32 ; |
2731 | Fmax = FmaxBin ; | 2522 | Fmax = FmaxBin ; |
2732 | Fmin = FminBin ; | 2523 | Fmin = FminBin ; |
@@ -2734,12 +2525,12 @@ u16 MXL_TuneRF(struct dvb_frontend *fe, u32 RF_Freq) | |||
2734 | FminBin = 85000000UL ; | 2525 | FminBin = 85000000UL ; |
2735 | FmaxBin = 112000000UL ; | 2526 | FmaxBin = 112000000UL ; |
2736 | if (state->RF_LO > FminBin && state->RF_LO <= FmaxBin) { | 2527 | if (state->RF_LO > FminBin && state->RF_LO <= FmaxBin) { |
2737 | status += MXL_ControlWrite(fe, RFSYN_EN_OUTMUX, 0) ; | 2528 | status += MXL_ControlWrite(fe, RFSYN_EN_OUTMUX, 0); |
2738 | status += MXL_ControlWrite(fe, RFSYN_SEL_VCO_OUT, 1) ; | 2529 | status += MXL_ControlWrite(fe, RFSYN_SEL_VCO_OUT, 1); |
2739 | status += MXL_ControlWrite(fe, RFSYN_SEL_VCO_HI, 1) ; | 2530 | status += MXL_ControlWrite(fe, RFSYN_SEL_VCO_HI, 1); |
2740 | status += MXL_ControlWrite(fe, RFSYN_SEL_DIVM, 0) ; | 2531 | status += MXL_ControlWrite(fe, RFSYN_SEL_DIVM, 0); |
2741 | status += MXL_ControlWrite(fe, RFSYN_RF_DIV_BIAS, 1) ; | 2532 | status += MXL_ControlWrite(fe, RFSYN_RF_DIV_BIAS, 1); |
2742 | status += MXL_ControlWrite(fe, DN_SEL_FREQ, 1) ; | 2533 | status += MXL_ControlWrite(fe, DN_SEL_FREQ, 1); |
2743 | divider_val = 32 ; | 2534 | divider_val = 32 ; |
2744 | Fmax = FmaxBin ; | 2535 | Fmax = FmaxBin ; |
2745 | Fmin = FminBin ; | 2536 | Fmin = FminBin ; |
@@ -2747,12 +2538,12 @@ u16 MXL_TuneRF(struct dvb_frontend *fe, u32 RF_Freq) | |||
2747 | FminBin = 112000000UL ; | 2538 | FminBin = 112000000UL ; |
2748 | FmaxBin = 170000000UL ; | 2539 | FmaxBin = 170000000UL ; |
2749 | if (state->RF_LO > FminBin && state->RF_LO <= FmaxBin) { | 2540 | if (state->RF_LO > FminBin && state->RF_LO <= FmaxBin) { |
2750 | status += MXL_ControlWrite(fe, RFSYN_EN_OUTMUX, 0) ; | 2541 | status += MXL_ControlWrite(fe, RFSYN_EN_OUTMUX, 0); |
2751 | status += MXL_ControlWrite(fe, RFSYN_SEL_VCO_OUT, 1) ; | 2542 | status += MXL_ControlWrite(fe, RFSYN_SEL_VCO_OUT, 1); |
2752 | status += MXL_ControlWrite(fe, RFSYN_SEL_VCO_HI, 0) ; | 2543 | status += MXL_ControlWrite(fe, RFSYN_SEL_VCO_HI, 0); |
2753 | status += MXL_ControlWrite(fe, RFSYN_SEL_DIVM, 0) ; | 2544 | status += MXL_ControlWrite(fe, RFSYN_SEL_DIVM, 0); |
2754 | status += MXL_ControlWrite(fe, RFSYN_RF_DIV_BIAS, 1) ; | 2545 | status += MXL_ControlWrite(fe, RFSYN_RF_DIV_BIAS, 1); |
2755 | status += MXL_ControlWrite(fe, DN_SEL_FREQ, 2) ; | 2546 | status += MXL_ControlWrite(fe, DN_SEL_FREQ, 2); |
2756 | divider_val = 16 ; | 2547 | divider_val = 16 ; |
2757 | Fmax = FmaxBin ; | 2548 | Fmax = FmaxBin ; |
2758 | Fmin = FminBin ; | 2549 | Fmin = FminBin ; |
@@ -2760,12 +2551,12 @@ u16 MXL_TuneRF(struct dvb_frontend *fe, u32 RF_Freq) | |||
2760 | FminBin = 170000000UL ; | 2551 | FminBin = 170000000UL ; |
2761 | FmaxBin = 225000000UL ; | 2552 | FmaxBin = 225000000UL ; |
2762 | if (state->RF_LO > FminBin && state->RF_LO <= FmaxBin) { | 2553 | if (state->RF_LO > FminBin && state->RF_LO <= FmaxBin) { |
2763 | status += MXL_ControlWrite(fe, RFSYN_EN_OUTMUX, 0) ; | 2554 | status += MXL_ControlWrite(fe, RFSYN_EN_OUTMUX, 0); |
2764 | status += MXL_ControlWrite(fe, RFSYN_SEL_VCO_OUT, 1) ; | 2555 | status += MXL_ControlWrite(fe, RFSYN_SEL_VCO_OUT, 1); |
2765 | status += MXL_ControlWrite(fe, RFSYN_SEL_VCO_HI, 1) ; | 2556 | status += MXL_ControlWrite(fe, RFSYN_SEL_VCO_HI, 1); |
2766 | status += MXL_ControlWrite(fe, RFSYN_SEL_DIVM, 0) ; | 2557 | status += MXL_ControlWrite(fe, RFSYN_SEL_DIVM, 0); |
2767 | status += MXL_ControlWrite(fe, RFSYN_RF_DIV_BIAS, 1) ; | 2558 | status += MXL_ControlWrite(fe, RFSYN_RF_DIV_BIAS, 1); |
2768 | status += MXL_ControlWrite(fe, DN_SEL_FREQ, 2) ; | 2559 | status += MXL_ControlWrite(fe, DN_SEL_FREQ, 2); |
2769 | divider_val = 16 ; | 2560 | divider_val = 16 ; |
2770 | Fmax = FmaxBin ; | 2561 | Fmax = FmaxBin ; |
2771 | Fmin = FminBin ; | 2562 | Fmin = FminBin ; |
@@ -2773,12 +2564,12 @@ u16 MXL_TuneRF(struct dvb_frontend *fe, u32 RF_Freq) | |||
2773 | FminBin = 225000000UL ; | 2564 | FminBin = 225000000UL ; |
2774 | FmaxBin = 300000000UL ; | 2565 | FmaxBin = 300000000UL ; |
2775 | if (state->RF_LO > FminBin && state->RF_LO <= FmaxBin) { | 2566 | if (state->RF_LO > FminBin && state->RF_LO <= FmaxBin) { |
2776 | status += MXL_ControlWrite(fe, RFSYN_EN_OUTMUX, 0) ; | 2567 | status += MXL_ControlWrite(fe, RFSYN_EN_OUTMUX, 0); |
2777 | status += MXL_ControlWrite(fe, RFSYN_SEL_VCO_OUT, 1) ; | 2568 | status += MXL_ControlWrite(fe, RFSYN_SEL_VCO_OUT, 1); |
2778 | status += MXL_ControlWrite(fe, RFSYN_SEL_VCO_HI, 0) ; | 2569 | status += MXL_ControlWrite(fe, RFSYN_SEL_VCO_HI, 0); |
2779 | status += MXL_ControlWrite(fe, RFSYN_SEL_DIVM, 0) ; | 2570 | status += MXL_ControlWrite(fe, RFSYN_SEL_DIVM, 0); |
2780 | status += MXL_ControlWrite(fe, RFSYN_RF_DIV_BIAS, 1) ; | 2571 | status += MXL_ControlWrite(fe, RFSYN_RF_DIV_BIAS, 1); |
2781 | status += MXL_ControlWrite(fe, DN_SEL_FREQ, 4) ; | 2572 | status += MXL_ControlWrite(fe, DN_SEL_FREQ, 4); |
2782 | divider_val = 8 ; | 2573 | divider_val = 8 ; |
2783 | Fmax = 340000000UL ; | 2574 | Fmax = 340000000UL ; |
2784 | Fmin = FminBin ; | 2575 | Fmin = FminBin ; |
@@ -2786,12 +2577,12 @@ u16 MXL_TuneRF(struct dvb_frontend *fe, u32 RF_Freq) | |||
2786 | FminBin = 300000000UL ; | 2577 | FminBin = 300000000UL ; |
2787 | FmaxBin = 340000000UL ; | 2578 | FmaxBin = 340000000UL ; |
2788 | if (state->RF_LO > FminBin && state->RF_LO <= FmaxBin) { | 2579 | if (state->RF_LO > FminBin && state->RF_LO <= FmaxBin) { |
2789 | status += MXL_ControlWrite(fe, RFSYN_EN_OUTMUX, 1) ; | 2580 | status += MXL_ControlWrite(fe, RFSYN_EN_OUTMUX, 1); |
2790 | status += MXL_ControlWrite(fe, RFSYN_SEL_VCO_OUT, 0) ; | 2581 | status += MXL_ControlWrite(fe, RFSYN_SEL_VCO_OUT, 0); |
2791 | status += MXL_ControlWrite(fe, RFSYN_SEL_VCO_HI, 0) ; | 2582 | status += MXL_ControlWrite(fe, RFSYN_SEL_VCO_HI, 0); |
2792 | status += MXL_ControlWrite(fe, RFSYN_SEL_DIVM, 0) ; | 2583 | status += MXL_ControlWrite(fe, RFSYN_SEL_DIVM, 0); |
2793 | status += MXL_ControlWrite(fe, RFSYN_RF_DIV_BIAS, 1) ; | 2584 | status += MXL_ControlWrite(fe, RFSYN_RF_DIV_BIAS, 1); |
2794 | status += MXL_ControlWrite(fe, DN_SEL_FREQ, 0) ; | 2585 | status += MXL_ControlWrite(fe, DN_SEL_FREQ, 0); |
2795 | divider_val = 8 ; | 2586 | divider_val = 8 ; |
2796 | Fmax = FmaxBin ; | 2587 | Fmax = FmaxBin ; |
2797 | Fmin = 225000000UL ; | 2588 | Fmin = 225000000UL ; |
@@ -2799,12 +2590,12 @@ u16 MXL_TuneRF(struct dvb_frontend *fe, u32 RF_Freq) | |||
2799 | FminBin = 340000000UL ; | 2590 | FminBin = 340000000UL ; |
2800 | FmaxBin = 450000000UL ; | 2591 | FmaxBin = 450000000UL ; |
2801 | if (state->RF_LO > FminBin && state->RF_LO <= FmaxBin) { | 2592 | if (state->RF_LO > FminBin && state->RF_LO <= FmaxBin) { |
2802 | status += MXL_ControlWrite(fe, RFSYN_EN_OUTMUX, 1) ; | 2593 | status += MXL_ControlWrite(fe, RFSYN_EN_OUTMUX, 1); |
2803 | status += MXL_ControlWrite(fe, RFSYN_SEL_VCO_OUT, 0) ; | 2594 | status += MXL_ControlWrite(fe, RFSYN_SEL_VCO_OUT, 0); |
2804 | status += MXL_ControlWrite(fe, RFSYN_SEL_VCO_HI, 1) ; | 2595 | status += MXL_ControlWrite(fe, RFSYN_SEL_VCO_HI, 1); |
2805 | status += MXL_ControlWrite(fe, RFSYN_SEL_DIVM, 0) ; | 2596 | status += MXL_ControlWrite(fe, RFSYN_SEL_DIVM, 0); |
2806 | status += MXL_ControlWrite(fe, RFSYN_RF_DIV_BIAS, 2) ; | 2597 | status += MXL_ControlWrite(fe, RFSYN_RF_DIV_BIAS, 2); |
2807 | status += MXL_ControlWrite(fe, DN_SEL_FREQ, 0) ; | 2598 | status += MXL_ControlWrite(fe, DN_SEL_FREQ, 0); |
2808 | divider_val = 8 ; | 2599 | divider_val = 8 ; |
2809 | Fmax = FmaxBin ; | 2600 | Fmax = FmaxBin ; |
2810 | Fmin = FminBin ; | 2601 | Fmin = FminBin ; |
@@ -2812,12 +2603,12 @@ u16 MXL_TuneRF(struct dvb_frontend *fe, u32 RF_Freq) | |||
2812 | FminBin = 450000000UL ; | 2603 | FminBin = 450000000UL ; |
2813 | FmaxBin = 680000000UL ; | 2604 | FmaxBin = 680000000UL ; |
2814 | if (state->RF_LO > FminBin && state->RF_LO <= FmaxBin) { | 2605 | if (state->RF_LO > FminBin && state->RF_LO <= FmaxBin) { |
2815 | status += MXL_ControlWrite(fe, RFSYN_EN_OUTMUX, 0) ; | 2606 | status += MXL_ControlWrite(fe, RFSYN_EN_OUTMUX, 0); |
2816 | status += MXL_ControlWrite(fe, RFSYN_SEL_VCO_OUT, 1) ; | 2607 | status += MXL_ControlWrite(fe, RFSYN_SEL_VCO_OUT, 1); |
2817 | status += MXL_ControlWrite(fe, RFSYN_SEL_VCO_HI, 0) ; | 2608 | status += MXL_ControlWrite(fe, RFSYN_SEL_VCO_HI, 0); |
2818 | status += MXL_ControlWrite(fe, RFSYN_SEL_DIVM, 1) ; | 2609 | status += MXL_ControlWrite(fe, RFSYN_SEL_DIVM, 1); |
2819 | status += MXL_ControlWrite(fe, RFSYN_RF_DIV_BIAS, 1) ; | 2610 | status += MXL_ControlWrite(fe, RFSYN_RF_DIV_BIAS, 1); |
2820 | status += MXL_ControlWrite(fe, DN_SEL_FREQ, 0) ; | 2611 | status += MXL_ControlWrite(fe, DN_SEL_FREQ, 0); |
2821 | divider_val = 4 ; | 2612 | divider_val = 4 ; |
2822 | Fmax = FmaxBin ; | 2613 | Fmax = FmaxBin ; |
2823 | Fmin = FminBin ; | 2614 | Fmin = FminBin ; |
@@ -2825,67 +2616,66 @@ u16 MXL_TuneRF(struct dvb_frontend *fe, u32 RF_Freq) | |||
2825 | FminBin = 680000000UL ; | 2616 | FminBin = 680000000UL ; |
2826 | FmaxBin = 900000000UL ; | 2617 | FmaxBin = 900000000UL ; |
2827 | if (state->RF_LO > FminBin && state->RF_LO <= FmaxBin) { | 2618 | if (state->RF_LO > FminBin && state->RF_LO <= FmaxBin) { |
2828 | status += MXL_ControlWrite(fe, RFSYN_EN_OUTMUX, 0) ; | 2619 | status += MXL_ControlWrite(fe, RFSYN_EN_OUTMUX, 0); |
2829 | status += MXL_ControlWrite(fe, RFSYN_SEL_VCO_OUT, 1) ; | 2620 | status += MXL_ControlWrite(fe, RFSYN_SEL_VCO_OUT, 1); |
2830 | status += MXL_ControlWrite(fe, RFSYN_SEL_VCO_HI, 1) ; | 2621 | status += MXL_ControlWrite(fe, RFSYN_SEL_VCO_HI, 1); |
2831 | status += MXL_ControlWrite(fe, RFSYN_SEL_DIVM, 1) ; | 2622 | status += MXL_ControlWrite(fe, RFSYN_SEL_DIVM, 1); |
2832 | status += MXL_ControlWrite(fe, RFSYN_RF_DIV_BIAS, 1) ; | 2623 | status += MXL_ControlWrite(fe, RFSYN_RF_DIV_BIAS, 1); |
2833 | status += MXL_ControlWrite(fe, DN_SEL_FREQ, 0) ; | 2624 | status += MXL_ControlWrite(fe, DN_SEL_FREQ, 0); |
2834 | divider_val = 4 ; | 2625 | divider_val = 4 ; |
2835 | Fmax = FmaxBin ; | 2626 | Fmax = FmaxBin ; |
2836 | Fmin = FminBin ; | 2627 | Fmin = FminBin ; |
2837 | } | 2628 | } |
2838 | 2629 | ||
2839 | // CHCAL_INT_MOD_RF | 2630 | /* CHCAL_INT_MOD_RF |
2840 | // CHCAL_FRAC_MOD_RF | 2631 | * CHCAL_FRAC_MOD_RF |
2841 | // RFSYN_LPF_R | 2632 | * RFSYN_LPF_R |
2842 | // CHCAL_EN_INT_RF | 2633 | * CHCAL_EN_INT_RF |
2843 | 2634 | */ | |
2844 | // Equation E3 | 2635 | /* Equation E3 RFSYN_VCO_BIAS */ |
2845 | // RFSYN_VCO_BIAS | ||
2846 | E3 = (((Fmax-state->RF_LO)/1000)*32)/((Fmax-Fmin)/1000) + 8 ; | 2636 | E3 = (((Fmax-state->RF_LO)/1000)*32)/((Fmax-Fmin)/1000) + 8 ; |
2847 | status += MXL_ControlWrite(fe, RFSYN_VCO_BIAS, E3) ; | 2637 | status += MXL_ControlWrite(fe, RFSYN_VCO_BIAS, E3); |
2848 | 2638 | ||
2849 | // Equation E4 | 2639 | /* Equation E4 CHCAL_INT_MOD_RF */ |
2850 | // CHCAL_INT_MOD_RF | 2640 | E4 = (state->RF_LO*divider_val/1000)/(2*state->Fxtal*Kdbl_RF/1000); |
2851 | E4 = (state->RF_LO*divider_val/1000)/(2*state->Fxtal*Kdbl_RF/1000) ; | 2641 | MXL_ControlWrite(fe, CHCAL_INT_MOD_RF, E4); |
2852 | MXL_ControlWrite(fe, CHCAL_INT_MOD_RF, E4) ; | ||
2853 | 2642 | ||
2854 | // Equation E5 | 2643 | /* Equation E5 CHCAL_FRAC_MOD_RF CHCAL_EN_INT_RF */ |
2855 | // CHCAL_FRAC_MOD_RF | 2644 | E5 = ((2<<17)*(state->RF_LO/10000*divider_val - |
2856 | // CHCAL_EN_INT_RF | 2645 | (E4*(2*state->Fxtal*Kdbl_RF)/10000))) / |
2857 | E5 = ((2<<17)*(state->RF_LO/10000*divider_val - (E4*(2*state->Fxtal*Kdbl_RF)/10000)))/(2*state->Fxtal*Kdbl_RF/10000) ; | 2646 | (2*state->Fxtal*Kdbl_RF/10000); |
2858 | status += MXL_ControlWrite(fe, CHCAL_FRAC_MOD_RF, E5) ; | ||
2859 | 2647 | ||
2860 | // Equation E5A | 2648 | status += MXL_ControlWrite(fe, CHCAL_FRAC_MOD_RF, E5); |
2861 | // RFSYN_LPF_R | 2649 | |
2650 | /* Equation E5A RFSYN_LPF_R */ | ||
2862 | E5A = (((Fmax - state->RF_LO)/1000)*4/((Fmax-Fmin)/1000)) + 1 ; | 2651 | E5A = (((Fmax - state->RF_LO)/1000)*4/((Fmax-Fmin)/1000)) + 1 ; |
2863 | status += MXL_ControlWrite(fe, RFSYN_LPF_R, E5A) ; | 2652 | status += MXL_ControlWrite(fe, RFSYN_LPF_R, E5A); |
2864 | 2653 | ||
2865 | // Euqation E5B | 2654 | /* Euqation E5B CHCAL_EN_INIT_RF */ |
2866 | // CHCAL_EN_INIT_RF | ||
2867 | status += MXL_ControlWrite(fe, CHCAL_EN_INT_RF, ((E5 == 0) ? 1 : 0)); | 2655 | status += MXL_ControlWrite(fe, CHCAL_EN_INT_RF, ((E5 == 0) ? 1 : 0)); |
2868 | //if (E5 == 0) | 2656 | /*if (E5 == 0) |
2869 | // status += MXL_ControlWrite(fe, CHCAL_EN_INT_RF, 1); | 2657 | * status += MXL_ControlWrite(fe, CHCAL_EN_INT_RF, 1); |
2870 | //else | 2658 | *else |
2871 | // status += MXL_ControlWrite(fe, CHCAL_FRAC_MOD_RF, E5) ; | 2659 | * status += MXL_ControlWrite(fe, CHCAL_FRAC_MOD_RF, E5); |
2872 | 2660 | */ | |
2873 | // | 2661 | |
2874 | // Set TG Synth | 2662 | /* |
2875 | // | 2663 | * Set TG Synth |
2876 | // Look-Up table implementation for: | 2664 | * |
2877 | // TG_LO_DIVVAL | 2665 | * Look-Up table implementation for: |
2878 | // TG_LO_SELVAL | 2666 | * TG_LO_DIVVAL |
2879 | // | 2667 | * TG_LO_SELVAL |
2880 | // Set divider_val, Fmax, Fmix to use in Equations | 2668 | * |
2881 | if (state->TG_LO < 33000000UL) { | 2669 | * Set divider_val, Fmax, Fmix to use in Equations |
2670 | */ | ||
2671 | if (state->TG_LO < 33000000UL) | ||
2882 | return -1; | 2672 | return -1; |
2883 | } | 2673 | |
2884 | FminBin = 33000000UL ; | 2674 | FminBin = 33000000UL ; |
2885 | FmaxBin = 50000000UL ; | 2675 | FmaxBin = 50000000UL ; |
2886 | if (state->TG_LO >= FminBin && state->TG_LO <= FmaxBin) { | 2676 | if (state->TG_LO >= FminBin && state->TG_LO <= FmaxBin) { |
2887 | status += MXL_ControlWrite(fe, TG_LO_DIVVAL, 0x6) ; | 2677 | status += MXL_ControlWrite(fe, TG_LO_DIVVAL, 0x6); |
2888 | status += MXL_ControlWrite(fe, TG_LO_SELVAL, 0x0) ; | 2678 | status += MXL_ControlWrite(fe, TG_LO_SELVAL, 0x0); |
2889 | divider_val = 36 ; | 2679 | divider_val = 36 ; |
2890 | Fmax = FmaxBin ; | 2680 | Fmax = FmaxBin ; |
2891 | Fmin = FminBin ; | 2681 | Fmin = FminBin ; |
@@ -2893,8 +2683,8 @@ u16 MXL_TuneRF(struct dvb_frontend *fe, u32 RF_Freq) | |||
2893 | FminBin = 50000000UL ; | 2683 | FminBin = 50000000UL ; |
2894 | FmaxBin = 67000000UL ; | 2684 | FmaxBin = 67000000UL ; |
2895 | if (state->TG_LO > FminBin && state->TG_LO <= FmaxBin) { | 2685 | if (state->TG_LO > FminBin && state->TG_LO <= FmaxBin) { |
2896 | status += MXL_ControlWrite(fe, TG_LO_DIVVAL, 0x1) ; | 2686 | status += MXL_ControlWrite(fe, TG_LO_DIVVAL, 0x1); |
2897 | status += MXL_ControlWrite(fe, TG_LO_SELVAL, 0x0) ; | 2687 | status += MXL_ControlWrite(fe, TG_LO_SELVAL, 0x0); |
2898 | divider_val = 24 ; | 2688 | divider_val = 24 ; |
2899 | Fmax = FmaxBin ; | 2689 | Fmax = FmaxBin ; |
2900 | Fmin = FminBin ; | 2690 | Fmin = FminBin ; |
@@ -2902,8 +2692,8 @@ u16 MXL_TuneRF(struct dvb_frontend *fe, u32 RF_Freq) | |||
2902 | FminBin = 67000000UL ; | 2692 | FminBin = 67000000UL ; |
2903 | FmaxBin = 100000000UL ; | 2693 | FmaxBin = 100000000UL ; |
2904 | if (state->TG_LO > FminBin && state->TG_LO <= FmaxBin) { | 2694 | if (state->TG_LO > FminBin && state->TG_LO <= FmaxBin) { |
2905 | status += MXL_ControlWrite(fe, TG_LO_DIVVAL, 0xC) ; | 2695 | status += MXL_ControlWrite(fe, TG_LO_DIVVAL, 0xC); |
2906 | status += MXL_ControlWrite(fe, TG_LO_SELVAL, 0x2) ; | 2696 | status += MXL_ControlWrite(fe, TG_LO_SELVAL, 0x2); |
2907 | divider_val = 18 ; | 2697 | divider_val = 18 ; |
2908 | Fmax = FmaxBin ; | 2698 | Fmax = FmaxBin ; |
2909 | Fmin = FminBin ; | 2699 | Fmin = FminBin ; |
@@ -2911,8 +2701,8 @@ u16 MXL_TuneRF(struct dvb_frontend *fe, u32 RF_Freq) | |||
2911 | FminBin = 100000000UL ; | 2701 | FminBin = 100000000UL ; |
2912 | FmaxBin = 150000000UL ; | 2702 | FmaxBin = 150000000UL ; |
2913 | if (state->TG_LO > FminBin && state->TG_LO <= FmaxBin) { | 2703 | if (state->TG_LO > FminBin && state->TG_LO <= FmaxBin) { |
2914 | status += MXL_ControlWrite(fe, TG_LO_DIVVAL, 0x8) ; | 2704 | status += MXL_ControlWrite(fe, TG_LO_DIVVAL, 0x8); |
2915 | status += MXL_ControlWrite(fe, TG_LO_SELVAL, 0x2) ; | 2705 | status += MXL_ControlWrite(fe, TG_LO_SELVAL, 0x2); |
2916 | divider_val = 12 ; | 2706 | divider_val = 12 ; |
2917 | Fmax = FmaxBin ; | 2707 | Fmax = FmaxBin ; |
2918 | Fmin = FminBin ; | 2708 | Fmin = FminBin ; |
@@ -2920,8 +2710,8 @@ u16 MXL_TuneRF(struct dvb_frontend *fe, u32 RF_Freq) | |||
2920 | FminBin = 150000000UL ; | 2710 | FminBin = 150000000UL ; |
2921 | FmaxBin = 200000000UL ; | 2711 | FmaxBin = 200000000UL ; |
2922 | if (state->TG_LO > FminBin && state->TG_LO <= FmaxBin) { | 2712 | if (state->TG_LO > FminBin && state->TG_LO <= FmaxBin) { |
2923 | status += MXL_ControlWrite(fe, TG_LO_DIVVAL, 0x0) ; | 2713 | status += MXL_ControlWrite(fe, TG_LO_DIVVAL, 0x0); |
2924 | status += MXL_ControlWrite(fe, TG_LO_SELVAL, 0x2) ; | 2714 | status += MXL_ControlWrite(fe, TG_LO_SELVAL, 0x2); |
2925 | divider_val = 8 ; | 2715 | divider_val = 8 ; |
2926 | Fmax = FmaxBin ; | 2716 | Fmax = FmaxBin ; |
2927 | Fmin = FminBin ; | 2717 | Fmin = FminBin ; |
@@ -2929,8 +2719,8 @@ u16 MXL_TuneRF(struct dvb_frontend *fe, u32 RF_Freq) | |||
2929 | FminBin = 200000000UL ; | 2719 | FminBin = 200000000UL ; |
2930 | FmaxBin = 300000000UL ; | 2720 | FmaxBin = 300000000UL ; |
2931 | if (state->TG_LO > FminBin && state->TG_LO <= FmaxBin) { | 2721 | if (state->TG_LO > FminBin && state->TG_LO <= FmaxBin) { |
2932 | status += MXL_ControlWrite(fe, TG_LO_DIVVAL, 0x8) ; | 2722 | status += MXL_ControlWrite(fe, TG_LO_DIVVAL, 0x8); |
2933 | status += MXL_ControlWrite(fe, TG_LO_SELVAL, 0x3) ; | 2723 | status += MXL_ControlWrite(fe, TG_LO_SELVAL, 0x3); |
2934 | divider_val = 6 ; | 2724 | divider_val = 6 ; |
2935 | Fmax = FmaxBin ; | 2725 | Fmax = FmaxBin ; |
2936 | Fmin = FminBin ; | 2726 | Fmin = FminBin ; |
@@ -2938,8 +2728,8 @@ u16 MXL_TuneRF(struct dvb_frontend *fe, u32 RF_Freq) | |||
2938 | FminBin = 300000000UL ; | 2728 | FminBin = 300000000UL ; |
2939 | FmaxBin = 400000000UL ; | 2729 | FmaxBin = 400000000UL ; |
2940 | if (state->TG_LO > FminBin && state->TG_LO <= FmaxBin) { | 2730 | if (state->TG_LO > FminBin && state->TG_LO <= FmaxBin) { |
2941 | status += MXL_ControlWrite(fe, TG_LO_DIVVAL, 0x0) ; | 2731 | status += MXL_ControlWrite(fe, TG_LO_DIVVAL, 0x0); |
2942 | status += MXL_ControlWrite(fe, TG_LO_SELVAL, 0x3) ; | 2732 | status += MXL_ControlWrite(fe, TG_LO_SELVAL, 0x3); |
2943 | divider_val = 4 ; | 2733 | divider_val = 4 ; |
2944 | Fmax = FmaxBin ; | 2734 | Fmax = FmaxBin ; |
2945 | Fmin = FminBin ; | 2735 | Fmin = FminBin ; |
@@ -2947,8 +2737,8 @@ u16 MXL_TuneRF(struct dvb_frontend *fe, u32 RF_Freq) | |||
2947 | FminBin = 400000000UL ; | 2737 | FminBin = 400000000UL ; |
2948 | FmaxBin = 600000000UL ; | 2738 | FmaxBin = 600000000UL ; |
2949 | if (state->TG_LO > FminBin && state->TG_LO <= FmaxBin) { | 2739 | if (state->TG_LO > FminBin && state->TG_LO <= FmaxBin) { |
2950 | status += MXL_ControlWrite(fe, TG_LO_DIVVAL, 0x8) ; | 2740 | status += MXL_ControlWrite(fe, TG_LO_DIVVAL, 0x8); |
2951 | status += MXL_ControlWrite(fe, TG_LO_SELVAL, 0x7) ; | 2741 | status += MXL_ControlWrite(fe, TG_LO_SELVAL, 0x7); |
2952 | divider_val = 3 ; | 2742 | divider_val = 3 ; |
2953 | Fmax = FmaxBin ; | 2743 | Fmax = FmaxBin ; |
2954 | Fmin = FminBin ; | 2744 | Fmin = FminBin ; |
@@ -2956,682 +2746,608 @@ u16 MXL_TuneRF(struct dvb_frontend *fe, u32 RF_Freq) | |||
2956 | FminBin = 600000000UL ; | 2746 | FminBin = 600000000UL ; |
2957 | FmaxBin = 900000000UL ; | 2747 | FmaxBin = 900000000UL ; |
2958 | if (state->TG_LO > FminBin && state->TG_LO <= FmaxBin) { | 2748 | if (state->TG_LO > FminBin && state->TG_LO <= FmaxBin) { |
2959 | status += MXL_ControlWrite(fe, TG_LO_DIVVAL, 0x0) ; | 2749 | status += MXL_ControlWrite(fe, TG_LO_DIVVAL, 0x0); |
2960 | status += MXL_ControlWrite(fe, TG_LO_SELVAL, 0x7) ; | 2750 | status += MXL_ControlWrite(fe, TG_LO_SELVAL, 0x7); |
2961 | divider_val = 2 ; | 2751 | divider_val = 2 ; |
2962 | Fmax = FmaxBin ; | 2752 | Fmax = FmaxBin ; |
2963 | Fmin = FminBin ; | 2753 | Fmin = FminBin ; |
2964 | } | 2754 | } |
2965 | 2755 | ||
2966 | // TG_DIV_VAL | 2756 | /* TG_DIV_VAL */ |
2967 | tg_divval = (state->TG_LO*divider_val/100000) | 2757 | tg_divval = (state->TG_LO*divider_val/100000) * |
2968 | *(MXL_Ceiling(state->Fxtal,1000000) * 100) / (state->Fxtal/1000) ; | 2758 | (MXL_Ceiling(state->Fxtal, 1000000) * 100) / |
2969 | status += MXL_ControlWrite(fe, TG_DIV_VAL, tg_divval) ; | 2759 | (state->Fxtal/1000); |
2760 | |||
2761 | status += MXL_ControlWrite(fe, TG_DIV_VAL, tg_divval); | ||
2970 | 2762 | ||
2971 | if (state->TG_LO > 600000000UL) | 2763 | if (state->TG_LO > 600000000UL) |
2972 | status += MXL_ControlWrite(fe, TG_DIV_VAL, tg_divval + 1 ) ; | 2764 | status += MXL_ControlWrite(fe, TG_DIV_VAL, tg_divval + 1); |
2973 | 2765 | ||
2974 | Fmax = 1800000000UL ; | 2766 | Fmax = 1800000000UL ; |
2975 | Fmin = 1200000000UL ; | 2767 | Fmin = 1200000000UL ; |
2976 | 2768 | ||
2769 | /* prevent overflow of 32 bit unsigned integer, use | ||
2770 | * following equation. Edit for v2.6.4 | ||
2771 | */ | ||
2772 | /* Fref_TF = Fref_TG * 1000 */ | ||
2773 | Fref_TG = (state->Fxtal/1000) / MXL_Ceiling(state->Fxtal, 1000000); | ||
2977 | 2774 | ||
2978 | 2775 | /* Fvco = Fvco/10 */ | |
2979 | // to prevent overflow of 32 bit unsigned integer, use following equation. Edit for v2.6.4 | 2776 | Fvco = (state->TG_LO/10000) * divider_val * Fref_TG; |
2980 | Fref_TG = (state->Fxtal/1000)/ MXL_Ceiling(state->Fxtal, 1000000) ; // Fref_TF = Fref_TG*1000 | ||
2981 | |||
2982 | Fvco = (state->TG_LO/10000) * divider_val * Fref_TG; //Fvco = Fvco/10 | ||
2983 | 2777 | ||
2984 | tg_lo = (((Fmax/10 - Fvco)/100)*32) / ((Fmax-Fmin)/1000)+8; | 2778 | tg_lo = (((Fmax/10 - Fvco)/100)*32) / ((Fmax-Fmin)/1000)+8; |
2985 | 2779 | ||
2986 | //below equation is same as above but much harder to debug. | 2780 | /* below equation is same as above but much harder to debug. |
2987 | //tg_lo = ( ((Fmax/10000 * Xtal_Int)/100) - ((state->TG_LO/10000)*divider_val*(state->Fxtal/10000)/100) )*32/((Fmax-Fmin)/10000 * Xtal_Int/100) + 8 ; | 2781 | * tg_lo = ( ((Fmax/10000 * Xtal_Int)/100) - |
2988 | 2782 | * ((state->TG_LO/10000)*divider_val * | |
2989 | 2783 | * (state->Fxtal/10000)/100) )*32/((Fmax-Fmin)/10000 * | |
2990 | status += MXL_ControlWrite(fe, TG_VCO_BIAS , tg_lo) ; | 2784 | * Xtal_Int/100) + 8; |
2991 | 2785 | */ | |
2992 | 2786 | ||
2787 | status += MXL_ControlWrite(fe, TG_VCO_BIAS , tg_lo); | ||
2993 | 2788 | ||
2994 | //add for 2.6.5 | 2789 | /* add for 2.6.5 Special setting for QAM */ |
2995 | //Special setting for QAM | 2790 | if (state->Mod_Type == MXL_QAM) { |
2996 | if(state->Mod_Type == MXL_QAM) | 2791 | if (state->RF_IN < 680000000) |
2997 | { | 2792 | status += MXL_ControlWrite(fe, RFSYN_CHP_GAIN, 3); |
2998 | if(state->RF_IN < 680000000) | 2793 | else |
2999 | status += MXL_ControlWrite(fe, RFSYN_CHP_GAIN, 3) ; | 2794 | status += MXL_ControlWrite(fe, RFSYN_CHP_GAIN, 2); |
3000 | else | ||
3001 | status += MXL_ControlWrite(fe, RFSYN_CHP_GAIN, 2) ; | ||
3002 | } | 2795 | } |
3003 | 2796 | ||
3004 | 2797 | /* Off Chip Tracking Filter Control */ | |
3005 | //remove 20.48MHz setting for 2.6.10 | 2798 | if (state->TF_Type == MXL_TF_OFF) { |
3006 | 2799 | /* Tracking Filter Off State; turn off all the banks */ | |
3007 | // | 2800 | status += MXL_ControlWrite(fe, DAC_A_ENABLE, 0); |
3008 | // Off Chip Tracking Filter Control | 2801 | status += MXL_ControlWrite(fe, DAC_B_ENABLE, 0); |
3009 | // | 2802 | status += MXL_SetGPIO(fe, 3, 1); /* Bank1 Off */ |
3010 | if (state->TF_Type == MXL_TF_OFF) // Tracking Filter Off State; turn off all the banks | 2803 | status += MXL_SetGPIO(fe, 1, 1); /* Bank2 Off */ |
3011 | { | 2804 | status += MXL_SetGPIO(fe, 4, 1); /* Bank3 Off */ |
3012 | status += MXL_ControlWrite(fe, DAC_A_ENABLE, 0) ; | ||
3013 | status += MXL_ControlWrite(fe, DAC_B_ENABLE, 0) ; | ||
3014 | |||
3015 | status += MXL_SetGPIO(fe, 3, 1) ; // turn off Bank 1 | ||
3016 | status += MXL_SetGPIO(fe, 1, 1) ; // turn off Bank 2 | ||
3017 | status += MXL_SetGPIO(fe, 4, 1) ; // turn off Bank 3 | ||
3018 | } | 2805 | } |
3019 | 2806 | ||
3020 | if (state->TF_Type == MXL_TF_C) // Tracking Filter type C | 2807 | if (state->TF_Type == MXL_TF_C) /* Tracking Filter type C */ { |
3021 | { | 2808 | status += MXL_ControlWrite(fe, DAC_B_ENABLE, 1); |
3022 | status += MXL_ControlWrite(fe, DAC_B_ENABLE, 1) ; | 2809 | status += MXL_ControlWrite(fe, DAC_DIN_A, 0); |
3023 | status += MXL_ControlWrite(fe, DAC_DIN_A, 0) ; | 2810 | |
3024 | 2811 | if (state->RF_IN >= 43000000 && state->RF_IN < 150000000) { | |
3025 | if (state->RF_IN >= 43000000 && state->RF_IN < 150000000) | 2812 | status += MXL_ControlWrite(fe, DAC_A_ENABLE, 0); |
3026 | { | 2813 | status += MXL_ControlWrite(fe, DAC_DIN_B, 0); |
3027 | 2814 | status += MXL_SetGPIO(fe, 3, 0); | |
3028 | status += MXL_ControlWrite(fe, DAC_A_ENABLE, 0) ; // Bank4 Off | 2815 | status += MXL_SetGPIO(fe, 1, 1); |
3029 | status += MXL_ControlWrite(fe, DAC_DIN_B, 0) ; | 2816 | status += MXL_SetGPIO(fe, 4, 1); |
3030 | status += MXL_SetGPIO(fe, 3, 0) ; // Bank1 On | 2817 | } |
3031 | status += MXL_SetGPIO(fe, 1, 1) ; // Bank2 Off | 2818 | if (state->RF_IN >= 150000000 && state->RF_IN < 280000000) { |
3032 | status += MXL_SetGPIO(fe, 4, 1) ; // Bank3 Off | 2819 | status += MXL_ControlWrite(fe, DAC_A_ENABLE, 0); |
3033 | } | 2820 | status += MXL_ControlWrite(fe, DAC_DIN_B, 0); |
3034 | if (state->RF_IN >= 150000000 && state->RF_IN < 280000000) | 2821 | status += MXL_SetGPIO(fe, 3, 1); |
3035 | { | 2822 | status += MXL_SetGPIO(fe, 1, 0); |
3036 | status += MXL_ControlWrite(fe, DAC_A_ENABLE, 0) ; // Bank4 Off | 2823 | status += MXL_SetGPIO(fe, 4, 1); |
3037 | status += MXL_ControlWrite(fe, DAC_DIN_B, 0) ; | 2824 | } |
3038 | status += MXL_SetGPIO(fe, 3, 1) ; // Bank1 Off | 2825 | if (state->RF_IN >= 280000000 && state->RF_IN < 360000000) { |
3039 | status += MXL_SetGPIO(fe, 1, 0) ; // Bank2 On | 2826 | status += MXL_ControlWrite(fe, DAC_A_ENABLE, 0); |
3040 | status += MXL_SetGPIO(fe, 4, 1) ; // Bank3 Off | 2827 | status += MXL_ControlWrite(fe, DAC_DIN_B, 0); |
3041 | } | 2828 | status += MXL_SetGPIO(fe, 3, 1); |
3042 | if (state->RF_IN >= 280000000 && state->RF_IN < 360000000) | 2829 | status += MXL_SetGPIO(fe, 1, 0); |
3043 | { | 2830 | status += MXL_SetGPIO(fe, 4, 0); |
3044 | status += MXL_ControlWrite(fe, DAC_A_ENABLE, 0) ; // Bank4 Off | 2831 | } |
3045 | status += MXL_ControlWrite(fe, DAC_DIN_B, 0) ; | 2832 | if (state->RF_IN >= 360000000 && state->RF_IN < 560000000) { |
3046 | status += MXL_SetGPIO(fe, 3, 1) ; // Bank1 Off | 2833 | status += MXL_ControlWrite(fe, DAC_A_ENABLE, 0); |
3047 | status += MXL_SetGPIO(fe, 1, 0) ; // Bank2 On | 2834 | status += MXL_ControlWrite(fe, DAC_DIN_B, 0); |
3048 | status += MXL_SetGPIO(fe, 4, 0) ; // Bank3 On | 2835 | status += MXL_SetGPIO(fe, 3, 1); |
3049 | } | 2836 | status += MXL_SetGPIO(fe, 1, 1); |
3050 | if (state->RF_IN >= 360000000 && state->RF_IN < 560000000) | 2837 | status += MXL_SetGPIO(fe, 4, 0); |
3051 | { | 2838 | } |
3052 | status += MXL_ControlWrite(fe, DAC_A_ENABLE, 0) ; // Bank4 Off | 2839 | if (state->RF_IN >= 560000000 && state->RF_IN < 580000000) { |
3053 | status += MXL_ControlWrite(fe, DAC_DIN_B, 0) ; | 2840 | status += MXL_ControlWrite(fe, DAC_A_ENABLE, 1); |
3054 | status += MXL_SetGPIO(fe, 3, 1) ; // Bank1 Off | 2841 | status += MXL_ControlWrite(fe, DAC_DIN_B, 29); |
3055 | status += MXL_SetGPIO(fe, 1, 1) ; // Bank2 Off | 2842 | status += MXL_SetGPIO(fe, 3, 1); |
3056 | status += MXL_SetGPIO(fe, 4, 0) ; // Bank3 On | 2843 | status += MXL_SetGPIO(fe, 1, 1); |
3057 | } | 2844 | status += MXL_SetGPIO(fe, 4, 0); |
3058 | if (state->RF_IN >= 560000000 && state->RF_IN < 580000000) | 2845 | } |
3059 | { | 2846 | if (state->RF_IN >= 580000000 && state->RF_IN < 630000000) { |
3060 | status += MXL_ControlWrite(fe, DAC_A_ENABLE, 1) ; // Bank4 On | 2847 | status += MXL_ControlWrite(fe, DAC_A_ENABLE, 1); |
3061 | status += MXL_ControlWrite(fe, DAC_DIN_B, 29) ; | 2848 | status += MXL_ControlWrite(fe, DAC_DIN_B, 0); |
3062 | status += MXL_SetGPIO(fe, 3, 1) ; // Bank1 Off | 2849 | status += MXL_SetGPIO(fe, 3, 1); |
3063 | status += MXL_SetGPIO(fe, 1, 1) ; // Bank2 Off | 2850 | status += MXL_SetGPIO(fe, 1, 1); |
3064 | status += MXL_SetGPIO(fe, 4, 0) ; // Bank3 On | 2851 | status += MXL_SetGPIO(fe, 4, 0); |
3065 | } | 2852 | } |
3066 | if (state->RF_IN >= 580000000 && state->RF_IN < 630000000) | 2853 | if (state->RF_IN >= 630000000 && state->RF_IN < 700000000) { |
3067 | { | 2854 | status += MXL_ControlWrite(fe, DAC_A_ENABLE, 1); |
3068 | status += MXL_ControlWrite(fe, DAC_A_ENABLE, 1) ; // Bank4 On | 2855 | status += MXL_ControlWrite(fe, DAC_DIN_B, 16); |
3069 | status += MXL_ControlWrite(fe, DAC_DIN_B, 0) ; | 2856 | status += MXL_SetGPIO(fe, 3, 1); |
3070 | status += MXL_SetGPIO(fe, 3, 1) ; // Bank1 Off | 2857 | status += MXL_SetGPIO(fe, 1, 1); |
3071 | status += MXL_SetGPIO(fe, 1, 1) ; // Bank2 Off | 2858 | status += MXL_SetGPIO(fe, 4, 1); |
3072 | status += MXL_SetGPIO(fe, 4, 0) ; // Bank3 On | 2859 | } |
3073 | } | 2860 | if (state->RF_IN >= 700000000 && state->RF_IN < 760000000) { |
3074 | if (state->RF_IN >= 630000000 && state->RF_IN < 700000000) | 2861 | status += MXL_ControlWrite(fe, DAC_A_ENABLE, 1); |
3075 | { | 2862 | status += MXL_ControlWrite(fe, DAC_DIN_B, 7); |
3076 | status += MXL_ControlWrite(fe, DAC_A_ENABLE, 1) ; // Bank4 On | 2863 | status += MXL_SetGPIO(fe, 3, 1); |
3077 | status += MXL_ControlWrite(fe, DAC_DIN_B, 16) ; | 2864 | status += MXL_SetGPIO(fe, 1, 1); |
3078 | status += MXL_SetGPIO(fe, 3, 1) ; // Bank1 Off | 2865 | status += MXL_SetGPIO(fe, 4, 1); |
3079 | status += MXL_SetGPIO(fe, 1, 1) ; // Bank2 Off | 2866 | } |
3080 | status += MXL_SetGPIO(fe, 4, 1) ; // Bank3 Off | 2867 | if (state->RF_IN >= 760000000 && state->RF_IN <= 900000000) { |
3081 | } | 2868 | status += MXL_ControlWrite(fe, DAC_A_ENABLE, 1); |
3082 | if (state->RF_IN >= 700000000 && state->RF_IN < 760000000) | 2869 | status += MXL_ControlWrite(fe, DAC_DIN_B, 0); |
3083 | { | 2870 | status += MXL_SetGPIO(fe, 3, 1); |
3084 | status += MXL_ControlWrite(fe, DAC_A_ENABLE, 1) ; // Bank4 On | 2871 | status += MXL_SetGPIO(fe, 1, 1); |
3085 | status += MXL_ControlWrite(fe, DAC_DIN_B, 7) ; | 2872 | status += MXL_SetGPIO(fe, 4, 1); |
3086 | status += MXL_SetGPIO(fe, 3, 1) ; // Bank1 Off | ||
3087 | status += MXL_SetGPIO(fe, 1, 1) ; // Bank2 Off | ||
3088 | status += MXL_SetGPIO(fe, 4, 1) ; // Bank3 Off | ||
3089 | } | ||
3090 | if (state->RF_IN >= 760000000 && state->RF_IN <= 900000000) | ||
3091 | { | ||
3092 | status += MXL_ControlWrite(fe, DAC_A_ENABLE, 1) ; // Bank4 On | ||
3093 | status += MXL_ControlWrite(fe, DAC_DIN_B, 0) ; | ||
3094 | status += MXL_SetGPIO(fe, 3, 1) ; // Bank1 Off | ||
3095 | status += MXL_SetGPIO(fe, 1, 1) ; // Bank2 Off | ||
3096 | status += MXL_SetGPIO(fe, 4, 1) ; // Bank3 Off | ||
3097 | } | 2873 | } |
3098 | } | 2874 | } |
3099 | 2875 | ||
3100 | if (state->TF_Type == MXL_TF_C_H) // Tracking Filter type C-H for Hauppauge only | 2876 | if (state->TF_Type == MXL_TF_C_H) { |
3101 | { | 2877 | |
3102 | printk("%s() CH filter\n", __func__); | 2878 | /* Tracking Filter type C-H for Hauppauge only */ |
3103 | status += MXL_ControlWrite(fe, DAC_DIN_A, 0) ; | 2879 | status += MXL_ControlWrite(fe, DAC_DIN_A, 0); |
3104 | 2880 | ||
3105 | if (state->RF_IN >= 43000000 && state->RF_IN < 150000000) | 2881 | if (state->RF_IN >= 43000000 && state->RF_IN < 150000000) { |
3106 | { | 2882 | status += MXL_ControlWrite(fe, DAC_A_ENABLE, 0); |
3107 | 2883 | status += MXL_SetGPIO(fe, 4, 0); | |
3108 | status += MXL_ControlWrite(fe, DAC_A_ENABLE, 0) ; // Bank4 Off | 2884 | status += MXL_SetGPIO(fe, 3, 1); |
3109 | status += MXL_SetGPIO(fe, 4, 0) ; // Bank1 On | 2885 | status += MXL_SetGPIO(fe, 1, 1); |
3110 | status += MXL_SetGPIO(fe, 3, 1) ; // Bank2 Off | 2886 | } |
3111 | status += MXL_SetGPIO(fe, 1, 1) ; // Bank3 Off | 2887 | if (state->RF_IN >= 150000000 && state->RF_IN < 280000000) { |
3112 | } | 2888 | status += MXL_ControlWrite(fe, DAC_A_ENABLE, 0); |
3113 | if (state->RF_IN >= 150000000 && state->RF_IN < 280000000) | 2889 | status += MXL_SetGPIO(fe, 4, 1); |
3114 | { | 2890 | status += MXL_SetGPIO(fe, 3, 0); |
3115 | status += MXL_ControlWrite(fe, DAC_A_ENABLE, 0) ; // Bank4 Off | 2891 | status += MXL_SetGPIO(fe, 1, 1); |
3116 | status += MXL_SetGPIO(fe, 4, 1) ; // Bank1 Off | 2892 | } |
3117 | status += MXL_SetGPIO(fe, 3, 0) ; // Bank2 On | 2893 | if (state->RF_IN >= 280000000 && state->RF_IN < 360000000) { |
3118 | status += MXL_SetGPIO(fe, 1, 1) ; // Bank3 Off | 2894 | status += MXL_ControlWrite(fe, DAC_A_ENABLE, 0); |
3119 | } | 2895 | status += MXL_SetGPIO(fe, 4, 1); |
3120 | if (state->RF_IN >= 280000000 && state->RF_IN < 360000000) | 2896 | status += MXL_SetGPIO(fe, 3, 0); |
3121 | { | 2897 | status += MXL_SetGPIO(fe, 1, 0); |
3122 | status += MXL_ControlWrite(fe, DAC_A_ENABLE, 0) ; // Bank4 Off | 2898 | } |
3123 | status += MXL_SetGPIO(fe, 4, 1) ; // Bank1 Off | 2899 | if (state->RF_IN >= 360000000 && state->RF_IN < 560000000) { |
3124 | status += MXL_SetGPIO(fe, 3, 0) ; // Bank2 On | 2900 | status += MXL_ControlWrite(fe, DAC_A_ENABLE, 0); |
3125 | status += MXL_SetGPIO(fe, 1, 0) ; // Bank3 On | 2901 | status += MXL_SetGPIO(fe, 4, 1); |
3126 | } | 2902 | status += MXL_SetGPIO(fe, 3, 1); |
3127 | if (state->RF_IN >= 360000000 && state->RF_IN < 560000000) | 2903 | status += MXL_SetGPIO(fe, 1, 0); |
3128 | { | 2904 | } |
3129 | status += MXL_ControlWrite(fe, DAC_A_ENABLE, 0) ; // Bank4 Off | 2905 | if (state->RF_IN >= 560000000 && state->RF_IN < 580000000) { |
3130 | status += MXL_SetGPIO(fe, 4, 1) ; // Bank1 Off | 2906 | status += MXL_ControlWrite(fe, DAC_A_ENABLE, 1); |
3131 | status += MXL_SetGPIO(fe, 3, 1) ; // Bank2 Off | 2907 | status += MXL_SetGPIO(fe, 4, 1); |
3132 | status += MXL_SetGPIO(fe, 1, 0) ; // Bank3 On | 2908 | status += MXL_SetGPIO(fe, 3, 1); |
3133 | } | 2909 | status += MXL_SetGPIO(fe, 1, 0); |
3134 | if (state->RF_IN >= 560000000 && state->RF_IN < 580000000) | 2910 | } |
3135 | { | 2911 | if (state->RF_IN >= 580000000 && state->RF_IN < 630000000) { |
3136 | status += MXL_ControlWrite(fe, DAC_A_ENABLE, 1) ; // Bank4 On | 2912 | status += MXL_ControlWrite(fe, DAC_A_ENABLE, 1); |
3137 | status += MXL_SetGPIO(fe, 4, 1) ; // Bank1 Off | 2913 | status += MXL_SetGPIO(fe, 4, 1); |
3138 | status += MXL_SetGPIO(fe, 3, 1) ; // Bank2 Off | 2914 | status += MXL_SetGPIO(fe, 3, 1); |
3139 | status += MXL_SetGPIO(fe, 1, 0) ; // Bank3 On | 2915 | status += MXL_SetGPIO(fe, 1, 0); |
3140 | } | 2916 | } |
3141 | if (state->RF_IN >= 580000000 && state->RF_IN < 630000000) | 2917 | if (state->RF_IN >= 630000000 && state->RF_IN < 700000000) { |
3142 | { | 2918 | status += MXL_ControlWrite(fe, DAC_A_ENABLE, 1); |
3143 | status += MXL_ControlWrite(fe, DAC_A_ENABLE, 1) ; // Bank4 On | 2919 | status += MXL_SetGPIO(fe, 4, 1); |
3144 | status += MXL_SetGPIO(fe, 4, 1) ; // Bank1 Off | 2920 | status += MXL_SetGPIO(fe, 3, 1); |
3145 | status += MXL_SetGPIO(fe, 3, 1) ; // Bank2 Off | 2921 | status += MXL_SetGPIO(fe, 1, 1); |
3146 | status += MXL_SetGPIO(fe, 1, 0) ; // Bank3 On | 2922 | } |
3147 | } | 2923 | if (state->RF_IN >= 700000000 && state->RF_IN < 760000000) { |
3148 | if (state->RF_IN >= 630000000 && state->RF_IN < 700000000) | 2924 | status += MXL_ControlWrite(fe, DAC_A_ENABLE, 1); |
3149 | { | 2925 | status += MXL_SetGPIO(fe, 4, 1); |
3150 | status += MXL_ControlWrite(fe, DAC_A_ENABLE, 1) ; // Bank4 On | 2926 | status += MXL_SetGPIO(fe, 3, 1); |
3151 | status += MXL_SetGPIO(fe, 4, 1) ; // Bank1 Off | 2927 | status += MXL_SetGPIO(fe, 1, 1); |
3152 | status += MXL_SetGPIO(fe, 3, 1) ; // Bank2 Off | 2928 | } |
3153 | status += MXL_SetGPIO(fe, 1, 1) ; // Bank3 Off | 2929 | if (state->RF_IN >= 760000000 && state->RF_IN <= 900000000) { |
3154 | } | 2930 | status += MXL_ControlWrite(fe, DAC_A_ENABLE, 1); |
3155 | if (state->RF_IN >= 700000000 && state->RF_IN < 760000000) | 2931 | status += MXL_SetGPIO(fe, 4, 1); |
3156 | { | 2932 | status += MXL_SetGPIO(fe, 3, 1); |
3157 | status += MXL_ControlWrite(fe, DAC_A_ENABLE, 1) ; // Bank4 On | 2933 | status += MXL_SetGPIO(fe, 1, 1); |
3158 | status += MXL_SetGPIO(fe, 4, 1) ; // Bank1 Off | ||
3159 | status += MXL_SetGPIO(fe, 3, 1) ; // Bank2 Off | ||
3160 | status += MXL_SetGPIO(fe, 1, 1) ; // Bank3 Off | ||
3161 | } | ||
3162 | if (state->RF_IN >= 760000000 && state->RF_IN <= 900000000) | ||
3163 | { | ||
3164 | status += MXL_ControlWrite(fe, DAC_A_ENABLE, 1) ; // Bank4 On | ||
3165 | status += MXL_SetGPIO(fe, 4, 1) ; // Bank1 Off | ||
3166 | status += MXL_SetGPIO(fe, 3, 1) ; // Bank2 Off | ||
3167 | status += MXL_SetGPIO(fe, 1, 1) ; // Bank3 Off | ||
3168 | } | 2934 | } |
3169 | } | 2935 | } |
3170 | 2936 | ||
3171 | if (state->TF_Type == MXL_TF_D) // Tracking Filter type D | 2937 | if (state->TF_Type == MXL_TF_D) { /* Tracking Filter type D */ |
3172 | { | 2938 | |
3173 | status += MXL_ControlWrite(fe, DAC_DIN_B, 0) ; | 2939 | status += MXL_ControlWrite(fe, DAC_DIN_B, 0); |
3174 | 2940 | ||
3175 | if (state->RF_IN >= 43000000 && state->RF_IN < 174000000) | 2941 | if (state->RF_IN >= 43000000 && state->RF_IN < 174000000) { |
3176 | { | 2942 | status += MXL_ControlWrite(fe, DAC_B_ENABLE, 0); |
3177 | 2943 | status += MXL_SetGPIO(fe, 4, 0); | |
3178 | status += MXL_ControlWrite(fe, DAC_B_ENABLE, 0) ; // Bank4 Off | 2944 | status += MXL_SetGPIO(fe, 1, 1); |
3179 | status += MXL_SetGPIO(fe, 4, 0) ; // Bank1 On | 2945 | status += MXL_SetGPIO(fe, 3, 1); |
3180 | status += MXL_SetGPIO(fe, 1, 1) ; // Bank2 Off | 2946 | } |
3181 | status += MXL_SetGPIO(fe, 3, 1) ; // Bank3 Off | 2947 | if (state->RF_IN >= 174000000 && state->RF_IN < 250000000) { |
3182 | } | 2948 | status += MXL_ControlWrite(fe, DAC_B_ENABLE, 0); |
3183 | if (state->RF_IN >= 174000000 && state->RF_IN < 250000000) | 2949 | status += MXL_SetGPIO(fe, 4, 0); |
3184 | { | 2950 | status += MXL_SetGPIO(fe, 1, 0); |
3185 | status += MXL_ControlWrite(fe, DAC_B_ENABLE, 0) ; // Bank4 Off | 2951 | status += MXL_SetGPIO(fe, 3, 1); |
3186 | status += MXL_SetGPIO(fe, 4, 0) ; // Bank1 On | 2952 | } |
3187 | status += MXL_SetGPIO(fe, 1, 0) ; // Bank2 On | 2953 | if (state->RF_IN >= 250000000 && state->RF_IN < 310000000) { |
3188 | status += MXL_SetGPIO(fe, 3, 1) ; // Bank3 Off | 2954 | status += MXL_ControlWrite(fe, DAC_B_ENABLE, 0); |
3189 | } | 2955 | status += MXL_SetGPIO(fe, 4, 1); |
3190 | if (state->RF_IN >= 250000000 && state->RF_IN < 310000000) | 2956 | status += MXL_SetGPIO(fe, 1, 0); |
3191 | { | 2957 | status += MXL_SetGPIO(fe, 3, 1); |
3192 | status += MXL_ControlWrite(fe, DAC_B_ENABLE, 0) ; // Bank4 Off | 2958 | } |
3193 | status += MXL_SetGPIO(fe, 4, 1) ; // Bank1 Off | 2959 | if (state->RF_IN >= 310000000 && state->RF_IN < 360000000) { |
3194 | status += MXL_SetGPIO(fe, 1, 0) ; // Bank2 On | 2960 | status += MXL_ControlWrite(fe, DAC_B_ENABLE, 0); |
3195 | status += MXL_SetGPIO(fe, 3, 1) ; // Bank3 Off | 2961 | status += MXL_SetGPIO(fe, 4, 1); |
3196 | } | 2962 | status += MXL_SetGPIO(fe, 1, 0); |
3197 | if (state->RF_IN >= 310000000 && state->RF_IN < 360000000) | 2963 | status += MXL_SetGPIO(fe, 3, 0); |
3198 | { | 2964 | } |
3199 | status += MXL_ControlWrite(fe, DAC_B_ENABLE, 0) ; // Bank4 Off | 2965 | if (state->RF_IN >= 360000000 && state->RF_IN < 470000000) { |
3200 | status += MXL_SetGPIO(fe, 4, 1) ; // Bank1 Off | 2966 | status += MXL_ControlWrite(fe, DAC_B_ENABLE, 0); |
3201 | status += MXL_SetGPIO(fe, 1, 0) ; // Bank2 On | 2967 | status += MXL_SetGPIO(fe, 4, 1); |
3202 | status += MXL_SetGPIO(fe, 3, 0) ; // Bank3 On | 2968 | status += MXL_SetGPIO(fe, 1, 1); |
3203 | } | 2969 | status += MXL_SetGPIO(fe, 3, 0); |
3204 | if (state->RF_IN >= 360000000 && state->RF_IN < 470000000) | 2970 | } |
3205 | { | 2971 | if (state->RF_IN >= 470000000 && state->RF_IN < 640000000) { |
3206 | status += MXL_ControlWrite(fe, DAC_B_ENABLE, 0) ; // Bank4 Off | 2972 | status += MXL_ControlWrite(fe, DAC_B_ENABLE, 1); |
3207 | status += MXL_SetGPIO(fe, 4, 1) ; // Bank1 Off | 2973 | status += MXL_SetGPIO(fe, 4, 1); |
3208 | status += MXL_SetGPIO(fe, 1, 1) ; // Bank2 Off | 2974 | status += MXL_SetGPIO(fe, 1, 1); |
3209 | status += MXL_SetGPIO(fe, 3, 0) ; // Bank3 On | 2975 | status += MXL_SetGPIO(fe, 3, 0); |
3210 | } | 2976 | } |
3211 | if (state->RF_IN >= 470000000 && state->RF_IN < 640000000) | 2977 | if (state->RF_IN >= 640000000 && state->RF_IN <= 900000000) { |
3212 | { | 2978 | status += MXL_ControlWrite(fe, DAC_B_ENABLE, 1); |
3213 | status += MXL_ControlWrite(fe, DAC_B_ENABLE, 1) ; // Bank4 On | 2979 | status += MXL_SetGPIO(fe, 4, 1); |
3214 | status += MXL_SetGPIO(fe, 4, 1) ; // Bank1 Off | 2980 | status += MXL_SetGPIO(fe, 1, 1); |
3215 | status += MXL_SetGPIO(fe, 1, 1) ; // Bank2 Off | 2981 | status += MXL_SetGPIO(fe, 3, 1); |
3216 | status += MXL_SetGPIO(fe, 3, 0) ; // Bank3 On | ||
3217 | } | ||
3218 | if (state->RF_IN >= 640000000 && state->RF_IN <= 900000000) | ||
3219 | { | ||
3220 | status += MXL_ControlWrite(fe, DAC_B_ENABLE, 1) ; // Bank4 On | ||
3221 | status += MXL_SetGPIO(fe, 4, 1) ; // Bank1 Off | ||
3222 | status += MXL_SetGPIO(fe, 1, 1) ; // Bank2 Off | ||
3223 | status += MXL_SetGPIO(fe, 3, 1) ; // Bank3 Off | ||
3224 | } | 2982 | } |
3225 | } | 2983 | } |
3226 | 2984 | ||
3227 | 2985 | if (state->TF_Type == MXL_TF_D_L) { | |
3228 | if (state->TF_Type == MXL_TF_D_L) // Tracking Filter type D-L for Lumanate ONLY change for 2.6.3 | 2986 | |
3229 | { | 2987 | /* Tracking Filter type D-L for Lumanate ONLY change 2.6.3 */ |
3230 | status += MXL_ControlWrite(fe, DAC_DIN_A, 0) ; | 2988 | status += MXL_ControlWrite(fe, DAC_DIN_A, 0); |
3231 | 2989 | ||
3232 | // if UHF and terrestrial => Turn off Tracking Filter | 2990 | /* if UHF and terrestrial => Turn off Tracking Filter */ |
3233 | if (state->RF_IN >= 471000000 && (state->RF_IN - 471000000)%6000000 != 0) | 2991 | if (state->RF_IN >= 471000000 && |
3234 | { | 2992 | (state->RF_IN - 471000000)%6000000 != 0) { |
3235 | // Turn off all the banks | 2993 | /* Turn off all the banks */ |
3236 | status += MXL_SetGPIO(fe, 3, 1) ; | 2994 | status += MXL_SetGPIO(fe, 3, 1); |
3237 | status += MXL_SetGPIO(fe, 1, 1) ; | 2995 | status += MXL_SetGPIO(fe, 1, 1); |
3238 | status += MXL_SetGPIO(fe, 4, 1) ; | 2996 | status += MXL_SetGPIO(fe, 4, 1); |
3239 | status += MXL_ControlWrite(fe, DAC_A_ENABLE, 0) ; | 2997 | status += MXL_ControlWrite(fe, DAC_A_ENABLE, 0); |
3240 | 2998 | status += MXL_ControlWrite(fe, AGC_IF, 10); | |
3241 | status += MXL_ControlWrite(fe, AGC_IF, 10) ; | 2999 | } else { |
3242 | } | 3000 | /* if VHF or cable => Turn on Tracking Filter */ |
3243 | 3001 | if (state->RF_IN >= 43000000 && | |
3244 | else // if VHF or cable => Turn on Tracking Filter | 3002 | state->RF_IN < 140000000) { |
3245 | { | 3003 | |
3246 | if (state->RF_IN >= 43000000 && state->RF_IN < 140000000) | 3004 | status += MXL_ControlWrite(fe, DAC_A_ENABLE, 0); |
3247 | { | 3005 | status += MXL_SetGPIO(fe, 4, 1); |
3248 | 3006 | status += MXL_SetGPIO(fe, 1, 1); | |
3249 | status += MXL_ControlWrite(fe, DAC_A_ENABLE, 0) ; // Bank4 Off | 3007 | status += MXL_SetGPIO(fe, 3, 0); |
3250 | status += MXL_SetGPIO(fe, 4, 1) ; // Bank1 On | ||
3251 | status += MXL_SetGPIO(fe, 1, 1) ; // Bank2 Off | ||
3252 | status += MXL_SetGPIO(fe, 3, 0) ; // Bank3 Off | ||
3253 | } | 3008 | } |
3254 | if (state->RF_IN >= 140000000 && state->RF_IN < 240000000) | 3009 | if (state->RF_IN >= 140000000 && |
3255 | { | 3010 | state->RF_IN < 240000000) { |
3256 | status += MXL_ControlWrite(fe, DAC_A_ENABLE, 0) ; // Bank4 Off | 3011 | status += MXL_ControlWrite(fe, DAC_A_ENABLE, 0); |
3257 | status += MXL_SetGPIO(fe, 4, 1) ; // Bank1 On | 3012 | status += MXL_SetGPIO(fe, 4, 1); |
3258 | status += MXL_SetGPIO(fe, 1, 0) ; // Bank2 On | 3013 | status += MXL_SetGPIO(fe, 1, 0); |
3259 | status += MXL_SetGPIO(fe, 3, 0) ; // Bank3 Off | 3014 | status += MXL_SetGPIO(fe, 3, 0); |
3260 | } | 3015 | } |
3261 | if (state->RF_IN >= 240000000 && state->RF_IN < 340000000) | 3016 | if (state->RF_IN >= 240000000 && |
3262 | { | 3017 | state->RF_IN < 340000000) { |
3263 | status += MXL_ControlWrite(fe, DAC_A_ENABLE, 0) ; // Bank4 Off | 3018 | status += MXL_ControlWrite(fe, DAC_A_ENABLE, 0); |
3264 | status += MXL_SetGPIO(fe, 4, 0) ; // Bank1 Off | 3019 | status += MXL_SetGPIO(fe, 4, 0); |
3265 | status += MXL_SetGPIO(fe, 1, 1) ; // Bank2 On | 3020 | status += MXL_SetGPIO(fe, 1, 1); |
3266 | status += MXL_SetGPIO(fe, 3, 0) ; // Bank3 Off | 3021 | status += MXL_SetGPIO(fe, 3, 0); |
3267 | } | 3022 | } |
3268 | if (state->RF_IN >= 340000000 && state->RF_IN < 430000000) | 3023 | if (state->RF_IN >= 340000000 && |
3269 | { | 3024 | state->RF_IN < 430000000) { |
3270 | status += MXL_ControlWrite(fe, DAC_A_ENABLE, 0) ; // Bank4 Off | 3025 | status += MXL_ControlWrite(fe, DAC_A_ENABLE, 0); |
3271 | status += MXL_SetGPIO(fe, 4, 0) ; // Bank1 Off | 3026 | status += MXL_SetGPIO(fe, 4, 0); |
3272 | status += MXL_SetGPIO(fe, 1, 0) ; // Bank2 On | 3027 | status += MXL_SetGPIO(fe, 1, 0); |
3273 | status += MXL_SetGPIO(fe, 3, 1) ; // Bank3 On | 3028 | status += MXL_SetGPIO(fe, 3, 1); |
3274 | } | 3029 | } |
3275 | if (state->RF_IN >= 430000000 && state->RF_IN < 470000000) | 3030 | if (state->RF_IN >= 430000000 && |
3276 | { | 3031 | state->RF_IN < 470000000) { |
3277 | status += MXL_ControlWrite(fe, DAC_A_ENABLE, 1) ; // Bank4 Off | 3032 | status += MXL_ControlWrite(fe, DAC_A_ENABLE, 1); |
3278 | status += MXL_SetGPIO(fe, 4, 1) ; // Bank1 Off | 3033 | status += MXL_SetGPIO(fe, 4, 1); |
3279 | status += MXL_SetGPIO(fe, 1, 0) ; // Bank2 Off | 3034 | status += MXL_SetGPIO(fe, 1, 0); |
3280 | status += MXL_SetGPIO(fe, 3, 1) ; // Bank3 On | 3035 | status += MXL_SetGPIO(fe, 3, 1); |
3281 | } | 3036 | } |
3282 | if (state->RF_IN >= 470000000 && state->RF_IN < 570000000) | 3037 | if (state->RF_IN >= 470000000 && |
3283 | { | 3038 | state->RF_IN < 570000000) { |
3284 | status += MXL_ControlWrite(fe, DAC_A_ENABLE, 1) ; // Bank4 On | 3039 | status += MXL_ControlWrite(fe, DAC_A_ENABLE, 1); |
3285 | status += MXL_SetGPIO(fe, 4, 0) ; // Bank1 Off | 3040 | status += MXL_SetGPIO(fe, 4, 0); |
3286 | status += MXL_SetGPIO(fe, 1, 0) ; // Bank2 Off | 3041 | status += MXL_SetGPIO(fe, 1, 0); |
3287 | status += MXL_SetGPIO(fe, 3, 1) ; // Bank3 On | 3042 | status += MXL_SetGPIO(fe, 3, 1); |
3288 | } | 3043 | } |
3289 | if (state->RF_IN >= 570000000 && state->RF_IN < 620000000) | 3044 | if (state->RF_IN >= 570000000 && |
3290 | { | 3045 | state->RF_IN < 620000000) { |
3291 | status += MXL_ControlWrite(fe, DAC_A_ENABLE, 0) ; // Bank4 On | 3046 | status += MXL_ControlWrite(fe, DAC_A_ENABLE, 0); |
3292 | status += MXL_SetGPIO(fe, 4, 0) ; // Bank1 Off | 3047 | status += MXL_SetGPIO(fe, 4, 0); |
3293 | status += MXL_SetGPIO(fe, 1, 1) ; // Bank2 Off | 3048 | status += MXL_SetGPIO(fe, 1, 1); |
3294 | status += MXL_SetGPIO(fe, 3, 1) ; // Bank3 Offq | 3049 | status += MXL_SetGPIO(fe, 3, 1); |
3295 | } | 3050 | } |
3296 | if (state->RF_IN >= 620000000 && state->RF_IN < 760000000) | 3051 | if (state->RF_IN >= 620000000 && |
3297 | { | 3052 | state->RF_IN < 760000000) { |
3298 | status += MXL_ControlWrite(fe, DAC_A_ENABLE, 1) ; // Bank4 On | 3053 | status += MXL_ControlWrite(fe, DAC_A_ENABLE, 1); |
3299 | status += MXL_SetGPIO(fe, 4, 0) ; // Bank1 Off | 3054 | status += MXL_SetGPIO(fe, 4, 0); |
3300 | status += MXL_SetGPIO(fe, 1, 1) ; // Bank2 Off | 3055 | status += MXL_SetGPIO(fe, 1, 1); |
3301 | status += MXL_SetGPIO(fe, 3, 1) ; // Bank3 Off | 3056 | status += MXL_SetGPIO(fe, 3, 1); |
3302 | } | 3057 | } |
3303 | if (state->RF_IN >= 760000000 && state->RF_IN <= 900000000) | 3058 | if (state->RF_IN >= 760000000 && |
3304 | { | 3059 | state->RF_IN <= 900000000) { |
3305 | status += MXL_ControlWrite(fe, DAC_A_ENABLE, 1) ; // Bank4 On | 3060 | status += MXL_ControlWrite(fe, DAC_A_ENABLE, 1); |
3306 | status += MXL_SetGPIO(fe, 4, 1) ; // Bank1 Off | 3061 | status += MXL_SetGPIO(fe, 4, 1); |
3307 | status += MXL_SetGPIO(fe, 1, 1) ; // Bank2 Off | 3062 | status += MXL_SetGPIO(fe, 1, 1); |
3308 | status += MXL_SetGPIO(fe, 3, 1) ; // Bank3 Off | 3063 | status += MXL_SetGPIO(fe, 3, 1); |
3309 | } | 3064 | } |
3310 | } | 3065 | } |
3311 | } | 3066 | } |
3312 | 3067 | ||
3313 | if (state->TF_Type == MXL_TF_E) // Tracking Filter type E | 3068 | if (state->TF_Type == MXL_TF_E) /* Tracking Filter type E */ { |
3314 | { | 3069 | |
3315 | status += MXL_ControlWrite(fe, DAC_DIN_B, 0) ; | 3070 | status += MXL_ControlWrite(fe, DAC_DIN_B, 0); |
3316 | 3071 | ||
3317 | if (state->RF_IN >= 43000000 && state->RF_IN < 174000000) | 3072 | if (state->RF_IN >= 43000000 && state->RF_IN < 174000000) { |
3318 | { | 3073 | status += MXL_ControlWrite(fe, DAC_B_ENABLE, 0); |
3319 | 3074 | status += MXL_SetGPIO(fe, 4, 0); | |
3320 | status += MXL_ControlWrite(fe, DAC_B_ENABLE, 0) ; // Bank4 Off | 3075 | status += MXL_SetGPIO(fe, 1, 1); |
3321 | status += MXL_SetGPIO(fe, 4, 0) ; // Bank1 On | 3076 | status += MXL_SetGPIO(fe, 3, 1); |
3322 | status += MXL_SetGPIO(fe, 1, 1) ; // Bank2 Off | 3077 | } |
3323 | status += MXL_SetGPIO(fe, 3, 1) ; // Bank3 Off | 3078 | if (state->RF_IN >= 174000000 && state->RF_IN < 250000000) { |
3324 | } | 3079 | status += MXL_ControlWrite(fe, DAC_B_ENABLE, 0); |
3325 | if (state->RF_IN >= 174000000 && state->RF_IN < 250000000) | 3080 | status += MXL_SetGPIO(fe, 4, 0); |
3326 | { | 3081 | status += MXL_SetGPIO(fe, 1, 0); |
3327 | status += MXL_ControlWrite(fe, DAC_B_ENABLE, 0) ; // Bank4 Off | 3082 | status += MXL_SetGPIO(fe, 3, 1); |
3328 | status += MXL_SetGPIO(fe, 4, 0) ; // Bank1 On | 3083 | } |
3329 | status += MXL_SetGPIO(fe, 1, 0) ; // Bank2 On | 3084 | if (state->RF_IN >= 250000000 && state->RF_IN < 310000000) { |
3330 | status += MXL_SetGPIO(fe, 3, 1) ; // Bank3 Off | 3085 | status += MXL_ControlWrite(fe, DAC_B_ENABLE, 0); |
3331 | } | 3086 | status += MXL_SetGPIO(fe, 4, 1); |
3332 | if (state->RF_IN >= 250000000 && state->RF_IN < 310000000) | 3087 | status += MXL_SetGPIO(fe, 1, 0); |
3333 | { | 3088 | status += MXL_SetGPIO(fe, 3, 1); |
3334 | status += MXL_ControlWrite(fe, DAC_B_ENABLE, 0) ; // Bank4 Off | 3089 | } |
3335 | status += MXL_SetGPIO(fe, 4, 1) ; // Bank1 Off | 3090 | if (state->RF_IN >= 310000000 && state->RF_IN < 360000000) { |
3336 | status += MXL_SetGPIO(fe, 1, 0) ; // Bank2 On | 3091 | status += MXL_ControlWrite(fe, DAC_B_ENABLE, 0); |
3337 | status += MXL_SetGPIO(fe, 3, 1) ; // Bank3 Off | 3092 | status += MXL_SetGPIO(fe, 4, 1); |
3338 | } | 3093 | status += MXL_SetGPIO(fe, 1, 0); |
3339 | if (state->RF_IN >= 310000000 && state->RF_IN < 360000000) | 3094 | status += MXL_SetGPIO(fe, 3, 0); |
3340 | { | 3095 | } |
3341 | status += MXL_ControlWrite(fe, DAC_B_ENABLE, 0) ; // Bank4 Off | 3096 | if (state->RF_IN >= 360000000 && state->RF_IN < 470000000) { |
3342 | status += MXL_SetGPIO(fe, 4, 1) ; // Bank1 Off | 3097 | status += MXL_ControlWrite(fe, DAC_B_ENABLE, 0); |
3343 | status += MXL_SetGPIO(fe, 1, 0) ; // Bank2 On | 3098 | status += MXL_SetGPIO(fe, 4, 1); |
3344 | status += MXL_SetGPIO(fe, 3, 0) ; // Bank3 On | 3099 | status += MXL_SetGPIO(fe, 1, 1); |
3345 | } | 3100 | status += MXL_SetGPIO(fe, 3, 0); |
3346 | if (state->RF_IN >= 360000000 && state->RF_IN < 470000000) | 3101 | } |
3347 | { | 3102 | if (state->RF_IN >= 470000000 && state->RF_IN < 640000000) { |
3348 | status += MXL_ControlWrite(fe, DAC_B_ENABLE, 0) ; // Bank4 Off | 3103 | status += MXL_ControlWrite(fe, DAC_B_ENABLE, 1); |
3349 | status += MXL_SetGPIO(fe, 4, 1) ; // Bank1 Off | 3104 | status += MXL_SetGPIO(fe, 4, 1); |
3350 | status += MXL_SetGPIO(fe, 1, 1) ; // Bank2 Off | 3105 | status += MXL_SetGPIO(fe, 1, 1); |
3351 | status += MXL_SetGPIO(fe, 3, 0) ; // Bank3 On | 3106 | status += MXL_SetGPIO(fe, 3, 0); |
3352 | } | 3107 | } |
3353 | if (state->RF_IN >= 470000000 && state->RF_IN < 640000000) | 3108 | if (state->RF_IN >= 640000000 && state->RF_IN <= 900000000) { |
3354 | { | 3109 | status += MXL_ControlWrite(fe, DAC_B_ENABLE, 1); |
3355 | status += MXL_ControlWrite(fe, DAC_B_ENABLE, 1) ; // Bank4 On | 3110 | status += MXL_SetGPIO(fe, 4, 1); |
3356 | status += MXL_SetGPIO(fe, 4, 1) ; // Bank1 Off | 3111 | status += MXL_SetGPIO(fe, 1, 1); |
3357 | status += MXL_SetGPIO(fe, 1, 1) ; // Bank2 Off | 3112 | status += MXL_SetGPIO(fe, 3, 1); |
3358 | status += MXL_SetGPIO(fe, 3, 0) ; // Bank3 On | ||
3359 | } | ||
3360 | if (state->RF_IN >= 640000000 && state->RF_IN <= 900000000) | ||
3361 | { | ||
3362 | status += MXL_ControlWrite(fe, DAC_B_ENABLE, 1) ; // Bank4 On | ||
3363 | status += MXL_SetGPIO(fe, 4, 1) ; // Bank1 Off | ||
3364 | status += MXL_SetGPIO(fe, 1, 1) ; // Bank2 Off | ||
3365 | status += MXL_SetGPIO(fe, 3, 1) ; // Bank3 Off | ||
3366 | } | 3113 | } |
3367 | } | 3114 | } |
3368 | 3115 | ||
3369 | if (state->TF_Type == MXL_TF_F) // Tracking Filter type F | 3116 | if (state->TF_Type == MXL_TF_F) { |
3370 | { | 3117 | |
3371 | status += MXL_ControlWrite(fe, DAC_DIN_B, 0) ; | 3118 | /* Tracking Filter type F */ |
3372 | 3119 | status += MXL_ControlWrite(fe, DAC_DIN_B, 0); | |
3373 | if (state->RF_IN >= 43000000 && state->RF_IN < 160000000) | 3120 | |
3374 | { | 3121 | if (state->RF_IN >= 43000000 && state->RF_IN < 160000000) { |
3375 | 3122 | status += MXL_ControlWrite(fe, DAC_B_ENABLE, 0); | |
3376 | status += MXL_ControlWrite(fe, DAC_B_ENABLE, 0) ; // Bank4 Off | 3123 | status += MXL_SetGPIO(fe, 4, 0); |
3377 | status += MXL_SetGPIO(fe, 4, 0) ; // Bank1 On | 3124 | status += MXL_SetGPIO(fe, 1, 1); |
3378 | status += MXL_SetGPIO(fe, 1, 1) ; // Bank2 Off | 3125 | status += MXL_SetGPIO(fe, 3, 1); |
3379 | status += MXL_SetGPIO(fe, 3, 1) ; // Bank3 Off | 3126 | } |
3380 | } | 3127 | if (state->RF_IN >= 160000000 && state->RF_IN < 210000000) { |
3381 | if (state->RF_IN >= 160000000 && state->RF_IN < 210000000) | 3128 | status += MXL_ControlWrite(fe, DAC_B_ENABLE, 0); |
3382 | { | 3129 | status += MXL_SetGPIO(fe, 4, 0); |
3383 | status += MXL_ControlWrite(fe, DAC_B_ENABLE, 0) ; // Bank4 Off | 3130 | status += MXL_SetGPIO(fe, 1, 0); |
3384 | status += MXL_SetGPIO(fe, 4, 0) ; // Bank1 On | 3131 | status += MXL_SetGPIO(fe, 3, 1); |
3385 | status += MXL_SetGPIO(fe, 1, 0) ; // Bank2 On | 3132 | } |
3386 | status += MXL_SetGPIO(fe, 3, 1) ; // Bank3 Off | 3133 | if (state->RF_IN >= 210000000 && state->RF_IN < 300000000) { |
3387 | } | 3134 | status += MXL_ControlWrite(fe, DAC_B_ENABLE, 0); |
3388 | if (state->RF_IN >= 210000000 && state->RF_IN < 300000000) | 3135 | status += MXL_SetGPIO(fe, 4, 1); |
3389 | { | 3136 | status += MXL_SetGPIO(fe, 1, 0); |
3390 | status += MXL_ControlWrite(fe, DAC_B_ENABLE, 0) ; // Bank4 Off | 3137 | status += MXL_SetGPIO(fe, 3, 1); |
3391 | status += MXL_SetGPIO(fe, 4, 1) ; // Bank1 Off | 3138 | } |
3392 | status += MXL_SetGPIO(fe, 1, 0) ; // Bank2 On | 3139 | if (state->RF_IN >= 300000000 && state->RF_IN < 390000000) { |
3393 | status += MXL_SetGPIO(fe, 3, 1) ; // Bank3 Off | 3140 | status += MXL_ControlWrite(fe, DAC_B_ENABLE, 0); |
3394 | } | 3141 | status += MXL_SetGPIO(fe, 4, 1); |
3395 | if (state->RF_IN >= 300000000 && state->RF_IN < 390000000) | 3142 | status += MXL_SetGPIO(fe, 1, 0); |
3396 | { | 3143 | status += MXL_SetGPIO(fe, 3, 0); |
3397 | status += MXL_ControlWrite(fe, DAC_B_ENABLE, 0) ; // Bank4 Off | 3144 | } |
3398 | status += MXL_SetGPIO(fe, 4, 1) ; // Bank1 Off | 3145 | if (state->RF_IN >= 390000000 && state->RF_IN < 515000000) { |
3399 | status += MXL_SetGPIO(fe, 1, 0) ; // Bank2 On | 3146 | status += MXL_ControlWrite(fe, DAC_B_ENABLE, 0); |
3400 | status += MXL_SetGPIO(fe, 3, 0) ; // Bank3 On | 3147 | status += MXL_SetGPIO(fe, 4, 1); |
3401 | } | 3148 | status += MXL_SetGPIO(fe, 1, 1); |
3402 | if (state->RF_IN >= 390000000 && state->RF_IN < 515000000) | 3149 | status += MXL_SetGPIO(fe, 3, 0); |
3403 | { | 3150 | } |
3404 | status += MXL_ControlWrite(fe, DAC_B_ENABLE, 0) ; // Bank4 Off | 3151 | if (state->RF_IN >= 515000000 && state->RF_IN < 650000000) { |
3405 | status += MXL_SetGPIO(fe, 4, 1) ; // Bank1 Off | 3152 | status += MXL_ControlWrite(fe, DAC_B_ENABLE, 1); |
3406 | status += MXL_SetGPIO(fe, 1, 1) ; // Bank2 Off | 3153 | status += MXL_SetGPIO(fe, 4, 1); |
3407 | status += MXL_SetGPIO(fe, 3, 0) ; // Bank3 On | 3154 | status += MXL_SetGPIO(fe, 1, 1); |
3408 | } | 3155 | status += MXL_SetGPIO(fe, 3, 0); |
3409 | if (state->RF_IN >= 515000000 && state->RF_IN < 650000000) | 3156 | } |
3410 | { | 3157 | if (state->RF_IN >= 650000000 && state->RF_IN <= 900000000) { |
3411 | status += MXL_ControlWrite(fe, DAC_B_ENABLE, 1) ; // Bank4 On | 3158 | status += MXL_ControlWrite(fe, DAC_B_ENABLE, 1); |
3412 | status += MXL_SetGPIO(fe, 4, 1) ; // Bank1 Off | 3159 | status += MXL_SetGPIO(fe, 4, 1); |
3413 | status += MXL_SetGPIO(fe, 1, 1) ; // Bank2 Off | 3160 | status += MXL_SetGPIO(fe, 1, 1); |
3414 | status += MXL_SetGPIO(fe, 3, 0) ; // Bank3 On | 3161 | status += MXL_SetGPIO(fe, 3, 1); |
3415 | } | ||
3416 | if (state->RF_IN >= 650000000 && state->RF_IN <= 900000000) | ||
3417 | { | ||
3418 | status += MXL_ControlWrite(fe, DAC_B_ENABLE, 1) ; // Bank4 On | ||
3419 | status += MXL_SetGPIO(fe, 4, 1) ; // Bank1 Off | ||
3420 | status += MXL_SetGPIO(fe, 1, 1) ; // Bank2 Off | ||
3421 | status += MXL_SetGPIO(fe, 3, 1) ; // Bank3 Off | ||
3422 | } | 3162 | } |
3423 | } | 3163 | } |
3424 | 3164 | ||
3425 | if (state->TF_Type == MXL_TF_E_2) // Tracking Filter type E_2 | 3165 | if (state->TF_Type == MXL_TF_E_2) { |
3426 | { | 3166 | |
3427 | status += MXL_ControlWrite(fe, DAC_DIN_B, 0) ; | 3167 | /* Tracking Filter type E_2 */ |
3428 | 3168 | status += MXL_ControlWrite(fe, DAC_DIN_B, 0); | |
3429 | if (state->RF_IN >= 43000000 && state->RF_IN < 174000000) | 3169 | |
3430 | { | 3170 | if (state->RF_IN >= 43000000 && state->RF_IN < 174000000) { |
3431 | 3171 | status += MXL_ControlWrite(fe, DAC_B_ENABLE, 0); | |
3432 | status += MXL_ControlWrite(fe, DAC_B_ENABLE, 0) ; // Bank4 Off | 3172 | status += MXL_SetGPIO(fe, 4, 0); |
3433 | status += MXL_SetGPIO(fe, 4, 0) ; // Bank1 On | 3173 | status += MXL_SetGPIO(fe, 1, 1); |
3434 | status += MXL_SetGPIO(fe, 1, 1) ; // Bank2 Off | 3174 | status += MXL_SetGPIO(fe, 3, 1); |
3435 | status += MXL_SetGPIO(fe, 3, 1) ; // Bank3 Off | 3175 | } |
3436 | } | 3176 | if (state->RF_IN >= 174000000 && state->RF_IN < 250000000) { |
3437 | if (state->RF_IN >= 174000000 && state->RF_IN < 250000000) | 3177 | status += MXL_ControlWrite(fe, DAC_B_ENABLE, 0); |
3438 | { | 3178 | status += MXL_SetGPIO(fe, 4, 0); |
3439 | status += MXL_ControlWrite(fe, DAC_B_ENABLE, 0) ; // Bank4 Off | 3179 | status += MXL_SetGPIO(fe, 1, 0); |
3440 | status += MXL_SetGPIO(fe, 4, 0) ; // Bank1 On | 3180 | status += MXL_SetGPIO(fe, 3, 1); |
3441 | status += MXL_SetGPIO(fe, 1, 0) ; // Bank2 On | 3181 | } |
3442 | status += MXL_SetGPIO(fe, 3, 1) ; // Bank3 Off | 3182 | if (state->RF_IN >= 250000000 && state->RF_IN < 350000000) { |
3443 | } | 3183 | status += MXL_ControlWrite(fe, DAC_B_ENABLE, 0); |
3444 | if (state->RF_IN >= 250000000 && state->RF_IN < 350000000) | 3184 | status += MXL_SetGPIO(fe, 4, 1); |
3445 | { | 3185 | status += MXL_SetGPIO(fe, 1, 0); |
3446 | status += MXL_ControlWrite(fe, DAC_B_ENABLE, 0) ; // Bank4 Off | 3186 | status += MXL_SetGPIO(fe, 3, 1); |
3447 | status += MXL_SetGPIO(fe, 4, 1) ; // Bank1 Off | 3187 | } |
3448 | status += MXL_SetGPIO(fe, 1, 0) ; // Bank2 On | 3188 | if (state->RF_IN >= 350000000 && state->RF_IN < 400000000) { |
3449 | status += MXL_SetGPIO(fe, 3, 1) ; // Bank3 Off | 3189 | status += MXL_ControlWrite(fe, DAC_B_ENABLE, 0); |
3450 | } | 3190 | status += MXL_SetGPIO(fe, 4, 1); |
3451 | if (state->RF_IN >= 350000000 && state->RF_IN < 400000000) | 3191 | status += MXL_SetGPIO(fe, 1, 0); |
3452 | { | 3192 | status += MXL_SetGPIO(fe, 3, 0); |
3453 | status += MXL_ControlWrite(fe, DAC_B_ENABLE, 0) ; // Bank4 Off | 3193 | } |
3454 | status += MXL_SetGPIO(fe, 4, 1) ; // Bank1 Off | 3194 | if (state->RF_IN >= 400000000 && state->RF_IN < 570000000) { |
3455 | status += MXL_SetGPIO(fe, 1, 0) ; // Bank2 On | 3195 | status += MXL_ControlWrite(fe, DAC_B_ENABLE, 0); |
3456 | status += MXL_SetGPIO(fe, 3, 0) ; // Bank3 On | 3196 | status += MXL_SetGPIO(fe, 4, 1); |
3457 | } | 3197 | status += MXL_SetGPIO(fe, 1, 1); |
3458 | if (state->RF_IN >= 400000000 && state->RF_IN < 570000000) | 3198 | status += MXL_SetGPIO(fe, 3, 0); |
3459 | { | 3199 | } |
3460 | status += MXL_ControlWrite(fe, DAC_B_ENABLE, 0) ; // Bank4 Off | 3200 | if (state->RF_IN >= 570000000 && state->RF_IN < 770000000) { |
3461 | status += MXL_SetGPIO(fe, 4, 1) ; // Bank1 Off | 3201 | status += MXL_ControlWrite(fe, DAC_B_ENABLE, 1); |
3462 | status += MXL_SetGPIO(fe, 1, 1) ; // Bank2 Off | 3202 | status += MXL_SetGPIO(fe, 4, 1); |
3463 | status += MXL_SetGPIO(fe, 3, 0) ; // Bank3 On | 3203 | status += MXL_SetGPIO(fe, 1, 1); |
3464 | } | 3204 | status += MXL_SetGPIO(fe, 3, 0); |
3465 | if (state->RF_IN >= 570000000 && state->RF_IN < 770000000) | 3205 | } |
3466 | { | 3206 | if (state->RF_IN >= 770000000 && state->RF_IN <= 900000000) { |
3467 | status += MXL_ControlWrite(fe, DAC_B_ENABLE, 1) ; // Bank4 On | 3207 | status += MXL_ControlWrite(fe, DAC_B_ENABLE, 1); |
3468 | status += MXL_SetGPIO(fe, 4, 1) ; // Bank1 Off | 3208 | status += MXL_SetGPIO(fe, 4, 1); |
3469 | status += MXL_SetGPIO(fe, 1, 1) ; // Bank2 Off | 3209 | status += MXL_SetGPIO(fe, 1, 1); |
3470 | status += MXL_SetGPIO(fe, 3, 0) ; // Bank3 On | 3210 | status += MXL_SetGPIO(fe, 3, 1); |
3471 | } | ||
3472 | if (state->RF_IN >= 770000000 && state->RF_IN <= 900000000) | ||
3473 | { | ||
3474 | status += MXL_ControlWrite(fe, DAC_B_ENABLE, 1) ; // Bank4 On | ||
3475 | status += MXL_SetGPIO(fe, 4, 1) ; // Bank1 Off | ||
3476 | status += MXL_SetGPIO(fe, 1, 1) ; // Bank2 Off | ||
3477 | status += MXL_SetGPIO(fe, 3, 1) ; // Bank3 Off | ||
3478 | } | 3211 | } |
3479 | } | 3212 | } |
3480 | 3213 | ||
3481 | if (state->TF_Type == MXL_TF_G) // Tracking Filter type G add for v2.6.8 | 3214 | if (state->TF_Type == MXL_TF_G) { |
3482 | { | 3215 | |
3483 | status += MXL_ControlWrite(fe, DAC_DIN_B, 0) ; | 3216 | /* Tracking Filter type G add for v2.6.8 */ |
3484 | 3217 | status += MXL_ControlWrite(fe, DAC_DIN_B, 0); | |
3485 | if (state->RF_IN >= 50000000 && state->RF_IN < 190000000) | 3218 | |
3486 | { | 3219 | if (state->RF_IN >= 50000000 && state->RF_IN < 190000000) { |
3487 | 3220 | ||
3488 | status += MXL_ControlWrite(fe, DAC_B_ENABLE, 0) ; // Bank4 Off | 3221 | status += MXL_ControlWrite(fe, DAC_B_ENABLE, 0); |
3489 | status += MXL_SetGPIO(fe, 4, 0) ; // Bank1 On | 3222 | status += MXL_SetGPIO(fe, 4, 0); |
3490 | status += MXL_SetGPIO(fe, 1, 1) ; // Bank2 Off | 3223 | status += MXL_SetGPIO(fe, 1, 1); |
3491 | status += MXL_SetGPIO(fe, 3, 1) ; // Bank3 Off | 3224 | status += MXL_SetGPIO(fe, 3, 1); |
3492 | } | 3225 | } |
3493 | if (state->RF_IN >= 190000000 && state->RF_IN < 280000000) | 3226 | if (state->RF_IN >= 190000000 && state->RF_IN < 280000000) { |
3494 | { | 3227 | status += MXL_ControlWrite(fe, DAC_B_ENABLE, 0); |
3495 | status += MXL_ControlWrite(fe, DAC_B_ENABLE, 0) ; // Bank4 Off | 3228 | status += MXL_SetGPIO(fe, 4, 0); |
3496 | status += MXL_SetGPIO(fe, 4, 0) ; // Bank1 On | 3229 | status += MXL_SetGPIO(fe, 1, 0); |
3497 | status += MXL_SetGPIO(fe, 1, 0) ; // Bank2 On | 3230 | status += MXL_SetGPIO(fe, 3, 1); |
3498 | status += MXL_SetGPIO(fe, 3, 1) ; // Bank3 Off | 3231 | } |
3499 | } | 3232 | if (state->RF_IN >= 280000000 && state->RF_IN < 350000000) { |
3500 | if (state->RF_IN >= 280000000 && state->RF_IN < 350000000) | 3233 | status += MXL_ControlWrite(fe, DAC_B_ENABLE, 0); |
3501 | { | 3234 | status += MXL_SetGPIO(fe, 4, 1); |
3502 | status += MXL_ControlWrite(fe, DAC_B_ENABLE, 0) ; // Bank4 Off | 3235 | status += MXL_SetGPIO(fe, 1, 0); |
3503 | status += MXL_SetGPIO(fe, 4, 1) ; // Bank1 Off | 3236 | status += MXL_SetGPIO(fe, 3, 1); |
3504 | status += MXL_SetGPIO(fe, 1, 0) ; // Bank2 On | 3237 | } |
3505 | status += MXL_SetGPIO(fe, 3, 1) ; // Bank3 Off | 3238 | if (state->RF_IN >= 350000000 && state->RF_IN < 400000000) { |
3506 | } | 3239 | status += MXL_ControlWrite(fe, DAC_B_ENABLE, 0); |
3507 | if (state->RF_IN >= 350000000 && state->RF_IN < 400000000) | 3240 | status += MXL_SetGPIO(fe, 4, 1); |
3508 | { | 3241 | status += MXL_SetGPIO(fe, 1, 0); |
3509 | status += MXL_ControlWrite(fe, DAC_B_ENABLE, 0) ; // Bank4 Off | 3242 | status += MXL_SetGPIO(fe, 3, 0); |
3510 | status += MXL_SetGPIO(fe, 4, 1) ; // Bank1 Off | 3243 | } |
3511 | status += MXL_SetGPIO(fe, 1, 0) ; // Bank2 On | 3244 | if (state->RF_IN >= 400000000 && state->RF_IN < 470000000) { |
3512 | status += MXL_SetGPIO(fe, 3, 0) ; // Bank3 On | 3245 | status += MXL_ControlWrite(fe, DAC_B_ENABLE, 1); |
3513 | } | 3246 | status += MXL_SetGPIO(fe, 4, 1); |
3514 | if (state->RF_IN >= 400000000 && state->RF_IN < 470000000) //modified for 2.6.11 | 3247 | status += MXL_SetGPIO(fe, 1, 0); |
3515 | { | 3248 | status += MXL_SetGPIO(fe, 3, 1); |
3516 | status += MXL_ControlWrite(fe, DAC_B_ENABLE, 1) ; // Bank4 On | 3249 | } |
3517 | status += MXL_SetGPIO(fe, 4, 1) ; // Bank1 On | 3250 | if (state->RF_IN >= 470000000 && state->RF_IN < 640000000) { |
3518 | status += MXL_SetGPIO(fe, 1, 0) ; // Bank2 Off | 3251 | status += MXL_ControlWrite(fe, DAC_B_ENABLE, 0); |
3519 | status += MXL_SetGPIO(fe, 3, 1) ; // Bank3 Off | 3252 | status += MXL_SetGPIO(fe, 4, 1); |
3520 | } | 3253 | status += MXL_SetGPIO(fe, 1, 1); |
3521 | if (state->RF_IN >= 470000000 && state->RF_IN < 640000000) | 3254 | status += MXL_SetGPIO(fe, 3, 0); |
3522 | { | 3255 | } |
3523 | status += MXL_ControlWrite(fe, DAC_B_ENABLE, 0) ; // Bank4 Off | 3256 | if (state->RF_IN >= 640000000 && state->RF_IN < 820000000) { |
3524 | status += MXL_SetGPIO(fe, 4, 1) ; // Bank1 Off | 3257 | status += MXL_ControlWrite(fe, DAC_B_ENABLE, 1); |
3525 | status += MXL_SetGPIO(fe, 1, 1) ; // Bank2 Off | 3258 | status += MXL_SetGPIO(fe, 4, 1); |
3526 | status += MXL_SetGPIO(fe, 3, 0) ; // Bank3 On | 3259 | status += MXL_SetGPIO(fe, 1, 1); |
3527 | } | 3260 | status += MXL_SetGPIO(fe, 3, 0); |
3528 | if (state->RF_IN >= 640000000 && state->RF_IN < 820000000) | 3261 | } |
3529 | { | 3262 | if (state->RF_IN >= 820000000 && state->RF_IN <= 900000000) { |
3530 | status += MXL_ControlWrite(fe, DAC_B_ENABLE, 1) ; // Bank4 On | 3263 | status += MXL_ControlWrite(fe, DAC_B_ENABLE, 1); |
3531 | status += MXL_SetGPIO(fe, 4, 1) ; // Bank1 Off | 3264 | status += MXL_SetGPIO(fe, 4, 1); |
3532 | status += MXL_SetGPIO(fe, 1, 1) ; // Bank2 Off | 3265 | status += MXL_SetGPIO(fe, 1, 1); |
3533 | status += MXL_SetGPIO(fe, 3, 0) ; // Bank3 On | 3266 | status += MXL_SetGPIO(fe, 3, 1); |
3534 | } | ||
3535 | if (state->RF_IN >= 820000000 && state->RF_IN <= 900000000) | ||
3536 | { | ||
3537 | status += MXL_ControlWrite(fe, DAC_B_ENABLE, 1) ; // Bank4 On | ||
3538 | status += MXL_SetGPIO(fe, 4, 1) ; // Bank1 Off | ||
3539 | status += MXL_SetGPIO(fe, 1, 1) ; // Bank2 Off | ||
3540 | status += MXL_SetGPIO(fe, 3, 1) ; // Bank3 Off | ||
3541 | } | 3267 | } |
3542 | } | 3268 | } |
3543 | 3269 | ||
3544 | if (state->TF_Type == MXL_TF_E_NA) // Tracking Filter type E-NA for Empia ONLY change for 2.6.8 | 3270 | if (state->TF_Type == MXL_TF_E_NA) { |
3545 | { | 3271 | |
3546 | status += MXL_ControlWrite(fe, DAC_DIN_B, 0) ; | 3272 | /* Tracking Filter type E-NA for Empia ONLY change for 2.6.8 */ |
3547 | 3273 | status += MXL_ControlWrite(fe, DAC_DIN_B, 0); | |
3548 | // if UHF and terrestrial=> Turn off Tracking Filter | 3274 | |
3549 | if (state->RF_IN >= 471000000 && (state->RF_IN - 471000000)%6000000 != 0) | 3275 | /* if UHF and terrestrial=> Turn off Tracking Filter */ |
3550 | { | 3276 | if (state->RF_IN >= 471000000 && |
3551 | // Turn off all the banks | 3277 | (state->RF_IN - 471000000)%6000000 != 0) { |
3552 | status += MXL_SetGPIO(fe, 3, 1) ; | 3278 | |
3553 | status += MXL_SetGPIO(fe, 1, 1) ; | 3279 | /* Turn off all the banks */ |
3554 | status += MXL_SetGPIO(fe, 4, 1) ; | 3280 | status += MXL_SetGPIO(fe, 3, 1); |
3555 | status += MXL_ControlWrite(fe, DAC_B_ENABLE, 0) ; | 3281 | status += MXL_SetGPIO(fe, 1, 1); |
3556 | 3282 | status += MXL_SetGPIO(fe, 4, 1); | |
3557 | //2.6.12 | 3283 | status += MXL_ControlWrite(fe, DAC_B_ENABLE, 0); |
3558 | //Turn on RSSI | 3284 | |
3559 | status += MXL_ControlWrite(fe, SEQ_EXTSYNTHCALIF, 1) ; | 3285 | /* 2.6.12 Turn on RSSI */ |
3560 | status += MXL_ControlWrite(fe, SEQ_EXTDCCAL, 1) ; | 3286 | status += MXL_ControlWrite(fe, SEQ_EXTSYNTHCALIF, 1); |
3561 | status += MXL_ControlWrite(fe, AGC_EN_RSSI, 1) ; | 3287 | status += MXL_ControlWrite(fe, SEQ_EXTDCCAL, 1); |
3562 | status += MXL_ControlWrite(fe, RFA_ENCLKRFAGC, 1) ; | 3288 | status += MXL_ControlWrite(fe, AGC_EN_RSSI, 1); |
3563 | 3289 | status += MXL_ControlWrite(fe, RFA_ENCLKRFAGC, 1); | |
3564 | // RSSI reference point | 3290 | |
3565 | status += MXL_ControlWrite(fe, RFA_RSSI_REFH, 5) ; | 3291 | /* RSSI reference point */ |
3566 | status += MXL_ControlWrite(fe, RFA_RSSI_REF, 3) ; | 3292 | status += MXL_ControlWrite(fe, RFA_RSSI_REFH, 5); |
3567 | status += MXL_ControlWrite(fe, RFA_RSSI_REFL, 2) ; | 3293 | status += MXL_ControlWrite(fe, RFA_RSSI_REF, 3); |
3568 | 3294 | status += MXL_ControlWrite(fe, RFA_RSSI_REFL, 2); | |
3569 | 3295 | ||
3570 | //status += MXL_ControlWrite(fe, AGC_IF, 10) ; //doesn't matter since RSSI is turn on | 3296 | /* following parameter is from analog OTA mode, |
3571 | 3297 | * can be change to seek better performance */ | |
3572 | //following parameter is from analog OTA mode, can be change to seek better performance | 3298 | status += MXL_ControlWrite(fe, RFSYN_CHP_GAIN, 3); |
3573 | status += MXL_ControlWrite(fe, RFSYN_CHP_GAIN, 3) ; | 3299 | } else { |
3574 | } | 3300 | /* if VHF or Cable => Turn on Tracking Filter */ |
3575 | 3301 | ||
3576 | else //if VHF or Cable => Turn on Tracking Filter | 3302 | /* 2.6.12 Turn off RSSI */ |
3577 | { | 3303 | status += MXL_ControlWrite(fe, AGC_EN_RSSI, 0); |
3578 | //2.6.12 | 3304 | |
3579 | //Turn off RSSI | 3305 | /* change back from above condition */ |
3580 | status += MXL_ControlWrite(fe, AGC_EN_RSSI, 0) ; | 3306 | status += MXL_ControlWrite(fe, RFSYN_CHP_GAIN, 5); |
3581 | 3307 | ||
3582 | //change back from above condition | 3308 | |
3583 | status += MXL_ControlWrite(fe, RFSYN_CHP_GAIN, 5) ; | 3309 | if (state->RF_IN >= 43000000 && state->RF_IN < 174000000) { |
3584 | 3310 | ||
3585 | 3311 | status += MXL_ControlWrite(fe, DAC_B_ENABLE, 0); | |
3586 | if (state->RF_IN >= 43000000 && state->RF_IN < 174000000) | 3312 | status += MXL_SetGPIO(fe, 4, 0); |
3587 | { | 3313 | status += MXL_SetGPIO(fe, 1, 1); |
3588 | 3314 | status += MXL_SetGPIO(fe, 3, 1); | |
3589 | status += MXL_ControlWrite(fe, DAC_B_ENABLE, 0) ; // Bank4 Off | 3315 | } |
3590 | status += MXL_SetGPIO(fe, 4, 0) ; // Bank1 On | 3316 | if (state->RF_IN >= 174000000 && state->RF_IN < 250000000) { |
3591 | status += MXL_SetGPIO(fe, 1, 1) ; // Bank2 Off | 3317 | status += MXL_ControlWrite(fe, DAC_B_ENABLE, 0); |
3592 | status += MXL_SetGPIO(fe, 3, 1) ; // Bank3 Off | 3318 | status += MXL_SetGPIO(fe, 4, 0); |
3593 | } | 3319 | status += MXL_SetGPIO(fe, 1, 0); |
3594 | if (state->RF_IN >= 174000000 && state->RF_IN < 250000000) | 3320 | status += MXL_SetGPIO(fe, 3, 1); |
3595 | { | 3321 | } |
3596 | status += MXL_ControlWrite(fe, DAC_B_ENABLE, 0) ; // Bank4 Off | 3322 | if (state->RF_IN >= 250000000 && state->RF_IN < 350000000) { |
3597 | status += MXL_SetGPIO(fe, 4, 0) ; // Bank1 On | 3323 | status += MXL_ControlWrite(fe, DAC_B_ENABLE, 0); |
3598 | status += MXL_SetGPIO(fe, 1, 0) ; // Bank2 On | 3324 | status += MXL_SetGPIO(fe, 4, 1); |
3599 | status += MXL_SetGPIO(fe, 3, 1) ; // Bank3 Off | 3325 | status += MXL_SetGPIO(fe, 1, 0); |
3600 | } | 3326 | status += MXL_SetGPIO(fe, 3, 1); |
3601 | if (state->RF_IN >= 250000000 && state->RF_IN < 350000000) | 3327 | } |
3602 | { | 3328 | if (state->RF_IN >= 350000000 && state->RF_IN < 400000000) { |
3603 | status += MXL_ControlWrite(fe, DAC_B_ENABLE, 0) ; // Bank4 Off | 3329 | status += MXL_ControlWrite(fe, DAC_B_ENABLE, 0); |
3604 | status += MXL_SetGPIO(fe, 4, 1) ; // Bank1 Off | 3330 | status += MXL_SetGPIO(fe, 4, 1); |
3605 | status += MXL_SetGPIO(fe, 1, 0) ; // Bank2 On | 3331 | status += MXL_SetGPIO(fe, 1, 0); |
3606 | status += MXL_SetGPIO(fe, 3, 1) ; // Bank3 Off | 3332 | status += MXL_SetGPIO(fe, 3, 0); |
3607 | } | 3333 | } |
3608 | if (state->RF_IN >= 350000000 && state->RF_IN < 400000000) | 3334 | if (state->RF_IN >= 400000000 && state->RF_IN < 570000000) { |
3609 | { | 3335 | status += MXL_ControlWrite(fe, DAC_B_ENABLE, 0); |
3610 | status += MXL_ControlWrite(fe, DAC_B_ENABLE, 0) ; // Bank4 Off | 3336 | status += MXL_SetGPIO(fe, 4, 1); |
3611 | status += MXL_SetGPIO(fe, 4, 1) ; // Bank1 Off | 3337 | status += MXL_SetGPIO(fe, 1, 1); |
3612 | status += MXL_SetGPIO(fe, 1, 0) ; // Bank2 On | 3338 | status += MXL_SetGPIO(fe, 3, 0); |
3613 | status += MXL_SetGPIO(fe, 3, 0) ; // Bank3 On | 3339 | } |
3614 | } | 3340 | if (state->RF_IN >= 570000000 && state->RF_IN < 770000000) { |
3615 | if (state->RF_IN >= 400000000 && state->RF_IN < 570000000) | 3341 | status += MXL_ControlWrite(fe, DAC_B_ENABLE, 1); |
3616 | { | 3342 | status += MXL_SetGPIO(fe, 4, 1); |
3617 | status += MXL_ControlWrite(fe, DAC_B_ENABLE, 0) ; // Bank4 Off | 3343 | status += MXL_SetGPIO(fe, 1, 1); |
3618 | status += MXL_SetGPIO(fe, 4, 1) ; // Bank1 Off | 3344 | status += MXL_SetGPIO(fe, 3, 0); |
3619 | status += MXL_SetGPIO(fe, 1, 1) ; // Bank2 Off | 3345 | } |
3620 | status += MXL_SetGPIO(fe, 3, 0) ; // Bank3 On | 3346 | if (state->RF_IN >= 770000000 && state->RF_IN <= 900000000) { |
3621 | } | 3347 | status += MXL_ControlWrite(fe, DAC_B_ENABLE, 1); |
3622 | if (state->RF_IN >= 570000000 && state->RF_IN < 770000000) | 3348 | status += MXL_SetGPIO(fe, 4, 1); |
3623 | { | 3349 | status += MXL_SetGPIO(fe, 1, 1); |
3624 | status += MXL_ControlWrite(fe, DAC_B_ENABLE, 1) ; // Bank4 On | 3350 | status += MXL_SetGPIO(fe, 3, 1); |
3625 | status += MXL_SetGPIO(fe, 4, 1) ; // Bank1 Off | ||
3626 | status += MXL_SetGPIO(fe, 1, 1) ; // Bank2 Off | ||
3627 | status += MXL_SetGPIO(fe, 3, 0) ; // Bank3 On | ||
3628 | } | ||
3629 | if (state->RF_IN >= 770000000 && state->RF_IN <= 900000000) | ||
3630 | { | ||
3631 | status += MXL_ControlWrite(fe, DAC_B_ENABLE, 1) ; // Bank4 On | ||
3632 | status += MXL_SetGPIO(fe, 4, 1) ; // Bank1 Off | ||
3633 | status += MXL_SetGPIO(fe, 1, 1) ; // Bank2 Off | ||
3634 | status += MXL_SetGPIO(fe, 3, 1) ; // Bank3 Off | ||
3635 | } | 3351 | } |
3636 | } | 3352 | } |
3637 | } | 3353 | } |
@@ -3679,72 +3395,24 @@ u16 MXL_SetGPIO(struct dvb_frontend *fe, u8 GPIO_Num, u8 GPIO_Val) | |||
3679 | return status; | 3395 | return status; |
3680 | } | 3396 | } |
3681 | 3397 | ||
3682 | /////////////////////////////////////////////////////////////////////////////// | ||
3683 | // // | ||
3684 | // Function: MXL_ControlWrite // | ||
3685 | // // | ||
3686 | // Description: Update control name value // | ||
3687 | // // | ||
3688 | // Globals: // | ||
3689 | // NONE // | ||
3690 | // // | ||
3691 | // Functions used: // | ||
3692 | // MXL_ControlWrite( Tuner, controlName, value, Group ) // | ||
3693 | // // | ||
3694 | // Inputs: // | ||
3695 | // Tuner : Tuner structure // | ||
3696 | // ControlName : Control name to be updated // | ||
3697 | // value : Value to be written // | ||
3698 | // // | ||
3699 | // Outputs: // | ||
3700 | // Tuner : Tuner structure defined at higher level // | ||
3701 | // // | ||
3702 | // Return: // | ||
3703 | // 0 : Successful write // | ||
3704 | // >0 : Value exceed maximum allowed for control number // | ||
3705 | // // | ||
3706 | /////////////////////////////////////////////////////////////////////////////// | ||
3707 | u16 MXL_ControlWrite(struct dvb_frontend *fe, u16 ControlNum, u32 value) | 3398 | u16 MXL_ControlWrite(struct dvb_frontend *fe, u16 ControlNum, u32 value) |
3708 | { | 3399 | { |
3709 | u16 status = 0; | 3400 | u16 status = 0; |
3710 | 3401 | ||
3711 | /* Will write ALL Matching Control Name */ | 3402 | /* Will write ALL Matching Control Name */ |
3712 | status += MXL_ControlWrite_Group(fe, ControlNum, value, 1); /* Write Matching INIT Control */ | 3403 | /* Write Matching INIT Control */ |
3713 | status += MXL_ControlWrite_Group(fe, ControlNum, value, 2); /* Write Matching CH Control */ | 3404 | status += MXL_ControlWrite_Group(fe, ControlNum, value, 1); |
3405 | /* Write Matching CH Control */ | ||
3406 | status += MXL_ControlWrite_Group(fe, ControlNum, value, 2); | ||
3714 | #ifdef _MXL_INTERNAL | 3407 | #ifdef _MXL_INTERNAL |
3715 | status += MXL_ControlWrite_Group(fe, ControlNum, value, 3); /* Write Matching MXL Control */ | 3408 | /* Write Matching MXL Control */ |
3409 | status += MXL_ControlWrite_Group(fe, ControlNum, value, 3); | ||
3716 | #endif | 3410 | #endif |
3717 | return status; | 3411 | return status; |
3718 | } | 3412 | } |
3719 | 3413 | ||
3720 | /////////////////////////////////////////////////////////////////////////////// | 3414 | u16 MXL_ControlWrite_Group(struct dvb_frontend *fe, u16 controlNum, u32 value, |
3721 | // // | 3415 | u16 controlGroup) |
3722 | // Function: MXL_ControlWrite // | ||
3723 | // // | ||
3724 | // Description: Update control name value // | ||
3725 | // // | ||
3726 | // Globals: // | ||
3727 | // NONE // | ||
3728 | // // | ||
3729 | // Functions used: // | ||
3730 | // strcmp // | ||
3731 | // // | ||
3732 | // Inputs: // | ||
3733 | // Tuner_struct: structure defined at higher level // | ||
3734 | // ControlName : Control Name // | ||
3735 | // value : Value Assigned to Control Name // | ||
3736 | // controlGroup : Control Register Group // | ||
3737 | // // | ||
3738 | // Outputs: // | ||
3739 | // NONE // | ||
3740 | // // | ||
3741 | // Return: // | ||
3742 | // 0 : Successful write // | ||
3743 | // 1 : Value exceed maximum allowed for control name // | ||
3744 | // 2 : Control name not found // | ||
3745 | // // | ||
3746 | /////////////////////////////////////////////////////////////////////////////// | ||
3747 | u16 MXL_ControlWrite_Group(struct dvb_frontend *fe, u16 controlNum, u32 value, u16 controlGroup) | ||
3748 | { | 3416 | { |
3749 | struct mxl5005s_state *state = fe->tuner_priv; | 3417 | struct mxl5005s_state *state = fe->tuner_priv; |
3750 | u16 i, j, k; | 3418 | u16 i, j, k; |
@@ -3763,13 +3431,12 @@ u16 MXL_ControlWrite_Group(struct dvb_frontend *fe, u16 controlNum, u32 value, u | |||
3763 | state->Init_Ctrl[i].val[j] = (u8)((value >> j) & 0x01); | 3431 | state->Init_Ctrl[i].val[j] = (u8)((value >> j) & 0x01); |
3764 | MXL_RegWriteBit(fe, (u8)(state->Init_Ctrl[i].addr[j]), | 3432 | MXL_RegWriteBit(fe, (u8)(state->Init_Ctrl[i].addr[j]), |
3765 | (u8)(state->Init_Ctrl[i].bit[j]), | 3433 | (u8)(state->Init_Ctrl[i].bit[j]), |
3766 | (u8)((value>>j) & 0x01) ); | 3434 | (u8)((value>>j) & 0x01)); |
3767 | } | 3435 | } |
3768 | ctrlVal = 0; | 3436 | ctrlVal = 0; |
3769 | for (k = 0; k < state->Init_Ctrl[i].size; k++) | 3437 | for (k = 0; k < state->Init_Ctrl[i].size; k++) |
3770 | ctrlVal += state->Init_Ctrl[i].val[k] * (1 << k); | 3438 | ctrlVal += state->Init_Ctrl[i].val[k] * (1 << k); |
3771 | } | 3439 | } else |
3772 | else | ||
3773 | return -1; | 3440 | return -1; |
3774 | } | 3441 | } |
3775 | } | 3442 | } |
@@ -3778,7 +3445,7 @@ u16 MXL_ControlWrite_Group(struct dvb_frontend *fe, u16 controlNum, u32 value, u | |||
3778 | 3445 | ||
3779 | for (i = 0; i < state->CH_Ctrl_Num; i++) { | 3446 | for (i = 0; i < state->CH_Ctrl_Num; i++) { |
3780 | 3447 | ||
3781 | if (controlNum == state->CH_Ctrl[i].Ctrl_Num ) { | 3448 | if (controlNum == state->CH_Ctrl[i].Ctrl_Num) { |
3782 | 3449 | ||
3783 | highLimit = 1 << state->CH_Ctrl[i].size; | 3450 | highLimit = 1 << state->CH_Ctrl[i].size; |
3784 | if (value < highLimit) { | 3451 | if (value < highLimit) { |
@@ -3786,13 +3453,12 @@ u16 MXL_ControlWrite_Group(struct dvb_frontend *fe, u16 controlNum, u32 value, u | |||
3786 | state->CH_Ctrl[i].val[j] = (u8)((value >> j) & 0x01); | 3453 | state->CH_Ctrl[i].val[j] = (u8)((value >> j) & 0x01); |
3787 | MXL_RegWriteBit(fe, (u8)(state->CH_Ctrl[i].addr[j]), | 3454 | MXL_RegWriteBit(fe, (u8)(state->CH_Ctrl[i].addr[j]), |
3788 | (u8)(state->CH_Ctrl[i].bit[j]), | 3455 | (u8)(state->CH_Ctrl[i].bit[j]), |
3789 | (u8)((value>>j) & 0x01) ); | 3456 | (u8)((value>>j) & 0x01)); |
3790 | } | 3457 | } |
3791 | ctrlVal = 0; | 3458 | ctrlVal = 0; |
3792 | for (k = 0; k < state->CH_Ctrl[i].size; k++) | 3459 | for (k = 0; k < state->CH_Ctrl[i].size; k++) |
3793 | ctrlVal += state->CH_Ctrl[i].val[k] * (1 << k); | 3460 | ctrlVal += state->CH_Ctrl[i].val[k] * (1 << k); |
3794 | } | 3461 | } else |
3795 | else | ||
3796 | return -1; | 3462 | return -1; |
3797 | } | 3463 | } |
3798 | } | 3464 | } |
@@ -3802,21 +3468,20 @@ u16 MXL_ControlWrite_Group(struct dvb_frontend *fe, u16 controlNum, u32 value, u | |||
3802 | 3468 | ||
3803 | for (i = 0; i < state->MXL_Ctrl_Num; i++) { | 3469 | for (i = 0; i < state->MXL_Ctrl_Num; i++) { |
3804 | 3470 | ||
3805 | if (controlNum == state->MXL_Ctrl[i].Ctrl_Num ) { | 3471 | if (controlNum == state->MXL_Ctrl[i].Ctrl_Num) { |
3806 | 3472 | ||
3807 | highLimit = (1 << state->MXL_Ctrl[i].size) ; | 3473 | highLimit = (1 << state->MXL_Ctrl[i].size); |
3808 | if (value < highLimit) { | 3474 | if (value < highLimit) { |
3809 | for (j = 0; j < state->MXL_Ctrl[i].size; j++) { | 3475 | for (j = 0; j < state->MXL_Ctrl[i].size; j++) { |
3810 | state->MXL_Ctrl[i].val[j] = (u8)((value >> j) & 0x01); | 3476 | state->MXL_Ctrl[i].val[j] = (u8)((value >> j) & 0x01); |
3811 | MXL_RegWriteBit(fe, (u8)(state->MXL_Ctrl[i].addr[j]), | 3477 | MXL_RegWriteBit(fe, (u8)(state->MXL_Ctrl[i].addr[j]), |
3812 | (u8)(state->MXL_Ctrl[i].bit[j]), | 3478 | (u8)(state->MXL_Ctrl[i].bit[j]), |
3813 | (u8)((value>>j) & 0x01) ); | 3479 | (u8)((value>>j) & 0x01)); |
3814 | } | 3480 | } |
3815 | ctrlVal = 0; | 3481 | ctrlVal = 0; |
3816 | for(k = 0; k < state->MXL_Ctrl[i].size; k++) | 3482 | for (k = 0; k < state->MXL_Ctrl[i].size; k++) |
3817 | ctrlVal += state->MXL_Ctrl[i].val[k] * (1 << k); | 3483 | ctrlVal += state->MXL_Ctrl[i].val[k] * (1 << k); |
3818 | } | 3484 | } else |
3819 | else | ||
3820 | return -1; | 3485 | return -1; |
3821 | } | 3486 | } |
3822 | } | 3487 | } |
@@ -3825,31 +3490,6 @@ u16 MXL_ControlWrite_Group(struct dvb_frontend *fe, u16 controlNum, u32 value, u | |||
3825 | return 0 ; /* successful return */ | 3490 | return 0 ; /* successful return */ |
3826 | } | 3491 | } |
3827 | 3492 | ||
3828 | /////////////////////////////////////////////////////////////////////////////// | ||
3829 | // // | ||
3830 | // Function: MXL_RegWrite // | ||
3831 | // // | ||
3832 | // Description: Update tuner register value // | ||
3833 | // // | ||
3834 | // Globals: // | ||
3835 | // NONE // | ||
3836 | // // | ||
3837 | // Functions used: // | ||
3838 | // NONE // | ||
3839 | // // | ||
3840 | // Inputs: // | ||
3841 | // Tuner_struct: structure defined at higher level // | ||
3842 | // RegNum : Register address to be assigned a value // | ||
3843 | // RegVal : Register value to write // | ||
3844 | // // | ||
3845 | // Outputs: // | ||
3846 | // NONE // | ||
3847 | // // | ||
3848 | // Return: // | ||
3849 | // 0 : Successful write // | ||
3850 | // -1 : Invalid Register Address // | ||
3851 | // // | ||
3852 | /////////////////////////////////////////////////////////////////////////////// | ||
3853 | u16 MXL_RegWrite(struct dvb_frontend *fe, u8 RegNum, u8 RegVal) | 3493 | u16 MXL_RegWrite(struct dvb_frontend *fe, u8 RegNum, u8 RegVal) |
3854 | { | 3494 | { |
3855 | struct mxl5005s_state *state = fe->tuner_priv; | 3495 | struct mxl5005s_state *state = fe->tuner_priv; |
@@ -3865,37 +3505,13 @@ u16 MXL_RegWrite(struct dvb_frontend *fe, u8 RegNum, u8 RegVal) | |||
3865 | return 1; | 3505 | return 1; |
3866 | } | 3506 | } |
3867 | 3507 | ||
3868 | /////////////////////////////////////////////////////////////////////////////// | ||
3869 | // // | ||
3870 | // Function: MXL_RegRead // | ||
3871 | // // | ||
3872 | // Description: Retrieve tuner register value // | ||
3873 | // // | ||
3874 | // Globals: // | ||
3875 | // NONE // | ||
3876 | // // | ||
3877 | // Functions used: // | ||
3878 | // NONE // | ||
3879 | // // | ||
3880 | // Inputs: // | ||
3881 | // Tuner_struct: structure defined at higher level // | ||
3882 | // RegNum : Register address to be assigned a value // | ||
3883 | // // | ||
3884 | // Outputs: // | ||
3885 | // RegVal : Retrieved register value // | ||
3886 | // // | ||
3887 | // Return: // | ||
3888 | // 0 : Successful read // | ||
3889 | // -1 : Invalid Register Address // | ||
3890 | // // | ||
3891 | /////////////////////////////////////////////////////////////////////////////// | ||
3892 | u16 MXL_RegRead(struct dvb_frontend *fe, u8 RegNum, u8 *RegVal) | 3508 | u16 MXL_RegRead(struct dvb_frontend *fe, u8 RegNum, u8 *RegVal) |
3893 | { | 3509 | { |
3894 | struct mxl5005s_state *state = fe->tuner_priv; | 3510 | struct mxl5005s_state *state = fe->tuner_priv; |
3895 | int i ; | 3511 | int i ; |
3896 | 3512 | ||
3897 | for (i = 0; i < 104; i++) { | 3513 | for (i = 0; i < 104; i++) { |
3898 | if (RegNum == state->TunerRegs[i].Reg_Num ) { | 3514 | if (RegNum == state->TunerRegs[i].Reg_Num) { |
3899 | *RegVal = (u8)(state->TunerRegs[i].Reg_Val); | 3515 | *RegVal = (u8)(state->TunerRegs[i].Reg_Val); |
3900 | return 0; | 3516 | return 0; |
3901 | } | 3517 | } |
@@ -3904,27 +3520,6 @@ u16 MXL_RegRead(struct dvb_frontend *fe, u8 RegNum, u8 *RegVal) | |||
3904 | return 1; | 3520 | return 1; |
3905 | } | 3521 | } |
3906 | 3522 | ||
3907 | /////////////////////////////////////////////////////////////////////////////// | ||
3908 | // // | ||
3909 | // Function: MXL_ControlRead // | ||
3910 | // // | ||
3911 | // Description: Retrieve the control value based on the control name // | ||
3912 | // // | ||
3913 | // Globals: // | ||
3914 | // NONE // | ||
3915 | // // | ||
3916 | // Inputs: // | ||
3917 | // Tuner_struct : structure defined at higher level // | ||
3918 | // ControlName : Control Name // | ||
3919 | // // | ||
3920 | // Outputs: // | ||
3921 | // value : returned control value // | ||
3922 | // // | ||
3923 | // Return: // | ||
3924 | // 0 : Successful read // | ||
3925 | // -1 : Invalid control name // | ||
3926 | // // | ||
3927 | /////////////////////////////////////////////////////////////////////////////// | ||
3928 | u16 MXL_ControlRead(struct dvb_frontend *fe, u16 controlNum, u32 *value) | 3523 | u16 MXL_ControlRead(struct dvb_frontend *fe, u16 controlNum, u32 *value) |
3929 | { | 3524 | { |
3930 | struct mxl5005s_state *state = fe->tuner_priv; | 3525 | struct mxl5005s_state *state = fe->tuner_priv; |
@@ -3937,7 +3532,7 @@ u16 MXL_ControlRead(struct dvb_frontend *fe, u16 controlNum, u32 *value) | |||
3937 | 3532 | ||
3938 | ctrlVal = 0; | 3533 | ctrlVal = 0; |
3939 | for (k = 0; k < state->Init_Ctrl[i].size; k++) | 3534 | for (k = 0; k < state->Init_Ctrl[i].size; k++) |
3940 | ctrlVal += state->Init_Ctrl[i].val[k] * (1 << k); | 3535 | ctrlVal += state->Init_Ctrl[i].val[k] * (1<<k); |
3941 | *value = ctrlVal; | 3536 | *value = ctrlVal; |
3942 | return 0; | 3537 | return 0; |
3943 | } | 3538 | } |
@@ -3973,30 +3568,8 @@ u16 MXL_ControlRead(struct dvb_frontend *fe, u16 controlNum, u32 *value) | |||
3973 | return 1; | 3568 | return 1; |
3974 | } | 3569 | } |
3975 | 3570 | ||
3976 | /////////////////////////////////////////////////////////////////////////////// | 3571 | u16 MXL_ControlRegRead(struct dvb_frontend *fe, u16 controlNum, u8 *RegNum, |
3977 | // // | 3572 | int *count) |
3978 | // Function: MXL_ControlRegRead // | ||
3979 | // // | ||
3980 | // Description: Retrieve the register addresses and count related to a // | ||
3981 | // a specific control name // | ||
3982 | // // | ||
3983 | // Globals: // | ||
3984 | // NONE // | ||
3985 | // // | ||
3986 | // Inputs: // | ||
3987 | // Tuner_struct : structure defined at higher level // | ||
3988 | // ControlName : Control Name // | ||
3989 | // // | ||
3990 | // Outputs: // | ||
3991 | // RegNum : returned register address array // | ||
3992 | // count : returned register count related to a control // | ||
3993 | // // | ||
3994 | // Return: // | ||
3995 | // 0 : Successful read // | ||
3996 | // -1 : Invalid control name // | ||
3997 | // // | ||
3998 | /////////////////////////////////////////////////////////////////////////////// | ||
3999 | u16 MXL_ControlRegRead(struct dvb_frontend *fe, u16 controlNum, u8 *RegNum, int * count) | ||
4000 | { | 3573 | { |
4001 | struct mxl5005s_state *state = fe->tuner_priv; | 3574 | struct mxl5005s_state *state = fe->tuner_priv; |
4002 | u16 i, j, k ; | 3575 | u16 i, j, k ; |
@@ -4004,7 +3577,7 @@ u16 MXL_ControlRegRead(struct dvb_frontend *fe, u16 controlNum, u8 *RegNum, int | |||
4004 | 3577 | ||
4005 | for (i = 0; i < state->Init_Ctrl_Num ; i++) { | 3578 | for (i = 0; i < state->Init_Ctrl_Num ; i++) { |
4006 | 3579 | ||
4007 | if ( controlNum == state->Init_Ctrl[i].Ctrl_Num ) { | 3580 | if (controlNum == state->Init_Ctrl[i].Ctrl_Num) { |
4008 | 3581 | ||
4009 | Count = 1; | 3582 | Count = 1; |
4010 | RegNum[0] = (u8)(state->Init_Ctrl[i].addr[0]); | 3583 | RegNum[0] = (u8)(state->Init_Ctrl[i].addr[0]); |
@@ -4013,9 +3586,10 @@ u16 MXL_ControlRegRead(struct dvb_frontend *fe, u16 controlNum, u8 *RegNum, int | |||
4013 | 3586 | ||
4014 | for (j = 0; j < Count; j++) { | 3587 | for (j = 0; j < Count; j++) { |
4015 | 3588 | ||
4016 | if (state->Init_Ctrl[i].addr[k] != RegNum[j]) { | 3589 | if (state->Init_Ctrl[i].addr[k] != |
3590 | RegNum[j]) { | ||
4017 | 3591 | ||
4018 | Count ++; | 3592 | Count++; |
4019 | RegNum[Count-1] = (u8)(state->Init_Ctrl[i].addr[k]); | 3593 | RegNum[Count-1] = (u8)(state->Init_Ctrl[i].addr[k]); |
4020 | 3594 | ||
4021 | } | 3595 | } |
@@ -4028,18 +3602,19 @@ u16 MXL_ControlRegRead(struct dvb_frontend *fe, u16 controlNum, u8 *RegNum, int | |||
4028 | } | 3602 | } |
4029 | for (i = 0; i < state->CH_Ctrl_Num ; i++) { | 3603 | for (i = 0; i < state->CH_Ctrl_Num ; i++) { |
4030 | 3604 | ||
4031 | if ( controlNum == state->CH_Ctrl[i].Ctrl_Num ) { | 3605 | if (controlNum == state->CH_Ctrl[i].Ctrl_Num) { |
4032 | 3606 | ||
4033 | Count = 1; | 3607 | Count = 1; |
4034 | RegNum[0] = (u8)(state->CH_Ctrl[i].addr[0]); | 3608 | RegNum[0] = (u8)(state->CH_Ctrl[i].addr[0]); |
4035 | 3609 | ||
4036 | for (k = 1; k < state->CH_Ctrl[i].size; k++) { | 3610 | for (k = 1; k < state->CH_Ctrl[i].size; k++) { |
4037 | 3611 | ||
4038 | for (j= 0; j<Count; j++) { | 3612 | for (j = 0; j < Count; j++) { |
4039 | 3613 | ||
4040 | if (state->CH_Ctrl[i].addr[k] != RegNum[j]) { | 3614 | if (state->CH_Ctrl[i].addr[k] != |
3615 | RegNum[j]) { | ||
4041 | 3616 | ||
4042 | Count ++; | 3617 | Count++; |
4043 | RegNum[Count-1] = (u8)(state->CH_Ctrl[i].addr[k]); | 3618 | RegNum[Count-1] = (u8)(state->CH_Ctrl[i].addr[k]); |
4044 | 3619 | ||
4045 | } | 3620 | } |
@@ -4052,18 +3627,19 @@ u16 MXL_ControlRegRead(struct dvb_frontend *fe, u16 controlNum, u8 *RegNum, int | |||
4052 | #ifdef _MXL_INTERNAL | 3627 | #ifdef _MXL_INTERNAL |
4053 | for (i = 0; i < state->MXL_Ctrl_Num ; i++) { | 3628 | for (i = 0; i < state->MXL_Ctrl_Num ; i++) { |
4054 | 3629 | ||
4055 | if ( controlNum == state->MXL_Ctrl[i].Ctrl_Num ) { | 3630 | if (controlNum == state->MXL_Ctrl[i].Ctrl_Num) { |
4056 | 3631 | ||
4057 | Count = 1; | 3632 | Count = 1; |
4058 | RegNum[0] = (u8)(state->MXL_Ctrl[i].addr[0]); | 3633 | RegNum[0] = (u8)(state->MXL_Ctrl[i].addr[0]); |
4059 | 3634 | ||
4060 | for (k = 1; k < state->MXL_Ctrl[i].size; k++) { | 3635 | for (k = 1; k < state->MXL_Ctrl[i].size; k++) { |
4061 | 3636 | ||
4062 | for (j = 0; j<Count; j++) { | 3637 | for (j = 0; j < Count; j++) { |
4063 | 3638 | ||
4064 | if (state->MXL_Ctrl[i].addr[k] != RegNum[j]) { | 3639 | if (state->MXL_Ctrl[i].addr[k] != |
3640 | RegNum[j]) { | ||
4065 | 3641 | ||
4066 | Count ++; | 3642 | Count++; |
4067 | RegNum[Count-1] = (u8)state->MXL_Ctrl[i].addr[k]; | 3643 | RegNum[Count-1] = (u8)state->MXL_Ctrl[i].addr[k]; |
4068 | 3644 | ||
4069 | } | 3645 | } |
@@ -4078,29 +3654,6 @@ u16 MXL_ControlRegRead(struct dvb_frontend *fe, u16 controlNum, u8 *RegNum, int | |||
4078 | return 1; | 3654 | return 1; |
4079 | } | 3655 | } |
4080 | 3656 | ||
4081 | /////////////////////////////////////////////////////////////////////////////// | ||
4082 | // // | ||
4083 | // Function: MXL_RegWriteBit // | ||
4084 | // // | ||
4085 | // Description: Write a register for specified register address, // | ||
4086 | // register bit and register bit value // | ||
4087 | // // | ||
4088 | // Globals: // | ||
4089 | // NONE // | ||
4090 | // // | ||
4091 | // Inputs: // | ||
4092 | // Tuner_struct : structure defined at higher level // | ||
4093 | // address : register address // | ||
4094 | // bit : register bit number // | ||
4095 | // bitVal : register bit value // | ||
4096 | // // | ||
4097 | // Outputs: // | ||
4098 | // NONE // | ||
4099 | // // | ||
4100 | // Return: // | ||
4101 | // NONE // | ||
4102 | // // | ||
4103 | /////////////////////////////////////////////////////////////////////////////// | ||
4104 | void MXL_RegWriteBit(struct dvb_frontend *fe, u8 address, u8 bit, u8 bitVal) | 3657 | void MXL_RegWriteBit(struct dvb_frontend *fe, u8 address, u8 bit, u8 bitVal) |
4105 | { | 3658 | { |
4106 | struct mxl5005s_state *state = fe->tuner_priv; | 3659 | struct mxl5005s_state *state = fe->tuner_priv; |
@@ -4125,38 +3678,14 @@ void MXL_RegWriteBit(struct dvb_frontend *fe, u8 address, u8 bit, u8 bitVal) | |||
4125 | } | 3678 | } |
4126 | } | 3679 | } |
4127 | 3680 | ||
4128 | /////////////////////////////////////////////////////////////////////////////// | ||
4129 | // // | ||
4130 | // Function: MXL_Ceiling // | ||
4131 | // // | ||
4132 | // Description: Complete to closest increment of resolution // | ||
4133 | // // | ||
4134 | // Globals: // | ||
4135 | // NONE // | ||
4136 | // // | ||
4137 | // Functions used: // | ||
4138 | // NONE // | ||
4139 | // // | ||
4140 | // Inputs: // | ||
4141 | // value : Input number to compute // | ||
4142 | // resolution : Increment step // | ||
4143 | // // | ||
4144 | // Outputs: // | ||
4145 | // NONE // | ||
4146 | // // | ||
4147 | // Return: // | ||
4148 | // Computed value // | ||
4149 | // // | ||
4150 | /////////////////////////////////////////////////////////////////////////////// | ||
4151 | u32 MXL_Ceiling(u32 value, u32 resolution) | 3681 | u32 MXL_Ceiling(u32 value, u32 resolution) |
4152 | { | 3682 | { |
4153 | return (value/resolution + (value % resolution > 0 ? 1 : 0)); | 3683 | return (value/resolution + (value % resolution > 0 ? 1 : 0)); |
4154 | } | 3684 | } |
4155 | 3685 | ||
4156 | // | 3686 | /* Retrieve the Initialzation Registers */ |
4157 | // Retrieve the Initialzation Registers | 3687 | u16 MXL_GetInitRegister(struct dvb_frontend *fe, u8 *RegNum, |
4158 | // | 3688 | u8 *RegVal, int *count) |
4159 | u16 MXL_GetInitRegister(struct dvb_frontend *fe, u8 * RegNum, u8 *RegVal, int *count) | ||
4160 | { | 3689 | { |
4161 | u16 status = 0; | 3690 | u16 status = 0; |
4162 | int i ; | 3691 | int i ; |
@@ -4178,21 +3707,24 @@ u16 MXL_GetInitRegister(struct dvb_frontend *fe, u8 * RegNum, u8 *RegVal, int *c | |||
4178 | return status; | 3707 | return status; |
4179 | } | 3708 | } |
4180 | 3709 | ||
4181 | u16 MXL_GetCHRegister(struct dvb_frontend *fe, u8 * RegNum, u8 *RegVal, int *count) | 3710 | u16 MXL_GetCHRegister(struct dvb_frontend *fe, u8 *RegNum, u8 *RegVal, |
3711 | int *count) | ||
4182 | { | 3712 | { |
4183 | u16 status = 0; | 3713 | u16 status = 0; |
4184 | int i ; | 3714 | int i ; |
4185 | 3715 | ||
4186 | //add 77, 166, 167, 168 register for 2.6.12 | 3716 | /* add 77, 166, 167, 168 register for 2.6.12 */ |
4187 | #ifdef _MXL_PRODUCTION | 3717 | #ifdef _MXL_PRODUCTION |
4188 | u8 RegAddr[] = {14, 15, 16, 17, 22, 43, 65, 68, 69, 70, 73, 92, 93, 106, | 3718 | u8 RegAddr[] = {14, 15, 16, 17, 22, 43, 65, 68, 69, 70, 73, 92, 93, 106, |
4189 | 107, 108, 109, 110, 111, 112, 136, 138, 149, 77, 166, 167, 168 } ; | 3719 | 107, 108, 109, 110, 111, 112, 136, 138, 149, 77, 166, 167, 168 } ; |
4190 | #else | 3720 | #else |
4191 | u8 RegAddr[] = {14, 15, 16, 17, 22, 43, 68, 69, 70, 73, 92, 93, 106, | 3721 | u8 RegAddr[] = {14, 15, 16, 17, 22, 43, 68, 69, 70, 73, 92, 93, 106, |
4192 | 107, 108, 109, 110, 111, 112, 136, 138, 149, 77, 166, 167, 168 } ; | 3722 | 107, 108, 109, 110, 111, 112, 136, 138, 149, 77, 166, 167, 168 } ; |
4193 | //u8 RegAddr[171]; | 3723 | /* |
4194 | //for (i=0; i<=170; i++) | 3724 | u8 RegAddr[171]; |
4195 | // RegAddr[i] = i; | 3725 | for (i = 0; i <= 170; i++) |
3726 | RegAddr[i] = i; | ||
3727 | */ | ||
4196 | #endif | 3728 | #endif |
4197 | 3729 | ||
4198 | *count = sizeof(RegAddr) / sizeof(u8); | 3730 | *count = sizeof(RegAddr) / sizeof(u8); |
@@ -4205,7 +3737,8 @@ u16 MXL_GetCHRegister(struct dvb_frontend *fe, u8 * RegNum, u8 *RegVal, int *cou | |||
4205 | return status; | 3737 | return status; |
4206 | } | 3738 | } |
4207 | 3739 | ||
4208 | u16 MXL_GetCHRegister_ZeroIF(struct dvb_frontend *fe, u8 * RegNum, u8 *RegVal, int *count) | 3740 | u16 MXL_GetCHRegister_ZeroIF(struct dvb_frontend *fe, u8 *RegNum, u8 *RegVal, |
3741 | int *count) | ||
4209 | { | 3742 | { |
4210 | u16 status = 0; | 3743 | u16 status = 0; |
4211 | int i; | 3744 | int i; |
@@ -4222,7 +3755,8 @@ u16 MXL_GetCHRegister_ZeroIF(struct dvb_frontend *fe, u8 * RegNum, u8 *RegVal, i | |||
4222 | return status; | 3755 | return status; |
4223 | } | 3756 | } |
4224 | 3757 | ||
4225 | u16 MXL_GetCHRegister_LowIF(struct dvb_frontend *fe, u8 * RegNum, u8 *RegVal, int *count) | 3758 | u16 MXL_GetCHRegister_LowIF(struct dvb_frontend *fe, u8 *RegNum, u8 *RegVal, |
3759 | int *count) | ||
4226 | { | 3760 | { |
4227 | u16 status = 0; | 3761 | u16 status = 0; |
4228 | int i; | 3762 | int i; |
@@ -4267,23 +3801,28 @@ u16 MXL_VCORange_Test(struct dvb_frontend *fe, int VCO_Range) | |||
4267 | status += MXL_ControlWrite(fe, RFSYN_SEL_VCO_OUT, 1); | 3801 | status += MXL_ControlWrite(fe, RFSYN_SEL_VCO_OUT, 1); |
4268 | status += MXL_ControlWrite(fe, RFSYN_RF_DIV_BIAS, 1); | 3802 | status += MXL_ControlWrite(fe, RFSYN_RF_DIV_BIAS, 1); |
4269 | status += MXL_ControlWrite(fe, DN_SEL_FREQ, 0); | 3803 | status += MXL_ControlWrite(fe, DN_SEL_FREQ, 0); |
4270 | if (state->Mode == 0 && state->IF_Mode == 1) /* Analog Low IF Mode */ { | 3804 | if (state->Mode == 0 && state->IF_Mode == 1) { |
3805 | /* Analog Low IF Mode */ | ||
4271 | status += MXL_ControlWrite(fe, RFSYN_SEL_VCO_HI, 1); | 3806 | status += MXL_ControlWrite(fe, RFSYN_SEL_VCO_HI, 1); |
4272 | status += MXL_ControlWrite(fe, RFSYN_VCO_BIAS, 8); | 3807 | status += MXL_ControlWrite(fe, RFSYN_VCO_BIAS, 8); |
4273 | status += MXL_ControlWrite(fe, CHCAL_INT_MOD_RF, 56); | 3808 | status += MXL_ControlWrite(fe, CHCAL_INT_MOD_RF, 56); |
4274 | status += MXL_ControlWrite(fe, CHCAL_FRAC_MOD_RF, 180224); | 3809 | status += MXL_ControlWrite(fe, |
3810 | CHCAL_FRAC_MOD_RF, 180224); | ||
4275 | } | 3811 | } |
4276 | if (state->Mode == 0 && state->IF_Mode == 0) /* Analog Zero IF Mode */ { | 3812 | if (state->Mode == 0 && state->IF_Mode == 0) { |
3813 | /* Analog Zero IF Mode */ | ||
4277 | status += MXL_ControlWrite(fe, RFSYN_SEL_VCO_HI, 1); | 3814 | status += MXL_ControlWrite(fe, RFSYN_SEL_VCO_HI, 1); |
4278 | status += MXL_ControlWrite(fe, RFSYN_VCO_BIAS, 8); | 3815 | status += MXL_ControlWrite(fe, RFSYN_VCO_BIAS, 8); |
4279 | status += MXL_ControlWrite(fe, CHCAL_INT_MOD_RF, 56); | 3816 | status += MXL_ControlWrite(fe, CHCAL_INT_MOD_RF, 56); |
4280 | status += MXL_ControlWrite(fe, CHCAL_FRAC_MOD_RF, 222822); | 3817 | status += MXL_ControlWrite(fe, |
3818 | CHCAL_FRAC_MOD_RF, 222822); | ||
4281 | } | 3819 | } |
4282 | if (state->Mode == 1) /* Digital Mode */ { | 3820 | if (state->Mode == 1) /* Digital Mode */ { |
4283 | status += MXL_ControlWrite(fe, RFSYN_SEL_VCO_HI, 1); | 3821 | status += MXL_ControlWrite(fe, RFSYN_SEL_VCO_HI, 1); |
4284 | status += MXL_ControlWrite(fe, RFSYN_VCO_BIAS, 8); | 3822 | status += MXL_ControlWrite(fe, RFSYN_VCO_BIAS, 8); |
4285 | status += MXL_ControlWrite(fe, CHCAL_INT_MOD_RF, 56); | 3823 | status += MXL_ControlWrite(fe, CHCAL_INT_MOD_RF, 56); |
4286 | status += MXL_ControlWrite(fe, CHCAL_FRAC_MOD_RF, 229376); | 3824 | status += MXL_ControlWrite(fe, |
3825 | CHCAL_FRAC_MOD_RF, 229376); | ||
4287 | } | 3826 | } |
4288 | } | 3827 | } |
4289 | 3828 | ||
@@ -4298,23 +3837,28 @@ u16 MXL_VCORange_Test(struct dvb_frontend *fe, int VCO_Range) | |||
4298 | status += MXL_ControlWrite(fe, RFSYN_SEL_VCO_HI, 1); | 3837 | status += MXL_ControlWrite(fe, RFSYN_SEL_VCO_HI, 1); |
4299 | status += MXL_ControlWrite(fe, RFSYN_VCO_BIAS, 40); | 3838 | status += MXL_ControlWrite(fe, RFSYN_VCO_BIAS, 40); |
4300 | status += MXL_ControlWrite(fe, CHCAL_INT_MOD_RF, 41); | 3839 | status += MXL_ControlWrite(fe, CHCAL_INT_MOD_RF, 41); |
4301 | if (state->Mode == 0 && state->IF_Mode == 1) /* Analog Low IF Mode */ { | 3840 | if (state->Mode == 0 && state->IF_Mode == 1) { |
3841 | /* Analog Low IF Mode */ | ||
4302 | status += MXL_ControlWrite(fe, RFSYN_SEL_VCO_HI, 1); | 3842 | status += MXL_ControlWrite(fe, RFSYN_SEL_VCO_HI, 1); |
4303 | status += MXL_ControlWrite(fe, RFSYN_VCO_BIAS, 40); | 3843 | status += MXL_ControlWrite(fe, RFSYN_VCO_BIAS, 40); |
4304 | status += MXL_ControlWrite(fe, CHCAL_INT_MOD_RF, 42); | 3844 | status += MXL_ControlWrite(fe, CHCAL_INT_MOD_RF, 42); |
4305 | status += MXL_ControlWrite(fe, CHCAL_FRAC_MOD_RF, 206438); | 3845 | status += MXL_ControlWrite(fe, |
3846 | CHCAL_FRAC_MOD_RF, 206438); | ||
4306 | } | 3847 | } |
4307 | if (state->Mode == 0 && state->IF_Mode == 0) /* Analog Zero IF Mode */ { | 3848 | if (state->Mode == 0 && state->IF_Mode == 0) { |
3849 | /* Analog Zero IF Mode */ | ||
4308 | status += MXL_ControlWrite(fe, RFSYN_SEL_VCO_HI, 1); | 3850 | status += MXL_ControlWrite(fe, RFSYN_SEL_VCO_HI, 1); |
4309 | status += MXL_ControlWrite(fe, RFSYN_VCO_BIAS, 40); | 3851 | status += MXL_ControlWrite(fe, RFSYN_VCO_BIAS, 40); |
4310 | status += MXL_ControlWrite(fe, CHCAL_INT_MOD_RF, 42); | 3852 | status += MXL_ControlWrite(fe, CHCAL_INT_MOD_RF, 42); |
4311 | status += MXL_ControlWrite(fe, CHCAL_FRAC_MOD_RF, 206438); | 3853 | status += MXL_ControlWrite(fe, |
3854 | CHCAL_FRAC_MOD_RF, 206438); | ||
4312 | } | 3855 | } |
4313 | if (state->Mode == 1) /* Digital Mode */ { | 3856 | if (state->Mode == 1) /* Digital Mode */ { |
4314 | status += MXL_ControlWrite(fe, RFSYN_SEL_VCO_HI, 1); | 3857 | status += MXL_ControlWrite(fe, RFSYN_SEL_VCO_HI, 1); |
4315 | status += MXL_ControlWrite(fe, RFSYN_VCO_BIAS, 40); | 3858 | status += MXL_ControlWrite(fe, RFSYN_VCO_BIAS, 40); |
4316 | status += MXL_ControlWrite(fe, CHCAL_INT_MOD_RF, 41); | 3859 | status += MXL_ControlWrite(fe, CHCAL_INT_MOD_RF, 41); |
4317 | status += MXL_ControlWrite(fe, CHCAL_FRAC_MOD_RF, 16384); | 3860 | status += MXL_ControlWrite(fe, |
3861 | CHCAL_FRAC_MOD_RF, 16384); | ||
4318 | } | 3862 | } |
4319 | } | 3863 | } |
4320 | 3864 | ||
@@ -4329,23 +3873,28 @@ u16 MXL_VCORange_Test(struct dvb_frontend *fe, int VCO_Range) | |||
4329 | status += MXL_ControlWrite(fe, RFSYN_SEL_VCO_HI, 0); | 3873 | status += MXL_ControlWrite(fe, RFSYN_SEL_VCO_HI, 0); |
4330 | status += MXL_ControlWrite(fe, RFSYN_VCO_BIAS, 8); | 3874 | status += MXL_ControlWrite(fe, RFSYN_VCO_BIAS, 8); |
4331 | status += MXL_ControlWrite(fe, CHCAL_INT_MOD_RF, 42); | 3875 | status += MXL_ControlWrite(fe, CHCAL_INT_MOD_RF, 42); |
4332 | if (state->Mode == 0 && state->IF_Mode == 1) /* Analog Low IF Mode */ { | 3876 | if (state->Mode == 0 && state->IF_Mode == 1) { |
3877 | /* Analog Low IF Mode */ | ||
4333 | status += MXL_ControlWrite(fe, RFSYN_SEL_VCO_HI, 0); | 3878 | status += MXL_ControlWrite(fe, RFSYN_SEL_VCO_HI, 0); |
4334 | status += MXL_ControlWrite(fe, RFSYN_VCO_BIAS, 8); | 3879 | status += MXL_ControlWrite(fe, RFSYN_VCO_BIAS, 8); |
4335 | status += MXL_ControlWrite(fe, CHCAL_INT_MOD_RF, 44); | 3880 | status += MXL_ControlWrite(fe, CHCAL_INT_MOD_RF, 44); |
4336 | status += MXL_ControlWrite(fe, CHCAL_FRAC_MOD_RF, 173670); | 3881 | status += MXL_ControlWrite(fe, |
3882 | CHCAL_FRAC_MOD_RF, 173670); | ||
4337 | } | 3883 | } |
4338 | if (state->Mode == 0 && state->IF_Mode == 0) /* Analog Zero IF Mode */ { | 3884 | if (state->Mode == 0 && state->IF_Mode == 0) { |
3885 | /* Analog Zero IF Mode */ | ||
4339 | status += MXL_ControlWrite(fe, RFSYN_SEL_VCO_HI, 0); | 3886 | status += MXL_ControlWrite(fe, RFSYN_SEL_VCO_HI, 0); |
4340 | status += MXL_ControlWrite(fe, RFSYN_VCO_BIAS, 8); | 3887 | status += MXL_ControlWrite(fe, RFSYN_VCO_BIAS, 8); |
4341 | status += MXL_ControlWrite(fe, CHCAL_INT_MOD_RF, 44); | 3888 | status += MXL_ControlWrite(fe, CHCAL_INT_MOD_RF, 44); |
4342 | status += MXL_ControlWrite(fe, CHCAL_FRAC_MOD_RF, 173670); | 3889 | status += MXL_ControlWrite(fe, |
3890 | CHCAL_FRAC_MOD_RF, 173670); | ||
4343 | } | 3891 | } |
4344 | if (state->Mode == 1) /* Digital Mode */ { | 3892 | if (state->Mode == 1) /* Digital Mode */ { |
4345 | status += MXL_ControlWrite(fe, RFSYN_SEL_VCO_HI, 0); | 3893 | status += MXL_ControlWrite(fe, RFSYN_SEL_VCO_HI, 0); |
4346 | status += MXL_ControlWrite(fe, RFSYN_VCO_BIAS, 8); | 3894 | status += MXL_ControlWrite(fe, RFSYN_VCO_BIAS, 8); |
4347 | status += MXL_ControlWrite(fe, CHCAL_INT_MOD_RF, 42); | 3895 | status += MXL_ControlWrite(fe, CHCAL_INT_MOD_RF, 42); |
4348 | status += MXL_ControlWrite(fe, CHCAL_FRAC_MOD_RF, 245760); | 3896 | status += MXL_ControlWrite(fe, |
3897 | CHCAL_FRAC_MOD_RF, 245760); | ||
4349 | } | 3898 | } |
4350 | } | 3899 | } |
4351 | 3900 | ||
@@ -4360,23 +3909,28 @@ u16 MXL_VCORange_Test(struct dvb_frontend *fe, int VCO_Range) | |||
4360 | status += MXL_ControlWrite(fe, RFSYN_SEL_VCO_HI, 0); | 3909 | status += MXL_ControlWrite(fe, RFSYN_SEL_VCO_HI, 0); |
4361 | status += MXL_ControlWrite(fe, RFSYN_VCO_BIAS, 40); | 3910 | status += MXL_ControlWrite(fe, RFSYN_VCO_BIAS, 40); |
4362 | status += MXL_ControlWrite(fe, CHCAL_INT_MOD_RF, 27); | 3911 | status += MXL_ControlWrite(fe, CHCAL_INT_MOD_RF, 27); |
4363 | if (state->Mode == 0 && state->IF_Mode == 1) /* Analog Low IF Mode */ { | 3912 | if (state->Mode == 0 && state->IF_Mode == 1) { |
3913 | /* Analog Low IF Mode */ | ||
4364 | status += MXL_ControlWrite(fe, RFSYN_SEL_VCO_HI, 0); | 3914 | status += MXL_ControlWrite(fe, RFSYN_SEL_VCO_HI, 0); |
4365 | status += MXL_ControlWrite(fe, RFSYN_VCO_BIAS, 40); | 3915 | status += MXL_ControlWrite(fe, RFSYN_VCO_BIAS, 40); |
4366 | status += MXL_ControlWrite(fe, CHCAL_INT_MOD_RF, 27); | 3916 | status += MXL_ControlWrite(fe, CHCAL_INT_MOD_RF, 27); |
4367 | status += MXL_ControlWrite(fe, CHCAL_FRAC_MOD_RF, 206438); | 3917 | status += MXL_ControlWrite(fe, |
3918 | CHCAL_FRAC_MOD_RF, 206438); | ||
4368 | } | 3919 | } |
4369 | if (state->Mode == 0 && state->IF_Mode == 0) /* Analog Zero IF Mode */ { | 3920 | if (state->Mode == 0 && state->IF_Mode == 0) { |
3921 | /* Analog Zero IF Mode */ | ||
4370 | status += MXL_ControlWrite(fe, RFSYN_SEL_VCO_HI, 0); | 3922 | status += MXL_ControlWrite(fe, RFSYN_SEL_VCO_HI, 0); |
4371 | status += MXL_ControlWrite(fe, RFSYN_VCO_BIAS, 40); | 3923 | status += MXL_ControlWrite(fe, RFSYN_VCO_BIAS, 40); |
4372 | status += MXL_ControlWrite(fe, CHCAL_INT_MOD_RF, 27); | 3924 | status += MXL_ControlWrite(fe, CHCAL_INT_MOD_RF, 27); |
4373 | status += MXL_ControlWrite(fe, CHCAL_FRAC_MOD_RF, 206438); | 3925 | status += MXL_ControlWrite(fe, |
3926 | CHCAL_FRAC_MOD_RF, 206438); | ||
4374 | } | 3927 | } |
4375 | if (state->Mode == 1) /* Digital Mode */ { | 3928 | if (state->Mode == 1) /* Digital Mode */ { |
4376 | status += MXL_ControlWrite(fe, RFSYN_SEL_VCO_HI, 0); | 3929 | status += MXL_ControlWrite(fe, RFSYN_SEL_VCO_HI, 0); |
4377 | status += MXL_ControlWrite(fe, RFSYN_VCO_BIAS, 40); | 3930 | status += MXL_ControlWrite(fe, RFSYN_VCO_BIAS, 40); |
4378 | status += MXL_ControlWrite(fe, CHCAL_INT_MOD_RF, 27); | 3931 | status += MXL_ControlWrite(fe, CHCAL_INT_MOD_RF, 27); |
4379 | status += MXL_ControlWrite(fe, CHCAL_FRAC_MOD_RF, 212992); | 3932 | status += MXL_ControlWrite(fe, |
3933 | CHCAL_FRAC_MOD_RF, 212992); | ||
4380 | } | 3934 | } |
4381 | } | 3935 | } |
4382 | 3936 | ||
@@ -4440,7 +3994,7 @@ static int mxl5005s_writereg(struct dvb_frontend *fe, u8 reg, u8 val, int latch) | |||
4440 | if (latch == 0) | 3994 | if (latch == 0) |
4441 | msg.len = 2; | 3995 | msg.len = 2; |
4442 | 3996 | ||
4443 | dprintk(2, "%s(reg = 0x%x val = 0x%x addr = 0x%x)\n", __func__, reg, val, msg.addr); | 3997 | dprintk(2, "%s(0x%x, 0x%x, 0x%x)\n", __func__, reg, val, msg.addr); |
4444 | 3998 | ||
4445 | if (i2c_transfer(state->i2c, &msg, 1) != 1) { | 3999 | if (i2c_transfer(state->i2c, &msg, 1) != 1) { |
4446 | printk(KERN_WARNING "mxl5005s I2C write failed\n"); | 4000 | printk(KERN_WARNING "mxl5005s I2C write failed\n"); |
@@ -4449,7 +4003,8 @@ static int mxl5005s_writereg(struct dvb_frontend *fe, u8 reg, u8 val, int latch) | |||
4449 | return 0; | 4003 | return 0; |
4450 | } | 4004 | } |
4451 | 4005 | ||
4452 | int mxl5005s_writeregs(struct dvb_frontend *fe, u8 *addrtable, u8 *datatable, u8 len) | 4006 | int mxl5005s_writeregs(struct dvb_frontend *fe, u8 *addrtable, u8 *datatable, |
4007 | u8 len) | ||
4453 | { | 4008 | { |
4454 | int ret = 0, i; | 4009 | int ret = 0, i; |
4455 | 4010 | ||
@@ -4506,7 +4061,8 @@ int mxl5005s_reconfigure(struct dvb_frontend *fe, u32 mod_type, u32 bandwidth) | |||
4506 | return 0; | 4061 | return 0; |
4507 | } | 4062 | } |
4508 | 4063 | ||
4509 | int mxl5005s_AssignTunerMode(struct dvb_frontend *fe, u32 mod_type, u32 bandwidth) | 4064 | int mxl5005s_AssignTunerMode(struct dvb_frontend *fe, u32 mod_type, |
4065 | u32 bandwidth) | ||
4510 | { | 4066 | { |
4511 | struct mxl5005s_state *state = fe->tuner_priv; | 4067 | struct mxl5005s_state *state = fe->tuner_priv; |
4512 | struct mxl5005s_config *c = state->config; | 4068 | struct mxl5005s_config *c = state->config; |
@@ -4553,8 +4109,8 @@ static int mxl5005s_set_params(struct dvb_frontend *fe, | |||
4553 | case QAM_AUTO: | 4109 | case QAM_AUTO: |
4554 | req_mode = MXL_QAM; break; | 4110 | req_mode = MXL_QAM; break; |
4555 | } | 4111 | } |
4556 | } | 4112 | } else |
4557 | else req_mode = MXL_DVBT; | 4113 | req_mode = MXL_DVBT; |
4558 | 4114 | ||
4559 | /* Change tuner for new modulation type if reqd */ | 4115 | /* Change tuner for new modulation type if reqd */ |
4560 | if (req_mode != state->current_mode) { | 4116 | if (req_mode != state->current_mode) { |
@@ -4655,9 +4211,11 @@ struct dvb_frontend *mxl5005s_attach(struct dvb_frontend *fe, | |||
4655 | state->i2c = i2c; | 4211 | state->i2c = i2c; |
4656 | state->current_mode = MXL_QAM; | 4212 | state->current_mode = MXL_QAM; |
4657 | 4213 | ||
4658 | printk(KERN_INFO "MXL5005S: Attached at address 0x%02x\n", config->i2c_address); | 4214 | printk(KERN_INFO "MXL5005S: Attached at address 0x%02x\n", |
4215 | config->i2c_address); | ||
4659 | 4216 | ||
4660 | memcpy(&fe->ops.tuner_ops, &mxl5005s_tuner_ops, sizeof(struct dvb_tuner_ops)); | 4217 | memcpy(&fe->ops.tuner_ops, &mxl5005s_tuner_ops, |
4218 | sizeof(struct dvb_tuner_ops)); | ||
4661 | 4219 | ||
4662 | fe->tuner_priv = state; | 4220 | fe->tuner_priv = state; |
4663 | return fe; | 4221 | return fe; |
diff --git a/drivers/media/common/tuners/mxl5005s.h b/drivers/media/common/tuners/mxl5005s.h index 687cf146c2a0..0027d1e03f99 100644 --- a/drivers/media/common/tuners/mxl5005s.h +++ b/drivers/media/common/tuners/mxl5005s.h | |||
@@ -25,8 +25,8 @@ | |||
25 | 25 | ||
26 | #include <linux/dvb/frontend.h> | 26 | #include <linux/dvb/frontend.h> |
27 | 27 | ||
28 | struct mxl5005s_config | 28 | struct mxl5005s_config { |
29 | { | 29 | |
30 | /* 7 bit i2c address */ | 30 | /* 7 bit i2c address */ |
31 | u8 i2c_address; | 31 | u8 i2c_address; |
32 | 32 | ||