diff options
author | Steven Toth <stoth@hauppauge.com> | 2007-12-17 23:57:06 -0500 |
---|---|---|
committer | Mauro Carvalho Chehab <mchehab@infradead.org> | 2008-01-25 16:04:12 -0500 |
commit | d1987d55a1eda774dfbab240a432607c17241d07 (patch) | |
tree | 7b45520cfd2496d15c47b1bac641c42c1964c9aa /drivers/media | |
parent | aacb9d31ee65c0685745ca4dfc7cdd24f8b7d92b (diff) |
V4L/DVB (6885): Add support for the Hauppauge HVR1500Q
The express card ATSC/QAM tuner.
Signed-off-by: Steven Toth <stoth@hauppauge.com>
Signed-off-by: Mauro Carvalho Chehab <mchehab@infradead.org>
Diffstat (limited to 'drivers/media')
-rw-r--r-- | drivers/media/video/cx23885/cx23885-cards.c | 17 | ||||
-rw-r--r-- | drivers/media/video/cx23885/cx23885-dvb.c | 54 | ||||
-rw-r--r-- | drivers/media/video/cx23885/cx23885-i2c.c | 2 | ||||
-rw-r--r-- | drivers/media/video/cx23885/cx23885.h | 1 |
4 files changed, 73 insertions, 1 deletions
diff --git a/drivers/media/video/cx23885/cx23885-cards.c b/drivers/media/video/cx23885/cx23885-cards.c index 134b931b160e..515f415564d5 100644 --- a/drivers/media/video/cx23885/cx23885-cards.c +++ b/drivers/media/video/cx23885/cx23885-cards.c | |||
@@ -113,6 +113,11 @@ struct cx23885_board cx23885_boards[] = { | |||
113 | .name = "DViCO FusionHDTV5 Express", | 113 | .name = "DViCO FusionHDTV5 Express", |
114 | .portb = CX23885_MPEG_DVB, | 114 | .portb = CX23885_MPEG_DVB, |
115 | }, | 115 | }, |
116 | [CX23885_BOARD_HAUPPAUGE_HVR1500Q] = { | ||
117 | .name = "Hauppauge WinTV-HVR1500Q", | ||
118 | .portc = CX23885_MPEG_DVB, | ||
119 | }, | ||
120 | |||
116 | }; | 121 | }; |
117 | const unsigned int cx23885_bcount = ARRAY_SIZE(cx23885_boards); | 122 | const unsigned int cx23885_bcount = ARRAY_SIZE(cx23885_boards); |
118 | 123 | ||
@@ -144,6 +149,10 @@ struct cx23885_subid cx23885_subids[] = { | |||
144 | .subvendor = 0x18ac, | 149 | .subvendor = 0x18ac, |
145 | .subdevice = 0xd500, | 150 | .subdevice = 0xd500, |
146 | .card = CX23885_BOARD_DVICO_FUSIONHDTV_5_EXP, | 151 | .card = CX23885_BOARD_DVICO_FUSIONHDTV_5_EXP, |
152 | },{ | ||
153 | .subvendor = 0x0070, | ||
154 | .subdevice = 0x7797, | ||
155 | .card = CX23885_BOARD_HAUPPAUGE_HVR1500Q, | ||
147 | }, | 156 | }, |
148 | }; | 157 | }; |
149 | const unsigned int cx23885_idcount = ARRAY_SIZE(cx23885_subids); | 158 | const unsigned int cx23885_idcount = ARRAY_SIZE(cx23885_subids); |
@@ -204,6 +213,11 @@ void cx23885_gpio_setup(struct cx23885_dev *dev) | |||
204 | /* GPIO-0 cx24227 demodulator reset */ | 213 | /* GPIO-0 cx24227 demodulator reset */ |
205 | cx_set(GP0_IO, 0x00010001); /* Bring the part out of reset */ | 214 | cx_set(GP0_IO, 0x00010001); /* Bring the part out of reset */ |
206 | break; | 215 | break; |
216 | case CX23885_BOARD_HAUPPAUGE_HVR1500Q: | ||
217 | /* GPIO-0 cx24227 demodulator reset */ | ||
218 | /* GPIO-2 xc5000 tuner reset */ | ||
219 | cx_set(GP0_IO, 0x00050005); /* Bring the part out of reset */ | ||
220 | break; | ||
207 | case CX23885_BOARD_HAUPPAUGE_HVR1800: | 221 | case CX23885_BOARD_HAUPPAUGE_HVR1800: |
208 | /* GPIO-0 656_CLK */ | 222 | /* GPIO-0 656_CLK */ |
209 | /* GPIO-1 656_D0 */ | 223 | /* GPIO-1 656_D0 */ |
@@ -221,6 +235,7 @@ int cx23885_ir_init(struct cx23885_dev *dev) | |||
221 | { | 235 | { |
222 | switch (dev->board) { | 236 | switch (dev->board) { |
223 | case CX23885_BOARD_HAUPPAUGE_HVR1250: | 237 | case CX23885_BOARD_HAUPPAUGE_HVR1250: |
238 | case CX23885_BOARD_HAUPPAUGE_HVR1500Q: | ||
224 | case CX23885_BOARD_HAUPPAUGE_HVR1800: | 239 | case CX23885_BOARD_HAUPPAUGE_HVR1800: |
225 | /* FIXME: Implement me */ | 240 | /* FIXME: Implement me */ |
226 | break; | 241 | break; |
@@ -244,6 +259,7 @@ void cx23885_card_setup(struct cx23885_dev *dev) | |||
244 | 259 | ||
245 | switch (dev->board) { | 260 | switch (dev->board) { |
246 | case CX23885_BOARD_HAUPPAUGE_HVR1250: | 261 | case CX23885_BOARD_HAUPPAUGE_HVR1250: |
262 | case CX23885_BOARD_HAUPPAUGE_HVR1500Q: | ||
247 | case CX23885_BOARD_HAUPPAUGE_HVR1800: | 263 | case CX23885_BOARD_HAUPPAUGE_HVR1800: |
248 | case CX23885_BOARD_HAUPPAUGE_HVR1800lp: | 264 | case CX23885_BOARD_HAUPPAUGE_HVR1800lp: |
249 | if (dev->i2c_bus[0].i2c_rc == 0) | 265 | if (dev->i2c_bus[0].i2c_rc == 0) |
@@ -258,6 +274,7 @@ void cx23885_card_setup(struct cx23885_dev *dev) | |||
258 | ts1->src_sel_val = CX23885_SRC_SEL_PARALLEL_MPEG_VIDEO; | 274 | ts1->src_sel_val = CX23885_SRC_SEL_PARALLEL_MPEG_VIDEO; |
259 | break; | 275 | break; |
260 | case CX23885_BOARD_HAUPPAUGE_HVR1250: | 276 | case CX23885_BOARD_HAUPPAUGE_HVR1250: |
277 | case CX23885_BOARD_HAUPPAUGE_HVR1500Q: | ||
261 | case CX23885_BOARD_HAUPPAUGE_HVR1800: | 278 | case CX23885_BOARD_HAUPPAUGE_HVR1800: |
262 | case CX23885_BOARD_HAUPPAUGE_HVR1800lp: | 279 | case CX23885_BOARD_HAUPPAUGE_HVR1800lp: |
263 | default: | 280 | default: |
diff --git a/drivers/media/video/cx23885/cx23885-dvb.c b/drivers/media/video/cx23885/cx23885-dvb.c index 96d732098a0d..5fa65ef08bfd 100644 --- a/drivers/media/video/cx23885/cx23885-dvb.c +++ b/drivers/media/video/cx23885/cx23885-dvb.c | |||
@@ -33,6 +33,7 @@ | |||
33 | #include "s5h1409.h" | 33 | #include "s5h1409.h" |
34 | #include "mt2131.h" | 34 | #include "mt2131.h" |
35 | #include "lgdt330x.h" | 35 | #include "lgdt330x.h" |
36 | #include "xc5000.h" | ||
36 | #include "dvb-pll.h" | 37 | #include "dvb-pll.h" |
37 | 38 | ||
38 | static unsigned int debug = 0; | 39 | static unsigned int debug = 0; |
@@ -74,6 +75,32 @@ static void dvb_buf_release(struct videobuf_queue *q, | |||
74 | cx23885_free_buffer(q, (struct cx23885_buffer*)vb); | 75 | cx23885_free_buffer(q, (struct cx23885_buffer*)vb); |
75 | } | 76 | } |
76 | 77 | ||
78 | static int cx23885_request_firmware(struct dvb_frontend *fe, | ||
79 | const struct firmware **fw, char *name) | ||
80 | { | ||
81 | struct cx23885_tsport *port = fe->dvb->priv; | ||
82 | struct cx23885_dev *dev = port->dev; | ||
83 | |||
84 | dprintk(1, "%s(?,?,%s)\n", __FUNCTION__, name); | ||
85 | |||
86 | return request_firmware(fw, name, &dev->pci->dev); | ||
87 | } | ||
88 | |||
89 | static int hauppauge_hvr1500q_tuner_reset(struct dvb_frontend *fe) | ||
90 | { | ||
91 | struct cx23885_tsport *port = fe->dvb->priv; | ||
92 | struct cx23885_dev *dev = port->dev; | ||
93 | |||
94 | dprintk(1, "%s()\n", __FUNCTION__); | ||
95 | |||
96 | /* Drive the tuner into reset back back */ | ||
97 | cx_clear(GP0_IO, 0x00000004); | ||
98 | mdelay(200); | ||
99 | cx_set(GP0_IO, 0x00000004); | ||
100 | |||
101 | return 0; | ||
102 | } | ||
103 | |||
77 | static struct videobuf_queue_ops dvb_qops = { | 104 | static struct videobuf_queue_ops dvb_qops = { |
78 | .buf_setup = dvb_buf_setup, | 105 | .buf_setup = dvb_buf_setup, |
79 | .buf_prepare = dvb_buf_prepare, | 106 | .buf_prepare = dvb_buf_prepare, |
@@ -109,6 +136,22 @@ static struct lgdt330x_config fusionhdtv_5_express = { | |||
109 | .serial_mpeg = 0x40, | 136 | .serial_mpeg = 0x40, |
110 | }; | 137 | }; |
111 | 138 | ||
139 | static struct s5h1409_config hauppauge_hvr1500q_config = { | ||
140 | .demod_address = 0x32 >> 1, | ||
141 | .output_mode = S5H1409_SERIAL_OUTPUT, | ||
142 | .gpio = S5H1409_GPIO_ON, | ||
143 | .qam_if = 44000, | ||
144 | .inversion = S5H1409_INVERSION_OFF, | ||
145 | .status_mode = S5H1409_DEMODLOCKING | ||
146 | }; | ||
147 | |||
148 | static struct xc5000_config hauppauge_hvr1500q_tunerconfig = { | ||
149 | .i2c_address = 0x61, | ||
150 | .if_frequency = 4570000, | ||
151 | .request_firmware = cx23885_request_firmware, | ||
152 | .tuner_reset = hauppauge_hvr1500q_tuner_reset | ||
153 | }; | ||
154 | |||
112 | static int dvb_register(struct cx23885_tsport *port) | 155 | static int dvb_register(struct cx23885_tsport *port) |
113 | { | 156 | { |
114 | struct cx23885_dev *dev = port->dev; | 157 | struct cx23885_dev *dev = port->dev; |
@@ -152,6 +195,17 @@ static int dvb_register(struct cx23885_tsport *port) | |||
152 | &i2c_bus->i2c_adap, DVB_PLL_LG_TDVS_H06XF); | 195 | &i2c_bus->i2c_adap, DVB_PLL_LG_TDVS_H06XF); |
153 | } | 196 | } |
154 | break; | 197 | break; |
198 | case CX23885_BOARD_HAUPPAUGE_HVR1500Q: | ||
199 | i2c_bus = &dev->i2c_bus[1]; | ||
200 | port->dvb.frontend = dvb_attach(s5h1409_attach, | ||
201 | &hauppauge_hvr1500q_config, | ||
202 | &dev->i2c_bus[0].i2c_adap); | ||
203 | if (port->dvb.frontend != NULL) { | ||
204 | dvb_attach(xc5000_attach, port->dvb.frontend, | ||
205 | &i2c_bus->i2c_adap, | ||
206 | &hauppauge_hvr1500q_tunerconfig); | ||
207 | } | ||
208 | break; | ||
155 | default: | 209 | default: |
156 | printk("%s: The frontend of your DVB/ATSC card isn't supported yet\n", | 210 | printk("%s: The frontend of your DVB/ATSC card isn't supported yet\n", |
157 | dev->name); | 211 | dev->name); |
diff --git a/drivers/media/video/cx23885/cx23885-i2c.c b/drivers/media/video/cx23885/cx23885-i2c.c index 20f3fb450f88..b2ffbf04ef2c 100644 --- a/drivers/media/video/cx23885/cx23885-i2c.c +++ b/drivers/media/video/cx23885/cx23885-i2c.c | |||
@@ -332,7 +332,7 @@ static char *i2c_devs[128] = { | |||
332 | [ 0x84 >> 1 ] = "tda8295", | 332 | [ 0x84 >> 1 ] = "tda8295", |
333 | [ 0xa0 >> 1 ] = "eeprom", | 333 | [ 0xa0 >> 1 ] = "eeprom", |
334 | [ 0xc0 >> 1 ] = "tuner/mt2131/tda8275", | 334 | [ 0xc0 >> 1 ] = "tuner/mt2131/tda8275", |
335 | [ 0xc2 >> 1 ] = "tuner/mt2131/tda8275", | 335 | [ 0xc2 >> 1 ] = "tuner/mt2131/tda8275/xc5000", |
336 | }; | 336 | }; |
337 | 337 | ||
338 | static void do_i2c_scan(char *name, struct i2c_client *c) | 338 | 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 205640cc48f7..3f019f3cb292 100644 --- a/drivers/media/video/cx23885/cx23885.h +++ b/drivers/media/video/cx23885/cx23885.h | |||
@@ -53,6 +53,7 @@ | |||
53 | #define CX23885_BOARD_HAUPPAUGE_HVR1800 2 | 53 | #define CX23885_BOARD_HAUPPAUGE_HVR1800 2 |
54 | #define CX23885_BOARD_HAUPPAUGE_HVR1250 3 | 54 | #define CX23885_BOARD_HAUPPAUGE_HVR1250 3 |
55 | #define CX23885_BOARD_DVICO_FUSIONHDTV_5_EXP 4 | 55 | #define CX23885_BOARD_DVICO_FUSIONHDTV_5_EXP 4 |
56 | #define CX23885_BOARD_HAUPPAUGE_HVR1500Q 5 | ||
56 | 57 | ||
57 | enum cx23885_itype { | 58 | enum cx23885_itype { |
58 | CX23885_VMUX_COMPOSITE1 = 1, | 59 | CX23885_VMUX_COMPOSITE1 = 1, |