diff options
author | Michael Krufky <mkrufky@linuxtv.org> | 2007-09-08 14:17:13 -0400 |
---|---|---|
committer | Mauro Carvalho Chehab <mchehab@infradead.org> | 2007-10-09 21:14:29 -0400 |
commit | 9bc37caadffe8327683980b2323371691fa182e3 (patch) | |
tree | 0253bee2e4fc0b13e740760399b0ca26fe2b4703 | |
parent | 579f1163cd5b2a3fd96ec5b84b18a071e7da3b6b (diff) |
V4L/DVB (6196): cx23885: add support for DViCO FusionHDTV 5 Express
This patch adds digital ATSC / QAM support for the DViCO FusionHDTV5 Express.
Remote control is supported by ir-kbd-i2c, RTC is supported by rtc-isl1208.
Signed-off-by: Michael Krufky <mkrufky@linuxtv.org>
Signed-off-by: Steven Toth <stoth@hauppauge.com>
Signed-off-by: Mauro Carvalho Chehab <mchehab@infradead.org>
-rw-r--r-- | drivers/media/video/cx23885/cx23885-cards.c | 8 | ||||
-rw-r--r-- | drivers/media/video/cx23885/cx23885-core.c | 26 | ||||
-rw-r--r-- | drivers/media/video/cx23885/cx23885-dvb.c | 18 | ||||
-rw-r--r-- | drivers/media/video/cx23885/cx23885-i2c.c | 6 | ||||
-rw-r--r-- | drivers/media/video/cx23885/cx23885.h | 1 | ||||
-rw-r--r-- | drivers/media/video/ir-kbd-i2c.c | 3 | ||||
-rw-r--r-- | drivers/media/video/tuner-core.c | 3 |
7 files changed, 62 insertions, 3 deletions
diff --git a/drivers/media/video/cx23885/cx23885-cards.c b/drivers/media/video/cx23885/cx23885-cards.c index 09d4376c2e05..cdda11ddf145 100644 --- a/drivers/media/video/cx23885/cx23885-cards.c +++ b/drivers/media/video/cx23885/cx23885-cards.c | |||
@@ -109,6 +109,10 @@ struct cx23885_board cx23885_boards[] = { | |||
109 | .gpio0 = 0xff02, | 109 | .gpio0 = 0xff02, |
110 | }}, | 110 | }}, |
111 | }, | 111 | }, |
112 | [CX23885_BOARD_DVICO_FUSIONHDTV_5_EXP] = { | ||
113 | .name = "DViCO FusionHDTV5 Express", | ||
114 | .portc = CX23885_MPEG_DVB, | ||
115 | }, | ||
112 | }; | 116 | }; |
113 | const unsigned int cx23885_bcount = ARRAY_SIZE(cx23885_boards); | 117 | const unsigned int cx23885_bcount = ARRAY_SIZE(cx23885_boards); |
114 | 118 | ||
@@ -136,6 +140,10 @@ struct cx23885_subid cx23885_subids[] = { | |||
136 | .subvendor = 0x0070, | 140 | .subvendor = 0x0070, |
137 | .subdevice = 0x7911, | 141 | .subdevice = 0x7911, |
138 | .card = CX23885_BOARD_HAUPPAUGE_HVR1250, | 142 | .card = CX23885_BOARD_HAUPPAUGE_HVR1250, |
143 | },{ | ||
144 | .subvendor = 0x18ac, | ||
145 | .subdevice = 0xd500, | ||
146 | .card = CX23885_BOARD_DVICO_FUSIONHDTV_5_EXP, | ||
139 | }, | 147 | }, |
140 | }; | 148 | }; |
141 | const unsigned int cx23885_idcount = ARRAY_SIZE(cx23885_subids); | 149 | const unsigned int cx23885_idcount = ARRAY_SIZE(cx23885_subids); |
diff --git a/drivers/media/video/cx23885/cx23885-core.c b/drivers/media/video/cx23885/cx23885-core.c index 553a72ae163a..bcba19263476 100644 --- a/drivers/media/video/cx23885/cx23885-core.c +++ b/drivers/media/video/cx23885/cx23885-core.c | |||
@@ -793,6 +793,32 @@ static int cx23885_dev_setup(struct cx23885_dev *dev) | |||
793 | cx23885_ir_init(dev); | 793 | cx23885_ir_init(dev); |
794 | 794 | ||
795 | switch (dev->board) { | 795 | switch (dev->board) { |
796 | case CX23885_BOARD_DVICO_FUSIONHDTV_5_EXP: | ||
797 | dev->ts2.reg_gpcnt = VID_B_GPCNT; | ||
798 | dev->ts2.reg_gpcnt_ctl = VID_B_GPCNT_CTL; | ||
799 | dev->ts2.reg_dma_ctl = VID_B_DMA_CTL; | ||
800 | dev->ts2.reg_lngth = VID_B_LNGTH; | ||
801 | dev->ts2.reg_hw_sop_ctrl = VID_B_HW_SOP_CTL; | ||
802 | dev->ts2.reg_gen_ctrl = VID_B_GEN_CTL; | ||
803 | dev->ts2.reg_bd_pkt_status = VID_B_BD_PKT_STATUS; | ||
804 | dev->ts2.reg_sop_status = VID_B_SOP_STATUS; | ||
805 | dev->ts2.reg_fifo_ovfl_stat = VID_B_FIFO_OVFL_STAT; | ||
806 | dev->ts2.reg_vld_misc = VID_B_VLD_MISC; | ||
807 | dev->ts2.reg_ts_clk_en = VID_B_TS_CLK_EN; | ||
808 | dev->ts2.reg_ts_int_msk = VID_B_INT_MSK; | ||
809 | dev->ts2.reg_src_sel = VID_B_SRC_SEL; | ||
810 | |||
811 | // FIXME: Make this board specific | ||
812 | dev->ts2.pci_irqmask = 0x02; /* TS Port 2 bit */ | ||
813 | dev->ts2.dma_ctl_val = 0x11; /* Enable RISC controller and Fifo */ | ||
814 | dev->ts2.ts_int_msk_val = 0x1111; /* TS port bits for RISC */ | ||
815 | dev->ts2.gen_ctrl_val = 0xc; /* Serial bus + punctured clock */ | ||
816 | dev->ts2.ts_clk_en_val = 0x1; /* Enable TS_CLK */ | ||
817 | dev->ts2.src_sel_val = CX23885_SRC_SEL_PARALLEL_MPEG_VIDEO; | ||
818 | |||
819 | // Drive this from cards.c (portb/c) and move it outside of this switch | ||
820 | dev->ts2.sram_chno = SRAM_CH03; | ||
821 | break; | ||
796 | default: | 822 | default: |
797 | dev->ts2.reg_gpcnt = VID_C_GPCNT; | 823 | dev->ts2.reg_gpcnt = VID_C_GPCNT; |
798 | dev->ts2.reg_gpcnt_ctl = VID_C_GPCNT_CTL; | 824 | dev->ts2.reg_gpcnt_ctl = VID_C_GPCNT_CTL; |
diff --git a/drivers/media/video/cx23885/cx23885-dvb.c b/drivers/media/video/cx23885/cx23885-dvb.c index ffa4c49d6916..0ace919195df 100644 --- a/drivers/media/video/cx23885/cx23885-dvb.c +++ b/drivers/media/video/cx23885/cx23885-dvb.c | |||
@@ -32,6 +32,8 @@ | |||
32 | 32 | ||
33 | #include "s5h1409.h" | 33 | #include "s5h1409.h" |
34 | #include "mt2131.h" | 34 | #include "mt2131.h" |
35 | #include "lgdt330x.h" | ||
36 | #include "dvb-pll.h" | ||
35 | 37 | ||
36 | static unsigned int debug = 0; | 38 | static unsigned int debug = 0; |
37 | 39 | ||
@@ -101,6 +103,12 @@ static struct mt2131_config hauppauge_generic_tunerconfig = { | |||
101 | 0x61 | 103 | 0x61 |
102 | }; | 104 | }; |
103 | 105 | ||
106 | static struct lgdt330x_config fusionhdtv_5_express = { | ||
107 | .demod_address = 0x0e, | ||
108 | .demod_chip = LGDT3303, | ||
109 | .serial_mpeg = 0x40, | ||
110 | }; | ||
111 | |||
104 | static int dvb_register(struct cx23885_tsport *port) | 112 | static int dvb_register(struct cx23885_tsport *port) |
105 | { | 113 | { |
106 | struct cx23885_dev *dev = port->dev; | 114 | struct cx23885_dev *dev = port->dev; |
@@ -131,6 +139,16 @@ static int dvb_register(struct cx23885_tsport *port) | |||
131 | &hauppauge_generic_tunerconfig, 0); | 139 | &hauppauge_generic_tunerconfig, 0); |
132 | } | 140 | } |
133 | break; | 141 | break; |
142 | case CX23885_BOARD_DVICO_FUSIONHDTV_5_EXP: | ||
143 | port->dvb.frontend = dvb_attach(lgdt330x_attach, | ||
144 | &fusionhdtv_5_express, | ||
145 | &dev->i2c_bus[0].i2c_adap); | ||
146 | if (port->dvb.frontend != NULL) { | ||
147 | dvb_attach(dvb_pll_attach, port->dvb.frontend, | ||
148 | 0x61, &dev->i2c_bus[0].i2c_adap, | ||
149 | DVB_PLL_LG_TDVS_H06XF); | ||
150 | } | ||
151 | break; | ||
134 | default: | 152 | default: |
135 | printk("%s: The frontend of your DVB/ATSC card isn't supported yet\n", | 153 | printk("%s: The frontend of your DVB/ATSC card isn't supported yet\n", |
136 | dev->name); | 154 | dev->name); |
diff --git a/drivers/media/video/cx23885/cx23885-i2c.c b/drivers/media/video/cx23885/cx23885-i2c.c index 5572fbbbb5ae..b517c8b5a566 100644 --- a/drivers/media/video/cx23885/cx23885-i2c.c +++ b/drivers/media/video/cx23885/cx23885-i2c.c | |||
@@ -305,12 +305,14 @@ static struct i2c_client cx23885_i2c_client_template = { | |||
305 | }; | 305 | }; |
306 | 306 | ||
307 | static char *i2c_devs[128] = { | 307 | static char *i2c_devs[128] = { |
308 | [ 0x1c >> 1 ] = "lgdt3303", | ||
309 | [ 0x86 >> 1 ] = "tda9887", | ||
308 | [ 0x32 >> 1 ] = "cx24227", | 310 | [ 0x32 >> 1 ] = "cx24227", |
309 | [ 0x88 >> 1 ] = "cx25837", | 311 | [ 0x88 >> 1 ] = "cx25837", |
310 | [ 0x84 >> 1 ] = "tda8295", | 312 | [ 0x84 >> 1 ] = "tda8295", |
311 | [ 0xa0 >> 1 ] = "eeprom", | 313 | [ 0xa0 >> 1 ] = "eeprom", |
312 | [ 0xc0 >> 1 ] = "mt2131/tda8275", | 314 | [ 0xc0 >> 1 ] = "tuner/mt2131/tda8275", |
313 | [ 0xc2 >> 1 ] = "mt2131/tda8275", | 315 | [ 0xc2 >> 1 ] = "tuner/mt2131/tda8275", |
314 | }; | 316 | }; |
315 | 317 | ||
316 | static void do_i2c_scan(char *name, struct i2c_client *c) | 318 | static void do_i2c_scan(char *name, struct i2c_client *c) |
diff --git a/drivers/media/video/cx23885/cx23885.h b/drivers/media/video/cx23885/cx23885.h index 62b44f6d749f..4933274b1e39 100644 --- a/drivers/media/video/cx23885/cx23885.h +++ b/drivers/media/video/cx23885/cx23885.h | |||
@@ -54,6 +54,7 @@ | |||
54 | #define CX23885_BOARD_HAUPPAUGE_HVR1800lp 1 | 54 | #define CX23885_BOARD_HAUPPAUGE_HVR1800lp 1 |
55 | #define CX23885_BOARD_HAUPPAUGE_HVR1800 2 | 55 | #define CX23885_BOARD_HAUPPAUGE_HVR1800 2 |
56 | #define CX23885_BOARD_HAUPPAUGE_HVR1250 3 | 56 | #define CX23885_BOARD_HAUPPAUGE_HVR1250 3 |
57 | #define CX23885_BOARD_DVICO_FUSIONHDTV_5_EXP 4 | ||
57 | 58 | ||
58 | enum cx23885_itype { | 59 | enum cx23885_itype { |
59 | CX23885_VMUX_COMPOSITE1 = 1, | 60 | CX23885_VMUX_COMPOSITE1 = 1, |
diff --git a/drivers/media/video/ir-kbd-i2c.c b/drivers/media/video/ir-kbd-i2c.c index 04f6eb5ea292..d98dd0d1e373 100644 --- a/drivers/media/video/ir-kbd-i2c.c +++ b/drivers/media/video/ir-kbd-i2c.c | |||
@@ -507,6 +507,7 @@ static int ir_probe(struct i2c_adapter *adap) | |||
507 | static const int probe_saa7134[] = { 0x7a, 0x47, 0x71, -1 }; | 507 | static const int probe_saa7134[] = { 0x7a, 0x47, 0x71, -1 }; |
508 | static const int probe_em28XX[] = { 0x30, 0x47, -1 }; | 508 | static const int probe_em28XX[] = { 0x30, 0x47, -1 }; |
509 | static const int probe_cx88[] = { 0x18, 0x6b, 0x71, -1 }; | 509 | static const int probe_cx88[] = { 0x18, 0x6b, 0x71, -1 }; |
510 | static const int probe_cx23885[] = { 0x6b, -1 }; | ||
510 | const int *probe = NULL; | 511 | const int *probe = NULL; |
511 | struct i2c_client c; | 512 | struct i2c_client c; |
512 | unsigned char buf; | 513 | unsigned char buf; |
@@ -527,6 +528,8 @@ static int ir_probe(struct i2c_adapter *adap) | |||
527 | break; | 528 | break; |
528 | case I2C_HW_B_CX2388x: | 529 | case I2C_HW_B_CX2388x: |
529 | probe = probe_cx88; | 530 | probe = probe_cx88; |
531 | case I2C_HW_B_CX23885: | ||
532 | probe = probe_cx23885; | ||
530 | break; | 533 | break; |
531 | } | 534 | } |
532 | if (NULL == probe) | 535 | if (NULL == probe) |
diff --git a/drivers/media/video/tuner-core.c b/drivers/media/video/tuner-core.c index 2d4a3e38f278..94843086cda9 100644 --- a/drivers/media/video/tuner-core.c +++ b/drivers/media/video/tuner-core.c | |||
@@ -665,7 +665,8 @@ static int tuner_probe(struct i2c_adapter *adap) | |||
665 | * FusionHDTV5 RT Gold has an ir receiver at 0x6b | 665 | * FusionHDTV5 RT Gold has an ir receiver at 0x6b |
666 | * and an RTC at 0x6f which can get corrupted if probed. | 666 | * and an RTC at 0x6f which can get corrupted if probed. |
667 | */ | 667 | */ |
668 | if (adap->id == I2C_HW_B_CX2388x) { | 668 | if ((adap->id == I2C_HW_B_CX2388x) || |
669 | (adap->id == I2C_HW_B_CX23885)) { | ||
669 | unsigned int i = 0; | 670 | unsigned int i = 0; |
670 | 671 | ||
671 | while (i < I2C_CLIENT_MAX_OPTS && ignore[i] != I2C_CLIENT_END) | 672 | while (i < I2C_CLIENT_MAX_OPTS && ignore[i] != I2C_CLIENT_END) |