aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorAndrew de Quincey <adq_dvb@lidskialf.net>2006-04-18 16:56:10 -0400
committerMauro Carvalho Chehab <mchehab@infradead.org>2006-06-25 00:59:20 -0400
commitf54376e275415588d5cb1c54b9edf895391efd71 (patch)
tree66aaaf107319cf1dbedfb02309fc687038fae234
parent8dec073225b0926a26656f416a8d32573205a78f (diff)
V4L/DVB (3891): Convert cx88-dvb to refactored tuner code
Rename pll calls to appropriate tuner calls. Remove pll functions from demod structures. Hook tuner call into tuner_ops. Attach dvb-pll where possible. Add pll gate control calls where appropriate. Sort out the hybrid cards to work with the revamped mt352/sl10353 demods supporting external tuners. Signed-off-by: Andrew de Quincey <adq_dvb@lidskialf.net> Signed-off-by: Mauro Carvalho Chehab <mchehab@infradead.org>
-rw-r--r--drivers/media/video/cx88/cx88-dvb.c134
1 files changed, 74 insertions, 60 deletions
diff --git a/drivers/media/video/cx88/cx88-dvb.c b/drivers/media/video/cx88/cx88-dvb.c
index f874fa686643..8b48c1f67a8b 100644
--- a/drivers/media/video/cx88/cx88-dvb.c
+++ b/drivers/media/video/cx88/cx88-dvb.c
@@ -114,21 +114,6 @@ static struct videobuf_queue_ops dvb_qops = {
114 114
115/* ------------------------------------------------------------------ */ 115/* ------------------------------------------------------------------ */
116 116
117#if defined(HAVE_MT352) || defined(HAVE_ZL10353)
118static int zarlink_pll_set(struct dvb_frontend *fe,
119 struct dvb_frontend_parameters *params,
120 u8 *pllbuf)
121{
122 struct cx8802_dev *dev = fe->dvb->priv;
123
124 pllbuf[0] = dev->core->pll_addr << 1;
125 dvb_pll_configure(dev->core->pll_desc, pllbuf + 1,
126 params->frequency,
127 params->u.ofdm.bandwidth);
128 return 0;
129}
130#endif
131
132#ifdef HAVE_MT352 117#ifdef HAVE_MT352
133static int dvico_fusionhdtv_demod_init(struct dvb_frontend* fe) 118static int dvico_fusionhdtv_demod_init(struct dvb_frontend* fe)
134{ 119{
@@ -197,19 +182,16 @@ static int dntv_live_dvbt_demod_init(struct dvb_frontend* fe)
197static struct mt352_config dvico_fusionhdtv = { 182static struct mt352_config dvico_fusionhdtv = {
198 .demod_address = 0x0F, 183 .demod_address = 0x0F,
199 .demod_init = dvico_fusionhdtv_demod_init, 184 .demod_init = dvico_fusionhdtv_demod_init,
200 .pll_set = zarlink_pll_set,
201}; 185};
202 186
203static struct mt352_config dntv_live_dvbt_config = { 187static struct mt352_config dntv_live_dvbt_config = {
204 .demod_address = 0x0f, 188 .demod_address = 0x0f,
205 .demod_init = dntv_live_dvbt_demod_init, 189 .demod_init = dntv_live_dvbt_demod_init,
206 .pll_set = zarlink_pll_set,
207}; 190};
208 191
209static struct mt352_config dvico_fusionhdtv_dual = { 192static struct mt352_config dvico_fusionhdtv_dual = {
210 .demod_address = 0x0F, 193 .demod_address = 0x0F,
211 .demod_init = dvico_dual_demod_init, 194 .demod_init = dvico_dual_demod_init,
212 .pll_set = zarlink_pll_set,
213}; 195};
214 196
215#ifdef HAVE_VP3054_I2C 197#ifdef HAVE_VP3054_I2C
@@ -247,6 +229,8 @@ static int philips_fmd1216_pll_init(struct dvb_frontend *fe)
247 .buf = fmd1216_init, .len = sizeof(fmd1216_init) }; 229 .buf = fmd1216_init, .len = sizeof(fmd1216_init) };
248 int err; 230 int err;
249 231
232 if (fe->ops->i2c_gate_ctrl)
233 fe->ops->i2c_gate_ctrl(fe, 1);
250 if ((err = i2c_transfer(&dev->core->i2c_adap, &msg, 1)) != 1) { 234 if ((err = i2c_transfer(&dev->core->i2c_adap, &msg, 1)) != 1) {
251 if (err < 0) 235 if (err < 0)
252 return err; 236 return err;
@@ -257,14 +241,14 @@ static int philips_fmd1216_pll_init(struct dvb_frontend *fe)
257 return 0; 241 return 0;
258} 242}
259 243
260static int dntv_live_dvbt_pro_pll_set(struct dvb_frontend* fe, 244static int dntv_live_dvbt_pro_tuner_set_params(struct dvb_frontend* fe,
261 struct dvb_frontend_parameters* params, 245 struct dvb_frontend_parameters* params)
262 u8* pllbuf)
263{ 246{
264 struct cx8802_dev *dev= fe->dvb->priv; 247 struct cx8802_dev *dev= fe->dvb->priv;
248 u8 buf[4];
265 struct i2c_msg msg = 249 struct i2c_msg msg =
266 { .addr = dev->core->pll_addr, .flags = 0, 250 { .addr = dev->core->pll_addr, .flags = 0,
267 .buf = pllbuf+1, .len = 4 }; 251 .buf = buf, .len = 4 };
268 int err; 252 int err;
269 253
270 /* Switch PLL to DVB mode */ 254 /* Switch PLL to DVB mode */
@@ -273,14 +257,16 @@ static int dntv_live_dvbt_pro_pll_set(struct dvb_frontend* fe,
273 return err; 257 return err;
274 258
275 /* Tune PLL */ 259 /* Tune PLL */
276 pllbuf[0] = dev->core->pll_addr << 1; 260 dvb_pll_configure(dev->core->pll_desc, buf,
277 dvb_pll_configure(dev->core->pll_desc, pllbuf+1,
278 params->frequency, 261 params->frequency,
279 params->u.ofdm.bandwidth); 262 params->u.ofdm.bandwidth);
263 if (fe->ops->i2c_gate_ctrl)
264 fe->ops->i2c_gate_ctrl(fe, 1);
280 if ((err = i2c_transfer(&dev->core->i2c_adap, &msg, 1)) != 1) { 265 if ((err = i2c_transfer(&dev->core->i2c_adap, &msg, 1)) != 1) {
266
281 printk(KERN_WARNING "cx88-dvb: %s error " 267 printk(KERN_WARNING "cx88-dvb: %s error "
282 "(addr %02x <- %02x, err = %i)\n", 268 "(addr %02x <- %02x, err = %i)\n",
283 __FUNCTION__, pllbuf[0], pllbuf[1], err); 269 __FUNCTION__, dev->core->pll_addr, buf[0], err);
284 if (err < 0) 270 if (err < 0)
285 return err; 271 return err;
286 else 272 else
@@ -294,27 +280,27 @@ static struct mt352_config dntv_live_dvbt_pro_config = {
294 .demod_address = 0x0f, 280 .demod_address = 0x0f,
295 .no_tuner = 1, 281 .no_tuner = 1,
296 .demod_init = dntv_live_dvbt_pro_demod_init, 282 .demod_init = dntv_live_dvbt_pro_demod_init,
297 .pll_set = dntv_live_dvbt_pro_pll_set,
298}; 283};
299#endif 284#endif
300#endif 285#endif
301 286
302#ifdef HAVE_ZL10353 287#ifdef HAVE_ZL10353
303static int dvico_hybrid_tune_pll(struct dvb_frontend *fe, 288static int dvico_hybrid_tuner_set_params(struct dvb_frontend *fe,
304 struct dvb_frontend_parameters *params, 289 struct dvb_frontend_parameters *params)
305 u8 *pllbuf)
306{ 290{
291 u8 pllbuf[4];
307 struct cx8802_dev *dev= fe->dvb->priv; 292 struct cx8802_dev *dev= fe->dvb->priv;
308 struct i2c_msg msg = 293 struct i2c_msg msg =
309 { .addr = dev->core->pll_addr, .flags = 0, 294 { .addr = dev->core->pll_addr, .flags = 0,
310 .buf = pllbuf + 1, .len = 4 }; 295 .buf = pllbuf, .len = 4 };
311 int err; 296 int err;
312 297
313 pllbuf[0] = dev->core->pll_addr << 1; 298 dvb_pll_configure(dev->core->pll_desc, pllbuf,
314 dvb_pll_configure(dev->core->pll_desc, pllbuf + 1,
315 params->frequency, 299 params->frequency,
316 params->u.ofdm.bandwidth); 300 params->u.ofdm.bandwidth);
317 301
302 if (fe->ops->i2c_gate_ctrl)
303 fe->ops->i2c_gate_ctrl(fe, 1);
318 if ((err = i2c_transfer(&dev->core->i2c_adap, &msg, 1)) != 1) { 304 if ((err = i2c_transfer(&dev->core->i2c_adap, &msg, 1)) != 1) {
319 printk(KERN_WARNING "cx88-dvb: %s error " 305 printk(KERN_WARNING "cx88-dvb: %s error "
320 "(addr %02x <- %02x, err = %i)\n", 306 "(addr %02x <- %02x, err = %i)\n",
@@ -330,12 +316,11 @@ static int dvico_hybrid_tune_pll(struct dvb_frontend *fe,
330 316
331static struct zl10353_config dvico_fusionhdtv_hybrid = { 317static struct zl10353_config dvico_fusionhdtv_hybrid = {
332 .demod_address = 0x0F, 318 .demod_address = 0x0F,
333 .pll_set = dvico_hybrid_tune_pll, 319 .no_tuner = 1,
334}; 320};
335 321
336static struct zl10353_config dvico_fusionhdtv_plus_v1_1 = { 322static struct zl10353_config dvico_fusionhdtv_plus_v1_1 = {
337 .demod_address = 0x0F, 323 .demod_address = 0x0F,
338 .pll_set = zarlink_pll_set,
339}; 324};
340#endif 325#endif
341 326
@@ -343,21 +328,15 @@ static struct zl10353_config dvico_fusionhdtv_plus_v1_1 = {
343static struct cx22702_config connexant_refboard_config = { 328static struct cx22702_config connexant_refboard_config = {
344 .demod_address = 0x43, 329 .demod_address = 0x43,
345 .output_mode = CX22702_SERIAL_OUTPUT, 330 .output_mode = CX22702_SERIAL_OUTPUT,
346 .pll_address = 0x60,
347 .pll_desc = &dvb_pll_thomson_dtt7579,
348}; 331};
349 332
350static struct cx22702_config hauppauge_novat_config = { 333static struct cx22702_config hauppauge_novat_config = {
351 .demod_address = 0x43, 334 .demod_address = 0x43,
352 .output_mode = CX22702_SERIAL_OUTPUT, 335 .output_mode = CX22702_SERIAL_OUTPUT,
353 .pll_address = 0x61,
354 .pll_desc = &dvb_pll_thomson_dtt759x,
355}; 336};
356static struct cx22702_config hauppauge_hvr1100_config = { 337static struct cx22702_config hauppauge_hvr1100_config = {
357 .demod_address = 0x63, 338 .demod_address = 0x63,
358 .output_mode = CX22702_SERIAL_OUTPUT, 339 .output_mode = CX22702_SERIAL_OUTPUT,
359 .pll_address = 0x61,
360 .pll_desc = &dvb_pll_fmd1216me,
361}; 340};
362#endif 341#endif
363 342
@@ -372,15 +351,13 @@ static int or51132_set_ts_param(struct dvb_frontend* fe,
372 351
373static struct or51132_config pchdtv_hd3000 = { 352static struct or51132_config pchdtv_hd3000 = {
374 .demod_address = 0x15, 353 .demod_address = 0x15,
375 .pll_address = 0x61,
376 .pll_desc = &dvb_pll_thomson_dtt761x,
377 .set_ts_params = or51132_set_ts_param, 354 .set_ts_params = or51132_set_ts_param,
378}; 355};
379#endif 356#endif
380 357
381#ifdef HAVE_LGDT330X 358#ifdef HAVE_LGDT330X
382static int lgdt3302_pll_set(struct dvb_frontend* fe, 359static int lgdt3302_tuner_set_params(struct dvb_frontend* fe,
383 struct dvb_frontend_parameters* params) 360 struct dvb_frontend_parameters* params)
384{ 361{
385 /* FIXME make this routine use the tuner-simple code. 362 /* FIXME make this routine use the tuner-simple code.
386 * It could probably be shared with a number of ATSC 363 * It could probably be shared with a number of ATSC
@@ -396,6 +373,9 @@ static int lgdt3302_pll_set(struct dvb_frontend* fe,
396 dvb_pll_configure(core->pll_desc, buf, params->frequency, 0); 373 dvb_pll_configure(core->pll_desc, buf, params->frequency, 0);
397 dprintk(1, "%s: tuner at 0x%02x bytes: 0x%02x 0x%02x 0x%02x 0x%02x\n", 374 dprintk(1, "%s: tuner at 0x%02x bytes: 0x%02x 0x%02x 0x%02x 0x%02x\n",
398 __FUNCTION__, msg.addr, buf[0],buf[1],buf[2],buf[3]); 375 __FUNCTION__, msg.addr, buf[0],buf[1],buf[2],buf[3]);
376
377 if (fe->ops->i2c_gate_ctrl)
378 fe->ops->i2c_gate_ctrl(fe, 1);
399 if ((err = i2c_transfer(&core->i2c_adap, &msg, 1)) != 1) { 379 if ((err = i2c_transfer(&core->i2c_adap, &msg, 1)) != 1) {
400 printk(KERN_WARNING "cx88-dvb: %s error " 380 printk(KERN_WARNING "cx88-dvb: %s error "
401 "(addr %02x <- %02x, err = %i)\n", 381 "(addr %02x <- %02x, err = %i)\n",
@@ -408,8 +388,8 @@ static int lgdt3302_pll_set(struct dvb_frontend* fe,
408 return 0; 388 return 0;
409} 389}
410 390
411static int lgdt3303_pll_set(struct dvb_frontend* fe, 391static int lgdt3303_tuner_set_params(struct dvb_frontend* fe,
412 struct dvb_frontend_parameters* params) 392 struct dvb_frontend_parameters* params)
413{ 393{
414 struct cx8802_dev *dev= fe->dvb->priv; 394 struct cx8802_dev *dev= fe->dvb->priv;
415 struct cx88_core *core = dev->core; 395 struct cx88_core *core = dev->core;
@@ -447,7 +427,6 @@ static struct lgdt330x_config fusionhdtv_3_gold = {
447 .demod_address = 0x0e, 427 .demod_address = 0x0e,
448 .demod_chip = LGDT3302, 428 .demod_chip = LGDT3302,
449 .serial_mpeg = 0x04, /* TPSERIAL for 3302 in TOP_CONTROL */ 429 .serial_mpeg = 0x04, /* TPSERIAL for 3302 in TOP_CONTROL */
450 .pll_set = lgdt3302_pll_set,
451 .set_ts_params = lgdt330x_set_ts_param, 430 .set_ts_params = lgdt330x_set_ts_param,
452}; 431};
453 432
@@ -455,7 +434,6 @@ static struct lgdt330x_config fusionhdtv_5_gold = {
455 .demod_address = 0x0e, 434 .demod_address = 0x0e,
456 .demod_chip = LGDT3303, 435 .demod_chip = LGDT3303,
457 .serial_mpeg = 0x40, /* TPSERIAL for 3303 in TOP_CONTROL */ 436 .serial_mpeg = 0x40, /* TPSERIAL for 3303 in TOP_CONTROL */
458 .pll_set = lgdt3303_pll_set,
459 .set_ts_params = lgdt330x_set_ts_param, 437 .set_ts_params = lgdt330x_set_ts_param,
460}; 438};
461 439
@@ -463,7 +441,6 @@ static struct lgdt330x_config pchdtv_hd5500 = {
463 .demod_address = 0x59, 441 .demod_address = 0x59,
464 .demod_chip = LGDT3303, 442 .demod_chip = LGDT3303,
465 .serial_mpeg = 0x40, /* TPSERIAL for 3303 in TOP_CONTROL */ 443 .serial_mpeg = 0x40, /* TPSERIAL for 3303 in TOP_CONTROL */
466 .pll_set = lgdt3303_pll_set,
467 .set_ts_params = lgdt330x_set_ts_param, 444 .set_ts_params = lgdt330x_set_ts_param,
468}; 445};
469#endif 446#endif
@@ -488,8 +465,6 @@ static int nxt200x_set_pll_input(u8* buf, int input)
488 465
489static struct nxt200x_config ati_hdtvwonder = { 466static struct nxt200x_config ati_hdtvwonder = {
490 .demod_address = 0x0a, 467 .demod_address = 0x0a,
491 .pll_address = 0x61,
492 .pll_desc = &dvb_pll_tuv1236d,
493 .set_pll_input = nxt200x_set_pll_input, 468 .set_pll_input = nxt200x_set_pll_input,
494 .set_ts_params = nxt200x_set_ts_param, 469 .set_ts_params = nxt200x_set_ts_param,
495}; 470};
@@ -541,6 +516,9 @@ static int dvb_register(struct cx8802_dev *dev)
541 case CX88_BOARD_HAUPPAUGE_DVB_T1: 516 case CX88_BOARD_HAUPPAUGE_DVB_T1:
542 dev->dvb.frontend = cx22702_attach(&hauppauge_novat_config, 517 dev->dvb.frontend = cx22702_attach(&hauppauge_novat_config,
543 &dev->core->i2c_adap); 518 &dev->core->i2c_adap);
519 if (dev->dvb.frontend != NULL) {
520 dvb_pll_attach(dev->dvb.frontend, 0x61, &dev->core->i2c_adap, &dvb_pll_thomson_dtt759x);
521 }
544 break; 522 break;
545 case CX88_BOARD_TERRATEC_CINERGY_1400_DVB_T1: 523 case CX88_BOARD_TERRATEC_CINERGY_1400_DVB_T1:
546 case CX88_BOARD_CONEXANT_DVB_T1: 524 case CX88_BOARD_CONEXANT_DVB_T1:
@@ -548,44 +526,55 @@ static int dvb_register(struct cx8802_dev *dev)
548 case CX88_BOARD_WINFAST_DTV1000: 526 case CX88_BOARD_WINFAST_DTV1000:
549 dev->dvb.frontend = cx22702_attach(&connexant_refboard_config, 527 dev->dvb.frontend = cx22702_attach(&connexant_refboard_config,
550 &dev->core->i2c_adap); 528 &dev->core->i2c_adap);
529 if (dev->dvb.frontend != NULL) {
530 dvb_pll_attach(dev->dvb.frontend, 0x60, &dev->core->i2c_adap, &dvb_pll_thomson_dtt7579);
531 }
551 break; 532 break;
552 case CX88_BOARD_HAUPPAUGE_HVR1100: 533 case CX88_BOARD_HAUPPAUGE_HVR1100:
553 case CX88_BOARD_HAUPPAUGE_HVR1100LP: 534 case CX88_BOARD_HAUPPAUGE_HVR1100LP:
554 dev->dvb.frontend = cx22702_attach(&hauppauge_hvr1100_config, 535 dev->dvb.frontend = cx22702_attach(&hauppauge_hvr1100_config,
555 &dev->core->i2c_adap); 536 &dev->core->i2c_adap);
537 if (dev->dvb.frontend != NULL) {
538 dvb_pll_attach(dev->dvb.frontend, 0x61, &dev->core->i2c_adap, &dvb_pll_fmd1216me);
539 }
556 break; 540 break;
557#endif 541#endif
558#if defined(HAVE_MT352) || defined(HAVE_ZL10353) 542#if defined(HAVE_MT352) || defined(HAVE_ZL10353)
559 case CX88_BOARD_DVICO_FUSIONHDTV_DVB_T_PLUS: 543 case CX88_BOARD_DVICO_FUSIONHDTV_DVB_T_PLUS:
560 dev->core->pll_addr = 0x60;
561 dev->core->pll_desc = &dvb_pll_thomson_dtt7579;
562#ifdef HAVE_MT352 544#ifdef HAVE_MT352
563 dev->dvb.frontend = mt352_attach(&dvico_fusionhdtv, 545 dev->dvb.frontend = mt352_attach(&dvico_fusionhdtv,
564 &dev->core->i2c_adap); 546 &dev->core->i2c_adap);
565 if (dev->dvb.frontend != NULL) 547 if (dev->dvb.frontend != NULL) {
548 dvb_pll_attach(dev->dvb.frontend, 0x60, &dev->core->i2c_adap, &dvb_pll_thomson_dtt7579);
566 break; 549 break;
550 }
567#endif 551#endif
568#ifdef HAVE_ZL10353 552#ifdef HAVE_ZL10353
569 /* ZL10353 replaces MT352 on later cards */ 553 /* ZL10353 replaces MT352 on later cards */
570 dev->dvb.frontend = zl10353_attach(&dvico_fusionhdtv_plus_v1_1, 554 dev->dvb.frontend = zl10353_attach(&dvico_fusionhdtv_plus_v1_1,
571 &dev->core->i2c_adap); 555 &dev->core->i2c_adap);
556 if (dev->dvb.frontend != NULL) {
557 dvb_pll_attach(dev->dvb.frontend, 0x60, &dev->core->i2c_adap, &dvb_pll_thomson_dtt7579);
558 }
572#endif 559#endif
573 break; 560 break;
574#endif /* HAVE_MT352 || HAVE_ZL10353 */ 561#endif /* HAVE_MT352 || HAVE_ZL10353 */
575#ifdef HAVE_MT352 562#ifdef HAVE_MT352
576 case CX88_BOARD_DVICO_FUSIONHDTV_DVB_T1: 563 case CX88_BOARD_DVICO_FUSIONHDTV_DVB_T1:
577 dev->core->pll_addr = 0x61;
578 dev->core->pll_desc = &dvb_pll_lg_z201;
579 dev->dvb.frontend = mt352_attach(&dvico_fusionhdtv, 564 dev->dvb.frontend = mt352_attach(&dvico_fusionhdtv,
580 &dev->core->i2c_adap); 565 &dev->core->i2c_adap);
566 if (dev->dvb.frontend != NULL) {
567 dvb_pll_attach(dev->dvb.frontend, 0x61, &dev->core->i2c_adap, &dvb_pll_lg_z201);
568 }
581 break; 569 break;
582 case CX88_BOARD_KWORLD_DVB_T: 570 case CX88_BOARD_KWORLD_DVB_T:
583 case CX88_BOARD_DNTV_LIVE_DVB_T: 571 case CX88_BOARD_DNTV_LIVE_DVB_T:
584 case CX88_BOARD_ADSTECH_DVB_T_PCI: 572 case CX88_BOARD_ADSTECH_DVB_T_PCI:
585 dev->core->pll_addr = 0x61;
586 dev->core->pll_desc = &dvb_pll_unknown_1;
587 dev->dvb.frontend = mt352_attach(&dntv_live_dvbt_config, 573 dev->dvb.frontend = mt352_attach(&dntv_live_dvbt_config,
588 &dev->core->i2c_adap); 574 &dev->core->i2c_adap);
575 if (dev->dvb.frontend != NULL) {
576 dvb_pll_attach(dev->dvb.frontend, 0x61, &dev->core->i2c_adap, &dvb_pll_unknown_1);
577 }
589 break; 578 break;
590 case CX88_BOARD_DNTV_LIVE_DVB_T_PRO: 579 case CX88_BOARD_DNTV_LIVE_DVB_T_PRO:
591#ifdef HAVE_VP3054_I2C 580#ifdef HAVE_VP3054_I2C
@@ -593,6 +582,9 @@ static int dvb_register(struct cx8802_dev *dev)
593 dev->core->pll_desc = &dvb_pll_fmd1216me; 582 dev->core->pll_desc = &dvb_pll_fmd1216me;
594 dev->dvb.frontend = mt352_attach(&dntv_live_dvbt_pro_config, 583 dev->dvb.frontend = mt352_attach(&dntv_live_dvbt_pro_config,
595 &((struct vp3054_i2c_state *)dev->card_priv)->adap); 584 &((struct vp3054_i2c_state *)dev->card_priv)->adap);
585 if (dev->dvb.frontend != NULL) {
586 dev->dvb.frontend->ops->tuner_ops.set_params = dntv_live_dvbt_pro_tuner_set_params;
587 }
596#else 588#else
597 printk("%s: built without vp3054 support\n", dev->core->name); 589 printk("%s: built without vp3054 support\n", dev->core->name);
598#endif 590#endif
@@ -600,10 +592,11 @@ static int dvb_register(struct cx8802_dev *dev)
600 case CX88_BOARD_DVICO_FUSIONHDTV_DVB_T_DUAL: 592 case CX88_BOARD_DVICO_FUSIONHDTV_DVB_T_DUAL:
601 /* The tin box says DEE1601, but it seems to be DTT7579 593 /* The tin box says DEE1601, but it seems to be DTT7579
602 * compatible, with a slightly different MT352 AGC gain. */ 594 * compatible, with a slightly different MT352 AGC gain. */
603 dev->core->pll_addr = 0x61;
604 dev->core->pll_desc = &dvb_pll_thomson_dtt7579;
605 dev->dvb.frontend = mt352_attach(&dvico_fusionhdtv_dual, 595 dev->dvb.frontend = mt352_attach(&dvico_fusionhdtv_dual,
606 &dev->core->i2c_adap); 596 &dev->core->i2c_adap);
597 if (dev->dvb.frontend != NULL) {
598 dvb_pll_attach(dev->dvb.frontend, 0x61, &dev->core->i2c_adap, &dvb_pll_thomson_dtt7579);
599 }
607 break; 600 break;
608#endif 601#endif
609#ifdef HAVE_ZL10353 602#ifdef HAVE_ZL10353
@@ -612,12 +605,18 @@ static int dvb_register(struct cx8802_dev *dev)
612 dev->core->pll_desc = &dvb_pll_thomson_fe6600; 605 dev->core->pll_desc = &dvb_pll_thomson_fe6600;
613 dev->dvb.frontend = zl10353_attach(&dvico_fusionhdtv_hybrid, 606 dev->dvb.frontend = zl10353_attach(&dvico_fusionhdtv_hybrid,
614 &dev->core->i2c_adap); 607 &dev->core->i2c_adap);
608 if (dev->dvb.frontend != NULL) {
609 dev->dvb.frontend->ops->tuner_ops.set_params = dvico_hybrid_tuner_set_params;
610 }
615 break; 611 break;
616#endif 612#endif
617#ifdef HAVE_OR51132 613#ifdef HAVE_OR51132
618 case CX88_BOARD_PCHDTV_HD3000: 614 case CX88_BOARD_PCHDTV_HD3000:
619 dev->dvb.frontend = or51132_attach(&pchdtv_hd3000, 615 dev->dvb.frontend = or51132_attach(&pchdtv_hd3000,
620 &dev->core->i2c_adap); 616 &dev->core->i2c_adap);
617 if (dev->dvb.frontend != NULL) {
618 dvb_pll_attach(dev->dvb.frontend, 0x61, &dev->core->i2c_adap, &dvb_pll_thomson_dtt761x);
619 }
621 break; 620 break;
622#endif 621#endif
623#ifdef HAVE_LGDT330X 622#ifdef HAVE_LGDT330X
@@ -638,6 +637,9 @@ static int dvb_register(struct cx8802_dev *dev)
638 dev->core->pll_desc = &dvb_pll_microtune_4042; 637 dev->core->pll_desc = &dvb_pll_microtune_4042;
639 dev->dvb.frontend = lgdt330x_attach(&fusionhdtv_3_gold, 638 dev->dvb.frontend = lgdt330x_attach(&fusionhdtv_3_gold,
640 &dev->core->i2c_adap); 639 &dev->core->i2c_adap);
640 if (dev->dvb.frontend != NULL) {
641 dev->dvb.frontend->ops->tuner_ops.set_params = lgdt3302_tuner_set_params;
642 }
641 } 643 }
642 break; 644 break;
643 case CX88_BOARD_DVICO_FUSIONHDTV_3_GOLD_T: 645 case CX88_BOARD_DVICO_FUSIONHDTV_3_GOLD_T:
@@ -654,6 +656,9 @@ static int dvb_register(struct cx8802_dev *dev)
654 dev->core->pll_desc = &dvb_pll_thomson_dtt761x; 656 dev->core->pll_desc = &dvb_pll_thomson_dtt761x;
655 dev->dvb.frontend = lgdt330x_attach(&fusionhdtv_3_gold, 657 dev->dvb.frontend = lgdt330x_attach(&fusionhdtv_3_gold,
656 &dev->core->i2c_adap); 658 &dev->core->i2c_adap);
659 if (dev->dvb.frontend != NULL) {
660 dev->dvb.frontend->ops->tuner_ops.set_params = lgdt3302_tuner_set_params;
661 }
657 } 662 }
658 break; 663 break;
659 case CX88_BOARD_DVICO_FUSIONHDTV_5_GOLD: 664 case CX88_BOARD_DVICO_FUSIONHDTV_5_GOLD:
@@ -668,6 +673,9 @@ static int dvb_register(struct cx8802_dev *dev)
668 mdelay(200); 673 mdelay(200);
669 dev->dvb.frontend = lgdt330x_attach(&fusionhdtv_5_gold, 674 dev->dvb.frontend = lgdt330x_attach(&fusionhdtv_5_gold,
670 &dev->core->i2c_adap); 675 &dev->core->i2c_adap);
676 if (dev->dvb.frontend != NULL) {
677 dev->dvb.frontend->ops->tuner_ops.set_params = lgdt3303_tuner_set_params;
678 }
671 } 679 }
672 break; 680 break;
673 case CX88_BOARD_PCHDTV_HD5500: 681 case CX88_BOARD_PCHDTV_HD5500:
@@ -682,6 +690,9 @@ static int dvb_register(struct cx8802_dev *dev)
682 mdelay(200); 690 mdelay(200);
683 dev->dvb.frontend = lgdt330x_attach(&pchdtv_hd5500, 691 dev->dvb.frontend = lgdt330x_attach(&pchdtv_hd5500,
684 &dev->core->i2c_adap); 692 &dev->core->i2c_adap);
693 if (dev->dvb.frontend != NULL) {
694 dev->dvb.frontend->ops->tuner_ops.set_params = lgdt3303_tuner_set_params;
695 }
685 } 696 }
686 break; 697 break;
687#endif 698#endif
@@ -689,6 +700,9 @@ static int dvb_register(struct cx8802_dev *dev)
689 case CX88_BOARD_ATI_HDTVWONDER: 700 case CX88_BOARD_ATI_HDTVWONDER:
690 dev->dvb.frontend = nxt200x_attach(&ati_hdtvwonder, 701 dev->dvb.frontend = nxt200x_attach(&ati_hdtvwonder,
691 &dev->core->i2c_adap); 702 &dev->core->i2c_adap);
703 if (dev->dvb.frontend != NULL) {
704 dvb_pll_attach(dev->dvb.frontend, 0x61, &dev->core->i2c_adap, &dvb_pll_tuv1236d);
705 }
692 break; 706 break;
693#endif 707#endif
694#ifdef HAVE_CX24123 708#ifdef HAVE_CX24123