blob: a4c192fb4e41172cb97e7a8104aecdda16341d74 [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,
337 .vmux = 2,
338 .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,
2999 .amux = LINE2,
3000 },{
3001 .name = name_svideo,
3002 .vmux = 8,
3003 .amux = LINE2,
3004 }},
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,
3224 .mpeg = SAA7134_MPEG_DVB,
Thomas Gentyc6e53da2006-11-05 14:17:30 -03003225 .inputs = {{
3226 .name = name_tv,
3227 .vmux = 1,
3228 .amux = TV,
3229 .tv = 1,
Thomas Genty177aaaf2006-11-29 21:57:24 -03003230 },{
3231 .name = name_comp1,
3232 .vmux = 3,
3233 .amux = LINE2, /* FIXME: audio doesn't work on svideo/composite */
3234 },{
3235 .name = name_svideo,
3236 .vmux = 8,
3237 .amux = LINE2, /* FIXME: audio doesn't work on svideo/composite */
Thomas Gentyc6e53da2006-11-05 14:17:30 -03003238 }},
3239 .radio = {
3240 .name = name_radio,
3241 .amux = TV,
Thomas Gentyc6e53da2006-11-05 14:17:30 -03003242 },
3243 },
Hartmut Hackmann550a9a52006-11-15 21:31:54 -03003244 [SAA7134_BOARD_CINERGY_HT_PCMCIA] = {
3245 .name = "Terratec Cinergy HT PCMCIA",
3246 .audio_clock = 0x00187de7,
3247 .tuner_type = TUNER_PHILIPS_TDA8290,
3248 .radio_type = UNSET,
3249 .tuner_addr = ADDR_UNSET,
3250 .radio_addr = ADDR_UNSET,
3251 .mpeg = SAA7134_MPEG_DVB,
3252 .inputs = {{
3253 .name = name_tv,
3254 .vmux = 1,
3255 .amux = TV,
3256 .tv = 1,
3257 },{
3258 .name = name_comp1,
3259 .vmux = 0,
3260 .amux = LINE1,
3261 },{
3262 .name = name_svideo,
3263 .vmux = 6,
3264 .amux = LINE1,
3265 }},
3266 },
Steven Walterd1158f42006-12-20 09:29:09 -03003267 [SAA7134_BOARD_ENCORE_ENLTV] = {
Juan Pablo Sormanic36c4592006-12-27 12:46:36 -03003268 /* Steven Walter <stevenrwalter@gmail.com>
3269 Juan Pablo Sormani <sorman@gmail.com> */
Steven Walterd1158f42006-12-20 09:29:09 -03003270 .name = "Encore ENLTV",
Juan Pablo Sormanic36c4592006-12-27 12:46:36 -03003271 .audio_clock = 0x00200000,
Steven Walterd1158f42006-12-20 09:29:09 -03003272 .tuner_type = TUNER_TNF_5335MF,
3273 .radio_type = UNSET,
3274 .tuner_addr = ADDR_UNSET,
3275 .radio_addr = ADDR_UNSET,
3276 .inputs = {{
3277 .name = name_tv,
3278 .vmux = 1,
Juan Pablo Sormanic36c4592006-12-27 12:46:36 -03003279 .amux = 3,
Steven Walterd1158f42006-12-20 09:29:09 -03003280 .tv = 1,
3281 },{
Juan Pablo Sormanic36c4592006-12-27 12:46:36 -03003282 .name = name_tv_mono,
3283 .vmux = 7,
3284 .amux = 4,
3285 .tv = 1,
3286 },{
3287 .name = name_comp1,
3288 .vmux = 3,
3289 .amux = 2,
3290 },{
Steven Walterd1158f42006-12-20 09:29:09 -03003291 .name = name_svideo,
Juan Pablo Sormanic36c4592006-12-27 12:46:36 -03003292 .vmux = 0,
3293 .amux = 2,
Steven Walterd1158f42006-12-20 09:29:09 -03003294 }},
Juan Pablo Sormanic36c4592006-12-27 12:46:36 -03003295 .radio = {
3296 .name = name_radio,
3297 .amux = LINE2,
3298/* .gpio = 0x00300001,*/
3299 .gpio = 0x20000,
3300
3301 },
3302 .mute = {
3303 .name = name_mute,
3304 .amux = 0,
3305 },
3306 },
3307 [SAA7134_BOARD_ENCORE_ENLTV_FM] = {
3308 /* Juan Pablo Sormani <sorman@gmail.com> */
3309 .name = "Encore ENLTV-FM",
3310 .audio_clock = 0x00200000,
3311 .tuner_type = TUNER_PHILIPS_ATSC,
3312 .radio_type = UNSET,
3313 .tuner_addr = ADDR_UNSET,
3314 .radio_addr = ADDR_UNSET,
3315 .inputs = {{
3316 .name = name_tv,
3317 .vmux = 1,
3318 .amux = 3,
3319 .tv = 1,
3320 },{
3321 .name = name_tv_mono,
3322 .vmux = 7,
3323 .amux = 4,
3324 .tv = 1,
3325 },{
3326 .name = name_comp1,
3327 .vmux = 3,
3328 .amux = 2,
3329 },{
3330 .name = name_svideo,
3331 .vmux = 0,
3332 .amux = 2,
3333 }},
3334 .radio = {
3335 .name = name_radio,
3336 .amux = LINE2,
3337 .gpio = 0x20000,
3338
3339 },
3340 .mute = {
3341 .name = name_mute,
3342 .amux = 0,
3343 },
Steven Walterd1158f42006-12-20 09:29:09 -03003344 },
Michael Krufky9de271e2007-01-16 18:36:40 -03003345 [SAA7134_BOARD_CINERGY_HT_PCI] = {
3346 .name = "Terratec Cinergy HT PCI",
3347 .audio_clock = 0x00187de7,
3348 .tuner_type = TUNER_PHILIPS_TDA8290,
3349 .radio_type = UNSET,
3350 .tuner_addr = ADDR_UNSET,
3351 .radio_addr = ADDR_UNSET,
3352 .mpeg = SAA7134_MPEG_DVB,
3353 .inputs = {{
3354 .name = name_tv,
3355 .vmux = 1,
3356 .amux = TV,
3357 .tv = 1,
3358 },{
3359 .name = name_comp1,
3360 .vmux = 0,
3361 .amux = LINE1,
3362 },{
3363 .name = name_svideo,
3364 .vmux = 6,
3365 .amux = LINE1,
3366 }},
3367 },
Hartmut Hackmann58ef4f92007-04-27 12:31:12 -03003368 [SAA7134_BOARD_PHILIPS_TIGER_S] = {
3369 .name = "Philips Tiger - S Reference design",
3370 .audio_clock = 0x00187de7,
3371 .tuner_type = TUNER_PHILIPS_TDA8290,
3372 .radio_type = UNSET,
3373 .tuner_addr = ADDR_UNSET,
3374 .radio_addr = ADDR_UNSET,
3375 .tuner_config = 2,
3376 .mpeg = SAA7134_MPEG_DVB,
3377 .gpiomask = 0x0200000,
3378 .inputs = {{
3379 .name = name_tv,
3380 .vmux = 1,
3381 .amux = TV,
3382 .tv = 1,
3383 },{
3384 .name = name_comp1,
3385 .vmux = 3,
3386 .amux = LINE1,
3387 },{
3388 .name = name_svideo,
3389 .vmux = 8,
3390 .amux = LINE1,
3391 }},
3392 .radio = {
3393 .name = name_radio,
3394 .amux = TV,
3395 .gpio = 0x0200000,
3396 },
3397 },
Markus Rechbergere95d3172007-04-27 12:31:19 -03003398 [SAA7134_BOARD_AVERMEDIA_M102] = {
3399 .name = "Avermedia M102",
3400 .audio_clock = 0x00187de7,
3401 .tuner_type = TUNER_PHILIPS_TDA8290,
3402 .radio_type = UNSET,
3403 .tuner_addr = ADDR_UNSET,
3404 .radio_addr = ADDR_UNSET,
3405 .gpiomask = 1<<21,
3406 .inputs = {{
3407 .name = name_tv,
3408 .vmux = 1,
3409 .amux = TV,
3410 .tv = 1,
3411 },{
3412 .name = name_comp1,
3413 .vmux = 0,
3414 .amux = LINE2,
3415 },{
3416 .name = name_svideo,
3417 .vmux = 6,
3418 .amux = LINE2,
3419 }},
3420 },
Hartmut Hackmanne06cea42007-03-13 20:58:29 -03003421 [SAA7134_BOARD_ASUS_P7131_4871] = {
3422 .name = "ASUS P7131 4871",
3423 .audio_clock = 0x00187de7,
3424 .tuner_type = TUNER_PHILIPS_TDA8290,
3425 .radio_type = UNSET,
3426 .tuner_addr = ADDR_UNSET,
3427 .radio_addr = ADDR_UNSET,
3428 .tuner_config = 2,
3429 .mpeg = SAA7134_MPEG_DVB,
3430 .gpiomask = 0x0200000,
3431 .inputs = {{
3432 .name = name_tv,
3433 .vmux = 1,
3434 .amux = TV,
3435 .tv = 1,
3436 .gpio = 0x0200000,
3437 }},
3438 },
Hartmut Hackmannf3eec0c02007-03-14 20:33:55 -03003439 [SAA7134_BOARD_ASUSTeK_P7131_HYBRID_LNA] = {
3440 .name = "ASUSTeK P7131 Hybrid",
Hartmut Hackmanne06cea42007-03-13 20:58:29 -03003441 .audio_clock = 0x00187de7,
3442 .tuner_type = TUNER_PHILIPS_TDA8290,
3443 .radio_type = UNSET,
3444 .tuner_addr = ADDR_UNSET,
3445 .radio_addr = ADDR_UNSET,
3446 .tuner_config = 2,
3447 .gpiomask = 1 << 21,
3448 .mpeg = SAA7134_MPEG_DVB,
3449 .inputs = {{
3450 .name = name_tv,
3451 .vmux = 1,
3452 .amux = TV,
3453 .tv = 1,
3454 .gpio = 0x0000000,
3455 },{
3456 .name = name_comp1,
3457 .vmux = 3,
3458 .amux = LINE2,
3459 .gpio = 0x0200000,
3460 },{
3461 .name = name_comp2,
3462 .vmux = 0,
3463 .amux = LINE2,
3464 .gpio = 0x0200000,
3465 },{
3466 .name = name_svideo,
3467 .vmux = 8,
3468 .amux = LINE2,
3469 .gpio = 0x0200000,
3470 }},
3471 .radio = {
3472 .name = name_radio,
3473 .amux = TV,
3474 .gpio = 0x0200000,
3475 },
3476 },
James T Klaas53958b32007-05-01 10:48:09 -03003477 [SAA7134_BOARD_SABRENT_TV_PCB05] = {
3478 .name = "Sabrent PCMCIA TV-PCB05",
3479 .audio_clock = 0x00187de7,
3480 .tuner_type = TUNER_PHILIPS_TDA8290,
3481 .radio_type = UNSET,
3482 .tuner_addr = ADDR_UNSET,
3483 .radio_addr = ADDR_UNSET,
3484 .inputs = {{
3485 .name = name_tv,
3486 .vmux = 1,
3487 .amux = TV,
3488 .tv = 1,
3489 },{
3490 .name = name_comp1,
3491 .vmux = 3,
3492 .amux = LINE1,
3493 },{
3494 .name = name_comp2,
3495 .vmux = 0,
3496 .amux = LINE1,
3497 },{
3498 .name = name_svideo,
3499 .vmux = 8,
3500 .amux = LINE1,
3501 }},
3502 .mute = {
3503 .name = name_mute,
3504 .amux = TV,
3505 },
3506 },
Tony Wanaaccb822007-05-10 12:16:47 -03003507 [SAA7134_BOARD_10MOONSTVMASTER3] = {
3508 /* Tony Wan <aloha_cn@hotmail.com> */
3509 .name = "10MOONS TM300 TV Card",
3510 .audio_clock = 0x00200000,
3511 .tuner_type = TUNER_LG_PAL_NEW_TAPC,
3512 .radio_type = UNSET,
3513 .tuner_addr = ADDR_UNSET,
3514 .radio_addr = ADDR_UNSET,
3515 .gpiomask = 0x7000,
3516 .inputs = {{
3517 .name = name_tv,
3518 .vmux = 1,
3519 .amux = LINE2,
3520 .gpio = 0x0000,
3521 .tv = 1,
3522 },{
3523 .name = name_comp1,
3524 .vmux = 3,
3525 .amux = LINE1,
3526 .gpio = 0x2000,
3527 },{
3528 .name = name_svideo,
3529 .vmux = 8,
3530 .amux = LINE1,
3531 .gpio = 0x2000,
3532 }},
3533 .mute = {
3534 .name = name_mute,
3535 .amux = LINE2,
3536 .gpio = 0x3000,
3537 },
3538 },
Edgar Simod90d9f52007-08-20 14:14:50 -03003539 [SAA7134_BOARD_AVERMEDIA_SUPER_007] = {
3540 .name = "Avermedia Super 007",
3541 .audio_clock = 0x00187de7,
3542 .tuner_type = TUNER_PHILIPS_TDA8290,
3543 .radio_type = UNSET,
3544 .tuner_addr = ADDR_UNSET,
3545 .radio_addr = ADDR_UNSET,
3546 .tuner_config = 0,
3547 .mpeg = SAA7134_MPEG_DVB,
3548 .inputs = {{
3549 .name = name_tv, /* FIXME: analog tv untested */
3550 .vmux = 1,
3551 .amux = TV,
3552 .tv = 1,
3553 }},
3554 },
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07003555};
3556
Linus Torvalds1da177e2005-04-16 15:20:36 -07003557const unsigned int saa7134_bcount = ARRAY_SIZE(saa7134_boards);
3558
3559/* ------------------------------------------------------------------ */
3560/* PCI ids + subsystem IDs */
3561
3562struct pci_device_id saa7134_pci_tbl[] = {
3563 {
3564 .vendor = PCI_VENDOR_ID_PHILIPS,
3565 .device = PCI_DEVICE_ID_PHILIPS_SAA7134,
3566 .subvendor = PCI_VENDOR_ID_PHILIPS,
3567 .subdevice = 0x2001,
3568 .driver_data = SAA7134_BOARD_PROTEUS_PRO,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07003569 },{
Linus Torvalds1da177e2005-04-16 15:20:36 -07003570 .vendor = PCI_VENDOR_ID_PHILIPS,
3571 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
3572 .subvendor = PCI_VENDOR_ID_PHILIPS,
3573 .subdevice = 0x2001,
3574 .driver_data = SAA7134_BOARD_PROTEUS_PRO,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07003575 },{
Linus Torvalds1da177e2005-04-16 15:20:36 -07003576 .vendor = PCI_VENDOR_ID_PHILIPS,
3577 .device = PCI_DEVICE_ID_PHILIPS_SAA7134,
3578 .subvendor = PCI_VENDOR_ID_PHILIPS,
3579 .subdevice = 0x6752,
3580 .driver_data = SAA7134_BOARD_EMPRESS,
3581 },{
3582 .vendor = PCI_VENDOR_ID_PHILIPS,
3583 .device = PCI_DEVICE_ID_PHILIPS_SAA7134,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07003584 .subvendor = 0x1131,
3585 .subdevice = 0x4e85,
Linus Torvalds1da177e2005-04-16 15:20:36 -07003586 .driver_data = SAA7134_BOARD_MONSTERTV,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07003587 },{
3588 .vendor = PCI_VENDOR_ID_PHILIPS,
3589 .device = PCI_DEVICE_ID_PHILIPS_SAA7134,
Michael Krufky7df64e82005-11-08 21:36:16 -08003590 .subvendor = 0x153b,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07003591 .subdevice = 0x1142,
3592 .driver_data = SAA7134_BOARD_CINERGY400,
3593 },{
3594 .vendor = PCI_VENDOR_ID_PHILIPS,
3595 .device = PCI_DEVICE_ID_PHILIPS_SAA7134,
Michael Krufky7df64e82005-11-08 21:36:16 -08003596 .subvendor = 0x153b,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07003597 .subdevice = 0x1143,
3598 .driver_data = SAA7134_BOARD_CINERGY600,
3599 },{
3600 .vendor = PCI_VENDOR_ID_PHILIPS,
3601 .device = PCI_DEVICE_ID_PHILIPS_SAA7134,
Michael Krufky7df64e82005-11-08 21:36:16 -08003602 .subvendor = 0x153b,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07003603 .subdevice = 0x1158,
3604 .driver_data = SAA7134_BOARD_CINERGY600_MK3,
3605 },{
Linus Torvalds1da177e2005-04-16 15:20:36 -07003606 .vendor = PCI_VENDOR_ID_PHILIPS,
3607 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
3608 .subvendor = 0x153b,
3609 .subdevice = 0x1162,
3610 .driver_data = SAA7134_BOARD_CINERGY400_CARDBUS,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07003611 },{
Linus Torvalds1da177e2005-04-16 15:20:36 -07003612 .vendor = PCI_VENDOR_ID_PHILIPS,
3613 .device = PCI_DEVICE_ID_PHILIPS_SAA7134,
Zac Bowlingf49ba8d2006-06-19 19:49:20 -03003614 .subvendor = 0x5169,
3615 .subdevice = 0x0138,
3616 .driver_data = SAA7134_BOARD_FLYVIDEO3000_NTSC,
3617 },{
3618 .vendor = PCI_VENDOR_ID_PHILIPS,
3619 .device = PCI_DEVICE_ID_PHILIPS_SAA7134,
Linus Torvalds1da177e2005-04-16 15:20:36 -07003620 .subvendor = 0x5168,
3621 .subdevice = 0x0138,
3622 .driver_data = SAA7134_BOARD_FLYVIDEO3000,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07003623 },{
Linus Torvalds1da177e2005-04-16 15:20:36 -07003624 .vendor = PCI_VENDOR_ID_PHILIPS,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07003625 .device = PCI_DEVICE_ID_PHILIPS_SAA7134,
3626 .subvendor = 0x4e42, /* "Typhoon PCI Capture TV Card" Art.No. 50673 */
3627 .subdevice = 0x0138,
3628 .driver_data = SAA7134_BOARD_FLYVIDEO3000,
3629 },{
Linus Torvalds1da177e2005-04-16 15:20:36 -07003630 .vendor = PCI_VENDOR_ID_PHILIPS,
3631 .device = PCI_DEVICE_ID_PHILIPS_SAA7130,
3632 .subvendor = 0x5168,
3633 .subdevice = 0x0138,
3634 .driver_data = SAA7134_BOARD_FLYVIDEO2000,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07003635 },{
Linus Torvalds1da177e2005-04-16 15:20:36 -07003636 .vendor = PCI_VENDOR_ID_PHILIPS,
Peter Missel10b7a902006-01-23 17:11:06 -02003637 .device = PCI_DEVICE_ID_PHILIPS_SAA7130,
3638 .subvendor = 0x4e42, /* Typhoon */
3639 .subdevice = 0x0138, /* LifeView FlyTV Prime30 OEM */
3640 .driver_data = SAA7134_BOARD_FLYVIDEO2000,
3641 },{
3642 .vendor = PCI_VENDOR_ID_PHILIPS,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07003643 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
Linus Torvalds1da177e2005-04-16 15:20:36 -07003644 .subvendor = 0x5168,
3645 .subdevice = 0x0212, /* minipci, LR212 */
3646 .driver_data = SAA7134_BOARD_FLYTVPLATINUM_MINI,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07003647 },{
Linus Torvalds1da177e2005-04-16 15:20:36 -07003648 .vendor = PCI_VENDOR_ID_PHILIPS,
3649 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
Mauro Carvalho Chehab058afaf2005-11-08 21:36:49 -08003650 .subvendor = 0x14c0,
3651 .subdevice = 0x1212, /* minipci, LR1212 */
3652 .driver_data = SAA7134_BOARD_FLYTVPLATINUM_MINI2,
3653 },{
3654 .vendor = PCI_VENDOR_ID_PHILIPS,
3655 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
Glen Gray2d14f782005-11-08 21:36:12 -08003656 .subvendor = 0x4e42,
3657 .subdevice = 0x0212, /* OEM minipci, LR212 */
3658 .driver_data = SAA7134_BOARD_FLYTVPLATINUM_MINI,
3659 },{
3660 .vendor = PCI_VENDOR_ID_PHILIPS,
3661 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
Peter Missel10e92062005-05-01 08:59:21 -07003662 .subvendor = 0x5168, /* Animation Technologies (LifeView) */
Simon Farnsworthb39423a2007-05-01 10:01:20 -03003663 .subdevice = 0x0214, /* Standard PCI, LR214 Rev E and earlier (SAA7135) */
3664 .driver_data = SAA7134_BOARD_FLYTVPLATINUM_FM,
3665 },{
3666 .vendor = PCI_VENDOR_ID_PHILIPS,
3667 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
3668 .subvendor = 0x5168, /* Animation Technologies (LifeView) */
3669 .subdevice = 0x5214, /* Standard PCI, LR214 Rev F onwards (SAA7131) */
Linus Torvalds1da177e2005-04-16 15:20:36 -07003670 .driver_data = SAA7134_BOARD_FLYTVPLATINUM_FM,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07003671 },{
Linus Torvalds1da177e2005-04-16 15:20:36 -07003672 .vendor = PCI_VENDOR_ID_PHILIPS,
Peter Missel10e92062005-05-01 08:59:21 -07003673 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
3674 .subvendor = 0x1489, /* KYE */
3675 .subdevice = 0x0214, /* Genius VideoWonder ProTV */
3676 .driver_data = SAA7134_BOARD_FLYTVPLATINUM_FM, /* is an LR214WF actually */
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07003677 },{
Peter Missel10e92062005-05-01 08:59:21 -07003678 .vendor = PCI_VENDOR_ID_PHILIPS,
Linus Torvalds1da177e2005-04-16 15:20:36 -07003679 .device = PCI_DEVICE_ID_PHILIPS_SAA7134,
3680 .subvendor = 0x16be,
3681 .subdevice = 0x0003,
3682 .driver_data = SAA7134_BOARD_MD7134,
3683 },{
3684 .vendor = PCI_VENDOR_ID_PHILIPS,
3685 .device = PCI_DEVICE_ID_PHILIPS_SAA7130,
3686 .subvendor = 0x1048,
3687 .subdevice = 0x226b,
3688 .driver_data = SAA7134_BOARD_ELSA,
3689 },{
3690 .vendor = PCI_VENDOR_ID_PHILIPS,
3691 .device = PCI_DEVICE_ID_PHILIPS_SAA7130,
3692 .subvendor = 0x1048,
Michael Krufky9a7871b2006-02-27 15:22:49 -03003693 .subdevice = 0x226a,
Linus Torvalds1da177e2005-04-16 15:20:36 -07003694 .driver_data = SAA7134_BOARD_ELSA_500TV,
3695 },{
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07003696 .vendor = PCI_VENDOR_ID_PHILIPS,
Tamuki Shoichid0456d12006-02-27 00:08:04 -03003697 .device = PCI_DEVICE_ID_PHILIPS_SAA7130,
Michael Krufkyba524292006-02-27 14:38:17 -03003698 .subvendor = 0x1048,
3699 .subdevice = 0x226c,
Tamuki Shoichid0456d12006-02-27 00:08:04 -03003700 .driver_data = SAA7134_BOARD_ELSA_700TV,
3701 },{
3702 .vendor = PCI_VENDOR_ID_PHILIPS,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07003703 .device = PCI_DEVICE_ID_PHILIPS_SAA7134,
3704 .subvendor = PCI_VENDOR_ID_ASUSTEK,
3705 .subdevice = 0x4842,
3706 .driver_data = SAA7134_BOARD_ASUSTeK_TVFM7134,
Linus Torvalds1da177e2005-04-16 15:20:36 -07003707 },{
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07003708 .vendor = PCI_VENDOR_ID_PHILIPS,
3709 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
3710 .subvendor = PCI_VENDOR_ID_ASUSTEK,
3711 .subdevice = 0x4845,
3712 .driver_data = SAA7134_BOARD_ASUSTeK_TVFM7135,
Linus Torvalds1da177e2005-04-16 15:20:36 -07003713 },{
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07003714 .vendor = PCI_VENDOR_ID_PHILIPS,
3715 .device = PCI_DEVICE_ID_PHILIPS_SAA7134,
3716 .subvendor = PCI_VENDOR_ID_ASUSTEK,
3717 .subdevice = 0x4830,
3718 .driver_data = SAA7134_BOARD_ASUSTeK_TVFM7134,
Linus Torvalds1da177e2005-04-16 15:20:36 -07003719 },{
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07003720 .vendor = PCI_VENDOR_ID_PHILIPS,
3721 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
3722 .subvendor = PCI_VENDOR_ID_ASUSTEK,
3723 .subdevice = 0x4843,
3724 .driver_data = SAA7134_BOARD_ASUSTEK_TVFM7133,
3725 },{
3726 .vendor = PCI_VENDOR_ID_PHILIPS,
3727 .device = PCI_DEVICE_ID_PHILIPS_SAA7134,
3728 .subvendor = PCI_VENDOR_ID_ASUSTEK,
3729 .subdevice = 0x4840,
3730 .driver_data = SAA7134_BOARD_ASUSTeK_TVFM7134,
3731 },{
Linus Torvalds1da177e2005-04-16 15:20:36 -07003732 .vendor = PCI_VENDOR_ID_PHILIPS,
3733 .device = PCI_DEVICE_ID_PHILIPS_SAA7134,
3734 .subvendor = PCI_VENDOR_ID_PHILIPS,
3735 .subdevice = 0xfe01,
3736 .driver_data = SAA7134_BOARD_TVSTATION_RDS,
3737 },{
3738 .vendor = PCI_VENDOR_ID_PHILIPS,
3739 .device = PCI_DEVICE_ID_PHILIPS_SAA7134,
3740 .subvendor = 0x1894,
3741 .subdevice = 0xfe01,
3742 .driver_data = SAA7134_BOARD_TVSTATION_RDS,
3743 },{
3744 .vendor = PCI_VENDOR_ID_PHILIPS,
3745 .device = PCI_DEVICE_ID_PHILIPS_SAA7134,
3746 .subvendor = 0x1894,
3747 .subdevice = 0xa006,
3748 .driver_data = SAA7134_BOARD_TVSTATION_DVR,
3749 },{
3750 .vendor = PCI_VENDOR_ID_PHILIPS,
3751 .device = PCI_DEVICE_ID_PHILIPS_SAA7134,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07003752 .subvendor = 0x1131,
3753 .subdevice = 0x7133,
Linus Torvalds1da177e2005-04-16 15:20:36 -07003754 .driver_data = SAA7134_BOARD_VA1000POWER,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07003755 },{
Linus Torvalds1da177e2005-04-16 15:20:36 -07003756 .vendor = PCI_VENDOR_ID_PHILIPS,
3757 .device = PCI_DEVICE_ID_PHILIPS_SAA7130,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07003758 .subvendor = PCI_VENDOR_ID_PHILIPS,
3759 .subdevice = 0x2001,
Linus Torvalds1da177e2005-04-16 15:20:36 -07003760 .driver_data = SAA7134_BOARD_10MOONSTVMASTER,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07003761 },{
Linus Torvalds1da177e2005-04-16 15:20:36 -07003762 .vendor = PCI_VENDOR_ID_PHILIPS,
3763 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07003764 .subvendor = 0x185b,
3765 .subdevice = 0xc100,
Linus Torvalds1da177e2005-04-16 15:20:36 -07003766 .driver_data = SAA7134_BOARD_VIDEOMATE_TV,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07003767 },{
Linus Torvalds1da177e2005-04-16 15:20:36 -07003768 .vendor = PCI_VENDOR_ID_PHILIPS,
3769 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07003770 .subvendor = 0x185b,
3771 .subdevice = 0xc100,
Linus Torvalds1da177e2005-04-16 15:20:36 -07003772 .driver_data = SAA7134_BOARD_VIDEOMATE_TV_GOLD_PLUS,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07003773 },{
Linus Torvalds1da177e2005-04-16 15:20:36 -07003774 .vendor = PCI_VENDOR_ID_PHILIPS,
3775 .device = PCI_DEVICE_ID_PHILIPS_SAA7130,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07003776 .subvendor = PCI_VENDOR_ID_MATROX,
3777 .subdevice = 0x48d0,
Linus Torvalds1da177e2005-04-16 15:20:36 -07003778 .driver_data = SAA7134_BOARD_CRONOS_PLUS,
3779 },{
3780 .vendor = PCI_VENDOR_ID_PHILIPS,
3781 .device = PCI_DEVICE_ID_PHILIPS_SAA7134,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07003782 .subvendor = 0x1461, /* Avermedia Technologies Inc */
3783 .subdevice = 0xa70b,
Linus Torvalds1da177e2005-04-16 15:20:36 -07003784 .driver_data = SAA7134_BOARD_MD2819,
3785 },{
3786 .vendor = PCI_VENDOR_ID_PHILIPS,
3787 .device = PCI_DEVICE_ID_PHILIPS_SAA7130,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07003788 .subvendor = 0x1461, /* Avermedia Technologies Inc */
3789 .subdevice = 0x2115,
Linus Torvalds1da177e2005-04-16 15:20:36 -07003790 .driver_data = SAA7134_BOARD_AVERMEDIA_STUDIO_305,
3791 },{
3792 .vendor = PCI_VENDOR_ID_PHILIPS,
3793 .device = PCI_DEVICE_ID_PHILIPS_SAA7130,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07003794 .subvendor = 0x1461, /* Avermedia Technologies Inc */
3795 .subdevice = 0x2108,
Linus Torvalds1da177e2005-04-16 15:20:36 -07003796 .driver_data = SAA7134_BOARD_AVERMEDIA_305,
3797 },{
3798 .vendor = PCI_VENDOR_ID_PHILIPS,
3799 .device = PCI_DEVICE_ID_PHILIPS_SAA7130,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07003800 .subvendor = 0x1461, /* Avermedia Technologies Inc */
3801 .subdevice = 0x10ff,
Linus Torvalds1da177e2005-04-16 15:20:36 -07003802 .driver_data = SAA7134_BOARD_AVERMEDIA_DVD_EZMAKER,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07003803 },{
Linus Torvalds1da177e2005-04-16 15:20:36 -07003804 /* AVerMedia CardBus */
3805 .vendor = PCI_VENDOR_ID_PHILIPS,
3806 .device = PCI_DEVICE_ID_PHILIPS_SAA7134,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07003807 .subvendor = 0x1461, /* Avermedia Technologies Inc */
3808 .subdevice = 0xd6ee,
Linus Torvalds1da177e2005-04-16 15:20:36 -07003809 .driver_data = SAA7134_BOARD_AVERMEDIA_CARDBUS,
3810 },{
3811 /* TransGear 3000TV */
3812 .vendor = PCI_VENDOR_ID_PHILIPS,
3813 .device = PCI_DEVICE_ID_PHILIPS_SAA7130,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07003814 .subvendor = 0x1461, /* Avermedia Technologies Inc */
3815 .subdevice = 0x050c,
Linus Torvalds1da177e2005-04-16 15:20:36 -07003816 .driver_data = SAA7134_BOARD_TG3000TV,
3817 },{
Linus Torvalds1da177e2005-04-16 15:20:36 -07003818 .vendor = PCI_VENDOR_ID_PHILIPS,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07003819 .device = PCI_DEVICE_ID_PHILIPS_SAA7134,
3820 .subvendor = 0x11bd,
3821 .subdevice = 0x002b,
3822 .driver_data = SAA7134_BOARD_PINNACLE_PCTV_STEREO,
3823 },{
3824 .vendor = PCI_VENDOR_ID_PHILIPS,
3825 .device = PCI_DEVICE_ID_PHILIPS_SAA7134,
3826 .subvendor = 0x11bd,
3827 .subdevice = 0x002d,
3828 .driver_data = SAA7134_BOARD_PINNACLE_300I_DVBT_PAL,
3829 },{
3830 .vendor = PCI_VENDOR_ID_PHILIPS,
3831 .device = PCI_DEVICE_ID_PHILIPS_SAA7134,
3832 .subvendor = 0x1019,
3833 .subdevice = 0x4cb4,
3834 .driver_data = SAA7134_BOARD_ECS_TVP3XP,
3835 },{
3836 .vendor = PCI_VENDOR_ID_PHILIPS,
3837 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
3838 .subvendor = 0x1019,
3839 .subdevice = 0x4cb5,
3840 .driver_data = SAA7134_BOARD_ECS_TVP3XP_4CB5,
3841 },{
3842 .vendor = PCI_VENDOR_ID_PHILIPS,
Simon Farnsworthb39423a2007-05-01 10:01:20 -03003843 .device = PCI_DEVICE_ID_PHILIPS_SAA7134,
3844 .subvendor = 0x1019,
3845 .subdevice = 0x4cb6,
3846 .driver_data = SAA7134_BOARD_ECS_TVP3XP_4CB6,
3847 },{
3848 .vendor = PCI_VENDOR_ID_PHILIPS,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07003849 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
3850 .subvendor = 0x12ab,
3851 .subdevice = 0x0800,
3852 .driver_data = SAA7134_BOARD_UPMOST_PURPLE_TV,
Linus Torvalds1da177e2005-04-16 15:20:36 -07003853 },{
3854 .vendor = PCI_VENDOR_ID_PHILIPS,
3855 .device = PCI_DEVICE_ID_PHILIPS_SAA7130,
Michael Krufky7df64e82005-11-08 21:36:16 -08003856 .subvendor = 0x153b,
Linus Torvalds1da177e2005-04-16 15:20:36 -07003857 .subdevice = 0x1152,
3858 .driver_data = SAA7134_BOARD_CINERGY200,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07003859 },{
Linus Torvalds1da177e2005-04-16 15:20:36 -07003860 .vendor = PCI_VENDOR_ID_PHILIPS,
3861 .device = PCI_DEVICE_ID_PHILIPS_SAA7130,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07003862 .subvendor = 0x185b,
3863 .subdevice = 0xc100,
Linus Torvalds1da177e2005-04-16 15:20:36 -07003864 .driver_data = SAA7134_BOARD_VIDEOMATE_TV_PVR,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07003865 },{
Linus Torvalds1da177e2005-04-16 15:20:36 -07003866 .vendor = PCI_VENDOR_ID_PHILIPS,
Linus Torvalds1da177e2005-04-16 15:20:36 -07003867 .device = PCI_DEVICE_ID_PHILIPS_SAA7134,
3868 .subvendor = 0x1461, /* Avermedia Technologies Inc */
3869 .subdevice = 0x9715,
Mauro Carvalho Chehabac19ecc2005-06-23 22:05:09 -07003870 .driver_data = SAA7134_BOARD_AVERMEDIA_STUDIO_307,
3871 },{
3872 .vendor = PCI_VENDOR_ID_PHILIPS,
3873 .device = PCI_DEVICE_ID_PHILIPS_SAA7134,
3874 .subvendor = 0x1461, /* Avermedia Technologies Inc */
3875 .subdevice = 0xa70a,
Linus Torvalds1da177e2005-04-16 15:20:36 -07003876 .driver_data = SAA7134_BOARD_AVERMEDIA_307,
3877 },{
3878 .vendor = PCI_VENDOR_ID_PHILIPS,
3879 .device = PCI_DEVICE_ID_PHILIPS_SAA7134,
3880 .subvendor = 0x185b,
3881 .subdevice = 0xc200,
3882 .driver_data = SAA7134_BOARD_VIDEOMATE_GOLD_PLUS,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07003883 },{
Linus Torvalds1da177e2005-04-16 15:20:36 -07003884 .vendor = PCI_VENDOR_ID_PHILIPS,
3885 .device = PCI_DEVICE_ID_PHILIPS_SAA7134,
3886 .subvendor = 0x1540,
3887 .subdevice = 0x9524,
3888 .driver_data = SAA7134_BOARD_PROVIDEO_PV952,
3889
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07003890 },{
Linus Torvalds1da177e2005-04-16 15:20:36 -07003891 .vendor = PCI_VENDOR_ID_PHILIPS,
3892 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
3893 .subvendor = 0x5168,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07003894 .subdevice = 0x0502, /* Cardbus version */
Peter Missel10b7a902006-01-23 17:11:06 -02003895 .driver_data = SAA7134_BOARD_FLYDVBT_DUO_CARDBUS,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07003896 },{
3897 .vendor = PCI_VENDOR_ID_PHILIPS,
3898 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
3899 .subvendor = 0x5168,
3900 .subdevice = 0x0306, /* PCI version */
Linus Torvalds1da177e2005-04-16 15:20:36 -07003901 .driver_data = SAA7134_BOARD_FLYDVBTDUO,
Mauro Carvalho Chehabac19ecc2005-06-23 22:05:09 -07003902 },{
3903 .vendor = PCI_VENDOR_ID_PHILIPS,
3904 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
3905 .subvendor = 0x1461, /* Avermedia Technologies Inc */
3906 .subdevice = 0xf31f,
3907 .driver_data = SAA7134_BOARD_AVERMEDIA_GO_007_FM,
3908
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07003909 },{
Mauro Carvalho Chehabac19ecc2005-06-23 22:05:09 -07003910 .vendor = PCI_VENDOR_ID_PHILIPS,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07003911 .device = PCI_DEVICE_ID_PHILIPS_SAA7130,
3912 .subvendor = PCI_VENDOR_ID_PHILIPS,
3913 .subdevice = 0x2004,
3914 .driver_data = SAA7134_BOARD_PHILIPS_TOUGH,
3915 },{
3916 .vendor = PCI_VENDOR_ID_PHILIPS,
3917 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
Mauro Carvalho Chehabac19ecc2005-06-23 22:05:09 -07003918 .subvendor = 0x1421,
3919 .subdevice = 0x0350, /* PCI version */
3920 .driver_data = SAA7134_BOARD_ADS_INSTANT_TV,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07003921 },{
Mauro Carvalho Chehabac19ecc2005-06-23 22:05:09 -07003922 .vendor = PCI_VENDOR_ID_PHILIPS,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07003923 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
Mauro Carvalho Chehabac19ecc2005-06-23 22:05:09 -07003924 .subvendor = 0x1421,
Ricardo Cerqueira41d70c22006-01-09 15:25:34 -02003925 .subdevice = 0x0351, /* PCI version, new revision */
3926 .driver_data = SAA7134_BOARD_ADS_INSTANT_TV,
3927 },{
3928 .vendor = PCI_VENDOR_ID_PHILIPS,
3929 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
3930 .subvendor = 0x1421,
Mauro Carvalho Chehabac19ecc2005-06-23 22:05:09 -07003931 .subdevice = 0x0370, /* cardbus version */
3932 .driver_data = SAA7134_BOARD_ADS_INSTANT_TV,
Hartmut Hackmannd4b0aba2005-11-08 21:38:44 -08003933 },{
3934 .vendor = PCI_VENDOR_ID_PHILIPS,
3935 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
3936 .subvendor = 0x1421,
3937 .subdevice = 0x1370, /* cardbus version */
3938 .driver_data = SAA7134_BOARD_ADS_INSTANT_TV,
Linus Torvalds1da177e2005-04-16 15:20:36 -07003939
Peter Missel10b7a902006-01-23 17:11:06 -02003940 },{
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07003941 .vendor = PCI_VENDOR_ID_PHILIPS,
3942 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
Peter Missel10b7a902006-01-23 17:11:06 -02003943 .subvendor = 0x4e42, /* Typhoon */
3944 .subdevice = 0x0502, /* LifeView LR502 OEM */
3945 .driver_data = SAA7134_BOARD_FLYDVBT_DUO_CARDBUS,
Mauro Carvalho Chehab2f180712005-09-09 13:03:46 -07003946 },{
3947 .vendor = PCI_VENDOR_ID_PHILIPS,
3948 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
3949 .subvendor = 0x1043,
3950 .subdevice = 0x0210, /* mini pci NTSC version */
3951 .driver_data = SAA7134_BOARD_FLYTV_DIGIMATRIX,
3952 },{
3953 .vendor = PCI_VENDOR_ID_PHILIPS,
3954 .device = PCI_DEVICE_ID_PHILIPS_SAA7134,
3955 .subvendor = 0x1043,
3956 .subdevice = 0x0210, /* mini pci PAL/SECAM version */
Michael Krufky5d5c9902005-11-08 21:38:08 -08003957 .driver_data = SAA7134_BOARD_ASUSTEK_DIGIMATRIX_TV,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07003958
3959 },{
Nickolay V. Shmyreva8ff4172005-11-08 21:36:16 -08003960 .vendor = PCI_VENDOR_ID_PHILIPS,
3961 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
3962 .subvendor = 0x0000, /* It shouldn't break anything, since subdevice id seems unique */
3963 .subdevice = 0x4091,
3964 .driver_data = SAA7134_BOARD_BEHOLD_409FM,
Mauro Carvalho Chehab4ac97912005-11-08 21:37:43 -08003965 },{
3966 .vendor = PCI_VENDOR_ID_PHILIPS,
3967 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
3968 .subvendor = 0x5456, /* GoTView */
3969 .subdevice = 0x7135,
3970 .driver_data = SAA7134_BOARD_GOTVIEW_7135,
3971 },{
Hartmut Hackmann2cf36ac2005-11-08 21:36:32 -08003972 .vendor = PCI_VENDOR_ID_PHILIPS,
3973 .device = PCI_DEVICE_ID_PHILIPS_SAA7134,
3974 .subvendor = PCI_VENDOR_ID_PHILIPS,
3975 .subdevice = 0x2004,
3976 .driver_data = SAA7134_BOARD_PHILIPS_EUROPA,
Mauro Carvalho Chehab4ac97912005-11-08 21:37:43 -08003977 },{
Hartmut Hackmann2cf36ac2005-11-08 21:36:32 -08003978 .vendor = PCI_VENDOR_ID_PHILIPS,
3979 .device = PCI_DEVICE_ID_PHILIPS_SAA7134,
3980 .subvendor = 0x185b,
3981 .subdevice = 0xc900,
3982 .driver_data = SAA7134_BOARD_VIDEOMATE_DVBT_300,
Mauro Carvalho Chehab4ac97912005-11-08 21:37:43 -08003983 },{
Hartmut Hackmann2cf36ac2005-11-08 21:36:32 -08003984 .vendor = PCI_VENDOR_ID_PHILIPS,
3985 .device = PCI_DEVICE_ID_PHILIPS_SAA7130,
3986 .subvendor = 0x185b,
3987 .subdevice = 0xc901,
3988 .driver_data = SAA7134_BOARD_VIDEOMATE_DVBT_200,
3989 },{
Mauro Carvalho Chehab4ac97912005-11-08 21:37:43 -08003990 .vendor = PCI_VENDOR_ID_PHILIPS,
3991 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
3992 .subvendor = 0x1435,
3993 .subdevice = 0x7350,
3994 .driver_data = SAA7134_BOARD_RTD_VFG7350,
Nickolay V. Shmyrevbb881f12005-11-08 21:36:35 -08003995 },{
Mauro Carvalho Chehab4ac97912005-11-08 21:37:43 -08003996 .vendor = PCI_VENDOR_ID_PHILIPS,
3997 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
3998 .subvendor = 0x1435,
3999 .subdevice = 0x7330,
4000 .driver_data = SAA7134_BOARD_RTD_VFG7330,
Pieter Palmerscf1c5d12005-11-08 21:37:40 -08004001 },{
Mauro Carvalho Chehab4ac97912005-11-08 21:37:43 -08004002 .vendor = PCI_VENDOR_ID_PHILIPS,
4003 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
4004 .subvendor = 0x1461,
4005 .subdevice = 0x1044,
4006 .driver_data = SAA7134_BOARD_AVERMEDIA_AVERTVHD_A180,
4007 },{
Pieter Palmerscf1c5d12005-11-08 21:37:40 -08004008 .vendor = PCI_VENDOR_ID_PHILIPS,
4009 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
4010 .subvendor = 0x1131,
4011 .subdevice = 0x4ee9,
4012 .driver_data = SAA7134_BOARD_MONSTERTV_MOBILE,
Mauro Carvalho Chehab4ac97912005-11-08 21:37:43 -08004013 },{
Ricardo Cerqueirac2f6f9d2005-11-08 21:37:51 -08004014 .vendor = PCI_VENDOR_ID_PHILIPS,
4015 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
4016 .subvendor = 0x11bd,
4017 .subdevice = 0x002e,
4018 .driver_data = SAA7134_BOARD_PINNACLE_PCTV_110i,
4019 },{
Hermann Pitton28f02242005-11-08 21:38:03 -08004020 .vendor = PCI_VENDOR_ID_PHILIPS,
4021 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
4022 .subvendor = 0x1043,
4023 .subdevice = 0x4862,
4024 .driver_data = SAA7134_BOARD_ASUSTeK_P7131_DUAL,
Pavel Mihaylovc3d93192005-11-08 21:38:43 -08004025 },{
Hartmut Hackmann90e9df72005-11-08 21:38:42 -08004026 .vendor = PCI_VENDOR_ID_PHILIPS,
4027 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
4028 .subvendor = PCI_VENDOR_ID_PHILIPS,
4029 .subdevice = 0x2018,
4030 .driver_data = SAA7134_BOARD_PHILIPS_TIGER,
Hermann Pitton28f02242005-11-08 21:38:03 -08004031 },{
Ricardo Cerqueira80d2ad92005-11-13 16:08:01 -08004032 .vendor = PCI_VENDOR_ID_PHILIPS,
4033 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
4034 .subvendor = 0x1462,
4035 .subdevice = 0x6231,
4036 .driver_data = SAA7134_BOARD_MSI_TVATANYWHERE_PLUS,
4037 },{
Jörg Schummerf639c9b2006-01-09 15:25:01 -02004038 .vendor = PCI_VENDOR_ID_PHILIPS,
4039 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
4040 .subvendor = 0x153b,
4041 .subdevice = 0x1160,
4042 .driver_data = SAA7134_BOARD_CINERGY250PCI,
4043 },{
Peter Missel4aa6ba52006-01-09 15:32:45 -02004044 .vendor = PCI_VENDOR_ID_PHILIPS,
4045 .device = PCI_DEVICE_ID_PHILIPS_SAA7133, /* SAA 7131E */
4046 .subvendor = 0x5168,
4047 .subdevice = 0x0319,
4048 .driver_data = SAA7134_BOARD_FLYDVB_TRIO,
4049 },{
Jose Alberto Regueroa78d0bf2006-02-07 06:25:14 -02004050 .vendor = PCI_VENDOR_ID_PHILIPS,
Hartmut Hackmann1e9bfb92006-08-07 14:03:32 -03004051 .device = PCI_DEVICE_ID_PHILIPS_SAA7134,
Jose Alberto Regueroa78d0bf2006-02-07 06:25:14 -02004052 .subvendor = 0x1461,
4053 .subdevice = 0x2c05,
4054 .driver_data = SAA7134_BOARD_AVERMEDIA_777,
4055 },{
Giampiero Giancipoli3d8466e2006-02-07 06:49:09 -02004056 .vendor = PCI_VENDOR_ID_PHILIPS,
4057 .device = PCI_DEVICE_ID_PHILIPS_SAA7134,
4058 .subvendor = 0x5168,
4059 .subdevice = 0x0301,
4060 .driver_data = SAA7134_BOARD_FLYDVBT_LR301,
4061 },{
Hartmut Hackmanndf42eaf2006-02-07 06:49:10 -02004062 .vendor = PCI_VENDOR_ID_PHILIPS,
4063 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
4064 .subvendor = 0x0331,
4065 .subdevice = 0x1421,
4066 .driver_data = SAA7134_BOARD_ADS_DUO_CARDBUS_PTV331,
4067 },{
Peter Hartshorn3dfb7292006-02-07 06:49:13 -02004068 .vendor = PCI_VENDOR_ID_PHILIPS,
4069 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
4070 .subvendor = 0x17de,
4071 .subdevice = 0x7201,
4072 .driver_data = SAA7134_BOARD_TEVION_DVBT_220RF,
4073 },{
Andrew Burri3e1410a2006-02-27 00:08:23 -03004074 .vendor = PCI_VENDOR_ID_PHILIPS,
Simon Farnsworthb39423a2007-05-01 10:01:20 -03004075 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
4076 .subvendor = 0x17de,
4077 .subdevice = 0x7250,
4078 .driver_data = SAA7134_BOARD_KWORLD_DVBT_210,
4079 },{
4080 .vendor = PCI_VENDOR_ID_PHILIPS,
Andrew Burri3e1410a2006-02-27 00:08:23 -03004081 .device = PCI_DEVICE_ID_PHILIPS_SAA7133, /* SAA7135HL */
4082 .subvendor = 0x17de,
4083 .subdevice = 0x7350,
4084 .driver_data = SAA7134_BOARD_KWORLD_ATSC110,
4085 },{
Rickard Osser68593af2006-03-11 17:14:12 -03004086 .vendor = PCI_VENDOR_ID_PHILIPS,
Eric Sandeen0ac3a5b2007-10-08 16:13:02 -03004087 .device = PCI_DEVICE_ID_PHILIPS_SAA7133, /* SAA7135HL */
4088 .subvendor = 0x17de,
4089 .subdevice = 0x7352,
4090 .driver_data = SAA7134_BOARD_KWORLD_ATSC110, /* ATSC 115 */
4091 },{
4092 .vendor = PCI_VENDOR_ID_PHILIPS,
Rickard Osser68593af2006-03-11 17:14:12 -03004093 .device = PCI_DEVICE_ID_PHILIPS_SAA7134,
4094 .subvendor = 0x1461,
4095 .subdevice = 0x7360,
4096 .driver_data = SAA7134_BOARD_AVERMEDIA_A169_B,
4097 },{
4098 .vendor = PCI_VENDOR_ID_PHILIPS,
4099 .device = PCI_DEVICE_ID_PHILIPS_SAA7134,
4100 .subvendor = 0x1461,
4101 .subdevice = 0x6360,
4102 .driver_data = SAA7134_BOARD_AVERMEDIA_A169_B1,
4103 },{
Michael Krufkyba3a5a82006-03-14 19:02:12 -03004104 .vendor = PCI_VENDOR_ID_PHILIPS,
4105 .device = PCI_DEVICE_ID_PHILIPS_SAA7134,
4106 .subvendor = 0x16be,
4107 .subdevice = 0x0005,
4108 .driver_data = SAA7134_BOARD_MD7134_BRIDGE_2,
4109 },{
Igor M. Liplianine2ac28f2006-08-08 09:10:10 -03004110 .vendor = PCI_VENDOR_ID_PHILIPS,
4111 .device = PCI_DEVICE_ID_PHILIPS_SAA7134,
4112 .subvendor = 0x5168,
4113 .subdevice = 0x0300,
4114 .driver_data = SAA7134_BOARD_FLYDVBS_LR300,
4115 },{
4116 .vendor = PCI_VENDOR_ID_PHILIPS,
4117 .device = PCI_DEVICE_ID_PHILIPS_SAA7134,
4118 .subvendor = 0x4e42,
4119 .subdevice = 0x0300,/* LR300 */
4120 .driver_data = SAA7134_BOARD_FLYDVBS_LR300,
4121 },{
Hartmut Hackmann42e6b3b2006-03-27 19:04:48 -03004122 .vendor = PCI_VENDOR_ID_PHILIPS,
4123 .device = PCI_DEVICE_ID_PHILIPS_SAA7134,
4124 .subvendor = 0x1489,
4125 .subdevice = 0x0301,
4126 .driver_data = SAA7134_BOARD_FLYDVBT_LR301,
4127 },{
4128 .vendor = PCI_VENDOR_ID_PHILIPS,
4129 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
4130 .subvendor = 0x5168, /* Animation Technologies (LifeView) */
4131 .subdevice = 0x0304,
4132 .driver_data = SAA7134_BOARD_FLYTVPLATINUM_FM,
4133 },{
Hartmut Hackmannd95b8942006-03-27 19:39:30 -03004134 .vendor = PCI_VENDOR_ID_PHILIPS,
4135 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
4136 .subvendor = 0x5168,
4137 .subdevice = 0x3306,
4138 .driver_data = SAA7134_BOARD_FLYDVBT_HYBRID_CARDBUS,
4139 },{
4140 .vendor = PCI_VENDOR_ID_PHILIPS,
4141 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
4142 .subvendor = 0x5168,
4143 .subdevice = 0x3502, /* whats the difference to 0x3306 ?*/
4144 .driver_data = SAA7134_BOARD_FLYDVBT_HYBRID_CARDBUS,
4145 },{
Hartmut Hackmann5eda2272006-08-07 14:03:32 -03004146 .vendor = PCI_VENDOR_ID_PHILIPS,
4147 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
4148 .subvendor = 0x16be,
4149 .subdevice = 0x0007,
4150 .driver_data = SAA7134_BOARD_MEDION_MD8800_QUADRO,
4151 },{
4152 .vendor = PCI_VENDOR_ID_PHILIPS,
4153 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
4154 .subvendor = 0x16be,
4155 .subdevice = 0x0008,
4156 .driver_data = SAA7134_BOARD_MEDION_MD8800_QUADRO,
4157 },{
Hartmut Hackmann1e9bfb92006-08-07 14:03:32 -03004158 .vendor = PCI_VENDOR_ID_PHILIPS,
4159 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
4160 .subvendor = 0x1461,
4161 .subdevice = 0x2c05,
4162 .driver_data = SAA7134_BOARD_AVERMEDIA_777,
4163 },{
Hartmut Hackmann2c591942006-08-07 14:03:32 -03004164 .vendor = PCI_VENDOR_ID_PHILIPS,
4165 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
4166 .subvendor = 0x1489,
4167 .subdevice = 0x0502, /* Cardbus version */
4168 .driver_data = SAA7134_BOARD_FLYDVBT_DUO_CARDBUS,
4169 },{
Michal Majchrowiczb04c1ba2006-09-13 16:42:42 -03004170 .vendor = PCI_VENDOR_ID_PHILIPS,
4171 .device = PCI_DEVICE_ID_PHILIPS_SAA7130,
4172 .subvendor = 0x0919, /* Philips Proteus PRO 2309 */
4173 .subdevice = 0x2003,
4174 .driver_data = SAA7134_BOARD_PROTEUS_2309,
4175 },{
Petr Baudis515c2082006-09-26 16:53:53 -03004176 .vendor = PCI_VENDOR_ID_PHILIPS,
4177 .device = PCI_DEVICE_ID_PHILIPS_SAA7134,
4178 .subvendor = 0x1461,
4179 .subdevice = 0x2c00,
4180 .driver_data = SAA7134_BOARD_AVERMEDIA_A16AR,
4181 },{
Hartmut Hackmanncf146ca2006-10-02 20:49:24 -03004182 .vendor = PCI_VENDOR_ID_PHILIPS,
4183 .device = PCI_DEVICE_ID_PHILIPS_SAA7134,
4184 .subvendor = 0x1043,
4185 .subdevice = 0x4860,
4186 .driver_data = SAA7134_BOARD_ASUS_EUROPA2_HYBRID,
4187 },{
Hartmut Hackmann587d2fd2006-10-06 19:13:50 -03004188 .vendor = PCI_VENDOR_ID_PHILIPS,
4189 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
4190 .subvendor = 0x11bd,
4191 .subdevice = 0x002f,
4192 .driver_data = SAA7134_BOARD_PINNACLE_PCTV_310i,
4193 },{
Mikhail Fedotov3ac706d2006-10-06 20:23:47 -03004194 .vendor = PCI_VENDOR_ID_PHILIPS,
4195 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
4196 .subvendor = 0x1461, /* Avermedia Technologies Inc */
4197 .subdevice = 0x9715,
4198 .driver_data = SAA7134_BOARD_AVERMEDIA_STUDIO_507,
4199 },{
Hartmut Hackmann83646812006-10-12 20:38:51 -03004200 .vendor = PCI_VENDOR_ID_PHILIPS,
4201 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
4202 .subvendor = 0x1043,
4203 .subdevice = 0x4876,
Hartmut Hackmannf3eec0c02007-03-14 20:33:55 -03004204 .driver_data = SAA7134_BOARD_ASUSTeK_P7131_HYBRID_LNA,
Hartmut Hackmann83646812006-10-12 20:38:51 -03004205 },{
Thomas Gentyc6e53da2006-11-05 14:17:30 -03004206 .vendor = PCI_VENDOR_ID_PHILIPS,
4207 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
4208 .subvendor = 0x0070,
4209 .subdevice = 0x6701,
4210 .driver_data = SAA7134_BOARD_HAUPPAUGE_HVR1110,
4211 },{
Hartmut Hackmann550a9a52006-11-15 21:31:54 -03004212 .vendor = PCI_VENDOR_ID_PHILIPS,
4213 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
4214 .subvendor = 0x153b,
4215 .subdevice = 0x1172,
4216 .driver_data = SAA7134_BOARD_CINERGY_HT_PCMCIA,
4217 },{
Steven Walterd1158f42006-12-20 09:29:09 -03004218 .vendor = PCI_VENDOR_ID_PHILIPS,
4219 .device = PCI_DEVICE_ID_PHILIPS_SAA7130,
4220 .subvendor = PCI_VENDOR_ID_PHILIPS,
4221 .subdevice = 0x2342,
4222 .driver_data = SAA7134_BOARD_ENCORE_ENLTV,
4223 },{
Juan Pablo Sormanic36c4592006-12-27 12:46:36 -03004224 .vendor = PCI_VENDOR_ID_PHILIPS,
4225 .device = PCI_DEVICE_ID_PHILIPS_SAA7130,
4226 .subvendor = 0x1131,
4227 .subdevice = 0x2341,
4228 .driver_data = SAA7134_BOARD_ENCORE_ENLTV,
4229 },{
4230 .vendor = PCI_VENDOR_ID_PHILIPS,
4231 .device = PCI_DEVICE_ID_PHILIPS_SAA7130,
4232 .subvendor = 0x3016,
4233 .subdevice = 0x2344,
4234 .driver_data = SAA7134_BOARD_ENCORE_ENLTV,
4235 },{
4236 .vendor = PCI_VENDOR_ID_PHILIPS,
4237 .device = PCI_DEVICE_ID_PHILIPS_SAA7130,
4238 .subvendor = 0x1131,
4239 .subdevice = 0x230f,
4240 .driver_data = SAA7134_BOARD_ENCORE_ENLTV_FM,
4241 },{
Michael Krufky9de271e2007-01-16 18:36:40 -03004242 .vendor = PCI_VENDOR_ID_PHILIPS,
4243 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
4244 .subvendor = 0x153b,
4245 .subdevice = 0x1175,
4246 .driver_data = SAA7134_BOARD_CINERGY_HT_PCI,
4247 },{
Markus Rechbergere95d3172007-04-27 12:31:19 -03004248 .vendor = PCI_VENDOR_ID_PHILIPS,
4249 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
4250 .subvendor = 0x1461, /* Avermedia Technologies Inc */
4251 .subdevice = 0xf31e,
4252 .driver_data = SAA7134_BOARD_AVERMEDIA_M102,
4253 },{
Peter Misseldb483672007-04-27 12:31:20 -03004254 .vendor = PCI_VENDOR_ID_PHILIPS,
4255 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
4256 .subvendor = 0x4E42, /* MSI */
4257 .subdevice = 0x0306, /* TV@nywhere DUO */
4258 .driver_data = SAA7134_BOARD_FLYDVBTDUO,
4259 },{
Hartmut Hackmanne06cea42007-03-13 20:58:29 -03004260 .vendor = PCI_VENDOR_ID_PHILIPS,
4261 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
4262 .subvendor = 0x1043,
4263 .subdevice = 0x4871,
4264 .driver_data = SAA7134_BOARD_ASUS_P7131_4871,
4265 },{
4266 .vendor = PCI_VENDOR_ID_PHILIPS,
4267 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
4268 .subvendor = 0x1043,
4269 .subdevice = 0x4857,
4270 .driver_data = SAA7134_BOARD_ASUSTeK_P7131_DUAL,
4271 },{
James T Klaas53958b32007-05-01 10:48:09 -03004272 .vendor = PCI_VENDOR_ID_PHILIPS,
4273 .device = PCI_DEVICE_ID_PHILIPS_SAA7134,
4274 .subvendor = 0x0919, /* SinoVideo PCI 2309 Proteus (7134) */
4275 .subdevice = 0x2003, /* OEM cardbus */
4276 .driver_data = SAA7134_BOARD_SABRENT_TV_PCB05,
4277 },{
Tony Wanaaccb822007-05-10 12:16:47 -03004278 .vendor = PCI_VENDOR_ID_PHILIPS,
4279 .device = PCI_DEVICE_ID_PHILIPS_SAA7130,
4280 .subvendor = PCI_VENDOR_ID_PHILIPS,
4281 .subdevice = 0x2304,
4282 .driver_data = SAA7134_BOARD_10MOONSTVMASTER3,
4283 },{
Edgar Simod90d9f52007-08-20 14:14:50 -03004284 .vendor = PCI_VENDOR_ID_PHILIPS,
4285 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
4286 .subvendor = 0x1461, /* Avermedia Technologies Inc */
4287 .subdevice = 0xf01d, /* AVerTV DVB-T Super 007 */
4288 .driver_data = SAA7134_BOARD_AVERMEDIA_SUPER_007,
4289 },{
Mauro Carvalho Chehab593f18c2007-10-07 02:17:09 -03004290 .vendor = PCI_VENDOR_ID_PHILIPS,
4291 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
4292 .subvendor = 0x4e42,
4293 .subdevice = 0x3502,
4294 .driver_data = SAA7134_BOARD_FLYDVBT_HYBRID_CARDBUS
4295 },{
Linus Torvalds1da177e2005-04-16 15:20:36 -07004296 /* --- boards without eeprom + subsystem ID --- */
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07004297 .vendor = PCI_VENDOR_ID_PHILIPS,
4298 .device = PCI_DEVICE_ID_PHILIPS_SAA7134,
4299 .subvendor = PCI_VENDOR_ID_PHILIPS,
Linus Torvalds1da177e2005-04-16 15:20:36 -07004300 .subdevice = 0,
4301 .driver_data = SAA7134_BOARD_NOAUTO,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07004302 },{
4303 .vendor = PCI_VENDOR_ID_PHILIPS,
4304 .device = PCI_DEVICE_ID_PHILIPS_SAA7130,
4305 .subvendor = PCI_VENDOR_ID_PHILIPS,
Linus Torvalds1da177e2005-04-16 15:20:36 -07004306 .subdevice = 0,
4307 .driver_data = SAA7134_BOARD_NOAUTO,
4308 },{
Linus Torvalds1da177e2005-04-16 15:20:36 -07004309 /* --- default catch --- */
4310 .vendor = PCI_VENDOR_ID_PHILIPS,
4311 .device = PCI_DEVICE_ID_PHILIPS_SAA7130,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07004312 .subvendor = PCI_ANY_ID,
4313 .subdevice = PCI_ANY_ID,
Linus Torvalds1da177e2005-04-16 15:20:36 -07004314 .driver_data = SAA7134_BOARD_UNKNOWN,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07004315 },{
Linus Torvalds1da177e2005-04-16 15:20:36 -07004316 .vendor = PCI_VENDOR_ID_PHILIPS,
4317 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07004318 .subvendor = PCI_ANY_ID,
4319 .subdevice = PCI_ANY_ID,
Linus Torvalds1da177e2005-04-16 15:20:36 -07004320 .driver_data = SAA7134_BOARD_UNKNOWN,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07004321 },{
Linus Torvalds1da177e2005-04-16 15:20:36 -07004322 .vendor = PCI_VENDOR_ID_PHILIPS,
4323 .device = PCI_DEVICE_ID_PHILIPS_SAA7134,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07004324 .subvendor = PCI_ANY_ID,
4325 .subdevice = PCI_ANY_ID,
Linus Torvalds1da177e2005-04-16 15:20:36 -07004326 .driver_data = SAA7134_BOARD_UNKNOWN,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07004327 },{
Linus Torvalds1da177e2005-04-16 15:20:36 -07004328 .vendor = PCI_VENDOR_ID_PHILIPS,
4329 .device = PCI_DEVICE_ID_PHILIPS_SAA7135,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07004330 .subvendor = PCI_ANY_ID,
4331 .subdevice = PCI_ANY_ID,
Linus Torvalds1da177e2005-04-16 15:20:36 -07004332 .driver_data = SAA7134_BOARD_UNKNOWN,
4333 },{
4334 /* --- end of list --- */
4335 }
4336};
4337MODULE_DEVICE_TABLE(pci, saa7134_pci_tbl);
4338
4339/* ----------------------------------------------------------- */
4340/* flyvideo tweaks */
4341
Linus Torvalds1da177e2005-04-16 15:20:36 -07004342
4343static void board_flyvideo(struct saa7134_dev *dev)
4344{
Linus Torvalds1da177e2005-04-16 15:20:36 -07004345 printk("%s: there are different flyvideo cards with different tuners\n"
4346 "%s: out there, you might have to use the tuner=<nr> insmod\n"
4347 "%s: option to override the default value.\n",
4348 dev->name, dev->name, dev->name);
4349}
4350
4351/* ----------------------------------------------------------- */
4352
4353int saa7134_board_init1(struct saa7134_dev *dev)
4354{
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07004355 /* Always print gpio, often manufacturers encode tuner type and other info. */
Linus Torvalds1da177e2005-04-16 15:20:36 -07004356 saa_writel(SAA7134_GPIO_GPMODE0 >> 2, 0);
4357 dev->gpio_value = saa_readl(SAA7134_GPIO_GPSTATUS0 >> 2);
4358 printk(KERN_INFO "%s: board init: gpio is %x\n", dev->name, dev->gpio_value);
4359
4360 switch (dev->board) {
4361 case SAA7134_BOARD_FLYVIDEO2000:
4362 case SAA7134_BOARD_FLYVIDEO3000:
Zac Bowlingf49ba8d2006-06-19 19:49:20 -03004363 case SAA7134_BOARD_FLYVIDEO3000_NTSC:
Ricardo Cerqueiracb2444d2005-11-08 21:38:47 -08004364 dev->has_remote = SAA7134_REMOTE_GPIO;
Linus Torvalds1da177e2005-04-16 15:20:36 -07004365 board_flyvideo(dev);
4366 break;
Arnaud Patard6af90ab2005-11-08 21:36:55 -08004367 case SAA7134_BOARD_FLYTVPLATINUM_MINI2:
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07004368 case SAA7134_BOARD_FLYTVPLATINUM_FM:
Linus Torvalds1da177e2005-04-16 15:20:36 -07004369 case SAA7134_BOARD_CINERGY400:
4370 case SAA7134_BOARD_CINERGY600:
4371 case SAA7134_BOARD_CINERGY600_MK3:
4372 case SAA7134_BOARD_ECS_TVP3XP:
4373 case SAA7134_BOARD_ECS_TVP3XP_4CB5:
Simon Farnsworthb39423a2007-05-01 10:01:20 -03004374 case SAA7134_BOARD_ECS_TVP3XP_4CB6:
Linus Torvalds1da177e2005-04-16 15:20:36 -07004375 case SAA7134_BOARD_MD2819:
Mauro Carvalho Chehabac19ecc2005-06-23 22:05:09 -07004376 case SAA7134_BOARD_KWORLD_VSTREAM_XPERT:
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07004377 case SAA7134_BOARD_KWORLD_XPERT:
Linus Torvalds1da177e2005-04-16 15:20:36 -07004378 case SAA7134_BOARD_AVERMEDIA_STUDIO_305:
4379 case SAA7134_BOARD_AVERMEDIA_305:
Mauro Carvalho Chehabac19ecc2005-06-23 22:05:09 -07004380 case SAA7134_BOARD_AVERMEDIA_STUDIO_307:
Linus Torvalds1da177e2005-04-16 15:20:36 -07004381 case SAA7134_BOARD_AVERMEDIA_307:
Mikhail Fedotov3ac706d2006-10-06 20:23:47 -03004382 case SAA7134_BOARD_AVERMEDIA_STUDIO_507:
Mauro Carvalho Chehabac19ecc2005-06-23 22:05:09 -07004383 case SAA7134_BOARD_AVERMEDIA_GO_007_FM:
pasky@ucw.cz450efcf2006-11-12 14:22:32 -03004384 case SAA7134_BOARD_AVERMEDIA_777:
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07004385/* case SAA7134_BOARD_SABRENT_SBTTVFM: */ /* not finished yet */
Linus Torvalds1da177e2005-04-16 15:20:36 -07004386 case SAA7134_BOARD_VIDEOMATE_TV_PVR:
Nickolay V. Shmyrev2a9a9a82006-01-09 15:25:33 -02004387 case SAA7134_BOARD_VIDEOMATE_GOLD_PLUS:
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07004388 case SAA7134_BOARD_VIDEOMATE_TV_GOLD_PLUSII:
Nickolay V. Shmyrevfea095f2005-11-08 21:36:47 -08004389 case SAA7134_BOARD_VIDEOMATE_DVBT_300:
Michael Krufkyafce8922005-11-08 21:36:57 -08004390 case SAA7134_BOARD_VIDEOMATE_DVBT_200:
Hartmut Hackmanncbb94522006-10-30 20:00:16 -03004391 case SAA7134_BOARD_VIDEOMATE_DVBT_200A:
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07004392 case SAA7134_BOARD_MANLI_MTV001:
4393 case SAA7134_BOARD_MANLI_MTV002:
Nickolay V. Shmyreva8ff4172005-11-08 21:36:16 -08004394 case SAA7134_BOARD_BEHOLD_409FM:
Linus Torvalds1da177e2005-04-16 15:20:36 -07004395 case SAA7134_BOARD_AVACSSMARTTV:
Nickolay V. Shmyrev6b961442005-11-08 21:36:22 -08004396 case SAA7134_BOARD_GOTVIEW_7135:
James R. Webbdc2286c2005-11-08 21:37:00 -08004397 case SAA7134_BOARD_KWORLD_TERMINATOR:
Ricardo Cerqueira17ce1ff2005-11-08 21:38:47 -08004398 case SAA7134_BOARD_SEDNA_PC_TV_CARDBUS:
Giampiero Giancipoli3d8466e2006-02-07 06:49:09 -02004399 case SAA7134_BOARD_FLYDVBT_LR301:
Hermann Pitton91607232006-12-07 21:45:28 -03004400 case SAA7134_BOARD_ASUSTeK_P7131_DUAL:
Hartmut Hackmannf3eec0c02007-03-14 20:33:55 -03004401 case SAA7134_BOARD_ASUSTeK_P7131_HYBRID_LNA:
Rudo Thomasa8029172006-02-27 00:08:46 -03004402 case SAA7134_BOARD_FLYDVBTDUO:
Michal Majchrowiczb04c1ba2006-09-13 16:42:42 -03004403 case SAA7134_BOARD_PROTEUS_2309:
pasky@ucw.cz29e0f1a2006-11-12 14:23:32 -03004404 case SAA7134_BOARD_AVERMEDIA_A16AR:
Juan Pablo Sormanic36c4592006-12-27 12:46:36 -03004405 case SAA7134_BOARD_ENCORE_ENLTV:
4406 case SAA7134_BOARD_ENCORE_ENLTV_FM:
Tony Wan480f75a2007-05-11 11:33:50 -03004407 case SAA7134_BOARD_10MOONSTVMASTER3:
Ricardo Cerqueiracb2444d2005-11-08 21:38:47 -08004408 dev->has_remote = SAA7134_REMOTE_GPIO;
Linus Torvalds1da177e2005-04-16 15:20:36 -07004409 break;
Igor M. Liplianine2ac28f2006-08-08 09:10:10 -03004410 case SAA7134_BOARD_FLYDVBS_LR300:
4411 saa_writeb(SAA7134_GPIO_GPMODE3, 0x80);
4412 saa_writeb(SAA7134_GPIO_GPSTATUS2, 0x40);
4413 dev->has_remote = SAA7134_REMOTE_GPIO;
4414 break;
Linus Torvalds1da177e2005-04-16 15:20:36 -07004415 case SAA7134_BOARD_MD5044:
4416 printk("%s: seems there are two different versions of the MD5044\n"
Michael Krufkyfd2f2672006-03-11 16:21:36 -03004417 "%s: (with the same ID) out there. If sound doesn't work for\n"
4418 "%s: you try the audio_clock_override=0x200000 insmod option.\n",
4419 dev->name,dev->name,dev->name);
Linus Torvalds1da177e2005-04-16 15:20:36 -07004420 break;
4421 case SAA7134_BOARD_CINERGY400_CARDBUS:
4422 /* power-up tuner chip */
4423 saa_andorl(SAA7134_GPIO_GPMODE0 >> 2, 0x00040000, 0x00040000);
4424 saa_andorl(SAA7134_GPIO_GPSTATUS0 >> 2, 0x00040000, 0x00000000);
Mikhail Gusarov7bbbc0a2006-04-20 13:18:50 -03004425 break;
Hartmut Hackmanndf8cf702006-03-03 12:09:26 -03004426 case SAA7134_BOARD_PINNACLE_300I_DVBT_PAL:
4427 /* this turns the remote control chip off to work around a bug in it */
4428 saa_writeb(SAA7134_GPIO_GPMODE1, 0x80);
4429 saa_writeb(SAA7134_GPIO_GPSTATUS1, 0x80);
4430 break;
Pieter Palmerscf1c5d12005-11-08 21:37:40 -08004431 case SAA7134_BOARD_MONSTERTV_MOBILE:
4432 /* power-up tuner chip */
4433 saa_andorl(SAA7134_GPIO_GPMODE0 >> 2, 0x00040000, 0x00040000);
4434 saa_andorl(SAA7134_GPIO_GPSTATUS0 >> 2, 0x00040000, 0x00000004);
Linus Torvalds1da177e2005-04-16 15:20:36 -07004435 break;
Peter Missel10b7a902006-01-23 17:11:06 -02004436 case SAA7134_BOARD_FLYDVBT_DUO_CARDBUS:
Nickolay V. Shmyrev6b961442005-11-08 21:36:22 -08004437 /* turn the fan on */
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07004438 saa_writeb(SAA7134_GPIO_GPMODE3, 0x08);
4439 saa_writeb(SAA7134_GPIO_GPSTATUS3, 0x06);
4440 break;
Hartmut Hackmanndf42eaf2006-02-07 06:49:10 -02004441 case SAA7134_BOARD_ADS_DUO_CARDBUS_PTV331:
Hartmut Hackmannd95b8942006-03-27 19:39:30 -03004442 case SAA7134_BOARD_FLYDVBT_HYBRID_CARDBUS:
Hartmut Hackmann58ef4f92007-04-27 12:31:12 -03004443 saa_andorl(SAA7134_GPIO_GPMODE0 >> 2, 0x08000000, 0x08000000);
4444 saa_andorl(SAA7134_GPIO_GPSTATUS0 >> 2, 0x08000000, 0x00000000);
Hartmut Hackmanndf42eaf2006-02-07 06:49:10 -02004445 break;
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07004446 case SAA7134_BOARD_AVERMEDIA_CARDBUS:
4447 /* power-up tuner chip */
4448 saa_andorl(SAA7134_GPIO_GPMODE0 >> 2, 0xffffffff, 0xffffffff);
4449 saa_andorl(SAA7134_GPIO_GPSTATUS0 >> 2, 0xffffffff, 0xffffffff);
4450 msleep(1);
4451 break;
Nickolay V. Shmyrevbb881f12005-11-08 21:36:35 -08004452 case SAA7134_BOARD_RTD_VFG7350:
4453
4454 /*
4455 * Make sure Production Test Register at offset 0x1D1 is cleared
4456 * to take chip out of test mode. Clearing bit 4 (TST_EN_AOUT)
4457 * prevents pin 105 from remaining low; keeping pin 105 low
4458 * continually resets the SAA6752 chip.
4459 */
4460
4461 saa_writeb (SAA7134_PRODUCTION_TEST_MODE, 0x00);
4462 break;
Ricardo Cerqueiracb2444d2005-11-08 21:38:47 -08004463 /* i2c remotes */
4464 case SAA7134_BOARD_PINNACLE_PCTV_110i:
Hartmut Hackmann587d2fd2006-10-06 19:13:50 -03004465 case SAA7134_BOARD_PINNACLE_PCTV_310i:
Ricardo Cerqueiracb2444d2005-11-08 21:38:47 -08004466 case SAA7134_BOARD_UPMOST_PURPLE_TV:
Thomas Genty177aaaf2006-11-29 21:57:24 -03004467 case SAA7134_BOARD_HAUPPAUGE_HVR1110:
Ricardo Cerqueiracb2444d2005-11-08 21:38:47 -08004468 dev->has_remote = SAA7134_REMOTE_I2C;
4469 break;
Rickard Osser68593af2006-03-11 17:14:12 -03004470 case SAA7134_BOARD_AVERMEDIA_A169_B:
Michael Krufkyba3a5a82006-03-14 19:02:12 -03004471 case SAA7134_BOARD_MD7134_BRIDGE_2:
Michael Krufky12a219d2006-03-14 16:07:42 -03004472 printk("%s: %s: dual saa713x broadcast decoders\n"
Rickard Osser68593af2006-03-11 17:14:12 -03004473 "%s: Sorry, none of the inputs to this chip are supported yet.\n"
4474 "%s: Dual decoder functionality is disabled for now, use the other chip.\n",
Michael Krufky12a219d2006-03-14 16:07:42 -03004475 dev->name,card(dev).name,dev->name,dev->name);
Rickard Osser68593af2006-03-11 17:14:12 -03004476 break;
Markus Rechbergere95d3172007-04-27 12:31:19 -03004477 case SAA7134_BOARD_AVERMEDIA_M102:
4478 /* enable tuner */
4479 saa_andorl(SAA7134_GPIO_GPMODE0 >> 2, 0x8c040007, 0x8c040007);
4480 saa_andorl(SAA7134_GPIO_GPSTATUS0 >> 2, 0x0c0007cd, 0x0c0007cd);
4481 break;
Linus Torvalds1da177e2005-04-16 15:20:36 -07004482 }
Linus Torvalds1da177e2005-04-16 15:20:36 -07004483 return 0;
4484}
4485
4486/* stuff which needs working i2c */
4487int saa7134_board_init2(struct saa7134_dev *dev)
4488{
4489 unsigned char buf;
4490 int board;
Hartmut Hackmanncfeb8832007-04-27 12:31:17 -03004491 struct tuner_setup tun_setup;
4492 tun_setup.config = 0;
4493 tun_setup.tuner_callback = saa7134_tuner_callback;
Linus Torvalds1da177e2005-04-16 15:20:36 -07004494
4495 switch (dev->board) {
4496 case SAA7134_BOARD_BMK_MPEX_NOTUNER:
4497 case SAA7134_BOARD_BMK_MPEX_TUNER:
4498 dev->i2c_client.addr = 0x60;
4499 board = (i2c_master_recv(&dev->i2c_client,&buf,0) < 0)
4500 ? SAA7134_BOARD_BMK_MPEX_NOTUNER
4501 : SAA7134_BOARD_BMK_MPEX_TUNER;
4502 if (board == dev->board)
4503 break;
4504 dev->board = board;
4505 printk("%s: board type fixup: %s\n", dev->name,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07004506 saa7134_boards[dev->board].name);
Linus Torvalds1da177e2005-04-16 15:20:36 -07004507 dev->tuner_type = saa7134_boards[dev->board].tuner_type;
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07004508
4509 if (TUNER_ABSENT != dev->tuner_type) {
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07004510 tun_setup.mode_mask = T_RADIO | T_ANALOG_TV | T_DIGITAL_TV;
4511 tun_setup.type = dev->tuner_type;
4512 tun_setup.addr = ADDR_UNSET;
4513
4514 saa7134_i2c_call_clients (dev, TUNER_SET_TYPE_ADDR, &tun_setup);
4515 }
4516 break;
Hartmut Hackmann2cf36ac2005-11-08 21:36:32 -08004517 case SAA7134_BOARD_MD7134:
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07004518 {
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07004519 u8 subaddr;
4520 u8 data[3];
4521 int ret, tuner_t;
4522
4523 struct i2c_msg msg[] = {{.addr=0x50, .flags=0, .buf=&subaddr, .len = 1},
4524 {.addr=0x50, .flags=I2C_M_RD, .buf=data, .len = 3}};
4525 subaddr= 0x14;
4526 tuner_t = 0;
4527 ret = i2c_transfer(&dev->i2c_adap, msg, 2);
4528 if (ret != 2) {
4529 printk(KERN_ERR "EEPROM read failure\n");
4530 } else if ((data[0] != 0) && (data[0] != 0xff)) {
4531 /* old config structure */
4532 subaddr = data[0] + 2;
4533 msg[1].len = 2;
4534 i2c_transfer(&dev->i2c_adap, msg, 2);
4535 tuner_t = (data[0] << 8) + data[1];
4536 switch (tuner_t){
4537 case 0x0103:
4538 dev->tuner_type = TUNER_PHILIPS_PAL;
4539 break;
4540 case 0x010C:
4541 dev->tuner_type = TUNER_PHILIPS_FM1216ME_MK3;
4542 break;
4543 default:
4544 printk(KERN_ERR "%s Cant determine tuner type %x from EEPROM\n", dev->name, tuner_t);
4545 }
4546 } else if ((data[1] != 0) && (data[1] != 0xff)) {
4547 /* new config structure */
4548 subaddr = data[1] + 1;
4549 msg[1].len = 1;
4550 i2c_transfer(&dev->i2c_adap, msg, 2);
4551 subaddr = data[0] + 1;
4552 msg[1].len = 2;
4553 i2c_transfer(&dev->i2c_adap, msg, 2);
4554 tuner_t = (data[1] << 8) + data[0];
4555 switch (tuner_t) {
4556 case 0x0005:
4557 dev->tuner_type = TUNER_PHILIPS_FM1216ME_MK3;
4558 break;
4559 case 0x001d:
4560 dev->tuner_type = TUNER_PHILIPS_FMD1216ME_MK3;
4561 printk(KERN_INFO "%s Board has DVB-T\n", dev->name);
4562 break;
4563 default:
4564 printk(KERN_ERR "%s Cant determine tuner type %x from EEPROM\n", dev->name, tuner_t);
4565 }
4566 } else {
4567 printk(KERN_ERR "%s unexpected config structure\n", dev->name);
4568 }
4569
4570 printk(KERN_INFO "%s Tuner type is %d\n", dev->name, dev->tuner_type);
4571 if (dev->tuner_type == TUNER_PHILIPS_FMD1216ME_MK3) {
4572 dev->tda9887_conf = TDA9887_PRESENT | TDA9887_PORT1_ACTIVE | TDA9887_PORT2_ACTIVE;
4573 saa7134_i2c_call_clients(dev,TDA9887_SET_CONFIG, &dev->tda9887_conf);
4574 }
4575
4576 tun_setup.mode_mask = T_RADIO | T_ANALOG_TV | T_DIGITAL_TV;
4577 tun_setup.type = dev->tuner_type;
4578 tun_setup.addr = ADDR_UNSET;
4579
4580 saa7134_i2c_call_clients (dev, TUNER_SET_TYPE_ADDR,&tun_setup);
4581 }
Linus Torvalds1da177e2005-04-16 15:20:36 -07004582 break;
Hartmut Hackmann2cf36ac2005-11-08 21:36:32 -08004583 case SAA7134_BOARD_PHILIPS_EUROPA:
4584 case SAA7134_BOARD_VIDEOMATE_DVBT_300:
Hartmut Hackmanncf146ca2006-10-02 20:49:24 -03004585 case SAA7134_BOARD_ASUS_EUROPA2_HYBRID:
Hartmut Hackmann2cf36ac2005-11-08 21:36:32 -08004586 /* The Philips EUROPA based hybrid boards have the tuner connected through
4587 * the channel decoder. We have to make it transparent to find it
Mauro Carvalho Chehab4ac97912005-11-08 21:37:43 -08004588 */
Hartmut Hackmann2cf36ac2005-11-08 21:36:32 -08004589 {
Hartmut Hackmann2cf36ac2005-11-08 21:36:32 -08004590 u8 data[] = { 0x07, 0x02};
4591 struct i2c_msg msg = {.addr=0x08, .flags=0, .buf=data, .len = sizeof(data)};
4592 i2c_transfer(&dev->i2c_adap, &msg, 1);
4593
4594 tun_setup.mode_mask = T_ANALOG_TV | T_DIGITAL_TV;
4595 tun_setup.type = dev->tuner_type;
4596 tun_setup.addr = dev->tuner_addr;
4597
4598 saa7134_i2c_call_clients (dev, TUNER_SET_TYPE_ADDR,&tun_setup);
Mauro Carvalho Chehab4ac97912005-11-08 21:37:43 -08004599 }
Hartmut Hackmann2cf36ac2005-11-08 21:36:32 -08004600 break;
Hartmut Hackmann90e9df72005-11-08 21:38:42 -08004601 case SAA7134_BOARD_PHILIPS_TIGER:
Hartmut Hackmann58ef4f92007-04-27 12:31:12 -03004602 case SAA7134_BOARD_PHILIPS_TIGER_S:
Edgar Simod90d9f52007-08-20 14:14:50 -03004603 case SAA7134_BOARD_AVERMEDIA_SUPER_007:
Hartmut Hackmann58ef4f92007-04-27 12:31:12 -03004604 {
4605 u8 data[] = { 0x3c, 0x33, 0x60};
Hartmut Hackmann58ef4f92007-04-27 12:31:12 -03004606 struct i2c_msg msg = {.addr=0x08, .flags=0, .buf=data, .len = sizeof(data)};
4607 if(dev->autodetected && (dev->eedata[0x49] == 0x50)) {
4608 dev->board = SAA7134_BOARD_PHILIPS_TIGER_S;
4609 printk(KERN_INFO "%s: Reconfigured board as %s\n",
4610 dev->name, saa7134_boards[dev->board].name);
4611 }
4612 if(dev->board == SAA7134_BOARD_PHILIPS_TIGER_S) {
4613 tun_setup.mode_mask = T_ANALOG_TV | T_DIGITAL_TV;
4614 tun_setup.type = TUNER_PHILIPS_TDA8290;
4615 tun_setup.addr = 0x4b;
4616 tun_setup.config = 2;
Hartmut Hackmann58ef4f92007-04-27 12:31:12 -03004617
4618 saa7134_i2c_call_clients (dev, TUNER_SET_TYPE_ADDR,&tun_setup);
4619 data[2] = 0x68;
4620 }
4621 i2c_transfer(&dev->i2c_adap, &msg, 1);
4622 }
4623 break;
Hartmut Hackmann587d2fd2006-10-06 19:13:50 -03004624 case SAA7134_BOARD_PINNACLE_PCTV_310i:
Simon Farnsworthb39423a2007-05-01 10:01:20 -03004625 case SAA7134_BOARD_KWORLD_DVBT_210:
Peter Hartshorn3dfb7292006-02-07 06:49:13 -02004626 case SAA7134_BOARD_TEVION_DVBT_220RF:
Hartmut Hackmannd4b0aba2005-11-08 21:38:44 -08004627 case SAA7134_BOARD_ASUSTeK_P7131_DUAL:
Hartmut Hackmannf3eec0c02007-03-14 20:33:55 -03004628 case SAA7134_BOARD_ASUSTeK_P7131_HYBRID_LNA:
Hartmut Hackmann5eda2272006-08-07 14:03:32 -03004629 case SAA7134_BOARD_MEDION_MD8800_QUADRO:
Thomas Gentyc6e53da2006-11-05 14:17:30 -03004630 case SAA7134_BOARD_HAUPPAUGE_HVR1110:
Peter Hartshorn3dfb7292006-02-07 06:49:13 -02004631 /* this is a hybrid board, initialize to analog mode
4632 * and configure firmware eeprom address
4633 */
Hartmut Hackmann90e9df72005-11-08 21:38:42 -08004634 {
Hartmut Hackmann58ef4f92007-04-27 12:31:12 -03004635 u8 data[] = { 0x3c, 0x33, 0x60};
Hartmut Hackmann90e9df72005-11-08 21:38:42 -08004636 struct i2c_msg msg = {.addr=0x08, .flags=0, .buf=data, .len = sizeof(data)};
4637 i2c_transfer(&dev->i2c_adap, &msg, 1);
4638 }
4639 break;
Nico Sabbi420f32f2006-03-03 12:11:28 -03004640 case SAA7134_BOARD_FLYDVB_TRIO:
Hartmut Hackmann293cdab2006-02-27 21:08:07 -03004641 {
4642 u8 data[] = { 0x3c, 0x33, 0x62};
4643 struct i2c_msg msg = {.addr=0x09, .flags=0, .buf=data, .len = sizeof(data)};
4644 i2c_transfer(&dev->i2c_adap, &msg, 1);
4645 }
4646 break;
Hartmut Hackmanndf42eaf2006-02-07 06:49:10 -02004647 case SAA7134_BOARD_ADS_DUO_CARDBUS_PTV331:
Hartmut Hackmannd95b8942006-03-27 19:39:30 -03004648 case SAA7134_BOARD_FLYDVBT_HYBRID_CARDBUS:
Hartmut Hackmann58ef4f92007-04-27 12:31:12 -03004649 /* initialize analog mode */
Hartmut Hackmanndf42eaf2006-02-07 06:49:10 -02004650 {
Hartmut Hackmann58ef4f92007-04-27 12:31:12 -03004651 u8 data[] = { 0x3c, 0x33, 0x6a};
Hartmut Hackmanndf42eaf2006-02-07 06:49:10 -02004652 struct i2c_msg msg = {.addr=0x08, .flags=0, .buf=data, .len = sizeof(data)};
4653 i2c_transfer(&dev->i2c_adap, &msg, 1);
4654 }
4655 break;
Hartmut Hackmann550a9a52006-11-15 21:31:54 -03004656 case SAA7134_BOARD_CINERGY_HT_PCMCIA:
Michael Krufky9de271e2007-01-16 18:36:40 -03004657 case SAA7134_BOARD_CINERGY_HT_PCI:
Hartmut Hackmann58ef4f92007-04-27 12:31:12 -03004658 /* initialize analog mode */
Hartmut Hackmann550a9a52006-11-15 21:31:54 -03004659 {
Hartmut Hackmann58ef4f92007-04-27 12:31:12 -03004660 u8 data[] = { 0x3c, 0x33, 0x68};
Hartmut Hackmann550a9a52006-11-15 21:31:54 -03004661 struct i2c_msg msg = {.addr=0x08, .flags=0, .buf=data, .len = sizeof(data)};
4662 i2c_transfer(&dev->i2c_adap, &msg, 1);
4663 }
4664 break;
Curt Meyers20b5ee52006-02-27 00:08:39 -03004665 case SAA7134_BOARD_KWORLD_ATSC110:
4666 {
4667 /* enable tuner */
4668 int i;
Michael Krufkyb9ee9ad2006-02-27 00:09:14 -03004669 static const u8 buffer [] = { 0x10,0x12,0x13,0x04,0x16,0x00,0x14,0x04,0x017,0x00 };
Curt Meyers20b5ee52006-02-27 00:08:39 -03004670 dev->i2c_client.addr = 0x0a;
4671 for (i = 0; i < 5; i++)
4672 if (2 != i2c_master_send(&dev->i2c_client,&buffer[i*2],2))
4673 printk(KERN_WARNING "%s: Unable to enable tuner(%i).\n",
4674 dev->name, i);
4675 }
4676 break;
Hartmut Hackmanncbb94522006-10-30 20:00:16 -03004677 case SAA7134_BOARD_VIDEOMATE_DVBT_200:
4678 case SAA7134_BOARD_VIDEOMATE_DVBT_200A:
4679 /* The T200 and the T200A share the same pci id. Consequently,
4680 * we are going to query eeprom to try to find out which one we
4681 * are actually looking at. */
4682
4683 /* Don't do this if the board was specifically selected with an
4684 * insmod option or if we have the default configuration T200*/
4685 if(!dev->autodetected || (dev->eedata[0x41] == 0xd0))
4686 break;
4687 if(dev->eedata[0x41] == 0x02) {
4688 /* Reconfigure board as T200A */
4689 dev->board = SAA7134_BOARD_VIDEOMATE_DVBT_200A;
4690 dev->tuner_type = saa7134_boards[dev->board].tuner_type;
4691 dev->tda9887_conf = saa7134_boards[dev->board].tda9887_conf;
4692 printk(KERN_INFO "%s: Reconfigured board as %s\n",
4693 dev->name, saa7134_boards[dev->board].name);
4694 } else {
4695 printk(KERN_WARNING "%s: Unexpected tuner type info: %x in eeprom\n",
4696 dev->name, dev->eedata[0x41]);
4697 break;
4698 }
4699 break;
Linus Torvalds1da177e2005-04-16 15:20:36 -07004700 }
4701 return 0;
4702}
4703
4704/* ----------------------------------------------------------- */
4705/*
4706 * Local variables:
4707 * c-basic-offset: 8
4708 * End:
4709 */