diff options
Diffstat (limited to 'drivers/media/video/cx23885/cx23885-dvb.c')
-rw-r--r-- | drivers/media/video/cx23885/cx23885-dvb.c | 123 |
1 files changed, 121 insertions, 2 deletions
diff --git a/drivers/media/video/cx23885/cx23885-dvb.c b/drivers/media/video/cx23885/cx23885-dvb.c index 1dc070da8652..e236df23370e 100644 --- a/drivers/media/video/cx23885/cx23885-dvb.c +++ b/drivers/media/video/cx23885/cx23885-dvb.c | |||
@@ -49,8 +49,10 @@ | |||
49 | #include "lnbh24.h" | 49 | #include "lnbh24.h" |
50 | #include "cx24116.h" | 50 | #include "cx24116.h" |
51 | #include "cimax2.h" | 51 | #include "cimax2.h" |
52 | #include "lgs8gxx.h" | ||
52 | #include "netup-eeprom.h" | 53 | #include "netup-eeprom.h" |
53 | #include "netup-init.h" | 54 | #include "netup-init.h" |
55 | #include "lgdt3305.h" | ||
54 | 56 | ||
55 | static unsigned int debug; | 57 | static unsigned int debug; |
56 | 58 | ||
@@ -122,7 +124,22 @@ static struct tda10048_config hauppauge_hvr1200_config = { | |||
122 | .demod_address = 0x10 >> 1, | 124 | .demod_address = 0x10 >> 1, |
123 | .output_mode = TDA10048_SERIAL_OUTPUT, | 125 | .output_mode = TDA10048_SERIAL_OUTPUT, |
124 | .fwbulkwritelen = TDA10048_BULKWRITE_200, | 126 | .fwbulkwritelen = TDA10048_BULKWRITE_200, |
125 | .inversion = TDA10048_INVERSION_ON | 127 | .inversion = TDA10048_INVERSION_ON, |
128 | .dtv6_if_freq_khz = TDA10048_IF_3300, | ||
129 | .dtv7_if_freq_khz = TDA10048_IF_3800, | ||
130 | .dtv8_if_freq_khz = TDA10048_IF_4300, | ||
131 | .clk_freq_khz = TDA10048_CLK_16000, | ||
132 | }; | ||
133 | |||
134 | static struct tda10048_config hauppauge_hvr1210_config = { | ||
135 | .demod_address = 0x10 >> 1, | ||
136 | .output_mode = TDA10048_SERIAL_OUTPUT, | ||
137 | .fwbulkwritelen = TDA10048_BULKWRITE_200, | ||
138 | .inversion = TDA10048_INVERSION_ON, | ||
139 | .dtv6_if_freq_khz = TDA10048_IF_3300, | ||
140 | .dtv7_if_freq_khz = TDA10048_IF_3500, | ||
141 | .dtv8_if_freq_khz = TDA10048_IF_4000, | ||
142 | .clk_freq_khz = TDA10048_CLK_16000, | ||
126 | }; | 143 | }; |
127 | 144 | ||
128 | static struct s5h1409_config hauppauge_ezqam_config = { | 145 | static struct s5h1409_config hauppauge_ezqam_config = { |
@@ -194,6 +211,16 @@ static struct s5h1411_config dvico_s5h1411_config = { | |||
194 | .mpeg_timing = S5H1411_MPEGTIMING_CONTINOUS_NONINVERTING_CLOCK, | 211 | .mpeg_timing = S5H1411_MPEGTIMING_CONTINOUS_NONINVERTING_CLOCK, |
195 | }; | 212 | }; |
196 | 213 | ||
214 | static struct s5h1411_config hcw_s5h1411_config = { | ||
215 | .output_mode = S5H1411_SERIAL_OUTPUT, | ||
216 | .gpio = S5H1411_GPIO_OFF, | ||
217 | .vsb_if = S5H1411_IF_44000, | ||
218 | .qam_if = S5H1411_IF_4000, | ||
219 | .inversion = S5H1411_INVERSION_ON, | ||
220 | .status_mode = S5H1411_DEMODLOCKING, | ||
221 | .mpeg_timing = S5H1411_MPEGTIMING_CONTINOUS_NONINVERTING_CLOCK, | ||
222 | }; | ||
223 | |||
197 | static struct xc5000_config hauppauge_hvr1500q_tunerconfig = { | 224 | static struct xc5000_config hauppauge_hvr1500q_tunerconfig = { |
198 | .i2c_address = 0x61, | 225 | .i2c_address = 0x61, |
199 | .if_khz = 5380, | 226 | .if_khz = 5380, |
@@ -224,6 +251,32 @@ static struct tda18271_config hauppauge_hvr1200_tuner_config = { | |||
224 | .gate = TDA18271_GATE_ANALOG, | 251 | .gate = TDA18271_GATE_ANALOG, |
225 | }; | 252 | }; |
226 | 253 | ||
254 | static struct tda18271_config hauppauge_hvr1210_tuner_config = { | ||
255 | .gate = TDA18271_GATE_DIGITAL, | ||
256 | }; | ||
257 | |||
258 | static struct tda18271_std_map hauppauge_hvr127x_std_map = { | ||
259 | .atsc_6 = { .if_freq = 3250, .agc_mode = 3, .std = 4, | ||
260 | .if_lvl = 1, .rfagc_top = 0x58 }, | ||
261 | .qam_6 = { .if_freq = 4000, .agc_mode = 3, .std = 5, | ||
262 | .if_lvl = 1, .rfagc_top = 0x58 }, | ||
263 | }; | ||
264 | |||
265 | static struct tda18271_config hauppauge_hvr127x_config = { | ||
266 | .std_map = &hauppauge_hvr127x_std_map, | ||
267 | }; | ||
268 | |||
269 | static struct lgdt3305_config hauppauge_lgdt3305_config = { | ||
270 | .i2c_addr = 0x0e, | ||
271 | .mpeg_mode = LGDT3305_MPEG_SERIAL, | ||
272 | .tpclk_edge = LGDT3305_TPCLK_FALLING_EDGE, | ||
273 | .tpvalid_polarity = LGDT3305_TP_VALID_HIGH, | ||
274 | .deny_i2c_rptr = 1, | ||
275 | .spectral_inversion = 1, | ||
276 | .qam_if_khz = 4000, | ||
277 | .vsb_if_khz = 3250, | ||
278 | }; | ||
279 | |||
227 | static struct dibx000_agc_config xc3028_agc_config = { | 280 | static struct dibx000_agc_config xc3028_agc_config = { |
228 | BAND_VHF | BAND_UHF, /* band_caps */ | 281 | BAND_VHF | BAND_UHF, /* band_caps */ |
229 | 282 | ||
@@ -368,10 +421,29 @@ static struct cx24116_config dvbworld_cx24116_config = { | |||
368 | .demod_address = 0x05, | 421 | .demod_address = 0x05, |
369 | }; | 422 | }; |
370 | 423 | ||
424 | static struct lgs8gxx_config mygica_x8506_lgs8gl5_config = { | ||
425 | .prod = LGS8GXX_PROD_LGS8GL5, | ||
426 | .demod_address = 0x19, | ||
427 | .serial_ts = 0, | ||
428 | .ts_clk_pol = 1, | ||
429 | .ts_clk_gated = 1, | ||
430 | .if_clk_freq = 30400, /* 30.4 MHz */ | ||
431 | .if_freq = 5380, /* 5.38 MHz */ | ||
432 | .if_neg_center = 1, | ||
433 | .ext_adc = 0, | ||
434 | .adc_signed = 0, | ||
435 | .if_neg_edge = 0, | ||
436 | }; | ||
437 | |||
438 | static struct xc5000_config mygica_x8506_xc5000_config = { | ||
439 | .i2c_address = 0x61, | ||
440 | .if_khz = 5380, | ||
441 | }; | ||
442 | |||
371 | static int dvb_register(struct cx23885_tsport *port) | 443 | static int dvb_register(struct cx23885_tsport *port) |
372 | { | 444 | { |
373 | struct cx23885_dev *dev = port->dev; | 445 | struct cx23885_dev *dev = port->dev; |
374 | struct cx23885_i2c *i2c_bus = NULL; | 446 | struct cx23885_i2c *i2c_bus = NULL, *i2c_bus2 = NULL; |
375 | struct videobuf_dvb_frontend *fe0; | 447 | struct videobuf_dvb_frontend *fe0; |
376 | int ret; | 448 | int ret; |
377 | 449 | ||
@@ -396,6 +468,29 @@ static int dvb_register(struct cx23885_tsport *port) | |||
396 | &hauppauge_generic_tunerconfig, 0); | 468 | &hauppauge_generic_tunerconfig, 0); |
397 | } | 469 | } |
398 | break; | 470 | break; |
471 | case CX23885_BOARD_HAUPPAUGE_HVR1270: | ||
472 | case CX23885_BOARD_HAUPPAUGE_HVR1275: | ||
473 | i2c_bus = &dev->i2c_bus[0]; | ||
474 | fe0->dvb.frontend = dvb_attach(lgdt3305_attach, | ||
475 | &hauppauge_lgdt3305_config, | ||
476 | &i2c_bus->i2c_adap); | ||
477 | if (fe0->dvb.frontend != NULL) { | ||
478 | dvb_attach(tda18271_attach, fe0->dvb.frontend, | ||
479 | 0x60, &dev->i2c_bus[1].i2c_adap, | ||
480 | &hauppauge_hvr127x_config); | ||
481 | } | ||
482 | break; | ||
483 | case CX23885_BOARD_HAUPPAUGE_HVR1255: | ||
484 | i2c_bus = &dev->i2c_bus[0]; | ||
485 | fe0->dvb.frontend = dvb_attach(s5h1411_attach, | ||
486 | &hcw_s5h1411_config, | ||
487 | &i2c_bus->i2c_adap); | ||
488 | if (fe0->dvb.frontend != NULL) { | ||
489 | dvb_attach(tda18271_attach, fe0->dvb.frontend, | ||
490 | 0x60, &dev->i2c_bus[1].i2c_adap, | ||
491 | &hauppauge_tda18271_config); | ||
492 | } | ||
493 | break; | ||
399 | case CX23885_BOARD_HAUPPAUGE_HVR1800: | 494 | case CX23885_BOARD_HAUPPAUGE_HVR1800: |
400 | i2c_bus = &dev->i2c_bus[0]; | 495 | i2c_bus = &dev->i2c_bus[0]; |
401 | switch (alt_tuner) { | 496 | switch (alt_tuner) { |
@@ -496,6 +591,17 @@ static int dvb_register(struct cx23885_tsport *port) | |||
496 | &hauppauge_hvr1200_tuner_config); | 591 | &hauppauge_hvr1200_tuner_config); |
497 | } | 592 | } |
498 | break; | 593 | break; |
594 | case CX23885_BOARD_HAUPPAUGE_HVR1210: | ||
595 | i2c_bus = &dev->i2c_bus[0]; | ||
596 | fe0->dvb.frontend = dvb_attach(tda10048_attach, | ||
597 | &hauppauge_hvr1210_config, | ||
598 | &i2c_bus->i2c_adap); | ||
599 | if (fe0->dvb.frontend != NULL) { | ||
600 | dvb_attach(tda18271_attach, fe0->dvb.frontend, | ||
601 | 0x60, &dev->i2c_bus[1].i2c_adap, | ||
602 | &hauppauge_hvr1210_tuner_config); | ||
603 | } | ||
604 | break; | ||
499 | case CX23885_BOARD_HAUPPAUGE_HVR1400: | 605 | case CX23885_BOARD_HAUPPAUGE_HVR1400: |
500 | i2c_bus = &dev->i2c_bus[0]; | 606 | i2c_bus = &dev->i2c_bus[0]; |
501 | fe0->dvb.frontend = dvb_attach(dib7000p_attach, | 607 | fe0->dvb.frontend = dvb_attach(dib7000p_attach, |
@@ -659,6 +765,19 @@ static int dvb_register(struct cx23885_tsport *port) | |||
659 | break; | 765 | break; |
660 | } | 766 | } |
661 | break; | 767 | break; |
768 | case CX23885_BOARD_MYGICA_X8506: | ||
769 | i2c_bus = &dev->i2c_bus[0]; | ||
770 | i2c_bus2 = &dev->i2c_bus[1]; | ||
771 | fe0->dvb.frontend = dvb_attach(lgs8gxx_attach, | ||
772 | &mygica_x8506_lgs8gl5_config, | ||
773 | &i2c_bus->i2c_adap); | ||
774 | if (fe0->dvb.frontend != NULL) { | ||
775 | dvb_attach(xc5000_attach, | ||
776 | fe0->dvb.frontend, | ||
777 | &i2c_bus2->i2c_adap, | ||
778 | &mygica_x8506_xc5000_config); | ||
779 | } | ||
780 | break; | ||
662 | default: | 781 | default: |
663 | printk(KERN_INFO "%s: The frontend of your DVB/ATSC card " | 782 | printk(KERN_INFO "%s: The frontend of your DVB/ATSC card " |
664 | " isn't supported yet\n", | 783 | " isn't supported yet\n", |