blob: 98c1b084a7160eeaeb18b7033c670cb3668a1ece [file] [log] [blame]
Linus Torvalds1da177e2005-04-16 15:20:36 -07001/*
Linus Torvalds1da177e2005-04-16 15:20:36 -07002 *
3 * device driver for philips saa7134 based TV cards
4 * card-specific stuff.
5 *
6 * (c) 2001-04 Gerd Knorr <kraxel@bytesex.org> [SuSE Labs]
7 *
8 * This program is free software; you can redistribute it and/or modify
9 * it under the terms of the GNU General Public License as published by
10 * the Free Software Foundation; either version 2 of the License, or
11 * (at your option) any later version.
12 *
13 * This program is distributed in the hope that it will be useful,
14 * but WITHOUT ANY WARRANTY; without even the implied warranty of
15 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
16 * GNU General Public License for more details.
17 *
18 * You should have received a copy of the GNU General Public License
19 * along with this program; if not, write to the Free Software
20 * Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
21 */
22
23#include <linux/init.h>
24#include <linux/module.h>
25
26#include "saa7134-reg.h"
27#include "saa7134.h"
Michael Krufky5e453dc2006-01-09 15:32:31 -020028#include <media/v4l2-common.h>
Linus Torvalds1da177e2005-04-16 15:20:36 -070029
30/* commly used strings */
31static char name_mute[] = "mute";
32static char name_radio[] = "Radio";
33static char name_tv[] = "Television";
34static char name_tv_mono[] = "TV (mono only)";
Stas Sergeevf438d972007-09-17 15:34:09 -030035static char name_comp[] = "Composite";
Linus Torvalds1da177e2005-04-16 15:20:36 -070036static char name_comp1[] = "Composite1";
37static char name_comp2[] = "Composite2";
38static char name_comp3[] = "Composite3";
39static char name_comp4[] = "Composite4";
40static char name_svideo[] = "S-Video";
41
42/* ------------------------------------------------------------------ */
43/* board config info */
44
45struct saa7134_board saa7134_boards[] = {
46 [SAA7134_BOARD_UNKNOWN] = {
47 .name = "UNKNOWN/GENERIC",
48 .audio_clock = 0x00187de7,
49 .tuner_type = TUNER_ABSENT,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -070050 .radio_type = UNSET,
51 .tuner_addr = ADDR_UNSET,
52 .radio_addr = ADDR_UNSET,
53
Linus Torvalds1da177e2005-04-16 15:20:36 -070054 .inputs = {{
55 .name = "default",
56 .vmux = 0,
57 .amux = LINE1,
58 }},
59 },
60 [SAA7134_BOARD_PROTEUS_PRO] = {
61 /* /me */
62 .name = "Proteus Pro [philips reference design]",
63 .audio_clock = 0x00187de7,
64 .tuner_type = TUNER_PHILIPS_PAL,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -070065 .radio_type = UNSET,
66 .tuner_addr = ADDR_UNSET,
67 .radio_addr = ADDR_UNSET,
68
Linus Torvalds1da177e2005-04-16 15:20:36 -070069 .inputs = {{
70 .name = name_comp1,
71 .vmux = 0,
72 .amux = LINE1,
73 },{
74 .name = name_tv,
75 .vmux = 1,
76 .amux = TV,
77 .tv = 1,
78 },{
79 .name = name_tv_mono,
80 .vmux = 1,
81 .amux = LINE2,
82 .tv = 1,
83 }},
84 .radio = {
85 .name = name_radio,
86 .amux = LINE2,
87 },
88 },
89 [SAA7134_BOARD_FLYVIDEO3000] = {
90 /* "Marco d'Itri" <md@Linux.IT> */
91 .name = "LifeView FlyVIDEO3000",
92 .audio_clock = 0x00200000,
93 .tuner_type = TUNER_PHILIPS_PAL,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -070094 .radio_type = UNSET,
95 .tuner_addr = ADDR_UNSET,
96 .radio_addr = ADDR_UNSET,
97
Linus Torvalds1da177e2005-04-16 15:20:36 -070098 .gpiomask = 0xe000,
99 .inputs = {{
100 .name = name_tv,
101 .vmux = 1,
102 .amux = TV,
103 .gpio = 0x8000,
104 .tv = 1,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -0700105 },{
Linus Torvalds1da177e2005-04-16 15:20:36 -0700106 .name = name_tv_mono,
107 .vmux = 1,
108 .amux = LINE2,
109 .gpio = 0x0000,
110 .tv = 1,
111 },{
112 .name = name_comp1,
113 .vmux = 0,
114 .amux = LINE2,
115 .gpio = 0x4000,
116 },{
117 .name = name_comp2,
118 .vmux = 3,
119 .amux = LINE2,
120 .gpio = 0x4000,
121 },{
122 .name = name_svideo,
123 .vmux = 8,
124 .amux = LINE2,
125 .gpio = 0x4000,
126 }},
127 .radio = {
128 .name = name_radio,
129 .amux = LINE2,
130 .gpio = 0x2000,
131 },
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -0700132 .mute = {
133 .name = name_mute,
134 .amux = TV,
135 .gpio = 0x8000,
136 },
Linus Torvalds1da177e2005-04-16 15:20:36 -0700137 },
138 [SAA7134_BOARD_FLYVIDEO2000] = {
139 /* "TC Wan" <tcwan@cs.usm.my> */
Peter Missel10b7a902006-01-23 17:11:06 -0200140 .name = "LifeView/Typhoon FlyVIDEO2000",
Linus Torvalds1da177e2005-04-16 15:20:36 -0700141 .audio_clock = 0x00200000,
142 .tuner_type = TUNER_LG_PAL_NEW_TAPC,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -0700143 .radio_type = UNSET,
144 .tuner_addr = ADDR_UNSET,
145 .radio_addr = ADDR_UNSET,
146
Linus Torvalds1da177e2005-04-16 15:20:36 -0700147 .gpiomask = 0xe000,
148 .inputs = {{
149 .name = name_tv,
150 .vmux = 1,
151 .amux = LINE2,
152 .gpio = 0x0000,
153 .tv = 1,
154 },{
155 .name = name_comp1,
156 .vmux = 0,
157 .amux = LINE2,
158 .gpio = 0x4000,
159 },{
160 .name = name_comp2,
161 .vmux = 3,
162 .amux = LINE2,
163 .gpio = 0x4000,
164 },{
165 .name = name_svideo,
166 .vmux = 8,
167 .amux = LINE2,
168 .gpio = 0x4000,
169 }},
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -0700170 .radio = {
171 .name = name_radio,
172 .amux = LINE2,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700173 .gpio = 0x2000,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -0700174 },
Linus Torvalds1da177e2005-04-16 15:20:36 -0700175 .mute = {
176 .name = name_mute,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -0700177 .amux = LINE2,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700178 .gpio = 0x8000,
179 },
180 },
181 [SAA7134_BOARD_FLYTVPLATINUM_MINI] = {
182 /* "Arnaud Quette" <aquette@free.fr> */
183 .name = "LifeView FlyTV Platinum Mini",
184 .audio_clock = 0x00200000,
185 .tuner_type = TUNER_PHILIPS_TDA8290,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -0700186 .radio_type = UNSET,
187 .tuner_addr = ADDR_UNSET,
188 .radio_addr = ADDR_UNSET,
189
Linus Torvalds1da177e2005-04-16 15:20:36 -0700190 .inputs = {{
191 .name = name_tv,
192 .vmux = 1,
Mauro Carvalho Chehabac19ecc2005-06-23 22:05:09 -0700193 .amux = TV,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700194 .tv = 1,
195 },{
Glen Gray2d14f782005-11-08 21:36:12 -0800196 .name = name_comp1, /* Composite signal on S-Video input */
Linus Torvalds1da177e2005-04-16 15:20:36 -0700197 .vmux = 0,
198 .amux = LINE2,
199 },{
Glen Gray2d14f782005-11-08 21:36:12 -0800200 .name = name_comp2, /* Composite input */
201 .vmux = 3,
202 .amux = LINE2,
203 },{
Linus Torvalds1da177e2005-04-16 15:20:36 -0700204 .name = name_svideo,
205 .vmux = 8,
206 .amux = LINE2,
207 }},
208 },
209 [SAA7134_BOARD_FLYTVPLATINUM_FM] = {
210 /* LifeView FlyTV Platinum FM (LR214WF) */
211 /* "Peter Missel <peter.missel@onlinehome.de> */
Hartmut Hackmann42e6b3b2006-03-27 19:04:48 -0300212 .name = "LifeView FlyTV Platinum FM / Gold",
Linus Torvalds1da177e2005-04-16 15:20:36 -0700213 .audio_clock = 0x00200000,
214 .tuner_type = TUNER_PHILIPS_TDA8290,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -0700215 .radio_type = UNSET,
216 .tuner_addr = ADDR_UNSET,
217 .radio_addr = ADDR_UNSET,
218
Peter Missel6c9e7372005-05-01 08:59:05 -0700219 .gpiomask = 0x1E000, /* Set GP16 and unused 15,14,13 to Output */
Linus Torvalds1da177e2005-04-16 15:20:36 -0700220 .inputs = {{
221 .name = name_tv,
222 .vmux = 1,
223 .amux = TV,
Peter Missel6c9e7372005-05-01 08:59:05 -0700224 .gpio = 0x10000, /* GP16=1 selects TV input */
Linus Torvalds1da177e2005-04-16 15:20:36 -0700225 .tv = 1,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -0700226 },{
Linus Torvalds1da177e2005-04-16 15:20:36 -0700227/* .name = name_tv_mono,
228 .vmux = 1,
229 .amux = LINE2,
230 .gpio = 0x0000,
231 .tv = 1,
232 },{
233*/ .name = name_comp1, /* Composite signal on S-Video input */
234 .vmux = 0,
235 .amux = LINE2,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -0700236/* .gpio = 0x4000, */
Linus Torvalds1da177e2005-04-16 15:20:36 -0700237 },{
238 .name = name_comp2, /* Composite input */
239 .vmux = 3,
240 .amux = LINE2,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -0700241/* .gpio = 0x4000, */
Linus Torvalds1da177e2005-04-16 15:20:36 -0700242 },{
243 .name = name_svideo, /* S-Video signal on S-Video input */
244 .vmux = 8,
245 .amux = LINE2,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -0700246/* .gpio = 0x4000, */
Linus Torvalds1da177e2005-04-16 15:20:36 -0700247 }},
Peter Missel6c9e7372005-05-01 08:59:05 -0700248 .radio = {
Linus Torvalds1da177e2005-04-16 15:20:36 -0700249 .name = name_radio,
Peter Missel6c9e7372005-05-01 08:59:05 -0700250 .amux = TV,
251 .gpio = 0x00000, /* GP16=0 selects FM radio antenna */
Linus Torvalds1da177e2005-04-16 15:20:36 -0700252 },
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -0700253 .mute = {
254 .name = name_mute,
255 .amux = TV,
256 .gpio = 0x10000,
257 },
Peter Missel6c9e7372005-05-01 08:59:05 -0700258 },
Linus Torvalds1da177e2005-04-16 15:20:36 -0700259 [SAA7134_BOARD_EMPRESS] = {
260 /* "Gert Vervoort" <gert.vervoort@philips.com> */
261 .name = "EMPRESS",
262 .audio_clock = 0x00187de7,
263 .tuner_type = TUNER_PHILIPS_PAL,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -0700264 .radio_type = UNSET,
265 .tuner_addr = ADDR_UNSET,
266 .radio_addr = ADDR_UNSET,
267
Linus Torvalds1da177e2005-04-16 15:20:36 -0700268 .inputs = {{
269 .name = name_comp1,
270 .vmux = 0,
271 .amux = LINE1,
272 },{
273 .name = name_svideo,
274 .vmux = 8,
275 .amux = LINE1,
276 },{
277 .name = name_tv,
278 .vmux = 1,
279 .amux = LINE2,
280 .tv = 1,
281 }},
282 .radio = {
283 .name = name_radio,
284 .amux = LINE2,
285 },
286 .mpeg = SAA7134_MPEG_EMPRESS,
287 .video_out = CCIR656,
288 },
289 [SAA7134_BOARD_MONSTERTV] = {
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -0700290 /* "K.Ohta" <alpha292@bremen.or.jp> */
291 .name = "SKNet Monster TV",
292 .audio_clock = 0x00187de7,
293 .tuner_type = TUNER_PHILIPS_NTSC_M,
294 .radio_type = UNSET,
295 .tuner_addr = ADDR_UNSET,
296 .radio_addr = ADDR_UNSET,
297
298 .inputs = {{
299 .name = name_tv,
300 .vmux = 1,
301 .amux = TV,
302 .tv = 1,
303 },{
304 .name = name_comp1,
305 .vmux = 0,
306 .amux = LINE1,
307 },{
308 .name = name_svideo,
309 .vmux = 8,
310 .amux = LINE1,
311 }},
312 .radio = {
313 .name = name_radio,
314 .amux = LINE2,
315 },
Linus Torvalds1da177e2005-04-16 15:20:36 -0700316 },
317 [SAA7134_BOARD_MD9717] = {
318 .name = "Tevion MD 9717",
319 .audio_clock = 0x00200000,
320 .tuner_type = TUNER_PHILIPS_PAL,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -0700321 .radio_type = UNSET,
322 .tuner_addr = ADDR_UNSET,
323 .radio_addr = ADDR_UNSET,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700324 .inputs = {{
325 .name = name_tv,
326 .vmux = 1,
327 .amux = TV,
328 .tv = 1,
329 },{
330 /* workaround for problems with normal TV sound */
331 .name = name_tv_mono,
332 .vmux = 1,
333 .amux = LINE2,
334 .tv = 1,
335 },{
336 .name = name_comp1,
Hermann Pitton4aa504a2007-11-28 21:50:26 -0300337 .vmux = 0,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700338 .amux = LINE1,
339 },{
340 .name = name_comp2,
341 .vmux = 3,
342 .amux = LINE1,
343 },{
344 .name = name_svideo,
345 .vmux = 8,
346 .amux = LINE1,
347 }},
348 .radio = {
349 .name = name_radio,
350 .amux = LINE2,
351 },
352 },
353 [SAA7134_BOARD_TVSTATION_RDS] = {
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -0700354 /* Typhoon TV Tuner RDS: Art.Nr. 50694 */
Linus Torvalds1da177e2005-04-16 15:20:36 -0700355 .name = "KNC One TV-Station RDS / Typhoon TV Tuner RDS",
356 .audio_clock = 0x00200000,
357 .tuner_type = TUNER_PHILIPS_FM1216ME_MK3,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -0700358 .radio_type = UNSET,
359 .tuner_addr = ADDR_UNSET,
360 .radio_addr = ADDR_UNSET,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700361 .tda9887_conf = TDA9887_PRESENT,
362 .inputs = {{
363 .name = name_tv,
364 .vmux = 1,
365 .amux = TV,
366 .tv = 1,
367 },{
368 .name = name_tv_mono,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -0700369 .vmux = 1,
370 .amux = LINE2,
371 .tv = 1,
372 },{
Linus Torvalds1da177e2005-04-16 15:20:36 -0700373
374 .name = name_svideo,
375 .vmux = 8,
376 .amux = LINE1,
377 },{
378 .name = name_comp1,
379 .vmux = 3,
380 .amux = LINE1,
381 },{
382
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -0700383 .name = "CVid over SVid",
384 .vmux = 0,
385 .amux = LINE1,
386 }},
Linus Torvalds1da177e2005-04-16 15:20:36 -0700387 .radio = {
388 .name = name_radio,
389 .amux = LINE2,
390 },
391 },
392 [SAA7134_BOARD_TVSTATION_DVR] = {
393 .name = "KNC One TV-Station DVR",
394 .audio_clock = 0x00200000,
395 .tuner_type = TUNER_PHILIPS_FM1216ME_MK3,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -0700396 .radio_type = UNSET,
397 .tuner_addr = ADDR_UNSET,
398 .radio_addr = ADDR_UNSET,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700399 .tda9887_conf = TDA9887_PRESENT,
400 .gpiomask = 0x820000,
401 .inputs = {{
402 .name = name_tv,
403 .vmux = 1,
Rafał Bilskiaac0ca62007-06-20 05:36:26 -0300404 .amux = TV,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700405 .tv = 1,
406 .gpio = 0x20000,
407 },{
408 .name = name_svideo,
409 .vmux = 8,
410 .amux = LINE1,
411 .gpio = 0x20000,
412 },{
413 .name = name_comp1,
414 .vmux = 3,
415 .amux = LINE1,
416 .gpio = 0x20000,
417 }},
418 .radio = {
419 .name = name_radio,
420 .amux = LINE2,
421 .gpio = 0x20000,
422 },
423 .mpeg = SAA7134_MPEG_EMPRESS,
424 .video_out = CCIR656,
425 },
426 [SAA7134_BOARD_CINERGY400] = {
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -0700427 .name = "Terratec Cinergy 400 TV",
428 .audio_clock = 0x00200000,
429 .tuner_type = TUNER_PHILIPS_PAL,
430 .radio_type = UNSET,
431 .tuner_addr = ADDR_UNSET,
432 .radio_addr = ADDR_UNSET,
433 .inputs = {{
434 .name = name_tv,
435 .vmux = 1,
436 .amux = TV,
437 .tv = 1,
438 },{
439 .name = name_comp1,
440 .vmux = 4,
441 .amux = LINE1,
442 },{
443 .name = name_svideo,
444 .vmux = 8,
445 .amux = LINE1,
446 },{
447 .name = name_comp2, /* CVideo over SVideo Connector */
448 .vmux = 0,
449 .amux = LINE1,
450 }}
451 },
Linus Torvalds1da177e2005-04-16 15:20:36 -0700452 [SAA7134_BOARD_MD5044] = {
453 .name = "Medion 5044",
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -0700454 .audio_clock = 0x00187de7, /* was: 0x00200000, */
Linus Torvalds1da177e2005-04-16 15:20:36 -0700455 .tuner_type = TUNER_PHILIPS_FM1216ME_MK3,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -0700456 .radio_type = UNSET,
457 .tuner_addr = ADDR_UNSET,
458 .radio_addr = ADDR_UNSET,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700459 .tda9887_conf = TDA9887_PRESENT,
460 .inputs = {{
461 .name = name_tv,
462 .vmux = 1,
463 .amux = TV,
464 .tv = 1,
465 },{
466 /* workaround for problems with normal TV sound */
467 .name = name_tv_mono,
468 .vmux = 1,
469 .amux = LINE2,
470 .tv = 1,
471 },{
472 .name = name_comp1,
473 .vmux = 0,
474 .amux = LINE2,
475 },{
476 .name = name_comp2,
477 .vmux = 3,
478 .amux = LINE2,
479 },{
480 .name = name_svideo,
481 .vmux = 8,
482 .amux = LINE2,
483 }},
484 .radio = {
485 .name = name_radio,
486 .amux = LINE2,
487 },
488 },
489 [SAA7134_BOARD_KWORLD] = {
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -0700490 .name = "Kworld/KuroutoShikou SAA7130-TVPCI",
Linus Torvalds1da177e2005-04-16 15:20:36 -0700491 .audio_clock = 0x00187de7,
492 .tuner_type = TUNER_PHILIPS_NTSC_M,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -0700493 .radio_type = UNSET,
494 .tuner_addr = ADDR_UNSET,
495 .radio_addr = ADDR_UNSET,
496 .inputs = {{
497 .name = name_svideo,
498 .vmux = 8,
499 .amux = LINE1,
500 },{
501 .name = name_comp1,
502 .vmux = 3,
503 .amux = LINE1,
504 },{
505 .name = name_tv,
506 .vmux = 1,
507 .amux = LINE2,
508 .tv = 1,
509 }},
510 },
Linus Torvalds1da177e2005-04-16 15:20:36 -0700511 [SAA7134_BOARD_CINERGY600] = {
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -0700512 .name = "Terratec Cinergy 600 TV",
513 .audio_clock = 0x00200000,
514 .tuner_type = TUNER_PHILIPS_PAL,
515 .radio_type = UNSET,
516 .tuner_addr = ADDR_UNSET,
517 .radio_addr = ADDR_UNSET,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700518 .tda9887_conf = TDA9887_PRESENT,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -0700519 .inputs = {{
520 .name = name_tv,
521 .vmux = 1,
522 .amux = TV,
523 .tv = 1,
524 },{
525 .name = name_comp1,
526 .vmux = 4,
527 .amux = LINE1,
528 },{
529 .name = name_svideo,
530 .vmux = 8,
531 .amux = LINE1,
532 },{
533 .name = name_comp2, /* CVideo over SVideo Connector */
534 .vmux = 0,
535 .amux = LINE1,
536 }},
Linus Torvalds1da177e2005-04-16 15:20:36 -0700537 .radio = {
538 .name = name_radio,
539 .amux = LINE2,
Michael Krufky67ac9a42006-03-14 16:18:49 -0300540 },
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -0700541 },
Linus Torvalds1da177e2005-04-16 15:20:36 -0700542 [SAA7134_BOARD_MD7134] = {
543 .name = "Medion 7134",
Linus Torvalds1da177e2005-04-16 15:20:36 -0700544 .audio_clock = 0x00187de7,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -0700545 .tuner_type = TUNER_PHILIPS_FMD1216ME_MK3,
546 .radio_type = UNSET,
547 .tuner_addr = ADDR_UNSET,
548 .radio_addr = ADDR_UNSET,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700549 .tda9887_conf = TDA9887_PRESENT,
550 .mpeg = SAA7134_MPEG_DVB,
551 .inputs = {{
552 .name = name_tv,
553 .vmux = 1,
554 .amux = TV,
555 .tv = 1,
556 },{
557 .name = name_comp1,
558 .vmux = 0,
559 .amux = LINE1,
560 },{
561 .name = name_svideo,
562 .vmux = 8,
563 .amux = LINE1,
564 }},
565 .radio = {
566 .name = name_radio,
567 .amux = LINE2,
568 },
569 },
570 [SAA7134_BOARD_TYPHOON_90031] = {
571 /* aka Typhoon "TV+Radio", Art.Nr 90031 */
572 /* Tom Zoerner <tomzo at users sourceforge net> */
573 .name = "Typhoon TV+Radio 90031",
574 .audio_clock = 0x00200000,
575 .tuner_type = TUNER_PHILIPS_PAL,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -0700576 .radio_type = UNSET,
577 .tuner_addr = ADDR_UNSET,
578 .radio_addr = ADDR_UNSET,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700579 .tda9887_conf = TDA9887_PRESENT,
580 .inputs = {{
581 .name = name_tv,
582 .vmux = 1,
583 .amux = TV,
584 .tv = 1,
585 },{
586 .name = name_comp1,
587 .vmux = 3,
588 .amux = LINE1,
589 },{
590 .name = name_svideo,
591 .vmux = 8,
592 .amux = LINE1,
593 }},
594 .radio = {
595 .name = name_radio,
596 .amux = LINE2,
597 },
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -0700598 },
Linus Torvalds1da177e2005-04-16 15:20:36 -0700599 [SAA7134_BOARD_ELSA] = {
600 .name = "ELSA EX-VISION 300TV",
601 .audio_clock = 0x00187de7,
602 .tuner_type = TUNER_HITACHI_NTSC,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -0700603 .radio_type = UNSET,
604 .tuner_addr = ADDR_UNSET,
605 .radio_addr = ADDR_UNSET,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700606 .inputs = {{
607 .name = name_svideo,
608 .vmux = 8,
609 .amux = LINE1,
610 },{
611 .name = name_comp1,
612 .vmux = 0,
613 .amux = LINE1,
614 },{
615 .name = name_tv,
616 .vmux = 4,
617 .amux = LINE2,
618 .tv = 1,
619 }},
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -0700620 },
Linus Torvalds1da177e2005-04-16 15:20:36 -0700621 [SAA7134_BOARD_ELSA_500TV] = {
622 .name = "ELSA EX-VISION 500TV",
623 .audio_clock = 0x00187de7,
624 .tuner_type = TUNER_HITACHI_NTSC,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -0700625 .radio_type = UNSET,
626 .tuner_addr = ADDR_UNSET,
627 .radio_addr = ADDR_UNSET,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700628 .inputs = {{
629 .name = name_svideo,
630 .vmux = 7,
631 .amux = LINE1,
632 },{
633 .name = name_tv,
634 .vmux = 8,
635 .amux = TV,
636 .tv = 1,
637 },{
638 .name = name_tv_mono,
639 .vmux = 8,
640 .amux = LINE2,
641 .tv = 1,
642 }},
Linus Torvalds1da177e2005-04-16 15:20:36 -0700643 },
Tamuki Shoichid0456d12006-02-27 00:08:04 -0300644 [SAA7134_BOARD_ELSA_700TV] = {
645 .name = "ELSA EX-VISION 700TV",
646 .audio_clock = 0x00187de7,
647 .tuner_type = TUNER_HITACHI_NTSC,
648 .radio_type = UNSET,
649 .tuner_addr = ADDR_UNSET,
650 .radio_addr = ADDR_UNSET,
651 .inputs = {{
652 .name = name_tv,
653 .vmux = 4,
654 .amux = LINE2,
655 .tv = 1,
656 },{
657 .name = name_comp1,
658 .vmux = 6,
659 .amux = LINE1,
660 },{
661 .name = name_svideo,
662 .vmux = 7,
663 .amux = LINE1,
664 }},
665 .mute = {
666 .name = name_mute,
667 .amux = TV,
668 },
669 },
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -0700670 [SAA7134_BOARD_ASUSTeK_TVFM7134] = {
671 .name = "ASUS TV-FM 7134",
672 .audio_clock = 0x00187de7,
673 .tuner_type = TUNER_PHILIPS_FM1216ME_MK3,
674 .radio_type = UNSET,
675 .tuner_addr = ADDR_UNSET,
676 .radio_addr = ADDR_UNSET,
677 .tda9887_conf = TDA9887_PRESENT,
678 .inputs = {{
679 .name = name_tv,
680 .vmux = 1,
681 .amux = TV,
682 .tv = 1,
683 },{
684 .name = name_comp1,
685 .vmux = 4,
686 .amux = LINE2,
687 },{
688 .name = name_svideo,
689 .vmux = 6,
690 .amux = LINE2,
691 }},
692 .radio = {
693 .name = name_radio,
694 .amux = LINE1,
695 },
696 },
697 [SAA7134_BOARD_ASUSTeK_TVFM7135] = {
698 .name = "ASUS TV-FM 7135",
699 .audio_clock = 0x00187de7,
700 .tuner_type = TUNER_PHILIPS_TDA8290,
701 .radio_type = UNSET,
702 .tuner_addr = ADDR_UNSET,
703 .radio_addr = ADDR_UNSET,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700704 .gpiomask = 0x200000,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -0700705 .inputs = {{
706 .name = name_tv,
707 .vmux = 1,
708 .amux = TV,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700709 .gpio = 0x0000,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -0700710 .tv = 1,
711 },{
712 .name = name_comp1,
713 .vmux = 4,
714 .amux = LINE2,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700715 .gpio = 0x0000,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -0700716 },{
717 .name = name_svideo,
718 .vmux = 6,
719 .amux = LINE2,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700720 .gpio = 0x0000,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -0700721 }},
722 .radio = {
723 .name = name_radio,
724 .amux = TV,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700725 .gpio = 0x200000,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -0700726 },
727 .mute = {
728 .name = name_mute,
729 .gpio = 0x0000,
730 },
731
Linus Torvalds1da177e2005-04-16 15:20:36 -0700732 },
733 [SAA7134_BOARD_VA1000POWER] = {
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -0700734 .name = "AOPEN VA1000 POWER",
Linus Torvalds1da177e2005-04-16 15:20:36 -0700735 .audio_clock = 0x00187de7,
736 .tuner_type = TUNER_PHILIPS_NTSC,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -0700737 .radio_type = UNSET,
738 .tuner_addr = ADDR_UNSET,
739 .radio_addr = ADDR_UNSET,
740 .inputs = {{
741 .name = name_svideo,
742 .vmux = 8,
743 .amux = LINE1,
744 },{
745 .name = name_comp1,
746 .vmux = 3,
747 .amux = LINE1,
748 },{
749 .name = name_tv,
750 .vmux = 1,
751 .amux = LINE2,
752 .tv = 1,
753 }},
Linus Torvalds1da177e2005-04-16 15:20:36 -0700754 },
755 [SAA7134_BOARD_10MOONSTVMASTER] = {
756 /* "lilicheng" <llc@linuxfans.org> */
757 .name = "10MOONS PCI TV CAPTURE CARD",
758 .audio_clock = 0x00200000,
759 .tuner_type = TUNER_LG_PAL_NEW_TAPC,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -0700760 .radio_type = UNSET,
761 .tuner_addr = ADDR_UNSET,
762 .radio_addr = ADDR_UNSET,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700763 .gpiomask = 0xe000,
764 .inputs = {{
765 .name = name_tv,
766 .vmux = 1,
767 .amux = LINE2,
768 .gpio = 0x0000,
769 .tv = 1,
770 },{
771 .name = name_comp1,
772 .vmux = 0,
773 .amux = LINE2,
774 .gpio = 0x4000,
775 },{
776 .name = name_comp2,
777 .vmux = 3,
778 .amux = LINE2,
779 .gpio = 0x4000,
780 },{
781 .name = name_svideo,
782 .vmux = 8,
783 .amux = LINE2,
784 .gpio = 0x4000,
785 }},
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -0700786 .radio = {
787 .name = name_radio,
788 .amux = LINE2,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700789 .gpio = 0x2000,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -0700790 },
Linus Torvalds1da177e2005-04-16 15:20:36 -0700791 .mute = {
792 .name = name_mute,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -0700793 .amux = LINE2,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700794 .gpio = 0x8000,
795 },
796 },
797 [SAA7134_BOARD_BMK_MPEX_NOTUNER] = {
798 /* "Andrew de Quincey" <adq@lidskialf.net> */
799 .name = "BMK MPEX No Tuner",
800 .audio_clock = 0x200000,
801 .tuner_type = TUNER_ABSENT,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -0700802 .radio_type = UNSET,
803 .tuner_addr = ADDR_UNSET,
804 .radio_addr = ADDR_UNSET,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700805 .inputs = {{
806 .name = name_comp1,
807 .vmux = 4,
808 .amux = LINE1,
809 },{
810 .name = name_comp2,
811 .vmux = 3,
812 .amux = LINE1,
813 },{
814 .name = name_comp3,
815 .vmux = 0,
816 .amux = LINE1,
817 },{
818 .name = name_comp4,
819 .vmux = 1,
820 .amux = LINE1,
821 },{
822 .name = name_svideo,
823 .vmux = 8,
824 .amux = LINE1,
825 }},
826 .mpeg = SAA7134_MPEG_EMPRESS,
827 .video_out = CCIR656,
828 },
829 [SAA7134_BOARD_VIDEOMATE_TV] = {
830 .name = "Compro VideoMate TV",
831 .audio_clock = 0x00187de7,
832 .tuner_type = TUNER_PHILIPS_NTSC_M,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -0700833 .radio_type = UNSET,
834 .tuner_addr = ADDR_UNSET,
835 .radio_addr = ADDR_UNSET,
836 .inputs = {{
837 .name = name_svideo,
838 .vmux = 8,
839 .amux = LINE1,
840 },{
841 .name = name_comp1,
842 .vmux = 3,
843 .amux = LINE1,
844 },{
845 .name = name_tv,
846 .vmux = 1,
847 .amux = LINE2,
848 .tv = 1,
849 }},
850 },
851 [SAA7134_BOARD_VIDEOMATE_TV_GOLD_PLUS] = {
Linus Torvalds1da177e2005-04-16 15:20:36 -0700852 .name = "Compro VideoMate TV Gold+",
853 .audio_clock = 0x00187de7,
854 .tuner_type = TUNER_PHILIPS_NTSC_M,
855 .gpiomask = 0x800c0000,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -0700856 .radio_type = UNSET,
857 .tuner_addr = ADDR_UNSET,
858 .radio_addr = ADDR_UNSET,
859 .inputs = {{
860 .name = name_svideo,
861 .vmux = 8,
862 .amux = LINE1,
863 .gpio = 0x06c00012,
864 },{
865 .name = name_comp1,
866 .vmux = 3,
867 .amux = LINE1,
868 .gpio = 0x0ac20012,
869 },{
870 .name = name_tv,
871 .vmux = 1,
872 .amux = LINE2,
873 .gpio = 0x08c20012,
874 .tv = 1,
875 }}, /* radio and probably mute is missing */
876 },
Linus Torvalds1da177e2005-04-16 15:20:36 -0700877 [SAA7134_BOARD_CRONOS_PLUS] = {
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -0700878 /*
879 gpio pins:
880 0 .. 3 BASE_ID
881 4 .. 7 PROTECT_ID
882 8 .. 11 USER_OUT
883 12 .. 13 USER_IN
884 14 .. 15 VIDIN_SEL
885 */
Linus Torvalds1da177e2005-04-16 15:20:36 -0700886 .name = "Matrox CronosPlus",
887 .tuner_type = TUNER_ABSENT,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -0700888 .radio_type = UNSET,
889 .tuner_addr = ADDR_UNSET,
890 .radio_addr = ADDR_UNSET,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700891 .gpiomask = 0xcf00,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -0700892 .inputs = {{
893 .name = name_comp1,
894 .vmux = 0,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700895 .gpio = 2 << 14,
896 },{
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -0700897 .name = name_comp2,
898 .vmux = 0,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700899 .gpio = 1 << 14,
900 },{
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -0700901 .name = name_comp3,
902 .vmux = 0,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700903 .gpio = 0 << 14,
904 },{
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -0700905 .name = name_comp4,
906 .vmux = 0,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700907 .gpio = 3 << 14,
908 },{
909 .name = name_svideo,
910 .vmux = 8,
911 .gpio = 2 << 14,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -0700912 }},
913 },
Linus Torvalds1da177e2005-04-16 15:20:36 -0700914 [SAA7134_BOARD_MD2819] = {
915 .name = "AverMedia M156 / Medion 2819",
916 .audio_clock = 0x00187de7,
917 .tuner_type = TUNER_PHILIPS_FM1216ME_MK3,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -0700918 .radio_type = UNSET,
919 .tuner_addr = ADDR_UNSET,
920 .radio_addr = ADDR_UNSET,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700921 .tda9887_conf = TDA9887_PRESENT,
922 .inputs = {{
923 .name = name_tv,
924 .vmux = 1,
925 .amux = TV,
926 .tv = 1,
927 },{
928 .name = name_comp1,
929 .vmux = 0,
930 .amux = LINE2,
931 },{
932 .name = name_comp2,
933 .vmux = 3,
934 .amux = LINE2,
935 },{
936 .name = name_svideo,
937 .vmux = 8,
938 .amux = LINE2,
939 }},
940 .radio = {
941 .name = name_radio,
942 .amux = LINE2,
943 },
944 },
945 [SAA7134_BOARD_BMK_MPEX_TUNER] = {
946 /* "Greg Wickham <greg.wickham@grangenet.net> */
947 .name = "BMK MPEX Tuner",
948 .audio_clock = 0x200000,
949 .tuner_type = TUNER_PHILIPS_PAL,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -0700950 .radio_type = UNSET,
951 .tuner_addr = ADDR_UNSET,
952 .radio_addr = ADDR_UNSET,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700953 .inputs = {{
954 .name = name_comp1,
955 .vmux = 1,
956 .amux = LINE1,
957 },{
958 .name = name_svideo,
959 .vmux = 8,
960 .amux = LINE1,
961 },{
962 .name = name_tv,
963 .vmux = 3,
964 .amux = TV,
965 .tv = 1,
966 }},
967 .mpeg = SAA7134_MPEG_EMPRESS,
968 .video_out = CCIR656,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -0700969 },
970 [SAA7134_BOARD_ASUSTEK_TVFM7133] = {
971 .name = "ASUS TV-FM 7133",
972 .audio_clock = 0x00187de7,
973 /* probably wrong, the 7133 one is the NTSC version ...
974 * .tuner_type = TUNER_PHILIPS_FM1236_MK3 */
975 .tuner_type = TUNER_LG_NTSC_NEW_TAPC,
976 .radio_type = UNSET,
977 .tuner_addr = ADDR_UNSET,
978 .radio_addr = ADDR_UNSET,
979 .tda9887_conf = TDA9887_PRESENT,
980 .inputs = {{
981 .name = name_tv,
982 .vmux = 1,
983 .amux = TV,
984 .tv = 1,
985
Linus Torvalds1da177e2005-04-16 15:20:36 -0700986 },{
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -0700987 .name = name_comp1,
988 .vmux = 4,
989 .amux = LINE2,
990 },{
991 .name = name_svideo,
992 .vmux = 6,
993 .amux = LINE2,
994 }},
995 .radio = {
996 .name = name_radio,
997 .amux = LINE1,
998 },
999 },
Linus Torvalds1da177e2005-04-16 15:20:36 -07001000 [SAA7134_BOARD_PINNACLE_PCTV_STEREO] = {
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07001001 .name = "Pinnacle PCTV Stereo (saa7134)",
1002 .audio_clock = 0x00187de7,
1003 .tuner_type = TUNER_MT2032,
1004 .radio_type = UNSET,
1005 .tuner_addr = ADDR_UNSET,
1006 .radio_addr = ADDR_UNSET,
Hartmut Hackmanndf8cf702006-03-03 12:09:26 -03001007 .tda9887_conf = TDA9887_PRESENT | TDA9887_INTERCARRIER | TDA9887_PORT2_INACTIVE,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07001008 .inputs = {{
1009 .name = name_tv,
1010 .vmux = 3,
1011 .amux = TV,
1012 .tv = 1,
1013 },{
1014 .name = name_comp1,
1015 .vmux = 0,
1016 .amux = LINE2,
1017 },{
1018 .name = name_comp2,
1019 .vmux = 1,
1020 .amux = LINE2,
1021 },{
1022 .name = name_svideo,
1023 .vmux = 8,
1024 .amux = LINE2,
1025 }},
1026 },
Linus Torvalds1da177e2005-04-16 15:20:36 -07001027 [SAA7134_BOARD_MANLI_MTV002] = {
1028 /* Ognjen Nastic <ognjen@logosoft.ba> */
Mauro Carvalho Chehabac19ecc2005-06-23 22:05:09 -07001029 .name = "Manli MuchTV M-TV002/Behold TV 403 FM",
Linus Torvalds1da177e2005-04-16 15:20:36 -07001030 .audio_clock = 0x00200000,
1031 .tuner_type = TUNER_PHILIPS_PAL,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07001032 .radio_type = UNSET,
1033 .tuner_addr = ADDR_UNSET,
1034 .radio_addr = ADDR_UNSET,
Linus Torvalds1da177e2005-04-16 15:20:36 -07001035 .inputs = {{
1036 .name = name_svideo,
1037 .vmux = 8,
1038 .amux = LINE1,
1039 },{
1040 .name = name_comp1,
1041 .vmux = 1,
1042 .amux = LINE1,
1043 },{
1044 .name = name_tv,
1045 .vmux = 3,
1046 .amux = LINE2,
1047 .tv = 1,
1048 }},
1049 .radio = {
1050 .name = name_radio,
1051 .amux = LINE2,
1052 },
Linus Torvalds1da177e2005-04-16 15:20:36 -07001053 },
1054 [SAA7134_BOARD_MANLI_MTV001] = {
1055 /* Ognjen Nastic <ognjen@logosoft.ba> UNTESTED */
Mauro Carvalho Chehabac19ecc2005-06-23 22:05:09 -07001056 .name = "Manli MuchTV M-TV001/Behold TV 401",
Linus Torvalds1da177e2005-04-16 15:20:36 -07001057 .audio_clock = 0x00200000,
1058 .tuner_type = TUNER_PHILIPS_PAL,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07001059 .radio_type = UNSET,
1060 .tuner_addr = ADDR_UNSET,
1061 .radio_addr = ADDR_UNSET,
Linus Torvalds1da177e2005-04-16 15:20:36 -07001062 .inputs = {{
1063 .name = name_svideo,
1064 .vmux = 8,
1065 .amux = LINE1,
1066 },{
1067 .name = name_comp1,
1068 .vmux = 1,
1069 .amux = LINE1,
1070 },{
1071 .name = name_tv,
1072 .vmux = 3,
1073 .amux = LINE2,
1074 .tv = 1,
1075 }},
Mauro Carvalho Chehabac19ecc2005-06-23 22:05:09 -07001076 .mute = {
1077 .name = name_mute,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07001078 .amux = LINE1,
Mauro Carvalho Chehabac19ecc2005-06-23 22:05:09 -07001079 },
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07001080 },
Linus Torvalds1da177e2005-04-16 15:20:36 -07001081 [SAA7134_BOARD_TG3000TV] = {
1082 /* TransGear 3000TV */
1083 .name = "Nagase Sangyo TransGear 3000TV",
1084 .audio_clock = 0x00187de7,
1085 .tuner_type = TUNER_PHILIPS_NTSC_M,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07001086 .radio_type = UNSET,
1087 .tuner_addr = ADDR_UNSET,
1088 .radio_addr = ADDR_UNSET,
Linus Torvalds1da177e2005-04-16 15:20:36 -07001089 .inputs = {{
1090 .name = name_tv,
1091 .vmux = 1,
1092 .amux = LINE2,
1093 .tv = 1,
1094 },{
1095 .name = name_comp1,
1096 .vmux = 3,
1097 .amux = LINE2,
1098 },{
1099 .name = name_svideo,
1100 .vmux = 8,
1101 .amux = LINE2,
1102 }},
1103 },
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07001104 [SAA7134_BOARD_ECS_TVP3XP] = {
1105 .name = "Elitegroup ECS TVP3XP FM1216 Tuner Card(PAL-BG,FM) ",
1106 .audio_clock = 0x187de7, /* xtal 32.1 MHz */
1107 .tuner_type = TUNER_PHILIPS_PAL,
1108 .radio_type = UNSET,
1109 .tuner_addr = ADDR_UNSET,
1110 .radio_addr = ADDR_UNSET,
1111 .inputs = {{
1112 .name = name_tv,
1113 .vmux = 1,
1114 .amux = TV,
1115 .tv = 1,
1116 },{
1117 .name = name_tv_mono,
1118 .vmux = 1,
1119 .amux = LINE2,
1120 .tv = 1,
1121 },{
1122 .name = name_comp1,
1123 .vmux = 3,
1124 .amux = LINE1,
1125 },{
1126 .name = name_svideo,
1127 .vmux = 8,
1128 .amux = LINE1,
Linus Torvalds1da177e2005-04-16 15:20:36 -07001129 },{
1130 .name = "CVid over SVid",
1131 .vmux = 0,
1132 .amux = LINE1,
1133 }},
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07001134 .radio = {
1135 .name = name_radio,
1136 .amux = LINE2,
1137 },
1138 },
1139 [SAA7134_BOARD_ECS_TVP3XP_4CB5] = {
1140 .name = "Elitegroup ECS TVP3XP FM1236 Tuner Card (NTSC,FM)",
1141 .audio_clock = 0x187de7,
1142 .tuner_type = TUNER_PHILIPS_NTSC,
1143 .radio_type = UNSET,
1144 .tuner_addr = ADDR_UNSET,
1145 .radio_addr = ADDR_UNSET,
1146 .inputs = {{
1147 .name = name_tv,
1148 .vmux = 1,
1149 .amux = TV,
1150 .tv = 1,
1151 },{
1152 .name = name_tv_mono,
1153 .vmux = 1,
1154 .amux = LINE2,
1155 .tv = 1,
1156 },{
1157 .name = name_comp1,
1158 .vmux = 3,
1159 .amux = LINE1,
1160 },{
1161 .name = name_svideo,
1162 .vmux = 8,
1163 .amux = LINE1,
1164 },{
1165 .name = "CVid over SVid",
1166 .vmux = 0,
1167 .amux = LINE1,
1168 }},
1169 .radio = {
1170 .name = name_radio,
1171 .amux = LINE2,
1172 },
1173 },
Simon Farnsworthb39423a2007-05-01 10:01:20 -03001174 [SAA7134_BOARD_ECS_TVP3XP_4CB6] = {
1175 /* Barry Scott <barry.scott@onelan.co.uk> */
1176 .name = "Elitegroup ECS TVP3XP FM1246 Tuner Card (PAL,FM)",
1177 .audio_clock = 0x187de7,
1178 .tuner_type = TUNER_PHILIPS_PAL_I,
1179 .radio_type = UNSET,
1180 .tuner_addr = ADDR_UNSET,
1181 .radio_addr = ADDR_UNSET,
1182 .inputs = {{
1183 .name = name_tv,
1184 .vmux = 1,
1185 .amux = TV,
1186 .tv = 1,
1187 },{
1188 .name = name_tv_mono,
1189 .vmux = 1,
1190 .amux = LINE2,
1191 .tv = 1,
1192 },{
1193 .name = name_comp1,
1194 .vmux = 3,
1195 .amux = LINE1,
1196 },{
1197 .name = name_svideo,
1198 .vmux = 8,
1199 .amux = LINE1,
1200 },{
1201 .name = "CVid over SVid",
1202 .vmux = 0,
1203 .amux = LINE1,
1204 }},
1205 .radio = {
1206 .name = name_radio,
1207 .amux = LINE2,
1208 },
1209 },
Linus Torvalds1da177e2005-04-16 15:20:36 -07001210 [SAA7134_BOARD_AVACSSMARTTV] = {
1211 /* Roman Pszonczenko <romka@kolos.math.uni.lodz.pl> */
1212 .name = "AVACS SmartTV",
1213 .audio_clock = 0x00187de7,
1214 .tuner_type = TUNER_PHILIPS_PAL,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07001215 .radio_type = UNSET,
1216 .tuner_addr = ADDR_UNSET,
1217 .radio_addr = ADDR_UNSET,
Linus Torvalds1da177e2005-04-16 15:20:36 -07001218 .inputs = {{
1219 .name = name_tv,
1220 .vmux = 1,
1221 .amux = TV,
1222 .tv = 1,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07001223 },{
Linus Torvalds1da177e2005-04-16 15:20:36 -07001224 .name = name_tv_mono,
1225 .vmux = 1,
1226 .amux = LINE2,
1227 .tv = 1,
1228 },{
1229 .name = name_comp1,
1230 .vmux = 0,
1231 .amux = LINE2,
1232 },{
1233 .name = name_comp2,
1234 .vmux = 3,
1235 .amux = LINE2,
1236 },{
1237 .name = name_svideo,
1238 .vmux = 8,
1239 .amux = LINE2,
1240 }},
1241 .radio = {
1242 .name = name_radio,
1243 .amux = LINE2,
1244 .gpio = 0x200000,
1245 },
1246 },
1247 [SAA7134_BOARD_AVERMEDIA_DVD_EZMAKER] = {
1248 /* Michael Smith <msmith@cbnco.com> */
1249 .name = "AVerMedia DVD EZMaker",
1250 .audio_clock = 0x00187de7,
1251 .tuner_type = TUNER_ABSENT,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07001252 .radio_type = UNSET,
1253 .tuner_addr = ADDR_UNSET,
1254 .radio_addr = ADDR_UNSET,
Linus Torvalds1da177e2005-04-16 15:20:36 -07001255 .inputs = {{
1256 .name = name_comp1,
1257 .vmux = 3,
1258 },{
1259 .name = name_svideo,
1260 .vmux = 8,
1261 }},
1262 },
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07001263 [SAA7134_BOARD_NOVAC_PRIMETV7133] = {
1264 /* toshii@netbsd.org */
1265 .name = "Noval Prime TV 7133",
1266 .audio_clock = 0x00200000,
1267 .tuner_type = TUNER_ALPS_TSBH1_NTSC,
1268 .radio_type = UNSET,
1269 .tuner_addr = ADDR_UNSET,
1270 .radio_addr = ADDR_UNSET,
1271 .inputs = {{
1272 .name = name_comp1,
1273 .vmux = 3,
1274 },{
1275 .name = name_tv,
1276 .vmux = 1,
1277 .amux = TV,
1278 .tv = 1,
1279 },{
1280 .name = name_svideo,
1281 .vmux = 8,
1282 }},
1283 },
Linus Torvalds1da177e2005-04-16 15:20:36 -07001284 [SAA7134_BOARD_AVERMEDIA_STUDIO_305] = {
1285 .name = "AverMedia AverTV Studio 305",
1286 .audio_clock = 0x00187de7,
1287 .tuner_type = TUNER_PHILIPS_FM1256_IH3,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07001288 .radio_type = UNSET,
1289 .tuner_addr = ADDR_UNSET,
1290 .radio_addr = ADDR_UNSET,
Linus Torvalds1da177e2005-04-16 15:20:36 -07001291 .tda9887_conf = TDA9887_PRESENT,
Linus Torvalds1da177e2005-04-16 15:20:36 -07001292 .inputs = {{
1293 .name = name_tv,
1294 .vmux = 1,
1295 .amux = LINE2,
1296 .tv = 1,
1297 },{
1298 .name = name_comp1,
1299 .vmux = 0,
1300 .amux = LINE2,
1301 },{
1302 .name = name_comp2,
1303 .vmux = 3,
1304 .amux = LINE2,
1305 },{
1306 .name = name_svideo,
1307 .vmux = 8,
1308 .amux = LINE2,
1309 }},
1310 .radio = {
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07001311 .name = name_radio,
1312 .amux = LINE2,
1313 },
Linus Torvalds1da177e2005-04-16 15:20:36 -07001314 .mute = {
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07001315 .name = name_mute,
1316 .amux = LINE1,
Linus Torvalds1da177e2005-04-16 15:20:36 -07001317 },
1318 },
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07001319 [SAA7134_BOARD_UPMOST_PURPLE_TV] = {
1320 .name = "UPMOST PURPLE TV",
1321 .audio_clock = 0x00187de7,
1322 .tuner_type = TUNER_PHILIPS_FM1236_MK3,
1323 .radio_type = UNSET,
1324 .tuner_addr = ADDR_UNSET,
1325 .radio_addr = ADDR_UNSET,
1326 .tda9887_conf = TDA9887_PRESENT,
1327 .inputs = {{
1328 .name = name_tv,
1329 .vmux = 7,
1330 .amux = TV,
1331 .tv = 1,
1332 },{
1333 .name = name_svideo,
1334 .vmux = 7,
1335 .amux = LINE1,
1336 }},
Linus Torvalds1da177e2005-04-16 15:20:36 -07001337 },
1338 [SAA7134_BOARD_ITEMS_MTV005] = {
1339 /* Norman Jonas <normanjonas@arcor.de> */
1340 .name = "Items MuchTV Plus / IT-005",
1341 .audio_clock = 0x00187de7,
1342 .tuner_type = TUNER_PHILIPS_PAL,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07001343 .radio_type = UNSET,
1344 .tuner_addr = ADDR_UNSET,
1345 .radio_addr = ADDR_UNSET,
Linus Torvalds1da177e2005-04-16 15:20:36 -07001346 .inputs = {{
1347 .name = name_tv,
1348 .vmux = 3,
1349 .amux = TV,
1350 .tv = 1,
1351 },{
1352 .name = name_comp1,
1353 .vmux = 1,
1354 .amux = LINE1,
1355 },{
1356 .name = name_svideo,
1357 .vmux = 8,
1358 .amux = LINE1,
1359 }},
1360 .radio = {
1361 .name = name_radio,
1362 .amux = LINE2,
1363 },
1364 },
1365 [SAA7134_BOARD_CINERGY200] = {
1366 .name = "Terratec Cinergy 200 TV",
1367 .audio_clock = 0x00200000,
1368 .tuner_type = TUNER_PHILIPS_PAL,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07001369 .radio_type = UNSET,
1370 .tuner_addr = ADDR_UNSET,
1371 .radio_addr = ADDR_UNSET,
Linus Torvalds1da177e2005-04-16 15:20:36 -07001372 .inputs = {{
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07001373 .name = name_tv,
Linus Torvalds1da177e2005-04-16 15:20:36 -07001374 .vmux = 1,
1375 .amux = LINE2,
1376 .tv = 1,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07001377 },{
1378 .name = name_comp1,
1379 .vmux = 4,
1380 .amux = LINE1,
1381 },{
1382 .name = name_svideo,
1383 .vmux = 8,
1384 .amux = LINE1,
1385 },{
1386 .name = name_comp2, /* CVideo over SVideo Connector */
1387 .vmux = 0,
1388 .amux = LINE1,
Linus Torvalds1da177e2005-04-16 15:20:36 -07001389 }},
1390 .mute = {
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07001391 .name = name_mute,
1392 .amux = LINE2,
Linus Torvalds1da177e2005-04-16 15:20:36 -07001393 },
1394 },
1395 [SAA7134_BOARD_VIDEOMATE_TV_PVR] = {
1396 /* Alain St-Denis <alain@topaze.homeip.net> */
1397 .name = "Compro VideoMate TV PVR/FM",
1398 .audio_clock = 0x00187de7,
1399 .tuner_type = TUNER_PHILIPS_NTSC_M,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07001400 .radio_type = UNSET,
1401 .tuner_addr = ADDR_UNSET,
1402 .radio_addr = ADDR_UNSET,
Linus Torvalds1da177e2005-04-16 15:20:36 -07001403 .gpiomask = 0x808c0080,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07001404 .inputs = {{
1405 .name = name_svideo,
1406 .vmux = 8,
1407 .amux = LINE1,
Linus Torvalds1da177e2005-04-16 15:20:36 -07001408 .gpio = 0x00080,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07001409 },{
1410 .name = name_comp1,
1411 .vmux = 3,
1412 .amux = LINE1,
Linus Torvalds1da177e2005-04-16 15:20:36 -07001413 .gpio = 0x00080,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07001414 },{
1415 .name = name_tv,
1416 .vmux = 1,
1417 .amux = LINE2_LEFT,
1418 .tv = 1,
Linus Torvalds1da177e2005-04-16 15:20:36 -07001419 .gpio = 0x00080,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07001420 }},
Linus Torvalds1da177e2005-04-16 15:20:36 -07001421 .radio = {
1422 .name = name_radio,
1423 .amux = LINE2,
1424 .gpio = 0x80000,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07001425 },
Linus Torvalds1da177e2005-04-16 15:20:36 -07001426 .mute = {
1427 .name = name_mute,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07001428 .amux = LINE2,
Linus Torvalds1da177e2005-04-16 15:20:36 -07001429 .gpio = 0x40000,
1430 },
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07001431 },
1432 [SAA7134_BOARD_SABRENT_SBTTVFM] = {
Linus Torvalds1da177e2005-04-16 15:20:36 -07001433 /* Michael Rodriguez-Torrent <mrtorrent@asu.edu> */
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07001434 .name = "Sabrent SBT-TVFM (saa7130)",
1435 .audio_clock = 0x00187de7,
1436 .tuner_type = TUNER_PHILIPS_NTSC_M,
1437 .radio_type = UNSET,
1438 .tuner_addr = ADDR_UNSET,
1439 .radio_addr = ADDR_UNSET,
1440 .inputs = {{
Linus Torvalds1da177e2005-04-16 15:20:36 -07001441 .name = name_comp1,
1442 .vmux = 1,
Mauro Carvalho Chehab6a989d72005-09-09 13:03:57 -07001443 .amux = LINE1,
Linus Torvalds1da177e2005-04-16 15:20:36 -07001444 },{
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07001445 .name = name_tv,
1446 .vmux = 3,
1447 .amux = LINE2,
1448 .tv = 1,
1449 },{
1450 .name = name_svideo,
1451 .vmux = 8,
Mauro Carvalho Chehab6a989d72005-09-09 13:03:57 -07001452 .amux = LINE1,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07001453 }},
1454 .radio = {
1455 .name = name_radio,
1456 .amux = LINE2,
1457 },
1458 },
Linus Torvalds1da177e2005-04-16 15:20:36 -07001459 [SAA7134_BOARD_ZOLID_XPERT_TV7134] = {
1460 /* Helge Jensen <helge.jensen@slog.dk> */
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07001461 .name = ":Zolid Xpert TV7134",
Linus Torvalds1da177e2005-04-16 15:20:36 -07001462 .audio_clock = 0x00187de7,
1463 .tuner_type = TUNER_PHILIPS_NTSC,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07001464 .radio_type = UNSET,
1465 .tuner_addr = ADDR_UNSET,
1466 .radio_addr = ADDR_UNSET,
1467 .inputs = {{
Linus Torvalds1da177e2005-04-16 15:20:36 -07001468 .name = name_svideo,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07001469 .vmux = 8,
1470 .amux = LINE1,
1471 },{
1472 .name = name_comp1,
1473 .vmux = 3,
1474 .amux = LINE1,
1475 },{
1476 .name = name_tv,
1477 .vmux = 1,
1478 .amux = LINE2,
1479 .tv = 1,
1480 }},
Linus Torvalds1da177e2005-04-16 15:20:36 -07001481 },
1482 [SAA7134_BOARD_EMPIRE_PCI_TV_RADIO_LE] = {
1483 /* "Matteo Az" <matte.az@nospam.libero.it> ;-) */
1484 .name = "Empire PCI TV-Radio LE",
1485 .audio_clock = 0x00187de7,
1486 .tuner_type = TUNER_PHILIPS_PAL,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07001487 .radio_type = UNSET,
1488 .tuner_addr = ADDR_UNSET,
1489 .radio_addr = ADDR_UNSET,
Linus Torvalds1da177e2005-04-16 15:20:36 -07001490 .gpiomask = 0x4000,
1491 .inputs = {{
1492 .name = name_tv_mono,
1493 .vmux = 1,
1494 .amux = LINE2,
1495 .gpio = 0x8000,
1496 .tv = 1,
1497 },{
1498 .name = name_comp1,
1499 .vmux = 3,
1500 .amux = LINE1,
1501 .gpio = 0x8000,
1502 },{
1503 .name = name_svideo,
1504 .vmux = 6,
1505 .amux = LINE1,
1506 .gpio = 0x8000,
1507 }},
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07001508 .radio = {
1509 .name = name_radio,
1510 .amux = LINE1,
1511 .gpio = 0x8000,
1512 },
Linus Torvalds1da177e2005-04-16 15:20:36 -07001513 .mute = {
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07001514 .name = name_mute,
1515 .amux = TV,
1516 .gpio =0x8000,
1517 }
Linus Torvalds1da177e2005-04-16 15:20:36 -07001518 },
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07001519 [SAA7134_BOARD_AVERMEDIA_STUDIO_307] = {
Linus Torvalds1da177e2005-04-16 15:20:36 -07001520 /*
1521 Nickolay V. Shmyrev <nshmyrev@yandex.ru>
1522 Lots of thanks to Andrey Zolotarev <zolotarev_andrey@mail.ru>
1523 */
1524 .name = "Avermedia AVerTV Studio 307",
1525 .audio_clock = 0x00187de7,
1526 .tuner_type = TUNER_PHILIPS_FM1256_IH3,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07001527 .radio_type = UNSET,
1528 .tuner_addr = ADDR_UNSET,
1529 .radio_addr = ADDR_UNSET,
Linus Torvalds1da177e2005-04-16 15:20:36 -07001530 .tda9887_conf = TDA9887_PRESENT,
1531 .gpiomask = 0x03,
1532 .inputs = {{
1533 .name = name_tv,
1534 .vmux = 1,
1535 .amux = TV,
1536 .tv = 1,
1537 .gpio = 0x00,
1538 },{
Stas Sergeevf438d972007-09-17 15:34:09 -03001539 .name = name_comp,
Linus Torvalds1da177e2005-04-16 15:20:36 -07001540 .vmux = 3,
Stas Sergeevf5e4fee2007-09-02 03:56:18 -03001541 .amux = LINE1,
1542 .gpio = 0x02,
Linus Torvalds1da177e2005-04-16 15:20:36 -07001543 },{
1544 .name = name_svideo,
1545 .vmux = 8,
Stas Sergeevf5e4fee2007-09-02 03:56:18 -03001546 .amux = LINE1,
1547 .gpio = 0x02,
Linus Torvalds1da177e2005-04-16 15:20:36 -07001548 }},
1549 .radio = {
1550 .name = name_radio,
1551 .amux = LINE1,
1552 .gpio = 0x01,
1553 },
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07001554 .mute = {
1555 .name = name_mute,
1556 .amux = LINE1,
1557 .gpio = 0x00,
1558 },
1559 },
1560 [SAA7134_BOARD_AVERMEDIA_GO_007_FM] = {
Mauro Carvalho Chehabac19ecc2005-06-23 22:05:09 -07001561 .name = "Avermedia AVerTV GO 007 FM",
1562 .audio_clock = 0x00187de7,
1563 .tuner_type = TUNER_PHILIPS_TDA8290,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07001564 .radio_type = UNSET,
1565 .tuner_addr = ADDR_UNSET,
1566 .radio_addr = ADDR_UNSET,
Mauro Carvalho Chehabac19ecc2005-06-23 22:05:09 -07001567 .gpiomask = 0x00300003,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07001568 /* .gpiomask = 0x8c240003, */
Mauro Carvalho Chehabac19ecc2005-06-23 22:05:09 -07001569 .inputs = {{
1570 .name = name_tv,
1571 .vmux = 1,
1572 .amux = TV,
1573 .tv = 1,
1574 .gpio = 0x01,
1575 },{
1576 .name = name_comp1,
1577 .vmux = 0,
Damian Minkovfbc84082007-03-29 08:47:39 -03001578 .amux = LINE1,
Mauro Carvalho Chehabac19ecc2005-06-23 22:05:09 -07001579 .gpio = 0x02,
1580 },{
1581 .name = name_svideo,
1582 .vmux = 6,
Damian Minkovfbc84082007-03-29 08:47:39 -03001583 .amux = LINE1,
Mauro Carvalho Chehabac19ecc2005-06-23 22:05:09 -07001584 .gpio = 0x02,
1585 }},
1586 .radio = {
1587 .name = name_radio,
1588 .amux = LINE1,
1589 .gpio = 0x00300001,
1590 },
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07001591 .mute = {
1592 .name = name_mute,
1593 .amux = TV,
1594 .gpio = 0x01,
1595 },
1596 },
Linus Torvalds1da177e2005-04-16 15:20:36 -07001597 [SAA7134_BOARD_AVERMEDIA_CARDBUS] = {
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07001598 /* Kees.Blom@cwi.nl */
1599 .name = "AVerMedia Cardbus TV/Radio (E500)",
1600 .audio_clock = 0x187de7,
1601 .tuner_type = TUNER_PHILIPS_TDA8290,
1602 .radio_type = UNSET,
1603 .tuner_addr = ADDR_UNSET,
1604 .radio_addr = ADDR_UNSET,
Linus Torvalds1da177e2005-04-16 15:20:36 -07001605 .inputs = {{
1606 .name = name_tv,
1607 .vmux = 1,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07001608 .amux = TV,
Linus Torvalds1da177e2005-04-16 15:20:36 -07001609 .tv = 1,
1610 },{
1611 .name = name_comp1,
1612 .vmux = 3,
1613 .amux = LINE2,
1614 },{
1615 .name = name_svideo,
1616 .vmux = 8,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07001617 .amux = LINE1,
Linus Torvalds1da177e2005-04-16 15:20:36 -07001618 }},
1619 .radio = {
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07001620 .name = name_radio,
Linus Torvalds1da177e2005-04-16 15:20:36 -07001621 .amux = LINE1,
1622 },
1623 },
1624 [SAA7134_BOARD_CINERGY400_CARDBUS] = {
1625 .name = "Terratec Cinergy 400 mobile",
1626 .audio_clock = 0x187de7,
1627 .tuner_type = TUNER_ALPS_TSBE5_PAL,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07001628 .radio_type = UNSET,
1629 .tuner_addr = ADDR_UNSET,
1630 .radio_addr = ADDR_UNSET,
1631 .tda9887_conf = TDA9887_PRESENT,
Linus Torvalds1da177e2005-04-16 15:20:36 -07001632 .inputs = {{
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07001633 .name = name_tv,
Linus Torvalds1da177e2005-04-16 15:20:36 -07001634 .vmux = 1,
1635 .amux = TV,
1636 .tv = 1,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07001637 },{
Linus Torvalds1da177e2005-04-16 15:20:36 -07001638 .name = name_tv_mono,
1639 .vmux = 1,
1640 .amux = LINE2,
1641 .tv = 1,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07001642 },{
1643 .name = name_comp1,
1644 .vmux = 3,
1645 .amux = LINE1,
1646 },{
1647 .name = name_svideo,
1648 .vmux = 8,
1649 .amux = LINE1,
Linus Torvalds1da177e2005-04-16 15:20:36 -07001650 }},
1651 },
1652 [SAA7134_BOARD_CINERGY600_MK3] = {
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07001653 .name = "Terratec Cinergy 600 TV MK3",
1654 .audio_clock = 0x00200000,
Linus Torvalds1da177e2005-04-16 15:20:36 -07001655 .tuner_type = TUNER_PHILIPS_FM1216ME_MK3,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07001656 .radio_type = UNSET,
1657 .tuner_addr = ADDR_UNSET,
1658 .radio_addr = ADDR_UNSET,
1659 .tda9887_conf = TDA9887_PRESENT,
1660 .inputs = {{
1661 .name = name_tv,
1662 .vmux = 1,
1663 .amux = TV,
1664 .tv = 1,
1665 },{
1666 .name = name_comp1,
1667 .vmux = 4,
1668 .amux = LINE1,
1669 },{
1670 .name = name_svideo,
1671 .vmux = 8,
1672 .amux = LINE1,
1673 },{
1674 .name = name_comp2, /* CVideo over SVideo Connector */
1675 .vmux = 0,
1676 .amux = LINE1,
1677 }},
Linus Torvalds1da177e2005-04-16 15:20:36 -07001678 .radio = {
1679 .name = name_radio,
1680 .amux = LINE2,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07001681 },
1682 },
1683 [SAA7134_BOARD_VIDEOMATE_GOLD_PLUS] = {
1684 /* Dylan Walkden <dylan_walkden@hotmail.com> */
1685 .name = "Compro VideoMate Gold+ Pal",
1686 .audio_clock = 0x00187de7,
1687 .tuner_type = TUNER_PHILIPS_PAL,
1688 .radio_type = UNSET,
1689 .tuner_addr = ADDR_UNSET,
1690 .radio_addr = ADDR_UNSET,
1691 .gpiomask = 0x1ce780,
1692 .inputs = {{
1693 .name = name_svideo,
1694 .vmux = 0, /* CVideo over SVideo Connector - ok? */
1695 .amux = LINE1,
1696 .gpio = 0x008080,
1697 },{
1698 .name = name_comp1,
1699 .vmux = 3,
1700 .amux = LINE1,
1701 .gpio = 0x008080,
1702 },{
1703 .name = name_tv,
1704 .vmux = 1,
1705 .amux = TV,
1706 .tv = 1,
1707 .gpio = 0x008080,
1708 }},
1709 .radio = {
1710 .name = name_radio,
1711 .amux = LINE2,
1712 .gpio = 0x80000,
1713 },
1714 .mute = {
1715 .name = name_mute,
1716 .amux = LINE2,
1717 .gpio = 0x0c8000,
1718 },
1719 },
Linus Torvalds1da177e2005-04-16 15:20:36 -07001720 [SAA7134_BOARD_PINNACLE_300I_DVBT_PAL] = {
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07001721 .name = "Pinnacle PCTV 300i DVB-T + PAL",
1722 .audio_clock = 0x00187de7,
1723 .tuner_type = TUNER_MT2032,
1724 .radio_type = UNSET,
1725 .tuner_addr = ADDR_UNSET,
1726 .radio_addr = ADDR_UNSET,
Hartmut Hackmanndf8cf702006-03-03 12:09:26 -03001727 .tda9887_conf = TDA9887_PRESENT | TDA9887_INTERCARRIER | TDA9887_PORT2_INACTIVE,
Linus Torvalds1da177e2005-04-16 15:20:36 -07001728 .mpeg = SAA7134_MPEG_DVB,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07001729 .inputs = {{
1730 .name = name_tv,
1731 .vmux = 3,
1732 .amux = TV,
1733 .tv = 1,
1734 },{
1735 .name = name_comp1,
1736 .vmux = 0,
1737 .amux = LINE2,
1738 },{
1739 .name = name_comp2,
1740 .vmux = 1,
1741 .amux = LINE2,
1742 },{
1743 .name = name_svideo,
1744 .vmux = 8,
1745 .amux = LINE2,
1746 }},
1747 },
Linus Torvalds1da177e2005-04-16 15:20:36 -07001748 [SAA7134_BOARD_PROVIDEO_PV952] = {
1749 /* andreas.kretschmer@web.de */
1750 .name = "ProVideo PV952",
1751 .audio_clock = 0x00187de7,
1752 .tuner_type = TUNER_PHILIPS_FM1216ME_MK3,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07001753 .radio_type = UNSET,
1754 .tuner_addr = ADDR_UNSET,
1755 .radio_addr = ADDR_UNSET,
Linus Torvalds1da177e2005-04-16 15:20:36 -07001756 .tda9887_conf = TDA9887_PRESENT,
1757 .inputs = {{
1758 .name = name_comp1,
1759 .vmux = 0,
1760 .amux = LINE1,
1761 },{
1762 .name = name_tv,
1763 .vmux = 1,
1764 .amux = TV,
1765 .tv = 1,
1766 },{
1767 .name = name_tv_mono,
1768 .vmux = 1,
1769 .amux = LINE2,
1770 .tv = 1,
1771 }},
1772 .radio = {
1773 .name = name_radio,
1774 .amux = LINE2,
1775 },
1776 },
1777 [SAA7134_BOARD_AVERMEDIA_305] = {
1778 /* much like the "studio" version but without radio
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07001779 * and another tuner (sirspiritus@yandex.ru) */
Linus Torvalds1da177e2005-04-16 15:20:36 -07001780 .name = "AverMedia AverTV/305",
1781 .audio_clock = 0x00187de7,
1782 .tuner_type = TUNER_PHILIPS_FQ1216ME,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07001783 .radio_type = UNSET,
1784 .tuner_addr = ADDR_UNSET,
1785 .radio_addr = ADDR_UNSET,
Linus Torvalds1da177e2005-04-16 15:20:36 -07001786 .tda9887_conf = TDA9887_PRESENT,
Linus Torvalds1da177e2005-04-16 15:20:36 -07001787 .inputs = {{
1788 .name = name_tv,
1789 .vmux = 1,
1790 .amux = LINE2,
1791 .tv = 1,
1792 },{
1793 .name = name_comp1,
1794 .vmux = 0,
1795 .amux = LINE2,
1796 },{
1797 .name = name_comp2,
1798 .vmux = 3,
1799 .amux = LINE2,
1800 },{
1801 .name = name_svideo,
1802 .vmux = 8,
1803 .amux = LINE2,
1804 }},
1805 .mute = {
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07001806 .name = name_mute,
1807 .amux = LINE1,
Linus Torvalds1da177e2005-04-16 15:20:36 -07001808 },
1809 },
1810 [SAA7134_BOARD_FLYDVBTDUO] = {
1811 /* LifeView FlyDVB-T DUO */
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07001812 /* "Nico Sabbi <nsabbi@tiscali.it> Hartmut Hackmann hartmut.hackmann@t-online.de*/
Peter Misseldb483672007-04-27 12:31:20 -03001813 .name = "LifeView FlyDVB-T DUO / MSI TV@nywhere Duo",
Linus Torvalds1da177e2005-04-16 15:20:36 -07001814 .audio_clock = 0x00200000,
1815 .tuner_type = TUNER_PHILIPS_TDA8290,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07001816 .radio_type = UNSET,
1817 .tuner_addr = ADDR_UNSET,
1818 .radio_addr = ADDR_UNSET,
Peter Missel7c7fea62007-04-27 12:31:14 -03001819 .gpiomask = 0x00200000,
Michael Krufky8ce47da2007-04-27 12:31:14 -03001820 .mpeg = SAA7134_MPEG_DVB,
Linus Torvalds1da177e2005-04-16 15:20:36 -07001821 .inputs = {{
1822 .name = name_tv,
1823 .vmux = 1,
1824 .amux = TV,
Peter Missel7c7fea62007-04-27 12:31:14 -03001825 .gpio = 0x200000, /* GPIO21=High for TV input */
Linus Torvalds1da177e2005-04-16 15:20:36 -07001826 .tv = 1,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07001827 },{
Linus Torvalds1da177e2005-04-16 15:20:36 -07001828 .name = name_comp1, /* Composite signal on S-Video input */
1829 .vmux = 0,
1830 .amux = LINE2,
Linus Torvalds1da177e2005-04-16 15:20:36 -07001831 },{
1832 .name = name_comp2, /* Composite input */
1833 .vmux = 3,
1834 .amux = LINE2,
Linus Torvalds1da177e2005-04-16 15:20:36 -07001835 },{
1836 .name = name_svideo, /* S-Video signal on S-Video input */
1837 .vmux = 8,
1838 .amux = LINE2,
Linus Torvalds1da177e2005-04-16 15:20:36 -07001839 }},
Peter Missel7c7fea62007-04-27 12:31:14 -03001840 .radio = {
1841 .name = name_radio,
1842 .amux = TV,
1843 .gpio = 0x000000, /* GPIO21=Low for FM radio antenna */
1844 },
Linus Torvalds1da177e2005-04-16 15:20:36 -07001845 },
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07001846 [SAA7134_BOARD_PHILIPS_TOUGH] = {
1847 .name = "Philips TOUGH DVB-T reference design",
1848 .tuner_type = TUNER_ABSENT,
Mauro Carvalho Chehabac19ecc2005-06-23 22:05:09 -07001849 .audio_clock = 0x00187de7,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07001850 .radio_type = UNSET,
1851 .tuner_addr = ADDR_UNSET,
1852 .radio_addr = ADDR_UNSET,
1853 .mpeg = SAA7134_MPEG_DVB,
1854 .inputs = {{
1855 .name = name_comp1,
1856 .vmux = 0,
1857 .amux = LINE1,
1858 },{
1859 .name = name_svideo,
1860 .vmux = 8,
1861 .amux = LINE1,
1862 }},
Mauro Carvalho Chehabac19ecc2005-06-23 22:05:09 -07001863 },
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07001864 [SAA7134_BOARD_AVERMEDIA_307] = {
1865 /*
1866 Davydov Vladimir <vladimir@iqmedia.com>
1867 */
1868 .name = "Avermedia AVerTV 307",
1869 .audio_clock = 0x00187de7,
1870 .tuner_type = TUNER_PHILIPS_FQ1216ME,
1871 .radio_type = UNSET,
1872 .tuner_addr = ADDR_UNSET,
1873 .radio_addr = ADDR_UNSET,
1874 .tda9887_conf = TDA9887_PRESENT,
1875 .inputs = {{
1876 .name = name_tv,
1877 .vmux = 1,
1878 .amux = TV,
1879 .tv = 1,
1880 },{
1881 .name = name_comp1,
1882 .vmux = 0,
1883 .amux = LINE1,
1884 },{
1885 .name = name_comp2,
1886 .vmux = 3,
1887 .amux = LINE1,
1888 },{
1889 .name = name_svideo,
1890 .vmux = 8,
1891 .amux = LINE1,
1892 }},
1893 },
1894 [SAA7134_BOARD_ADS_INSTANT_TV] = {
1895 .name = "ADS Tech Instant TV (saa7135)",
1896 .audio_clock = 0x00187de7,
1897 .tuner_type = TUNER_PHILIPS_TDA8290,
1898 .radio_type = UNSET,
1899 .tuner_addr = ADDR_UNSET,
1900 .radio_addr = ADDR_UNSET,
1901 .inputs = {{
1902 .name = name_tv,
1903 .vmux = 1,
1904 .amux = TV,
1905 .tv = 1,
1906 },{
1907 .name = name_comp1,
1908 .vmux = 3,
1909 .amux = LINE2,
1910 },{
1911 .name = name_svideo,
1912 .vmux = 8,
1913 .amux = LINE2,
1914 }},
1915 },
1916 [SAA7134_BOARD_KWORLD_VSTREAM_XPERT] = {
1917 .name = "Kworld/Tevion V-Stream Xpert TV PVR7134",
1918 .audio_clock = 0x00187de7,
1919 .tuner_type = TUNER_PHILIPS_PAL_I,
1920 .radio_type = UNSET,
1921 .tuner_addr = ADDR_UNSET,
1922 .radio_addr = ADDR_UNSET,
1923 .gpiomask = 0x0700,
1924 .inputs = {{
1925 .name = name_tv,
1926 .vmux = 1,
1927 .amux = TV,
1928 .tv = 1,
1929 .gpio = 0x000,
1930 },{
1931 .name = name_comp1,
1932 .vmux = 3,
1933 .amux = LINE1,
1934 .gpio = 0x200, /* gpio by DScaler */
1935 },{
1936 .name = name_svideo,
1937 .vmux = 0,
1938 .amux = LINE1,
1939 .gpio = 0x200,
1940 }},
1941 .radio = {
1942 .name = name_radio,
1943 .amux = LINE1,
1944 .gpio = 0x100,
1945 },
1946 .mute = {
1947 .name = name_mute,
1948 .amux = TV,
1949 .gpio = 0x000,
1950 },
1951 },
Peter Missel10b7a902006-01-23 17:11:06 -02001952 [SAA7134_BOARD_FLYDVBT_DUO_CARDBUS] = {
Hartmut Hackmann2c591942006-08-07 14:03:32 -03001953 .name = "LifeView/Typhoon/Genius FlyDVB-T Duo Cardbus",
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07001954 .audio_clock = 0x00200000,
1955 .tuner_type = TUNER_PHILIPS_TDA8290,
1956 .radio_type = UNSET,
1957 .tuner_addr = ADDR_UNSET,
1958 .radio_addr = ADDR_UNSET,
1959 .mpeg = SAA7134_MPEG_DVB,
Peter Missel10b7a902006-01-23 17:11:06 -02001960 .gpiomask = 0x00200000,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07001961 .inputs = {{
1962 .name = name_tv,
1963 .vmux = 1,
1964 .amux = TV,
Peter Missel10b7a902006-01-23 17:11:06 -02001965 .gpio = 0x200000, /* GPIO21=High for TV input */
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07001966 .tv = 1,
1967 },{
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07001968 .name = name_svideo, /* S-Video signal on S-Video input */
1969 .vmux = 8,
1970 .amux = LINE2,
Peter Missel10b7a902006-01-23 17:11:06 -02001971 },{
1972 .name = name_comp1, /* Composite signal on S-Video input */
1973 .vmux = 0,
1974 .amux = LINE2,
1975 },{
1976 .name = name_comp2, /* Composite input */
1977 .vmux = 3,
1978 .amux = LINE2,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07001979 }},
1980 .radio = {
1981 .name = name_radio,
Peter Missel10b7a902006-01-23 17:11:06 -02001982 .amux = TV,
1983 .gpio = 0x000000, /* GPIO21=Low for FM radio antenna */
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07001984 },
1985 },
1986 [SAA7134_BOARD_VIDEOMATE_TV_GOLD_PLUSII] = {
1987 .name = "Compro VideoMate TV Gold+II",
1988 .audio_clock = 0x002187de7,
1989 .tuner_type = TUNER_LG_PAL_NEW_TAPC,
1990 .radio_type = TUNER_TEA5767,
1991 .tuner_addr = 0x63,
1992 .radio_addr = 0x60,
1993 .gpiomask = 0x8c1880,
1994 .inputs = {{
1995 .name = name_svideo,
1996 .vmux = 0,
1997 .amux = LINE1,
1998 .gpio = 0x800800,
1999 },{
2000 .name = name_comp1,
2001 .vmux = 3,
2002 .amux = LINE1,
2003 .gpio = 0x801000,
2004 },{
2005 .name = name_tv,
2006 .vmux = 1,
2007 .amux = TV,
2008 .tv = 1,
2009 .gpio = 0x800000,
2010 }},
2011 .radio = {
2012 .name = name_radio,
2013 .amux = TV,
2014 .gpio = 0x880000,
2015 },
2016 .mute = {
2017 .name = name_mute,
2018 .amux = LINE2,
2019 .gpio = 0x840000,
2020 },
2021 },
2022 [SAA7134_BOARD_KWORLD_XPERT] = {
2023 /*
2024 FIXME:
2025 - Remote control doesn't initialize properly.
2026 - Audio volume starts muted,
2027 then gradually increases after channel change.
2028 - Overlay scaling problems (application error?)
2029 - Composite S-Video untested.
2030 From: Konrad Rzepecki <hannibal@megapolis.pl>
2031 */
2032 .name = "Kworld Xpert TV PVR7134",
2033 .audio_clock = 0x00187de7,
2034 .tuner_type = TUNER_TENA_9533_DI,
2035 .radio_type = TUNER_TEA5767,
2036 .tuner_addr = 0x61,
2037 .radio_addr = 0x60,
2038 .gpiomask = 0x0700,
2039 .inputs = {{
2040 .name = name_tv,
2041 .vmux = 1,
2042 .amux = TV,
2043 .tv = 1,
2044 .gpio = 0x000,
2045 },{
2046 .name = name_comp1,
2047 .vmux = 3,
2048 .amux = LINE1,
2049 .gpio = 0x200, /* gpio by DScaler */
2050 },{
2051 .name = name_svideo,
2052 .vmux = 0,
2053 .amux = LINE1,
2054 .gpio = 0x200,
2055 }},
2056 .radio = {
2057 .name = name_radio,
2058 .amux = LINE1,
2059 .gpio = 0x100,
2060 },
2061 .mute = {
2062 .name = name_mute,
2063 .amux = TV,
2064 .gpio = 0x000,
2065 },
2066 },
Mauro Carvalho Chehab2f180712005-09-09 13:03:46 -07002067 [SAA7134_BOARD_FLYTV_DIGIMATRIX] = {
2068 .name = "FlyTV mini Asus Digimatrix",
2069 .audio_clock = 0x00200000,
Michael Krufkyf3629be2006-03-11 17:02:01 -03002070 .tuner_type = TUNER_LG_TALN,
Mauro Carvalho Chehab2f180712005-09-09 13:03:46 -07002071 .radio_type = UNSET,
2072 .tuner_addr = ADDR_UNSET,
2073 .radio_addr = ADDR_UNSET,
2074 .inputs = {{
2075 .name = name_tv,
2076 .vmux = 1,
2077 .amux = TV,
2078 .tv = 1,
2079 },{
2080 .name = name_tv_mono,
2081 .vmux = 1,
2082 .amux = LINE2,
2083 .tv = 1,
2084 },{
2085 .name = name_comp1,
2086 .vmux = 0,
2087 .amux = LINE2,
2088 },{
2089 .name = name_comp2,
2090 .vmux = 3,
2091 .amux = LINE2,
2092 },{
2093 .name = name_svideo,
2094 .vmux = 8,
2095 .amux = LINE2,
2096 }},
2097 .radio = {
2098 .name = name_radio, /* radio unconfirmed */
2099 .amux = LINE2,
2100 },
2101 },
Mauro Carvalho Chehab260784d2005-09-09 13:03:49 -07002102 [SAA7134_BOARD_KWORLD_TERMINATOR] = {
2103 /* Kworld V-Stream Studio TV Terminator */
2104 /* "James Webb <jrwebb@qwest.net> */
2105 .name = "V-Stream Studio TV Terminator",
2106 .audio_clock = 0x00187de7,
2107 .tuner_type = TUNER_PHILIPS_TDA8290,
2108 .radio_type = UNSET,
2109 .tuner_addr = ADDR_UNSET,
2110 .radio_addr = ADDR_UNSET,
2111 .gpiomask = 1 << 21,
2112 .inputs = {{
2113 .name = name_tv,
2114 .vmux = 1,
2115 .amux = TV,
2116 .gpio = 0x0000000,
2117 .tv = 1,
2118 },{
2119 .name = name_comp1, /* Composite input */
2120 .vmux = 3,
2121 .amux = LINE2,
2122 .gpio = 0x0000000,
2123 },{
2124 .name = name_svideo, /* S-Video input */
2125 .vmux = 8,
2126 .amux = LINE2,
2127 .gpio = 0x0000000,
2128 }},
2129 .radio = {
2130 .name = name_radio,
2131 .amux = TV,
2132 .gpio = 0x0200000,
2133 },
2134 },
Mauro Carvalho Chehab4279f022005-09-09 13:03:51 -07002135 [SAA7134_BOARD_YUAN_TUN900] = {
2136 /* FIXME:
2137 * S-Video and composite sources untested.
2138 * Radio not working.
2139 * Remote control not yet implemented.
2140 * From : codemaster@webgeeks.be */
2141 .name = "Yuan TUN-900 (saa7135)",
2142 .audio_clock = 0x00187de7,
2143 .tuner_type = TUNER_PHILIPS_TDA8290,
2144 .radio_type = UNSET,
2145 .tuner_addr= ADDR_UNSET,
2146 .radio_addr= ADDR_UNSET,
2147 .gpiomask = 0x00010003,
2148 .inputs = {{
2149 .name = name_tv,
2150 .vmux = 1,
2151 .amux = TV,
2152 .tv = 1,
2153 .gpio = 0x01,
2154 },{
2155 .name = name_comp1,
2156 .vmux = 0,
2157 .amux = LINE2,
2158 .gpio = 0x02,
2159 },{
2160 .name = name_svideo,
2161 .vmux = 6,
2162 .amux = LINE2,
2163 .gpio = 0x02,
2164 }},
2165 .radio = {
2166 .name = name_radio,
2167 .amux = LINE1,
2168 .gpio = 0x00010003,
2169 },
2170 .mute = {
2171 .name = name_mute,
2172 .amux = TV,
2173 .gpio = 0x01,
2174 },
2175 },
Nickolay V. Shmyreva8ff4172005-11-08 21:36:16 -08002176 [SAA7134_BOARD_BEHOLD_409FM] = {
Mauro Carvalho Chehab4ac97912005-11-08 21:37:43 -08002177 /* <http://tuner.beholder.ru>, Sergey <skiv@orel.ru> */
2178 .name = "Beholder BeholdTV 409 FM",
2179 .audio_clock = 0x00187de7,
2180 .tuner_type = TUNER_PHILIPS_FM1216ME_MK3,
2181 .radio_type = UNSET,
2182 .tuner_addr = ADDR_UNSET,
2183 .radio_addr = ADDR_UNSET,
2184 .tda9887_conf = TDA9887_PRESENT,
2185 .inputs = {{
2186 .name = name_tv,
Nickolay V. Shmyreva8ff4172005-11-08 21:36:16 -08002187 .vmux = 3,
2188 .amux = TV,
2189 .tv = 1,
2190 },{
2191 .name = name_comp1,
2192 .vmux = 1,
2193 .amux = LINE1,
Mauro Carvalho Chehab4ac97912005-11-08 21:37:43 -08002194 },{
2195 .name = name_svideo,
Nickolay V. Shmyreva8ff4172005-11-08 21:36:16 -08002196 .vmux = 8,
2197 .amux = LINE1,
Mauro Carvalho Chehab4ac97912005-11-08 21:37:43 -08002198 }},
2199 .radio = {
2200 .name = name_radio,
Nickolay V. Shmyreva8ff4172005-11-08 21:36:16 -08002201 .amux = LINE2,
Trent Piepho657de3c2006-06-20 00:30:57 -03002202 },
Mauro Carvalho Chehab4ac97912005-11-08 21:37:43 -08002203 },
2204 [SAA7134_BOARD_GOTVIEW_7135] = {
Nickolay V. Shmyrevdcd555e2005-11-08 21:36:23 -08002205 /* Mike Baikov <mike@baikov.com> */
Nickolay V. Shmyrev6b961442005-11-08 21:36:22 -08002206 /* Andrey Cvetcov <ays14@yandex.ru> */
Mauro Carvalho Chehab4ac97912005-11-08 21:37:43 -08002207 .name = "GoTView 7135 PCI",
2208 .audio_clock = 0x00187de7,
2209 .tuner_type = TUNER_PHILIPS_FM1216ME_MK3,
2210 .radio_type = UNSET,
2211 .tuner_addr = ADDR_UNSET,
2212 .radio_addr = ADDR_UNSET,
2213 .tda9887_conf = TDA9887_PRESENT,
2214 .gpiomask = 0x00200003,
2215 .inputs = {{
2216 .name = name_tv,
2217 .vmux = 1,
2218 .amux = TV,
2219 .tv = 1,
2220 .gpio = 0x00200003,
2221 },{
2222 .name = name_tv_mono,
2223 .vmux = 1,
2224 .amux = LINE2,
2225 .gpio = 0x00200003,
2226 },{
2227 .name = name_comp1,
2228 .vmux = 3,
2229 .amux = LINE1,
2230 .gpio = 0x00200003,
2231 },{
2232 .name = name_svideo,
2233 .vmux = 8,
2234 .amux = LINE1,
2235 .gpio = 0x00200003,
2236 }},
2237 .radio = {
2238 .name = name_radio,
2239 .amux = LINE2,
2240 .gpio = 0x00200003,
2241 },
2242 .mute = {
2243 .name = name_mute,
2244 .amux = TV,
2245 .gpio = 0x00200003,
2246 },
2247 },
Hartmut Hackmann2cf36ac2005-11-08 21:36:32 -08002248 [SAA7134_BOARD_PHILIPS_EUROPA] = {
2249 .name = "Philips EUROPA V3 reference design",
2250 .audio_clock = 0x00187de7,
2251 .tuner_type = TUNER_PHILIPS_TD1316,
2252 .radio_type = UNSET,
2253 .tuner_addr = 0x61,
2254 .radio_addr = ADDR_UNSET,
Hartmut Hackmann44fd06f2006-02-27 00:09:11 -03002255 .tda9887_conf = TDA9887_PRESENT | TDA9887_PORT1_ACTIVE,
Hartmut Hackmann2cf36ac2005-11-08 21:36:32 -08002256 .mpeg = SAA7134_MPEG_DVB,
2257 .inputs = {{
2258 .name = name_tv,
2259 .vmux = 3,
2260 .amux = TV,
2261 .tv = 1,
2262 },{
2263 .name = name_comp1,
2264 .vmux = 0,
2265 .amux = LINE2,
2266 },{
2267 .name = name_svideo,
2268 .vmux = 8,
2269 .amux = LINE2,
2270 }},
2271 },
2272 [SAA7134_BOARD_VIDEOMATE_DVBT_300] = {
2273 .name = "Compro Videomate DVB-T300",
2274 .audio_clock = 0x00187de7,
2275 .tuner_type = TUNER_PHILIPS_TD1316,
2276 .radio_type = UNSET,
2277 .tuner_addr = 0x61,
2278 .radio_addr = ADDR_UNSET,
Hartmut Hackmann44fd06f2006-02-27 00:09:11 -03002279 .tda9887_conf = TDA9887_PRESENT | TDA9887_PORT1_ACTIVE,
Hartmut Hackmann2cf36ac2005-11-08 21:36:32 -08002280 .mpeg = SAA7134_MPEG_DVB,
2281 .inputs = {{
2282 .name = name_tv,
2283 .vmux = 3,
2284 .amux = TV,
2285 .tv = 1,
2286 },{
2287 .name = name_comp1,
2288 .vmux = 1,
2289 .amux = LINE2,
2290 },{
2291 .name = name_svideo,
2292 .vmux = 8,
2293 .amux = LINE2,
2294 }},
2295 },
2296 [SAA7134_BOARD_VIDEOMATE_DVBT_200] = {
2297 .name = "Compro Videomate DVB-T200",
2298 .tuner_type = TUNER_ABSENT,
2299 .audio_clock = 0x00187de7,
2300 .radio_type = UNSET,
2301 .tuner_addr = ADDR_UNSET,
2302 .radio_addr = ADDR_UNSET,
2303 .mpeg = SAA7134_MPEG_DVB,
2304 .inputs = {{
2305 .name = name_comp1,
2306 .vmux = 0,
2307 .amux = LINE1,
2308 },{
2309 .name = name_svideo,
2310 .vmux = 8,
2311 .amux = LINE1,
2312 }},
2313 },
Mauro Carvalho Chehab4ac97912005-11-08 21:37:43 -08002314 [SAA7134_BOARD_RTD_VFG7350] = {
2315 .name = "RTD Embedded Technologies VFG7350",
2316 .audio_clock = 0x00200000,
2317 .tuner_type = TUNER_ABSENT,
2318 .radio_type = UNSET,
2319 .tuner_addr = ADDR_UNSET,
2320 .radio_addr = ADDR_UNSET,
2321 .inputs = {{
2322 .name = "Composite 0",
2323 .vmux = 0,
2324 .amux = LINE1,
2325 },{
2326 .name = "Composite 1",
2327 .vmux = 1,
2328 .amux = LINE2,
2329 },{
2330 .name = "Composite 2",
2331 .vmux = 2,
2332 .amux = LINE1,
2333 },{
2334 .name = "Composite 3",
2335 .vmux = 3,
2336 .amux = LINE2,
2337 },{
2338 .name = "S-Video 0",
2339 .vmux = 8,
2340 .amux = LINE1,
2341 },{
2342 .name = "S-Video 1",
2343 .vmux = 9,
2344 .amux = LINE2,
2345 }},
2346 .mpeg = SAA7134_MPEG_EMPRESS,
2347 .video_out = CCIR656,
Robert W. Boone2f8d4f52005-11-08 21:37:10 -08002348 .vid_port_opts = ( SET_T_CODE_POLARITY_NON_INVERTED |
2349 SET_CLOCK_NOT_DELAYED |
2350 SET_CLOCK_INVERTED |
2351 SET_VSYNC_OFF ),
Mauro Carvalho Chehab4ac97912005-11-08 21:37:43 -08002352 },
2353 [SAA7134_BOARD_RTD_VFG7330] = {
2354 .name = "RTD Embedded Technologies VFG7330",
2355 .audio_clock = 0x00200000,
2356 .tuner_type = TUNER_ABSENT,
2357 .radio_type = UNSET,
2358 .tuner_addr = ADDR_UNSET,
2359 .radio_addr = ADDR_UNSET,
2360 .inputs = {{
2361 .name = "Composite 0",
2362 .vmux = 0,
2363 .amux = LINE1,
2364 },{
2365 .name = "Composite 1",
2366 .vmux = 1,
2367 .amux = LINE2,
2368 },{
2369 .name = "Composite 2",
2370 .vmux = 2,
2371 .amux = LINE1,
2372 },{
2373 .name = "Composite 3",
2374 .vmux = 3,
2375 .amux = LINE2,
2376 },{
2377 .name = "S-Video 0",
2378 .vmux = 8,
2379 .amux = LINE1,
2380 },{
2381 .name = "S-Video 1",
2382 .vmux = 9,
2383 .amux = LINE2,
2384 }},
2385 },
Mauro Carvalho Chehab058afaf2005-11-08 21:36:49 -08002386 [SAA7134_BOARD_FLYTVPLATINUM_MINI2] = {
2387 .name = "LifeView FlyTV Platinum Mini2",
2388 .audio_clock = 0x00200000,
2389 .tuner_type = TUNER_PHILIPS_TDA8290,
2390 .radio_type = UNSET,
2391 .tuner_addr = ADDR_UNSET,
2392 .radio_addr = ADDR_UNSET,
2393
2394 .inputs = {{
2395 .name = name_tv,
2396 .vmux = 1,
2397 .amux = TV,
2398 .tv = 1,
2399 },{
2400 .name = name_comp1, /* Composite signal on S-Video input */
2401 .vmux = 0,
2402 .amux = LINE2,
2403 },{
2404 .name = name_comp2, /* Composite input */
2405 .vmux = 3,
2406 .amux = LINE2,
2407 },{
2408 .name = name_svideo,
2409 .vmux = 8,
2410 .amux = LINE2,
2411 }},
2412 },
Michael Krufky76bc3a32005-11-08 21:37:27 -08002413 [SAA7134_BOARD_AVERMEDIA_AVERTVHD_A180] = {
Michael Krufkyac113d12005-11-08 21:38:21 -08002414 /* Michael Krufky <mkrufky@m1k.net>
2415 * Uses Alps Electric TDHU2, containing NXT2004 ATSC Decoder
2416 * AFAIK, there is no analog demod, thus,
2417 * no support for analog television.
2418 */
Michael Krufky76bc3a32005-11-08 21:37:27 -08002419 .name = "AVerMedia AVerTVHD MCE A180",
2420 .audio_clock = 0x00187de7,
2421 .tuner_type = TUNER_ABSENT,
2422 .radio_type = UNSET,
2423 .tuner_addr = ADDR_UNSET,
2424 .radio_addr = ADDR_UNSET,
Michael Krufky3b64e8e2005-11-08 21:38:20 -08002425 .mpeg = SAA7134_MPEG_DVB,
Michael Krufky76bc3a32005-11-08 21:37:27 -08002426 .inputs = {{
2427 .name = name_comp1,
2428 .vmux = 3,
2429 .amux = LINE2,
2430 },{
2431 .name = name_svideo,
2432 .vmux = 8,
2433 .amux = LINE2,
2434 }},
2435 },
Pieter Palmerscf1c5d12005-11-08 21:37:40 -08002436 [SAA7134_BOARD_MONSTERTV_MOBILE] = {
2437 .name = "SKNet MonsterTV Mobile",
2438 .audio_clock = 0x00187de7,
2439 .tuner_type = TUNER_PHILIPS_TDA8290,
2440 .radio_type = UNSET,
2441 .tuner_addr = ADDR_UNSET,
2442 .radio_addr = ADDR_UNSET,
2443
2444 .inputs = {{
2445 .name = name_tv,
2446 .vmux = 1,
2447 .amux = TV,
2448 .tv = 1,
2449 },{
2450 .name = name_comp1,
2451 .vmux = 3,
2452 .amux = LINE1,
2453 },{
2454 .name = name_svideo,
2455 .vmux = 6,
2456 .amux = LINE1,
2457 }},
2458 },
Ricardo Cerqueirac2f6f9d2005-11-08 21:37:51 -08002459 [SAA7134_BOARD_PINNACLE_PCTV_110i] = {
Karsten Suehringcb46e3c2006-02-27 00:08:08 -03002460 .name = "Pinnacle PCTV 40i/50i/110i (saa7133)",
Ricardo Cerqueirac2f6f9d2005-11-08 21:37:51 -08002461 .audio_clock = 0x00187de7,
2462 .tuner_type = TUNER_PHILIPS_TDA8290,
2463 .radio_type = UNSET,
2464 .tuner_addr = ADDR_UNSET,
2465 .radio_addr = ADDR_UNSET,
2466 .gpiomask = 0x080200000,
2467 .inputs = {{
2468 .name = name_tv,
2469 .vmux = 4,
2470 .amux = TV,
2471 .tv = 1,
2472 },{
2473 .name = name_comp1,
2474 .vmux = 1,
Karsten Suehringcb46e3c2006-02-27 00:08:08 -03002475 .amux = LINE2,
2476 },{
2477 .name = name_comp2,
2478 .vmux = 0,
Ricardo Cerqueirac2f6f9d2005-11-08 21:37:51 -08002479 .amux = LINE2,
2480 },{
2481 .name = name_svideo,
2482 .vmux = 8,
2483 .amux = LINE2,
2484 }},
2485 .radio = {
2486 .name = name_radio,
2487 .amux = LINE1,
2488 },
2489 },
Hermann Pitton28f02242005-11-08 21:38:03 -08002490 [SAA7134_BOARD_ASUSTeK_P7131_DUAL] = {
2491 .name = "ASUSTeK P7131 Dual",
2492 .audio_clock = 0x00187de7,
2493 .tuner_type = TUNER_PHILIPS_TDA8290,
2494 .radio_type = UNSET,
2495 .tuner_addr = ADDR_UNSET,
2496 .radio_addr = ADDR_UNSET,
2497 .gpiomask = 1 << 21,
Hartmut Hackmannd4b0aba2005-11-08 21:38:44 -08002498 .mpeg = SAA7134_MPEG_DVB,
Hermann Pitton28f02242005-11-08 21:38:03 -08002499 .inputs = {{
2500 .name = name_tv,
2501 .vmux = 1,
2502 .amux = TV,
2503 .tv = 1,
Hartmut Hackmann83646812006-10-12 20:38:51 -03002504 .gpio = 0x0000000,
Hermann Pitton28f02242005-11-08 21:38:03 -08002505 },{
2506 .name = name_comp1,
2507 .vmux = 3,
2508 .amux = LINE2,
Hartmut Hackmann83646812006-10-12 20:38:51 -03002509 .gpio = 0x0200000,
Hermann Pitton28f02242005-11-08 21:38:03 -08002510 },{
Hermann Pitton8387c662006-12-10 21:08:03 -03002511 .name = name_comp2,
2512 .vmux = 0,
2513 .amux = LINE2,
2514 .gpio = 0x0200000,
2515 },{
Hermann Pitton28f02242005-11-08 21:38:03 -08002516 .name = name_svideo,
2517 .vmux = 8,
2518 .amux = LINE2,
Hartmut Hackmann83646812006-10-12 20:38:51 -03002519 .gpio = 0x0200000,
Hermann Pitton28f02242005-11-08 21:38:03 -08002520 }},
2521 .radio = {
2522 .name = name_radio,
2523 .amux = TV,
2524 .gpio = 0x0200000,
2525 },
2526 },
Ricardo Cerqueira17ce1ff2005-11-08 21:38:47 -08002527 [SAA7134_BOARD_SEDNA_PC_TV_CARDBUS] = {
Paul T Zalacfe2e36c2005-11-08 21:38:04 -08002528 /* Paul Tom Zalac <pzalac@gmail.com> */
Pavel Mihaylovc3d93192005-11-08 21:38:43 -08002529 /* Pavel Mihaylov <bin@bash.info> */
Ricardo Cerqueira17ce1ff2005-11-08 21:38:47 -08002530 .name = "Sedna/MuchTV PC TV Cardbus TV/Radio (ITO25 Rev:2B)",
2531 /* Sedna/MuchTV (OEM) Cardbus TV Tuner */
Paul T Zalacfe2e36c2005-11-08 21:38:04 -08002532 .audio_clock = 0x00187de7,
Pavel Mihaylovc3d93192005-11-08 21:38:43 -08002533 .tuner_type = TUNER_PHILIPS_TDA8290,
Paul T Zalacfe2e36c2005-11-08 21:38:04 -08002534 .radio_type = UNSET,
2535 .tuner_addr = ADDR_UNSET,
2536 .radio_addr = ADDR_UNSET,
Pavel Mihaylovc3d93192005-11-08 21:38:43 -08002537 .gpiomask = 0xe880c0,
Paul T Zalacfe2e36c2005-11-08 21:38:04 -08002538 .inputs = {{
Pavel Mihaylovc3d93192005-11-08 21:38:43 -08002539 .name = name_tv,
2540 .vmux = 3,
2541 .amux = TV,
2542 .tv = 1,
2543 },{
Paul T Zalacfe2e36c2005-11-08 21:38:04 -08002544 .name = name_comp1,
2545 .vmux = 1,
Pavel Mihaylovc3d93192005-11-08 21:38:43 -08002546 .amux = LINE1,
2547 },{
2548 .name = name_svideo,
2549 .vmux = 6,
2550 .amux = LINE1,
Paul T Zalacfe2e36c2005-11-08 21:38:04 -08002551 }},
Pavel Mihaylovc3d93192005-11-08 21:38:43 -08002552 .radio = {
2553 .name = name_radio,
2554 .amux = LINE2,
2555 },
Paul T Zalacfe2e36c2005-11-08 21:38:04 -08002556 },
Michael Krufky5d5c9902005-11-08 21:38:08 -08002557 [SAA7134_BOARD_ASUSTEK_DIGIMATRIX_TV] = {
2558 /* "Cyril Lacoux (Yack)" <clacoux@ifeelgood.org> */
2559 .name = "ASUS Digimatrix TV",
2560 .audio_clock = 0x00200000,
2561 .tuner_type = TUNER_PHILIPS_FQ1216ME,
2562 .tda9887_conf = TDA9887_PRESENT,
2563 .radio_type = UNSET,
2564 .tuner_addr = ADDR_UNSET,
2565 .radio_addr = ADDR_UNSET,
2566 .inputs = {{
2567 .name = name_tv,
2568 .vmux = 1,
2569 .amux = TV,
2570 .tv = 1,
2571 },{
2572 .name = name_comp1,
2573 .vmux = 3,
2574 .amux = LINE1,
2575 },{
2576 .name = name_svideo,
2577 .vmux = 8,
2578 .amux = LINE1,
2579 }},
2580 },
Hartmut Hackmann90e9df72005-11-08 21:38:42 -08002581 [SAA7134_BOARD_PHILIPS_TIGER] = {
2582 .name = "Philips Tiger reference design",
2583 .audio_clock = 0x00187de7,
2584 .tuner_type = TUNER_PHILIPS_TDA8290,
2585 .radio_type = UNSET,
2586 .tuner_addr = ADDR_UNSET,
2587 .radio_addr = ADDR_UNSET,
Hartmut Hackmann58ef4f92007-04-27 12:31:12 -03002588 .tuner_config = 0,
Hartmut Hackmann90e9df72005-11-08 21:38:42 -08002589 .mpeg = SAA7134_MPEG_DVB,
Hartmut Hackmannde956c12007-04-27 12:31:12 -03002590 .gpiomask = 0x0200000,
Hartmut Hackmann90e9df72005-11-08 21:38:42 -08002591 .inputs = {{
2592 .name = name_tv,
2593 .vmux = 1,
2594 .amux = TV,
2595 .tv = 1,
2596 },{
2597 .name = name_comp1,
2598 .vmux = 3,
2599 .amux = LINE1,
2600 },{
2601 .name = name_svideo,
2602 .vmux = 8,
2603 .amux = LINE1,
2604 }},
Hartmut Hackmann0f79c362006-01-14 21:26:44 -02002605 .radio = {
2606 .name = name_radio,
2607 .amux = TV,
2608 .gpio = 0x0200000,
2609 },
Hartmut Hackmann90e9df72005-11-08 21:38:42 -08002610 },
Ricardo Cerqueira80d2ad92005-11-13 16:08:01 -08002611 [SAA7134_BOARD_MSI_TVATANYWHERE_PLUS] = {
2612 .name = "MSI TV@Anywhere plus",
2613 .audio_clock = 0x00187de7,
2614 .tuner_type = TUNER_PHILIPS_TDA8290,
2615 .radio_type = UNSET,
2616 .tuner_addr = ADDR_UNSET,
2617 .radio_addr = ADDR_UNSET,
hermann pittone382f622007-01-07 21:19:48 -03002618 .gpiomask = 1 << 21,
Ricardo Cerqueira80d2ad92005-11-13 16:08:01 -08002619 .inputs = {{
2620 .name = name_tv,
2621 .vmux = 1,
2622 .amux = TV,
2623 .tv = 1,
2624 },{
2625 .name = name_comp1,
2626 .vmux = 3,
hermann pittone382f622007-01-07 21:19:48 -03002627 .amux = LINE2, /* unconfirmed, taken from Philips driver */
2628 },{
2629 .name = name_comp2,
2630 .vmux = 0, /* untested, Composite over S-Video */
2631 .amux = LINE2,
Ricardo Cerqueira80d2ad92005-11-13 16:08:01 -08002632 },{
2633 .name = name_svideo,
hermann pittone382f622007-01-07 21:19:48 -03002634 .vmux = 8,
2635 .amux = LINE2,
Ricardo Cerqueira80d2ad92005-11-13 16:08:01 -08002636 }},
2637 .radio = {
2638 .name = name_radio,
hermann pittone382f622007-01-07 21:19:48 -03002639 .amux = TV,
2640 .gpio = 0x0200000,
Ricardo Cerqueira80d2ad92005-11-13 16:08:01 -08002641 },
2642 },
Jörg Schummerf639c9b2006-01-09 15:25:01 -02002643 [SAA7134_BOARD_CINERGY250PCI] = {
2644 /* remote-control does not work. The signal about a
2645 key press comes in via gpio, but the key code
2646 doesn't. Neither does it have an i2c remote control
2647 interface. */
2648 .name = "Terratec Cinergy 250 PCI TV",
2649 .audio_clock = 0x00187de7,
2650 .tuner_type = TUNER_PHILIPS_TDA8290,
2651 .radio_type = UNSET,
2652 .tuner_addr = ADDR_UNSET,
2653 .radio_addr = ADDR_UNSET,
2654 .gpiomask = 0x80200000,
2655 .inputs = {{
2656 .name = name_tv,
2657 .vmux = 1,
2658 .amux = TV,
2659 .tv = 1,
2660 },{
2661 .name = name_svideo, /* NOT tested */
2662 .vmux = 8,
2663 .amux = LINE1,
2664 }},
2665 .radio = {
2666 .name = name_radio,
Hartmut Hackmann58ef4f92007-04-27 12:31:12 -03002667 .amux = TV,
Jörg Schummerf639c9b2006-01-09 15:25:01 -02002668 .gpio = 0x0200000,
2669 },
2670 },
Peter Missel4aa6ba52006-01-09 15:32:45 -02002671 [SAA7134_BOARD_FLYDVB_TRIO] = {
2672 /* LifeView LR319 FlyDVB Trio */
2673 /* Peter Missel <peter.missel@onlinehome.de> */
2674 .name = "LifeView FlyDVB Trio",
2675 .audio_clock = 0x00200000,
2676 .tuner_type = TUNER_PHILIPS_TDA8290,
2677 .radio_type = UNSET,
2678 .tuner_addr = ADDR_UNSET,
2679 .radio_addr = ADDR_UNSET,
2680 .gpiomask = 0x00200000,
Hartmut Hackmann293cdab2006-02-27 21:08:07 -03002681 .mpeg = SAA7134_MPEG_DVB,
Peter Missel4aa6ba52006-01-09 15:32:45 -02002682 .inputs = {{
2683 .name = name_tv, /* Analog broadcast/cable TV */
2684 .vmux = 1,
2685 .amux = TV,
2686 .gpio = 0x200000, /* GPIO21=High for TV input */
2687 .tv = 1,
2688 },{
2689 .name = name_svideo, /* S-Video signal on S-Video input */
2690 .vmux = 8,
2691 .amux = LINE2,
2692 },{
2693 .name = name_comp1, /* Composite signal on S-Video input */
2694 .vmux = 0,
2695 .amux = LINE2,
2696 },{
2697 .name = name_comp2, /* Composite input */
2698 .vmux = 3,
2699 .amux = LINE2,
2700 }},
2701 .radio = {
2702 .name = name_radio,
2703 .amux = TV,
2704 .gpio = 0x000000, /* GPIO21=Low for FM radio antenna */
2705 },
2706 },
Jose Alberto Regueroa78d0bf2006-02-07 06:25:14 -02002707 [SAA7134_BOARD_AVERMEDIA_777] = {
2708 .name = "AverTV DVB-T 777",
2709 .audio_clock = 0x00187de7,
2710 .tuner_type = TUNER_ABSENT,
2711 .radio_type = UNSET,
2712 .tuner_addr = ADDR_UNSET,
2713 .radio_addr = ADDR_UNSET,
2714 .mpeg = SAA7134_MPEG_DVB,
2715 .inputs = {{
2716 .name = name_comp1,
Hartmut Hackmann2174eb92006-03-27 19:15:47 -03002717 .vmux = 1,
Jose Alberto Regueroa78d0bf2006-02-07 06:25:14 -02002718 .amux = LINE1,
2719 },{
2720 .name = name_svideo,
2721 .vmux = 8,
2722 .amux = LINE1,
2723 }},
2724 },
Giampiero Giancipoli3d8466e2006-02-07 06:49:09 -02002725 [SAA7134_BOARD_FLYDVBT_LR301] = {
2726 /* LifeView FlyDVB-T */
2727 /* Giampiero Giancipoli <gianci@libero.it> */
Hartmut Hackmann42e6b3b2006-03-27 19:04:48 -03002728 .name = "LifeView FlyDVB-T / Genius VideoWonder DVB-T",
Giampiero Giancipoli3d8466e2006-02-07 06:49:09 -02002729 .audio_clock = 0x00200000,
2730 .tuner_type = TUNER_ABSENT,
2731 .radio_type = UNSET,
2732 .tuner_addr = ADDR_UNSET,
2733 .radio_addr = ADDR_UNSET,
2734 .mpeg = SAA7134_MPEG_DVB,
2735 .inputs = {{
2736 .name = name_comp1, /* Composite input */
2737 .vmux = 3,
2738 .amux = LINE2,
2739 },{
2740 .name = name_svideo, /* S-Video signal on S-Video input */
2741 .vmux = 8,
2742 .amux = LINE2,
2743 }},
2744 },
Hartmut Hackmanndf42eaf2006-02-07 06:49:10 -02002745 [SAA7134_BOARD_ADS_DUO_CARDBUS_PTV331] = {
2746 .name = "ADS Instant TV Duo Cardbus PTV331",
2747 .audio_clock = 0x00200000,
2748 .tuner_type = TUNER_PHILIPS_TDA8290,
2749 .radio_type = UNSET,
2750 .tuner_addr = ADDR_UNSET,
2751 .radio_addr = ADDR_UNSET,
2752 .mpeg = SAA7134_MPEG_DVB,
2753 .gpiomask = 0x00600000, /* Bit 21 0=Radio, Bit 22 0=TV */
2754 .inputs = {{
2755 .name = name_tv,
2756 .vmux = 1,
2757 .amux = TV,
2758 .tv = 1,
2759 .gpio = 0x00200000,
2760 }},
2761 },
Peter Hartshorn3dfb7292006-02-07 06:49:13 -02002762 [SAA7134_BOARD_TEVION_DVBT_220RF] = {
Adrian Bunk793f2252006-03-08 10:50:06 -03002763 .name = "Tevion/KWorld DVB-T 220RF",
Peter Hartshorn3dfb7292006-02-07 06:49:13 -02002764 .audio_clock = 0x00187de7,
2765 .tuner_type = TUNER_PHILIPS_TDA8290,
2766 .radio_type = UNSET,
2767 .tuner_addr = ADDR_UNSET,
2768 .radio_addr = ADDR_UNSET,
2769 .mpeg = SAA7134_MPEG_DVB,
Simon Farnsworth289ea1f2007-09-10 13:37:26 -03002770 .gpiomask = 1 << 21,
Peter Hartshorn3dfb7292006-02-07 06:49:13 -02002771 .inputs = {{
2772 .name = name_tv,
2773 .vmux = 1,
2774 .amux = TV,
2775 .tv = 1,
2776 },{
2777 .name = name_comp1,
2778 .vmux = 3,
2779 .amux = LINE1,
2780 },{
Simon Farnsworth289ea1f2007-09-10 13:37:26 -03002781 .name = name_comp2,
Peter Hartshorn3dfb7292006-02-07 06:49:13 -02002782 .vmux = 0,
2783 .amux = LINE1,
Simon Farnsworth289ea1f2007-09-10 13:37:26 -03002784 },{
2785 .name = name_svideo,
2786 .vmux = 8,
2787 .amux = LINE1,
Peter Hartshorn3dfb7292006-02-07 06:49:13 -02002788 }},
2789 .radio = {
2790 .name = name_radio,
Simon Farnsworth289ea1f2007-09-10 13:37:26 -03002791 .amux = TV,
2792 .gpio = 0x0200000,
Peter Hartshorn3dfb7292006-02-07 06:49:13 -02002793 },
2794 },
Simon Farnsworthb39423a2007-05-01 10:01:20 -03002795 [SAA7134_BOARD_KWORLD_DVBT_210] = {
2796 .name = "KWorld DVB-T 210",
2797 .audio_clock = 0x00187de7,
2798 .tuner_type = TUNER_PHILIPS_TDA8290,
2799 .radio_type = UNSET,
2800 .tuner_addr = ADDR_UNSET,
2801 .radio_addr = ADDR_UNSET,
2802 .mpeg = SAA7134_MPEG_DVB,
2803 .gpiomask = 1 << 21,
2804 .inputs = {{
2805 .name = name_tv,
2806 .vmux = 1,
2807 .amux = TV,
2808 .tv = 1,
2809 },{
2810 .name = name_comp1,
2811 .vmux = 3,
2812 .amux = LINE1,
2813 },{
2814 .name = name_svideo,
2815 .vmux = 8,
2816 .amux = LINE1,
2817 }},
2818 .radio = {
2819 .name = name_radio,
2820 .amux = TV,
2821 .gpio = 0x0200000,
2822 },
2823 },
Andrew Burri3e1410a2006-02-27 00:08:23 -03002824 [SAA7134_BOARD_KWORLD_ATSC110] = {
Eric Sandeen0ac3a5b2007-10-08 16:13:02 -03002825 .name = "Kworld ATSC110/115",
Andrew Burri3e1410a2006-02-27 00:08:23 -03002826 .audio_clock = 0x00187de7,
2827 .tuner_type = TUNER_PHILIPS_TUV1236D,
2828 .radio_type = UNSET,
2829 .tuner_addr = ADDR_UNSET,
2830 .radio_addr = ADDR_UNSET,
2831 .tda9887_conf = TDA9887_PRESENT,
2832 .mpeg = SAA7134_MPEG_DVB,
2833 .inputs = {{
2834 .name = name_tv,
2835 .vmux = 1,
2836 .amux = TV,
2837 .tv = 1,
Curt Meyers6ba509d2006-02-27 00:08:32 -03002838 },{
2839 .name = name_comp1,
2840 .vmux = 3,
2841 .amux = LINE2,
2842 },{
2843 .name = name_svideo,
2844 .vmux = 8,
2845 .amux = LINE2,
Andrew Burri3e1410a2006-02-27 00:08:23 -03002846 }},
2847 },
Rickard Osser68593af2006-03-11 17:14:12 -03002848 [SAA7134_BOARD_AVERMEDIA_A169_B] = {
2849 /* AVerMedia A169 */
2850 /* Rickard Osser <ricky@osser.se> */
2851 /* This card has two saa7134 chips on it,
2852 but only one of them is currently working. */
2853 .name = "AVerMedia A169 B",
2854 .audio_clock = 0x02187de7,
2855 .tuner_type = TUNER_LG_TALN,
2856 .radio_type = UNSET,
2857 .tuner_addr = ADDR_UNSET,
2858 .radio_addr = ADDR_UNSET,
2859 .tda9887_conf = TDA9887_PRESENT,
2860 .gpiomask = 0x0a60000,
2861 },
2862 [SAA7134_BOARD_AVERMEDIA_A169_B1] = {
2863 /* AVerMedia A169 */
2864 /* Rickard Osser <ricky@osser.se> */
2865 .name = "AVerMedia A169 B1",
2866 .audio_clock = 0x02187de7,
2867 .tuner_type = TUNER_LG_TALN,
2868 .radio_type = UNSET,
2869 .tuner_addr = ADDR_UNSET,
2870 .radio_addr = ADDR_UNSET,
2871 .tda9887_conf = TDA9887_PRESENT,
2872 .gpiomask = 0xca60000,
2873 .inputs = {{
2874 .name = name_tv,
2875 .vmux = 4,
2876 .amux = TV,
2877 .tv = 1,
2878 .gpio = 0x04a61000,
2879 },{
2880 .name = name_comp2, /* Composite SVIDEO (B/W if signal is carried with SVIDEO) */
2881 .vmux = 1,
2882 .amux = LINE2,
2883 },{
2884 .name = name_svideo,
2885 .vmux = 9, /* 9 is correct as S-VIDEO1 according to a169.inf! */
2886 .amux = LINE1,
2887 }},
2888 },
Michael Krufkyba3a5a82006-03-14 19:02:12 -03002889 [SAA7134_BOARD_MD7134_BRIDGE_2] = {
2890 /* This card has two saa7134 chips on it,
2891 but only one of them is currently working.
2892 The programming for the primary decoder is
2893 in SAA7134_BOARD_MD7134 */
2894 .name = "Medion 7134 Bridge #2",
2895 .audio_clock = 0x00187de7,
2896 .radio_type = UNSET,
2897 .tuner_addr = ADDR_UNSET,
2898 .radio_addr = ADDR_UNSET,
2899 },
Hartmut Hackmannd95b8942006-03-27 19:39:30 -03002900 [SAA7134_BOARD_FLYDVBT_HYBRID_CARDBUS] = {
Mauro Carvalho Chehab593f18c2007-10-07 02:17:09 -03002901 .name = "LifeView FlyDVB-T Hybrid Cardbus/MSI TV @nywhere A/D NB",
Hartmut Hackmannd95b8942006-03-27 19:39:30 -03002902 .audio_clock = 0x00200000,
2903 .tuner_type = TUNER_PHILIPS_TDA8290,
2904 .radio_type = UNSET,
2905 .tuner_addr = ADDR_UNSET,
2906 .radio_addr = ADDR_UNSET,
2907 .mpeg = SAA7134_MPEG_DVB,
2908 .gpiomask = 0x00600000, /* Bit 21 0=Radio, Bit 22 0=TV */
2909 .inputs = {{
2910 .name = name_tv,
2911 .vmux = 1,
2912 .amux = TV,
2913 .gpio = 0x200000, /* GPIO21=High for TV input */
2914 .tv = 1,
2915 },{
2916 .name = name_svideo, /* S-Video signal on S-Video input */
2917 .vmux = 8,
2918 .amux = LINE2,
2919 },{
2920 .name = name_comp1, /* Composite signal on S-Video input */
2921 .vmux = 0,
2922 .amux = LINE2,
2923 },{
2924 .name = name_comp2, /* Composite input */
2925 .vmux = 3,
2926 .amux = LINE2,
2927 }},
2928 .radio = {
2929 .name = name_radio,
2930 .amux = TV,
2931 .gpio = 0x000000, /* GPIO21=Low for FM radio antenna */
2932 },
2933 },
Zac Bowlingf49ba8d2006-06-19 19:49:20 -03002934 [SAA7134_BOARD_FLYVIDEO3000_NTSC] = {
2935 /* "Zac Bowling" <zac@zacbowling.com> */
2936 .name = "LifeView FlyVIDEO3000 (NTSC)",
2937 .audio_clock = 0x00200000,
2938 .tuner_type = TUNER_PHILIPS_NTSC,
2939 .radio_type = UNSET,
2940 .tuner_addr = ADDR_UNSET,
2941 .radio_addr = ADDR_UNSET,
2942
2943 .gpiomask = 0xe000,
2944 .inputs = {{
2945 .name = name_tv,
2946 .vmux = 1,
2947 .amux = TV,
2948 .gpio = 0x8000,
2949 .tv = 1,
2950 },{
2951 .name = name_tv_mono,
2952 .vmux = 1,
2953 .amux = LINE2,
2954 .gpio = 0x0000,
2955 .tv = 1,
2956 },{
2957 .name = name_comp1,
2958 .vmux = 0,
2959 .amux = LINE2,
2960 .gpio = 0x4000,
2961 },{
2962 .name = name_comp2,
2963 .vmux = 3,
2964 .amux = LINE2,
2965 .gpio = 0x4000,
2966 },{
2967 .name = name_svideo,
2968 .vmux = 8,
2969 .amux = LINE2,
2970 .gpio = 0x4000,
2971 }},
2972 .radio = {
2973 .name = name_radio,
2974 .amux = LINE2,
2975 .gpio = 0x2000,
2976 },
2977 .mute = {
2978 .name = name_mute,
2979 .amux = TV,
2980 .gpio = 0x8000,
2981 },
2982 },
Hartmut Hackmann5eda2272006-08-07 14:03:32 -03002983 [SAA7134_BOARD_MEDION_MD8800_QUADRO] = {
2984 .name = "Medion Md8800 Quadro",
2985 .audio_clock = 0x00187de7,
2986 .tuner_type = TUNER_PHILIPS_TDA8290,
2987 .radio_type = UNSET,
2988 .tuner_addr = ADDR_UNSET,
2989 .radio_addr = ADDR_UNSET,
2990 .mpeg = SAA7134_MPEG_DVB,
2991 .inputs = {{
2992 .name = name_tv,
2993 .vmux = 1,
2994 .amux = TV,
2995 .tv = 1,
2996 },{
2997 .name = name_comp1,
2998 .vmux = 0,
hermann pitton387a2992007-10-25 21:26:53 -03002999 .amux = LINE1,
Hartmut Hackmann5eda2272006-08-07 14:03:32 -03003000 },{
3001 .name = name_svideo,
3002 .vmux = 8,
hermann pitton387a2992007-10-25 21:26:53 -03003003 .amux = LINE1,
Hartmut Hackmann5eda2272006-08-07 14:03:32 -03003004 }},
3005 },
Igor M. Liplianine2ac28f2006-08-08 09:10:10 -03003006 [SAA7134_BOARD_FLYDVBS_LR300] = {
3007 /* LifeView FlyDVB-s */
3008 /* Igor M. Liplianin <liplianin@tut.by> */
3009 .name = "LifeView FlyDVB-S /Acorp TV134DS",
3010 .audio_clock = 0x00200000,
3011 .tuner_type = TUNER_ABSENT,
3012 .radio_type = UNSET,
3013 .tuner_addr = ADDR_UNSET,
3014 .radio_addr = ADDR_UNSET,
3015 .mpeg = SAA7134_MPEG_DVB,
3016 .inputs = {{
3017 .name = name_comp1, /* Composite input */
3018 .vmux = 3,
3019 .amux = LINE1,
3020 },{
3021 .name = name_svideo, /* S-Video signal on S-Video input */
3022 .vmux = 8,
3023 .amux = LINE1,
3024 }},
3025 },
Michal Majchrowiczb04c1ba2006-09-13 16:42:42 -03003026 [SAA7134_BOARD_PROTEUS_2309] = {
3027 .name = "Proteus Pro 2309",
3028 .audio_clock = 0x00187de7,
3029 .tuner_type = TUNER_PHILIPS_FM1216ME_MK3,
3030 .radio_type = UNSET,
3031 .tuner_addr = ADDR_UNSET,
3032 .radio_addr = ADDR_UNSET,
3033 .tda9887_conf = TDA9887_PRESENT,
3034 .inputs = {{
3035 .name = name_tv,
3036 .vmux = 1,
3037 .amux = LINE2,
3038 .tv = 1,
3039 },{
3040 .name = name_comp1,
3041 .vmux = 0,
3042 .amux = LINE2,
3043 },{
3044 .name = name_comp2,
3045 .vmux = 3,
3046 .amux = LINE2,
3047 },{
3048 .name = name_svideo,
3049 .vmux = 8,
3050 .amux = LINE2,
3051 }},
3052 .mute = {
3053 .name = name_mute,
3054 .amux = LINE1,
3055 },
3056 },
Petr Baudis515c2082006-09-26 16:53:53 -03003057 [SAA7134_BOARD_AVERMEDIA_A16AR] = {
3058 /* Petr Baudis <pasky@ucw.cz> */
3059 .name = "AVerMedia TV Hybrid A16AR",
3060 .audio_clock = 0x187de7,
pasky@ucw.cz0871a882006-11-12 14:24:57 -03003061 .tuner_type = TUNER_PHILIPS_TD1316, /* untested */
Petr Baudis515c2082006-09-26 16:53:53 -03003062 .radio_type = TUNER_TEA5767, /* untested */
3063 .tuner_addr = ADDR_UNSET,
3064 .radio_addr = ADDR_UNSET,
3065 .tda9887_conf = TDA9887_PRESENT,
3066 .mpeg = SAA7134_MPEG_DVB,
3067 .inputs = {{
3068 .name = name_tv,
3069 .vmux = 1,
3070 .amux = TV,
3071 .tv = 1,
3072 },{
3073 .name = name_comp1,
3074 .vmux = 3,
3075 .amux = LINE2,
3076 },{
3077 .name = name_svideo,
3078 .vmux = 8,
3079 .amux = LINE1,
3080 }},
3081 .radio = {
3082 .name = name_radio,
3083 .amux = LINE1,
3084 },
3085 },
Hartmut Hackmanncf146ca2006-10-02 20:49:24 -03003086 [SAA7134_BOARD_ASUS_EUROPA2_HYBRID] = {
3087 .name = "Asus Europa2 OEM",
3088 .audio_clock = 0x00187de7,
3089 .tuner_type = TUNER_PHILIPS_FMD1216ME_MK3,
3090 .radio_type = UNSET,
3091 .tuner_addr = ADDR_UNSET,
3092 .radio_addr = ADDR_UNSET,
3093 .tda9887_conf = TDA9887_PRESENT| TDA9887_PORT1_ACTIVE | TDA9887_PORT2_ACTIVE,
3094 .mpeg = SAA7134_MPEG_DVB,
3095 .inputs = {{
3096 .name = name_tv,
3097 .vmux = 3,
3098 .amux = TV,
3099 .tv = 1,
3100 },{
3101 .name = name_comp1,
3102 .vmux = 4,
3103 .amux = LINE2,
3104 },{
3105 .name = name_svideo,
3106 .vmux = 8,
3107 .amux = LINE2,
3108 }},
3109 .radio = {
3110 .name = name_radio,
3111 .amux = LINE1,
3112 },
3113 },
Hartmut Hackmann587d2fd2006-10-06 19:13:50 -03003114 [SAA7134_BOARD_PINNACLE_PCTV_310i] = {
3115 .name = "Pinnacle PCTV 310i",
3116 .audio_clock = 0x00187de7,
3117 .tuner_type = TUNER_PHILIPS_TDA8290,
3118 .radio_type = UNSET,
3119 .tuner_addr = ADDR_UNSET,
3120 .radio_addr = ADDR_UNSET,
Hartmut Hackmann58ef4f92007-04-27 12:31:12 -03003121 .tuner_config = 1,
Hartmut Hackmann587d2fd2006-10-06 19:13:50 -03003122 .mpeg = SAA7134_MPEG_DVB,
3123 .gpiomask = 0x000200000,
3124 .inputs = {{
3125 .name = name_tv,
3126 .vmux = 4,
3127 .amux = TV,
3128 .tv = 1,
3129 },{
3130 .name = name_comp1,
3131 .vmux = 1,
3132 .amux = LINE2,
3133 },{
3134 .name = name_comp2,
3135 .vmux = 0,
3136 .amux = LINE2,
3137 },{
3138 .name = name_svideo,
3139 .vmux = 8,
3140 .amux = LINE2,
3141 }},
3142 .radio = {
3143 .name = name_radio,
3144 .amux = TV,
3145 .gpio = 0x0200000,
3146 },
3147 },
Mikhail Fedotov3ac706d2006-10-06 20:23:47 -03003148 [SAA7134_BOARD_AVERMEDIA_STUDIO_507] = {
3149 /* Mikhail Fedotov <mo_fedotov@mail.ru> */
3150 .name = "Avermedia AVerTV Studio 507",
3151 .audio_clock = 0x00187de7,
3152 .tuner_type = TUNER_PHILIPS_FM1256_IH3,
3153 .radio_type = UNSET,
3154 .tuner_addr = ADDR_UNSET,
3155 .radio_addr = ADDR_UNSET,
3156 .tda9887_conf = TDA9887_PRESENT,
3157 .gpiomask = 0x03,
3158 .inputs = {{
3159 .name = name_tv,
3160 .vmux = 1,
3161 .amux = TV,
3162 .tv = 1,
3163 .gpio = 0x00,
3164 },{
3165 .name = name_comp1,
3166 .vmux = 0,
3167 .amux = LINE2,
3168 .gpio = 0x00,
3169 },{
3170 .name = name_comp2,
3171 .vmux = 3,
3172 .amux = LINE2,
3173 .gpio = 0x00,
3174 },{
3175 .name = name_svideo,
3176 .vmux = 8,
3177 .amux = LINE2,
3178 .gpio = 0x00,
3179 }},
3180 .radio = {
3181 .name = name_radio,
3182 .amux = LINE2,
3183 .gpio = 0x01,
3184 },
3185 .mute = {
3186 .name = name_mute,
3187 .amux = LINE1,
3188 .gpio = 0x00,
3189 },
3190 },
Hartmut Hackmanncbb94522006-10-30 20:00:16 -03003191 [SAA7134_BOARD_VIDEOMATE_DVBT_200A] = {
3192 /* Francis Barber <fedora@barber-family.id.au> */
3193 .name = "Compro Videomate DVB-T200A",
3194 .audio_clock = 0x00187de7,
3195 .tuner_type = TUNER_ABSENT,
3196 .radio_type = UNSET,
3197 .tuner_addr = ADDR_UNSET,
3198 .radio_addr = ADDR_UNSET,
3199 .tda9887_conf = TDA9887_PRESENT | TDA9887_PORT1_ACTIVE,
3200 .mpeg = SAA7134_MPEG_DVB,
3201 .inputs = {{
3202 .name = name_tv,
3203 .vmux = 3,
3204 .amux = TV,
3205 .tv = 1,
3206 },{
3207 .name = name_comp1,
3208 .vmux = 1,
3209 .amux = LINE2,
3210 },{
3211 .name = name_svideo,
3212 .vmux = 8,
3213 .amux = LINE2,
3214 }},
3215 },
Thomas Gentyc6e53da2006-11-05 14:17:30 -03003216 [SAA7134_BOARD_HAUPPAUGE_HVR1110] = {
3217 /* Thomas Genty <tomlohave@gmail.com> */
3218 .name = "Hauppauge WinTV-HVR1110 DVB-T/Hybrid",
3219 .audio_clock = 0x00187de7,
3220 .tuner_type = TUNER_PHILIPS_TDA8290,
3221 .radio_type = UNSET,
3222 .tuner_addr = ADDR_UNSET,
3223 .radio_addr = ADDR_UNSET,
Michael Krufkyb3aa2262007-12-09 21:13:38 -03003224 .tuner_config = 1,
Thomas Gentyc6e53da2006-11-05 14:17:30 -03003225 .mpeg = SAA7134_MPEG_DVB,
Thomas Gentyc6e53da2006-11-05 14:17:30 -03003226 .inputs = {{
3227 .name = name_tv,
3228 .vmux = 1,
3229 .amux = TV,
3230 .tv = 1,
Thomas Genty177aaaf2006-11-29 21:57:24 -03003231 },{
3232 .name = name_comp1,
3233 .vmux = 3,
3234 .amux = LINE2, /* FIXME: audio doesn't work on svideo/composite */
3235 },{
3236 .name = name_svideo,
3237 .vmux = 8,
3238 .amux = LINE2, /* FIXME: audio doesn't work on svideo/composite */
Thomas Gentyc6e53da2006-11-05 14:17:30 -03003239 }},
3240 .radio = {
3241 .name = name_radio,
3242 .amux = TV,
Thomas Gentyc6e53da2006-11-05 14:17:30 -03003243 },
3244 },
Hartmut Hackmann550a9a52006-11-15 21:31:54 -03003245 [SAA7134_BOARD_CINERGY_HT_PCMCIA] = {
3246 .name = "Terratec Cinergy HT PCMCIA",
3247 .audio_clock = 0x00187de7,
3248 .tuner_type = TUNER_PHILIPS_TDA8290,
3249 .radio_type = UNSET,
3250 .tuner_addr = ADDR_UNSET,
3251 .radio_addr = ADDR_UNSET,
3252 .mpeg = SAA7134_MPEG_DVB,
3253 .inputs = {{
3254 .name = name_tv,
3255 .vmux = 1,
3256 .amux = TV,
3257 .tv = 1,
3258 },{
3259 .name = name_comp1,
3260 .vmux = 0,
3261 .amux = LINE1,
3262 },{
3263 .name = name_svideo,
3264 .vmux = 6,
3265 .amux = LINE1,
3266 }},
3267 },
Steven Walterd1158f42006-12-20 09:29:09 -03003268 [SAA7134_BOARD_ENCORE_ENLTV] = {
Juan Pablo Sormanic36c4592006-12-27 12:46:36 -03003269 /* Steven Walter <stevenrwalter@gmail.com>
3270 Juan Pablo Sormani <sorman@gmail.com> */
Steven Walterd1158f42006-12-20 09:29:09 -03003271 .name = "Encore ENLTV",
Juan Pablo Sormanic36c4592006-12-27 12:46:36 -03003272 .audio_clock = 0x00200000,
Steven Walterd1158f42006-12-20 09:29:09 -03003273 .tuner_type = TUNER_TNF_5335MF,
3274 .radio_type = UNSET,
3275 .tuner_addr = ADDR_UNSET,
3276 .radio_addr = ADDR_UNSET,
3277 .inputs = {{
3278 .name = name_tv,
3279 .vmux = 1,
Juan Pablo Sormanic36c4592006-12-27 12:46:36 -03003280 .amux = 3,
Steven Walterd1158f42006-12-20 09:29:09 -03003281 .tv = 1,
3282 },{
Juan Pablo Sormanic36c4592006-12-27 12:46:36 -03003283 .name = name_tv_mono,
3284 .vmux = 7,
3285 .amux = 4,
3286 .tv = 1,
3287 },{
3288 .name = name_comp1,
3289 .vmux = 3,
3290 .amux = 2,
3291 },{
Steven Walterd1158f42006-12-20 09:29:09 -03003292 .name = name_svideo,
Juan Pablo Sormanic36c4592006-12-27 12:46:36 -03003293 .vmux = 0,
3294 .amux = 2,
Steven Walterd1158f42006-12-20 09:29:09 -03003295 }},
Juan Pablo Sormanic36c4592006-12-27 12:46:36 -03003296 .radio = {
3297 .name = name_radio,
3298 .amux = LINE2,
3299/* .gpio = 0x00300001,*/
3300 .gpio = 0x20000,
3301
3302 },
3303 .mute = {
3304 .name = name_mute,
3305 .amux = 0,
3306 },
3307 },
3308 [SAA7134_BOARD_ENCORE_ENLTV_FM] = {
3309 /* Juan Pablo Sormani <sorman@gmail.com> */
3310 .name = "Encore ENLTV-FM",
3311 .audio_clock = 0x00200000,
3312 .tuner_type = TUNER_PHILIPS_ATSC,
3313 .radio_type = UNSET,
3314 .tuner_addr = ADDR_UNSET,
3315 .radio_addr = ADDR_UNSET,
3316 .inputs = {{
3317 .name = name_tv,
3318 .vmux = 1,
3319 .amux = 3,
3320 .tv = 1,
3321 },{
3322 .name = name_tv_mono,
3323 .vmux = 7,
3324 .amux = 4,
3325 .tv = 1,
3326 },{
3327 .name = name_comp1,
3328 .vmux = 3,
3329 .amux = 2,
3330 },{
3331 .name = name_svideo,
3332 .vmux = 0,
3333 .amux = 2,
3334 }},
3335 .radio = {
3336 .name = name_radio,
3337 .amux = LINE2,
3338 .gpio = 0x20000,
3339
3340 },
3341 .mute = {
3342 .name = name_mute,
3343 .amux = 0,
3344 },
Steven Walterd1158f42006-12-20 09:29:09 -03003345 },
Michael Krufky9de271e2007-01-16 18:36:40 -03003346 [SAA7134_BOARD_CINERGY_HT_PCI] = {
3347 .name = "Terratec Cinergy HT PCI",
3348 .audio_clock = 0x00187de7,
3349 .tuner_type = TUNER_PHILIPS_TDA8290,
3350 .radio_type = UNSET,
3351 .tuner_addr = ADDR_UNSET,
3352 .radio_addr = ADDR_UNSET,
3353 .mpeg = SAA7134_MPEG_DVB,
3354 .inputs = {{
3355 .name = name_tv,
3356 .vmux = 1,
3357 .amux = TV,
3358 .tv = 1,
3359 },{
3360 .name = name_comp1,
3361 .vmux = 0,
3362 .amux = LINE1,
3363 },{
3364 .name = name_svideo,
3365 .vmux = 6,
3366 .amux = LINE1,
3367 }},
3368 },
Hartmut Hackmann58ef4f92007-04-27 12:31:12 -03003369 [SAA7134_BOARD_PHILIPS_TIGER_S] = {
3370 .name = "Philips Tiger - S Reference design",
3371 .audio_clock = 0x00187de7,
3372 .tuner_type = TUNER_PHILIPS_TDA8290,
3373 .radio_type = UNSET,
3374 .tuner_addr = ADDR_UNSET,
3375 .radio_addr = ADDR_UNSET,
3376 .tuner_config = 2,
3377 .mpeg = SAA7134_MPEG_DVB,
3378 .gpiomask = 0x0200000,
3379 .inputs = {{
3380 .name = name_tv,
3381 .vmux = 1,
3382 .amux = TV,
3383 .tv = 1,
3384 },{
3385 .name = name_comp1,
3386 .vmux = 3,
3387 .amux = LINE1,
3388 },{
3389 .name = name_svideo,
3390 .vmux = 8,
3391 .amux = LINE1,
3392 }},
3393 .radio = {
3394 .name = name_radio,
3395 .amux = TV,
3396 .gpio = 0x0200000,
3397 },
3398 },
Markus Rechbergere95d3172007-04-27 12:31:19 -03003399 [SAA7134_BOARD_AVERMEDIA_M102] = {
3400 .name = "Avermedia M102",
3401 .audio_clock = 0x00187de7,
3402 .tuner_type = TUNER_PHILIPS_TDA8290,
3403 .radio_type = UNSET,
3404 .tuner_addr = ADDR_UNSET,
3405 .radio_addr = ADDR_UNSET,
3406 .gpiomask = 1<<21,
3407 .inputs = {{
3408 .name = name_tv,
3409 .vmux = 1,
3410 .amux = TV,
3411 .tv = 1,
3412 },{
3413 .name = name_comp1,
3414 .vmux = 0,
3415 .amux = LINE2,
3416 },{
3417 .name = name_svideo,
3418 .vmux = 6,
3419 .amux = LINE2,
3420 }},
3421 },
Hartmut Hackmanne06cea42007-03-13 20:58:29 -03003422 [SAA7134_BOARD_ASUS_P7131_4871] = {
3423 .name = "ASUS P7131 4871",
3424 .audio_clock = 0x00187de7,
3425 .tuner_type = TUNER_PHILIPS_TDA8290,
3426 .radio_type = UNSET,
3427 .tuner_addr = ADDR_UNSET,
3428 .radio_addr = ADDR_UNSET,
3429 .tuner_config = 2,
3430 .mpeg = SAA7134_MPEG_DVB,
3431 .gpiomask = 0x0200000,
3432 .inputs = {{
3433 .name = name_tv,
3434 .vmux = 1,
3435 .amux = TV,
3436 .tv = 1,
3437 .gpio = 0x0200000,
3438 }},
3439 },
Hartmut Hackmannf3eec0c02007-03-14 20:33:55 -03003440 [SAA7134_BOARD_ASUSTeK_P7131_HYBRID_LNA] = {
3441 .name = "ASUSTeK P7131 Hybrid",
Hartmut Hackmanne06cea42007-03-13 20:58:29 -03003442 .audio_clock = 0x00187de7,
3443 .tuner_type = TUNER_PHILIPS_TDA8290,
3444 .radio_type = UNSET,
3445 .tuner_addr = ADDR_UNSET,
3446 .radio_addr = ADDR_UNSET,
3447 .tuner_config = 2,
3448 .gpiomask = 1 << 21,
3449 .mpeg = SAA7134_MPEG_DVB,
3450 .inputs = {{
3451 .name = name_tv,
3452 .vmux = 1,
3453 .amux = TV,
3454 .tv = 1,
3455 .gpio = 0x0000000,
3456 },{
3457 .name = name_comp1,
3458 .vmux = 3,
3459 .amux = LINE2,
3460 .gpio = 0x0200000,
3461 },{
3462 .name = name_comp2,
3463 .vmux = 0,
3464 .amux = LINE2,
3465 .gpio = 0x0200000,
3466 },{
3467 .name = name_svideo,
3468 .vmux = 8,
3469 .amux = LINE2,
3470 .gpio = 0x0200000,
3471 }},
3472 .radio = {
3473 .name = name_radio,
3474 .amux = TV,
3475 .gpio = 0x0200000,
3476 },
3477 },
James T Klaas53958b32007-05-01 10:48:09 -03003478 [SAA7134_BOARD_SABRENT_TV_PCB05] = {
3479 .name = "Sabrent PCMCIA TV-PCB05",
3480 .audio_clock = 0x00187de7,
3481 .tuner_type = TUNER_PHILIPS_TDA8290,
3482 .radio_type = UNSET,
3483 .tuner_addr = ADDR_UNSET,
3484 .radio_addr = ADDR_UNSET,
3485 .inputs = {{
3486 .name = name_tv,
3487 .vmux = 1,
3488 .amux = TV,
3489 .tv = 1,
3490 },{
3491 .name = name_comp1,
3492 .vmux = 3,
3493 .amux = LINE1,
3494 },{
3495 .name = name_comp2,
3496 .vmux = 0,
3497 .amux = LINE1,
3498 },{
3499 .name = name_svideo,
3500 .vmux = 8,
3501 .amux = LINE1,
3502 }},
3503 .mute = {
3504 .name = name_mute,
3505 .amux = TV,
3506 },
3507 },
Tony Wanaaccb822007-05-10 12:16:47 -03003508 [SAA7134_BOARD_10MOONSTVMASTER3] = {
3509 /* Tony Wan <aloha_cn@hotmail.com> */
3510 .name = "10MOONS TM300 TV Card",
3511 .audio_clock = 0x00200000,
3512 .tuner_type = TUNER_LG_PAL_NEW_TAPC,
3513 .radio_type = UNSET,
3514 .tuner_addr = ADDR_UNSET,
3515 .radio_addr = ADDR_UNSET,
3516 .gpiomask = 0x7000,
3517 .inputs = {{
3518 .name = name_tv,
3519 .vmux = 1,
3520 .amux = LINE2,
3521 .gpio = 0x0000,
3522 .tv = 1,
3523 },{
3524 .name = name_comp1,
3525 .vmux = 3,
3526 .amux = LINE1,
3527 .gpio = 0x2000,
3528 },{
3529 .name = name_svideo,
3530 .vmux = 8,
3531 .amux = LINE1,
3532 .gpio = 0x2000,
3533 }},
3534 .mute = {
3535 .name = name_mute,
3536 .amux = LINE2,
3537 .gpio = 0x3000,
3538 },
3539 },
Edgar Simod90d9f52007-08-20 14:14:50 -03003540 [SAA7134_BOARD_AVERMEDIA_SUPER_007] = {
3541 .name = "Avermedia Super 007",
3542 .audio_clock = 0x00187de7,
3543 .tuner_type = TUNER_PHILIPS_TDA8290,
3544 .radio_type = UNSET,
3545 .tuner_addr = ADDR_UNSET,
3546 .radio_addr = ADDR_UNSET,
3547 .tuner_config = 0,
3548 .mpeg = SAA7134_MPEG_DVB,
3549 .inputs = {{
3550 .name = name_tv, /* FIXME: analog tv untested */
3551 .vmux = 1,
3552 .amux = TV,
3553 .tv = 1,
3554 }},
3555 },
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07003556};
3557
Linus Torvalds1da177e2005-04-16 15:20:36 -07003558const unsigned int saa7134_bcount = ARRAY_SIZE(saa7134_boards);
3559
3560/* ------------------------------------------------------------------ */
3561/* PCI ids + subsystem IDs */
3562
3563struct pci_device_id saa7134_pci_tbl[] = {
3564 {
3565 .vendor = PCI_VENDOR_ID_PHILIPS,
3566 .device = PCI_DEVICE_ID_PHILIPS_SAA7134,
3567 .subvendor = PCI_VENDOR_ID_PHILIPS,
3568 .subdevice = 0x2001,
3569 .driver_data = SAA7134_BOARD_PROTEUS_PRO,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07003570 },{
Linus Torvalds1da177e2005-04-16 15:20:36 -07003571 .vendor = PCI_VENDOR_ID_PHILIPS,
3572 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
3573 .subvendor = PCI_VENDOR_ID_PHILIPS,
3574 .subdevice = 0x2001,
3575 .driver_data = SAA7134_BOARD_PROTEUS_PRO,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07003576 },{
Linus Torvalds1da177e2005-04-16 15:20:36 -07003577 .vendor = PCI_VENDOR_ID_PHILIPS,
3578 .device = PCI_DEVICE_ID_PHILIPS_SAA7134,
3579 .subvendor = PCI_VENDOR_ID_PHILIPS,
3580 .subdevice = 0x6752,
3581 .driver_data = SAA7134_BOARD_EMPRESS,
3582 },{
3583 .vendor = PCI_VENDOR_ID_PHILIPS,
3584 .device = PCI_DEVICE_ID_PHILIPS_SAA7134,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07003585 .subvendor = 0x1131,
3586 .subdevice = 0x4e85,
Linus Torvalds1da177e2005-04-16 15:20:36 -07003587 .driver_data = SAA7134_BOARD_MONSTERTV,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07003588 },{
3589 .vendor = PCI_VENDOR_ID_PHILIPS,
3590 .device = PCI_DEVICE_ID_PHILIPS_SAA7134,
Michael Krufky7df64e82005-11-08 21:36:16 -08003591 .subvendor = 0x153b,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07003592 .subdevice = 0x1142,
3593 .driver_data = SAA7134_BOARD_CINERGY400,
3594 },{
3595 .vendor = PCI_VENDOR_ID_PHILIPS,
3596 .device = PCI_DEVICE_ID_PHILIPS_SAA7134,
Michael Krufky7df64e82005-11-08 21:36:16 -08003597 .subvendor = 0x153b,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07003598 .subdevice = 0x1143,
3599 .driver_data = SAA7134_BOARD_CINERGY600,
3600 },{
3601 .vendor = PCI_VENDOR_ID_PHILIPS,
3602 .device = PCI_DEVICE_ID_PHILIPS_SAA7134,
Michael Krufky7df64e82005-11-08 21:36:16 -08003603 .subvendor = 0x153b,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07003604 .subdevice = 0x1158,
3605 .driver_data = SAA7134_BOARD_CINERGY600_MK3,
3606 },{
Linus Torvalds1da177e2005-04-16 15:20:36 -07003607 .vendor = PCI_VENDOR_ID_PHILIPS,
3608 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
3609 .subvendor = 0x153b,
3610 .subdevice = 0x1162,
3611 .driver_data = SAA7134_BOARD_CINERGY400_CARDBUS,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07003612 },{
Linus Torvalds1da177e2005-04-16 15:20:36 -07003613 .vendor = PCI_VENDOR_ID_PHILIPS,
3614 .device = PCI_DEVICE_ID_PHILIPS_SAA7134,
Zac Bowlingf49ba8d2006-06-19 19:49:20 -03003615 .subvendor = 0x5169,
3616 .subdevice = 0x0138,
3617 .driver_data = SAA7134_BOARD_FLYVIDEO3000_NTSC,
3618 },{
3619 .vendor = PCI_VENDOR_ID_PHILIPS,
3620 .device = PCI_DEVICE_ID_PHILIPS_SAA7134,
Linus Torvalds1da177e2005-04-16 15:20:36 -07003621 .subvendor = 0x5168,
3622 .subdevice = 0x0138,
3623 .driver_data = SAA7134_BOARD_FLYVIDEO3000,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07003624 },{
Linus Torvalds1da177e2005-04-16 15:20:36 -07003625 .vendor = PCI_VENDOR_ID_PHILIPS,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07003626 .device = PCI_DEVICE_ID_PHILIPS_SAA7134,
3627 .subvendor = 0x4e42, /* "Typhoon PCI Capture TV Card" Art.No. 50673 */
3628 .subdevice = 0x0138,
3629 .driver_data = SAA7134_BOARD_FLYVIDEO3000,
3630 },{
Linus Torvalds1da177e2005-04-16 15:20:36 -07003631 .vendor = PCI_VENDOR_ID_PHILIPS,
3632 .device = PCI_DEVICE_ID_PHILIPS_SAA7130,
3633 .subvendor = 0x5168,
3634 .subdevice = 0x0138,
3635 .driver_data = SAA7134_BOARD_FLYVIDEO2000,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07003636 },{
Linus Torvalds1da177e2005-04-16 15:20:36 -07003637 .vendor = PCI_VENDOR_ID_PHILIPS,
Peter Missel10b7a902006-01-23 17:11:06 -02003638 .device = PCI_DEVICE_ID_PHILIPS_SAA7130,
3639 .subvendor = 0x4e42, /* Typhoon */
3640 .subdevice = 0x0138, /* LifeView FlyTV Prime30 OEM */
3641 .driver_data = SAA7134_BOARD_FLYVIDEO2000,
3642 },{
3643 .vendor = PCI_VENDOR_ID_PHILIPS,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07003644 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
Linus Torvalds1da177e2005-04-16 15:20:36 -07003645 .subvendor = 0x5168,
3646 .subdevice = 0x0212, /* minipci, LR212 */
3647 .driver_data = SAA7134_BOARD_FLYTVPLATINUM_MINI,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07003648 },{
Linus Torvalds1da177e2005-04-16 15:20:36 -07003649 .vendor = PCI_VENDOR_ID_PHILIPS,
3650 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
Mauro Carvalho Chehab058afaf2005-11-08 21:36:49 -08003651 .subvendor = 0x14c0,
3652 .subdevice = 0x1212, /* minipci, LR1212 */
3653 .driver_data = SAA7134_BOARD_FLYTVPLATINUM_MINI2,
3654 },{
3655 .vendor = PCI_VENDOR_ID_PHILIPS,
3656 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
Glen Gray2d14f782005-11-08 21:36:12 -08003657 .subvendor = 0x4e42,
3658 .subdevice = 0x0212, /* OEM minipci, LR212 */
3659 .driver_data = SAA7134_BOARD_FLYTVPLATINUM_MINI,
3660 },{
3661 .vendor = PCI_VENDOR_ID_PHILIPS,
3662 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
Peter Missel10e92062005-05-01 08:59:21 -07003663 .subvendor = 0x5168, /* Animation Technologies (LifeView) */
Simon Farnsworthb39423a2007-05-01 10:01:20 -03003664 .subdevice = 0x0214, /* Standard PCI, LR214 Rev E and earlier (SAA7135) */
3665 .driver_data = SAA7134_BOARD_FLYTVPLATINUM_FM,
3666 },{
3667 .vendor = PCI_VENDOR_ID_PHILIPS,
3668 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
3669 .subvendor = 0x5168, /* Animation Technologies (LifeView) */
3670 .subdevice = 0x5214, /* Standard PCI, LR214 Rev F onwards (SAA7131) */
Linus Torvalds1da177e2005-04-16 15:20:36 -07003671 .driver_data = SAA7134_BOARD_FLYTVPLATINUM_FM,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07003672 },{
Linus Torvalds1da177e2005-04-16 15:20:36 -07003673 .vendor = PCI_VENDOR_ID_PHILIPS,
Peter Missel10e92062005-05-01 08:59:21 -07003674 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
3675 .subvendor = 0x1489, /* KYE */
3676 .subdevice = 0x0214, /* Genius VideoWonder ProTV */
3677 .driver_data = SAA7134_BOARD_FLYTVPLATINUM_FM, /* is an LR214WF actually */
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07003678 },{
Peter Missel10e92062005-05-01 08:59:21 -07003679 .vendor = PCI_VENDOR_ID_PHILIPS,
Linus Torvalds1da177e2005-04-16 15:20:36 -07003680 .device = PCI_DEVICE_ID_PHILIPS_SAA7134,
3681 .subvendor = 0x16be,
3682 .subdevice = 0x0003,
3683 .driver_data = SAA7134_BOARD_MD7134,
3684 },{
3685 .vendor = PCI_VENDOR_ID_PHILIPS,
3686 .device = PCI_DEVICE_ID_PHILIPS_SAA7130,
3687 .subvendor = 0x1048,
3688 .subdevice = 0x226b,
3689 .driver_data = SAA7134_BOARD_ELSA,
3690 },{
3691 .vendor = PCI_VENDOR_ID_PHILIPS,
3692 .device = PCI_DEVICE_ID_PHILIPS_SAA7130,
3693 .subvendor = 0x1048,
Michael Krufky9a7871b2006-02-27 15:22:49 -03003694 .subdevice = 0x226a,
Linus Torvalds1da177e2005-04-16 15:20:36 -07003695 .driver_data = SAA7134_BOARD_ELSA_500TV,
3696 },{
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07003697 .vendor = PCI_VENDOR_ID_PHILIPS,
Tamuki Shoichid0456d12006-02-27 00:08:04 -03003698 .device = PCI_DEVICE_ID_PHILIPS_SAA7130,
Michael Krufkyba524292006-02-27 14:38:17 -03003699 .subvendor = 0x1048,
3700 .subdevice = 0x226c,
Tamuki Shoichid0456d12006-02-27 00:08:04 -03003701 .driver_data = SAA7134_BOARD_ELSA_700TV,
3702 },{
3703 .vendor = PCI_VENDOR_ID_PHILIPS,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07003704 .device = PCI_DEVICE_ID_PHILIPS_SAA7134,
3705 .subvendor = PCI_VENDOR_ID_ASUSTEK,
3706 .subdevice = 0x4842,
3707 .driver_data = SAA7134_BOARD_ASUSTeK_TVFM7134,
Linus Torvalds1da177e2005-04-16 15:20:36 -07003708 },{
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07003709 .vendor = PCI_VENDOR_ID_PHILIPS,
3710 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
3711 .subvendor = PCI_VENDOR_ID_ASUSTEK,
3712 .subdevice = 0x4845,
3713 .driver_data = SAA7134_BOARD_ASUSTeK_TVFM7135,
Linus Torvalds1da177e2005-04-16 15:20:36 -07003714 },{
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07003715 .vendor = PCI_VENDOR_ID_PHILIPS,
3716 .device = PCI_DEVICE_ID_PHILIPS_SAA7134,
3717 .subvendor = PCI_VENDOR_ID_ASUSTEK,
3718 .subdevice = 0x4830,
3719 .driver_data = SAA7134_BOARD_ASUSTeK_TVFM7134,
Linus Torvalds1da177e2005-04-16 15:20:36 -07003720 },{
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07003721 .vendor = PCI_VENDOR_ID_PHILIPS,
3722 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
3723 .subvendor = PCI_VENDOR_ID_ASUSTEK,
3724 .subdevice = 0x4843,
3725 .driver_data = SAA7134_BOARD_ASUSTEK_TVFM7133,
3726 },{
3727 .vendor = PCI_VENDOR_ID_PHILIPS,
3728 .device = PCI_DEVICE_ID_PHILIPS_SAA7134,
3729 .subvendor = PCI_VENDOR_ID_ASUSTEK,
3730 .subdevice = 0x4840,
3731 .driver_data = SAA7134_BOARD_ASUSTeK_TVFM7134,
3732 },{
Linus Torvalds1da177e2005-04-16 15:20:36 -07003733 .vendor = PCI_VENDOR_ID_PHILIPS,
3734 .device = PCI_DEVICE_ID_PHILIPS_SAA7134,
3735 .subvendor = PCI_VENDOR_ID_PHILIPS,
3736 .subdevice = 0xfe01,
3737 .driver_data = SAA7134_BOARD_TVSTATION_RDS,
3738 },{
3739 .vendor = PCI_VENDOR_ID_PHILIPS,
3740 .device = PCI_DEVICE_ID_PHILIPS_SAA7134,
3741 .subvendor = 0x1894,
3742 .subdevice = 0xfe01,
3743 .driver_data = SAA7134_BOARD_TVSTATION_RDS,
3744 },{
3745 .vendor = PCI_VENDOR_ID_PHILIPS,
3746 .device = PCI_DEVICE_ID_PHILIPS_SAA7134,
3747 .subvendor = 0x1894,
3748 .subdevice = 0xa006,
3749 .driver_data = SAA7134_BOARD_TVSTATION_DVR,
3750 },{
3751 .vendor = PCI_VENDOR_ID_PHILIPS,
3752 .device = PCI_DEVICE_ID_PHILIPS_SAA7134,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07003753 .subvendor = 0x1131,
3754 .subdevice = 0x7133,
Linus Torvalds1da177e2005-04-16 15:20:36 -07003755 .driver_data = SAA7134_BOARD_VA1000POWER,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07003756 },{
Linus Torvalds1da177e2005-04-16 15:20:36 -07003757 .vendor = PCI_VENDOR_ID_PHILIPS,
3758 .device = PCI_DEVICE_ID_PHILIPS_SAA7130,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07003759 .subvendor = PCI_VENDOR_ID_PHILIPS,
3760 .subdevice = 0x2001,
Linus Torvalds1da177e2005-04-16 15:20:36 -07003761 .driver_data = SAA7134_BOARD_10MOONSTVMASTER,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07003762 },{
Linus Torvalds1da177e2005-04-16 15:20:36 -07003763 .vendor = PCI_VENDOR_ID_PHILIPS,
3764 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07003765 .subvendor = 0x185b,
3766 .subdevice = 0xc100,
Linus Torvalds1da177e2005-04-16 15:20:36 -07003767 .driver_data = SAA7134_BOARD_VIDEOMATE_TV,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07003768 },{
Linus Torvalds1da177e2005-04-16 15:20:36 -07003769 .vendor = PCI_VENDOR_ID_PHILIPS,
3770 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07003771 .subvendor = 0x185b,
3772 .subdevice = 0xc100,
Linus Torvalds1da177e2005-04-16 15:20:36 -07003773 .driver_data = SAA7134_BOARD_VIDEOMATE_TV_GOLD_PLUS,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07003774 },{
Linus Torvalds1da177e2005-04-16 15:20:36 -07003775 .vendor = PCI_VENDOR_ID_PHILIPS,
3776 .device = PCI_DEVICE_ID_PHILIPS_SAA7130,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07003777 .subvendor = PCI_VENDOR_ID_MATROX,
3778 .subdevice = 0x48d0,
Linus Torvalds1da177e2005-04-16 15:20:36 -07003779 .driver_data = SAA7134_BOARD_CRONOS_PLUS,
3780 },{
3781 .vendor = PCI_VENDOR_ID_PHILIPS,
3782 .device = PCI_DEVICE_ID_PHILIPS_SAA7134,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07003783 .subvendor = 0x1461, /* Avermedia Technologies Inc */
3784 .subdevice = 0xa70b,
Linus Torvalds1da177e2005-04-16 15:20:36 -07003785 .driver_data = SAA7134_BOARD_MD2819,
3786 },{
3787 .vendor = PCI_VENDOR_ID_PHILIPS,
3788 .device = PCI_DEVICE_ID_PHILIPS_SAA7130,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07003789 .subvendor = 0x1461, /* Avermedia Technologies Inc */
3790 .subdevice = 0x2115,
Linus Torvalds1da177e2005-04-16 15:20:36 -07003791 .driver_data = SAA7134_BOARD_AVERMEDIA_STUDIO_305,
3792 },{
3793 .vendor = PCI_VENDOR_ID_PHILIPS,
3794 .device = PCI_DEVICE_ID_PHILIPS_SAA7130,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07003795 .subvendor = 0x1461, /* Avermedia Technologies Inc */
3796 .subdevice = 0x2108,
Linus Torvalds1da177e2005-04-16 15:20:36 -07003797 .driver_data = SAA7134_BOARD_AVERMEDIA_305,
3798 },{
3799 .vendor = PCI_VENDOR_ID_PHILIPS,
3800 .device = PCI_DEVICE_ID_PHILIPS_SAA7130,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07003801 .subvendor = 0x1461, /* Avermedia Technologies Inc */
3802 .subdevice = 0x10ff,
Linus Torvalds1da177e2005-04-16 15:20:36 -07003803 .driver_data = SAA7134_BOARD_AVERMEDIA_DVD_EZMAKER,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07003804 },{
Linus Torvalds1da177e2005-04-16 15:20:36 -07003805 /* AVerMedia CardBus */
3806 .vendor = PCI_VENDOR_ID_PHILIPS,
3807 .device = PCI_DEVICE_ID_PHILIPS_SAA7134,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07003808 .subvendor = 0x1461, /* Avermedia Technologies Inc */
3809 .subdevice = 0xd6ee,
Linus Torvalds1da177e2005-04-16 15:20:36 -07003810 .driver_data = SAA7134_BOARD_AVERMEDIA_CARDBUS,
3811 },{
3812 /* TransGear 3000TV */
3813 .vendor = PCI_VENDOR_ID_PHILIPS,
3814 .device = PCI_DEVICE_ID_PHILIPS_SAA7130,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07003815 .subvendor = 0x1461, /* Avermedia Technologies Inc */
3816 .subdevice = 0x050c,
Linus Torvalds1da177e2005-04-16 15:20:36 -07003817 .driver_data = SAA7134_BOARD_TG3000TV,
3818 },{
Linus Torvalds1da177e2005-04-16 15:20:36 -07003819 .vendor = PCI_VENDOR_ID_PHILIPS,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07003820 .device = PCI_DEVICE_ID_PHILIPS_SAA7134,
3821 .subvendor = 0x11bd,
3822 .subdevice = 0x002b,
3823 .driver_data = SAA7134_BOARD_PINNACLE_PCTV_STEREO,
3824 },{
3825 .vendor = PCI_VENDOR_ID_PHILIPS,
3826 .device = PCI_DEVICE_ID_PHILIPS_SAA7134,
3827 .subvendor = 0x11bd,
3828 .subdevice = 0x002d,
3829 .driver_data = SAA7134_BOARD_PINNACLE_300I_DVBT_PAL,
3830 },{
3831 .vendor = PCI_VENDOR_ID_PHILIPS,
3832 .device = PCI_DEVICE_ID_PHILIPS_SAA7134,
3833 .subvendor = 0x1019,
3834 .subdevice = 0x4cb4,
3835 .driver_data = SAA7134_BOARD_ECS_TVP3XP,
3836 },{
3837 .vendor = PCI_VENDOR_ID_PHILIPS,
3838 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
3839 .subvendor = 0x1019,
3840 .subdevice = 0x4cb5,
3841 .driver_data = SAA7134_BOARD_ECS_TVP3XP_4CB5,
3842 },{
3843 .vendor = PCI_VENDOR_ID_PHILIPS,
Simon Farnsworthb39423a2007-05-01 10:01:20 -03003844 .device = PCI_DEVICE_ID_PHILIPS_SAA7134,
3845 .subvendor = 0x1019,
3846 .subdevice = 0x4cb6,
3847 .driver_data = SAA7134_BOARD_ECS_TVP3XP_4CB6,
3848 },{
3849 .vendor = PCI_VENDOR_ID_PHILIPS,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07003850 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
3851 .subvendor = 0x12ab,
3852 .subdevice = 0x0800,
3853 .driver_data = SAA7134_BOARD_UPMOST_PURPLE_TV,
Linus Torvalds1da177e2005-04-16 15:20:36 -07003854 },{
3855 .vendor = PCI_VENDOR_ID_PHILIPS,
3856 .device = PCI_DEVICE_ID_PHILIPS_SAA7130,
Michael Krufky7df64e82005-11-08 21:36:16 -08003857 .subvendor = 0x153b,
Linus Torvalds1da177e2005-04-16 15:20:36 -07003858 .subdevice = 0x1152,
3859 .driver_data = SAA7134_BOARD_CINERGY200,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07003860 },{
Linus Torvalds1da177e2005-04-16 15:20:36 -07003861 .vendor = PCI_VENDOR_ID_PHILIPS,
3862 .device = PCI_DEVICE_ID_PHILIPS_SAA7130,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07003863 .subvendor = 0x185b,
3864 .subdevice = 0xc100,
Linus Torvalds1da177e2005-04-16 15:20:36 -07003865 .driver_data = SAA7134_BOARD_VIDEOMATE_TV_PVR,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07003866 },{
Linus Torvalds1da177e2005-04-16 15:20:36 -07003867 .vendor = PCI_VENDOR_ID_PHILIPS,
Linus Torvalds1da177e2005-04-16 15:20:36 -07003868 .device = PCI_DEVICE_ID_PHILIPS_SAA7134,
3869 .subvendor = 0x1461, /* Avermedia Technologies Inc */
3870 .subdevice = 0x9715,
Mauro Carvalho Chehabac19ecc2005-06-23 22:05:09 -07003871 .driver_data = SAA7134_BOARD_AVERMEDIA_STUDIO_307,
3872 },{
3873 .vendor = PCI_VENDOR_ID_PHILIPS,
3874 .device = PCI_DEVICE_ID_PHILIPS_SAA7134,
3875 .subvendor = 0x1461, /* Avermedia Technologies Inc */
3876 .subdevice = 0xa70a,
Linus Torvalds1da177e2005-04-16 15:20:36 -07003877 .driver_data = SAA7134_BOARD_AVERMEDIA_307,
3878 },{
3879 .vendor = PCI_VENDOR_ID_PHILIPS,
3880 .device = PCI_DEVICE_ID_PHILIPS_SAA7134,
3881 .subvendor = 0x185b,
3882 .subdevice = 0xc200,
3883 .driver_data = SAA7134_BOARD_VIDEOMATE_GOLD_PLUS,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07003884 },{
Linus Torvalds1da177e2005-04-16 15:20:36 -07003885 .vendor = PCI_VENDOR_ID_PHILIPS,
3886 .device = PCI_DEVICE_ID_PHILIPS_SAA7134,
3887 .subvendor = 0x1540,
3888 .subdevice = 0x9524,
3889 .driver_data = SAA7134_BOARD_PROVIDEO_PV952,
3890
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07003891 },{
Linus Torvalds1da177e2005-04-16 15:20:36 -07003892 .vendor = PCI_VENDOR_ID_PHILIPS,
3893 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
3894 .subvendor = 0x5168,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07003895 .subdevice = 0x0502, /* Cardbus version */
Peter Missel10b7a902006-01-23 17:11:06 -02003896 .driver_data = SAA7134_BOARD_FLYDVBT_DUO_CARDBUS,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07003897 },{
3898 .vendor = PCI_VENDOR_ID_PHILIPS,
3899 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
3900 .subvendor = 0x5168,
3901 .subdevice = 0x0306, /* PCI version */
Linus Torvalds1da177e2005-04-16 15:20:36 -07003902 .driver_data = SAA7134_BOARD_FLYDVBTDUO,
Mauro Carvalho Chehabac19ecc2005-06-23 22:05:09 -07003903 },{
3904 .vendor = PCI_VENDOR_ID_PHILIPS,
3905 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
3906 .subvendor = 0x1461, /* Avermedia Technologies Inc */
3907 .subdevice = 0xf31f,
3908 .driver_data = SAA7134_BOARD_AVERMEDIA_GO_007_FM,
3909
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07003910 },{
Mauro Carvalho Chehabac19ecc2005-06-23 22:05:09 -07003911 .vendor = PCI_VENDOR_ID_PHILIPS,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07003912 .device = PCI_DEVICE_ID_PHILIPS_SAA7130,
3913 .subvendor = PCI_VENDOR_ID_PHILIPS,
3914 .subdevice = 0x2004,
3915 .driver_data = SAA7134_BOARD_PHILIPS_TOUGH,
3916 },{
3917 .vendor = PCI_VENDOR_ID_PHILIPS,
3918 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
Mauro Carvalho Chehabac19ecc2005-06-23 22:05:09 -07003919 .subvendor = 0x1421,
3920 .subdevice = 0x0350, /* PCI version */
3921 .driver_data = SAA7134_BOARD_ADS_INSTANT_TV,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07003922 },{
Mauro Carvalho Chehabac19ecc2005-06-23 22:05:09 -07003923 .vendor = PCI_VENDOR_ID_PHILIPS,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07003924 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
Mauro Carvalho Chehabac19ecc2005-06-23 22:05:09 -07003925 .subvendor = 0x1421,
Ricardo Cerqueira41d70c22006-01-09 15:25:34 -02003926 .subdevice = 0x0351, /* PCI version, new revision */
3927 .driver_data = SAA7134_BOARD_ADS_INSTANT_TV,
3928 },{
3929 .vendor = PCI_VENDOR_ID_PHILIPS,
3930 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
3931 .subvendor = 0x1421,
Mauro Carvalho Chehabac19ecc2005-06-23 22:05:09 -07003932 .subdevice = 0x0370, /* cardbus version */
3933 .driver_data = SAA7134_BOARD_ADS_INSTANT_TV,
Hartmut Hackmannd4b0aba2005-11-08 21:38:44 -08003934 },{
3935 .vendor = PCI_VENDOR_ID_PHILIPS,
3936 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
3937 .subvendor = 0x1421,
3938 .subdevice = 0x1370, /* cardbus version */
3939 .driver_data = SAA7134_BOARD_ADS_INSTANT_TV,
Linus Torvalds1da177e2005-04-16 15:20:36 -07003940
Peter Missel10b7a902006-01-23 17:11:06 -02003941 },{
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07003942 .vendor = PCI_VENDOR_ID_PHILIPS,
3943 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
Peter Missel10b7a902006-01-23 17:11:06 -02003944 .subvendor = 0x4e42, /* Typhoon */
3945 .subdevice = 0x0502, /* LifeView LR502 OEM */
3946 .driver_data = SAA7134_BOARD_FLYDVBT_DUO_CARDBUS,
Mauro Carvalho Chehab2f180712005-09-09 13:03:46 -07003947 },{
3948 .vendor = PCI_VENDOR_ID_PHILIPS,
3949 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
3950 .subvendor = 0x1043,
3951 .subdevice = 0x0210, /* mini pci NTSC version */
3952 .driver_data = SAA7134_BOARD_FLYTV_DIGIMATRIX,
3953 },{
3954 .vendor = PCI_VENDOR_ID_PHILIPS,
3955 .device = PCI_DEVICE_ID_PHILIPS_SAA7134,
3956 .subvendor = 0x1043,
3957 .subdevice = 0x0210, /* mini pci PAL/SECAM version */
Michael Krufky5d5c9902005-11-08 21:38:08 -08003958 .driver_data = SAA7134_BOARD_ASUSTEK_DIGIMATRIX_TV,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07003959
3960 },{
Nickolay V. Shmyreva8ff4172005-11-08 21:36:16 -08003961 .vendor = PCI_VENDOR_ID_PHILIPS,
3962 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
3963 .subvendor = 0x0000, /* It shouldn't break anything, since subdevice id seems unique */
3964 .subdevice = 0x4091,
3965 .driver_data = SAA7134_BOARD_BEHOLD_409FM,
Mauro Carvalho Chehab4ac97912005-11-08 21:37:43 -08003966 },{
3967 .vendor = PCI_VENDOR_ID_PHILIPS,
3968 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
3969 .subvendor = 0x5456, /* GoTView */
3970 .subdevice = 0x7135,
3971 .driver_data = SAA7134_BOARD_GOTVIEW_7135,
3972 },{
Hartmut Hackmann2cf36ac2005-11-08 21:36:32 -08003973 .vendor = PCI_VENDOR_ID_PHILIPS,
3974 .device = PCI_DEVICE_ID_PHILIPS_SAA7134,
3975 .subvendor = PCI_VENDOR_ID_PHILIPS,
3976 .subdevice = 0x2004,
3977 .driver_data = SAA7134_BOARD_PHILIPS_EUROPA,
Mauro Carvalho Chehab4ac97912005-11-08 21:37:43 -08003978 },{
Hartmut Hackmann2cf36ac2005-11-08 21:36:32 -08003979 .vendor = PCI_VENDOR_ID_PHILIPS,
3980 .device = PCI_DEVICE_ID_PHILIPS_SAA7134,
3981 .subvendor = 0x185b,
3982 .subdevice = 0xc900,
3983 .driver_data = SAA7134_BOARD_VIDEOMATE_DVBT_300,
Mauro Carvalho Chehab4ac97912005-11-08 21:37:43 -08003984 },{
Hartmut Hackmann2cf36ac2005-11-08 21:36:32 -08003985 .vendor = PCI_VENDOR_ID_PHILIPS,
3986 .device = PCI_DEVICE_ID_PHILIPS_SAA7130,
3987 .subvendor = 0x185b,
3988 .subdevice = 0xc901,
3989 .driver_data = SAA7134_BOARD_VIDEOMATE_DVBT_200,
3990 },{
Mauro Carvalho Chehab4ac97912005-11-08 21:37:43 -08003991 .vendor = PCI_VENDOR_ID_PHILIPS,
3992 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
3993 .subvendor = 0x1435,
3994 .subdevice = 0x7350,
3995 .driver_data = SAA7134_BOARD_RTD_VFG7350,
Nickolay V. Shmyrevbb881f12005-11-08 21:36:35 -08003996 },{
Mauro Carvalho Chehab4ac97912005-11-08 21:37:43 -08003997 .vendor = PCI_VENDOR_ID_PHILIPS,
3998 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
3999 .subvendor = 0x1435,
4000 .subdevice = 0x7330,
4001 .driver_data = SAA7134_BOARD_RTD_VFG7330,
Pieter Palmerscf1c5d12005-11-08 21:37:40 -08004002 },{
Mauro Carvalho Chehab4ac97912005-11-08 21:37:43 -08004003 .vendor = PCI_VENDOR_ID_PHILIPS,
4004 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
4005 .subvendor = 0x1461,
4006 .subdevice = 0x1044,
4007 .driver_data = SAA7134_BOARD_AVERMEDIA_AVERTVHD_A180,
4008 },{
Pieter Palmerscf1c5d12005-11-08 21:37:40 -08004009 .vendor = PCI_VENDOR_ID_PHILIPS,
4010 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
4011 .subvendor = 0x1131,
4012 .subdevice = 0x4ee9,
4013 .driver_data = SAA7134_BOARD_MONSTERTV_MOBILE,
Mauro Carvalho Chehab4ac97912005-11-08 21:37:43 -08004014 },{
Ricardo Cerqueirac2f6f9d2005-11-08 21:37:51 -08004015 .vendor = PCI_VENDOR_ID_PHILIPS,
4016 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
4017 .subvendor = 0x11bd,
4018 .subdevice = 0x002e,
4019 .driver_data = SAA7134_BOARD_PINNACLE_PCTV_110i,
4020 },{
Hermann Pitton28f02242005-11-08 21:38:03 -08004021 .vendor = PCI_VENDOR_ID_PHILIPS,
4022 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
4023 .subvendor = 0x1043,
4024 .subdevice = 0x4862,
4025 .driver_data = SAA7134_BOARD_ASUSTeK_P7131_DUAL,
Pavel Mihaylovc3d93192005-11-08 21:38:43 -08004026 },{
Hartmut Hackmann90e9df72005-11-08 21:38:42 -08004027 .vendor = PCI_VENDOR_ID_PHILIPS,
4028 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
4029 .subvendor = PCI_VENDOR_ID_PHILIPS,
4030 .subdevice = 0x2018,
4031 .driver_data = SAA7134_BOARD_PHILIPS_TIGER,
Hermann Pitton28f02242005-11-08 21:38:03 -08004032 },{
Ricardo Cerqueira80d2ad92005-11-13 16:08:01 -08004033 .vendor = PCI_VENDOR_ID_PHILIPS,
4034 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
4035 .subvendor = 0x1462,
4036 .subdevice = 0x6231,
4037 .driver_data = SAA7134_BOARD_MSI_TVATANYWHERE_PLUS,
4038 },{
Jörg Schummerf639c9b2006-01-09 15:25:01 -02004039 .vendor = PCI_VENDOR_ID_PHILIPS,
4040 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
4041 .subvendor = 0x153b,
4042 .subdevice = 0x1160,
4043 .driver_data = SAA7134_BOARD_CINERGY250PCI,
4044 },{
Peter Missel4aa6ba52006-01-09 15:32:45 -02004045 .vendor = PCI_VENDOR_ID_PHILIPS,
4046 .device = PCI_DEVICE_ID_PHILIPS_SAA7133, /* SAA 7131E */
4047 .subvendor = 0x5168,
4048 .subdevice = 0x0319,
4049 .driver_data = SAA7134_BOARD_FLYDVB_TRIO,
4050 },{
Jose Alberto Regueroa78d0bf2006-02-07 06:25:14 -02004051 .vendor = PCI_VENDOR_ID_PHILIPS,
Hartmut Hackmann1e9bfb92006-08-07 14:03:32 -03004052 .device = PCI_DEVICE_ID_PHILIPS_SAA7134,
Jose Alberto Regueroa78d0bf2006-02-07 06:25:14 -02004053 .subvendor = 0x1461,
4054 .subdevice = 0x2c05,
4055 .driver_data = SAA7134_BOARD_AVERMEDIA_777,
4056 },{
Giampiero Giancipoli3d8466e2006-02-07 06:49:09 -02004057 .vendor = PCI_VENDOR_ID_PHILIPS,
4058 .device = PCI_DEVICE_ID_PHILIPS_SAA7134,
4059 .subvendor = 0x5168,
4060 .subdevice = 0x0301,
4061 .driver_data = SAA7134_BOARD_FLYDVBT_LR301,
4062 },{
Hartmut Hackmanndf42eaf2006-02-07 06:49:10 -02004063 .vendor = PCI_VENDOR_ID_PHILIPS,
4064 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
4065 .subvendor = 0x0331,
4066 .subdevice = 0x1421,
4067 .driver_data = SAA7134_BOARD_ADS_DUO_CARDBUS_PTV331,
4068 },{
Peter Hartshorn3dfb7292006-02-07 06:49:13 -02004069 .vendor = PCI_VENDOR_ID_PHILIPS,
4070 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
4071 .subvendor = 0x17de,
4072 .subdevice = 0x7201,
4073 .driver_data = SAA7134_BOARD_TEVION_DVBT_220RF,
4074 },{
Andrew Burri3e1410a2006-02-27 00:08:23 -03004075 .vendor = PCI_VENDOR_ID_PHILIPS,
Simon Farnsworthb39423a2007-05-01 10:01:20 -03004076 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
4077 .subvendor = 0x17de,
4078 .subdevice = 0x7250,
4079 .driver_data = SAA7134_BOARD_KWORLD_DVBT_210,
4080 },{
4081 .vendor = PCI_VENDOR_ID_PHILIPS,
Andrew Burri3e1410a2006-02-27 00:08:23 -03004082 .device = PCI_DEVICE_ID_PHILIPS_SAA7133, /* SAA7135HL */
4083 .subvendor = 0x17de,
4084 .subdevice = 0x7350,
4085 .driver_data = SAA7134_BOARD_KWORLD_ATSC110,
4086 },{
Rickard Osser68593af2006-03-11 17:14:12 -03004087 .vendor = PCI_VENDOR_ID_PHILIPS,
Eric Sandeen0ac3a5b2007-10-08 16:13:02 -03004088 .device = PCI_DEVICE_ID_PHILIPS_SAA7133, /* SAA7135HL */
4089 .subvendor = 0x17de,
4090 .subdevice = 0x7352,
4091 .driver_data = SAA7134_BOARD_KWORLD_ATSC110, /* ATSC 115 */
4092 },{
4093 .vendor = PCI_VENDOR_ID_PHILIPS,
Rickard Osser68593af2006-03-11 17:14:12 -03004094 .device = PCI_DEVICE_ID_PHILIPS_SAA7134,
4095 .subvendor = 0x1461,
4096 .subdevice = 0x7360,
4097 .driver_data = SAA7134_BOARD_AVERMEDIA_A169_B,
4098 },{
4099 .vendor = PCI_VENDOR_ID_PHILIPS,
4100 .device = PCI_DEVICE_ID_PHILIPS_SAA7134,
4101 .subvendor = 0x1461,
4102 .subdevice = 0x6360,
4103 .driver_data = SAA7134_BOARD_AVERMEDIA_A169_B1,
4104 },{
Michael Krufkyba3a5a82006-03-14 19:02:12 -03004105 .vendor = PCI_VENDOR_ID_PHILIPS,
4106 .device = PCI_DEVICE_ID_PHILIPS_SAA7134,
4107 .subvendor = 0x16be,
4108 .subdevice = 0x0005,
4109 .driver_data = SAA7134_BOARD_MD7134_BRIDGE_2,
4110 },{
Igor M. Liplianine2ac28f2006-08-08 09:10:10 -03004111 .vendor = PCI_VENDOR_ID_PHILIPS,
4112 .device = PCI_DEVICE_ID_PHILIPS_SAA7134,
4113 .subvendor = 0x5168,
4114 .subdevice = 0x0300,
4115 .driver_data = SAA7134_BOARD_FLYDVBS_LR300,
4116 },{
4117 .vendor = PCI_VENDOR_ID_PHILIPS,
4118 .device = PCI_DEVICE_ID_PHILIPS_SAA7134,
4119 .subvendor = 0x4e42,
4120 .subdevice = 0x0300,/* LR300 */
4121 .driver_data = SAA7134_BOARD_FLYDVBS_LR300,
4122 },{
Hartmut Hackmann42e6b3b2006-03-27 19:04:48 -03004123 .vendor = PCI_VENDOR_ID_PHILIPS,
4124 .device = PCI_DEVICE_ID_PHILIPS_SAA7134,
4125 .subvendor = 0x1489,
4126 .subdevice = 0x0301,
4127 .driver_data = SAA7134_BOARD_FLYDVBT_LR301,
4128 },{
4129 .vendor = PCI_VENDOR_ID_PHILIPS,
4130 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
4131 .subvendor = 0x5168, /* Animation Technologies (LifeView) */
4132 .subdevice = 0x0304,
4133 .driver_data = SAA7134_BOARD_FLYTVPLATINUM_FM,
4134 },{
Hartmut Hackmannd95b8942006-03-27 19:39:30 -03004135 .vendor = PCI_VENDOR_ID_PHILIPS,
4136 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
4137 .subvendor = 0x5168,
4138 .subdevice = 0x3306,
4139 .driver_data = SAA7134_BOARD_FLYDVBT_HYBRID_CARDBUS,
4140 },{
4141 .vendor = PCI_VENDOR_ID_PHILIPS,
4142 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
4143 .subvendor = 0x5168,
4144 .subdevice = 0x3502, /* whats the difference to 0x3306 ?*/
4145 .driver_data = SAA7134_BOARD_FLYDVBT_HYBRID_CARDBUS,
4146 },{
Hartmut Hackmann5eda2272006-08-07 14:03:32 -03004147 .vendor = PCI_VENDOR_ID_PHILIPS,
4148 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
4149 .subvendor = 0x16be,
4150 .subdevice = 0x0007,
4151 .driver_data = SAA7134_BOARD_MEDION_MD8800_QUADRO,
4152 },{
4153 .vendor = PCI_VENDOR_ID_PHILIPS,
4154 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
4155 .subvendor = 0x16be,
4156 .subdevice = 0x0008,
4157 .driver_data = SAA7134_BOARD_MEDION_MD8800_QUADRO,
4158 },{
Hartmut Hackmann1e9bfb92006-08-07 14:03:32 -03004159 .vendor = PCI_VENDOR_ID_PHILIPS,
4160 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
4161 .subvendor = 0x1461,
4162 .subdevice = 0x2c05,
4163 .driver_data = SAA7134_BOARD_AVERMEDIA_777,
4164 },{
Hartmut Hackmann2c591942006-08-07 14:03:32 -03004165 .vendor = PCI_VENDOR_ID_PHILIPS,
4166 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
4167 .subvendor = 0x1489,
4168 .subdevice = 0x0502, /* Cardbus version */
4169 .driver_data = SAA7134_BOARD_FLYDVBT_DUO_CARDBUS,
4170 },{
Michal Majchrowiczb04c1ba2006-09-13 16:42:42 -03004171 .vendor = PCI_VENDOR_ID_PHILIPS,
4172 .device = PCI_DEVICE_ID_PHILIPS_SAA7130,
4173 .subvendor = 0x0919, /* Philips Proteus PRO 2309 */
4174 .subdevice = 0x2003,
4175 .driver_data = SAA7134_BOARD_PROTEUS_2309,
4176 },{
Petr Baudis515c2082006-09-26 16:53:53 -03004177 .vendor = PCI_VENDOR_ID_PHILIPS,
4178 .device = PCI_DEVICE_ID_PHILIPS_SAA7134,
4179 .subvendor = 0x1461,
4180 .subdevice = 0x2c00,
4181 .driver_data = SAA7134_BOARD_AVERMEDIA_A16AR,
4182 },{
Hartmut Hackmanncf146ca2006-10-02 20:49:24 -03004183 .vendor = PCI_VENDOR_ID_PHILIPS,
4184 .device = PCI_DEVICE_ID_PHILIPS_SAA7134,
4185 .subvendor = 0x1043,
4186 .subdevice = 0x4860,
4187 .driver_data = SAA7134_BOARD_ASUS_EUROPA2_HYBRID,
4188 },{
Hartmut Hackmann587d2fd2006-10-06 19:13:50 -03004189 .vendor = PCI_VENDOR_ID_PHILIPS,
4190 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
4191 .subvendor = 0x11bd,
4192 .subdevice = 0x002f,
4193 .driver_data = SAA7134_BOARD_PINNACLE_PCTV_310i,
4194 },{
Mikhail Fedotov3ac706d2006-10-06 20:23:47 -03004195 .vendor = PCI_VENDOR_ID_PHILIPS,
4196 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
4197 .subvendor = 0x1461, /* Avermedia Technologies Inc */
4198 .subdevice = 0x9715,
4199 .driver_data = SAA7134_BOARD_AVERMEDIA_STUDIO_507,
4200 },{
Hartmut Hackmann83646812006-10-12 20:38:51 -03004201 .vendor = PCI_VENDOR_ID_PHILIPS,
4202 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
4203 .subvendor = 0x1043,
4204 .subdevice = 0x4876,
Hartmut Hackmannf3eec0c02007-03-14 20:33:55 -03004205 .driver_data = SAA7134_BOARD_ASUSTeK_P7131_HYBRID_LNA,
Hartmut Hackmann83646812006-10-12 20:38:51 -03004206 },{
Thomas Gentyc6e53da2006-11-05 14:17:30 -03004207 .vendor = PCI_VENDOR_ID_PHILIPS,
4208 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
4209 .subvendor = 0x0070,
4210 .subdevice = 0x6701,
4211 .driver_data = SAA7134_BOARD_HAUPPAUGE_HVR1110,
4212 },{
Hartmut Hackmann550a9a52006-11-15 21:31:54 -03004213 .vendor = PCI_VENDOR_ID_PHILIPS,
4214 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
4215 .subvendor = 0x153b,
4216 .subdevice = 0x1172,
4217 .driver_data = SAA7134_BOARD_CINERGY_HT_PCMCIA,
4218 },{
Steven Walterd1158f42006-12-20 09:29:09 -03004219 .vendor = PCI_VENDOR_ID_PHILIPS,
4220 .device = PCI_DEVICE_ID_PHILIPS_SAA7130,
4221 .subvendor = PCI_VENDOR_ID_PHILIPS,
4222 .subdevice = 0x2342,
4223 .driver_data = SAA7134_BOARD_ENCORE_ENLTV,
4224 },{
Juan Pablo Sormanic36c4592006-12-27 12:46:36 -03004225 .vendor = PCI_VENDOR_ID_PHILIPS,
4226 .device = PCI_DEVICE_ID_PHILIPS_SAA7130,
4227 .subvendor = 0x1131,
4228 .subdevice = 0x2341,
4229 .driver_data = SAA7134_BOARD_ENCORE_ENLTV,
4230 },{
4231 .vendor = PCI_VENDOR_ID_PHILIPS,
4232 .device = PCI_DEVICE_ID_PHILIPS_SAA7130,
4233 .subvendor = 0x3016,
4234 .subdevice = 0x2344,
4235 .driver_data = SAA7134_BOARD_ENCORE_ENLTV,
4236 },{
4237 .vendor = PCI_VENDOR_ID_PHILIPS,
4238 .device = PCI_DEVICE_ID_PHILIPS_SAA7130,
4239 .subvendor = 0x1131,
4240 .subdevice = 0x230f,
4241 .driver_data = SAA7134_BOARD_ENCORE_ENLTV_FM,
4242 },{
Michael Krufky9de271e2007-01-16 18:36:40 -03004243 .vendor = PCI_VENDOR_ID_PHILIPS,
4244 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
4245 .subvendor = 0x153b,
4246 .subdevice = 0x1175,
4247 .driver_data = SAA7134_BOARD_CINERGY_HT_PCI,
4248 },{
Markus Rechbergere95d3172007-04-27 12:31:19 -03004249 .vendor = PCI_VENDOR_ID_PHILIPS,
4250 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
4251 .subvendor = 0x1461, /* Avermedia Technologies Inc */
4252 .subdevice = 0xf31e,
4253 .driver_data = SAA7134_BOARD_AVERMEDIA_M102,
4254 },{
Peter Misseldb483672007-04-27 12:31:20 -03004255 .vendor = PCI_VENDOR_ID_PHILIPS,
4256 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
4257 .subvendor = 0x4E42, /* MSI */
4258 .subdevice = 0x0306, /* TV@nywhere DUO */
4259 .driver_data = SAA7134_BOARD_FLYDVBTDUO,
4260 },{
Hartmut Hackmanne06cea42007-03-13 20:58:29 -03004261 .vendor = PCI_VENDOR_ID_PHILIPS,
4262 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
4263 .subvendor = 0x1043,
4264 .subdevice = 0x4871,
4265 .driver_data = SAA7134_BOARD_ASUS_P7131_4871,
4266 },{
4267 .vendor = PCI_VENDOR_ID_PHILIPS,
4268 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
4269 .subvendor = 0x1043,
4270 .subdevice = 0x4857,
4271 .driver_data = SAA7134_BOARD_ASUSTeK_P7131_DUAL,
4272 },{
James T Klaas53958b32007-05-01 10:48:09 -03004273 .vendor = PCI_VENDOR_ID_PHILIPS,
4274 .device = PCI_DEVICE_ID_PHILIPS_SAA7134,
4275 .subvendor = 0x0919, /* SinoVideo PCI 2309 Proteus (7134) */
4276 .subdevice = 0x2003, /* OEM cardbus */
4277 .driver_data = SAA7134_BOARD_SABRENT_TV_PCB05,
4278 },{
Tony Wanaaccb822007-05-10 12:16:47 -03004279 .vendor = PCI_VENDOR_ID_PHILIPS,
4280 .device = PCI_DEVICE_ID_PHILIPS_SAA7130,
4281 .subvendor = PCI_VENDOR_ID_PHILIPS,
4282 .subdevice = 0x2304,
4283 .driver_data = SAA7134_BOARD_10MOONSTVMASTER3,
4284 },{
Edgar Simod90d9f52007-08-20 14:14:50 -03004285 .vendor = PCI_VENDOR_ID_PHILIPS,
4286 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
4287 .subvendor = 0x1461, /* Avermedia Technologies Inc */
4288 .subdevice = 0xf01d, /* AVerTV DVB-T Super 007 */
4289 .driver_data = SAA7134_BOARD_AVERMEDIA_SUPER_007,
4290 },{
Mauro Carvalho Chehab593f18c2007-10-07 02:17:09 -03004291 .vendor = PCI_VENDOR_ID_PHILIPS,
4292 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
4293 .subvendor = 0x4e42,
4294 .subdevice = 0x3502,
4295 .driver_data = SAA7134_BOARD_FLYDVBT_HYBRID_CARDBUS
4296 },{
Linus Torvalds1da177e2005-04-16 15:20:36 -07004297 /* --- boards without eeprom + subsystem ID --- */
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07004298 .vendor = PCI_VENDOR_ID_PHILIPS,
4299 .device = PCI_DEVICE_ID_PHILIPS_SAA7134,
4300 .subvendor = PCI_VENDOR_ID_PHILIPS,
Linus Torvalds1da177e2005-04-16 15:20:36 -07004301 .subdevice = 0,
4302 .driver_data = SAA7134_BOARD_NOAUTO,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07004303 },{
4304 .vendor = PCI_VENDOR_ID_PHILIPS,
4305 .device = PCI_DEVICE_ID_PHILIPS_SAA7130,
4306 .subvendor = PCI_VENDOR_ID_PHILIPS,
Linus Torvalds1da177e2005-04-16 15:20:36 -07004307 .subdevice = 0,
4308 .driver_data = SAA7134_BOARD_NOAUTO,
4309 },{
Linus Torvalds1da177e2005-04-16 15:20:36 -07004310 /* --- default catch --- */
4311 .vendor = PCI_VENDOR_ID_PHILIPS,
4312 .device = PCI_DEVICE_ID_PHILIPS_SAA7130,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07004313 .subvendor = PCI_ANY_ID,
4314 .subdevice = PCI_ANY_ID,
Linus Torvalds1da177e2005-04-16 15:20:36 -07004315 .driver_data = SAA7134_BOARD_UNKNOWN,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07004316 },{
Linus Torvalds1da177e2005-04-16 15:20:36 -07004317 .vendor = PCI_VENDOR_ID_PHILIPS,
4318 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07004319 .subvendor = PCI_ANY_ID,
4320 .subdevice = PCI_ANY_ID,
Linus Torvalds1da177e2005-04-16 15:20:36 -07004321 .driver_data = SAA7134_BOARD_UNKNOWN,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07004322 },{
Linus Torvalds1da177e2005-04-16 15:20:36 -07004323 .vendor = PCI_VENDOR_ID_PHILIPS,
4324 .device = PCI_DEVICE_ID_PHILIPS_SAA7134,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07004325 .subvendor = PCI_ANY_ID,
4326 .subdevice = PCI_ANY_ID,
Linus Torvalds1da177e2005-04-16 15:20:36 -07004327 .driver_data = SAA7134_BOARD_UNKNOWN,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07004328 },{
Linus Torvalds1da177e2005-04-16 15:20:36 -07004329 .vendor = PCI_VENDOR_ID_PHILIPS,
4330 .device = PCI_DEVICE_ID_PHILIPS_SAA7135,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07004331 .subvendor = PCI_ANY_ID,
4332 .subdevice = PCI_ANY_ID,
Linus Torvalds1da177e2005-04-16 15:20:36 -07004333 .driver_data = SAA7134_BOARD_UNKNOWN,
4334 },{
4335 /* --- end of list --- */
4336 }
4337};
4338MODULE_DEVICE_TABLE(pci, saa7134_pci_tbl);
4339
4340/* ----------------------------------------------------------- */
4341/* flyvideo tweaks */
4342
Linus Torvalds1da177e2005-04-16 15:20:36 -07004343
4344static void board_flyvideo(struct saa7134_dev *dev)
4345{
Linus Torvalds1da177e2005-04-16 15:20:36 -07004346 printk("%s: there are different flyvideo cards with different tuners\n"
4347 "%s: out there, you might have to use the tuner=<nr> insmod\n"
4348 "%s: option to override the default value.\n",
4349 dev->name, dev->name, dev->name);
4350}
4351
4352/* ----------------------------------------------------------- */
4353
4354int saa7134_board_init1(struct saa7134_dev *dev)
4355{
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07004356 /* Always print gpio, often manufacturers encode tuner type and other info. */
Linus Torvalds1da177e2005-04-16 15:20:36 -07004357 saa_writel(SAA7134_GPIO_GPMODE0 >> 2, 0);
4358 dev->gpio_value = saa_readl(SAA7134_GPIO_GPSTATUS0 >> 2);
4359 printk(KERN_INFO "%s: board init: gpio is %x\n", dev->name, dev->gpio_value);
4360
4361 switch (dev->board) {
4362 case SAA7134_BOARD_FLYVIDEO2000:
4363 case SAA7134_BOARD_FLYVIDEO3000:
Zac Bowlingf49ba8d2006-06-19 19:49:20 -03004364 case SAA7134_BOARD_FLYVIDEO3000_NTSC:
Ricardo Cerqueiracb2444d2005-11-08 21:38:47 -08004365 dev->has_remote = SAA7134_REMOTE_GPIO;
Linus Torvalds1da177e2005-04-16 15:20:36 -07004366 board_flyvideo(dev);
4367 break;
Arnaud Patard6af90ab2005-11-08 21:36:55 -08004368 case SAA7134_BOARD_FLYTVPLATINUM_MINI2:
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07004369 case SAA7134_BOARD_FLYTVPLATINUM_FM:
Linus Torvalds1da177e2005-04-16 15:20:36 -07004370 case SAA7134_BOARD_CINERGY400:
4371 case SAA7134_BOARD_CINERGY600:
4372 case SAA7134_BOARD_CINERGY600_MK3:
4373 case SAA7134_BOARD_ECS_TVP3XP:
4374 case SAA7134_BOARD_ECS_TVP3XP_4CB5:
Simon Farnsworthb39423a2007-05-01 10:01:20 -03004375 case SAA7134_BOARD_ECS_TVP3XP_4CB6:
Linus Torvalds1da177e2005-04-16 15:20:36 -07004376 case SAA7134_BOARD_MD2819:
Mauro Carvalho Chehabac19ecc2005-06-23 22:05:09 -07004377 case SAA7134_BOARD_KWORLD_VSTREAM_XPERT:
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07004378 case SAA7134_BOARD_KWORLD_XPERT:
Linus Torvalds1da177e2005-04-16 15:20:36 -07004379 case SAA7134_BOARD_AVERMEDIA_STUDIO_305:
4380 case SAA7134_BOARD_AVERMEDIA_305:
Mauro Carvalho Chehabac19ecc2005-06-23 22:05:09 -07004381 case SAA7134_BOARD_AVERMEDIA_STUDIO_307:
Linus Torvalds1da177e2005-04-16 15:20:36 -07004382 case SAA7134_BOARD_AVERMEDIA_307:
Mikhail Fedotov3ac706d2006-10-06 20:23:47 -03004383 case SAA7134_BOARD_AVERMEDIA_STUDIO_507:
Mauro Carvalho Chehabac19ecc2005-06-23 22:05:09 -07004384 case SAA7134_BOARD_AVERMEDIA_GO_007_FM:
pasky@ucw.cz450efcf2006-11-12 14:22:32 -03004385 case SAA7134_BOARD_AVERMEDIA_777:
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07004386/* case SAA7134_BOARD_SABRENT_SBTTVFM: */ /* not finished yet */
Linus Torvalds1da177e2005-04-16 15:20:36 -07004387 case SAA7134_BOARD_VIDEOMATE_TV_PVR:
Nickolay V. Shmyrev2a9a9a82006-01-09 15:25:33 -02004388 case SAA7134_BOARD_VIDEOMATE_GOLD_PLUS:
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07004389 case SAA7134_BOARD_VIDEOMATE_TV_GOLD_PLUSII:
Nickolay V. Shmyrevfea095f2005-11-08 21:36:47 -08004390 case SAA7134_BOARD_VIDEOMATE_DVBT_300:
Michael Krufkyafce8922005-11-08 21:36:57 -08004391 case SAA7134_BOARD_VIDEOMATE_DVBT_200:
Hartmut Hackmanncbb94522006-10-30 20:00:16 -03004392 case SAA7134_BOARD_VIDEOMATE_DVBT_200A:
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07004393 case SAA7134_BOARD_MANLI_MTV001:
4394 case SAA7134_BOARD_MANLI_MTV002:
Nickolay V. Shmyreva8ff4172005-11-08 21:36:16 -08004395 case SAA7134_BOARD_BEHOLD_409FM:
Linus Torvalds1da177e2005-04-16 15:20:36 -07004396 case SAA7134_BOARD_AVACSSMARTTV:
Nickolay V. Shmyrev6b961442005-11-08 21:36:22 -08004397 case SAA7134_BOARD_GOTVIEW_7135:
James R. Webbdc2286c2005-11-08 21:37:00 -08004398 case SAA7134_BOARD_KWORLD_TERMINATOR:
Ricardo Cerqueira17ce1ff2005-11-08 21:38:47 -08004399 case SAA7134_BOARD_SEDNA_PC_TV_CARDBUS:
Giampiero Giancipoli3d8466e2006-02-07 06:49:09 -02004400 case SAA7134_BOARD_FLYDVBT_LR301:
Hermann Pitton91607232006-12-07 21:45:28 -03004401 case SAA7134_BOARD_ASUSTeK_P7131_DUAL:
Hartmut Hackmannf3eec0c02007-03-14 20:33:55 -03004402 case SAA7134_BOARD_ASUSTeK_P7131_HYBRID_LNA:
Rudo Thomasa8029172006-02-27 00:08:46 -03004403 case SAA7134_BOARD_FLYDVBTDUO:
Michal Majchrowiczb04c1ba2006-09-13 16:42:42 -03004404 case SAA7134_BOARD_PROTEUS_2309:
pasky@ucw.cz29e0f1a2006-11-12 14:23:32 -03004405 case SAA7134_BOARD_AVERMEDIA_A16AR:
Juan Pablo Sormanic36c4592006-12-27 12:46:36 -03004406 case SAA7134_BOARD_ENCORE_ENLTV:
4407 case SAA7134_BOARD_ENCORE_ENLTV_FM:
Tony Wan480f75a2007-05-11 11:33:50 -03004408 case SAA7134_BOARD_10MOONSTVMASTER3:
Ricardo Cerqueiracb2444d2005-11-08 21:38:47 -08004409 dev->has_remote = SAA7134_REMOTE_GPIO;
Linus Torvalds1da177e2005-04-16 15:20:36 -07004410 break;
Igor M. Liplianine2ac28f2006-08-08 09:10:10 -03004411 case SAA7134_BOARD_FLYDVBS_LR300:
4412 saa_writeb(SAA7134_GPIO_GPMODE3, 0x80);
4413 saa_writeb(SAA7134_GPIO_GPSTATUS2, 0x40);
4414 dev->has_remote = SAA7134_REMOTE_GPIO;
4415 break;
Linus Torvalds1da177e2005-04-16 15:20:36 -07004416 case SAA7134_BOARD_MD5044:
4417 printk("%s: seems there are two different versions of the MD5044\n"
Michael Krufkyfd2f2672006-03-11 16:21:36 -03004418 "%s: (with the same ID) out there. If sound doesn't work for\n"
4419 "%s: you try the audio_clock_override=0x200000 insmod option.\n",
4420 dev->name,dev->name,dev->name);
Linus Torvalds1da177e2005-04-16 15:20:36 -07004421 break;
4422 case SAA7134_BOARD_CINERGY400_CARDBUS:
4423 /* power-up tuner chip */
4424 saa_andorl(SAA7134_GPIO_GPMODE0 >> 2, 0x00040000, 0x00040000);
4425 saa_andorl(SAA7134_GPIO_GPSTATUS0 >> 2, 0x00040000, 0x00000000);
Mikhail Gusarov7bbbc0a2006-04-20 13:18:50 -03004426 break;
Hartmut Hackmanndf8cf702006-03-03 12:09:26 -03004427 case SAA7134_BOARD_PINNACLE_300I_DVBT_PAL:
4428 /* this turns the remote control chip off to work around a bug in it */
4429 saa_writeb(SAA7134_GPIO_GPMODE1, 0x80);
4430 saa_writeb(SAA7134_GPIO_GPSTATUS1, 0x80);
4431 break;
Pieter Palmerscf1c5d12005-11-08 21:37:40 -08004432 case SAA7134_BOARD_MONSTERTV_MOBILE:
4433 /* power-up tuner chip */
4434 saa_andorl(SAA7134_GPIO_GPMODE0 >> 2, 0x00040000, 0x00040000);
4435 saa_andorl(SAA7134_GPIO_GPSTATUS0 >> 2, 0x00040000, 0x00000004);
Linus Torvalds1da177e2005-04-16 15:20:36 -07004436 break;
Peter Missel10b7a902006-01-23 17:11:06 -02004437 case SAA7134_BOARD_FLYDVBT_DUO_CARDBUS:
Nickolay V. Shmyrev6b961442005-11-08 21:36:22 -08004438 /* turn the fan on */
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07004439 saa_writeb(SAA7134_GPIO_GPMODE3, 0x08);
4440 saa_writeb(SAA7134_GPIO_GPSTATUS3, 0x06);
4441 break;
Hartmut Hackmanndf42eaf2006-02-07 06:49:10 -02004442 case SAA7134_BOARD_ADS_DUO_CARDBUS_PTV331:
Hartmut Hackmannd95b8942006-03-27 19:39:30 -03004443 case SAA7134_BOARD_FLYDVBT_HYBRID_CARDBUS:
Hartmut Hackmann58ef4f92007-04-27 12:31:12 -03004444 saa_andorl(SAA7134_GPIO_GPMODE0 >> 2, 0x08000000, 0x08000000);
4445 saa_andorl(SAA7134_GPIO_GPSTATUS0 >> 2, 0x08000000, 0x00000000);
Hartmut Hackmanndf42eaf2006-02-07 06:49:10 -02004446 break;
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07004447 case SAA7134_BOARD_AVERMEDIA_CARDBUS:
4448 /* power-up tuner chip */
4449 saa_andorl(SAA7134_GPIO_GPMODE0 >> 2, 0xffffffff, 0xffffffff);
4450 saa_andorl(SAA7134_GPIO_GPSTATUS0 >> 2, 0xffffffff, 0xffffffff);
4451 msleep(1);
4452 break;
Nickolay V. Shmyrevbb881f12005-11-08 21:36:35 -08004453 case SAA7134_BOARD_RTD_VFG7350:
4454
4455 /*
4456 * Make sure Production Test Register at offset 0x1D1 is cleared
4457 * to take chip out of test mode. Clearing bit 4 (TST_EN_AOUT)
4458 * prevents pin 105 from remaining low; keeping pin 105 low
4459 * continually resets the SAA6752 chip.
4460 */
4461
4462 saa_writeb (SAA7134_PRODUCTION_TEST_MODE, 0x00);
4463 break;
Ricardo Cerqueiracb2444d2005-11-08 21:38:47 -08004464 /* i2c remotes */
4465 case SAA7134_BOARD_PINNACLE_PCTV_110i:
Hartmut Hackmann587d2fd2006-10-06 19:13:50 -03004466 case SAA7134_BOARD_PINNACLE_PCTV_310i:
Ricardo Cerqueiracb2444d2005-11-08 21:38:47 -08004467 case SAA7134_BOARD_UPMOST_PURPLE_TV:
Thomas Genty177aaaf2006-11-29 21:57:24 -03004468 case SAA7134_BOARD_HAUPPAUGE_HVR1110:
Ricardo Cerqueiracb2444d2005-11-08 21:38:47 -08004469 dev->has_remote = SAA7134_REMOTE_I2C;
4470 break;
Rickard Osser68593af2006-03-11 17:14:12 -03004471 case SAA7134_BOARD_AVERMEDIA_A169_B:
Michael Krufkyba3a5a82006-03-14 19:02:12 -03004472 case SAA7134_BOARD_MD7134_BRIDGE_2:
Michael Krufky12a219d2006-03-14 16:07:42 -03004473 printk("%s: %s: dual saa713x broadcast decoders\n"
Rickard Osser68593af2006-03-11 17:14:12 -03004474 "%s: Sorry, none of the inputs to this chip are supported yet.\n"
4475 "%s: Dual decoder functionality is disabled for now, use the other chip.\n",
Michael Krufky12a219d2006-03-14 16:07:42 -03004476 dev->name,card(dev).name,dev->name,dev->name);
Rickard Osser68593af2006-03-11 17:14:12 -03004477 break;
Markus Rechbergere95d3172007-04-27 12:31:19 -03004478 case SAA7134_BOARD_AVERMEDIA_M102:
4479 /* enable tuner */
4480 saa_andorl(SAA7134_GPIO_GPMODE0 >> 2, 0x8c040007, 0x8c040007);
4481 saa_andorl(SAA7134_GPIO_GPSTATUS0 >> 2, 0x0c0007cd, 0x0c0007cd);
4482 break;
Linus Torvalds1da177e2005-04-16 15:20:36 -07004483 }
Linus Torvalds1da177e2005-04-16 15:20:36 -07004484 return 0;
4485}
4486
4487/* stuff which needs working i2c */
4488int saa7134_board_init2(struct saa7134_dev *dev)
4489{
4490 unsigned char buf;
4491 int board;
Hartmut Hackmanncfeb8832007-04-27 12:31:17 -03004492 struct tuner_setup tun_setup;
4493 tun_setup.config = 0;
4494 tun_setup.tuner_callback = saa7134_tuner_callback;
Linus Torvalds1da177e2005-04-16 15:20:36 -07004495
4496 switch (dev->board) {
4497 case SAA7134_BOARD_BMK_MPEX_NOTUNER:
4498 case SAA7134_BOARD_BMK_MPEX_TUNER:
4499 dev->i2c_client.addr = 0x60;
4500 board = (i2c_master_recv(&dev->i2c_client,&buf,0) < 0)
4501 ? SAA7134_BOARD_BMK_MPEX_NOTUNER
4502 : SAA7134_BOARD_BMK_MPEX_TUNER;
4503 if (board == dev->board)
4504 break;
4505 dev->board = board;
4506 printk("%s: board type fixup: %s\n", dev->name,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07004507 saa7134_boards[dev->board].name);
Linus Torvalds1da177e2005-04-16 15:20:36 -07004508 dev->tuner_type = saa7134_boards[dev->board].tuner_type;
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07004509
4510 if (TUNER_ABSENT != dev->tuner_type) {
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07004511 tun_setup.mode_mask = T_RADIO | T_ANALOG_TV | T_DIGITAL_TV;
4512 tun_setup.type = dev->tuner_type;
4513 tun_setup.addr = ADDR_UNSET;
4514
4515 saa7134_i2c_call_clients (dev, TUNER_SET_TYPE_ADDR, &tun_setup);
4516 }
4517 break;
Hartmut Hackmann2cf36ac2005-11-08 21:36:32 -08004518 case SAA7134_BOARD_MD7134:
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07004519 {
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07004520 u8 subaddr;
4521 u8 data[3];
4522 int ret, tuner_t;
4523
4524 struct i2c_msg msg[] = {{.addr=0x50, .flags=0, .buf=&subaddr, .len = 1},
4525 {.addr=0x50, .flags=I2C_M_RD, .buf=data, .len = 3}};
4526 subaddr= 0x14;
4527 tuner_t = 0;
4528 ret = i2c_transfer(&dev->i2c_adap, msg, 2);
4529 if (ret != 2) {
4530 printk(KERN_ERR "EEPROM read failure\n");
4531 } else if ((data[0] != 0) && (data[0] != 0xff)) {
4532 /* old config structure */
4533 subaddr = data[0] + 2;
4534 msg[1].len = 2;
4535 i2c_transfer(&dev->i2c_adap, msg, 2);
4536 tuner_t = (data[0] << 8) + data[1];
4537 switch (tuner_t){
4538 case 0x0103:
4539 dev->tuner_type = TUNER_PHILIPS_PAL;
4540 break;
4541 case 0x010C:
4542 dev->tuner_type = TUNER_PHILIPS_FM1216ME_MK3;
4543 break;
4544 default:
4545 printk(KERN_ERR "%s Cant determine tuner type %x from EEPROM\n", dev->name, tuner_t);
4546 }
4547 } else if ((data[1] != 0) && (data[1] != 0xff)) {
4548 /* new config structure */
4549 subaddr = data[1] + 1;
4550 msg[1].len = 1;
4551 i2c_transfer(&dev->i2c_adap, msg, 2);
4552 subaddr = data[0] + 1;
4553 msg[1].len = 2;
4554 i2c_transfer(&dev->i2c_adap, msg, 2);
4555 tuner_t = (data[1] << 8) + data[0];
4556 switch (tuner_t) {
4557 case 0x0005:
4558 dev->tuner_type = TUNER_PHILIPS_FM1216ME_MK3;
4559 break;
4560 case 0x001d:
4561 dev->tuner_type = TUNER_PHILIPS_FMD1216ME_MK3;
4562 printk(KERN_INFO "%s Board has DVB-T\n", dev->name);
4563 break;
4564 default:
4565 printk(KERN_ERR "%s Cant determine tuner type %x from EEPROM\n", dev->name, tuner_t);
4566 }
4567 } else {
4568 printk(KERN_ERR "%s unexpected config structure\n", dev->name);
4569 }
4570
4571 printk(KERN_INFO "%s Tuner type is %d\n", dev->name, dev->tuner_type);
4572 if (dev->tuner_type == TUNER_PHILIPS_FMD1216ME_MK3) {
4573 dev->tda9887_conf = TDA9887_PRESENT | TDA9887_PORT1_ACTIVE | TDA9887_PORT2_ACTIVE;
4574 saa7134_i2c_call_clients(dev,TDA9887_SET_CONFIG, &dev->tda9887_conf);
4575 }
4576
4577 tun_setup.mode_mask = T_RADIO | T_ANALOG_TV | T_DIGITAL_TV;
4578 tun_setup.type = dev->tuner_type;
4579 tun_setup.addr = ADDR_UNSET;
4580
4581 saa7134_i2c_call_clients (dev, TUNER_SET_TYPE_ADDR,&tun_setup);
4582 }
Linus Torvalds1da177e2005-04-16 15:20:36 -07004583 break;
Hartmut Hackmann2cf36ac2005-11-08 21:36:32 -08004584 case SAA7134_BOARD_PHILIPS_EUROPA:
4585 case SAA7134_BOARD_VIDEOMATE_DVBT_300:
Hartmut Hackmanncf146ca2006-10-02 20:49:24 -03004586 case SAA7134_BOARD_ASUS_EUROPA2_HYBRID:
Hartmut Hackmann2cf36ac2005-11-08 21:36:32 -08004587 /* The Philips EUROPA based hybrid boards have the tuner connected through
4588 * the channel decoder. We have to make it transparent to find it
Mauro Carvalho Chehab4ac97912005-11-08 21:37:43 -08004589 */
Hartmut Hackmann2cf36ac2005-11-08 21:36:32 -08004590 {
Hartmut Hackmann2cf36ac2005-11-08 21:36:32 -08004591 u8 data[] = { 0x07, 0x02};
4592 struct i2c_msg msg = {.addr=0x08, .flags=0, .buf=data, .len = sizeof(data)};
4593 i2c_transfer(&dev->i2c_adap, &msg, 1);
4594
4595 tun_setup.mode_mask = T_ANALOG_TV | T_DIGITAL_TV;
4596 tun_setup.type = dev->tuner_type;
4597 tun_setup.addr = dev->tuner_addr;
4598
4599 saa7134_i2c_call_clients (dev, TUNER_SET_TYPE_ADDR,&tun_setup);
Mauro Carvalho Chehab4ac97912005-11-08 21:37:43 -08004600 }
Hartmut Hackmann2cf36ac2005-11-08 21:36:32 -08004601 break;
Hartmut Hackmann90e9df72005-11-08 21:38:42 -08004602 case SAA7134_BOARD_PHILIPS_TIGER:
Hartmut Hackmann58ef4f92007-04-27 12:31:12 -03004603 case SAA7134_BOARD_PHILIPS_TIGER_S:
Edgar Simod90d9f52007-08-20 14:14:50 -03004604 case SAA7134_BOARD_AVERMEDIA_SUPER_007:
Hartmut Hackmann58ef4f92007-04-27 12:31:12 -03004605 {
4606 u8 data[] = { 0x3c, 0x33, 0x60};
Hartmut Hackmann58ef4f92007-04-27 12:31:12 -03004607 struct i2c_msg msg = {.addr=0x08, .flags=0, .buf=data, .len = sizeof(data)};
4608 if(dev->autodetected && (dev->eedata[0x49] == 0x50)) {
4609 dev->board = SAA7134_BOARD_PHILIPS_TIGER_S;
4610 printk(KERN_INFO "%s: Reconfigured board as %s\n",
4611 dev->name, saa7134_boards[dev->board].name);
4612 }
4613 if(dev->board == SAA7134_BOARD_PHILIPS_TIGER_S) {
4614 tun_setup.mode_mask = T_ANALOG_TV | T_DIGITAL_TV;
4615 tun_setup.type = TUNER_PHILIPS_TDA8290;
4616 tun_setup.addr = 0x4b;
4617 tun_setup.config = 2;
Hartmut Hackmann58ef4f92007-04-27 12:31:12 -03004618
4619 saa7134_i2c_call_clients (dev, TUNER_SET_TYPE_ADDR,&tun_setup);
4620 data[2] = 0x68;
4621 }
4622 i2c_transfer(&dev->i2c_adap, &msg, 1);
4623 }
4624 break;
Hartmut Hackmann587d2fd2006-10-06 19:13:50 -03004625 case SAA7134_BOARD_PINNACLE_PCTV_310i:
Simon Farnsworthb39423a2007-05-01 10:01:20 -03004626 case SAA7134_BOARD_KWORLD_DVBT_210:
Peter Hartshorn3dfb7292006-02-07 06:49:13 -02004627 case SAA7134_BOARD_TEVION_DVBT_220RF:
Hartmut Hackmannd4b0aba2005-11-08 21:38:44 -08004628 case SAA7134_BOARD_ASUSTeK_P7131_DUAL:
Hartmut Hackmannf3eec0c02007-03-14 20:33:55 -03004629 case SAA7134_BOARD_ASUSTeK_P7131_HYBRID_LNA:
Hartmut Hackmann5eda2272006-08-07 14:03:32 -03004630 case SAA7134_BOARD_MEDION_MD8800_QUADRO:
Thomas Gentyc6e53da2006-11-05 14:17:30 -03004631 case SAA7134_BOARD_HAUPPAUGE_HVR1110:
Peter Hartshorn3dfb7292006-02-07 06:49:13 -02004632 /* this is a hybrid board, initialize to analog mode
4633 * and configure firmware eeprom address
4634 */
Hartmut Hackmann90e9df72005-11-08 21:38:42 -08004635 {
Hartmut Hackmann58ef4f92007-04-27 12:31:12 -03004636 u8 data[] = { 0x3c, 0x33, 0x60};
Hartmut Hackmann90e9df72005-11-08 21:38:42 -08004637 struct i2c_msg msg = {.addr=0x08, .flags=0, .buf=data, .len = sizeof(data)};
4638 i2c_transfer(&dev->i2c_adap, &msg, 1);
4639 }
4640 break;
Nico Sabbi420f32f2006-03-03 12:11:28 -03004641 case SAA7134_BOARD_FLYDVB_TRIO:
Hartmut Hackmann293cdab2006-02-27 21:08:07 -03004642 {
4643 u8 data[] = { 0x3c, 0x33, 0x62};
4644 struct i2c_msg msg = {.addr=0x09, .flags=0, .buf=data, .len = sizeof(data)};
4645 i2c_transfer(&dev->i2c_adap, &msg, 1);
4646 }
4647 break;
Hartmut Hackmanndf42eaf2006-02-07 06:49:10 -02004648 case SAA7134_BOARD_ADS_DUO_CARDBUS_PTV331:
Hartmut Hackmannd95b8942006-03-27 19:39:30 -03004649 case SAA7134_BOARD_FLYDVBT_HYBRID_CARDBUS:
Hartmut Hackmann58ef4f92007-04-27 12:31:12 -03004650 /* initialize analog mode */
Hartmut Hackmanndf42eaf2006-02-07 06:49:10 -02004651 {
Hartmut Hackmann58ef4f92007-04-27 12:31:12 -03004652 u8 data[] = { 0x3c, 0x33, 0x6a};
Hartmut Hackmanndf42eaf2006-02-07 06:49:10 -02004653 struct i2c_msg msg = {.addr=0x08, .flags=0, .buf=data, .len = sizeof(data)};
4654 i2c_transfer(&dev->i2c_adap, &msg, 1);
4655 }
4656 break;
Hartmut Hackmann550a9a52006-11-15 21:31:54 -03004657 case SAA7134_BOARD_CINERGY_HT_PCMCIA:
Michael Krufky9de271e2007-01-16 18:36:40 -03004658 case SAA7134_BOARD_CINERGY_HT_PCI:
Hartmut Hackmann58ef4f92007-04-27 12:31:12 -03004659 /* initialize analog mode */
Hartmut Hackmann550a9a52006-11-15 21:31:54 -03004660 {
Hartmut Hackmann58ef4f92007-04-27 12:31:12 -03004661 u8 data[] = { 0x3c, 0x33, 0x68};
Hartmut Hackmann550a9a52006-11-15 21:31:54 -03004662 struct i2c_msg msg = {.addr=0x08, .flags=0, .buf=data, .len = sizeof(data)};
4663 i2c_transfer(&dev->i2c_adap, &msg, 1);
4664 }
4665 break;
Curt Meyers20b5ee52006-02-27 00:08:39 -03004666 case SAA7134_BOARD_KWORLD_ATSC110:
4667 {
4668 /* enable tuner */
4669 int i;
Michael Krufkyb9ee9ad2006-02-27 00:09:14 -03004670 static const u8 buffer [] = { 0x10,0x12,0x13,0x04,0x16,0x00,0x14,0x04,0x017,0x00 };
Curt Meyers20b5ee52006-02-27 00:08:39 -03004671 dev->i2c_client.addr = 0x0a;
4672 for (i = 0; i < 5; i++)
4673 if (2 != i2c_master_send(&dev->i2c_client,&buffer[i*2],2))
4674 printk(KERN_WARNING "%s: Unable to enable tuner(%i).\n",
4675 dev->name, i);
4676 }
4677 break;
Hartmut Hackmanncbb94522006-10-30 20:00:16 -03004678 case SAA7134_BOARD_VIDEOMATE_DVBT_200:
4679 case SAA7134_BOARD_VIDEOMATE_DVBT_200A:
4680 /* The T200 and the T200A share the same pci id. Consequently,
4681 * we are going to query eeprom to try to find out which one we
4682 * are actually looking at. */
4683
4684 /* Don't do this if the board was specifically selected with an
4685 * insmod option or if we have the default configuration T200*/
4686 if(!dev->autodetected || (dev->eedata[0x41] == 0xd0))
4687 break;
4688 if(dev->eedata[0x41] == 0x02) {
4689 /* Reconfigure board as T200A */
4690 dev->board = SAA7134_BOARD_VIDEOMATE_DVBT_200A;
4691 dev->tuner_type = saa7134_boards[dev->board].tuner_type;
4692 dev->tda9887_conf = saa7134_boards[dev->board].tda9887_conf;
4693 printk(KERN_INFO "%s: Reconfigured board as %s\n",
4694 dev->name, saa7134_boards[dev->board].name);
4695 } else {
4696 printk(KERN_WARNING "%s: Unexpected tuner type info: %x in eeprom\n",
4697 dev->name, dev->eedata[0x41]);
4698 break;
4699 }
4700 break;
Linus Torvalds1da177e2005-04-16 15:20:36 -07004701 }
4702 return 0;
4703}
4704
4705/* ----------------------------------------------------------- */
4706/*
4707 * Local variables:
4708 * c-basic-offset: 8
4709 * End:
4710 */