1 /*
2
3 bttv-cards.c
4
5 this file has configuration informations - card-specific stuff
6 like the big tvcards array for the most part
7
8 Copyright (C) 1996,97,98 Ralph Metzler (rjkm@thp.uni-koeln.de)
9 & Marcus Metzler (mocm@thp.uni-koeln.de)
10 (c) 1999-2001 Gerd Knorr <kraxel@goldbach.in-berlin.de>
11
12 This program is free software; you can redistribute it and/or modify
13 it under the terms of the GNU General Public License as published by
14 the Free Software Foundation; either version 2 of the License, or
15 (at your option) any later version.
16
17 This program is distributed in the hope that it will be useful,
18 but WITHOUT ANY WARRANTY; without even the implied warranty of
19 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
20 GNU General Public License for more details.
21
22 You should have received a copy of the GNU General Public License
23 along with this program; if not, write to the Free Software
24 Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
25
26 */
27
28 #include <linux/config.h>
29 #include <linux/delay.h>
30 #include <linux/module.h>
31 #include <linux/moduleparam.h>
32 #include <linux/kmod.h>
33 #include <linux/init.h>
34 #include <linux/pci.h>
35 #include <linux/vmalloc.h>
36 #include <linux/firmware.h>
37
38 #include <asm/io.h>
39
40 #include "bttvp.h"
41 #include <media/v4l2-common.h>
42 #include <media/tvaudio.h>
43
44 /* fwd decl */
45 static void boot_msp34xx(struct bttv *btv, int pin);
46 static void boot_bt832(struct bttv *btv);
47 static void hauppauge_eeprom(struct bttv *btv);
48 static void avermedia_eeprom(struct bttv *btv);
49 static void osprey_eeprom(struct bttv *btv);
50 static void modtec_eeprom(struct bttv *btv);
51 static void init_PXC200(struct bttv *btv);
52 static void init_RTV24(struct bttv *btv);
53
54 static void winview_audio(struct bttv *btv, struct video_audio *v, int set);
55 static void lt9415_audio(struct bttv *btv, struct video_audio *v, int set);
56 static void avermedia_tvphone_audio(struct bttv *btv, struct video_audio *v,
57 int set);
58 static void avermedia_tv_stereo_audio(struct bttv *btv, struct video_audio *v,
59 int set);
60 static void terratv_audio(struct bttv *btv, struct video_audio *v, int set);
61 static void gvbctv3pci_audio(struct bttv *btv, struct video_audio *v, int set);
62 static void gvbctv5pci_audio(struct bttv *btv, struct video_audio *v, int set);
63 static void winfast2000_audio(struct bttv *btv, struct video_audio *v, int set);
64 static void pvbt878p9b_audio(struct bttv *btv, struct video_audio *v, int set);
65 static void fv2000s_audio(struct bttv *btv, struct video_audio *v, int set);
66 static void windvr_audio(struct bttv *btv, struct video_audio *v, int set);
67 static void adtvk503_audio(struct bttv *btv, struct video_audio *v, int set);
68 static void rv605_muxsel(struct bttv *btv, unsigned int input);
69 static void eagle_muxsel(struct bttv *btv, unsigned int input);
70 static void xguard_muxsel(struct bttv *btv, unsigned int input);
71 static void ivc120_muxsel(struct bttv *btv, unsigned int input);
72 static void gvc1100_muxsel(struct bttv *btv, unsigned int input);
73
74 static void PXC200_muxsel(struct bttv *btv, unsigned int input);
75
76 static void picolo_tetra_muxsel(struct bttv *btv, unsigned int input);
77 static void picolo_tetra_init(struct bttv *btv);
78
79 static void tibetCS16_muxsel(struct bttv *btv, unsigned int input);
80 static void tibetCS16_init(struct bttv *btv);
81
82 static void kodicom4400r_muxsel(struct bttv *btv, unsigned int input);
83 static void kodicom4400r_init(struct bttv *btv);
84
85 static void sigmaSLC_muxsel(struct bttv *btv, unsigned int input);
86 static void sigmaSQ_muxsel(struct bttv *btv, unsigned int input);
87
88 static int terratec_active_radio_upgrade(struct bttv *btv);
89 static int tea5757_read(struct bttv *btv);
90 static int tea5757_write(struct bttv *btv, int value);
91 static void identify_by_eeprom(struct bttv *btv,
92 unsigned char eeprom_data[256]);
93 static int __devinit pvr_boot(struct bttv *btv);
94
95 /* config variables */
96 static unsigned int triton1;
97 static unsigned int vsfx;
98 static unsigned int latency = UNSET;
99 int no_overlay=-1;
100
101 static unsigned int card[BTTV_MAX] = { [ 0 ... (BTTV_MAX-1) ] = UNSET };
102 static unsigned int pll[BTTV_MAX] = { [ 0 ... (BTTV_MAX-1) ] = UNSET };
103 static unsigned int tuner[BTTV_MAX] = { [ 0 ... (BTTV_MAX-1) ] = UNSET };
104 static unsigned int svhs[BTTV_MAX] = { [ 0 ... (BTTV_MAX-1) ] = UNSET };
105 static unsigned int remote[BTTV_MAX] = { [ 0 ... (BTTV_MAX-1) ] = UNSET };
106 static struct bttv *master[BTTV_MAX] = { [ 0 ... (BTTV_MAX-1) ] = NULL };
107 #ifdef MODULE
108 static unsigned int autoload = 1;
109 #else
110 static unsigned int autoload;
111 #endif
112 static unsigned int gpiomask = UNSET;
113 static unsigned int audioall = UNSET;
114 static unsigned int audiomux[5] = { [ 0 ... 4 ] = UNSET };
115
116 /* insmod options */
117 module_param(triton1, int, 0444);
118 module_param(vsfx, int, 0444);
119 module_param(no_overlay, int, 0444);
120 module_param(latency, int, 0444);
121 module_param(gpiomask, int, 0444);
122 module_param(audioall, int, 0444);
123 module_param(autoload, int, 0444);
124
125 module_param_array(card, int, NULL, 0444);
126 module_param_array(pll, int, NULL, 0444);
127 module_param_array(tuner, int, NULL, 0444);
128 module_param_array(svhs, int, NULL, 0444);
129 module_param_array(remote, int, NULL, 0444);
130 module_param_array(audiomux, int, NULL, 0444);
131
132 MODULE_PARM_DESC(triton1,"set ETBF pci config bit "
133 "[enable bug compatibility for triton1 + others]");
134 MODULE_PARM_DESC(vsfx,"set VSFX pci config bit "
135 "[yet another chipset flaw workaround]");
136 MODULE_PARM_DESC(latency,"pci latency timer");
137 MODULE_PARM_DESC(card,"specify TV/grabber card model, see CARDLIST file for a list");
138 MODULE_PARM_DESC(pll,"specify installed crystal (0=none, 28=28 MHz, 35=35 MHz)");
139 MODULE_PARM_DESC(tuner,"specify installed tuner type");
140 MODULE_PARM_DESC(autoload,"automatically load i2c modules like tuner.o, default is 1 (yes)");
141 MODULE_PARM_DESC(no_overlay,"allow override overlay default (0 disables, 1 enables)"
142 " [some VIA/SIS chipsets are known to have problem with overlay]");
143
144 /* ----------------------------------------------------------------------- */
145 /* list of card IDs for bt878+ cards */
146
147 static struct CARD {
148 unsigned id;
149 int cardnr;
150 char *name;
151 } cards[] __devinitdata = {
152 { 0x13eb0070, BTTV_BOARD_HAUPPAUGE878, "Hauppauge WinTV" },
153 { 0x39000070, BTTV_BOARD_HAUPPAUGE878, "Hauppauge WinTV-D" },
154 { 0x45000070, BTTV_BOARD_HAUPPAUGEPVR, "Hauppauge WinTV/PVR" },
155 { 0xff000070, BTTV_BOARD_OSPREY1x0, "Osprey-100" },
156 { 0xff010070, BTTV_BOARD_OSPREY2x0_SVID,"Osprey-200" },
157 { 0xff020070, BTTV_BOARD_OSPREY500, "Osprey-500" },
158 { 0xff030070, BTTV_BOARD_OSPREY2000, "Osprey-2000" },
159 { 0xff040070, BTTV_BOARD_OSPREY540, "Osprey-540" },
160 { 0xff070070, BTTV_BOARD_OSPREY440, "Osprey-440" },
161
162 { 0x00011002, BTTV_BOARD_ATI_TVWONDER, "ATI TV Wonder" },
163 { 0x00031002, BTTV_BOARD_ATI_TVWONDERVE,"ATI TV Wonder/VE" },
164
165 { 0x6606107d, BTTV_BOARD_WINFAST2000, "Leadtek WinFast TV 2000" },
166 { 0x6607107d, BTTV_BOARD_WINFASTVC100, "Leadtek WinFast VC 100" },
167 { 0x6609107d, BTTV_BOARD_WINFAST2000, "Leadtek TV 2000 XP" },
168 { 0x263610b4, BTTV_BOARD_STB2, "STB TV PCI FM, Gateway P/N 6000704" },
169 { 0x264510b4, BTTV_BOARD_STB2, "STB TV PCI FM, Gateway P/N 6000704" },
170 { 0x402010fc, BTTV_BOARD_GVBCTV3PCI, "I-O Data Co. GV-BCTV3/PCI" },
171 { 0x405010fc, BTTV_BOARD_GVBCTV4PCI, "I-O Data Co. GV-BCTV4/PCI" },
172 { 0x407010fc, BTTV_BOARD_GVBCTV5PCI, "I-O Data Co. GV-BCTV5/PCI" },
173 { 0xd01810fc, BTTV_BOARD_GVBCTV5PCI, "I-O Data Co. GV-BCTV5/PCI" },
174
175 { 0x001211bd, BTTV_BOARD_PINNACLE, "Pinnacle PCTV" },
176 /* some cards ship with byteswapped IDs ... */
177 { 0x1200bd11, BTTV_BOARD_PINNACLE, "Pinnacle PCTV [bswap]" },
178 { 0xff00bd11, BTTV_BOARD_PINNACLE, "Pinnacle PCTV [bswap]" },
179 /* this seems to happen as well ... */
180 { 0xff1211bd, BTTV_BOARD_PINNACLE, "Pinnacle PCTV" },
181
182 { 0x3000121a, BTTV_BOARD_VOODOOTV_FM, "3Dfx VoodooTV FM/ VoodooTV 200" },
183 { 0x263710b4, BTTV_BOARD_VOODOOTV_FM, "3Dfx VoodooTV FM/ VoodooTV 200" },
184 { 0x3060121a, BTTV_BOARD_STB2, "3Dfx VoodooTV 100/ STB OEM" },
185
186 { 0x3000144f, BTTV_BOARD_MAGICTVIEW063, "(Askey Magic/others) TView99 CPH06x" },
187 { 0xa005144f, BTTV_BOARD_MAGICTVIEW063, "CPH06X TView99-Card" },
188 { 0x3002144f, BTTV_BOARD_MAGICTVIEW061, "(Askey Magic/others) TView99 CPH05x" },
189 { 0x3005144f, BTTV_BOARD_MAGICTVIEW061, "(Askey Magic/others) TView99 CPH061/06L (T1/LC)" },
190 { 0x5000144f, BTTV_BOARD_MAGICTVIEW061, "Askey CPH050" },
191 { 0x300014ff, BTTV_BOARD_MAGICTVIEW061, "TView 99 (CPH061)" },
192 { 0x300214ff, BTTV_BOARD_PHOEBE_TVMAS, "Phoebe TV Master (CPH060)" },
193
194 { 0x00011461, BTTV_BOARD_AVPHONE98, "AVerMedia TVPhone98" },
195 { 0x00021461, BTTV_BOARD_AVERMEDIA98, "AVermedia TVCapture 98" },
196 { 0x00031461, BTTV_BOARD_AVPHONE98, "AVerMedia TVPhone98" },
197 { 0x00041461, BTTV_BOARD_AVERMEDIA98, "AVerMedia TVCapture 98" },
198 { 0x03001461, BTTV_BOARD_AVERMEDIA98, "VDOMATE TV TUNER CARD" },
199
200 { 0x1117153b, BTTV_BOARD_TERRATVALUE, "Terratec TValue (Philips PAL B/G)" },
201 { 0x1118153b, BTTV_BOARD_TERRATVALUE, "Terratec TValue (Temic PAL B/G)" },
202 { 0x1119153b, BTTV_BOARD_TERRATVALUE, "Terratec TValue (Philips PAL I)" },
203 { 0x111a153b, BTTV_BOARD_TERRATVALUE, "Terratec TValue (Temic PAL I)" },
204
205 { 0x1123153b, BTTV_BOARD_TERRATVRADIO, "Terratec TV Radio+" },
206 { 0x1127153b, BTTV_BOARD_TERRATV, "Terratec TV+ (V1.05)" },
207 /* clashes with FlyVideo
208 *{ 0x18521852, BTTV_BOARD_TERRATV, "Terratec TV+ (V1.10)" }, */
209 { 0x1134153b, BTTV_BOARD_TERRATVALUE, "Terratec TValue (LR102)" },
210 { 0x1135153b, BTTV_BOARD_TERRATVALUER, "Terratec TValue Radio" }, /* LR102 */
211 { 0x5018153b, BTTV_BOARD_TERRATVALUE, "Terratec TValue" }, /* ?? */
212 { 0xff3b153b, BTTV_BOARD_TERRATVALUER, "Terratec TValue Radio" }, /* ?? */
213
214 { 0x400015b0, BTTV_BOARD_ZOLTRIX_GENIE, "Zoltrix Genie TV" },
215 { 0x400a15b0, BTTV_BOARD_ZOLTRIX_GENIE, "Zoltrix Genie TV" },
216 { 0x400d15b0, BTTV_BOARD_ZOLTRIX_GENIE, "Zoltrix Genie TV / Radio" },
217 { 0x401015b0, BTTV_BOARD_ZOLTRIX_GENIE, "Zoltrix Genie TV / Radio" },
218 { 0x401615b0, BTTV_BOARD_ZOLTRIX_GENIE, "Zoltrix Genie TV / Radio" },
219
220 { 0x1430aa00, BTTV_BOARD_PV143, "Provideo PV143A" },
221 { 0x1431aa00, BTTV_BOARD_PV143, "Provideo PV143B" },
222 { 0x1432aa00, BTTV_BOARD_PV143, "Provideo PV143C" },
223 { 0x1433aa00, BTTV_BOARD_PV143, "Provideo PV143D" },
224 { 0x1433aa03, BTTV_BOARD_PV143, "Security Eyes" },
225
226 { 0x1460aa00, BTTV_BOARD_PV150, "Provideo PV150A-1" },
227 { 0x1461aa01, BTTV_BOARD_PV150, "Provideo PV150A-2" },
228 { 0x1462aa02, BTTV_BOARD_PV150, "Provideo PV150A-3" },
229 { 0x1463aa03, BTTV_BOARD_PV150, "Provideo PV150A-4" },
230
231 { 0x1464aa04, BTTV_BOARD_PV150, "Provideo PV150B-1" },
232 { 0x1465aa05, BTTV_BOARD_PV150, "Provideo PV150B-2" },
233 { 0x1466aa06, BTTV_BOARD_PV150, "Provideo PV150B-3" },
234 { 0x1467aa07, BTTV_BOARD_PV150, "Provideo PV150B-4" },
235
236 { 0xa132ff00, BTTV_BOARD_IVC100, "IVC-100" },
237 { 0xa1550000, BTTV_BOARD_IVC200, "IVC-200" },
238 { 0xa1550001, BTTV_BOARD_IVC200, "IVC-200" },
239 { 0xa1550002, BTTV_BOARD_IVC200, "IVC-200" },
240 { 0xa1550003, BTTV_BOARD_IVC200, "IVC-200" },
241 { 0xa1550100, BTTV_BOARD_IVC200, "IVC-200G" },
242 { 0xa1550101, BTTV_BOARD_IVC200, "IVC-200G" },
243 { 0xa1550102, BTTV_BOARD_IVC200, "IVC-200G" },
244 { 0xa1550103, BTTV_BOARD_IVC200, "IVC-200G" },
245 { 0xa182ff00, BTTV_BOARD_IVC120, "IVC-120G" },
246 { 0xa182ff01, BTTV_BOARD_IVC120, "IVC-120G" },
247 { 0xa182ff02, BTTV_BOARD_IVC120, "IVC-120G" },
248 { 0xa182ff03, BTTV_BOARD_IVC120, "IVC-120G" },
249 { 0xa182ff04, BTTV_BOARD_IVC120, "IVC-120G" },
250 { 0xa182ff05, BTTV_BOARD_IVC120, "IVC-120G" },
251 { 0xa182ff06, BTTV_BOARD_IVC120, "IVC-120G" },
252 { 0xa182ff07, BTTV_BOARD_IVC120, "IVC-120G" },
253 { 0xa182ff08, BTTV_BOARD_IVC120, "IVC-120G" },
254 { 0xa182ff09, BTTV_BOARD_IVC120, "IVC-120G" },
255 { 0xa182ff0a, BTTV_BOARD_IVC120, "IVC-120G" },
256 { 0xa182ff0b, BTTV_BOARD_IVC120, "IVC-120G" },
257 { 0xa182ff0c, BTTV_BOARD_IVC120, "IVC-120G" },
258 { 0xa182ff0d, BTTV_BOARD_IVC120, "IVC-120G" },
259 { 0xa182ff0e, BTTV_BOARD_IVC120, "IVC-120G" },
260 { 0xa182ff0f, BTTV_BOARD_IVC120, "IVC-120G" },
261
262 { 0x41424344, BTTV_BOARD_GRANDTEC, "GrandTec Multi Capture" },
263 { 0x01020304, BTTV_BOARD_XGUARD, "Grandtec Grand X-Guard" },
264
265 { 0x18501851, BTTV_BOARD_CHRONOS_VS2, "FlyVideo 98 (LR50)/ Chronos Video Shuttle II" },
266 { 0xa0501851, BTTV_BOARD_CHRONOS_VS2, "FlyVideo 98 (LR50)/ Chronos Video Shuttle II" },
267 { 0x18511851, BTTV_BOARD_FLYVIDEO98EZ, "FlyVideo 98EZ (LR51)/ CyberMail AV" },
268 { 0x18521852, BTTV_BOARD_TYPHOON_TVIEW, "FlyVideo 98FM (LR50)/ Typhoon TView TV/FM Tuner" },
269 { 0x41a0a051, BTTV_BOARD_FLYVIDEO_98FM, "Lifeview FlyVideo 98 LR50 Rev Q" },
270 { 0x18501f7f, BTTV_BOARD_FLYVIDEO_98, "Lifeview Flyvideo 98" },
271
272 { 0x010115cb, BTTV_BOARD_GMV1, "AG GMV1" },
273 { 0x010114c7, BTTV_BOARD_MODTEC_205, "Modular Technology MM201/MM202/MM205/MM210/MM215 PCTV" },
274
275 { 0x10b42636, BTTV_BOARD_HAUPPAUGE878, "STB ???" },
276 { 0x217d6606, BTTV_BOARD_WINFAST2000, "Leadtek WinFast TV 2000" },
277 { 0xfff6f6ff, BTTV_BOARD_WINFAST2000, "Leadtek WinFast TV 2000" },
278 { 0x03116000, BTTV_BOARD_SENSORAY311, "Sensoray 311" },
279 { 0x00790e11, BTTV_BOARD_WINDVR, "Canopus WinDVR PCI" },
280 { 0xa0fca1a0, BTTV_BOARD_ZOLTRIX, "Face to Face Tvmax" },
281 { 0x82b2aa6a, BTTV_BOARD_SIMUS_GVC1100, "SIMUS GVC1100" },
282 { 0x146caa0c, BTTV_BOARD_PV951, "ituner spectra8" },
283 { 0x200a1295, BTTV_BOARD_PXC200, "ImageNation PXC200A" },
284
285 { 0x40111554, BTTV_BOARD_PV_BT878P_9B, "Prolink Pixelview PV-BT" },
286 { 0x17de0a01, BTTV_BOARD_KWORLD, "Mecer TV/FM/Video Tuner" },
287
288 { 0x01051805, BTTV_BOARD_PICOLO_TETRA_CHIP, "Picolo Tetra Chip #1" },
289 { 0x01061805, BTTV_BOARD_PICOLO_TETRA_CHIP, "Picolo Tetra Chip #2" },
290 { 0x01071805, BTTV_BOARD_PICOLO_TETRA_CHIP, "Picolo Tetra Chip #3" },
291 { 0x01081805, BTTV_BOARD_PICOLO_TETRA_CHIP, "Picolo Tetra Chip #4" },
292
293 { 0x15409511, BTTV_BOARD_ACORP_Y878F, "Acorp Y878F" },
294
295 /* likely broken, vendor id doesn't match the other magic views ...
296 * { 0xa0fca04f, BTTV_BOARD_MAGICTVIEW063, "Guillemot Maxi TV Video 3" }, */
297
298 /* Duplicate PCI ID, reconfigure for this board during the eeprom read.
299 * { 0x13eb0070, BTTV_BOARD_HAUPPAUGE_IMPACTVCB, "Hauppauge ImpactVCB" }, */
300
301 /* DVB cards (using pci function .1 for mpeg data xfer) */
302 { 0x001c11bd, BTTV_BOARD_PINNACLESAT, "Pinnacle PCTV Sat" },
303 { 0x01010071, BTTV_BOARD_NEBULA_DIGITV, "Nebula Electronics DigiTV" },
304 { 0x20007063, BTTV_BOARD_PC_HDTV, "pcHDTV HD-2000 TV"},
305 { 0x002611bd, BTTV_BOARD_TWINHAN_DST, "Pinnacle PCTV SAT CI" },
306 { 0x00011822, BTTV_BOARD_TWINHAN_DST, "Twinhan VisionPlus DVB" },
307 { 0xfc00270f, BTTV_BOARD_TWINHAN_DST, "ChainTech digitop DST-1000 DVB-S" },
308 { 0x07711461, BTTV_BOARD_AVDVBT_771, "AVermedia AverTV DVB-T 771" },
309 { 0x07611461, BTTV_BOARD_AVDVBT_761, "AverMedia AverTV DVB-T 761" },
310 { 0xdb1018ac, BTTV_BOARD_DVICO_DVBT_LITE, "DViCO FusionHDTV DVB-T Lite" },
311 { 0xd50018ac, BTTV_BOARD_DVICO_FUSIONHDTV_5_LITE, "DViCO FusionHDTV 5 Lite" },
312
313 { 0, -1, NULL }
314 };
315
316 /* ----------------------------------------------------------------------- */
317 /* array with description for bt848 / bt878 tv/grabber cards */
318
319 struct tvcard bttv_tvcards[] = {
320 /* ---- card 0x00 ---------------------------------- */
321 [BTTV_BOARD_UNKNOWN] = {
322 .name = " *** UNKNOWN/GENERIC *** ",
323 .video_inputs = 4,
324 .audio_inputs = 1,
325 .tuner = 0,
326 .svhs = 2,
327 .muxsel = { 2, 3, 1, 0 },
328 .tuner_type = -1,
329 .tuner_addr = ADDR_UNSET,
330 .radio_addr = ADDR_UNSET,
331 },
332 [BTTV_BOARD_MIRO] = {
333 .name = "MIRO PCTV",
334 .video_inputs = 4,
335 .audio_inputs = 1,
336 .tuner = 0,
337 .svhs = 2,
338 .gpiomask = 15,
339 .muxsel = { 2, 3, 1, 1 },
340 .gpiomux = { 2, 0, 0, 0 },
341 .gpiomute = 10,
342 .needs_tvaudio = 1,
343 .tuner_type = -1,
344 .tuner_addr = ADDR_UNSET,
345 .radio_addr = ADDR_UNSET,
346 },
347 [BTTV_BOARD_HAUPPAUGE] = {
348 .name = "Hauppauge (bt848)",
349 .video_inputs = 4,
350 .audio_inputs = 1,
351 .tuner = 0,
352 .svhs = 2,
353 .gpiomask = 7,
354 .muxsel = { 2, 3, 1, 1 },
355 .gpiomux = { 0, 1, 2, 3 },
356 .gpiomute = 4,
357 .needs_tvaudio = 1,
358 .tuner_type = -1,
359 .tuner_addr = ADDR_UNSET,
360 .radio_addr = ADDR_UNSET,
361 },
362 [BTTV_BOARD_STB] = {
363 .name = "STB, Gateway P/N 6000699 (bt848)",
364 .video_inputs = 3,
365 .audio_inputs = 1,
366 .tuner = 0,
367 .svhs = 2,
368 .gpiomask = 7,
369 .muxsel = { 2, 3, 1, 1 },
370 .gpiomux = { 4, 0, 2, 3 },
371 .gpiomute = 1,
372 .no_msp34xx = 1,
373 .needs_tvaudio = 1,
374 .tuner_type = TUNER_PHILIPS_NTSC,
375 .tuner_addr = ADDR_UNSET,
376 .radio_addr = ADDR_UNSET,
377 .pll = PLL_28,
378 .has_radio = 1,
379 },
380
381 /* ---- card 0x04 ---------------------------------- */
382 [BTTV_BOARD_INTEL] = {
383 .name = "Intel Create and Share PCI/ Smart Video Recorder III",
384 .video_inputs = 4,
385 .audio_inputs = 0,
386 .tuner = -1,
387 .svhs = 2,
388 .gpiomask = 0,
389 .muxsel = { 2, 3, 1, 1 },
390 .gpiomux = { 0 },
391 .needs_tvaudio = 0,
392 .tuner_type = 4,
393 .tuner_addr = ADDR_UNSET,
394 .radio_addr = ADDR_UNSET,
395 },
396 [BTTV_BOARD_DIAMOND] = {
397 .name = "Diamond DTV2000",
398 .video_inputs = 4,
399 .audio_inputs = 1,
400 .tuner = 0,
401 .svhs = 2,
402 .gpiomask = 3,
403 .muxsel = { 2, 3, 1, 0 },
404 .gpiomux = { 0, 1, 0, 1 },
405 .gpiomute = 3,
406 .needs_tvaudio = 1,
407 .tuner_type = -1,
408 .tuner_addr = ADDR_UNSET,
409 .radio_addr = ADDR_UNSET,
410 },
411 [BTTV_BOARD_AVERMEDIA] = {
412 .name = "AVerMedia TVPhone",
413 .video_inputs = 3,
414 .audio_inputs = 1,
415 .tuner = 0,
416 .svhs = 3,
417 .muxsel = { 2, 3, 1, 1 },
418 .gpiomask = 0x0f,
419 .gpiomux = { 0x0c, 0x04, 0x08, 0x04 },
420 /* 0x04 for some cards ?? */
421 .needs_tvaudio = 1,
422 .tuner_type = -1,
423 .tuner_addr = ADDR_UNSET,
424 .radio_addr = ADDR_UNSET,
425 .audio_hook = avermedia_tvphone_audio,
426 .has_remote = 1,
427 },
428 [BTTV_BOARD_MATRIX_VISION] = {
429 .name = "MATRIX-Vision MV-Delta",
430 .video_inputs = 5,
431 .audio_inputs = 1,
432 .tuner = -1,
433 .svhs = 3,
434 .gpiomask = 0,
435 .muxsel = { 2, 3, 1, 0, 0 },
436 .gpiomux = { 0 },
437 .needs_tvaudio = 1,
438 .tuner_type = -1,
439 .tuner_addr = ADDR_UNSET,
440 .radio_addr = ADDR_UNSET,
441 },
442
443 /* ---- card 0x08 ---------------------------------- */
444 [BTTV_BOARD_FLYVIDEO] = {
445 .name = "Lifeview FlyVideo II (Bt848) LR26 / MAXI TV Video PCI2 LR26",
446 .video_inputs = 4,
447 .audio_inputs = 1,
448 .tuner = 0,
449 .svhs = 2,
450 .gpiomask = 0xc00,
451 .muxsel = { 2, 3, 1, 1 },
452 .gpiomux = { 0, 0xc00, 0x800, 0x400 },
453 .gpiomute = 0xc00,
454 .needs_tvaudio = 1,
455 .pll = PLL_28,
456 .tuner_type = -1,
457 .tuner_addr = ADDR_UNSET,
458 .radio_addr = ADDR_UNSET,
459 },
460 [BTTV_BOARD_TURBOTV] = {
461 .name = "IMS/IXmicro TurboTV",
462 .video_inputs = 3,
463 .audio_inputs = 1,
464 .tuner = 0,
465 .svhs = 2,
466 .gpiomask = 3,
467 .muxsel = { 2, 3, 1, 1 },
468 .gpiomux = { 1, 1, 2, 3 },
469 .needs_tvaudio = 0,
470 .pll = PLL_28,
471 .tuner_type = TUNER_TEMIC_PAL,
472 .tuner_addr = ADDR_UNSET,
473 .radio_addr = ADDR_UNSET,
474 },
475 [BTTV_BOARD_HAUPPAUGE878] = {
476 .name = "Hauppauge (bt878)",
477 .video_inputs = 4,
478 .audio_inputs = 1,
479 .tuner = 0,
480 .svhs = 2,
481 .gpiomask = 0x0f, /* old: 7 */
482 .muxsel = { 2, 0, 1, 1 },
483 .gpiomux = { 0, 1, 2, 3 },
484 .gpiomute = 4,
485 .needs_tvaudio = 1,
486 .pll = PLL_28,
487 .tuner_type = -1,
488 .tuner_addr = ADDR_UNSET,
489 .radio_addr = ADDR_UNSET,
490 },
491 [BTTV_BOARD_MIROPRO] = {
492 .name = "MIRO PCTV pro",
493 .video_inputs = 3,
494 .audio_inputs = 1,
495 .tuner = 0,
496 .svhs = 2,
497 .gpiomask = 0x3014f,
498 .muxsel = { 2, 3, 1, 1 },
499 .gpiomux = { 0x20001,0x10001, 0, 0 },
500 .gpiomute = 10,
501 .needs_tvaudio = 1,
502 .tuner_type = -1,
503 .tuner_addr = ADDR_UNSET,
504 .radio_addr = ADDR_UNSET,
505 },
506
507 /* ---- card 0x0c ---------------------------------- */
508 [BTTV_BOARD_ADSTECH_TV] = {
509 .name = "ADS Technologies Channel Surfer TV (bt848)",
510 .video_inputs = 3,
511 .audio_inputs = 1,
512 .tuner = 0,
513 .svhs = 2,
514 .gpiomask = 15,
515 .muxsel = { 2, 3, 1, 1 },
516 .gpiomux = { 13, 14, 11, 7 },
517 .needs_tvaudio = 1,
518 .tuner_type = -1,
519 .tuner_addr = ADDR_UNSET,
520 .radio_addr = ADDR_UNSET,
521 },
522 [BTTV_BOARD_AVERMEDIA98] = {
523 .name = "AVerMedia TVCapture 98",
524 .video_inputs = 3,
525 .audio_inputs = 4,
526 .tuner = 0,
527 .svhs = 2,
528 .gpiomask = 15,
529 .muxsel = { 2, 3, 1, 1 },
530 .gpiomux = { 13, 14, 11, 7 },
531 .needs_tvaudio = 1,
532 .msp34xx_alt = 1,
533 .pll = PLL_28,
534 .tuner_type = TUNER_PHILIPS_PAL,
535 .tuner_addr = ADDR_UNSET,
536 .radio_addr = ADDR_UNSET,
537 .audio_hook = avermedia_tv_stereo_audio,
538 .no_gpioirq = 1,
539 },
540 [BTTV_BOARD_VHX] = {
541 .name = "Aimslab Video Highway Xtreme (VHX)",
542 .video_inputs = 3,
543 .audio_inputs = 1,
544 .tuner = 0,
545 .svhs = 2,
546 .gpiomask = 7,
547 .muxsel = { 2, 3, 1, 1 },
548 .gpiomux = { 0, 2, 1, 3 }, /* old: {0, 1, 2, 3, 4} */
549 .gpiomute = 4,
550 .needs_tvaudio = 1,
551 .pll = PLL_28,
552 .tuner_type = -1,
553 .tuner_addr = ADDR_UNSET,
554 .radio_addr = ADDR_UNSET,
555 },
556 [BTTV_BOARD_ZOLTRIX] = {
557 .name = "Zoltrix TV-Max",
558 .video_inputs = 3,
559 .audio_inputs = 1,
560 .tuner = 0,
561 .svhs = 2,
562 .gpiomask = 15,
563 .muxsel = { 2, 3, 1, 1 },
564 .gpiomux = { 0, 0, 1, 0 },
565 .gpiomute = 10,
566 .needs_tvaudio = 1,
567 .tuner_type = -1,
568 .tuner_addr = ADDR_UNSET,
569 .radio_addr = ADDR_UNSET,
570 },
571
572 /* ---- card 0x10 ---------------------------------- */
573 [BTTV_BOARD_PIXVIEWPLAYTV] = {
574 .name = "Prolink Pixelview PlayTV (bt878)",
575 .video_inputs = 3,
576 .audio_inputs = 1,
577 .tuner = 0,
578 .svhs = 2,
579 .gpiomask = 0x01fe00,
580 .muxsel = { 2, 3, 1, 1 },
581 #if 0
582 /* old */
583 .gpiomux = { 0x01c000, 0, 0x018000, 0x014000, 0x002000 },
584 #else
585 /* 2003-10-20 by "Anton A. Arapov" <arapov@mail.ru> */
586 .gpiomux = { 0x001e00, 0, 0x018000, 0x014000 },
587 .gpiomute = 0x002000,
588 #endif
589 .needs_tvaudio = 1,
590 .pll = PLL_28,
591 .tuner_type = -1,
592 },
593 [BTTV_BOARD_WINVIEW_601] = {
594 .name = "Leadtek WinView 601",
595 .video_inputs = 3,
596 .audio_inputs = 1,
597 .tuner = 0,
598 .svhs = 2,
599 .gpiomask = 0x8300f8,
600 .muxsel = { 2, 3, 1, 1,0 },
601 .gpiomux = { 0x4fa007,0xcfa007,0xcfa007,0xcfa007 },
602 .gpiomute = 0xcfa007,
603 .needs_tvaudio = 1,
604 .tuner_type = -1,
605 .tuner_addr = ADDR_UNSET,
606 .radio_addr = ADDR_UNSET,
607 .audio_hook = winview_audio,
608 .has_radio = 1,
609 },
610 [BTTV_BOARD_AVEC_INTERCAP] = {
611 .name = "AVEC Intercapture",
612 .video_inputs = 3,
613 .audio_inputs = 2,
614 .tuner = 0,
615 .svhs = 2,
616 .gpiomask = 0,
617 .muxsel = { 2, 3, 1, 1 },
618 .gpiomux = { 1, 0, 0, 0 },
619 .needs_tvaudio = 1,
620 .tuner_type = -1,
621 .tuner_addr = ADDR_UNSET,
622 .radio_addr = ADDR_UNSET,
623 },
624 [BTTV_BOARD_LIFE_FLYKIT] = {
625 .name = "Lifeview FlyVideo II EZ /FlyKit LR38 Bt848 (capture only)",
626 .video_inputs = 4,
627 .audio_inputs = 1,
628 .tuner = -1,
629 .svhs = -1,
630 .gpiomask = 0x8dff00,
631 .muxsel = { 2, 3, 1, 1 },
632 .gpiomux = { 0 },
633 .no_msp34xx = 1,
634 .tuner_type = -1,
635 .tuner_addr = ADDR_UNSET,
636 .radio_addr = ADDR_UNSET,
637 },
638
639 /* ---- card 0x14 ---------------------------------- */
640 [BTTV_BOARD_CEI_RAFFLES] = {
641 .name = "CEI Raffles Card",
642 .video_inputs = 3,
643 .audio_inputs = 3,
644 .tuner = 0,
645 .svhs = 2,
646 .muxsel = { 2, 3, 1, 1 },
647 .tuner_type = -1,
648 .tuner_addr = ADDR_UNSET,
649 .radio_addr = ADDR_UNSET,
650 },
651 [BTTV_BOARD_CONFERENCETV] = {
652 .name = "Lifeview FlyVideo 98/ Lucky Star Image World ConferenceTV LR50",
653 .video_inputs = 4,
654 .audio_inputs = 2, /* tuner, line in */
655 .tuner = 0,
656 .svhs = 2,
657 .gpiomask = 0x1800,
658 .muxsel = { 2, 3, 1, 1 },
659 .gpiomux = { 0, 0x800, 0x1000, 0x1000 },
660 .gpiomute = 0x1800,
661 .pll = PLL_28,
662 .tuner_type = TUNER_PHILIPS_PAL_I,
663 .tuner_addr = ADDR_UNSET,
664 .radio_addr = ADDR_UNSET,
665 },
666 [BTTV_BOARD_PHOEBE_TVMAS] = {
667 .name = "Askey CPH050/ Phoebe Tv Master + FM",
668 .video_inputs = 3,
669 .audio_inputs = 1,
670 .tuner = 0,
671 .svhs = 2,
672 .gpiomask = 0xc00,
673 .muxsel = { 2, 3, 1, 1 },
674 .gpiomux = { 0, 1, 0x800, 0x400 },
675 .gpiomute = 0xc00,
676 .needs_tvaudio = 1,
677 .pll = PLL_28,
678 .tuner_type = -1,
679 .tuner_addr = ADDR_UNSET,
680 .radio_addr = ADDR_UNSET,
681 },
682 [BTTV_BOARD_MODTEC_205] = {
683 .name = "Modular Technology MM201/MM202/MM205/MM210/MM215 PCTV, bt878",
684 .video_inputs = 3,
685 .audio_inputs = 1,
686 .tuner = 0,
687 .svhs = -1,
688 .gpiomask = 7,
689 .muxsel = { 2, 3, -1 },
690 .digital_mode = DIGITAL_MODE_CAMERA,
691 .gpiomux = { 0, 0, 0, 0 },
692 .no_msp34xx = 1,
693 .pll = PLL_28,
694 .tuner_type = TUNER_ALPS_TSBB5_PAL_I,
695 .tuner_addr = ADDR_UNSET,
696 .radio_addr = ADDR_UNSET,
697 },
698
699 /* ---- card 0x18 ---------------------------------- */
700 [BTTV_BOARD_MAGICTVIEW061] = {
701 .name = "Askey CPH05X/06X (bt878) [many vendors]",
702 .video_inputs = 3,
703 .audio_inputs = 1,
704 .tuner = 0,
705 .svhs = 2,
706 .gpiomask = 0xe00,
707 .muxsel = { 2, 3, 1, 1 },
708 .gpiomux = {0x400, 0x400, 0x400, 0x400 },
709 .gpiomute = 0xc00,
710 .needs_tvaudio = 1,
711 .pll = PLL_28,
712 .tuner_type = -1,
713 .tuner_addr = ADDR_UNSET,
714 .radio_addr = ADDR_UNSET,
715 .has_remote = 1,
716 },
717 [BTTV_BOARD_VOBIS_BOOSTAR] = {
718 .name = "Terratec TerraTV+ Version 1.0 (Bt848)/ Terra TValue Version 1.0/ Vobis TV-Boostar",
719 .video_inputs = 3,
720 .audio_inputs = 1,
721 .tuner = 0,
722 .svhs = 2,
723 .gpiomask = 0x1f0fff,
724 .muxsel = { 2, 3, 1, 1 },
725 .gpiomux = { 0x20000, 0x30000, 0x10000, 0 },
726 .gpiomute = 0x40000,
727 .needs_tvaudio = 0,
728 .tuner_type = TUNER_PHILIPS_PAL,
729 .tuner_addr = ADDR_UNSET,
730 .radio_addr = ADDR_UNSET,
731 .audio_hook = terratv_audio,
732 },
733 [BTTV_BOARD_HAUPPAUG_WCAM] = {
734 .name = "Hauppauge WinCam newer (bt878)",
735 .video_inputs = 4,
736 .audio_inputs = 1,
737 .tuner = 0,
738 .svhs = 3,
739 .gpiomask = 7,
740 .muxsel = { 2, 0, 1, 1 },
741 .gpiomux = { 0, 1, 2, 3 },
742 .gpiomute = 4,
743 .needs_tvaudio = 1,
744 .tuner_type = -1,
745 .tuner_addr = ADDR_UNSET,
746 .radio_addr = ADDR_UNSET,
747 },
748 [BTTV_BOARD_MAXI] = {
749 .name = "Lifeview FlyVideo 98/ MAXI TV Video PCI2 LR50",
750 .video_inputs = 4,
751 .audio_inputs = 2,
752 .tuner = 0,
753 .svhs = 2,
754 .gpiomask = 0x1800,
755 .muxsel = { 2, 3, 1, 1 },
756 .gpiomux = { 0, 0x800, 0x1000, 0x1000 },
757 .gpiomute = 0x1800,
758 .pll = PLL_28,
759 .tuner_type = TUNER_PHILIPS_SECAM,
760 .tuner_addr = ADDR_UNSET,
761 .radio_addr = ADDR_UNSET,
762 },
763
764 /* ---- card 0x1c ---------------------------------- */
765 [BTTV_BOARD_TERRATV] = {
766 .name = "Terratec TerraTV+ Version 1.1 (bt878)",
767 .video_inputs = 3,
768 .audio_inputs = 1,
769 .tuner = 0,
770 .svhs = 2,
771 .gpiomask = 0x1f0fff,
772 .muxsel = { 2, 3, 1, 1 },
773 .gpiomux = { 0x20000, 0x30000, 0x10000, 0x00000 },
774 .gpiomute = 0x40000,
775 .needs_tvaudio = 0,
776 .tuner_type = TUNER_PHILIPS_PAL,
777 .tuner_addr = ADDR_UNSET,
778 .radio_addr = ADDR_UNSET,
779 .audio_hook = terratv_audio,
780 /* GPIO wiring:
781 External 20 pin connector (for Active Radio Upgrade board)
782 gpio00: i2c-sda
783 gpio01: i2c-scl
784 gpio02: om5610-data
785 gpio03: om5610-clk
786 gpio04: om5610-wre
787 gpio05: om5610-stereo
788 gpio06: rds6588-davn
789 gpio07: Pin 7 n.c.
790 gpio08: nIOW
791 gpio09+10: nIOR, nSEL ?? (bt878)
792 gpio09: nIOR (bt848)
793 gpio10: nSEL (bt848)
794 Sound Routing:
795 gpio16: u2-A0 (1st 4052bt)
796 gpio17: u2-A1
797 gpio18: u2-nEN
798 gpio19: u4-A0 (2nd 4052)
799 gpio20: u4-A1
800 u4-nEN - GND
801 Btspy:
802 00000 : Cdrom (internal audio input)
803 10000 : ext. Video audio input
804 20000 : TV Mono
805 a0000 : TV Mono/2
806 1a0000 : TV Stereo
807 30000 : Radio
808 40000 : Mute
809 */
810
811 },
812 [BTTV_BOARD_PXC200] = {
813 /* Jannik Fritsch <jannik@techfak.uni-bielefeld.de> */
814 .name = "Imagenation PXC200",
815 .video_inputs = 5,
816 .audio_inputs = 1,
817 .tuner = -1,
818 .svhs = 1, /* was: 4 */
819 .gpiomask = 0,
820 .muxsel = { 2, 3, 1, 0, 0},
821 .gpiomux = { 0 },
822 .needs_tvaudio = 1,
823 .tuner_type = -1,
824 .tuner_addr = ADDR_UNSET,
825 .radio_addr = ADDR_UNSET,
826 .muxsel_hook = PXC200_muxsel,
827
828 },
829 [BTTV_BOARD_FLYVIDEO_98] = {
830 .name = "Lifeview FlyVideo 98 LR50",
831 .video_inputs = 4,
832 .audio_inputs = 1,
833 .tuner = 0,
834 .svhs = 2,
835 .gpiomask = 0x1800, /* 0x8dfe00 */
836 .muxsel = { 2, 3, 1, 1 },
837 .gpiomux = { 0, 0x0800, 0x1000, 0x1000 },
838 .gpiomute = 0x1800,
839 .pll = PLL_28,
840 .tuner_type = -1,
841 .tuner_addr = ADDR_UNSET,
842 .radio_addr = ADDR_UNSET,
843 },
844 [BTTV_BOARD_IPROTV] = {
845 .name = "Formac iProTV, Formac ProTV I (bt848)",
846 .video_inputs = 4,
847 .audio_inputs = 1,
848 .tuner = 0,
849 .svhs = 3,
850 .gpiomask = 1,
851 .muxsel = { 2, 3, 1, 1 },
852