xref: /openbmc/linux/drivers/media/usb/cx231xx/cx231xx-cards.c (revision 8ef9ea1503d0a129cc6f5cf48fb63633efa5d766)
1 // SPDX-License-Identifier: GPL-2.0-or-later
2 /*
3    cx231xx-cards.c - driver for Conexant Cx23100/101/102
4 				USB video capture devices
5 
6    Copyright (C) 2008 <srinivasa.deevi at conexant dot com>
7 				Based on em28xx driver
8 
9  */
10 
11 #include "cx231xx.h"
12 #include <linux/init.h>
13 #include <linux/module.h>
14 #include <linux/slab.h>
15 #include <linux/delay.h>
16 #include <linux/i2c.h>
17 #include <media/tuner.h>
18 #include <media/tveeprom.h>
19 #include <media/v4l2-common.h>
20 
21 #include <media/drv-intf/cx25840.h>
22 #include <media/dvb-usb-ids.h>
23 #include "xc5000.h"
24 #include "tda18271.h"
25 
26 
27 static int tuner = -1;
28 module_param(tuner, int, 0444);
29 MODULE_PARM_DESC(tuner, "tuner type");
30 
31 static int transfer_mode = 1;
32 module_param(transfer_mode, int, 0444);
33 MODULE_PARM_DESC(transfer_mode, "transfer mode (1-ISO or 0-BULK)");
34 
35 static unsigned int disable_ir;
36 module_param(disable_ir, int, 0444);
37 MODULE_PARM_DESC(disable_ir, "disable infrared remote support");
38 
39 /* Bitmask marking allocated devices from 0 to CX231XX_MAXBOARDS */
40 static unsigned long cx231xx_devused;
41 
42 /*
43  *  Reset sequences for analog/digital modes
44  */
45 
46 static struct cx231xx_reg_seq RDE250_XCV_TUNER[] = {
47 	{0x03, 0x01, 10},
48 	{0x03, 0x00, 30},
49 	{0x03, 0x01, 10},
50 	{-1, -1, -1},
51 };
52 
53 /*
54  *  Board definitions
55  */
56 struct cx231xx_board cx231xx_boards[] = {
57 	[CX231XX_BOARD_UNKNOWN] = {
58 		.name = "Unknown CX231xx video grabber",
59 		.tuner_type = TUNER_ABSENT,
60 		.input = {{
61 				.type = CX231XX_VMUX_TELEVISION,
62 				.vmux = CX231XX_VIN_3_1,
63 				.amux = CX231XX_AMUX_VIDEO,
64 				.gpio = NULL,
65 			}, {
66 				.type = CX231XX_VMUX_COMPOSITE1,
67 				.vmux = CX231XX_VIN_2_1,
68 				.amux = CX231XX_AMUX_LINE_IN,
69 				.gpio = NULL,
70 			}, {
71 				.type = CX231XX_VMUX_SVIDEO,
72 				.vmux = CX231XX_VIN_1_1 |
73 					(CX231XX_VIN_1_2 << 8) |
74 					CX25840_SVIDEO_ON,
75 				.amux = CX231XX_AMUX_LINE_IN,
76 				.gpio = NULL,
77 			}
78 		},
79 	},
80 	[CX231XX_BOARD_CNXT_CARRAERA] = {
81 		.name = "Conexant Hybrid TV - CARRAERA",
82 		.tuner_type = TUNER_XC5000,
83 		.tuner_addr = 0x61,
84 		.tuner_gpio = RDE250_XCV_TUNER,
85 		.tuner_sif_gpio = 0x05,
86 		.tuner_scl_gpio = 0x1a,
87 		.tuner_sda_gpio = 0x1b,
88 		.decoder = CX231XX_AVDECODER,
89 		.output_mode = OUT_MODE_VIP11,
90 		.demod_xfer_mode = 0,
91 		.ctl_pin_status_mask = 0xFFFFFFC4,
92 		.agc_analog_digital_select_gpio = 0x0c,
93 		.gpio_pin_status_mask = 0x4001000,
94 		.tuner_i2c_master = I2C_1_MUX_3,
95 		.demod_i2c_master = I2C_2,
96 		.has_dvb = 1,
97 		.demod_addr = 0x02,
98 		.norm = V4L2_STD_PAL,
99 
100 		.input = {{
101 				.type = CX231XX_VMUX_TELEVISION,
102 				.vmux = CX231XX_VIN_3_1,
103 				.amux = CX231XX_AMUX_VIDEO,
104 				.gpio = NULL,
105 			}, {
106 				.type = CX231XX_VMUX_COMPOSITE1,
107 				.vmux = CX231XX_VIN_2_1,
108 				.amux = CX231XX_AMUX_LINE_IN,
109 				.gpio = NULL,
110 			}, {
111 				.type = CX231XX_VMUX_SVIDEO,
112 				.vmux = CX231XX_VIN_1_1 |
113 					(CX231XX_VIN_1_2 << 8) |
114 					CX25840_SVIDEO_ON,
115 				.amux = CX231XX_AMUX_LINE_IN,
116 				.gpio = NULL,
117 			}
118 		},
119 	},
120 	[CX231XX_BOARD_CNXT_SHELBY] = {
121 		.name = "Conexant Hybrid TV - SHELBY",
122 		.tuner_type = TUNER_XC5000,
123 		.tuner_addr = 0x61,
124 		.tuner_gpio = RDE250_XCV_TUNER,
125 		.tuner_sif_gpio = 0x05,
126 		.tuner_scl_gpio = 0x1a,
127 		.tuner_sda_gpio = 0x1b,
128 		.decoder = CX231XX_AVDECODER,
129 		.output_mode = OUT_MODE_VIP11,
130 		.demod_xfer_mode = 0,
131 		.ctl_pin_status_mask = 0xFFFFFFC4,
132 		.agc_analog_digital_select_gpio = 0x0c,
133 		.gpio_pin_status_mask = 0x4001000,
134 		.tuner_i2c_master = I2C_1_MUX_3,
135 		.demod_i2c_master = I2C_2,
136 		.has_dvb = 1,
137 		.demod_addr = 0x32,
138 		.norm = V4L2_STD_NTSC,
139 
140 		.input = {{
141 				.type = CX231XX_VMUX_TELEVISION,
142 				.vmux = CX231XX_VIN_3_1,
143 				.amux = CX231XX_AMUX_VIDEO,
144 				.gpio = NULL,
145 			}, {
146 				.type = CX231XX_VMUX_COMPOSITE1,
147 				.vmux = CX231XX_VIN_2_1,
148 				.amux = CX231XX_AMUX_LINE_IN,
149 				.gpio = NULL,
150 			}, {
151 				.type = CX231XX_VMUX_SVIDEO,
152 				.vmux = CX231XX_VIN_1_1 |
153 					(CX231XX_VIN_1_2 << 8) |
154 					CX25840_SVIDEO_ON,
155 				.amux = CX231XX_AMUX_LINE_IN,
156 				.gpio = NULL,
157 			}
158 		},
159 	},
160 	[CX231XX_BOARD_CNXT_RDE_253S] = {
161 		.name = "Conexant Hybrid TV - RDE253S",
162 		.tuner_type = TUNER_NXP_TDA18271,
163 		.tuner_addr = 0x60,
164 		.tuner_gpio = RDE250_XCV_TUNER,
165 		.tuner_sif_gpio = 0x05,
166 		.tuner_scl_gpio = 0x1a,
167 		.tuner_sda_gpio = 0x1b,
168 		.decoder = CX231XX_AVDECODER,
169 		.output_mode = OUT_MODE_VIP11,
170 		.demod_xfer_mode = 0,
171 		.ctl_pin_status_mask = 0xFFFFFFC4,
172 		.agc_analog_digital_select_gpio = 0x1c,
173 		.gpio_pin_status_mask = 0x4001000,
174 		.tuner_i2c_master = I2C_1_MUX_3,
175 		.demod_i2c_master = I2C_2,
176 		.has_dvb = 1,
177 		.demod_addr = 0x02,
178 		.norm = V4L2_STD_PAL,
179 
180 		.input = {{
181 				.type = CX231XX_VMUX_TELEVISION,
182 				.vmux = CX231XX_VIN_3_1,
183 				.amux = CX231XX_AMUX_VIDEO,
184 				.gpio = NULL,
185 			}, {
186 				.type = CX231XX_VMUX_COMPOSITE1,
187 				.vmux = CX231XX_VIN_2_1,
188 				.amux = CX231XX_AMUX_LINE_IN,
189 				.gpio = NULL,
190 			}, {
191 				.type = CX231XX_VMUX_SVIDEO,
192 				.vmux = CX231XX_VIN_1_1 |
193 					(CX231XX_VIN_1_2 << 8) |
194 					CX25840_SVIDEO_ON,
195 				.amux = CX231XX_AMUX_LINE_IN,
196 				.gpio = NULL,
197 			}
198 		},
199 	},
200 
201 	[CX231XX_BOARD_CNXT_RDU_253S] = {
202 		.name = "Conexant Hybrid TV - RDU253S",
203 		.tuner_type = TUNER_NXP_TDA18271,
204 		.tuner_addr = 0x60,
205 		.tuner_gpio = RDE250_XCV_TUNER,
206 		.tuner_sif_gpio = 0x05,
207 		.tuner_scl_gpio = 0x1a,
208 		.tuner_sda_gpio = 0x1b,
209 		.decoder = CX231XX_AVDECODER,
210 		.output_mode = OUT_MODE_VIP11,
211 		.demod_xfer_mode = 0,
212 		.ctl_pin_status_mask = 0xFFFFFFC4,
213 		.agc_analog_digital_select_gpio = 0x1c,
214 		.gpio_pin_status_mask = 0x4001000,
215 		.tuner_i2c_master = I2C_1_MUX_3,
216 		.demod_i2c_master = I2C_2,
217 		.has_dvb = 1,
218 		.demod_addr = 0x02,
219 		.norm = V4L2_STD_PAL,
220 
221 		.input = {{
222 				.type = CX231XX_VMUX_TELEVISION,
223 				.vmux = CX231XX_VIN_3_1,
224 				.amux = CX231XX_AMUX_VIDEO,
225 				.gpio = NULL,
226 			}, {
227 				.type = CX231XX_VMUX_COMPOSITE1,
228 				.vmux = CX231XX_VIN_2_1,
229 				.amux = CX231XX_AMUX_LINE_IN,
230 				.gpio = NULL,
231 			}, {
232 				.type = CX231XX_VMUX_SVIDEO,
233 				.vmux = CX231XX_VIN_1_1 |
234 					(CX231XX_VIN_1_2 << 8) |
235 					CX25840_SVIDEO_ON,
236 				.amux = CX231XX_AMUX_LINE_IN,
237 				.gpio = NULL,
238 			}
239 		},
240 	},
241 	[CX231XX_BOARD_CNXT_VIDEO_GRABBER] = {
242 		.name = "Conexant VIDEO GRABBER",
243 		.tuner_type = TUNER_ABSENT,
244 		.decoder = CX231XX_AVDECODER,
245 		.output_mode = OUT_MODE_VIP11,
246 		.ctl_pin_status_mask = 0xFFFFFFC4,
247 		.agc_analog_digital_select_gpio = 0x1c,
248 		.gpio_pin_status_mask = 0x4001000,
249 		.norm = V4L2_STD_PAL,
250 		.no_alt_vanc = 1,
251 		.external_av = 1,
252 		/* Actually, it has a 417, but it isn't working correctly.
253 		 * So set to 0 for now until someone can manage to get this
254 		 * to work reliably. */
255 		.has_417 = 0,
256 
257 		.input = {{
258 				.type = CX231XX_VMUX_COMPOSITE1,
259 				.vmux = CX231XX_VIN_2_1,
260 				.amux = CX231XX_AMUX_LINE_IN,
261 				.gpio = NULL,
262 			}, {
263 				.type = CX231XX_VMUX_SVIDEO,
264 				.vmux = CX231XX_VIN_1_1 |
265 					(CX231XX_VIN_1_2 << 8) |
266 					CX25840_SVIDEO_ON,
267 				.amux = CX231XX_AMUX_LINE_IN,
268 				.gpio = NULL,
269 			}
270 		},
271 	},
272 	[CX231XX_BOARD_CNXT_RDE_250] = {
273 		.name = "Conexant Hybrid TV - rde 250",
274 		.tuner_type = TUNER_XC5000,
275 		.tuner_addr = 0x61,
276 		.tuner_gpio = RDE250_XCV_TUNER,
277 		.tuner_sif_gpio = 0x05,
278 		.tuner_scl_gpio = 0x1a,
279 		.tuner_sda_gpio = 0x1b,
280 		.decoder = CX231XX_AVDECODER,
281 		.output_mode = OUT_MODE_VIP11,
282 		.demod_xfer_mode = 0,
283 		.ctl_pin_status_mask = 0xFFFFFFC4,
284 		.agc_analog_digital_select_gpio = 0x0c,
285 		.gpio_pin_status_mask = 0x4001000,
286 		.tuner_i2c_master = I2C_1_MUX_3,
287 		.demod_i2c_master = I2C_2,
288 		.has_dvb = 1,
289 		.demod_addr = 0x02,
290 		.norm = V4L2_STD_PAL,
291 
292 		.input = {{
293 				.type = CX231XX_VMUX_TELEVISION,
294 				.vmux = CX231XX_VIN_2_1,
295 				.amux = CX231XX_AMUX_VIDEO,
296 				.gpio = NULL,
297 			}
298 		},
299 	},
300 	[CX231XX_BOARD_CNXT_RDU_250] = {
301 		.name = "Conexant Hybrid TV - RDU 250",
302 		.tuner_type = TUNER_XC5000,
303 		.tuner_addr = 0x61,
304 		.tuner_gpio = RDE250_XCV_TUNER,
305 		.tuner_sif_gpio = 0x05,
306 		.tuner_scl_gpio = 0x1a,
307 		.tuner_sda_gpio = 0x1b,
308 		.decoder = CX231XX_AVDECODER,
309 		.output_mode = OUT_MODE_VIP11,
310 		.demod_xfer_mode = 0,
311 		.ctl_pin_status_mask = 0xFFFFFFC4,
312 		.agc_analog_digital_select_gpio = 0x0c,
313 		.gpio_pin_status_mask = 0x4001000,
314 		.tuner_i2c_master = I2C_1_MUX_3,
315 		.demod_i2c_master = I2C_2,
316 		.has_dvb = 1,
317 		.demod_addr = 0x32,
318 		.norm = V4L2_STD_NTSC,
319 
320 		.input = {{
321 				.type = CX231XX_VMUX_TELEVISION,
322 				.vmux = CX231XX_VIN_2_1,
323 				.amux = CX231XX_AMUX_VIDEO,
324 				.gpio = NULL,
325 			}
326 		},
327 	},
328 	[CX231XX_BOARD_HAUPPAUGE_EXETER] = {
329 		.name = "Hauppauge EXETER",
330 		.tuner_type = TUNER_NXP_TDA18271,
331 		.tuner_addr = 0x60,
332 		.tuner_gpio = RDE250_XCV_TUNER,
333 		.tuner_sif_gpio = 0x05,
334 		.tuner_scl_gpio = 0x1a,
335 		.tuner_sda_gpio = 0x1b,
336 		.decoder = CX231XX_AVDECODER,
337 		.output_mode = OUT_MODE_VIP11,
338 		.demod_xfer_mode = 0,
339 		.ctl_pin_status_mask = 0xFFFFFFC4,
340 		.agc_analog_digital_select_gpio = 0x0c,
341 		.gpio_pin_status_mask = 0x4001000,
342 		.tuner_i2c_master = I2C_1_MUX_1,
343 		.demod_i2c_master = I2C_1_MUX_1,
344 		.has_dvb = 1,
345 		.demod_addr = 0x0e,
346 		.norm = V4L2_STD_NTSC,
347 
348 		.input = {{
349 			.type = CX231XX_VMUX_TELEVISION,
350 			.vmux = CX231XX_VIN_3_1,
351 			.amux = CX231XX_AMUX_VIDEO,
352 			.gpio = NULL,
353 		}, {
354 			.type = CX231XX_VMUX_COMPOSITE1,
355 			.vmux = CX231XX_VIN_2_1,
356 			.amux = CX231XX_AMUX_LINE_IN,
357 			.gpio = NULL,
358 		}, {
359 			.type = CX231XX_VMUX_SVIDEO,
360 			.vmux = CX231XX_VIN_1_1 |
361 				(CX231XX_VIN_1_2 << 8) |
362 				CX25840_SVIDEO_ON,
363 			.amux = CX231XX_AMUX_LINE_IN,
364 			.gpio = NULL,
365 		} },
366 	},
367 	[CX231XX_BOARD_HAUPPAUGE_USBLIVE2] = {
368 		.name = "Hauppauge USB Live 2",
369 		.tuner_type = TUNER_ABSENT,
370 		.decoder = CX231XX_AVDECODER,
371 		.output_mode = OUT_MODE_VIP11,
372 		.demod_xfer_mode = 0,
373 		.ctl_pin_status_mask = 0xFFFFFFC4,
374 		.agc_analog_digital_select_gpio = 0x0c,
375 		.gpio_pin_status_mask = 0x4001000,
376 		.norm = V4L2_STD_NTSC,
377 		.no_alt_vanc = 1,
378 		.external_av = 1,
379 		.input = {{
380 			.type = CX231XX_VMUX_COMPOSITE1,
381 			.vmux = CX231XX_VIN_2_1,
382 			.amux = CX231XX_AMUX_LINE_IN,
383 			.gpio = NULL,
384 		}, {
385 			.type = CX231XX_VMUX_SVIDEO,
386 			.vmux = CX231XX_VIN_1_1 |
387 				(CX231XX_VIN_1_2 << 8) |
388 				CX25840_SVIDEO_ON,
389 			.amux = CX231XX_AMUX_LINE_IN,
390 			.gpio = NULL,
391 		} },
392 	},
393 	[CX231XX_BOARD_KWORLD_UB430_USB_HYBRID] = {
394 		.name = "Kworld UB430 USB Hybrid",
395 		.tuner_type = TUNER_NXP_TDA18271,
396 		.tuner_addr = 0x60,
397 		.decoder = CX231XX_AVDECODER,
398 		.output_mode = OUT_MODE_VIP11,
399 		.demod_xfer_mode = 0,
400 		.ctl_pin_status_mask = 0xFFFFFFC4,
401 		.agc_analog_digital_select_gpio = 0x11,	/* According with PV cxPolaris.inf file */
402 		.tuner_sif_gpio = -1,
403 		.tuner_scl_gpio = -1,
404 		.tuner_sda_gpio = -1,
405 		.gpio_pin_status_mask = 0x4001000,
406 		.tuner_i2c_master = I2C_2,
407 		.demod_i2c_master = I2C_1_MUX_3,
408 		.ir_i2c_master = I2C_2,
409 		.has_dvb = 1,
410 		.demod_addr = 0x10,
411 		.norm = V4L2_STD_PAL_M,
412 		.input = {{
413 			.type = CX231XX_VMUX_TELEVISION,
414 			.vmux = CX231XX_VIN_3_1,
415 			.amux = CX231XX_AMUX_VIDEO,
416 			.gpio = NULL,
417 		}, {
418 			.type = CX231XX_VMUX_COMPOSITE1,
419 			.vmux = CX231XX_VIN_2_1,
420 			.amux = CX231XX_AMUX_LINE_IN,
421 			.gpio = NULL,
422 		}, {
423 			.type = CX231XX_VMUX_SVIDEO,
424 			.vmux = CX231XX_VIN_1_1 |
425 				(CX231XX_VIN_1_2 << 8) |
426 				CX25840_SVIDEO_ON,
427 			.amux = CX231XX_AMUX_LINE_IN,
428 			.gpio = NULL,
429 		} },
430 	},
431 	[CX231XX_BOARD_KWORLD_UB445_USB_HYBRID] = {
432 		.name = "Kworld UB445 USB Hybrid",
433 		.tuner_type = TUNER_NXP_TDA18271,
434 		.tuner_addr = 0x60,
435 		.decoder = CX231XX_AVDECODER,
436 		.output_mode = OUT_MODE_VIP11,
437 		.demod_xfer_mode = 0,
438 		.ctl_pin_status_mask = 0xFFFFFFC4,
439 		.agc_analog_digital_select_gpio = 0x11,	/* According with PV cxPolaris.inf file */
440 		.tuner_sif_gpio = -1,
441 		.tuner_scl_gpio = -1,
442 		.tuner_sda_gpio = -1,
443 		.gpio_pin_status_mask = 0x4001000,
444 		.tuner_i2c_master = I2C_2,
445 		.demod_i2c_master = I2C_1_MUX_3,
446 		.ir_i2c_master = I2C_2,
447 		.has_dvb = 1,
448 		.demod_addr = 0x10,
449 		.norm = V4L2_STD_NTSC_M,
450 		.input = {{
451 			.type = CX231XX_VMUX_TELEVISION,
452 			.vmux = CX231XX_VIN_3_1,
453 			.amux = CX231XX_AMUX_VIDEO,
454 			.gpio = NULL,
455 		}, {
456 			.type = CX231XX_VMUX_COMPOSITE1,
457 			.vmux = CX231XX_VIN_2_1,
458 			.amux = CX231XX_AMUX_LINE_IN,
459 			.gpio = NULL,
460 		}, {
461 			.type = CX231XX_VMUX_SVIDEO,
462 			.vmux = CX231XX_VIN_1_1 |
463 				(CX231XX_VIN_1_2 << 8) |
464 				CX25840_SVIDEO_ON,
465 			.amux = CX231XX_AMUX_LINE_IN,
466 			.gpio = NULL,
467 		} },
468 	},
469 	[CX231XX_BOARD_PV_PLAYTV_USB_HYBRID] = {
470 		.name = "Pixelview PlayTV USB Hybrid",
471 		.tuner_type = TUNER_NXP_TDA18271,
472 		.tuner_addr = 0x60,
473 		.decoder = CX231XX_AVDECODER,
474 		.output_mode = OUT_MODE_VIP11,
475 		.demod_xfer_mode = 0,
476 		.ctl_pin_status_mask = 0xFFFFFFC4,
477 		.agc_analog_digital_select_gpio = 0x1c,
478 		.tuner_sif_gpio = -1,
479 		.tuner_scl_gpio = -1,
480 		.tuner_sda_gpio = -1,
481 		.gpio_pin_status_mask = 0x4001000,
482 		.tuner_i2c_master = I2C_2,
483 		.demod_i2c_master = I2C_1_MUX_3,
484 		.ir_i2c_master = I2C_2,
485 		.rc_map_name = RC_MAP_PIXELVIEW_002T,
486 		.has_dvb = 1,
487 		.demod_addr = 0x10,
488 		.norm = V4L2_STD_PAL_M,
489 		.input = {{
490 			.type = CX231XX_VMUX_TELEVISION,
491 			.vmux = CX231XX_VIN_3_1,
492 			.amux = CX231XX_AMUX_VIDEO,
493 			.gpio = NULL,
494 		}, {
495 			.type = CX231XX_VMUX_COMPOSITE1,
496 			.vmux = CX231XX_VIN_2_1,
497 			.amux = CX231XX_AMUX_LINE_IN,
498 			.gpio = NULL,
499 		}, {
500 			.type = CX231XX_VMUX_SVIDEO,
501 			.vmux = CX231XX_VIN_1_1 |
502 				(CX231XX_VIN_1_2 << 8) |
503 				CX25840_SVIDEO_ON,
504 			.amux = CX231XX_AMUX_LINE_IN,
505 			.gpio = NULL,
506 		} },
507 	},
508 	[CX231XX_BOARD_PV_XCAPTURE_USB] = {
509 		.name = "Pixelview Xcapture USB",
510 		.tuner_type = TUNER_ABSENT,
511 		.decoder = CX231XX_AVDECODER,
512 		.output_mode = OUT_MODE_VIP11,
513 		.demod_xfer_mode = 0,
514 		.ctl_pin_status_mask = 0xFFFFFFC4,
515 		.agc_analog_digital_select_gpio = 0x0c,
516 		.gpio_pin_status_mask = 0x4001000,
517 		.norm = V4L2_STD_NTSC,
518 		.no_alt_vanc = 1,
519 		.external_av = 1,
520 
521 		.input = {{
522 				.type = CX231XX_VMUX_COMPOSITE1,
523 				.vmux = CX231XX_VIN_2_1,
524 				.amux = CX231XX_AMUX_LINE_IN,
525 				.gpio = NULL,
526 			}, {
527 				.type = CX231XX_VMUX_SVIDEO,
528 				.vmux = CX231XX_VIN_1_1 |
529 					(CX231XX_VIN_1_2 << 8) |
530 					CX25840_SVIDEO_ON,
531 				.amux = CX231XX_AMUX_LINE_IN,
532 				.gpio = NULL,
533 			}
534 		},
535 	},
536 
537 	[CX231XX_BOARD_ICONBIT_U100] = {
538 		.name = "Iconbit Analog Stick U100 FM",
539 		.tuner_type = TUNER_ABSENT,
540 		.decoder = CX231XX_AVDECODER,
541 		.output_mode = OUT_MODE_VIP11,
542 		.demod_xfer_mode = 0,
543 		.ctl_pin_status_mask = 0xFFFFFFC4,
544 		.agc_analog_digital_select_gpio = 0x1C,
545 		.gpio_pin_status_mask = 0x4001000,
546 
547 		.input = {{
548 			.type = CX231XX_VMUX_COMPOSITE1,
549 			.vmux = CX231XX_VIN_2_1,
550 			.amux = CX231XX_AMUX_LINE_IN,
551 			.gpio = NULL,
552 		}, {
553 			.type = CX231XX_VMUX_SVIDEO,
554 			.vmux = CX231XX_VIN_1_1 |
555 				(CX231XX_VIN_1_2 << 8) |
556 				CX25840_SVIDEO_ON,
557 			.amux = CX231XX_AMUX_LINE_IN,
558 			.gpio = NULL,
559 		} },
560 	},
561 	[CX231XX_BOARD_HAUPPAUGE_USB2_FM_PAL] = {
562 		.name = "Hauppauge WinTV USB2 FM (PAL)",
563 		.tuner_type = TUNER_NXP_TDA18271,
564 		.tuner_addr = 0x60,
565 		.tuner_gpio = RDE250_XCV_TUNER,
566 		.tuner_sif_gpio = 0x05,
567 		.tuner_scl_gpio = 0x1a,
568 		.tuner_sda_gpio = 0x1b,
569 		.decoder = CX231XX_AVDECODER,
570 		.output_mode = OUT_MODE_VIP11,
571 		.ctl_pin_status_mask = 0xFFFFFFC4,
572 		.agc_analog_digital_select_gpio = 0x0c,
573 		.gpio_pin_status_mask = 0x4001000,
574 		.tuner_i2c_master = I2C_1_MUX_3,
575 		.norm = V4L2_STD_PAL,
576 
577 		.input = {{
578 			.type = CX231XX_VMUX_TELEVISION,
579 			.vmux = CX231XX_VIN_3_1,
580 			.amux = CX231XX_AMUX_VIDEO,
581 			.gpio = NULL,
582 		}, {
583 			.type = CX231XX_VMUX_COMPOSITE1,
584 			.vmux = CX231XX_VIN_2_1,
585 			.amux = CX231XX_AMUX_LINE_IN,
586 			.gpio = NULL,
587 		}, {
588 			.type = CX231XX_VMUX_SVIDEO,
589 			.vmux = CX231XX_VIN_1_1 |
590 				(CX231XX_VIN_1_2 << 8) |
591 				CX25840_SVIDEO_ON,
592 			.amux = CX231XX_AMUX_LINE_IN,
593 			.gpio = NULL,
594 		} },
595 	},
596 	[CX231XX_BOARD_HAUPPAUGE_USB2_FM_NTSC] = {
597 		.name = "Hauppauge WinTV USB2 FM (NTSC)",
598 		.tuner_type = TUNER_NXP_TDA18271,
599 		.tuner_addr = 0x60,
600 		.tuner_gpio = RDE250_XCV_TUNER,
601 		.tuner_sif_gpio = 0x05,
602 		.tuner_scl_gpio = 0x1a,
603 		.tuner_sda_gpio = 0x1b,
604 		.decoder = CX231XX_AVDECODER,
605 		.output_mode = OUT_MODE_VIP11,
606 		.ctl_pin_status_mask = 0xFFFFFFC4,
607 		.agc_analog_digital_select_gpio = 0x0c,
608 		.gpio_pin_status_mask = 0x4001000,
609 		.tuner_i2c_master = I2C_1_MUX_3,
610 		.norm = V4L2_STD_NTSC,
611 
612 		.input = {{
613 			.type = CX231XX_VMUX_TELEVISION,
614 			.vmux = CX231XX_VIN_3_1,
615 			.amux = CX231XX_AMUX_VIDEO,
616 			.gpio = NULL,
617 		}, {
618 			.type = CX231XX_VMUX_COMPOSITE1,
619 			.vmux = CX231XX_VIN_2_1,
620 			.amux = CX231XX_AMUX_LINE_IN,
621 			.gpio = NULL,
622 		}, {
623 			.type = CX231XX_VMUX_SVIDEO,
624 			.vmux = CX231XX_VIN_1_1 |
625 				(CX231XX_VIN_1_2 << 8) |
626 				CX25840_SVIDEO_ON,
627 			.amux = CX231XX_AMUX_LINE_IN,
628 			.gpio = NULL,
629 		} },
630 	},
631 	[CX231XX_BOARD_ELGATO_VIDEO_CAPTURE_V2] = {
632 		.name = "Elgato Video Capture V2",
633 		.tuner_type = TUNER_ABSENT,
634 		.decoder = CX231XX_AVDECODER,
635 		.output_mode = OUT_MODE_VIP11,
636 		.demod_xfer_mode = 0,
637 		.ctl_pin_status_mask = 0xFFFFFFC4,
638 		.agc_analog_digital_select_gpio = 0x0c,
639 		.gpio_pin_status_mask = 0x4001000,
640 		.norm = V4L2_STD_NTSC,
641 		.no_alt_vanc = 1,
642 		.external_av = 1,
643 		.input = {{
644 			.type = CX231XX_VMUX_COMPOSITE1,
645 			.vmux = CX231XX_VIN_2_1,
646 			.amux = CX231XX_AMUX_LINE_IN,
647 			.gpio = NULL,
648 		}, {
649 			.type = CX231XX_VMUX_SVIDEO,
650 			.vmux = CX231XX_VIN_1_1 |
651 				(CX231XX_VIN_1_2 << 8) |
652 				CX25840_SVIDEO_ON,
653 			.amux = CX231XX_AMUX_LINE_IN,
654 			.gpio = NULL,
655 		} },
656 	},
657 	[CX231XX_BOARD_OTG102] = {
658 		.name = "Geniatech OTG102",
659 		.tuner_type = TUNER_ABSENT,
660 		.decoder = CX231XX_AVDECODER,
661 		.output_mode = OUT_MODE_VIP11,
662 		.ctl_pin_status_mask = 0xFFFFFFC4,
663 		.agc_analog_digital_select_gpio = 0x0c,
664 			/* According with PV CxPlrCAP.inf file */
665 		.gpio_pin_status_mask = 0x4001000,
666 		.norm = V4L2_STD_NTSC,
667 		.no_alt_vanc = 1,
668 		.external_av = 1,
669 		/*.has_417 = 1, */
670 		/* This board is believed to have a hardware encoding chip
671 		 * supporting mpeg1/2/4, but as the 417 is apparently not
672 		 * working for the reference board it is not here either. */
673 
674 		.input = {{
675 				.type = CX231XX_VMUX_COMPOSITE1,
676 				.vmux = CX231XX_VIN_2_1,
677 				.amux = CX231XX_AMUX_LINE_IN,
678 				.gpio = NULL,
679 			}, {
680 				.type = CX231XX_VMUX_SVIDEO,
681 				.vmux = CX231XX_VIN_1_1 |
682 					(CX231XX_VIN_1_2 << 8) |
683 					CX25840_SVIDEO_ON,
684 				.amux = CX231XX_AMUX_LINE_IN,
685 				.gpio = NULL,
686 			}
687 		},
688 	},
689 	[CX231XX_BOARD_HAUPPAUGE_930C_HD_1113xx] = {
690 		.name = "Hauppauge WinTV 930C-HD (1113xx) / HVR-900H (111xxx) / PCTV QuatroStick 521e",
691 		.tuner_type = TUNER_NXP_TDA18271,
692 		.tuner_addr = 0x60,
693 		.tuner_gpio = RDE250_XCV_TUNER,
694 		.tuner_sif_gpio = 0x05,
695 		.tuner_scl_gpio = 0x1a,
696 		.tuner_sda_gpio = 0x1b,
697 		.decoder = CX231XX_AVDECODER,
698 		.output_mode = OUT_MODE_VIP11,
699 		.demod_xfer_mode = 0,
700 		.ctl_pin_status_mask = 0xFFFFFFC4,
701 		.agc_analog_digital_select_gpio = 0x0c,
702 		.gpio_pin_status_mask = 0x4001000,
703 		.tuner_i2c_master = I2C_1_MUX_3,
704 		.demod_i2c_master = I2C_1_MUX_3,
705 		.has_dvb = 1,
706 		.demod_addr = 0x64, /* 0xc8 >> 1 */
707 		.norm = V4L2_STD_PAL,
708 
709 		.input = {{
710 			.type = CX231XX_VMUX_TELEVISION,
711 			.vmux = CX231XX_VIN_3_1,
712 			.amux = CX231XX_AMUX_VIDEO,
713 			.gpio = NULL,
714 		}, {
715 			.type = CX231XX_VMUX_COMPOSITE1,
716 			.vmux = CX231XX_VIN_2_1,
717 			.amux = CX231XX_AMUX_LINE_IN,
718 			.gpio = NULL,
719 		}, {
720 			.type = CX231XX_VMUX_SVIDEO,
721 			.vmux = CX231XX_VIN_1_1 |
722 				(CX231XX_VIN_1_2 << 8) |
723 				CX25840_SVIDEO_ON,
724 			.amux = CX231XX_AMUX_LINE_IN,
725 			.gpio = NULL,
726 		} },
727 	},
728 	[CX231XX_BOARD_HAUPPAUGE_930C_HD_1114xx] = {
729 		.name = "Hauppauge WinTV 930C-HD (1114xx) / HVR-901H (1114xx) / PCTV QuatroStick 522e",
730 		.tuner_type = TUNER_ABSENT,
731 		.tuner_addr = 0x60,
732 		.tuner_gpio = RDE250_XCV_TUNER,
733 		.tuner_sif_gpio = 0x05,
734 		.tuner_scl_gpio = 0x1a,
735 		.tuner_sda_gpio = 0x1b,
736 		.decoder = CX231XX_AVDECODER,
737 		.output_mode = OUT_MODE_VIP11,
738 		.demod_xfer_mode = 0,
739 		.ctl_pin_status_mask = 0xFFFFFFC4,
740 		.agc_analog_digital_select_gpio = 0x0c,
741 		.gpio_pin_status_mask = 0x4001000,
742 		.tuner_i2c_master = I2C_1_MUX_3,
743 		.demod_i2c_master = I2C_1_MUX_3,
744 		.has_dvb = 1,
745 		.demod_addr = 0x64, /* 0xc8 >> 1 */
746 		.norm = V4L2_STD_PAL,
747 
748 		.input = {{
749 			.type = CX231XX_VMUX_TELEVISION,
750 			.vmux = CX231XX_VIN_3_1,
751 			.amux = CX231XX_AMUX_VIDEO,
752 			.gpio = NULL,
753 		}, {
754 			.type = CX231XX_VMUX_COMPOSITE1,
755 			.vmux = CX231XX_VIN_2_1,
756 			.amux = CX231XX_AMUX_LINE_IN,
757 			.gpio = NULL,
758 		}, {
759 			.type = CX231XX_VMUX_SVIDEO,
760 			.vmux = CX231XX_VIN_1_1 |
761 				(CX231XX_VIN_1_2 << 8) |
762 				CX25840_SVIDEO_ON,
763 			.amux = CX231XX_AMUX_LINE_IN,
764 			.gpio = NULL,
765 		} },
766 	},
767 	[CX231XX_BOARD_HAUPPAUGE_955Q] = {
768 		.name = "Hauppauge WinTV-HVR-955Q (111401)",
769 		.tuner_type = TUNER_ABSENT,
770 		.tuner_addr = 0x60,
771 		.tuner_gpio = RDE250_XCV_TUNER,
772 		.tuner_sif_gpio = 0x05,
773 		.tuner_scl_gpio = 0x1a,
774 		.tuner_sda_gpio = 0x1b,
775 		.decoder = CX231XX_AVDECODER,
776 		.output_mode = OUT_MODE_VIP11,
777 		.demod_xfer_mode = 0,
778 		.ctl_pin_status_mask = 0xFFFFFFC4,
779 		.agc_analog_digital_select_gpio = 0x0c,
780 		.gpio_pin_status_mask = 0x4001000,
781 		.tuner_i2c_master = I2C_1_MUX_3,
782 		.demod_i2c_master = I2C_1_MUX_3,
783 		.has_dvb = 1,
784 		.demod_addr = 0x59, /* 0xb2 >> 1 */
785 		.norm = V4L2_STD_NTSC,
786 
787 		.input = {{
788 			.type = CX231XX_VMUX_TELEVISION,
789 			.vmux = CX231XX_VIN_3_1,
790 			.amux = CX231XX_AMUX_VIDEO,
791 			.gpio = NULL,
792 		}, {
793 			.type = CX231XX_VMUX_COMPOSITE1,
794 			.vmux = CX231XX_VIN_2_1,
795 			.amux = CX231XX_AMUX_LINE_IN,
796 			.gpio = NULL,
797 		}, {
798 			.type = CX231XX_VMUX_SVIDEO,
799 			.vmux = CX231XX_VIN_1_1 |
800 				(CX231XX_VIN_1_2 << 8) |
801 				CX25840_SVIDEO_ON,
802 			.amux = CX231XX_AMUX_LINE_IN,
803 			.gpio = NULL,
804 		} },
805 	},
806 	[CX231XX_BOARD_TERRATEC_GRABBY] = {
807 		.name = "Terratec Grabby",
808 		.tuner_type = TUNER_ABSENT,
809 		.decoder = CX231XX_AVDECODER,
810 		.output_mode = OUT_MODE_VIP11,
811 		.demod_xfer_mode = 0,
812 		.ctl_pin_status_mask = 0xFFFFFFC4,
813 		.agc_analog_digital_select_gpio = 0x0c,
814 		.gpio_pin_status_mask = 0x4001000,
815 		.norm = V4L2_STD_PAL,
816 		.no_alt_vanc = 1,
817 		.external_av = 1,
818 		.input = {{
819 			.type = CX231XX_VMUX_COMPOSITE1,
820 			.vmux = CX231XX_VIN_2_1,
821 			.amux = CX231XX_AMUX_LINE_IN,
822 			.gpio = NULL,
823 		}, {
824 			.type = CX231XX_VMUX_SVIDEO,
825 			.vmux = CX231XX_VIN_1_1 |
826 				(CX231XX_VIN_1_2 << 8) |
827 				CX25840_SVIDEO_ON,
828 			.amux = CX231XX_AMUX_LINE_IN,
829 			.gpio = NULL,
830 		} },
831 	},
832 	[CX231XX_BOARD_EVROMEDIA_FULL_HYBRID_FULLHD] = {
833 		.name = "Evromedia USB Full Hybrid Full HD",
834 		.tuner_type = TUNER_ABSENT,
835 		.demod_addr = 0x64, /* 0xc8 >> 1 */
836 		.demod_i2c_master = I2C_1_MUX_3,
837 		.has_dvb = 1,
838 		.decoder = CX231XX_AVDECODER,
839 		.norm = V4L2_STD_PAL,
840 		.output_mode = OUT_MODE_VIP11,
841 		.tuner_addr = 0x60, /* 0xc0 >> 1 */
842 		.tuner_i2c_master = I2C_2,
843 		.input = {{
844 			.type = CX231XX_VMUX_TELEVISION,
845 			.vmux = 0,
846 			.amux = CX231XX_AMUX_VIDEO,
847 		}, {
848 			.type = CX231XX_VMUX_COMPOSITE1,
849 			.vmux = CX231XX_VIN_2_1,
850 			.amux = CX231XX_AMUX_LINE_IN,
851 		}, {
852 			.type = CX231XX_VMUX_SVIDEO,
853 			.vmux = CX231XX_VIN_1_1 |
854 				(CX231XX_VIN_1_2 << 8) |
855 				CX25840_SVIDEO_ON,
856 			.amux = CX231XX_AMUX_LINE_IN,
857 		} },
858 	},
859 	[CX231XX_BOARD_ASTROMETA_T2HYBRID] = {
860 		.name = "Astrometa T2hybrid",
861 		.tuner_type = TUNER_ABSENT,
862 		.has_dvb = 1,
863 		.decoder = CX231XX_AVDECODER,
864 		.output_mode = OUT_MODE_VIP11,
865 		.agc_analog_digital_select_gpio = 0x01,
866 		.ctl_pin_status_mask = 0xffffffc4,
867 		.demod_addr = 0x18, /* 0x30 >> 1 */
868 		.demod_i2c_master = I2C_1_MUX_1,
869 		.gpio_pin_status_mask = 0xa,
870 		.norm = V4L2_STD_NTSC,
871 		.tuner_addr = 0x3a, /* 0x74 >> 1 */
872 		.tuner_i2c_master = I2C_1_MUX_3,
873 		.tuner_scl_gpio = 0x1a,
874 		.tuner_sda_gpio = 0x1b,
875 		.tuner_sif_gpio = 0x05,
876 		.input = {{
877 				.type = CX231XX_VMUX_TELEVISION,
878 				.vmux = CX231XX_VIN_1_1,
879 				.amux = CX231XX_AMUX_VIDEO,
880 			}, {
881 				.type = CX231XX_VMUX_COMPOSITE1,
882 				.vmux = CX231XX_VIN_2_1,
883 				.amux = CX231XX_AMUX_LINE_IN,
884 			},
885 		},
886 	},
887 	[CX231XX_BOARD_THE_IMAGING_SOURCE_DFG_USB2_PRO] = {
888 		.name = "The Imaging Source DFG/USB2pro",
889 		.tuner_type = TUNER_ABSENT,
890 		.decoder = CX231XX_AVDECODER,
891 		.output_mode = OUT_MODE_VIP11,
892 		.demod_xfer_mode = 0,
893 		.ctl_pin_status_mask = 0xFFFFFFC4,
894 		.agc_analog_digital_select_gpio = 0x0c,
895 		.gpio_pin_status_mask = 0x4001000,
896 		.norm = V4L2_STD_PAL,
897 		.no_alt_vanc = 1,
898 		.external_av = 1,
899 		.input = {{
900 			.type = CX231XX_VMUX_COMPOSITE1,
901 			.vmux = CX231XX_VIN_1_1,
902 			.amux = CX231XX_AMUX_LINE_IN,
903 			.gpio = NULL,
904 		}, {
905 			.type = CX231XX_VMUX_SVIDEO,
906 			.vmux = CX231XX_VIN_2_1 |
907 				(CX231XX_VIN_2_2 << 8) |
908 				CX25840_SVIDEO_ON,
909 			.amux = CX231XX_AMUX_LINE_IN,
910 			.gpio = NULL,
911 		} },
912 	},
913 	[CX231XX_BOARD_HAUPPAUGE_935C] = {
914 		.name = "Hauppauge WinTV-HVR-935C",
915 		.tuner_type = TUNER_ABSENT,
916 		.tuner_addr = 0x60,
917 		.tuner_gpio = RDE250_XCV_TUNER,
918 		.tuner_sif_gpio = 0x05,
919 		.tuner_scl_gpio = 0x1a,
920 		.tuner_sda_gpio = 0x1b,
921 		.decoder = CX231XX_AVDECODER,
922 		.output_mode = OUT_MODE_VIP11,
923 		.demod_xfer_mode = 0,
924 		.ctl_pin_status_mask = 0xFFFFFFC4,
925 		.agc_analog_digital_select_gpio = 0x0c,
926 		.gpio_pin_status_mask = 0x4001000,
927 		.tuner_i2c_master = I2C_1_MUX_3,
928 		.demod_i2c_master = I2C_1_MUX_3,
929 		.has_dvb = 1,
930 		.demod_addr = 0x64, /* 0xc8 >> 1 */
931 		.norm = V4L2_STD_PAL,
932 
933 		.input = {{
934 			.type = CX231XX_VMUX_TELEVISION,
935 			.vmux = CX231XX_VIN_3_1,
936 			.amux = CX231XX_AMUX_VIDEO,
937 			.gpio = NULL,
938 		}, {
939 			.type = CX231XX_VMUX_COMPOSITE1,
940 			.vmux = CX231XX_VIN_2_1,
941 			.amux = CX231XX_AMUX_LINE_IN,
942 			.gpio = NULL,
943 		}, {
944 			.type = CX231XX_VMUX_SVIDEO,
945 			.vmux = CX231XX_VIN_1_1 |
946 				(CX231XX_VIN_1_2 << 8) |
947 				CX25840_SVIDEO_ON,
948 			.amux = CX231XX_AMUX_LINE_IN,
949 			.gpio = NULL,
950 		} },
951 	},
952 	[CX231XX_BOARD_HAUPPAUGE_975] = {
953 		.name = "Hauppauge WinTV-HVR-975",
954 		.tuner_type = TUNER_ABSENT,
955 		.tuner_addr = 0x60,
956 		.tuner_gpio = RDE250_XCV_TUNER,
957 		.tuner_sif_gpio = 0x05,
958 		.tuner_scl_gpio = 0x1a,
959 		.tuner_sda_gpio = 0x1b,
960 		.decoder = CX231XX_AVDECODER,
961 		.output_mode = OUT_MODE_VIP11,
962 		.demod_xfer_mode = 0,
963 		.ctl_pin_status_mask = 0xFFFFFFC4,
964 		.agc_analog_digital_select_gpio = 0x0c,
965 		.gpio_pin_status_mask = 0x4001000,
966 		.tuner_i2c_master = I2C_1_MUX_3,
967 		.demod_i2c_master = I2C_1_MUX_3,
968 		.has_dvb = 1,
969 		.demod_addr = 0x59, /* 0xb2 >> 1 */
970 		.demod_addr2 = 0x64, /* 0xc8 >> 1 */
971 		.norm = V4L2_STD_ALL,
972 
973 		.input = {{
974 			.type = CX231XX_VMUX_TELEVISION,
975 			.vmux = CX231XX_VIN_3_1,
976 			.amux = CX231XX_AMUX_VIDEO,
977 			.gpio = NULL,
978 		}, {
979 			.type = CX231XX_VMUX_COMPOSITE1,
980 			.vmux = CX231XX_VIN_2_1,
981 			.amux = CX231XX_AMUX_LINE_IN,
982 			.gpio = NULL,
983 		}, {
984 			.type = CX231XX_VMUX_SVIDEO,
985 			.vmux = CX231XX_VIN_1_1 |
986 				(CX231XX_VIN_1_2 << 8) |
987 				CX25840_SVIDEO_ON,
988 			.amux = CX231XX_AMUX_LINE_IN,
989 			.gpio = NULL,
990 		} },
991 	},
992 };
993 const unsigned int cx231xx_bcount = ARRAY_SIZE(cx231xx_boards);
994 
995 /* table of devices that work with this driver */
996 struct usb_device_id cx231xx_id_table[] = {
997 	{USB_DEVICE(0x1D19, 0x6108),
998 	.driver_info = CX231XX_BOARD_PV_XCAPTURE_USB},
999 	{USB_DEVICE(0x1D19, 0x6109),
1000 	.driver_info = CX231XX_BOARD_PV_XCAPTURE_USB},
1001 	{USB_DEVICE(0x0572, 0x5A3C),
1002 	 .driver_info = CX231XX_BOARD_UNKNOWN},
1003 	{USB_DEVICE(0x0572, 0x58A2),
1004 	 .driver_info = CX231XX_BOARD_CNXT_CARRAERA},
1005 	{USB_DEVICE(0x0572, 0x58A1),
1006 	 .driver_info = CX231XX_BOARD_CNXT_SHELBY},
1007 	{USB_DEVICE(0x0572, 0x58A4),
1008 	 .driver_info = CX231XX_BOARD_CNXT_RDE_253S},
1009 	{USB_DEVICE(0x0572, 0x58A5),
1010 	 .driver_info = CX231XX_BOARD_CNXT_RDU_253S},
1011 	{USB_DEVICE(0x0572, 0x58A6),
1012 	 .driver_info = CX231XX_BOARD_CNXT_VIDEO_GRABBER},
1013 	{USB_DEVICE(0x0572, 0x589E),
1014 	 .driver_info = CX231XX_BOARD_CNXT_RDE_250},
1015 	{USB_DEVICE(0x0572, 0x58A0),
1016 	 .driver_info = CX231XX_BOARD_CNXT_RDU_250},
1017 	/* AverMedia DVD EZMaker 7 */
1018 	{USB_DEVICE(0x07ca, 0xc039),
1019 	 .driver_info = CX231XX_BOARD_CNXT_VIDEO_GRABBER},
1020 	{USB_DEVICE(0x2040, 0xb110),
1021 	 .driver_info = CX231XX_BOARD_HAUPPAUGE_USB2_FM_PAL},
1022 	{USB_DEVICE(0x2040, 0xb111),
1023 	 .driver_info = CX231XX_BOARD_HAUPPAUGE_USB2_FM_NTSC},
1024 	{USB_DEVICE(0x2040, 0xb120),
1025 	 .driver_info = CX231XX_BOARD_HAUPPAUGE_EXETER},
1026 	{USB_DEVICE(0x2040, 0xb123),
1027 	 .driver_info = CX231XX_BOARD_HAUPPAUGE_955Q},
1028 	{USB_DEVICE(0x2040, 0xb124),
1029 	 .driver_info = CX231XX_BOARD_HAUPPAUGE_955Q},
1030 	{USB_DEVICE(0x2040, 0xb151),
1031 	 .driver_info = CX231XX_BOARD_HAUPPAUGE_935C},
1032 	{USB_DEVICE(0x2040, 0xb150),
1033 	 .driver_info = CX231XX_BOARD_HAUPPAUGE_975},
1034 	{USB_DEVICE(0x2040, 0xb130),
1035 	 .driver_info = CX231XX_BOARD_HAUPPAUGE_930C_HD_1113xx},
1036 	{USB_DEVICE(0x2040, 0xb131),
1037 	 .driver_info = CX231XX_BOARD_HAUPPAUGE_930C_HD_1114xx},
1038 	/* Hauppauge WinTV-HVR-900-H */
1039 	{USB_DEVICE(0x2040, 0xb138),
1040 	 .driver_info = CX231XX_BOARD_HAUPPAUGE_930C_HD_1113xx},
1041 	/* Hauppauge WinTV-HVR-901-H */
1042 	{USB_DEVICE(0x2040, 0xb139),
1043 	 .driver_info = CX231XX_BOARD_HAUPPAUGE_930C_HD_1114xx},
1044 	{USB_DEVICE(0x2040, 0xb140),
1045 	 .driver_info = CX231XX_BOARD_HAUPPAUGE_EXETER},
1046 	{USB_DEVICE(0x2040, 0xc200),
1047 	 .driver_info = CX231XX_BOARD_HAUPPAUGE_USBLIVE2},
1048 	/* PCTV QuatroStick 521e */
1049 	{USB_DEVICE(0x2013, 0x0259),
1050 	 .driver_info = CX231XX_BOARD_HAUPPAUGE_930C_HD_1113xx},
1051 	/* PCTV QuatroStick 522e */
1052 	{USB_DEVICE(0x2013, 0x025e),
1053 	 .driver_info = CX231XX_BOARD_HAUPPAUGE_930C_HD_1114xx},
1054 	{USB_DEVICE_VER(USB_VID_PIXELVIEW, USB_PID_PIXELVIEW_SBTVD, 0x4000, 0x4001),
1055 	 .driver_info = CX231XX_BOARD_PV_PLAYTV_USB_HYBRID},
1056 	{USB_DEVICE(USB_VID_PIXELVIEW, 0x5014),
1057 	 .driver_info = CX231XX_BOARD_PV_XCAPTURE_USB},
1058 	{USB_DEVICE(0x1b80, 0xe424),
1059 	 .driver_info = CX231XX_BOARD_KWORLD_UB430_USB_HYBRID},
1060 	{USB_DEVICE(0x1b80, 0xe421),
1061 	 .driver_info = CX231XX_BOARD_KWORLD_UB445_USB_HYBRID},
1062 	{USB_DEVICE(0x1f4d, 0x0237),
1063 	 .driver_info = CX231XX_BOARD_ICONBIT_U100},
1064 	{USB_DEVICE(0x0fd9, 0x0037),
1065 	 .driver_info = CX231XX_BOARD_ELGATO_VIDEO_CAPTURE_V2},
1066 	{USB_DEVICE(0x1f4d, 0x0102),
1067 	 .driver_info = CX231XX_BOARD_OTG102},
1068 	{USB_DEVICE(USB_VID_TERRATEC, 0x00a6),
1069 	 .driver_info = CX231XX_BOARD_TERRATEC_GRABBY},
1070 	{USB_DEVICE(0x1b80, 0xd3b2),
1071 	.driver_info = CX231XX_BOARD_EVROMEDIA_FULL_HYBRID_FULLHD},
1072 	{USB_DEVICE(0x15f4, 0x0135),
1073 	.driver_info = CX231XX_BOARD_ASTROMETA_T2HYBRID},
1074 	{USB_DEVICE(0x199e, 0x8002),
1075 	 .driver_info = CX231XX_BOARD_THE_IMAGING_SOURCE_DFG_USB2_PRO},
1076 	{},
1077 };
1078 
1079 MODULE_DEVICE_TABLE(usb, cx231xx_id_table);
1080 
1081 /* cx231xx_tuner_callback
1082  * will be used to reset XC5000 tuner using GPIO pin
1083  */
1084 
1085 int cx231xx_tuner_callback(void *ptr, int component, int command, int arg)
1086 {
1087 	int rc = 0;
1088 	struct cx231xx *dev = ptr;
1089 
1090 	if (dev->tuner_type == TUNER_XC5000) {
1091 		if (command == XC5000_TUNER_RESET) {
1092 			dev_dbg(dev->dev,
1093 				"Tuner CB: RESET: cmd %d : tuner type %d\n",
1094 				command, dev->tuner_type);
1095 			cx231xx_set_gpio_value(dev, dev->board.tuner_gpio->bit,
1096 					       1);
1097 			msleep(10);
1098 			cx231xx_set_gpio_value(dev, dev->board.tuner_gpio->bit,
1099 					       0);
1100 			msleep(330);
1101 			cx231xx_set_gpio_value(dev, dev->board.tuner_gpio->bit,
1102 					       1);
1103 			msleep(10);
1104 		}
1105 	} else if (dev->tuner_type == TUNER_NXP_TDA18271) {
1106 		switch (command) {
1107 		case TDA18271_CALLBACK_CMD_AGC_ENABLE:
1108 			if (dev->model == CX231XX_BOARD_PV_PLAYTV_USB_HYBRID)
1109 				rc = cx231xx_set_agc_analog_digital_mux_select(dev, arg);
1110 			break;
1111 		default:
1112 			rc = -EINVAL;
1113 			break;
1114 		}
1115 	}
1116 	return rc;
1117 }
1118 EXPORT_SYMBOL_GPL(cx231xx_tuner_callback);
1119 
1120 static void cx231xx_reset_out(struct cx231xx *dev)
1121 {
1122 	cx231xx_set_gpio_value(dev, CX23417_RESET, 1);
1123 	msleep(200);
1124 	cx231xx_set_gpio_value(dev, CX23417_RESET, 0);
1125 	msleep(200);
1126 	cx231xx_set_gpio_value(dev, CX23417_RESET, 1);
1127 }
1128 
1129 static void cx231xx_enable_OSC(struct cx231xx *dev)
1130 {
1131 	cx231xx_set_gpio_value(dev, CX23417_OSC_EN, 1);
1132 }
1133 
1134 static void cx231xx_sleep_s5h1432(struct cx231xx *dev)
1135 {
1136 	cx231xx_set_gpio_value(dev, SLEEP_S5H1432, 0);
1137 }
1138 
1139 static inline void cx231xx_set_model(struct cx231xx *dev)
1140 {
1141 	dev->board = cx231xx_boards[dev->model];
1142 }
1143 
1144 /* Since cx231xx_pre_card_setup() requires a proper dev->model,
1145  * this won't work for boards with generic PCI IDs
1146  */
1147 void cx231xx_pre_card_setup(struct cx231xx *dev)
1148 {
1149 	dev_info(dev->dev, "Identified as %s (card=%d)\n",
1150 		dev->board.name, dev->model);
1151 
1152 	if (CX231XX_BOARD_ASTROMETA_T2HYBRID == dev->model) {
1153 		/* turn on demodulator chip */
1154 		cx231xx_set_gpio_value(dev, 0x03, 0x01);
1155 	}
1156 
1157 	/* set the direction for GPIO pins */
1158 	if (dev->board.tuner_gpio) {
1159 		cx231xx_set_gpio_direction(dev, dev->board.tuner_gpio->bit, 1);
1160 		cx231xx_set_gpio_value(dev, dev->board.tuner_gpio->bit, 1);
1161 	}
1162 	if (dev->board.tuner_sif_gpio >= 0)
1163 		cx231xx_set_gpio_direction(dev, dev->board.tuner_sif_gpio, 1);
1164 
1165 	/* request some modules if any required */
1166 
1167 	/* set the mode to Analog mode initially */
1168 	cx231xx_set_mode(dev, CX231XX_ANALOG_MODE);
1169 
1170 	/* Unlock device */
1171 	/* cx231xx_set_mode(dev, CX231XX_SUSPEND); */
1172 
1173 }
1174 
1175 static void cx231xx_config_tuner(struct cx231xx *dev)
1176 {
1177 	struct tuner_setup tun_setup;
1178 	struct v4l2_frequency f;
1179 
1180 	if (dev->tuner_type == TUNER_ABSENT)
1181 		return;
1182 
1183 	tun_setup.mode_mask = T_ANALOG_TV | T_RADIO;
1184 	tun_setup.type = dev->tuner_type;
1185 	tun_setup.addr = dev->tuner_addr;
1186 	tun_setup.tuner_callback = cx231xx_tuner_callback;
1187 
1188 	tuner_call(dev, tuner, s_type_addr, &tun_setup);
1189 
1190 #if 0
1191 	if (tun_setup.type == TUNER_XC5000) {
1192 		static struct xc2028_ctrl ctrl = {
1193 			.fname = XC5000_DEFAULT_FIRMWARE,
1194 			.max_len = 64,
1195 			.demod = 0;
1196 		};
1197 		struct v4l2_priv_tun_config cfg = {
1198 			.tuner = dev->tuner_type,
1199 			.priv = &ctrl,
1200 		};
1201 		tuner_call(dev, tuner, s_config, &cfg);
1202 	}
1203 #endif
1204 	/* configure tuner */
1205 	f.tuner = 0;
1206 	f.type = V4L2_TUNER_ANALOG_TV;
1207 	f.frequency = 9076;	/* just a magic number */
1208 	dev->ctl_freq = f.frequency;
1209 	call_all(dev, tuner, s_frequency, &f);
1210 
1211 }
1212 
1213 static int read_eeprom(struct cx231xx *dev, struct i2c_client *client,
1214 		       u8 *eedata, int len)
1215 {
1216 	int ret;
1217 	u8 start_offset = 0;
1218 	int len_todo = len;
1219 	u8 *eedata_cur = eedata;
1220 	int i;
1221 	struct i2c_msg msg_write = { .addr = client->addr, .flags = 0,
1222 		.buf = &start_offset, .len = 1 };
1223 	struct i2c_msg msg_read = { .addr = client->addr, .flags = I2C_M_RD };
1224 
1225 	/* start reading at offset 0 */
1226 	ret = i2c_transfer(client->adapter, &msg_write, 1);
1227 	if (ret < 0) {
1228 		dev_err(dev->dev, "Can't read eeprom\n");
1229 		return ret;
1230 	}
1231 
1232 	while (len_todo > 0) {
1233 		msg_read.len = (len_todo > 64) ? 64 : len_todo;
1234 		msg_read.buf = eedata_cur;
1235 
1236 		ret = i2c_transfer(client->adapter, &msg_read, 1);
1237 		if (ret < 0) {
1238 			dev_err(dev->dev, "Can't read eeprom\n");
1239 			return ret;
1240 		}
1241 		eedata_cur += msg_read.len;
1242 		len_todo -= msg_read.len;
1243 	}
1244 
1245 	for (i = 0; i + 15 < len; i += 16)
1246 		dev_dbg(dev->dev, "i2c eeprom %02x: %*ph\n",
1247 			i, 16, &eedata[i]);
1248 
1249 	return 0;
1250 }
1251 
1252 void cx231xx_card_setup(struct cx231xx *dev)
1253 {
1254 
1255 	cx231xx_set_model(dev);
1256 
1257 	dev->tuner_type = cx231xx_boards[dev->model].tuner_type;
1258 	if (cx231xx_boards[dev->model].tuner_addr)
1259 		dev->tuner_addr = cx231xx_boards[dev->model].tuner_addr;
1260 
1261 	/* request some modules */
1262 	if (dev->board.decoder == CX231XX_AVDECODER) {
1263 		dev->sd_cx25840 = v4l2_i2c_new_subdev(&dev->v4l2_dev,
1264 					cx231xx_get_i2c_adap(dev, I2C_0),
1265 					"cx25840", 0x88 >> 1, NULL);
1266 		if (dev->sd_cx25840 == NULL)
1267 			dev_err(dev->dev,
1268 				"cx25840 subdev registration failure\n");
1269 		cx25840_call(dev, core, load_fw);
1270 
1271 	}
1272 
1273 	/* Initialize the tuner */
1274 	if (dev->board.tuner_type != TUNER_ABSENT) {
1275 		struct i2c_adapter *tuner_i2c = cx231xx_get_i2c_adap(dev,
1276 						dev->board.tuner_i2c_master);
1277 		dev->sd_tuner = v4l2_i2c_new_subdev(&dev->v4l2_dev,
1278 						    tuner_i2c,
1279 						    "tuner",
1280 						    dev->tuner_addr, NULL);
1281 		if (dev->sd_tuner == NULL)
1282 			dev_err(dev->dev,
1283 				"tuner subdev registration failure\n");
1284 		else
1285 			cx231xx_config_tuner(dev);
1286 	}
1287 
1288 	switch (dev->model) {
1289 	case CX231XX_BOARD_HAUPPAUGE_930C_HD_1113xx:
1290 	case CX231XX_BOARD_HAUPPAUGE_930C_HD_1114xx:
1291 	case CX231XX_BOARD_HAUPPAUGE_955Q:
1292 	case CX231XX_BOARD_HAUPPAUGE_935C:
1293 	case CX231XX_BOARD_HAUPPAUGE_975:
1294 		{
1295 			struct eeprom {
1296 				struct tveeprom tvee;
1297 				u8 eeprom[256];
1298 				struct i2c_client client;
1299 			};
1300 			struct eeprom *e = kzalloc(sizeof(*e), GFP_KERNEL);
1301 
1302 			if (e == NULL) {
1303 				dev_err(dev->dev,
1304 					"failed to allocate memory to read eeprom\n");
1305 				break;
1306 			}
1307 			e->client.adapter = cx231xx_get_i2c_adap(dev, I2C_1_MUX_1);
1308 			e->client.addr = 0xa0 >> 1;
1309 
1310 			read_eeprom(dev, &e->client, e->eeprom, sizeof(e->eeprom));
1311 			tveeprom_hauppauge_analog(&e->tvee, e->eeprom + 0xc0);
1312 			kfree(e);
1313 			break;
1314 		}
1315 	}
1316 
1317 }
1318 
1319 /*
1320  * cx231xx_config()
1321  * inits registers with sane defaults
1322  */
1323 int cx231xx_config(struct cx231xx *dev)
1324 {
1325 	/* TBD need to add cx231xx specific code */
1326 
1327 	return 0;
1328 }
1329 
1330 /*
1331  * cx231xx_config_i2c()
1332  * configure i2c attached devices
1333  */
1334 void cx231xx_config_i2c(struct cx231xx *dev)
1335 {
1336 	/* u32 input = INPUT(dev->video_input)->vmux; */
1337 
1338 	call_all(dev, video, s_stream, 1);
1339 }
1340 
1341 static void cx231xx_unregister_media_device(struct cx231xx *dev)
1342 {
1343 #ifdef CONFIG_MEDIA_CONTROLLER
1344 	if (dev->media_dev) {
1345 		media_device_unregister(dev->media_dev);
1346 		media_device_cleanup(dev->media_dev);
1347 		kfree(dev->media_dev);
1348 		dev->media_dev = NULL;
1349 	}
1350 #endif
1351 }
1352 
1353 /*
1354  * cx231xx_realease_resources()
1355  * unregisters the v4l2,i2c and usb devices
1356  * called when the device gets disconnected or at module unload
1357 */
1358 void cx231xx_release_resources(struct cx231xx *dev)
1359 {
1360 	cx231xx_ir_exit(dev);
1361 
1362 	cx231xx_release_analog_resources(dev);
1363 
1364 	cx231xx_remove_from_devlist(dev);
1365 
1366 	/* Release I2C buses */
1367 	cx231xx_dev_uninit(dev);
1368 
1369 	/* delete v4l2 device */
1370 	v4l2_device_unregister(&dev->v4l2_dev);
1371 
1372 	cx231xx_unregister_media_device(dev);
1373 
1374 	usb_put_dev(dev->udev);
1375 
1376 	/* Mark device as unused */
1377 	clear_bit(dev->devno, &cx231xx_devused);
1378 }
1379 
1380 static int cx231xx_media_device_init(struct cx231xx *dev,
1381 				      struct usb_device *udev)
1382 {
1383 #ifdef CONFIG_MEDIA_CONTROLLER
1384 	struct media_device *mdev;
1385 
1386 	mdev = kzalloc(sizeof(*mdev), GFP_KERNEL);
1387 	if (!mdev)
1388 		return -ENOMEM;
1389 
1390 	media_device_usb_init(mdev, udev, dev->board.name);
1391 
1392 	dev->media_dev = mdev;
1393 #endif
1394 	return 0;
1395 }
1396 
1397 /*
1398  * cx231xx_init_dev()
1399  * allocates and inits the device structs, registers i2c bus and v4l device
1400  */
1401 static int cx231xx_init_dev(struct cx231xx *dev, struct usb_device *udev,
1402 			    int minor)
1403 {
1404 	int retval = -ENOMEM;
1405 	unsigned int maxh, maxw;
1406 
1407 	dev->udev = udev;
1408 	mutex_init(&dev->lock);
1409 	mutex_init(&dev->ctrl_urb_lock);
1410 	mutex_init(&dev->gpio_i2c_lock);
1411 	mutex_init(&dev->i2c_lock);
1412 
1413 	spin_lock_init(&dev->video_mode.slock);
1414 	spin_lock_init(&dev->vbi_mode.slock);
1415 	spin_lock_init(&dev->sliced_cc_mode.slock);
1416 
1417 	init_waitqueue_head(&dev->open);
1418 	init_waitqueue_head(&dev->wait_frame);
1419 	init_waitqueue_head(&dev->wait_stream);
1420 
1421 	dev->cx231xx_read_ctrl_reg = cx231xx_read_ctrl_reg;
1422 	dev->cx231xx_write_ctrl_reg = cx231xx_write_ctrl_reg;
1423 	dev->cx231xx_send_usb_command = cx231xx_send_usb_command;
1424 	dev->cx231xx_gpio_i2c_read = cx231xx_gpio_i2c_read;
1425 	dev->cx231xx_gpio_i2c_write = cx231xx_gpio_i2c_write;
1426 
1427 	/* Query cx231xx to find what pcb config it is related to */
1428 	retval = initialize_cx231xx(dev);
1429 	if (retval < 0) {
1430 		dev_err(dev->dev, "Failed to read PCB config\n");
1431 		return retval;
1432 	}
1433 
1434 	/*To workaround error number=-71 on EP0 for VideoGrabber,
1435 		 need set alt here.*/
1436 	if (dev->model == CX231XX_BOARD_CNXT_VIDEO_GRABBER ||
1437 	    dev->model == CX231XX_BOARD_HAUPPAUGE_USBLIVE2) {
1438 		cx231xx_set_alt_setting(dev, INDEX_VIDEO, 3);
1439 		cx231xx_set_alt_setting(dev, INDEX_VANC, 1);
1440 	}
1441 	/* Cx231xx pre card setup */
1442 	cx231xx_pre_card_setup(dev);
1443 
1444 	retval = cx231xx_config(dev);
1445 	if (retval) {
1446 		dev_err(dev->dev, "error configuring device\n");
1447 		return -ENOMEM;
1448 	}
1449 
1450 	/* set default norm */
1451 	dev->norm = dev->board.norm;
1452 
1453 	/* register i2c bus */
1454 	retval = cx231xx_dev_init(dev);
1455 	if (retval) {
1456 		dev_err(dev->dev,
1457 			"%s: cx231xx_i2c_register - errCode [%d]!\n",
1458 			__func__, retval);
1459 		goto err_dev_init;
1460 	}
1461 
1462 	/* Do board specific init */
1463 	cx231xx_card_setup(dev);
1464 
1465 	/* configure the device */
1466 	cx231xx_config_i2c(dev);
1467 
1468 	maxw = norm_maxw(dev);
1469 	maxh = norm_maxh(dev);
1470 
1471 	/* set default image size */
1472 	dev->width = maxw;
1473 	dev->height = maxh;
1474 	dev->interlaced = 0;
1475 	dev->video_input = 0;
1476 
1477 	retval = cx231xx_config(dev);
1478 	if (retval) {
1479 		dev_err(dev->dev, "%s: cx231xx_config - errCode [%d]!\n",
1480 			__func__, retval);
1481 		goto err_dev_init;
1482 	}
1483 
1484 	/* init video dma queue */
1485 	INIT_LIST_HEAD(&dev->video_mode.vidq.active);
1486 
1487 	/* init vbi dma queue */
1488 	INIT_LIST_HEAD(&dev->vbi_mode.vidq.active);
1489 
1490 	/* Reset other chips required if they are tied up with GPIO pins */
1491 	cx231xx_add_into_devlist(dev);
1492 
1493 	if (dev->board.has_417) {
1494 		dev_info(dev->dev, "attach 417 %d\n", dev->model);
1495 		if (cx231xx_417_register(dev) < 0) {
1496 			dev_err(dev->dev,
1497 				"%s() Failed to register 417 on VID_B\n",
1498 				__func__);
1499 		}
1500 	}
1501 
1502 	retval = cx231xx_register_analog_devices(dev);
1503 	if (retval)
1504 		goto err_analog;
1505 
1506 	cx231xx_ir_init(dev);
1507 
1508 	cx231xx_init_extension(dev);
1509 
1510 	return 0;
1511 err_analog:
1512 	cx231xx_unregister_media_device(dev);
1513 	cx231xx_release_analog_resources(dev);
1514 	cx231xx_remove_from_devlist(dev);
1515 err_dev_init:
1516 	cx231xx_dev_uninit(dev);
1517 	return retval;
1518 }
1519 
1520 #if defined(CONFIG_MODULES) && defined(MODULE)
1521 static void request_module_async(struct work_struct *work)
1522 {
1523 	struct cx231xx *dev = container_of(work,
1524 					   struct cx231xx, request_module_wk);
1525 
1526 	if (dev->has_alsa_audio)
1527 		request_module("cx231xx-alsa");
1528 
1529 	if (dev->board.has_dvb)
1530 		request_module("cx231xx-dvb");
1531 
1532 }
1533 
1534 static void request_modules(struct cx231xx *dev)
1535 {
1536 	INIT_WORK(&dev->request_module_wk, request_module_async);
1537 	schedule_work(&dev->request_module_wk);
1538 }
1539 
1540 static void flush_request_modules(struct cx231xx *dev)
1541 {
1542 	flush_work(&dev->request_module_wk);
1543 }
1544 #else
1545 #define request_modules(dev)
1546 #define flush_request_modules(dev)
1547 #endif /* CONFIG_MODULES */
1548 
1549 static int cx231xx_init_v4l2(struct cx231xx *dev,
1550 			     struct usb_device *udev,
1551 			     struct usb_interface *interface,
1552 			     int isoc_pipe)
1553 {
1554 	struct usb_interface *uif;
1555 	int i, idx;
1556 
1557 	/* Video Init */
1558 
1559 	/* compute alternate max packet sizes for video */
1560 	idx = dev->current_pcb_config.hs_config_info[0].interface_info.video_index + 1;
1561 	if (idx >= dev->max_iad_interface_count) {
1562 		dev_err(dev->dev,
1563 			"Video PCB interface #%d doesn't exist\n", idx);
1564 		return -ENODEV;
1565 	}
1566 
1567 	uif = udev->actconfig->interface[idx];
1568 
1569 	if (uif->altsetting[0].desc.bNumEndpoints < isoc_pipe + 1)
1570 		return -ENODEV;
1571 
1572 	dev->video_mode.end_point_addr = uif->altsetting[0].endpoint[isoc_pipe].desc.bEndpointAddress;
1573 	dev->video_mode.num_alt = uif->num_altsetting;
1574 
1575 	dev_info(dev->dev,
1576 		 "video EndPoint Addr 0x%x, Alternate settings: %i\n",
1577 		 dev->video_mode.end_point_addr,
1578 		 dev->video_mode.num_alt);
1579 
1580 	dev->video_mode.alt_max_pkt_size = devm_kmalloc_array(&udev->dev, 32, dev->video_mode.num_alt, GFP_KERNEL);
1581 	if (dev->video_mode.alt_max_pkt_size == NULL)
1582 		return -ENOMEM;
1583 
1584 	for (i = 0; i < dev->video_mode.num_alt; i++) {
1585 		u16 tmp;
1586 
1587 		if (uif->altsetting[i].desc.bNumEndpoints < isoc_pipe + 1)
1588 			return -ENODEV;
1589 
1590 		tmp = le16_to_cpu(uif->altsetting[i].endpoint[isoc_pipe].desc.wMaxPacketSize);
1591 		dev->video_mode.alt_max_pkt_size[i] = (tmp & 0x07ff) * (((tmp & 0x1800) >> 11) + 1);
1592 		dev_dbg(dev->dev,
1593 			"Alternate setting %i, max size= %i\n", i,
1594 			dev->video_mode.alt_max_pkt_size[i]);
1595 	}
1596 
1597 	/* VBI Init */
1598 
1599 	idx = dev->current_pcb_config.hs_config_info[0].interface_info.vanc_index + 1;
1600 	if (idx >= dev->max_iad_interface_count) {
1601 		dev_err(dev->dev,
1602 			"VBI PCB interface #%d doesn't exist\n", idx);
1603 		return -ENODEV;
1604 	}
1605 	uif = udev->actconfig->interface[idx];
1606 
1607 	if (uif->altsetting[0].desc.bNumEndpoints < isoc_pipe + 1)
1608 		return -ENODEV;
1609 
1610 	dev->vbi_mode.end_point_addr =
1611 	    uif->altsetting[0].endpoint[isoc_pipe].desc.
1612 			bEndpointAddress;
1613 
1614 	dev->vbi_mode.num_alt = uif->num_altsetting;
1615 	dev_info(dev->dev,
1616 		 "VBI EndPoint Addr 0x%x, Alternate settings: %i\n",
1617 		 dev->vbi_mode.end_point_addr,
1618 		 dev->vbi_mode.num_alt);
1619 
1620 	/* compute alternate max packet sizes for vbi */
1621 	dev->vbi_mode.alt_max_pkt_size = devm_kmalloc_array(&udev->dev, 32, dev->vbi_mode.num_alt, GFP_KERNEL);
1622 	if (dev->vbi_mode.alt_max_pkt_size == NULL)
1623 		return -ENOMEM;
1624 
1625 	for (i = 0; i < dev->vbi_mode.num_alt; i++) {
1626 		u16 tmp;
1627 
1628 		if (uif->altsetting[i].desc.bNumEndpoints < isoc_pipe + 1)
1629 			return -ENODEV;
1630 
1631 		tmp = le16_to_cpu(uif->altsetting[i].endpoint[isoc_pipe].
1632 				desc.wMaxPacketSize);
1633 		dev->vbi_mode.alt_max_pkt_size[i] =
1634 		    (tmp & 0x07ff) * (((tmp & 0x1800) >> 11) + 1);
1635 		dev_dbg(dev->dev,
1636 			"Alternate setting %i, max size= %i\n", i,
1637 			dev->vbi_mode.alt_max_pkt_size[i]);
1638 	}
1639 
1640 	/* Sliced CC VBI init */
1641 
1642 	/* compute alternate max packet sizes for sliced CC */
1643 	idx = dev->current_pcb_config.hs_config_info[0].interface_info.hanc_index + 1;
1644 	if (idx >= dev->max_iad_interface_count) {
1645 		dev_err(dev->dev,
1646 			"Sliced CC PCB interface #%d doesn't exist\n", idx);
1647 		return -ENODEV;
1648 	}
1649 	uif = udev->actconfig->interface[idx];
1650 
1651 	if (uif->altsetting[0].desc.bNumEndpoints < isoc_pipe + 1)
1652 		return -ENODEV;
1653 
1654 	dev->sliced_cc_mode.end_point_addr =
1655 	    uif->altsetting[0].endpoint[isoc_pipe].desc.
1656 			bEndpointAddress;
1657 
1658 	dev->sliced_cc_mode.num_alt = uif->num_altsetting;
1659 	dev_info(dev->dev,
1660 		 "sliced CC EndPoint Addr 0x%x, Alternate settings: %i\n",
1661 		 dev->sliced_cc_mode.end_point_addr,
1662 		 dev->sliced_cc_mode.num_alt);
1663 	dev->sliced_cc_mode.alt_max_pkt_size = devm_kmalloc_array(&udev->dev, 32, dev->sliced_cc_mode.num_alt, GFP_KERNEL);
1664 	if (dev->sliced_cc_mode.alt_max_pkt_size == NULL)
1665 		return -ENOMEM;
1666 
1667 	for (i = 0; i < dev->sliced_cc_mode.num_alt; i++) {
1668 		u16 tmp;
1669 
1670 		if (uif->altsetting[i].desc.bNumEndpoints < isoc_pipe + 1)
1671 			return -ENODEV;
1672 
1673 		tmp = le16_to_cpu(uif->altsetting[i].endpoint[isoc_pipe].
1674 				desc.wMaxPacketSize);
1675 		dev->sliced_cc_mode.alt_max_pkt_size[i] =
1676 		    (tmp & 0x07ff) * (((tmp & 0x1800) >> 11) + 1);
1677 		dev_dbg(dev->dev,
1678 			"Alternate setting %i, max size= %i\n", i,
1679 			dev->sliced_cc_mode.alt_max_pkt_size[i]);
1680 	}
1681 
1682 	return 0;
1683 }
1684 
1685 /*
1686  * cx231xx_usb_probe()
1687  * checks for supported devices
1688  */
1689 static int cx231xx_usb_probe(struct usb_interface *interface,
1690 			     const struct usb_device_id *id)
1691 {
1692 	struct usb_device *udev;
1693 	struct device *d = &interface->dev;
1694 	struct usb_interface *uif;
1695 	struct cx231xx *dev = NULL;
1696 	int retval = -ENODEV;
1697 	int nr = 0, ifnum;
1698 	int i, isoc_pipe = 0;
1699 	char *speed;
1700 	u8 idx;
1701 	struct usb_interface_assoc_descriptor *assoc_desc;
1702 
1703 	ifnum = interface->altsetting[0].desc.bInterfaceNumber;
1704 
1705 	/*
1706 	 * Interface number 0 - IR interface (handled by mceusb driver)
1707 	 * Interface number 1 - AV interface (handled by this driver)
1708 	 */
1709 	if (ifnum != 1)
1710 		return -ENODEV;
1711 
1712 	/* Check to see next free device and mark as used */
1713 	do {
1714 		nr = find_first_zero_bit(&cx231xx_devused, CX231XX_MAXBOARDS);
1715 		if (nr >= CX231XX_MAXBOARDS) {
1716 			/* No free device slots */
1717 			dev_err(d,
1718 				"Supports only %i devices.\n",
1719 				CX231XX_MAXBOARDS);
1720 			return -ENOMEM;
1721 		}
1722 	} while (test_and_set_bit(nr, &cx231xx_devused));
1723 
1724 	udev = usb_get_dev(interface_to_usbdev(interface));
1725 
1726 	/* allocate memory for our device state and initialize it */
1727 	dev = devm_kzalloc(&udev->dev, sizeof(*dev), GFP_KERNEL);
1728 	if (dev == NULL) {
1729 		retval = -ENOMEM;
1730 		goto err_if;
1731 	}
1732 
1733 	snprintf(dev->name, 29, "cx231xx #%d", nr);
1734 	dev->devno = nr;
1735 	dev->model = id->driver_info;
1736 	dev->video_mode.alt = -1;
1737 	dev->dev = d;
1738 
1739 	cx231xx_set_model(dev);
1740 
1741 	dev->interface_count++;
1742 	/* reset gpio dir and value */
1743 	dev->gpio_dir = 0;
1744 	dev->gpio_val = 0;
1745 	dev->xc_fw_load_done = 0;
1746 	dev->has_alsa_audio = 1;
1747 	dev->power_mode = -1;
1748 	atomic_set(&dev->devlist_count, 0);
1749 
1750 	/* 0 - vbi ; 1 -sliced cc mode */
1751 	dev->vbi_or_sliced_cc_mode = 0;
1752 
1753 	/* get maximum no.of IAD interfaces */
1754 	dev->max_iad_interface_count = udev->config->desc.bNumInterfaces;
1755 
1756 	/* init CIR module TBD */
1757 
1758 	/*mode_tv: digital=1 or analog=0*/
1759 	dev->mode_tv = 0;
1760 
1761 	dev->USE_ISO = transfer_mode;
1762 
1763 	switch (udev->speed) {
1764 	case USB_SPEED_LOW:
1765 		speed = "1.5";
1766 		break;
1767 	case USB_SPEED_UNKNOWN:
1768 	case USB_SPEED_FULL:
1769 		speed = "12";
1770 		break;
1771 	case USB_SPEED_HIGH:
1772 		speed = "480";
1773 		break;
1774 	default:
1775 		speed = "unknown";
1776 	}
1777 
1778 	dev_info(d,
1779 		 "New device %s %s @ %s Mbps (%04x:%04x) with %d interfaces\n",
1780 		 udev->manufacturer ? udev->manufacturer : "",
1781 		 udev->product ? udev->product : "",
1782 		 speed,
1783 		 le16_to_cpu(udev->descriptor.idVendor),
1784 		 le16_to_cpu(udev->descriptor.idProduct),
1785 		 dev->max_iad_interface_count);
1786 
1787 	/* increment interface count */
1788 	dev->interface_count++;
1789 
1790 	/* get device number */
1791 	nr = dev->devno;
1792 
1793 	assoc_desc = udev->actconfig->intf_assoc[0];
1794 	if (!assoc_desc || assoc_desc->bFirstInterface != ifnum) {
1795 		dev_err(d, "Not found matching IAD interface\n");
1796 		retval = -ENODEV;
1797 		goto err_if;
1798 	}
1799 
1800 	dev_dbg(d, "registering interface %d\n", ifnum);
1801 
1802 	/* save our data pointer in this interface device */
1803 	usb_set_intfdata(interface, dev);
1804 
1805 	/* Initialize the media controller */
1806 	retval = cx231xx_media_device_init(dev, udev);
1807 	if (retval) {
1808 		dev_err(d, "cx231xx_media_device_init failed\n");
1809 		goto err_media_init;
1810 	}
1811 
1812 	/* Create v4l2 device */
1813 #ifdef CONFIG_MEDIA_CONTROLLER
1814 	dev->v4l2_dev.mdev = dev->media_dev;
1815 #endif
1816 	retval = v4l2_device_register(&interface->dev, &dev->v4l2_dev);
1817 	if (retval) {
1818 		dev_err(d, "v4l2_device_register failed\n");
1819 		goto err_v4l2;
1820 	}
1821 
1822 	/* allocate device struct */
1823 	retval = cx231xx_init_dev(dev, udev, nr);
1824 	if (retval)
1825 		goto err_init;
1826 
1827 	retval = cx231xx_init_v4l2(dev, udev, interface, isoc_pipe);
1828 	if (retval)
1829 		goto err_init;
1830 
1831 	if (dev->current_pcb_config.ts1_source != 0xff) {
1832 		/* compute alternate max packet sizes for TS1 */
1833 		idx = dev->current_pcb_config.hs_config_info[0].interface_info.ts1_index + 1;
1834 		if (idx >= dev->max_iad_interface_count) {
1835 			dev_err(d, "TS1 PCB interface #%d doesn't exist\n",
1836 				idx);
1837 			retval = -ENODEV;
1838 			goto err_video_alt;
1839 		}
1840 		uif = udev->actconfig->interface[idx];
1841 
1842 		if (uif->altsetting[0].desc.bNumEndpoints < isoc_pipe + 1) {
1843 			retval = -ENODEV;
1844 			goto err_video_alt;
1845 		}
1846 
1847 		dev->ts1_mode.end_point_addr =
1848 		    uif->altsetting[0].endpoint[isoc_pipe].
1849 				desc.bEndpointAddress;
1850 
1851 		dev->ts1_mode.num_alt = uif->num_altsetting;
1852 		dev_info(d,
1853 			 "TS EndPoint Addr 0x%x, Alternate settings: %i\n",
1854 			 dev->ts1_mode.end_point_addr,
1855 			 dev->ts1_mode.num_alt);
1856 
1857 		dev->ts1_mode.alt_max_pkt_size = devm_kmalloc_array(&udev->dev, 32, dev->ts1_mode.num_alt, GFP_KERNEL);
1858 		if (dev->ts1_mode.alt_max_pkt_size == NULL) {
1859 			retval = -ENOMEM;
1860 			goto err_video_alt;
1861 		}
1862 
1863 		for (i = 0; i < dev->ts1_mode.num_alt; i++) {
1864 			u16 tmp;
1865 
1866 			if (uif->altsetting[i].desc.bNumEndpoints < isoc_pipe + 1) {
1867 				retval = -ENODEV;
1868 				goto err_video_alt;
1869 			}
1870 
1871 			tmp = le16_to_cpu(uif->altsetting[i].
1872 						endpoint[isoc_pipe].desc.
1873 						wMaxPacketSize);
1874 			dev->ts1_mode.alt_max_pkt_size[i] =
1875 			    (tmp & 0x07ff) * (((tmp & 0x1800) >> 11) + 1);
1876 			dev_dbg(d, "Alternate setting %i, max size= %i\n",
1877 				i, dev->ts1_mode.alt_max_pkt_size[i]);
1878 		}
1879 	}
1880 
1881 	if (dev->model == CX231XX_BOARD_CNXT_VIDEO_GRABBER) {
1882 		cx231xx_enable_OSC(dev);
1883 		cx231xx_reset_out(dev);
1884 		cx231xx_set_alt_setting(dev, INDEX_VIDEO, 3);
1885 	}
1886 
1887 	if (dev->model == CX231XX_BOARD_CNXT_RDE_253S)
1888 		cx231xx_sleep_s5h1432(dev);
1889 
1890 	/* load other modules required */
1891 	request_modules(dev);
1892 
1893 #ifdef CONFIG_MEDIA_CONTROLLER
1894 	/* Init entities at the Media Controller */
1895 	cx231xx_v4l2_create_entities(dev);
1896 
1897 	retval = v4l2_mc_create_media_graph(dev->media_dev);
1898 	if (!retval)
1899 		retval = media_device_register(dev->media_dev);
1900 #endif
1901 	if (retval < 0)
1902 		cx231xx_release_resources(dev);
1903 	return retval;
1904 
1905 err_video_alt:
1906 	/* cx231xx_uninit_dev: */
1907 	cx231xx_close_extension(dev);
1908 	cx231xx_ir_exit(dev);
1909 	cx231xx_release_analog_resources(dev);
1910 	cx231xx_417_unregister(dev);
1911 	cx231xx_remove_from_devlist(dev);
1912 	cx231xx_dev_uninit(dev);
1913 err_init:
1914 	v4l2_device_unregister(&dev->v4l2_dev);
1915 err_v4l2:
1916 	cx231xx_unregister_media_device(dev);
1917 err_media_init:
1918 	usb_set_intfdata(interface, NULL);
1919 err_if:
1920 	usb_put_dev(udev);
1921 	clear_bit(nr, &cx231xx_devused);
1922 	return retval;
1923 }
1924 
1925 /*
1926  * cx231xx_usb_disconnect()
1927  * called when the device gets disconnected
1928  * video device will be unregistered on v4l2_close in case it is still open
1929  */
1930 static void cx231xx_usb_disconnect(struct usb_interface *interface)
1931 {
1932 	struct cx231xx *dev;
1933 
1934 	dev = usb_get_intfdata(interface);
1935 	usb_set_intfdata(interface, NULL);
1936 
1937 	if (!dev)
1938 		return;
1939 
1940 	if (!dev->udev)
1941 		return;
1942 
1943 	dev->state |= DEV_DISCONNECTED;
1944 
1945 	flush_request_modules(dev);
1946 
1947 	/* wait until all current v4l2 io is finished then deallocate
1948 	   resources */
1949 	mutex_lock(&dev->lock);
1950 
1951 	wake_up_interruptible_all(&dev->open);
1952 
1953 	if (dev->users) {
1954 		dev_warn(dev->dev,
1955 			 "device %s is open! Deregistration and memory deallocation are deferred on close.\n",
1956 			 video_device_node_name(&dev->vdev));
1957 
1958 		/* Even having users, it is safe to remove the RC i2c driver */
1959 		cx231xx_ir_exit(dev);
1960 
1961 		if (dev->USE_ISO)
1962 			cx231xx_uninit_isoc(dev);
1963 		else
1964 			cx231xx_uninit_bulk(dev);
1965 		wake_up_interruptible(&dev->wait_frame);
1966 		wake_up_interruptible(&dev->wait_stream);
1967 	} else {
1968 	}
1969 
1970 	cx231xx_close_extension(dev);
1971 
1972 	mutex_unlock(&dev->lock);
1973 
1974 	if (!dev->users)
1975 		cx231xx_release_resources(dev);
1976 }
1977 
1978 static struct usb_driver cx231xx_usb_driver = {
1979 	.name = "cx231xx",
1980 	.probe = cx231xx_usb_probe,
1981 	.disconnect = cx231xx_usb_disconnect,
1982 	.id_table = cx231xx_id_table,
1983 };
1984 
1985 module_usb_driver(cx231xx_usb_driver);
1986