]> bbs.cooldavid.org Git - net-next-2.6.git/blame - drivers/media/video/bt8xx/bttv-cards.c
V4L/DVB (5803): Bttv: add support for DViCO FusionHDTV 2
[net-next-2.6.git] / drivers / media / video / bt8xx / bttv-cards.c
CommitLineData
1da177e4 1/*
1da177e4
LT
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)
4ac97914 9 & Marcus Metzler (mocm@thp.uni-koeln.de)
1da177e4
LT
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
1da177e4
LT
28#include <linux/delay.h>
29#include <linux/module.h>
30#include <linux/moduleparam.h>
31#include <linux/kmod.h>
32#include <linux/init.h>
33#include <linux/pci.h>
34#include <linux/vmalloc.h>
35#include <linux/firmware.h>
36
37#include <asm/io.h>
38
39#include "bttvp.h"
5e453dc7 40#include <media/v4l2-common.h>
8bf2f8e7 41#include <media/tvaudio.h>
1da177e4
LT
42
43/* fwd decl */
44static void boot_msp34xx(struct bttv *btv, int pin);
45static void boot_bt832(struct bttv *btv);
46static void hauppauge_eeprom(struct bttv *btv);
47static void avermedia_eeprom(struct bttv *btv);
48static void osprey_eeprom(struct bttv *btv);
49static void modtec_eeprom(struct bttv *btv);
50static void init_PXC200(struct bttv *btv);
93b43f13 51static void init_RTV24(struct bttv *btv);
1da177e4
LT
52
53static void winview_audio(struct bttv *btv, struct video_audio *v, int set);
54static void lt9415_audio(struct bttv *btv, struct video_audio *v, int set);
55static void avermedia_tvphone_audio(struct bttv *btv, struct video_audio *v,
56 int set);
57static void avermedia_tv_stereo_audio(struct bttv *btv, struct video_audio *v,
58 int set);
59static void terratv_audio(struct bttv *btv, struct video_audio *v, int set);
60static void gvbctv3pci_audio(struct bttv *btv, struct video_audio *v, int set);
61static void gvbctv5pci_audio(struct bttv *btv, struct video_audio *v, int set);
62static void winfast2000_audio(struct bttv *btv, struct video_audio *v, int set);
63static void pvbt878p9b_audio(struct bttv *btv, struct video_audio *v, int set);
64static void fv2000s_audio(struct bttv *btv, struct video_audio *v, int set);
65static void windvr_audio(struct bttv *btv, struct video_audio *v, int set);
66static void adtvk503_audio(struct bttv *btv, struct video_audio *v, int set);
67static void rv605_muxsel(struct bttv *btv, unsigned int input);
68static void eagle_muxsel(struct bttv *btv, unsigned int input);
69static void xguard_muxsel(struct bttv *btv, unsigned int input);
70static void ivc120_muxsel(struct bttv *btv, unsigned int input);
71static void gvc1100_muxsel(struct bttv *btv, unsigned int input);
72
73static void PXC200_muxsel(struct bttv *btv, unsigned int input);
74
75static void picolo_tetra_muxsel(struct bttv *btv, unsigned int input);
76static void picolo_tetra_init(struct bttv *btv);
77
78static void tibetCS16_muxsel(struct bttv *btv, unsigned int input);
79static void tibetCS16_init(struct bttv *btv);
80
81static void kodicom4400r_muxsel(struct bttv *btv, unsigned int input);
82static void kodicom4400r_init(struct bttv *btv);
83
84static void sigmaSLC_muxsel(struct bttv *btv, unsigned int input);
85static void sigmaSQ_muxsel(struct bttv *btv, unsigned int input);
86
87static int terratec_active_radio_upgrade(struct bttv *btv);
88static int tea5757_read(struct bttv *btv);
89static int tea5757_write(struct bttv *btv, int value);
90static void identify_by_eeprom(struct bttv *btv,
91 unsigned char eeprom_data[256]);
92static int __devinit pvr_boot(struct bttv *btv);
93
94/* config variables */
a5ed425c
MCC
95static unsigned int triton1;
96static unsigned int vsfx;
1da177e4 97static unsigned int latency = UNSET;
4dcef524 98int no_overlay=-1;
1da177e4
LT
99
100static unsigned int card[BTTV_MAX] = { [ 0 ... (BTTV_MAX-1) ] = UNSET };
101static unsigned int pll[BTTV_MAX] = { [ 0 ... (BTTV_MAX-1) ] = UNSET };
102static unsigned int tuner[BTTV_MAX] = { [ 0 ... (BTTV_MAX-1) ] = UNSET };
103static unsigned int svhs[BTTV_MAX] = { [ 0 ... (BTTV_MAX-1) ] = UNSET };
104static unsigned int remote[BTTV_MAX] = { [ 0 ... (BTTV_MAX-1) ] = UNSET };
105static struct bttv *master[BTTV_MAX] = { [ 0 ... (BTTV_MAX-1) ] = NULL };
106#ifdef MODULE
107static unsigned int autoload = 1;
108#else
a5ed425c 109static unsigned int autoload;
1da177e4
LT
110#endif
111static unsigned int gpiomask = UNSET;
112static unsigned int audioall = UNSET;
113static unsigned int audiomux[5] = { [ 0 ... 4 ] = UNSET };
114
115/* insmod options */
116module_param(triton1, int, 0444);
117module_param(vsfx, int, 0444);
118module_param(no_overlay, int, 0444);
119module_param(latency, int, 0444);
120module_param(gpiomask, int, 0444);
121module_param(audioall, int, 0444);
122module_param(autoload, int, 0444);
123
124module_param_array(card, int, NULL, 0444);
125module_param_array(pll, int, NULL, 0444);
126module_param_array(tuner, int, NULL, 0444);
127module_param_array(svhs, int, NULL, 0444);
128module_param_array(remote, int, NULL, 0444);
129module_param_array(audiomux, int, NULL, 0444);
130
131MODULE_PARM_DESC(triton1,"set ETBF pci config bit "
132 "[enable bug compatibility for triton1 + others]");
133MODULE_PARM_DESC(vsfx,"set VSFX pci config bit "
134 "[yet another chipset flaw workaround]");
135MODULE_PARM_DESC(latency,"pci latency timer");
136MODULE_PARM_DESC(card,"specify TV/grabber card model, see CARDLIST file for a list");
137MODULE_PARM_DESC(pll,"specify installed crystal (0=none, 28=28 MHz, 35=35 MHz)");
138MODULE_PARM_DESC(tuner,"specify installed tuner type");
139MODULE_PARM_DESC(autoload,"automatically load i2c modules like tuner.o, default is 1 (yes)");
9050d942
MCC
140MODULE_PARM_DESC(no_overlay,"allow override overlay default (0 disables, 1 enables)"
141 " [some VIA/SIS chipsets are known to have problem with overlay]");
1da177e4
LT
142
143/* ----------------------------------------------------------------------- */
144/* list of card IDs for bt878+ cards */
145
146static struct CARD {
147 unsigned id;
148 int cardnr;
149 char *name;
150} cards[] __devinitdata = {
5a25e84b
MCC
151 { 0x13eb0070, BTTV_BOARD_HAUPPAUGE878, "Hauppauge WinTV" },
152 { 0x39000070, BTTV_BOARD_HAUPPAUGE878, "Hauppauge WinTV-D" },
153 { 0x45000070, BTTV_BOARD_HAUPPAUGEPVR, "Hauppauge WinTV/PVR" },
154 { 0xff000070, BTTV_BOARD_OSPREY1x0, "Osprey-100" },
155 { 0xff010070, BTTV_BOARD_OSPREY2x0_SVID,"Osprey-200" },
156 { 0xff020070, BTTV_BOARD_OSPREY500, "Osprey-500" },
157 { 0xff030070, BTTV_BOARD_OSPREY2000, "Osprey-2000" },
158 { 0xff040070, BTTV_BOARD_OSPREY540, "Osprey-540" },
f718e6e7 159 { 0xff070070, BTTV_BOARD_OSPREY440, "Osprey-440" },
5a25e84b
MCC
160
161 { 0x00011002, BTTV_BOARD_ATI_TVWONDER, "ATI TV Wonder" },
162 { 0x00031002, BTTV_BOARD_ATI_TVWONDERVE,"ATI TV Wonder/VE" },
163
164 { 0x6606107d, BTTV_BOARD_WINFAST2000, "Leadtek WinFast TV 2000" },
165 { 0x6607107d, BTTV_BOARD_WINFASTVC100, "Leadtek WinFast VC 100" },
166 { 0x6609107d, BTTV_BOARD_WINFAST2000, "Leadtek TV 2000 XP" },
167 { 0x263610b4, BTTV_BOARD_STB2, "STB TV PCI FM, Gateway P/N 6000704" },
168 { 0x264510b4, BTTV_BOARD_STB2, "STB TV PCI FM, Gateway P/N 6000704" },
4ac97914 169 { 0x402010fc, BTTV_BOARD_GVBCTV3PCI, "I-O Data Co. GV-BCTV3/PCI" },
5a25e84b
MCC
170 { 0x405010fc, BTTV_BOARD_GVBCTV4PCI, "I-O Data Co. GV-BCTV4/PCI" },
171 { 0x407010fc, BTTV_BOARD_GVBCTV5PCI, "I-O Data Co. GV-BCTV5/PCI" },
4ac97914 172 { 0xd01810fc, BTTV_BOARD_GVBCTV5PCI, "I-O Data Co. GV-BCTV5/PCI" },
5a25e84b
MCC
173
174 { 0x001211bd, BTTV_BOARD_PINNACLE, "Pinnacle PCTV" },
24a70fdc 175 /* some cards ship with byteswapped IDs ... */
5a25e84b
MCC
176 { 0x1200bd11, BTTV_BOARD_PINNACLE, "Pinnacle PCTV [bswap]" },
177 { 0xff00bd11, BTTV_BOARD_PINNACLE, "Pinnacle PCTV [bswap]" },
24a70fdc 178 /* this seems to happen as well ... */
5a25e84b
MCC
179 { 0xff1211bd, BTTV_BOARD_PINNACLE, "Pinnacle PCTV" },
180
434b2526
WB
181 { 0x3000121a, BTTV_BOARD_VOODOOTV_200, "3Dfx VoodooTV 200" },
182 { 0x263710b4, BTTV_BOARD_VOODOOTV_FM, "3Dfx VoodooTV FM" },
5a25e84b
MCC
183 { 0x3060121a, BTTV_BOARD_STB2, "3Dfx VoodooTV 100/ STB OEM" },
184
185 { 0x3000144f, BTTV_BOARD_MAGICTVIEW063, "(Askey Magic/others) TView99 CPH06x" },
186 { 0xa005144f, BTTV_BOARD_MAGICTVIEW063, "CPH06X TView99-Card" },
187 { 0x3002144f, BTTV_BOARD_MAGICTVIEW061, "(Askey Magic/others) TView99 CPH05x" },
188 { 0x3005144f, BTTV_BOARD_MAGICTVIEW061, "(Askey Magic/others) TView99 CPH061/06L (T1/LC)" },
189 { 0x5000144f, BTTV_BOARD_MAGICTVIEW061, "Askey CPH050" },
190 { 0x300014ff, BTTV_BOARD_MAGICTVIEW061, "TView 99 (CPH061)" },
191 { 0x300214ff, BTTV_BOARD_PHOEBE_TVMAS, "Phoebe TV Master (CPH060)" },
192
193 { 0x00011461, BTTV_BOARD_AVPHONE98, "AVerMedia TVPhone98" },
194 { 0x00021461, BTTV_BOARD_AVERMEDIA98, "AVermedia TVCapture 98" },
195 { 0x00031461, BTTV_BOARD_AVPHONE98, "AVerMedia TVPhone98" },
196 { 0x00041461, BTTV_BOARD_AVERMEDIA98, "AVerMedia TVCapture 98" },
197 { 0x03001461, BTTV_BOARD_AVERMEDIA98, "VDOMATE TV TUNER CARD" },
198
199 { 0x1117153b, BTTV_BOARD_TERRATVALUE, "Terratec TValue (Philips PAL B/G)" },
200 { 0x1118153b, BTTV_BOARD_TERRATVALUE, "Terratec TValue (Temic PAL B/G)" },
201 { 0x1119153b, BTTV_BOARD_TERRATVALUE, "Terratec TValue (Philips PAL I)" },
202 { 0x111a153b, BTTV_BOARD_TERRATVALUE, "Terratec TValue (Temic PAL I)" },
203
204 { 0x1123153b, BTTV_BOARD_TERRATVRADIO, "Terratec TV Radio+" },
205 { 0x1127153b, BTTV_BOARD_TERRATV, "Terratec TV+ (V1.05)" },
24a70fdc 206 /* clashes with FlyVideo
5a25e84b
MCC
207 *{ 0x18521852, BTTV_BOARD_TERRATV, "Terratec TV+ (V1.10)" }, */
208 { 0x1134153b, BTTV_BOARD_TERRATVALUE, "Terratec TValue (LR102)" },
209 { 0x1135153b, BTTV_BOARD_TERRATVALUER, "Terratec TValue Radio" }, /* LR102 */
210 { 0x5018153b, BTTV_BOARD_TERRATVALUE, "Terratec TValue" }, /* ?? */
211 { 0xff3b153b, BTTV_BOARD_TERRATVALUER, "Terratec TValue Radio" }, /* ?? */
212
213 { 0x400015b0, BTTV_BOARD_ZOLTRIX_GENIE, "Zoltrix Genie TV" },
214 { 0x400a15b0, BTTV_BOARD_ZOLTRIX_GENIE, "Zoltrix Genie TV" },
215 { 0x400d15b0, BTTV_BOARD_ZOLTRIX_GENIE, "Zoltrix Genie TV / Radio" },
216 { 0x401015b0, BTTV_BOARD_ZOLTRIX_GENIE, "Zoltrix Genie TV / Radio" },
217 { 0x401615b0, BTTV_BOARD_ZOLTRIX_GENIE, "Zoltrix Genie TV / Radio" },
218
219 { 0x1430aa00, BTTV_BOARD_PV143, "Provideo PV143A" },
220 { 0x1431aa00, BTTV_BOARD_PV143, "Provideo PV143B" },
221 { 0x1432aa00, BTTV_BOARD_PV143, "Provideo PV143C" },
222 { 0x1433aa00, BTTV_BOARD_PV143, "Provideo PV143D" },
223 { 0x1433aa03, BTTV_BOARD_PV143, "Security Eyes" },
224
225 { 0x1460aa00, BTTV_BOARD_PV150, "Provideo PV150A-1" },
226 { 0x1461aa01, BTTV_BOARD_PV150, "Provideo PV150A-2" },
227 { 0x1462aa02, BTTV_BOARD_PV150, "Provideo PV150A-3" },
228 { 0x1463aa03, BTTV_BOARD_PV150, "Provideo PV150A-4" },
229
230 { 0x1464aa04, BTTV_BOARD_PV150, "Provideo PV150B-1" },
231 { 0x1465aa05, BTTV_BOARD_PV150, "Provideo PV150B-2" },
232 { 0x1466aa06, BTTV_BOARD_PV150, "Provideo PV150B-3" },
233 { 0x1467aa07, BTTV_BOARD_PV150, "Provideo PV150B-4" },
234
235 { 0xa132ff00, BTTV_BOARD_IVC100, "IVC-100" },
236 { 0xa1550000, BTTV_BOARD_IVC200, "IVC-200" },
237 { 0xa1550001, BTTV_BOARD_IVC200, "IVC-200" },
238 { 0xa1550002, BTTV_BOARD_IVC200, "IVC-200" },
239 { 0xa1550003, BTTV_BOARD_IVC200, "IVC-200" },
240 { 0xa1550100, BTTV_BOARD_IVC200, "IVC-200G" },
241 { 0xa1550101, BTTV_BOARD_IVC200, "IVC-200G" },
242 { 0xa1550102, BTTV_BOARD_IVC200, "IVC-200G" },
243 { 0xa1550103, BTTV_BOARD_IVC200, "IVC-200G" },
244 { 0xa182ff00, BTTV_BOARD_IVC120, "IVC-120G" },
245 { 0xa182ff01, BTTV_BOARD_IVC120, "IVC-120G" },
246 { 0xa182ff02, BTTV_BOARD_IVC120, "IVC-120G" },
247 { 0xa182ff03, BTTV_BOARD_IVC120, "IVC-120G" },
248 { 0xa182ff04, BTTV_BOARD_IVC120, "IVC-120G" },
249 { 0xa182ff05, BTTV_BOARD_IVC120, "IVC-120G" },
250 { 0xa182ff06, BTTV_BOARD_IVC120, "IVC-120G" },
251 { 0xa182ff07, BTTV_BOARD_IVC120, "IVC-120G" },
252 { 0xa182ff08, BTTV_BOARD_IVC120, "IVC-120G" },
253 { 0xa182ff09, BTTV_BOARD_IVC120, "IVC-120G" },
254 { 0xa182ff0a, BTTV_BOARD_IVC120, "IVC-120G" },
255 { 0xa182ff0b, BTTV_BOARD_IVC120, "IVC-120G" },
256 { 0xa182ff0c, BTTV_BOARD_IVC120, "IVC-120G" },
257 { 0xa182ff0d, BTTV_BOARD_IVC120, "IVC-120G" },
258 { 0xa182ff0e, BTTV_BOARD_IVC120, "IVC-120G" },
259 { 0xa182ff0f, BTTV_BOARD_IVC120, "IVC-120G" },
260
261 { 0x41424344, BTTV_BOARD_GRANDTEC, "GrandTec Multi Capture" },
262 { 0x01020304, BTTV_BOARD_XGUARD, "Grandtec Grand X-Guard" },
263
264 { 0x18501851, BTTV_BOARD_CHRONOS_VS2, "FlyVideo 98 (LR50)/ Chronos Video Shuttle II" },
265 { 0xa0501851, BTTV_BOARD_CHRONOS_VS2, "FlyVideo 98 (LR50)/ Chronos Video Shuttle II" },
266 { 0x18511851, BTTV_BOARD_FLYVIDEO98EZ, "FlyVideo 98EZ (LR51)/ CyberMail AV" },
267 { 0x18521852, BTTV_BOARD_TYPHOON_TVIEW, "FlyVideo 98FM (LR50)/ Typhoon TView TV/FM Tuner" },
268 { 0x41a0a051, BTTV_BOARD_FLYVIDEO_98FM, "Lifeview FlyVideo 98 LR50 Rev Q" },
269 { 0x18501f7f, BTTV_BOARD_FLYVIDEO_98, "Lifeview Flyvideo 98" },
270
657de3cd 271 { 0x010115cb, BTTV_BOARD_GMV1, "AG GMV1" },
5a25e84b
MCC
272 { 0x010114c7, BTTV_BOARD_MODTEC_205, "Modular Technology MM201/MM202/MM205/MM210/MM215 PCTV" },
273
274 { 0x10b42636, BTTV_BOARD_HAUPPAUGE878, "STB ???" },
275 { 0x217d6606, BTTV_BOARD_WINFAST2000, "Leadtek WinFast TV 2000" },
276 { 0xfff6f6ff, BTTV_BOARD_WINFAST2000, "Leadtek WinFast TV 2000" },
277 { 0x03116000, BTTV_BOARD_SENSORAY311, "Sensoray 311" },
278 { 0x00790e11, BTTV_BOARD_WINDVR, "Canopus WinDVR PCI" },
279 { 0xa0fca1a0, BTTV_BOARD_ZOLTRIX, "Face to Face Tvmax" },
5a25e84b
MCC
280 { 0x82b2aa6a, BTTV_BOARD_SIMUS_GVC1100, "SIMUS GVC1100" },
281 { 0x146caa0c, BTTV_BOARD_PV951, "ituner spectra8" },
4ac97914 282 { 0x200a1295, BTTV_BOARD_PXC200, "ImageNation PXC200A" },
5a25e84b
MCC
283
284 { 0x40111554, BTTV_BOARD_PV_BT878P_9B, "Prolink Pixelview PV-BT" },
285 { 0x17de0a01, BTTV_BOARD_KWORLD, "Mecer TV/FM/Video Tuner" },
286
287 { 0x01051805, BTTV_BOARD_PICOLO_TETRA_CHIP, "Picolo Tetra Chip #1" },
288 { 0x01061805, BTTV_BOARD_PICOLO_TETRA_CHIP, "Picolo Tetra Chip #2" },
289 { 0x01071805, BTTV_BOARD_PICOLO_TETRA_CHIP, "Picolo Tetra Chip #3" },
290 { 0x01081805, BTTV_BOARD_PICOLO_TETRA_CHIP, "Picolo Tetra Chip #4" },
291
292 { 0x15409511, BTTV_BOARD_ACORP_Y878F, "Acorp Y878F" },
1da177e4 293
1ebba670
SA
294 { 0x53534149, BTTV_BOARD_SSAI_SECURITY, "SSAI Security Video Interface" },
295 { 0x5353414a, BTTV_BOARD_SSAI_ULTRASOUND, "SSAI Ultrasound Video Interface" },
296
24a70fdc 297 /* likely broken, vendor id doesn't match the other magic views ...
5a25e84b 298 * { 0xa0fca04f, BTTV_BOARD_MAGICTVIEW063, "Guillemot Maxi TV Video 3" }, */
24a70fdc 299
cd1257d8
ST
300 /* Duplicate PCI ID, reconfigure for this board during the eeprom read.
301 * { 0x13eb0070, BTTV_BOARD_HAUPPAUGE_IMPACTVCB, "Hauppauge ImpactVCB" }, */
302
24a70fdc 303 /* DVB cards (using pci function .1 for mpeg data xfer) */
5a25e84b 304 { 0x001c11bd, BTTV_BOARD_PINNACLESAT, "Pinnacle PCTV Sat" },
2af35577
MK
305 { 0x01010071, BTTV_BOARD_NEBULA_DIGITV, "Nebula Electronics DigiTV" },
306 { 0x20007063, BTTV_BOARD_PC_HDTV, "pcHDTV HD-2000 TV"},
5a25e84b
MCC
307 { 0x002611bd, BTTV_BOARD_TWINHAN_DST, "Pinnacle PCTV SAT CI" },
308 { 0x00011822, BTTV_BOARD_TWINHAN_DST, "Twinhan VisionPlus DVB" },
309 { 0xfc00270f, BTTV_BOARD_TWINHAN_DST, "ChainTech digitop DST-1000 DVB-S" },
310 { 0x07711461, BTTV_BOARD_AVDVBT_771, "AVermedia AverTV DVB-T 771" },
2af35577 311 { 0x07611461, BTTV_BOARD_AVDVBT_761, "AverMedia AverTV DVB-T 761" },
5a25e84b 312 { 0xdb1018ac, BTTV_BOARD_DVICO_DVBT_LITE, "DViCO FusionHDTV DVB-T Lite" },
19790db0 313 { 0xdb1118ac, BTTV_BOARD_DVICO_DVBT_LITE, "Ultraview DVB-T Lite" },
5a25e84b 314 { 0xd50018ac, BTTV_BOARD_DVICO_FUSIONHDTV_5_LITE, "DViCO FusionHDTV 5 Lite" },
442d15d5 315 { 0x00261822, BTTV_BOARD_TWINHAN_DST, "DNTV Live! Mini "},
27cb786f 316 { 0xd200dbc0, BTTV_BOARD_DVICO_FUSIONHDTV_2, "DViCO FusionHDTV 2" },
1da177e4
LT
317
318 { 0, -1, NULL }
319};
320
321/* ----------------------------------------------------------------------- */
322/* array with description for bt848 / bt878 tv/grabber cards */
323
324struct tvcard bttv_tvcards[] = {
2bfa1ac6 325 /* ---- card 0x00 ---------------------------------- */
5a25e84b 326 [BTTV_BOARD_UNKNOWN] = {
2bfa1ac6
MCC
327 .name = " *** UNKNOWN/GENERIC *** ",
328 .video_inputs = 4,
329 .audio_inputs = 1,
330 .tuner = 0,
331 .svhs = 2,
bc28636a 332 .muxsel = { 2, 3, 1, 0 },
2bfa1ac6
MCC
333 .tuner_type = -1,
334 .tuner_addr = ADDR_UNSET,
10c2c8b1 335 .radio_addr = ADDR_UNSET,
2bfa1ac6 336 },
5a25e84b 337 [BTTV_BOARD_MIRO] = {
2bfa1ac6
MCC
338 .name = "MIRO PCTV",
339 .video_inputs = 4,
340 .audio_inputs = 1,
341 .tuner = 0,
342 .svhs = 2,
343 .gpiomask = 15,
bc28636a 344 .muxsel = { 2, 3, 1, 1 },
8bf2f8e7
HV
345 .gpiomux = { 2, 0, 0, 0 },
346 .gpiomute = 10,
2bfa1ac6
MCC
347 .needs_tvaudio = 1,
348 .tuner_type = -1,
349 .tuner_addr = ADDR_UNSET,
10c2c8b1 350 .radio_addr = ADDR_UNSET,
2bfa1ac6 351 },
5a25e84b 352 [BTTV_BOARD_HAUPPAUGE] = {
2bfa1ac6
MCC
353 .name = "Hauppauge (bt848)",
354 .video_inputs = 4,
355 .audio_inputs = 1,
356 .tuner = 0,
357 .svhs = 2,
358 .gpiomask = 7,
bc28636a 359 .muxsel = { 2, 3, 1, 1 },
8bf2f8e7
HV
360 .gpiomux = { 0, 1, 2, 3 },
361 .gpiomute = 4,
2bfa1ac6
MCC
362 .needs_tvaudio = 1,
363 .tuner_type = -1,
364 .tuner_addr = ADDR_UNSET,
10c2c8b1 365 .radio_addr = ADDR_UNSET,
2bfa1ac6 366 },
5a25e84b 367 [BTTV_BOARD_STB] = {
2bfa1ac6
MCC
368 .name = "STB, Gateway P/N 6000699 (bt848)",
369 .video_inputs = 3,
370 .audio_inputs = 1,
371 .tuner = 0,
372 .svhs = 2,
373 .gpiomask = 7,
bc28636a 374 .muxsel = { 2, 3, 1, 1 },
8bf2f8e7
HV
375 .gpiomux = { 4, 0, 2, 3 },
376 .gpiomute = 1,
2bfa1ac6
MCC
377 .no_msp34xx = 1,
378 .needs_tvaudio = 1,
379 .tuner_type = TUNER_PHILIPS_NTSC,
380 .tuner_addr = ADDR_UNSET,
10c2c8b1 381 .radio_addr = ADDR_UNSET,
2bfa1ac6
MCC
382 .pll = PLL_28,
383 .has_radio = 1,
384 },
385
386 /* ---- card 0x04 ---------------------------------- */
5a25e84b 387 [BTTV_BOARD_INTEL] = {
2bfa1ac6
MCC
388 .name = "Intel Create and Share PCI/ Smart Video Recorder III",
389 .video_inputs = 4,
390 .audio_inputs = 0,
391 .tuner = -1,
392 .svhs = 2,
393 .gpiomask = 0,
bc28636a 394 .muxsel = { 2, 3, 1, 1 },
8bf2f8e7 395 .gpiomux = { 0 },
2bfa1ac6
MCC
396 .needs_tvaudio = 0,
397 .tuner_type = 4,
398 .tuner_addr = ADDR_UNSET,
10c2c8b1 399 .radio_addr = ADDR_UNSET,
2bfa1ac6 400 },
5a25e84b 401 [BTTV_BOARD_DIAMOND] = {
2bfa1ac6
MCC
402 .name = "Diamond DTV2000",
403 .video_inputs = 4,
404 .audio_inputs = 1,
405 .tuner = 0,
406 .svhs = 2,
407 .gpiomask = 3,
bc28636a 408 .muxsel = { 2, 3, 1, 0 },
8bf2f8e7
HV
409 .gpiomux = { 0, 1, 0, 1 },
410 .gpiomute = 3,
2bfa1ac6
MCC
411 .needs_tvaudio = 1,
412 .tuner_type = -1,
413 .tuner_addr = ADDR_UNSET,
10c2c8b1 414 .radio_addr = ADDR_UNSET,
2bfa1ac6 415 },
5a25e84b 416 [BTTV_BOARD_AVERMEDIA] = {
2bfa1ac6
MCC
417 .name = "AVerMedia TVPhone",
418 .video_inputs = 3,
419 .audio_inputs = 1,
420 .tuner = 0,
421 .svhs = 3,
bc28636a 422 .muxsel = { 2, 3, 1, 1 },
2bfa1ac6 423 .gpiomask = 0x0f,
8bf2f8e7 424 .gpiomux = { 0x0c, 0x04, 0x08, 0x04 },
2bfa1ac6
MCC
425 /* 0x04 for some cards ?? */
426 .needs_tvaudio = 1,
427 .tuner_type = -1,
428 .tuner_addr = ADDR_UNSET,
10c2c8b1 429 .radio_addr = ADDR_UNSET,
2bfa1ac6
MCC
430 .audio_hook = avermedia_tvphone_audio,
431 .has_remote = 1,
432 },
5a25e84b 433 [BTTV_BOARD_MATRIX_VISION] = {
2bfa1ac6
MCC
434 .name = "MATRIX-Vision MV-Delta",
435 .video_inputs = 5,
436 .audio_inputs = 1,
437 .tuner = -1,
438 .svhs = 3,
439 .gpiomask = 0,
bc28636a 440 .muxsel = { 2, 3, 1, 0, 0 },
8bf2f8e7 441 .gpiomux = { 0 },
2bfa1ac6
MCC
442 .needs_tvaudio = 1,
443 .tuner_type = -1,
444 .tuner_addr = ADDR_UNSET,
10c2c8b1 445 .radio_addr = ADDR_UNSET,
2bfa1ac6
MCC
446 },
447
448 /* ---- card 0x08 ---------------------------------- */
5a25e84b 449 [BTTV_BOARD_FLYVIDEO] = {
2bfa1ac6
MCC
450 .name = "Lifeview FlyVideo II (Bt848) LR26 / MAXI TV Video PCI2 LR26",
451 .video_inputs = 4,
452 .audio_inputs = 1,
453 .tuner = 0,
454 .svhs = 2,
455 .gpiomask = 0xc00,
bc28636a 456 .muxsel = { 2, 3, 1, 1 },
8bf2f8e7
HV
457 .gpiomux = { 0, 0xc00, 0x800, 0x400 },
458 .gpiomute = 0xc00,
2bfa1ac6
MCC
459 .needs_tvaudio = 1,
460 .pll = PLL_28,
461 .tuner_type = -1,
462 .tuner_addr = ADDR_UNSET,
10c2c8b1 463 .radio_addr = ADDR_UNSET,
2bfa1ac6 464 },
5a25e84b 465 [BTTV_BOARD_TURBOTV] = {
2bfa1ac6
MCC
466 .name = "IMS/IXmicro TurboTV",
467 .video_inputs = 3,
468 .audio_inputs = 1,
469 .tuner = 0,
470 .svhs = 2,
471 .gpiomask = 3,
bc28636a 472 .muxsel = { 2, 3, 1, 1 },
8bf2f8e7 473 .gpiomux = { 1, 1, 2, 3 },
2bfa1ac6
MCC
474 .needs_tvaudio = 0,
475 .pll = PLL_28,
476 .tuner_type = TUNER_TEMIC_PAL,
477 .tuner_addr = ADDR_UNSET,
10c2c8b1 478 .radio_addr = ADDR_UNSET,
2bfa1ac6 479 },
5a25e84b 480 [BTTV_BOARD_HAUPPAUGE878] = {
2bfa1ac6
MCC
481 .name = "Hauppauge (bt878)",
482 .video_inputs = 4,
483 .audio_inputs = 1,
484 .tuner = 0,
485 .svhs = 2,
486 .gpiomask = 0x0f, /* old: 7 */
bc28636a 487 .muxsel = { 2, 0, 1, 1 },
8bf2f8e7
HV
488 .gpiomux = { 0, 1, 2, 3 },
489 .gpiomute = 4,
2bfa1ac6
MCC
490 .needs_tvaudio = 1,
491 .pll = PLL_28,
492 .tuner_type = -1,
493 .tuner_addr = ADDR_UNSET,
10c2c8b1 494 .radio_addr = ADDR_UNSET,
2bfa1ac6 495 },
5a25e84b 496 [BTTV_BOARD_MIROPRO] = {
2bfa1ac6
MCC
497 .name = "MIRO PCTV pro",
498 .video_inputs = 3,
499 .audio_inputs = 1,
500 .tuner = 0,
501 .svhs = 2,
502 .gpiomask = 0x3014f,
bc28636a 503 .muxsel = { 2, 3, 1, 1 },
8bf2f8e7
HV
504 .gpiomux = { 0x20001,0x10001, 0, 0 },
505 .gpiomute = 10,
2bfa1ac6
MCC
506 .needs_tvaudio = 1,
507 .tuner_type = -1,
508 .tuner_addr = ADDR_UNSET,
10c2c8b1 509 .radio_addr = ADDR_UNSET,
2bfa1ac6
MCC
510 },
511
512 /* ---- card 0x0c ---------------------------------- */
5a25e84b 513 [BTTV_BOARD_ADSTECH_TV] = {
2bfa1ac6
MCC
514 .name = "ADS Technologies Channel Surfer TV (bt848)",
515 .video_inputs = 3,
516 .audio_inputs = 1,
517 .tuner = 0,
518 .svhs = 2,
519 .gpiomask = 15,
bc28636a 520 .muxsel = { 2, 3, 1, 1 },
8bf2f8e7 521 .gpiomux = { 13, 14, 11, 7 },
2bfa1ac6
MCC
522 .needs_tvaudio = 1,
523 .tuner_type = -1,
524 .tuner_addr = ADDR_UNSET,
10c2c8b1 525 .radio_addr = ADDR_UNSET,
2bfa1ac6 526 },
5a25e84b 527 [BTTV_BOARD_AVERMEDIA98] = {
2bfa1ac6
MCC
528 .name = "AVerMedia TVCapture 98",
529 .video_inputs = 3,
530 .audio_inputs = 4,
531 .tuner = 0,
532 .svhs = 2,
533 .gpiomask = 15,
bc28636a 534 .muxsel = { 2, 3, 1, 1 },
8bf2f8e7 535 .gpiomux = { 13, 14, 11, 7 },
2bfa1ac6
MCC
536 .needs_tvaudio = 1,
537 .msp34xx_alt = 1,
538 .pll = PLL_28,
539 .tuner_type = TUNER_PHILIPS_PAL,
540 .tuner_addr = ADDR_UNSET,
10c2c8b1 541 .radio_addr = ADDR_UNSET,
2bfa1ac6 542 .audio_hook = avermedia_tv_stereo_audio,
a8900fc2 543 .no_gpioirq = 1,
2bfa1ac6 544 },
5a25e84b 545 [BTTV_BOARD_VHX] = {
2bfa1ac6
MCC
546 .name = "Aimslab Video Highway Xtreme (VHX)",
547 .video_inputs = 3,
548 .audio_inputs = 1,
549 .tuner = 0,
550 .svhs = 2,
551 .gpiomask = 7,
bc28636a 552 .muxsel = { 2, 3, 1, 1 },
8bf2f8e7
HV
553 .gpiomux = { 0, 2, 1, 3 }, /* old: {0, 1, 2, 3, 4} */
554 .gpiomute = 4,
2bfa1ac6
MCC
555 .needs_tvaudio = 1,
556 .pll = PLL_28,
557 .tuner_type = -1,
558 .tuner_addr = ADDR_UNSET,
10c2c8b1 559 .radio_addr = ADDR_UNSET,
2bfa1ac6 560 },
5a25e84b 561 [BTTV_BOARD_ZOLTRIX] = {
2bfa1ac6
MCC
562 .name = "Zoltrix TV-Max",
563 .video_inputs = 3,
564 .audio_inputs = 1,
565 .tuner = 0,
566 .svhs = 2,
567 .gpiomask = 15,
bc28636a 568 .muxsel = { 2, 3, 1, 1 },
8bf2f8e7
HV
569 .gpiomux = { 0, 0, 1, 0 },
570 .gpiomute = 10,
2bfa1ac6
MCC
571 .needs_tvaudio = 1,
572 .tuner_type = -1,
573 .tuner_addr = ADDR_UNSET,
10c2c8b1 574 .radio_addr = ADDR_UNSET,
2bfa1ac6
MCC
575 },
576
577 /* ---- card 0x10 ---------------------------------- */
5a25e84b 578 [BTTV_BOARD_PIXVIEWPLAYTV] = {
2bfa1ac6
MCC
579 .name = "Prolink Pixelview PlayTV (bt878)",
580 .video_inputs = 3,
581 .audio_inputs = 1,
582 .tuner = 0,
583 .svhs = 2,
584 .gpiomask = 0x01fe00,
bc28636a 585 .muxsel = { 2, 3, 1, 1 },
2bfa1ac6 586 /* 2003-10-20 by "Anton A. Arapov" <arapov@mail.ru> */
8bf2f8e7
HV
587 .gpiomux = { 0x001e00, 0, 0x018000, 0x014000 },
588 .gpiomute = 0x002000,
2bfa1ac6
MCC
589 .needs_tvaudio = 1,
590 .pll = PLL_28,
591 .tuner_type = -1,
592 },
5a25e84b 593 [BTTV_BOARD_WINVIEW_601] = {
2bfa1ac6
MCC
594 .name = "Leadtek WinView 601",
595 .video_inputs = 3,
596 .audio_inputs = 1,
597 .tuner = 0,
598 .svhs = 2,
599 .gpiomask = 0x8300f8,
bc28636a 600 .muxsel = { 2, 3, 1, 1,0 },
8bf2f8e7
HV
601 .gpiomux = { 0x4fa007,0xcfa007,0xcfa007,0xcfa007 },
602 .gpiomute = 0xcfa007,
2bfa1ac6
MCC
603 .needs_tvaudio = 1,
604 .tuner_type = -1,
605 .tuner_addr = ADDR_UNSET,
10c2c8b1 606 .radio_addr = ADDR_UNSET,
2bfa1ac6
MCC
607 .audio_hook = winview_audio,
608 .has_radio = 1,
609 },
5a25e84b 610 [BTTV_BOARD_AVEC_INTERCAP] = {
2bfa1ac6
MCC
611 .name = "AVEC Intercapture",
612 .video_inputs = 3,
613 .audio_inputs = 2,
614 .tuner = 0,
615 .svhs = 2,
616 .gpiomask = 0,
bc28636a 617 .muxsel = { 2, 3, 1, 1 },
8bf2f8e7 618 .gpiomux = { 1, 0, 0, 0 },
2bfa1ac6
MCC
619 .needs_tvaudio = 1,
620 .tuner_type = -1,
621 .tuner_addr = ADDR_UNSET,
10c2c8b1 622 .radio_addr = ADDR_UNSET,
2bfa1ac6 623 },
5a25e84b 624 [BTTV_BOARD_LIFE_FLYKIT] = {
2bfa1ac6
MCC
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,
bc28636a 631 .muxsel = { 2, 3, 1, 1 },
8bf2f8e7 632 .gpiomux = { 0 },
2bfa1ac6
MCC
633 .no_msp34xx = 1,
634 .tuner_type = -1,
635 .tuner_addr = ADDR_UNSET,
10c2c8b1 636 .radio_addr = ADDR_UNSET,
2bfa1ac6
MCC
637 },
638
639 /* ---- card 0x14 ---------------------------------- */
5a25e84b 640 [BTTV_BOARD_CEI_RAFFLES] = {
2bfa1ac6
MCC
641 .name = "CEI Raffles Card",
642 .video_inputs = 3,
643 .audio_inputs = 3,
644 .tuner = 0,
645 .svhs = 2,
bc28636a 646 .muxsel = { 2, 3, 1, 1 },
2bfa1ac6
MCC
647 .tuner_type = -1,
648 .tuner_addr = ADDR_UNSET,
10c2c8b1 649 .radio_addr = ADDR_UNSET,
2bfa1ac6 650 },
5a25e84b 651 [BTTV_BOARD_CONFERENCETV] = {
2bfa1ac6
MCC
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,
bc28636a 658 .muxsel = { 2, 3, 1, 1 },
8bf2f8e7
HV
659 .gpiomux = { 0, 0x800, 0x1000, 0x1000 },
660 .gpiomute = 0x1800,
2bfa1ac6
MCC
661 .pll = PLL_28,
662 .tuner_type = TUNER_PHILIPS_PAL_I,
663 .tuner_addr = ADDR_UNSET,
10c2c8b1 664 .radio_addr = ADDR_UNSET,
2bfa1ac6 665 },
5a25e84b 666 [BTTV_BOARD_PHOEBE_TVMAS] = {
2bfa1ac6
MCC
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,
bc28636a 673 .muxsel = { 2, 3, 1, 1 },
8bf2f8e7
HV
674 .gpiomux = { 0, 1, 0x800, 0x400 },
675 .gpiomute = 0xc00,
2bfa1ac6
MCC
676 .needs_tvaudio = 1,
677 .pll = PLL_28,
678 .tuner_type = -1,
679 .tuner_addr = ADDR_UNSET,
10c2c8b1 680 .radio_addr = ADDR_UNSET,
2bfa1ac6 681 },
5a25e84b 682 [BTTV_BOARD_MODTEC_205] = {
2bfa1ac6
MCC
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,
8bf2f8e7 691 .gpiomux = { 0, 0, 0, 0 },
2bfa1ac6
MCC
692 .no_msp34xx = 1,
693 .pll = PLL_28,
694 .tuner_type = TUNER_ALPS_TSBB5_PAL_I,
695 .tuner_addr = ADDR_UNSET,
10c2c8b1 696 .radio_addr = ADDR_UNSET,
2bfa1ac6
MCC
697 },
698
699 /* ---- card 0x18 ---------------------------------- */
5a25e84b 700 [BTTV_BOARD_MAGICTVIEW061] = {
2bfa1ac6
MCC
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,
bc28636a 707 .muxsel = { 2, 3, 1, 1 },
8bf2f8e7
HV
708 .gpiomux = {0x400, 0x400, 0x400, 0x400 },
709 .gpiomute = 0xc00,
2bfa1ac6
MCC
710 .needs_tvaudio = 1,
711 .pll = PLL_28,
712 .tuner_type = -1,
713 .tuner_addr = ADDR_UNSET,
10c2c8b1 714 .radio_addr = ADDR_UNSET,
2bfa1ac6
MCC
715 .has_remote = 1,
716 },
5a25e84b 717 [BTTV_BOARD_VOBIS_BOOSTAR] = {
2bfa1ac6
MCC
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,
bc28636a 724 .muxsel = { 2, 3, 1, 1 },
8bf2f8e7
HV
725 .gpiomux = { 0x20000, 0x30000, 0x10000, 0 },
726 .gpiomute = 0x40000,
2bfa1ac6
MCC
727 .needs_tvaudio = 0,
728 .tuner_type = TUNER_PHILIPS_PAL,
729 .tuner_addr = ADDR_UNSET,
10c2c8b1 730 .radio_addr = ADDR_UNSET,
2bfa1ac6
MCC
731 .audio_hook = terratv_audio,
732 },
5a25e84b 733 [BTTV_BOARD_HAUPPAUG_WCAM] = {
2bfa1ac6
MCC
734 .name = "Hauppauge WinCam newer (bt878)",
735 .video_inputs = 4,
736 .audio_inputs = 1,
737 .tuner = 0,
738 .svhs = 3,
739 .gpiomask = 7,
bc28636a 740 .muxsel = { 2, 0, 1, 1 },
8bf2f8e7
HV
741 .gpiomux = { 0, 1, 2, 3 },
742 .gpiomute = 4,
2bfa1ac6
MCC
743 .needs_tvaudio = 1,
744 .tuner_type = -1,
745 .tuner_addr = ADDR_UNSET,
10c2c8b1 746 .radio_addr = ADDR_UNSET,
2bfa1ac6 747 },
5a25e84b 748 [BTTV_BOARD_MAXI] = {
2bfa1ac6
MCC
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,
bc28636a 755 .muxsel = { 2, 3, 1, 1 },
8bf2f8e7
HV
756 .gpiomux = { 0, 0x800, 0x1000, 0x1000 },
757 .gpiomute = 0x1800,
2bfa1ac6
MCC
758 .pll = PLL_28,
759 .tuner_type = TUNER_PHILIPS_SECAM,
760 .tuner_addr = ADDR_UNSET,
10c2c8b1 761 .radio_addr = ADDR_UNSET,
2bfa1ac6
MCC
762 },
763
764 /* ---- card 0x1c ---------------------------------- */
5a25e84b 765 [BTTV_BOARD_TERRATV] = {
2bfa1ac6
MCC
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,
bc28636a 772 .muxsel = { 2, 3, 1, 1 },
8bf2f8e7
HV
773 .gpiomux = { 0x20000, 0x30000, 0x10000, 0x00000 },
774 .gpiomute = 0x40000,
2bfa1ac6
MCC
775 .needs_tvaudio = 0,
776 .tuner_type = TUNER_PHILIPS_PAL,
777 .tuner_addr = ADDR_UNSET,
10c2c8b1 778 .radio_addr = ADDR_UNSET,
2bfa1ac6
MCC
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
24a70fdc 809 */
2bfa1ac6
MCC
810
811 },
5a25e84b 812 [BTTV_BOARD_PXC200] = {
2bfa1ac6
MCC
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},
8bf2f8e7 821 .gpiomux = { 0 },
2bfa1ac6
MCC
822 .needs_tvaudio = 1,
823 .tuner_type = -1,
824 .tuner_addr = ADDR_UNSET,
10c2c8b1 825 .radio_addr = ADDR_UNSET,
2bfa1ac6
MCC
826 .muxsel_hook = PXC200_muxsel,
827
828 },
5a25e84b 829 [BTTV_BOARD_FLYVIDEO_98] = {
2bfa1ac6
MCC
830 .name = "Lifeview FlyVideo 98 LR50",
831 .video_inputs = 4,
832 .audio_inputs = 1,
833 .tuner = 0,
834 .svhs = 2,
835 .gpiomask = 0x1800, /* 0x8dfe00 */
bc28636a 836 .muxsel = { 2, 3, 1, 1 },
8bf2f8e7
HV
837 .gpiomux = { 0, 0x0800, 0x1000, 0x1000 },
838 .gpiomute = 0x1800,
2bfa1ac6
MCC
839 .pll = PLL_28,
840 .tuner_type = -1,
841 .tuner_addr = ADDR_UNSET,
10c2c8b1 842 .radio_addr = ADDR_UNSET,
2bfa1ac6 843 },
5a25e84b 844 [BTTV_BOARD_IPROTV] = {
2bfa1ac6
MCC
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,
bc28636a 851 .muxsel = { 2, 3, 1, 1 },
8bf2f8e7 852 .gpiomux = { 1, 0, 0, 0 },
2bfa1ac6
MCC
853 .pll = PLL_28,
854 .tuner_type = TUNER_PHILIPS_PAL,
855 .tuner_addr = ADDR_UNSET,
10c2c8b1 856 .radio_addr = ADDR_UNSET,
2bfa1ac6
MCC
857 },
858
859 /* ---- card 0x20 ---------------------------------- */
5a25e84b 860 [BTTV_BOARD_INTEL_C_S_PCI] = {
2bfa1ac6
MCC
861 .name = "Intel Create and Share PCI/ Smart Video Recorder III",
862 .video_inputs = 4,
863 .audio_inputs = 0,
864 .tuner = -1,
865 .svhs = 2,
866 .gpiomask = 0,
bc28636a 867 .muxsel = { 2, 3, 1, 1 },
8bf2f8e7 868 .gpiomux = { 0 },
2bfa1ac6
MCC
869 .needs_tvaudio = 0,
870 .tuner_type = 4,
871 .tuner_addr = ADDR_UNSET,
10c2c8b1 872 .radio_addr = ADDR_UNSET,
2bfa1ac6 873 },
5a25e84b 874 [BTTV_BOARD_TERRATVALUE] = {
2bfa1ac6
MCC
875 .name = "Terratec TerraTValue Version Bt878",
876 .video_inputs = 3,
877 .audio_inputs = 1,
878 .tuner = 0,
879 .svhs = 2,
880 .gpiomask = 0xffff00,
bc28636a 881 .muxsel = { 2, 3, 1, 1 },
8bf2f8e7
HV
882 .gpiomux = { 0x500, 0, 0x300, 0x900 },
883 .gpiomute = 0x900,
2bfa1ac6
MCC
884 .needs_tvaudio = 1,
885 .pll = PLL_28,
886 .tuner_type = TUNER_PHILIPS_PAL,
887 .tuner_addr = ADDR_UNSET,
10c2c8b1 888 .radio_addr = ADDR_UNSET,
2bfa1ac6 889 },
5a25e84b 890 [BTTV_BOARD_WINFAST2000] = {
2bfa1ac6
MCC
891 .name = "Leadtek WinFast 2000/ WinFast 2000 XP",
892 .video_inputs = 4,
893 .audio_inputs = 1,
894 .tuner = 0,
895 .svhs = 2,
bc28636a 896 .muxsel = { 2, 3, 1, 1, 0 }, /* TV, CVid, SVid, CVid over SVid connector */
2bfa1ac6
MCC
897 /* Alexander Varakin <avarakin@hotmail.com> [stereo version] */
898 .gpiomask = 0xb33000,
8bf2f8e7
HV
899 .gpiomux = { 0x122000,0x1000,0x0000,0x620000 },
900 .gpiomute = 0x800000,
2bfa1ac6
MCC
901 /* Audio Routing for "WinFast 2000 XP" (no tv stereo !)
902 gpio23 -- hef4052:nEnable (0x800000)
903 gpio12 -- hef4052:A1
904 gpio13 -- hef4052:A0
905 0x0000: external audio
906 0x1000: FM
907 0x2000: TV
908 0x3000: n.c.
909 Note: There exists another variant "Winfast 2000" with tv stereo !?
910 Note: eeprom only contains FF and pci subsystem id 107d:6606
911 */
912 .needs_tvaudio = 0,
913 .pll = PLL_28,
914 .has_radio = 1,
915 .tuner_type = 5, /* default for now, gpio reads BFFF06 for Pal bg+dk */
916 .tuner_addr = ADDR_UNSET,
10c2c8b1 917 .radio_addr = ADDR_UNSET,
2bfa1ac6
MCC
918 .audio_hook = winfast2000_audio,
919 .has_remote = 1,
920 },
5a25e84b 921 [BTTV_BOARD_CHRONOS_VS2] = {
2bfa1ac6
MCC
922 .name = "Lifeview FlyVideo 98 LR50 / Chronos Video Shuttle II",
923 .video_inputs = 4,
924 .audio_inputs = 3,
925 .tuner = 0,
926 .svhs = 2,
927 .gpiomask = 0x1800,
bc28636a 928 .muxsel = { 2, 3, 1, 1 },
8bf2f8e7
HV
929 .gpiomux = { 0, 0x800, 0x1000, 0x1000 },
930 .gpiomute = 0x1800,
2bfa1ac6
MCC
931 .pll = PLL_28,
932 .tuner_type = -1,
933 .tuner_addr = ADDR_UNSET,
10c2c8b1 934 .radio_addr = ADDR_UNSET,
2bfa1ac6
MCC
935 },
936
937 /* ---- card 0x24 ---------------------------------- */
5a25e84b 938 [BTTV_BOARD_TYPHOON_TVIEW] = {
2bfa1ac6
MCC
939 .name = "Lifeview FlyVideo 98FM LR50 / Typhoon TView TV/FM Tuner",
940 .video_inputs = 4,
941 .audio_inputs = 3,
942 .tuner = 0,
943 .svhs = 2,
944 .gpiomask = 0x1800,
bc28636a 945 .muxsel = { 2, 3, 1, 1 },
8bf2f8e7
HV
946 .gpiomux = { 0, 0x800, 0x1000, 0x1000 },
947 .gpiomute = 0x1800,
2bfa1ac6
MCC
948 .pll = PLL_28,
949 .tuner_type = -1,
950 .tuner_addr = ADDR_UNSET,
10c2c8b1 951 .radio_addr = ADDR_UNSET,
2bfa1ac6
MCC
952 .has_radio = 1,
953 },
5a25e84b 954 [BTTV_BOARD_PXELVWPLTVPRO] = {
2bfa1ac6
MCC
955 .name = "Prolink PixelView PlayTV pro",
956 .video_inputs = 3,
957 .audio_inputs = 1,
958 .tuner = 0,
959 .svhs = 2,
960 .gpiomask = 0xff,
961 .muxsel = { 2, 3, 1, 1 },
8bf2f8e7
HV
962 .gpiomux = { 0x21, 0x20, 0x24, 0x2c },
963 .gpiomute = 0x29,
2bfa1ac6
MCC
964 .no_msp34xx = 1,
965 .pll = PLL_28,
966 .tuner_type = -1,
967 .tuner_addr = ADDR_UNSET,
10c2c8b1 968 .radio_addr = ADDR_UNSET,
2bfa1ac6 969 },
5a25e84b 970 [BTTV_BOARD_MAGICTVIEW063] = {
2bfa1ac6
MCC
971 .name = "Askey CPH06X TView99",
972 .video_inputs = 4,
973 .audio_inputs = 1,
974 .tuner = 0,
975 .svhs = 2,
976 .gpiomask = 0x551e00,
bc28636a 977 .muxsel = { 2, 3, 1, 0 },
8bf2f8e7
HV
978 .gpiomux = { 0x551400, 0x551200, 0, 0 },
979 .gpiomute = 0x551c00,
2bfa1ac6
MCC
980 .needs_tvaudio = 1,
981 .pll = PLL_28,
982 .tuner_type = 1,
983 .tuner_addr = ADDR_UNSET,
10c2c8b1 984 .radio_addr = ADDR_UNSET,
2bfa1ac6
MCC
985 .has_remote = 1,
986 },
5a25e84b 987 [BTTV_BOARD_PINNACLE] = {
2bfa1ac6
MCC
988 .name = "Pinnacle PCTV Studio/Rave",
989 .video_inputs = 3,
990 .audio_inputs = 1,
991 .tuner = 0,
992 .svhs = 2,
993 .gpiomask = 0x03000F,
bc28636a 994 .muxsel = { 2, 3, 1, 1 },
8bf2f8e7
HV
995 .gpiomux = { 2, 0xd0001, 0, 0 },
996 .gpiomute = 1,
2bfa1ac6
MCC
997 .needs_tvaudio = 0,
998 .pll = PLL_28,
999 .tuner_type = -1,
1000 .tuner_addr = ADDR_UNSET,
10c2c8b1 1001 .radio_addr = ADDR_UNSET,
2bfa1ac6
MCC
1002 },
1003
1004 /* ---- card 0x28 ---------------------------------- */
5a25e84b 1005 [BTTV_BOARD_STB2] = {
2bfa1ac6
MCC
1006 .name = "STB TV PCI FM, Gateway P/N 6000704 (bt878), 3Dfx VoodooTV 100",
1007 .video_inputs = 3,
1008 .audio_inputs = 1,
1009 .tuner = 0,
1010 .svhs = 2,
1011 .gpiomask = 7,
bc28636a 1012 .muxsel = { 2, 3, 1, 1 },
8bf2f8e7
HV
1013 .gpiomux = { 4, 0, 2, 3 },
1014 .gpiomute = 1,
2bfa1ac6
MCC
1015 .no_msp34xx = 1,
1016 .needs_tvaudio = 1,
1017 .tuner_type = TUNER_PHILIPS_NTSC,
1018 .tuner_addr = ADDR_UNSET,
10c2c8b1 1019 .radio_addr = ADDR_UNSET,
2bfa1ac6
MCC
1020 .pll = PLL_28,
1021 .has_radio = 1,
1022 },
5a25e84b 1023 [BTTV_BOARD_AVPHONE98] = {
2bfa1ac6
MCC
1024 .name = "AVerMedia TVPhone 98",
1025 .video_inputs = 3,
1026 .audio_inputs = 4,
1027 .tuner = 0,
1028 .svhs = 2,
1029 .gpiomask = 15,
bc28636a 1030 .muxsel = { 2, 3, 1, 1 },
8bf2f8e7 1031 .gpiomux = { 13, 4, 11, 7 },
2bfa1ac6
MCC
1032 .needs_tvaudio = 1,
1033 .pll = PLL_28,
1034 .tuner_type = -1,
1035 .tuner_addr = ADDR_UNSET,
10c2c8b1 1036 .radio_addr = ADDR_UNSET,
2bfa1ac6
MCC
1037 .has_radio = 1,
1038 .audio_hook = avermedia_tvphone_audio,
1039 },
5a25e84b 1040 [BTTV_BOARD_PV951] = {
2bfa1ac6
MCC
1041 .name = "ProVideo PV951", /* pic16c54 */
1042 .video_inputs = 3,
1043 .audio_inputs = 1,
1044 .tuner = 0,
1045 .svhs = 2,
1046 .gpiomask = 0,
1047 .muxsel = { 2, 3, 1, 1},
8bf2f8e7 1048 .gpiomux = { 0, 0, 0, 0},
2bfa1ac6
MCC
1049 .needs_tvaudio = 1,
1050 .no_msp34xx = 1,
1051 .pll = PLL_28,
1052 .tuner_type = 1,
1053 .tuner_addr = ADDR_UNSET,
10c2c8b1 1054 .radio_addr = ADDR_UNSET,
2bfa1ac6 1055 },
5a25e84b 1056 [BTTV_BOARD_ONAIR_TV] = {
2bfa1ac6
MCC
1057 .name = "Little OnAir TV",
1058 .video_inputs = 3,
1059 .audio_inputs = 1,
1060 .tuner = 0,
1061 .svhs = 2,
1062 .gpiomask = 0xe00b,
bc28636a 1063 .muxsel = { 2, 3, 1, 1 },
8bf2f8e7
HV
1064 .gpiomux = { 0xff9ff6, 0xff9ff6, 0xff1ff7, 0 },
1065 .gpiomute = 0xff3ffc,
2bfa1ac6
MCC
1066 .no_msp34xx = 1,
1067 .tuner_type = -1,
1068 .tuner_addr = ADDR_UNSET,
10c2c8b1 1069 .radio_addr = ADDR_UNSET,
2bfa1ac6
MCC
1070 },
1071
1072 /* ---- card 0x2c ---------------------------------- */
5a25e84b 1073 [BTTV_BOARD_SIGMA_TVII_FM] = {
2bfa1ac6
MCC
1074 .name = "Sigma TVII-FM",
1075 .video_inputs = 2,
1076 .audio_inputs = 1,
1077 .tuner = 0,
1078 .svhs = -1,
1079 .gpiomask = 3,
bc28636a 1080 .muxsel = { 2, 3, 1, 1 },
8bf2f8e7
HV
1081 .gpiomux = { 1, 1, 0, 2 },
1082 .gpiomute = 3,
2bfa1ac6
MCC
1083 .no_msp34xx = 1,
1084 .pll = PLL_NONE,
1085 .tuner_type = -1,
1086 .tuner_addr = ADDR_UNSET,
10c2c8b1 1087 .radio_addr = ADDR_UNSET,
2bfa1ac6 1088 },
5a25e84b 1089 [BTTV_BOARD_MATRIX_VISION2] = {
2bfa1ac6
MCC
1090 .name = "MATRIX-Vision MV-Delta 2",
1091 .video_inputs = 5,
1092 .audio_inputs = 1,
1093 .tuner = -1,
1094 .svhs = 3,
1095 .gpiomask = 0,
bc28636a 1096 .muxsel = { 2, 3, 1, 0, 0 },
8bf2f8e7 1097 .gpiomux = { 0 },
2bfa1ac6
MCC
1098 .no_msp34xx = 1,
1099 .pll = PLL_28,
1100 .tuner_type = -1,
1101 .tuner_addr = ADDR_UNSET,
10c2c8b1 1102 .radio_addr = ADDR_UNSET,
2bfa1ac6 1103 },
5a25e84b 1104 [BTTV_BOARD_ZOLTRIX_GENIE] = {
2bfa1ac6
MCC
1105 .name = "Zoltrix Genie TV/FM",
1106 .video_inputs = 3,
1107 .audio_inputs = 1,
1108 .tuner = 0,
1109 .svhs = 2,
1110 .gpiomask = 0xbcf03f,
bc28636a 1111 .muxsel = { 2, 3, 1, 1 },
8bf2f8e7
HV
1112 .gpiomux = { 0xbc803f, 0xbc903f, 0xbcb03f, 0 },
1113 .gpiomute = 0xbcb03f,
2bfa1ac6
MCC
1114 .no_msp34xx = 1,
1115 .pll = PLL_28,
1116 .tuner_type = 21,
1117 .tuner_addr = ADDR_UNSET,
10c2c8b1 1118 .radio_addr = ADDR_UNSET,
2bfa1ac6 1119 },
5a25e84b 1120 [BTTV_BOARD_TERRATVRADIO] = {
2bfa1ac6
MCC
1121 .name = "Terratec TV/Radio+",
1122 .video_inputs = 3,
1123 .audio_inputs = 1,
1124 .tuner = 0,
1125 .svhs = 2,
1126 .gpiomask = 0x70000,
bc28636a 1127 .muxsel = { 2, 3, 1, 1 },
8bf2f8e7
HV
1128 .gpiomux = { 0x20000, 0x30000, 0x10000, 0 },
1129 .gpiomute = 0x40000,
2bfa1ac6
MCC
1130 .needs_tvaudio = 1,
1131 .no_msp34xx = 1,
1132 .pll = PLL_35,
1133 .tuner_type = 1,
1134 .tuner_addr = ADDR_UNSET,
10c2c8b1 1135 .radio_addr = ADDR_UNSET,
2bfa1ac6
MCC
1136 .has_radio = 1,
1137 },
1138
1139 /* ---- card 0x30 ---------------------------------- */
5a25e84b 1140 [BTTV_BOARD_DYNALINK] = {
2bfa1ac6
MCC
1141 .name = "Askey CPH03x/ Dynalink Magic TView",
1142 .video_inputs = 3,
1143 .audio_inputs = 1,
1144 .tuner = 0,
1145 .svhs = 2,
1146 .gpiomask = 15,
bc28636a 1147 .muxsel = { 2, 3, 1, 1 },
8bf2f8e7
HV
1148 .gpiomux = {2,0,0,0 },
1149 .gpiomute = 1,
2bfa1ac6
MCC
1150 .needs_tvaudio = 1,
1151 .pll = PLL_28,
1152 .tuner_type = -1,
1153 .tuner_addr = ADDR_UNSET,
10c2c8b1 1154 .radio_addr = ADDR_UNSET,
2bfa1ac6 1155 },
5a25e84b 1156 [BTTV_BOARD_GVBCTV3PCI] = {
2bfa1ac6
MCC
1157 .name = "IODATA GV-BCTV3/PCI",
1158 .video_inputs = 3,
1159 .audio_inputs = 1,
1160 .tuner = 0,
1161 .svhs = 2,
1162 .gpiomask = 0x010f00,
bc28636a 1163 .muxsel = {2, 3, 0, 0 },
8bf2f8e7 1164 .gpiomux = {0x10000, 0, 0x10000, 0 },
2bfa1ac6
MCC
1165 .no_msp34xx = 1,
1166 .pll = PLL_28,
1167 .tuner_type = TUNER_ALPS_TSHC6_NTSC,
1168 .tuner_addr = ADDR_UNSET,
10c2c8b1 1169 .radio_addr = ADDR_UNSET,
2bfa1ac6
MCC
1170 .audio_hook = gvbctv3pci_audio,
1171 },
5a25e84b 1172 [BTTV_BOARD_PXELVWPLTVPAK] = {
2bfa1ac6
MCC
1173 .name = "Prolink PV-BT878P+4E / PixelView PlayTV PAK / Lenco MXTV-9578 CP",
1174 .video_inputs = 5,
1175 .audio_inputs = 1,
1176 .tuner = 0,
1177 .svhs = 3,
1178 .gpiomask = 0xAA0000,
1179 .muxsel = { 2,3,1,1,-1 },
1180 .digital_mode = DIGITAL_MODE_CAMERA,
8bf2f8e7
HV
1181 .gpiomux = { 0x20000, 0, 0x80000, 0x80000 },
1182 .gpiomute = 0xa8000,
2bfa1ac6
MCC
1183 .no_msp34xx = 1,
1184 .pll = PLL_28,
1185 .tuner_type = TUNER_PHILIPS_PAL_I,
1186 .tuner_addr = ADDR_UNSET,
10c2c8b1 1187 .radio_addr = ADDR_UNSET,
2bfa1ac6
MCC
1188 .has_remote = 1,
1189 /* GPIO wiring: (different from Rev.4C !)
1190 GPIO17: U4.A0 (first hef4052bt)
1191 GPIO19: U4.A1
1192 GPIO20: U5.A1 (second hef4052bt)
1193 GPIO21: U4.nEN
1194 GPIO22: BT832 Reset Line
1195 GPIO23: A5,A0, U5,nEN
1196 Note: At i2c=0x8a is a Bt832 chip, which changes to 0x88 after being reset via GPIO22
1197 */
1198 },
5a25e84b 1199 [BTTV_BOARD_EAGLE] = {
2bfa1ac6
MCC
1200 .name = "Eagle Wireless Capricorn2 (bt878A)",
1201 .video_inputs = 4,
1202 .audio_inputs = 1,
1203 .tuner = 0,
1204 .svhs = 2,
1205 .gpiomask = 7,
bc28636a 1206 .muxsel = { 2, 0, 1, 1 },
8bf2f8e7
HV
1207 .gpiomux = { 0, 1, 2, 3 },
1208 .gpiomute = 4,
2bfa1ac6
MCC
1209 .pll = PLL_28,
1210 .tuner_type = -1 /* TUNER_ALPS_TMDH2_NTSC */,
1211 .tuner_addr = ADDR_UNSET,
10c2c8b1 1212 .radio_addr = ADDR_UNSET,
2bfa1ac6
MCC
1213 },
1214
1215 /* ---- card 0x34 ---------------------------------- */
5a25e84b 1216 [BTTV_BOARD_PINNACLEPRO] = {
2bfa1ac6
MCC
1217 /* David Härdeman <david@2gen.com> */
1218 .name = "Pinnacle PCTV Studio Pro",
1219 .video_inputs = 4,
1220 .audio_inputs = 1,
1221 .tuner = 0,
1222 .svhs = 3,
1223 .gpiomask = 0x03000F,
bc28636a 1224 .muxsel = { 2, 3, 1, 1 },
8bf2f8e7
HV
1225 .gpiomux = { 1, 0xd0001, 0, 0 },
1226 .gpiomute = 10,
2bfa1ac6
MCC
1227 /* sound path (5 sources):
1228 MUX1 (mask 0x03), Enable Pin 0x08 (0=enable, 1=disable)
1229 0= ext. Audio IN
1230 1= from MUX2
1231 2= Mono TV sound from Tuner
1232 3= not connected
1233 MUX2 (mask 0x30000):
1234 0,2,3= from MSP34xx
1235 1= FM stereo Radio from Tuner */
1236 .needs_tvaudio = 0,
1237 .pll = PLL_28,
1238 .tuner_type = -1,
1239 .tuner_addr = ADDR_UNSET,
10c2c8b1 1240 .radio_addr = ADDR_UNSET,
2bfa1ac6 1241 },
5a25e84b 1242 [BTTV_BOARD_TVIEW_RDS_FM] = {
2bfa1ac6
MCC
1243 /* Claas Langbehn <claas@bigfoot.com>,
1244 Sven Grothklags <sven@upb.de> */
1245 .name = "Typhoon TView RDS + FM Stereo / KNC1 TV Station RDS",
1246 .video_inputs = 4,
1247 .audio_inputs = 3,
1248 .tuner = 0,
1249 .svhs = 2,
1250 .gpiomask = 0x1c,
bc28636a 1251 .muxsel = { 2, 3, 1, 1 },
8bf2f8e7
HV
1252 .gpiomux = { 0, 0, 0x10, 8 },
1253 .gpiomute = 4,
2bfa1ac6
MCC
1254 .needs_tvaudio = 1,
1255 .pll = PLL_28,
1256 .tuner_type = TUNER_PHILIPS_PAL,
1257 .tuner_addr = ADDR_UNSET,
10c2c8b1 1258 .radio_addr = ADDR_UNSET,
2bfa1ac6
MCC
1259 .has_radio = 1,
1260 },
5a25e84b 1261 [BTTV_BOARD_LIFETEC_9415] = {
2bfa1ac6
MCC
1262