~ [ source navigation ] ~ [ diff markup ] ~ [ identifier search ] ~ [ freetext search ] ~ [ file search ] ~

Linux Cross Reference
Linux-2.6.17/drivers/media/video/bt8xx/bttv-cards.c

Version: ~ [ 2.6.16 ] ~ [ 2.6.17 ] ~
Architecture: ~ [ ia64 ] ~ [ i386 ] ~ [ arm ] ~ [ ppc ] ~ [ sparc64 ] ~

  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