blob: b29427aaa88d18502018ca6fbd1feb5783a54a8c [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>
Michael Krufky993efa72007-11-15 10:34:33 -030029#include <media/tveeprom.h>
Linus Torvalds1da177e2005-04-16 15:20:36 -070030
31/* commly used strings */
32static char name_mute[] = "mute";
33static char name_radio[] = "Radio";
34static char name_tv[] = "Television";
35static char name_tv_mono[] = "TV (mono only)";
Stas Sergeevf438d972007-09-17 15:34:09 -030036static char name_comp[] = "Composite";
Linus Torvalds1da177e2005-04-16 15:20:36 -070037static char name_comp1[] = "Composite1";
38static char name_comp2[] = "Composite2";
39static char name_comp3[] = "Composite3";
40static char name_comp4[] = "Composite4";
41static char name_svideo[] = "S-Video";
42
43/* ------------------------------------------------------------------ */
44/* board config info */
45
46struct saa7134_board saa7134_boards[] = {
47 [SAA7134_BOARD_UNKNOWN] = {
48 .name = "UNKNOWN/GENERIC",
49 .audio_clock = 0x00187de7,
50 .tuner_type = TUNER_ABSENT,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -070051 .radio_type = UNSET,
52 .tuner_addr = ADDR_UNSET,
53 .radio_addr = ADDR_UNSET,
54
Linus Torvalds1da177e2005-04-16 15:20:36 -070055 .inputs = {{
56 .name = "default",
57 .vmux = 0,
58 .amux = LINE1,
59 }},
60 },
61 [SAA7134_BOARD_PROTEUS_PRO] = {
62 /* /me */
63 .name = "Proteus Pro [philips reference design]",
64 .audio_clock = 0x00187de7,
65 .tuner_type = TUNER_PHILIPS_PAL,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -070066 .radio_type = UNSET,
67 .tuner_addr = ADDR_UNSET,
68 .radio_addr = ADDR_UNSET,
69
Linus Torvalds1da177e2005-04-16 15:20:36 -070070 .inputs = {{
71 .name = name_comp1,
72 .vmux = 0,
73 .amux = LINE1,
74 },{
75 .name = name_tv,
76 .vmux = 1,
77 .amux = TV,
78 .tv = 1,
79 },{
80 .name = name_tv_mono,
81 .vmux = 1,
82 .amux = LINE2,
83 .tv = 1,
84 }},
85 .radio = {
86 .name = name_radio,
87 .amux = LINE2,
88 },
89 },
90 [SAA7134_BOARD_FLYVIDEO3000] = {
91 /* "Marco d'Itri" <md@Linux.IT> */
92 .name = "LifeView FlyVIDEO3000",
93 .audio_clock = 0x00200000,
94 .tuner_type = TUNER_PHILIPS_PAL,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -070095 .radio_type = UNSET,
96 .tuner_addr = ADDR_UNSET,
97 .radio_addr = ADDR_UNSET,
98
Linus Torvalds1da177e2005-04-16 15:20:36 -070099 .gpiomask = 0xe000,
100 .inputs = {{
101 .name = name_tv,
102 .vmux = 1,
103 .amux = TV,
104 .gpio = 0x8000,
105 .tv = 1,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -0700106 },{
Linus Torvalds1da177e2005-04-16 15:20:36 -0700107 .name = name_tv_mono,
108 .vmux = 1,
109 .amux = LINE2,
110 .gpio = 0x0000,
111 .tv = 1,
112 },{
113 .name = name_comp1,
114 .vmux = 0,
115 .amux = LINE2,
116 .gpio = 0x4000,
117 },{
118 .name = name_comp2,
119 .vmux = 3,
120 .amux = LINE2,
121 .gpio = 0x4000,
122 },{
123 .name = name_svideo,
124 .vmux = 8,
125 .amux = LINE2,
126 .gpio = 0x4000,
127 }},
128 .radio = {
129 .name = name_radio,
130 .amux = LINE2,
131 .gpio = 0x2000,
132 },
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -0700133 .mute = {
134 .name = name_mute,
135 .amux = TV,
136 .gpio = 0x8000,
137 },
Linus Torvalds1da177e2005-04-16 15:20:36 -0700138 },
139 [SAA7134_BOARD_FLYVIDEO2000] = {
140 /* "TC Wan" <tcwan@cs.usm.my> */
Peter Missel10b7a902006-01-23 17:11:06 -0200141 .name = "LifeView/Typhoon FlyVIDEO2000",
Linus Torvalds1da177e2005-04-16 15:20:36 -0700142 .audio_clock = 0x00200000,
143 .tuner_type = TUNER_LG_PAL_NEW_TAPC,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -0700144 .radio_type = UNSET,
145 .tuner_addr = ADDR_UNSET,
146 .radio_addr = ADDR_UNSET,
147
Linus Torvalds1da177e2005-04-16 15:20:36 -0700148 .gpiomask = 0xe000,
149 .inputs = {{
150 .name = name_tv,
151 .vmux = 1,
152 .amux = LINE2,
153 .gpio = 0x0000,
154 .tv = 1,
155 },{
156 .name = name_comp1,
157 .vmux = 0,
158 .amux = LINE2,
159 .gpio = 0x4000,
160 },{
161 .name = name_comp2,
162 .vmux = 3,
163 .amux = LINE2,
164 .gpio = 0x4000,
165 },{
166 .name = name_svideo,
167 .vmux = 8,
168 .amux = LINE2,
169 .gpio = 0x4000,
170 }},
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -0700171 .radio = {
172 .name = name_radio,
173 .amux = LINE2,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700174 .gpio = 0x2000,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -0700175 },
Linus Torvalds1da177e2005-04-16 15:20:36 -0700176 .mute = {
177 .name = name_mute,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -0700178 .amux = LINE2,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700179 .gpio = 0x8000,
180 },
181 },
182 [SAA7134_BOARD_FLYTVPLATINUM_MINI] = {
183 /* "Arnaud Quette" <aquette@free.fr> */
184 .name = "LifeView FlyTV Platinum Mini",
185 .audio_clock = 0x00200000,
186 .tuner_type = TUNER_PHILIPS_TDA8290,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -0700187 .radio_type = UNSET,
188 .tuner_addr = ADDR_UNSET,
189 .radio_addr = ADDR_UNSET,
190
Linus Torvalds1da177e2005-04-16 15:20:36 -0700191 .inputs = {{
192 .name = name_tv,
193 .vmux = 1,
Mauro Carvalho Chehabac19ecc2005-06-23 22:05:09 -0700194 .amux = TV,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700195 .tv = 1,
196 },{
Glen Gray2d14f782005-11-08 21:36:12 -0800197 .name = name_comp1, /* Composite signal on S-Video input */
Linus Torvalds1da177e2005-04-16 15:20:36 -0700198 .vmux = 0,
199 .amux = LINE2,
200 },{
Glen Gray2d14f782005-11-08 21:36:12 -0800201 .name = name_comp2, /* Composite input */
202 .vmux = 3,
203 .amux = LINE2,
204 },{
Linus Torvalds1da177e2005-04-16 15:20:36 -0700205 .name = name_svideo,
206 .vmux = 8,
207 .amux = LINE2,
208 }},
209 },
210 [SAA7134_BOARD_FLYTVPLATINUM_FM] = {
211 /* LifeView FlyTV Platinum FM (LR214WF) */
212 /* "Peter Missel <peter.missel@onlinehome.de> */
Hartmut Hackmann42e6b3b2006-03-27 19:04:48 -0300213 .name = "LifeView FlyTV Platinum FM / Gold",
Linus Torvalds1da177e2005-04-16 15:20:36 -0700214 .audio_clock = 0x00200000,
215 .tuner_type = TUNER_PHILIPS_TDA8290,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -0700216 .radio_type = UNSET,
217 .tuner_addr = ADDR_UNSET,
218 .radio_addr = ADDR_UNSET,
219
Peter Missel6c9e7372005-05-01 08:59:05 -0700220 .gpiomask = 0x1E000, /* Set GP16 and unused 15,14,13 to Output */
Linus Torvalds1da177e2005-04-16 15:20:36 -0700221 .inputs = {{
222 .name = name_tv,
223 .vmux = 1,
224 .amux = TV,
Peter Missel6c9e7372005-05-01 08:59:05 -0700225 .gpio = 0x10000, /* GP16=1 selects TV input */
Linus Torvalds1da177e2005-04-16 15:20:36 -0700226 .tv = 1,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -0700227 },{
Linus Torvalds1da177e2005-04-16 15:20:36 -0700228/* .name = name_tv_mono,
229 .vmux = 1,
230 .amux = LINE2,
231 .gpio = 0x0000,
232 .tv = 1,
233 },{
234*/ .name = name_comp1, /* Composite signal on S-Video input */
235 .vmux = 0,
236 .amux = LINE2,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -0700237/* .gpio = 0x4000, */
Linus Torvalds1da177e2005-04-16 15:20:36 -0700238 },{
239 .name = name_comp2, /* Composite input */
240 .vmux = 3,
241 .amux = LINE2,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -0700242/* .gpio = 0x4000, */
Linus Torvalds1da177e2005-04-16 15:20:36 -0700243 },{
244 .name = name_svideo, /* S-Video signal on S-Video input */
245 .vmux = 8,
246 .amux = LINE2,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -0700247/* .gpio = 0x4000, */
Linus Torvalds1da177e2005-04-16 15:20:36 -0700248 }},
Peter Missel6c9e7372005-05-01 08:59:05 -0700249 .radio = {
Linus Torvalds1da177e2005-04-16 15:20:36 -0700250 .name = name_radio,
Peter Missel6c9e7372005-05-01 08:59:05 -0700251 .amux = TV,
252 .gpio = 0x00000, /* GP16=0 selects FM radio antenna */
Linus Torvalds1da177e2005-04-16 15:20:36 -0700253 },
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -0700254 .mute = {
255 .name = name_mute,
256 .amux = TV,
257 .gpio = 0x10000,
258 },
Peter Missel6c9e7372005-05-01 08:59:05 -0700259 },
Linus Torvalds1da177e2005-04-16 15:20:36 -0700260 [SAA7134_BOARD_EMPRESS] = {
261 /* "Gert Vervoort" <gert.vervoort@philips.com> */
262 .name = "EMPRESS",
263 .audio_clock = 0x00187de7,
264 .tuner_type = TUNER_PHILIPS_PAL,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -0700265 .radio_type = UNSET,
266 .tuner_addr = ADDR_UNSET,
267 .radio_addr = ADDR_UNSET,
268
Linus Torvalds1da177e2005-04-16 15:20:36 -0700269 .inputs = {{
270 .name = name_comp1,
271 .vmux = 0,
272 .amux = LINE1,
273 },{
274 .name = name_svideo,
275 .vmux = 8,
276 .amux = LINE1,
277 },{
278 .name = name_tv,
279 .vmux = 1,
280 .amux = LINE2,
281 .tv = 1,
282 }},
283 .radio = {
284 .name = name_radio,
285 .amux = LINE2,
286 },
287 .mpeg = SAA7134_MPEG_EMPRESS,
288 .video_out = CCIR656,
289 },
290 [SAA7134_BOARD_MONSTERTV] = {
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -0700291 /* "K.Ohta" <alpha292@bremen.or.jp> */
292 .name = "SKNet Monster TV",
293 .audio_clock = 0x00187de7,
294 .tuner_type = TUNER_PHILIPS_NTSC_M,
295 .radio_type = UNSET,
296 .tuner_addr = ADDR_UNSET,
297 .radio_addr = ADDR_UNSET,
298
299 .inputs = {{
300 .name = name_tv,
301 .vmux = 1,
302 .amux = TV,
303 .tv = 1,
304 },{
305 .name = name_comp1,
306 .vmux = 0,
307 .amux = LINE1,
308 },{
309 .name = name_svideo,
310 .vmux = 8,
311 .amux = LINE1,
312 }},
313 .radio = {
314 .name = name_radio,
315 .amux = LINE2,
316 },
Linus Torvalds1da177e2005-04-16 15:20:36 -0700317 },
318 [SAA7134_BOARD_MD9717] = {
319 .name = "Tevion MD 9717",
320 .audio_clock = 0x00200000,
321 .tuner_type = TUNER_PHILIPS_PAL,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -0700322 .radio_type = UNSET,
323 .tuner_addr = ADDR_UNSET,
324 .radio_addr = ADDR_UNSET,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700325 .inputs = {{
326 .name = name_tv,
327 .vmux = 1,
328 .amux = TV,
329 .tv = 1,
330 },{
331 /* workaround for problems with normal TV sound */
332 .name = name_tv_mono,
333 .vmux = 1,
334 .amux = LINE2,
335 .tv = 1,
336 },{
337 .name = name_comp1,
Hermann Pitton4aa504a2007-11-28 21:50:26 -0300338 .vmux = 0,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700339 .amux = LINE1,
340 },{
341 .name = name_comp2,
342 .vmux = 3,
343 .amux = LINE1,
344 },{
345 .name = name_svideo,
346 .vmux = 8,
347 .amux = LINE1,
348 }},
349 .radio = {
350 .name = name_radio,
351 .amux = LINE2,
352 },
Hermann Pittoncc764662007-11-28 21:54:35 -0300353 .mute = {
354 .name = name_mute,
355 .amux = TV,
356 },
Linus Torvalds1da177e2005-04-16 15:20:36 -0700357 },
358 [SAA7134_BOARD_TVSTATION_RDS] = {
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -0700359 /* Typhoon TV Tuner RDS: Art.Nr. 50694 */
Linus Torvalds1da177e2005-04-16 15:20:36 -0700360 .name = "KNC One TV-Station RDS / Typhoon TV Tuner RDS",
361 .audio_clock = 0x00200000,
362 .tuner_type = TUNER_PHILIPS_FM1216ME_MK3,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -0700363 .radio_type = UNSET,
364 .tuner_addr = ADDR_UNSET,
365 .radio_addr = ADDR_UNSET,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700366 .tda9887_conf = TDA9887_PRESENT,
367 .inputs = {{
368 .name = name_tv,
369 .vmux = 1,
370 .amux = TV,
371 .tv = 1,
372 },{
373 .name = name_tv_mono,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -0700374 .vmux = 1,
375 .amux = LINE2,
376 .tv = 1,
377 },{
Linus Torvalds1da177e2005-04-16 15:20:36 -0700378
379 .name = name_svideo,
380 .vmux = 8,
381 .amux = LINE1,
382 },{
383 .name = name_comp1,
384 .vmux = 3,
385 .amux = LINE1,
386 },{
387
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -0700388 .name = "CVid over SVid",
389 .vmux = 0,
390 .amux = LINE1,
391 }},
Linus Torvalds1da177e2005-04-16 15:20:36 -0700392 .radio = {
393 .name = name_radio,
394 .amux = LINE2,
395 },
396 },
397 [SAA7134_BOARD_TVSTATION_DVR] = {
398 .name = "KNC One TV-Station DVR",
399 .audio_clock = 0x00200000,
400 .tuner_type = TUNER_PHILIPS_FM1216ME_MK3,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -0700401 .radio_type = UNSET,
402 .tuner_addr = ADDR_UNSET,
403 .radio_addr = ADDR_UNSET,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700404 .tda9887_conf = TDA9887_PRESENT,
405 .gpiomask = 0x820000,
406 .inputs = {{
407 .name = name_tv,
408 .vmux = 1,
Rafał Bilskiaac0ca62007-06-20 05:36:26 -0300409 .amux = TV,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700410 .tv = 1,
411 .gpio = 0x20000,
412 },{
413 .name = name_svideo,
414 .vmux = 8,
415 .amux = LINE1,
416 .gpio = 0x20000,
417 },{
418 .name = name_comp1,
419 .vmux = 3,
420 .amux = LINE1,
421 .gpio = 0x20000,
422 }},
423 .radio = {
424 .name = name_radio,
425 .amux = LINE2,
426 .gpio = 0x20000,
427 },
428 .mpeg = SAA7134_MPEG_EMPRESS,
429 .video_out = CCIR656,
430 },
431 [SAA7134_BOARD_CINERGY400] = {
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -0700432 .name = "Terratec Cinergy 400 TV",
433 .audio_clock = 0x00200000,
434 .tuner_type = TUNER_PHILIPS_PAL,
435 .radio_type = UNSET,
436 .tuner_addr = ADDR_UNSET,
437 .radio_addr = ADDR_UNSET,
438 .inputs = {{
439 .name = name_tv,
440 .vmux = 1,
441 .amux = TV,
442 .tv = 1,
443 },{
444 .name = name_comp1,
445 .vmux = 4,
446 .amux = LINE1,
447 },{
448 .name = name_svideo,
449 .vmux = 8,
450 .amux = LINE1,
451 },{
452 .name = name_comp2, /* CVideo over SVideo Connector */
453 .vmux = 0,
454 .amux = LINE1,
455 }}
456 },
Linus Torvalds1da177e2005-04-16 15:20:36 -0700457 [SAA7134_BOARD_MD5044] = {
458 .name = "Medion 5044",
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -0700459 .audio_clock = 0x00187de7, /* was: 0x00200000, */
Linus Torvalds1da177e2005-04-16 15:20:36 -0700460 .tuner_type = TUNER_PHILIPS_FM1216ME_MK3,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -0700461 .radio_type = UNSET,
462 .tuner_addr = ADDR_UNSET,
463 .radio_addr = ADDR_UNSET,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700464 .tda9887_conf = TDA9887_PRESENT,
465 .inputs = {{
466 .name = name_tv,
467 .vmux = 1,
468 .amux = TV,
469 .tv = 1,
470 },{
471 /* workaround for problems with normal TV sound */
472 .name = name_tv_mono,
473 .vmux = 1,
474 .amux = LINE2,
475 .tv = 1,
476 },{
477 .name = name_comp1,
478 .vmux = 0,
479 .amux = LINE2,
480 },{
481 .name = name_comp2,
482 .vmux = 3,
483 .amux = LINE2,
484 },{
485 .name = name_svideo,
486 .vmux = 8,
487 .amux = LINE2,
488 }},
489 .radio = {
490 .name = name_radio,
491 .amux = LINE2,
492 },
493 },
494 [SAA7134_BOARD_KWORLD] = {
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -0700495 .name = "Kworld/KuroutoShikou SAA7130-TVPCI",
Linus Torvalds1da177e2005-04-16 15:20:36 -0700496 .audio_clock = 0x00187de7,
497 .tuner_type = TUNER_PHILIPS_NTSC_M,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -0700498 .radio_type = UNSET,
499 .tuner_addr = ADDR_UNSET,
500 .radio_addr = ADDR_UNSET,
501 .inputs = {{
502 .name = name_svideo,
503 .vmux = 8,
504 .amux = LINE1,
505 },{
506 .name = name_comp1,
507 .vmux = 3,
508 .amux = LINE1,
509 },{
510 .name = name_tv,
511 .vmux = 1,
512 .amux = LINE2,
513 .tv = 1,
514 }},
515 },
Linus Torvalds1da177e2005-04-16 15:20:36 -0700516 [SAA7134_BOARD_CINERGY600] = {
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -0700517 .name = "Terratec Cinergy 600 TV",
518 .audio_clock = 0x00200000,
519 .tuner_type = TUNER_PHILIPS_PAL,
520 .radio_type = UNSET,
521 .tuner_addr = ADDR_UNSET,
522 .radio_addr = ADDR_UNSET,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700523 .tda9887_conf = TDA9887_PRESENT,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -0700524 .inputs = {{
525 .name = name_tv,
526 .vmux = 1,
527 .amux = TV,
528 .tv = 1,
529 },{
530 .name = name_comp1,
531 .vmux = 4,
532 .amux = LINE1,
533 },{
534 .name = name_svideo,
535 .vmux = 8,
536 .amux = LINE1,
537 },{
538 .name = name_comp2, /* CVideo over SVideo Connector */
539 .vmux = 0,
540 .amux = LINE1,
541 }},
Linus Torvalds1da177e2005-04-16 15:20:36 -0700542 .radio = {
543 .name = name_radio,
544 .amux = LINE2,
Michael Krufky67ac9a42006-03-14 16:18:49 -0300545 },
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -0700546 },
Linus Torvalds1da177e2005-04-16 15:20:36 -0700547 [SAA7134_BOARD_MD7134] = {
548 .name = "Medion 7134",
Linus Torvalds1da177e2005-04-16 15:20:36 -0700549 .audio_clock = 0x00187de7,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -0700550 .tuner_type = TUNER_PHILIPS_FMD1216ME_MK3,
551 .radio_type = UNSET,
552 .tuner_addr = ADDR_UNSET,
553 .radio_addr = ADDR_UNSET,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700554 .tda9887_conf = TDA9887_PRESENT,
555 .mpeg = SAA7134_MPEG_DVB,
556 .inputs = {{
557 .name = name_tv,
558 .vmux = 1,
559 .amux = TV,
560 .tv = 1,
561 },{
562 .name = name_comp1,
563 .vmux = 0,
564 .amux = LINE1,
565 },{
566 .name = name_svideo,
567 .vmux = 8,
568 .amux = LINE1,
569 }},
570 .radio = {
571 .name = name_radio,
572 .amux = LINE2,
Hermann Pittoncc764662007-11-28 21:54:35 -0300573 },
574 .mute = {
575 .name = name_mute,
576 .amux = TV,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700577 },
578 },
579 [SAA7134_BOARD_TYPHOON_90031] = {
580 /* aka Typhoon "TV+Radio", Art.Nr 90031 */
581 /* Tom Zoerner <tomzo at users sourceforge net> */
582 .name = "Typhoon TV+Radio 90031",
583 .audio_clock = 0x00200000,
584 .tuner_type = TUNER_PHILIPS_PAL,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -0700585 .radio_type = UNSET,
586 .tuner_addr = ADDR_UNSET,
587 .radio_addr = ADDR_UNSET,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700588 .tda9887_conf = TDA9887_PRESENT,
589 .inputs = {{
590 .name = name_tv,
591 .vmux = 1,
592 .amux = TV,
593 .tv = 1,
594 },{
595 .name = name_comp1,
596 .vmux = 3,
597 .amux = LINE1,
598 },{
599 .name = name_svideo,
600 .vmux = 8,
601 .amux = LINE1,
602 }},
603 .radio = {
604 .name = name_radio,
605 .amux = LINE2,
606 },
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -0700607 },
Linus Torvalds1da177e2005-04-16 15:20:36 -0700608 [SAA7134_BOARD_ELSA] = {
609 .name = "ELSA EX-VISION 300TV",
610 .audio_clock = 0x00187de7,
611 .tuner_type = TUNER_HITACHI_NTSC,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -0700612 .radio_type = UNSET,
613 .tuner_addr = ADDR_UNSET,
614 .radio_addr = ADDR_UNSET,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700615 .inputs = {{
616 .name = name_svideo,
617 .vmux = 8,
618 .amux = LINE1,
619 },{
620 .name = name_comp1,
621 .vmux = 0,
622 .amux = LINE1,
623 },{
624 .name = name_tv,
625 .vmux = 4,
626 .amux = LINE2,
627 .tv = 1,
628 }},
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -0700629 },
Linus Torvalds1da177e2005-04-16 15:20:36 -0700630 [SAA7134_BOARD_ELSA_500TV] = {
631 .name = "ELSA EX-VISION 500TV",
632 .audio_clock = 0x00187de7,
633 .tuner_type = TUNER_HITACHI_NTSC,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -0700634 .radio_type = UNSET,
635 .tuner_addr = ADDR_UNSET,
636 .radio_addr = ADDR_UNSET,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700637 .inputs = {{
638 .name = name_svideo,
639 .vmux = 7,
640 .amux = LINE1,
641 },{
642 .name = name_tv,
643 .vmux = 8,
644 .amux = TV,
645 .tv = 1,
646 },{
647 .name = name_tv_mono,
648 .vmux = 8,
649 .amux = LINE2,
650 .tv = 1,
651 }},
Linus Torvalds1da177e2005-04-16 15:20:36 -0700652 },
Tamuki Shoichid0456d12006-02-27 00:08:04 -0300653 [SAA7134_BOARD_ELSA_700TV] = {
654 .name = "ELSA EX-VISION 700TV",
655 .audio_clock = 0x00187de7,
656 .tuner_type = TUNER_HITACHI_NTSC,
657 .radio_type = UNSET,
658 .tuner_addr = ADDR_UNSET,
659 .radio_addr = ADDR_UNSET,
660 .inputs = {{
661 .name = name_tv,
662 .vmux = 4,
663 .amux = LINE2,
664 .tv = 1,
665 },{
666 .name = name_comp1,
667 .vmux = 6,
668 .amux = LINE1,
669 },{
670 .name = name_svideo,
671 .vmux = 7,
672 .amux = LINE1,
673 }},
674 .mute = {
675 .name = name_mute,
676 .amux = TV,
677 },
678 },
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -0700679 [SAA7134_BOARD_ASUSTeK_TVFM7134] = {
680 .name = "ASUS TV-FM 7134",
681 .audio_clock = 0x00187de7,
682 .tuner_type = TUNER_PHILIPS_FM1216ME_MK3,
683 .radio_type = UNSET,
684 .tuner_addr = ADDR_UNSET,
685 .radio_addr = ADDR_UNSET,
686 .tda9887_conf = TDA9887_PRESENT,
687 .inputs = {{
688 .name = name_tv,
689 .vmux = 1,
690 .amux = TV,
691 .tv = 1,
692 },{
693 .name = name_comp1,
694 .vmux = 4,
695 .amux = LINE2,
696 },{
697 .name = name_svideo,
698 .vmux = 6,
699 .amux = LINE2,
700 }},
701 .radio = {
702 .name = name_radio,
703 .amux = LINE1,
704 },
705 },
706 [SAA7134_BOARD_ASUSTeK_TVFM7135] = {
707 .name = "ASUS TV-FM 7135",
708 .audio_clock = 0x00187de7,
709 .tuner_type = TUNER_PHILIPS_TDA8290,
710 .radio_type = UNSET,
711 .tuner_addr = ADDR_UNSET,
712 .radio_addr = ADDR_UNSET,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700713 .gpiomask = 0x200000,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -0700714 .inputs = {{
715 .name = name_tv,
716 .vmux = 1,
717 .amux = TV,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700718 .gpio = 0x0000,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -0700719 .tv = 1,
720 },{
721 .name = name_comp1,
722 .vmux = 4,
723 .amux = LINE2,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700724 .gpio = 0x0000,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -0700725 },{
726 .name = name_svideo,
727 .vmux = 6,
728 .amux = LINE2,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700729 .gpio = 0x0000,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -0700730 }},
731 .radio = {
732 .name = name_radio,
733 .amux = TV,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700734 .gpio = 0x200000,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -0700735 },
736 .mute = {
737 .name = name_mute,
738 .gpio = 0x0000,
739 },
740
Linus Torvalds1da177e2005-04-16 15:20:36 -0700741 },
742 [SAA7134_BOARD_VA1000POWER] = {
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -0700743 .name = "AOPEN VA1000 POWER",
Linus Torvalds1da177e2005-04-16 15:20:36 -0700744 .audio_clock = 0x00187de7,
745 .tuner_type = TUNER_PHILIPS_NTSC,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -0700746 .radio_type = UNSET,
747 .tuner_addr = ADDR_UNSET,
748 .radio_addr = ADDR_UNSET,
749 .inputs = {{
750 .name = name_svideo,
751 .vmux = 8,
752 .amux = LINE1,
753 },{
754 .name = name_comp1,
755 .vmux = 3,
756 .amux = LINE1,
757 },{
758 .name = name_tv,
759 .vmux = 1,
760 .amux = LINE2,
761 .tv = 1,
762 }},
Linus Torvalds1da177e2005-04-16 15:20:36 -0700763 },
764 [SAA7134_BOARD_10MOONSTVMASTER] = {
765 /* "lilicheng" <llc@linuxfans.org> */
766 .name = "10MOONS PCI TV CAPTURE CARD",
767 .audio_clock = 0x00200000,
768 .tuner_type = TUNER_LG_PAL_NEW_TAPC,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -0700769 .radio_type = UNSET,
770 .tuner_addr = ADDR_UNSET,
771 .radio_addr = ADDR_UNSET,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700772 .gpiomask = 0xe000,
773 .inputs = {{
774 .name = name_tv,
775 .vmux = 1,
776 .amux = LINE2,
777 .gpio = 0x0000,
778 .tv = 1,
779 },{
780 .name = name_comp1,
781 .vmux = 0,
782 .amux = LINE2,
783 .gpio = 0x4000,
784 },{
785 .name = name_comp2,
786 .vmux = 3,
787 .amux = LINE2,
788 .gpio = 0x4000,
789 },{
790 .name = name_svideo,
791 .vmux = 8,
792 .amux = LINE2,
793 .gpio = 0x4000,
794 }},
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -0700795 .radio = {
796 .name = name_radio,
797 .amux = LINE2,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700798 .gpio = 0x2000,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -0700799 },
Linus Torvalds1da177e2005-04-16 15:20:36 -0700800 .mute = {
801 .name = name_mute,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -0700802 .amux = LINE2,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700803 .gpio = 0x8000,
804 },
805 },
806 [SAA7134_BOARD_BMK_MPEX_NOTUNER] = {
807 /* "Andrew de Quincey" <adq@lidskialf.net> */
808 .name = "BMK MPEX No Tuner",
809 .audio_clock = 0x200000,
810 .tuner_type = TUNER_ABSENT,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -0700811 .radio_type = UNSET,
812 .tuner_addr = ADDR_UNSET,
813 .radio_addr = ADDR_UNSET,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700814 .inputs = {{
815 .name = name_comp1,
816 .vmux = 4,
817 .amux = LINE1,
818 },{
819 .name = name_comp2,
820 .vmux = 3,
821 .amux = LINE1,
822 },{
823 .name = name_comp3,
824 .vmux = 0,
825 .amux = LINE1,
826 },{
827 .name = name_comp4,
828 .vmux = 1,
829 .amux = LINE1,
830 },{
831 .name = name_svideo,
832 .vmux = 8,
833 .amux = LINE1,
834 }},
835 .mpeg = SAA7134_MPEG_EMPRESS,
836 .video_out = CCIR656,
837 },
838 [SAA7134_BOARD_VIDEOMATE_TV] = {
839 .name = "Compro VideoMate TV",
840 .audio_clock = 0x00187de7,
841 .tuner_type = TUNER_PHILIPS_NTSC_M,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -0700842 .radio_type = UNSET,
843 .tuner_addr = ADDR_UNSET,
844 .radio_addr = ADDR_UNSET,
845 .inputs = {{
846 .name = name_svideo,
847 .vmux = 8,
848 .amux = LINE1,
849 },{
850 .name = name_comp1,
851 .vmux = 3,
852 .amux = LINE1,
853 },{
854 .name = name_tv,
855 .vmux = 1,
856 .amux = LINE2,
857 .tv = 1,
858 }},
859 },
860 [SAA7134_BOARD_VIDEOMATE_TV_GOLD_PLUS] = {
Linus Torvalds1da177e2005-04-16 15:20:36 -0700861 .name = "Compro VideoMate TV Gold+",
862 .audio_clock = 0x00187de7,
863 .tuner_type = TUNER_PHILIPS_NTSC_M,
864 .gpiomask = 0x800c0000,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -0700865 .radio_type = UNSET,
866 .tuner_addr = ADDR_UNSET,
867 .radio_addr = ADDR_UNSET,
868 .inputs = {{
869 .name = name_svideo,
870 .vmux = 8,
871 .amux = LINE1,
872 .gpio = 0x06c00012,
873 },{
874 .name = name_comp1,
875 .vmux = 3,
876 .amux = LINE1,
877 .gpio = 0x0ac20012,
878 },{
879 .name = name_tv,
880 .vmux = 1,
881 .amux = LINE2,
882 .gpio = 0x08c20012,
883 .tv = 1,
884 }}, /* radio and probably mute is missing */
885 },
Linus Torvalds1da177e2005-04-16 15:20:36 -0700886 [SAA7134_BOARD_CRONOS_PLUS] = {
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -0700887 /*
888 gpio pins:
889 0 .. 3 BASE_ID
890 4 .. 7 PROTECT_ID
891 8 .. 11 USER_OUT
892 12 .. 13 USER_IN
893 14 .. 15 VIDIN_SEL
894 */
Linus Torvalds1da177e2005-04-16 15:20:36 -0700895 .name = "Matrox CronosPlus",
896 .tuner_type = TUNER_ABSENT,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -0700897 .radio_type = UNSET,
898 .tuner_addr = ADDR_UNSET,
899 .radio_addr = ADDR_UNSET,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700900 .gpiomask = 0xcf00,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -0700901 .inputs = {{
902 .name = name_comp1,
903 .vmux = 0,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700904 .gpio = 2 << 14,
905 },{
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -0700906 .name = name_comp2,
907 .vmux = 0,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700908 .gpio = 1 << 14,
909 },{
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -0700910 .name = name_comp3,
911 .vmux = 0,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700912 .gpio = 0 << 14,
913 },{
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -0700914 .name = name_comp4,
915 .vmux = 0,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700916 .gpio = 3 << 14,
917 },{
918 .name = name_svideo,
919 .vmux = 8,
920 .gpio = 2 << 14,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -0700921 }},
922 },
Linus Torvalds1da177e2005-04-16 15:20:36 -0700923 [SAA7134_BOARD_MD2819] = {
924 .name = "AverMedia M156 / Medion 2819",
925 .audio_clock = 0x00187de7,
926 .tuner_type = TUNER_PHILIPS_FM1216ME_MK3,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -0700927 .radio_type = UNSET,
928 .tuner_addr = ADDR_UNSET,
929 .radio_addr = ADDR_UNSET,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700930 .tda9887_conf = TDA9887_PRESENT,
931 .inputs = {{
932 .name = name_tv,
933 .vmux = 1,
934 .amux = TV,
935 .tv = 1,
936 },{
937 .name = name_comp1,
938 .vmux = 0,
939 .amux = LINE2,
940 },{
941 .name = name_comp2,
942 .vmux = 3,
943 .amux = LINE2,
944 },{
945 .name = name_svideo,
946 .vmux = 8,
947 .amux = LINE2,
948 }},
949 .radio = {
950 .name = name_radio,
951 .amux = LINE2,
952 },
953 },
954 [SAA7134_BOARD_BMK_MPEX_TUNER] = {
955 /* "Greg Wickham <greg.wickham@grangenet.net> */
956 .name = "BMK MPEX Tuner",
957 .audio_clock = 0x200000,
958 .tuner_type = TUNER_PHILIPS_PAL,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -0700959 .radio_type = UNSET,
960 .tuner_addr = ADDR_UNSET,
961 .radio_addr = ADDR_UNSET,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700962 .inputs = {{
963 .name = name_comp1,
964 .vmux = 1,
965 .amux = LINE1,
966 },{
967 .name = name_svideo,
968 .vmux = 8,
969 .amux = LINE1,
970 },{
971 .name = name_tv,
972 .vmux = 3,
973 .amux = TV,
974 .tv = 1,
975 }},
976 .mpeg = SAA7134_MPEG_EMPRESS,
977 .video_out = CCIR656,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -0700978 },
979 [SAA7134_BOARD_ASUSTEK_TVFM7133] = {
980 .name = "ASUS TV-FM 7133",
981 .audio_clock = 0x00187de7,
982 /* probably wrong, the 7133 one is the NTSC version ...
983 * .tuner_type = TUNER_PHILIPS_FM1236_MK3 */
984 .tuner_type = TUNER_LG_NTSC_NEW_TAPC,
985 .radio_type = UNSET,
986 .tuner_addr = ADDR_UNSET,
987 .radio_addr = ADDR_UNSET,
988 .tda9887_conf = TDA9887_PRESENT,
989 .inputs = {{
990 .name = name_tv,
991 .vmux = 1,
992 .amux = TV,
993 .tv = 1,
994
Linus Torvalds1da177e2005-04-16 15:20:36 -0700995 },{
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -0700996 .name = name_comp1,
997 .vmux = 4,
998 .amux = LINE2,
999 },{
1000 .name = name_svideo,
1001 .vmux = 6,
1002 .amux = LINE2,
1003 }},
1004 .radio = {
1005 .name = name_radio,
1006 .amux = LINE1,
1007 },
1008 },
Linus Torvalds1da177e2005-04-16 15:20:36 -07001009 [SAA7134_BOARD_PINNACLE_PCTV_STEREO] = {
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07001010 .name = "Pinnacle PCTV Stereo (saa7134)",
1011 .audio_clock = 0x00187de7,
1012 .tuner_type = TUNER_MT2032,
1013 .radio_type = UNSET,
1014 .tuner_addr = ADDR_UNSET,
1015 .radio_addr = ADDR_UNSET,
Hartmut Hackmanndf8cf702006-03-03 12:09:26 -03001016 .tda9887_conf = TDA9887_PRESENT | TDA9887_INTERCARRIER | TDA9887_PORT2_INACTIVE,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07001017 .inputs = {{
1018 .name = name_tv,
1019 .vmux = 3,
1020 .amux = TV,
1021 .tv = 1,
1022 },{
1023 .name = name_comp1,
1024 .vmux = 0,
1025 .amux = LINE2,
1026 },{
1027 .name = name_comp2,
1028 .vmux = 1,
1029 .amux = LINE2,
1030 },{
1031 .name = name_svideo,
1032 .vmux = 8,
1033 .amux = LINE2,
1034 }},
1035 },
Linus Torvalds1da177e2005-04-16 15:20:36 -07001036 [SAA7134_BOARD_MANLI_MTV002] = {
1037 /* Ognjen Nastic <ognjen@logosoft.ba> */
Mauro Carvalho Chehabac19ecc2005-06-23 22:05:09 -07001038 .name = "Manli MuchTV M-TV002/Behold TV 403 FM",
Linus Torvalds1da177e2005-04-16 15:20:36 -07001039 .audio_clock = 0x00200000,
1040 .tuner_type = TUNER_PHILIPS_PAL,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07001041 .radio_type = UNSET,
1042 .tuner_addr = ADDR_UNSET,
1043 .radio_addr = ADDR_UNSET,
Linus Torvalds1da177e2005-04-16 15:20:36 -07001044 .inputs = {{
1045 .name = name_svideo,
1046 .vmux = 8,
1047 .amux = LINE1,
1048 },{
1049 .name = name_comp1,
1050 .vmux = 1,
1051 .amux = LINE1,
1052 },{
1053 .name = name_tv,
1054 .vmux = 3,
1055 .amux = LINE2,
1056 .tv = 1,
1057 }},
1058 .radio = {
1059 .name = name_radio,
1060 .amux = LINE2,
1061 },
Linus Torvalds1da177e2005-04-16 15:20:36 -07001062 },
1063 [SAA7134_BOARD_MANLI_MTV001] = {
1064 /* Ognjen Nastic <ognjen@logosoft.ba> UNTESTED */
Mauro Carvalho Chehabac19ecc2005-06-23 22:05:09 -07001065 .name = "Manli MuchTV M-TV001/Behold TV 401",
Linus Torvalds1da177e2005-04-16 15:20:36 -07001066 .audio_clock = 0x00200000,
1067 .tuner_type = TUNER_PHILIPS_PAL,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07001068 .radio_type = UNSET,
1069 .tuner_addr = ADDR_UNSET,
1070 .radio_addr = ADDR_UNSET,
Linus Torvalds1da177e2005-04-16 15:20:36 -07001071 .inputs = {{
1072 .name = name_svideo,
1073 .vmux = 8,
1074 .amux = LINE1,
1075 },{
1076 .name = name_comp1,
1077 .vmux = 1,
1078 .amux = LINE1,
1079 },{
1080 .name = name_tv,
1081 .vmux = 3,
1082 .amux = LINE2,
1083 .tv = 1,
1084 }},
Mauro Carvalho Chehabac19ecc2005-06-23 22:05:09 -07001085 .mute = {
1086 .name = name_mute,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07001087 .amux = LINE1,
Mauro Carvalho Chehabac19ecc2005-06-23 22:05:09 -07001088 },
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07001089 },
Linus Torvalds1da177e2005-04-16 15:20:36 -07001090 [SAA7134_BOARD_TG3000TV] = {
1091 /* TransGear 3000TV */
1092 .name = "Nagase Sangyo TransGear 3000TV",
1093 .audio_clock = 0x00187de7,
1094 .tuner_type = TUNER_PHILIPS_NTSC_M,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07001095 .radio_type = UNSET,
1096 .tuner_addr = ADDR_UNSET,
1097 .radio_addr = ADDR_UNSET,
Linus Torvalds1da177e2005-04-16 15:20:36 -07001098 .inputs = {{
1099 .name = name_tv,
1100 .vmux = 1,
1101 .amux = LINE2,
1102 .tv = 1,
1103 },{
1104 .name = name_comp1,
1105 .vmux = 3,
1106 .amux = LINE2,
1107 },{
1108 .name = name_svideo,
1109 .vmux = 8,
1110 .amux = LINE2,
1111 }},
1112 },
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07001113 [SAA7134_BOARD_ECS_TVP3XP] = {
1114 .name = "Elitegroup ECS TVP3XP FM1216 Tuner Card(PAL-BG,FM) ",
1115 .audio_clock = 0x187de7, /* xtal 32.1 MHz */
1116 .tuner_type = TUNER_PHILIPS_PAL,
1117 .radio_type = UNSET,
1118 .tuner_addr = ADDR_UNSET,
1119 .radio_addr = ADDR_UNSET,
1120 .inputs = {{
1121 .name = name_tv,
1122 .vmux = 1,
1123 .amux = TV,
1124 .tv = 1,
1125 },{
1126 .name = name_tv_mono,
1127 .vmux = 1,
1128 .amux = LINE2,
1129 .tv = 1,
1130 },{
1131 .name = name_comp1,
1132 .vmux = 3,
1133 .amux = LINE1,
1134 },{
1135 .name = name_svideo,
1136 .vmux = 8,
1137 .amux = LINE1,
Linus Torvalds1da177e2005-04-16 15:20:36 -07001138 },{
1139 .name = "CVid over SVid",
1140 .vmux = 0,
1141 .amux = LINE1,
1142 }},
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07001143 .radio = {
1144 .name = name_radio,
1145 .amux = LINE2,
1146 },
1147 },
1148 [SAA7134_BOARD_ECS_TVP3XP_4CB5] = {
1149 .name = "Elitegroup ECS TVP3XP FM1236 Tuner Card (NTSC,FM)",
1150 .audio_clock = 0x187de7,
1151 .tuner_type = TUNER_PHILIPS_NTSC,
1152 .radio_type = UNSET,
1153 .tuner_addr = ADDR_UNSET,
1154 .radio_addr = ADDR_UNSET,
1155 .inputs = {{
1156 .name = name_tv,
1157 .vmux = 1,
1158 .amux = TV,
1159 .tv = 1,
1160 },{
1161 .name = name_tv_mono,
1162 .vmux = 1,
1163 .amux = LINE2,
1164 .tv = 1,
1165 },{
1166 .name = name_comp1,
1167 .vmux = 3,
1168 .amux = LINE1,
1169 },{
1170 .name = name_svideo,
1171 .vmux = 8,
1172 .amux = LINE1,
1173 },{
1174 .name = "CVid over SVid",
1175 .vmux = 0,
1176 .amux = LINE1,
1177 }},
1178 .radio = {
1179 .name = name_radio,
1180 .amux = LINE2,
1181 },
1182 },
Simon Farnsworthb39423a2007-05-01 10:01:20 -03001183 [SAA7134_BOARD_ECS_TVP3XP_4CB6] = {
1184 /* Barry Scott <barry.scott@onelan.co.uk> */
1185 .name = "Elitegroup ECS TVP3XP FM1246 Tuner Card (PAL,FM)",
1186 .audio_clock = 0x187de7,
1187 .tuner_type = TUNER_PHILIPS_PAL_I,
1188 .radio_type = UNSET,
1189 .tuner_addr = ADDR_UNSET,
1190 .radio_addr = ADDR_UNSET,
1191 .inputs = {{
1192 .name = name_tv,
1193 .vmux = 1,
1194 .amux = TV,
1195 .tv = 1,
1196 },{
1197 .name = name_tv_mono,
1198 .vmux = 1,
1199 .amux = LINE2,
1200 .tv = 1,
1201 },{
1202 .name = name_comp1,
1203 .vmux = 3,
1204 .amux = LINE1,
1205 },{
1206 .name = name_svideo,
1207 .vmux = 8,
1208 .amux = LINE1,
1209 },{
1210 .name = "CVid over SVid",
1211 .vmux = 0,
1212 .amux = LINE1,
1213 }},
1214 .radio = {
1215 .name = name_radio,
1216 .amux = LINE2,
1217 },
1218 },
Linus Torvalds1da177e2005-04-16 15:20:36 -07001219 [SAA7134_BOARD_AVACSSMARTTV] = {
1220 /* Roman Pszonczenko <romka@kolos.math.uni.lodz.pl> */
1221 .name = "AVACS SmartTV",
1222 .audio_clock = 0x00187de7,
1223 .tuner_type = TUNER_PHILIPS_PAL,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07001224 .radio_type = UNSET,
1225 .tuner_addr = ADDR_UNSET,
1226 .radio_addr = ADDR_UNSET,
Linus Torvalds1da177e2005-04-16 15:20:36 -07001227 .inputs = {{
1228 .name = name_tv,
1229 .vmux = 1,
1230 .amux = TV,
1231 .tv = 1,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07001232 },{
Linus Torvalds1da177e2005-04-16 15:20:36 -07001233 .name = name_tv_mono,
1234 .vmux = 1,
1235 .amux = LINE2,
1236 .tv = 1,
1237 },{
1238 .name = name_comp1,
1239 .vmux = 0,
1240 .amux = LINE2,
1241 },{
1242 .name = name_comp2,
1243 .vmux = 3,
1244 .amux = LINE2,
1245 },{
1246 .name = name_svideo,
1247 .vmux = 8,
1248 .amux = LINE2,
1249 }},
1250 .radio = {
1251 .name = name_radio,
1252 .amux = LINE2,
1253 .gpio = 0x200000,
1254 },
1255 },
1256 [SAA7134_BOARD_AVERMEDIA_DVD_EZMAKER] = {
1257 /* Michael Smith <msmith@cbnco.com> */
1258 .name = "AVerMedia DVD EZMaker",
1259 .audio_clock = 0x00187de7,
1260 .tuner_type = TUNER_ABSENT,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07001261 .radio_type = UNSET,
1262 .tuner_addr = ADDR_UNSET,
1263 .radio_addr = ADDR_UNSET,
Linus Torvalds1da177e2005-04-16 15:20:36 -07001264 .inputs = {{
1265 .name = name_comp1,
1266 .vmux = 3,
1267 },{
1268 .name = name_svideo,
1269 .vmux = 8,
1270 }},
1271 },
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07001272 [SAA7134_BOARD_NOVAC_PRIMETV7133] = {
1273 /* toshii@netbsd.org */
1274 .name = "Noval Prime TV 7133",
1275 .audio_clock = 0x00200000,
1276 .tuner_type = TUNER_ALPS_TSBH1_NTSC,
1277 .radio_type = UNSET,
1278 .tuner_addr = ADDR_UNSET,
1279 .radio_addr = ADDR_UNSET,
1280 .inputs = {{
1281 .name = name_comp1,
1282 .vmux = 3,
1283 },{
1284 .name = name_tv,
1285 .vmux = 1,
1286 .amux = TV,
1287 .tv = 1,
1288 },{
1289 .name = name_svideo,
1290 .vmux = 8,
1291 }},
1292 },
Linus Torvalds1da177e2005-04-16 15:20:36 -07001293 [SAA7134_BOARD_AVERMEDIA_STUDIO_305] = {
1294 .name = "AverMedia AverTV Studio 305",
1295 .audio_clock = 0x00187de7,
1296 .tuner_type = TUNER_PHILIPS_FM1256_IH3,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07001297 .radio_type = UNSET,
1298 .tuner_addr = ADDR_UNSET,
1299 .radio_addr = ADDR_UNSET,
Linus Torvalds1da177e2005-04-16 15:20:36 -07001300 .tda9887_conf = TDA9887_PRESENT,
Linus Torvalds1da177e2005-04-16 15:20:36 -07001301 .inputs = {{
1302 .name = name_tv,
1303 .vmux = 1,
1304 .amux = LINE2,
1305 .tv = 1,
1306 },{
1307 .name = name_comp1,
1308 .vmux = 0,
1309 .amux = LINE2,
1310 },{
1311 .name = name_comp2,
1312 .vmux = 3,
1313 .amux = LINE2,
1314 },{
1315 .name = name_svideo,
1316 .vmux = 8,
1317 .amux = LINE2,
1318 }},
1319 .radio = {
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07001320 .name = name_radio,
1321 .amux = LINE2,
1322 },
Linus Torvalds1da177e2005-04-16 15:20:36 -07001323 .mute = {
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07001324 .name = name_mute,
1325 .amux = LINE1,
Linus Torvalds1da177e2005-04-16 15:20:36 -07001326 },
1327 },
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07001328 [SAA7134_BOARD_UPMOST_PURPLE_TV] = {
1329 .name = "UPMOST PURPLE TV",
1330 .audio_clock = 0x00187de7,
1331 .tuner_type = TUNER_PHILIPS_FM1236_MK3,
1332 .radio_type = UNSET,
1333 .tuner_addr = ADDR_UNSET,
1334 .radio_addr = ADDR_UNSET,
1335 .tda9887_conf = TDA9887_PRESENT,
1336 .inputs = {{
1337 .name = name_tv,
1338 .vmux = 7,
1339 .amux = TV,
1340 .tv = 1,
1341 },{
1342 .name = name_svideo,
1343 .vmux = 7,
1344 .amux = LINE1,
1345 }},
Linus Torvalds1da177e2005-04-16 15:20:36 -07001346 },
1347 [SAA7134_BOARD_ITEMS_MTV005] = {
1348 /* Norman Jonas <normanjonas@arcor.de> */
1349 .name = "Items MuchTV Plus / IT-005",
1350 .audio_clock = 0x00187de7,
1351 .tuner_type = TUNER_PHILIPS_PAL,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07001352 .radio_type = UNSET,
1353 .tuner_addr = ADDR_UNSET,
1354 .radio_addr = ADDR_UNSET,
Linus Torvalds1da177e2005-04-16 15:20:36 -07001355 .inputs = {{
1356 .name = name_tv,
1357 .vmux = 3,
1358 .amux = TV,
1359 .tv = 1,
1360 },{
1361 .name = name_comp1,
1362 .vmux = 1,
1363 .amux = LINE1,
1364 },{
1365 .name = name_svideo,
1366 .vmux = 8,
1367 .amux = LINE1,
1368 }},
1369 .radio = {
1370 .name = name_radio,
1371 .amux = LINE2,
1372 },
1373 },
1374 [SAA7134_BOARD_CINERGY200] = {
1375 .name = "Terratec Cinergy 200 TV",
1376 .audio_clock = 0x00200000,
1377 .tuner_type = TUNER_PHILIPS_PAL,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07001378 .radio_type = UNSET,
1379 .tuner_addr = ADDR_UNSET,
1380 .radio_addr = ADDR_UNSET,
Linus Torvalds1da177e2005-04-16 15:20:36 -07001381 .inputs = {{
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07001382 .name = name_tv,
Linus Torvalds1da177e2005-04-16 15:20:36 -07001383 .vmux = 1,
1384 .amux = LINE2,
1385 .tv = 1,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07001386 },{
1387 .name = name_comp1,
1388 .vmux = 4,
1389 .amux = LINE1,
1390 },{
1391 .name = name_svideo,
1392 .vmux = 8,
1393 .amux = LINE1,
1394 },{
1395 .name = name_comp2, /* CVideo over SVideo Connector */
1396 .vmux = 0,
1397 .amux = LINE1,
Linus Torvalds1da177e2005-04-16 15:20:36 -07001398 }},
1399 .mute = {
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07001400 .name = name_mute,
1401 .amux = LINE2,
Linus Torvalds1da177e2005-04-16 15:20:36 -07001402 },
1403 },
1404 [SAA7134_BOARD_VIDEOMATE_TV_PVR] = {
1405 /* Alain St-Denis <alain@topaze.homeip.net> */
1406 .name = "Compro VideoMate TV PVR/FM",
1407 .audio_clock = 0x00187de7,
1408 .tuner_type = TUNER_PHILIPS_NTSC_M,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07001409 .radio_type = UNSET,
1410 .tuner_addr = ADDR_UNSET,
1411 .radio_addr = ADDR_UNSET,
Linus Torvalds1da177e2005-04-16 15:20:36 -07001412 .gpiomask = 0x808c0080,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07001413 .inputs = {{
1414 .name = name_svideo,
1415 .vmux = 8,
1416 .amux = LINE1,
Linus Torvalds1da177e2005-04-16 15:20:36 -07001417 .gpio = 0x00080,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07001418 },{
1419 .name = name_comp1,
1420 .vmux = 3,
1421 .amux = LINE1,
Linus Torvalds1da177e2005-04-16 15:20:36 -07001422 .gpio = 0x00080,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07001423 },{
1424 .name = name_tv,
1425 .vmux = 1,
1426 .amux = LINE2_LEFT,
1427 .tv = 1,
Linus Torvalds1da177e2005-04-16 15:20:36 -07001428 .gpio = 0x00080,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07001429 }},
Linus Torvalds1da177e2005-04-16 15:20:36 -07001430 .radio = {
1431 .name = name_radio,
1432 .amux = LINE2,
1433 .gpio = 0x80000,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07001434 },
Linus Torvalds1da177e2005-04-16 15:20:36 -07001435 .mute = {
1436 .name = name_mute,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07001437 .amux = LINE2,
Linus Torvalds1da177e2005-04-16 15:20:36 -07001438 .gpio = 0x40000,
1439 },
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07001440 },
1441 [SAA7134_BOARD_SABRENT_SBTTVFM] = {
Linus Torvalds1da177e2005-04-16 15:20:36 -07001442 /* Michael Rodriguez-Torrent <mrtorrent@asu.edu> */
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07001443 .name = "Sabrent SBT-TVFM (saa7130)",
1444 .audio_clock = 0x00187de7,
1445 .tuner_type = TUNER_PHILIPS_NTSC_M,
1446 .radio_type = UNSET,
1447 .tuner_addr = ADDR_UNSET,
1448 .radio_addr = ADDR_UNSET,
1449 .inputs = {{
Linus Torvalds1da177e2005-04-16 15:20:36 -07001450 .name = name_comp1,
1451 .vmux = 1,
Mauro Carvalho Chehab6a989d72005-09-09 13:03:57 -07001452 .amux = LINE1,
Linus Torvalds1da177e2005-04-16 15:20:36 -07001453 },{
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07001454 .name = name_tv,
1455 .vmux = 3,
1456 .amux = LINE2,
1457 .tv = 1,
1458 },{
1459 .name = name_svideo,
1460 .vmux = 8,
Mauro Carvalho Chehab6a989d72005-09-09 13:03:57 -07001461 .amux = LINE1,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07001462 }},
1463 .radio = {
1464 .name = name_radio,
1465 .amux = LINE2,
1466 },
1467 },
Linus Torvalds1da177e2005-04-16 15:20:36 -07001468 [SAA7134_BOARD_ZOLID_XPERT_TV7134] = {
1469 /* Helge Jensen <helge.jensen@slog.dk> */
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07001470 .name = ":Zolid Xpert TV7134",
Linus Torvalds1da177e2005-04-16 15:20:36 -07001471 .audio_clock = 0x00187de7,
1472 .tuner_type = TUNER_PHILIPS_NTSC,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07001473 .radio_type = UNSET,
1474 .tuner_addr = ADDR_UNSET,
1475 .radio_addr = ADDR_UNSET,
1476 .inputs = {{
Linus Torvalds1da177e2005-04-16 15:20:36 -07001477 .name = name_svideo,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07001478 .vmux = 8,
1479 .amux = LINE1,
1480 },{
1481 .name = name_comp1,
1482 .vmux = 3,
1483 .amux = LINE1,
1484 },{
1485 .name = name_tv,
1486 .vmux = 1,
1487 .amux = LINE2,
1488 .tv = 1,
1489 }},
Linus Torvalds1da177e2005-04-16 15:20:36 -07001490 },
1491 [SAA7134_BOARD_EMPIRE_PCI_TV_RADIO_LE] = {
1492 /* "Matteo Az" <matte.az@nospam.libero.it> ;-) */
1493 .name = "Empire PCI TV-Radio LE",
1494 .audio_clock = 0x00187de7,
1495 .tuner_type = TUNER_PHILIPS_PAL,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07001496 .radio_type = UNSET,
1497 .tuner_addr = ADDR_UNSET,
1498 .radio_addr = ADDR_UNSET,
Linus Torvalds1da177e2005-04-16 15:20:36 -07001499 .gpiomask = 0x4000,
1500 .inputs = {{
1501 .name = name_tv_mono,
1502 .vmux = 1,
1503 .amux = LINE2,
1504 .gpio = 0x8000,
1505 .tv = 1,
1506 },{
1507 .name = name_comp1,
1508 .vmux = 3,
1509 .amux = LINE1,
1510 .gpio = 0x8000,
1511 },{
1512 .name = name_svideo,
1513 .vmux = 6,
1514 .amux = LINE1,
1515 .gpio = 0x8000,
1516 }},
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07001517 .radio = {
1518 .name = name_radio,
1519 .amux = LINE1,
1520 .gpio = 0x8000,
1521 },
Linus Torvalds1da177e2005-04-16 15:20:36 -07001522 .mute = {
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07001523 .name = name_mute,
1524 .amux = TV,
1525 .gpio =0x8000,
1526 }
Linus Torvalds1da177e2005-04-16 15:20:36 -07001527 },
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07001528 [SAA7134_BOARD_AVERMEDIA_STUDIO_307] = {
Linus Torvalds1da177e2005-04-16 15:20:36 -07001529 /*
1530 Nickolay V. Shmyrev <nshmyrev@yandex.ru>
1531 Lots of thanks to Andrey Zolotarev <zolotarev_andrey@mail.ru>
1532 */
1533 .name = "Avermedia AVerTV Studio 307",
1534 .audio_clock = 0x00187de7,
1535 .tuner_type = TUNER_PHILIPS_FM1256_IH3,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07001536 .radio_type = UNSET,
1537 .tuner_addr = ADDR_UNSET,
1538 .radio_addr = ADDR_UNSET,
Linus Torvalds1da177e2005-04-16 15:20:36 -07001539 .tda9887_conf = TDA9887_PRESENT,
1540 .gpiomask = 0x03,
1541 .inputs = {{
1542 .name = name_tv,
1543 .vmux = 1,
1544 .amux = TV,
1545 .tv = 1,
1546 .gpio = 0x00,
1547 },{
Stas Sergeevf438d972007-09-17 15:34:09 -03001548 .name = name_comp,
Linus Torvalds1da177e2005-04-16 15:20:36 -07001549 .vmux = 3,
Stas Sergeevf5e4fee2007-09-02 03:56:18 -03001550 .amux = LINE1,
1551 .gpio = 0x02,
Linus Torvalds1da177e2005-04-16 15:20:36 -07001552 },{
1553 .name = name_svideo,
1554 .vmux = 8,
Stas Sergeevf5e4fee2007-09-02 03:56:18 -03001555 .amux = LINE1,
1556 .gpio = 0x02,
Linus Torvalds1da177e2005-04-16 15:20:36 -07001557 }},
1558 .radio = {
1559 .name = name_radio,
1560 .amux = LINE1,
1561 .gpio = 0x01,
1562 },
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07001563 .mute = {
1564 .name = name_mute,
1565 .amux = LINE1,
1566 .gpio = 0x00,
1567 },
1568 },
1569 [SAA7134_BOARD_AVERMEDIA_GO_007_FM] = {
Mauro Carvalho Chehabac19ecc2005-06-23 22:05:09 -07001570 .name = "Avermedia AVerTV GO 007 FM",
1571 .audio_clock = 0x00187de7,
1572 .tuner_type = TUNER_PHILIPS_TDA8290,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07001573 .radio_type = UNSET,
1574 .tuner_addr = ADDR_UNSET,
1575 .radio_addr = ADDR_UNSET,
Mauro Carvalho Chehabac19ecc2005-06-23 22:05:09 -07001576 .gpiomask = 0x00300003,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07001577 /* .gpiomask = 0x8c240003, */
Mauro Carvalho Chehabac19ecc2005-06-23 22:05:09 -07001578 .inputs = {{
1579 .name = name_tv,
1580 .vmux = 1,
1581 .amux = TV,
1582 .tv = 1,
1583 .gpio = 0x01,
1584 },{
1585 .name = name_comp1,
1586 .vmux = 0,
Damian Minkovfbc84082007-03-29 08:47:39 -03001587 .amux = LINE1,
Mauro Carvalho Chehabac19ecc2005-06-23 22:05:09 -07001588 .gpio = 0x02,
1589 },{
1590 .name = name_svideo,
1591 .vmux = 6,
Damian Minkovfbc84082007-03-29 08:47:39 -03001592 .amux = LINE1,
Mauro Carvalho Chehabac19ecc2005-06-23 22:05:09 -07001593 .gpio = 0x02,
1594 }},
1595 .radio = {
1596 .name = name_radio,
1597 .amux = LINE1,
1598 .gpio = 0x00300001,
1599 },
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07001600 .mute = {
1601 .name = name_mute,
1602 .amux = TV,
1603 .gpio = 0x01,
1604 },
1605 },
Linus Torvalds1da177e2005-04-16 15:20:36 -07001606 [SAA7134_BOARD_AVERMEDIA_CARDBUS] = {
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07001607 /* Kees.Blom@cwi.nl */
1608 .name = "AVerMedia Cardbus TV/Radio (E500)",
1609 .audio_clock = 0x187de7,
1610 .tuner_type = TUNER_PHILIPS_TDA8290,
1611 .radio_type = UNSET,
1612 .tuner_addr = ADDR_UNSET,
1613 .radio_addr = ADDR_UNSET,
Linus Torvalds1da177e2005-04-16 15:20:36 -07001614 .inputs = {{
1615 .name = name_tv,
1616 .vmux = 1,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07001617 .amux = TV,
Linus Torvalds1da177e2005-04-16 15:20:36 -07001618 .tv = 1,
1619 },{
1620 .name = name_comp1,
1621 .vmux = 3,
1622 .amux = LINE2,
1623 },{
1624 .name = name_svideo,
1625 .vmux = 8,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07001626 .amux = LINE1,
Linus Torvalds1da177e2005-04-16 15:20:36 -07001627 }},
1628 .radio = {
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07001629 .name = name_radio,
Linus Torvalds1da177e2005-04-16 15:20:36 -07001630 .amux = LINE1,
1631 },
1632 },
1633 [SAA7134_BOARD_CINERGY400_CARDBUS] = {
1634 .name = "Terratec Cinergy 400 mobile",
1635 .audio_clock = 0x187de7,
1636 .tuner_type = TUNER_ALPS_TSBE5_PAL,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07001637 .radio_type = UNSET,
1638 .tuner_addr = ADDR_UNSET,
1639 .radio_addr = ADDR_UNSET,
1640 .tda9887_conf = TDA9887_PRESENT,
Linus Torvalds1da177e2005-04-16 15:20:36 -07001641 .inputs = {{
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07001642 .name = name_tv,
Linus Torvalds1da177e2005-04-16 15:20:36 -07001643 .vmux = 1,
1644 .amux = TV,
1645 .tv = 1,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07001646 },{
Linus Torvalds1da177e2005-04-16 15:20:36 -07001647 .name = name_tv_mono,
1648 .vmux = 1,
1649 .amux = LINE2,
1650 .tv = 1,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07001651 },{
1652 .name = name_comp1,
1653 .vmux = 3,
1654 .amux = LINE1,
1655 },{
1656 .name = name_svideo,
1657 .vmux = 8,
1658 .amux = LINE1,
Linus Torvalds1da177e2005-04-16 15:20:36 -07001659 }},
1660 },
1661 [SAA7134_BOARD_CINERGY600_MK3] = {
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07001662 .name = "Terratec Cinergy 600 TV MK3",
1663 .audio_clock = 0x00200000,
Linus Torvalds1da177e2005-04-16 15:20:36 -07001664 .tuner_type = TUNER_PHILIPS_FM1216ME_MK3,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07001665 .radio_type = UNSET,
1666 .tuner_addr = ADDR_UNSET,
1667 .radio_addr = ADDR_UNSET,
1668 .tda9887_conf = TDA9887_PRESENT,
1669 .inputs = {{
1670 .name = name_tv,
1671 .vmux = 1,
1672 .amux = TV,
1673 .tv = 1,
1674 },{
1675 .name = name_comp1,
1676 .vmux = 4,
1677 .amux = LINE1,
1678 },{
1679 .name = name_svideo,
1680 .vmux = 8,
1681 .amux = LINE1,
1682 },{
1683 .name = name_comp2, /* CVideo over SVideo Connector */
1684 .vmux = 0,
1685 .amux = LINE1,
1686 }},
Linus Torvalds1da177e2005-04-16 15:20:36 -07001687 .radio = {
1688 .name = name_radio,
1689 .amux = LINE2,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07001690 },
1691 },
1692 [SAA7134_BOARD_VIDEOMATE_GOLD_PLUS] = {
1693 /* Dylan Walkden <dylan_walkden@hotmail.com> */
1694 .name = "Compro VideoMate Gold+ Pal",
1695 .audio_clock = 0x00187de7,
1696 .tuner_type = TUNER_PHILIPS_PAL,
1697 .radio_type = UNSET,
1698 .tuner_addr = ADDR_UNSET,
1699 .radio_addr = ADDR_UNSET,
1700 .gpiomask = 0x1ce780,
1701 .inputs = {{
1702 .name = name_svideo,
1703 .vmux = 0, /* CVideo over SVideo Connector - ok? */
1704 .amux = LINE1,
1705 .gpio = 0x008080,
1706 },{
1707 .name = name_comp1,
1708 .vmux = 3,
1709 .amux = LINE1,
1710 .gpio = 0x008080,
1711 },{
1712 .name = name_tv,
1713 .vmux = 1,
1714 .amux = TV,
1715 .tv = 1,
1716 .gpio = 0x008080,
1717 }},
1718 .radio = {
1719 .name = name_radio,
1720 .amux = LINE2,
1721 .gpio = 0x80000,
1722 },
1723 .mute = {
1724 .name = name_mute,
1725 .amux = LINE2,
1726 .gpio = 0x0c8000,
1727 },
1728 },
Linus Torvalds1da177e2005-04-16 15:20:36 -07001729 [SAA7134_BOARD_PINNACLE_300I_DVBT_PAL] = {
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07001730 .name = "Pinnacle PCTV 300i DVB-T + PAL",
1731 .audio_clock = 0x00187de7,
1732 .tuner_type = TUNER_MT2032,
1733 .radio_type = UNSET,
1734 .tuner_addr = ADDR_UNSET,
1735 .radio_addr = ADDR_UNSET,
Hartmut Hackmanndf8cf702006-03-03 12:09:26 -03001736 .tda9887_conf = TDA9887_PRESENT | TDA9887_INTERCARRIER | TDA9887_PORT2_INACTIVE,
Linus Torvalds1da177e2005-04-16 15:20:36 -07001737 .mpeg = SAA7134_MPEG_DVB,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07001738 .inputs = {{
1739 .name = name_tv,
1740 .vmux = 3,
1741 .amux = TV,
1742 .tv = 1,
1743 },{
1744 .name = name_comp1,
1745 .vmux = 0,
1746 .amux = LINE2,
1747 },{
1748 .name = name_comp2,
1749 .vmux = 1,
1750 .amux = LINE2,
1751 },{
1752 .name = name_svideo,
1753 .vmux = 8,
1754 .amux = LINE2,
1755 }},
1756 },
Linus Torvalds1da177e2005-04-16 15:20:36 -07001757 [SAA7134_BOARD_PROVIDEO_PV952] = {
1758 /* andreas.kretschmer@web.de */
1759 .name = "ProVideo PV952",
1760 .audio_clock = 0x00187de7,
1761 .tuner_type = TUNER_PHILIPS_FM1216ME_MK3,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07001762 .radio_type = UNSET,
1763 .tuner_addr = ADDR_UNSET,
1764 .radio_addr = ADDR_UNSET,
Linus Torvalds1da177e2005-04-16 15:20:36 -07001765 .tda9887_conf = TDA9887_PRESENT,
1766 .inputs = {{
1767 .name = name_comp1,
1768 .vmux = 0,
1769 .amux = LINE1,
1770 },{
1771 .name = name_tv,
1772 .vmux = 1,
1773 .amux = TV,
1774 .tv = 1,
1775 },{
1776 .name = name_tv_mono,
1777 .vmux = 1,
1778 .amux = LINE2,
1779 .tv = 1,
1780 }},
1781 .radio = {
1782 .name = name_radio,
1783 .amux = LINE2,
1784 },
1785 },
1786 [SAA7134_BOARD_AVERMEDIA_305] = {
1787 /* much like the "studio" version but without radio
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07001788 * and another tuner (sirspiritus@yandex.ru) */
Linus Torvalds1da177e2005-04-16 15:20:36 -07001789 .name = "AverMedia AverTV/305",
1790 .audio_clock = 0x00187de7,
1791 .tuner_type = TUNER_PHILIPS_FQ1216ME,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07001792 .radio_type = UNSET,
1793 .tuner_addr = ADDR_UNSET,
1794 .radio_addr = ADDR_UNSET,
Linus Torvalds1da177e2005-04-16 15:20:36 -07001795 .tda9887_conf = TDA9887_PRESENT,
Linus Torvalds1da177e2005-04-16 15:20:36 -07001796 .inputs = {{
1797 .name = name_tv,
1798 .vmux = 1,
1799 .amux = LINE2,
1800 .tv = 1,
1801 },{
1802 .name = name_comp1,
1803 .vmux = 0,
1804 .amux = LINE2,
1805 },{
1806 .name = name_comp2,
1807 .vmux = 3,
1808 .amux = LINE2,
1809 },{
1810 .name = name_svideo,
1811 .vmux = 8,
1812 .amux = LINE2,
1813 }},
1814 .mute = {
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07001815 .name = name_mute,
1816 .amux = LINE1,
Linus Torvalds1da177e2005-04-16 15:20:36 -07001817 },
1818 },
1819 [SAA7134_BOARD_FLYDVBTDUO] = {
1820 /* LifeView FlyDVB-T DUO */
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07001821 /* "Nico Sabbi <nsabbi@tiscali.it> Hartmut Hackmann hartmut.hackmann@t-online.de*/
Peter Misseldb483672007-04-27 12:31:20 -03001822 .name = "LifeView FlyDVB-T DUO / MSI TV@nywhere Duo",
Linus Torvalds1da177e2005-04-16 15:20:36 -07001823 .audio_clock = 0x00200000,
1824 .tuner_type = TUNER_PHILIPS_TDA8290,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07001825 .radio_type = UNSET,
1826 .tuner_addr = ADDR_UNSET,
1827 .radio_addr = ADDR_UNSET,
Peter Missel7c7fea62007-04-27 12:31:14 -03001828 .gpiomask = 0x00200000,
Michael Krufky8ce47da2007-04-27 12:31:14 -03001829 .mpeg = SAA7134_MPEG_DVB,
Linus Torvalds1da177e2005-04-16 15:20:36 -07001830 .inputs = {{
1831 .name = name_tv,
1832 .vmux = 1,
1833 .amux = TV,
Peter Missel7c7fea62007-04-27 12:31:14 -03001834 .gpio = 0x200000, /* GPIO21=High for TV input */
Linus Torvalds1da177e2005-04-16 15:20:36 -07001835 .tv = 1,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07001836 },{
Linus Torvalds1da177e2005-04-16 15:20:36 -07001837 .name = name_comp1, /* Composite signal on S-Video input */
1838 .vmux = 0,
1839 .amux = LINE2,
Linus Torvalds1da177e2005-04-16 15:20:36 -07001840 },{
1841 .name = name_comp2, /* Composite input */
1842 .vmux = 3,
1843 .amux = LINE2,
Linus Torvalds1da177e2005-04-16 15:20:36 -07001844 },{
1845 .name = name_svideo, /* S-Video signal on S-Video input */
1846 .vmux = 8,
1847 .amux = LINE2,
Linus Torvalds1da177e2005-04-16 15:20:36 -07001848 }},
Peter Missel7c7fea62007-04-27 12:31:14 -03001849 .radio = {
1850 .name = name_radio,
1851 .amux = TV,
1852 .gpio = 0x000000, /* GPIO21=Low for FM radio antenna */
1853 },
Linus Torvalds1da177e2005-04-16 15:20:36 -07001854 },
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07001855 [SAA7134_BOARD_PHILIPS_TOUGH] = {
1856 .name = "Philips TOUGH DVB-T reference design",
1857 .tuner_type = TUNER_ABSENT,
Mauro Carvalho Chehabac19ecc2005-06-23 22:05:09 -07001858 .audio_clock = 0x00187de7,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07001859 .radio_type = UNSET,
1860 .tuner_addr = ADDR_UNSET,
1861 .radio_addr = ADDR_UNSET,
1862 .mpeg = SAA7134_MPEG_DVB,
1863 .inputs = {{
1864 .name = name_comp1,
1865 .vmux = 0,
1866 .amux = LINE1,
1867 },{
1868 .name = name_svideo,
1869 .vmux = 8,
1870 .amux = LINE1,
1871 }},
Mauro Carvalho Chehabac19ecc2005-06-23 22:05:09 -07001872 },
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07001873 [SAA7134_BOARD_AVERMEDIA_307] = {
1874 /*
1875 Davydov Vladimir <vladimir@iqmedia.com>
1876 */
1877 .name = "Avermedia AVerTV 307",
1878 .audio_clock = 0x00187de7,
1879 .tuner_type = TUNER_PHILIPS_FQ1216ME,
1880 .radio_type = UNSET,
1881 .tuner_addr = ADDR_UNSET,
1882 .radio_addr = ADDR_UNSET,
1883 .tda9887_conf = TDA9887_PRESENT,
1884 .inputs = {{
1885 .name = name_tv,
1886 .vmux = 1,
1887 .amux = TV,
1888 .tv = 1,
1889 },{
1890 .name = name_comp1,
1891 .vmux = 0,
1892 .amux = LINE1,
1893 },{
1894 .name = name_comp2,
1895 .vmux = 3,
1896 .amux = LINE1,
1897 },{
1898 .name = name_svideo,
1899 .vmux = 8,
1900 .amux = LINE1,
1901 }},
1902 },
1903 [SAA7134_BOARD_ADS_INSTANT_TV] = {
1904 .name = "ADS Tech Instant TV (saa7135)",
1905 .audio_clock = 0x00187de7,
1906 .tuner_type = TUNER_PHILIPS_TDA8290,
1907 .radio_type = UNSET,
1908 .tuner_addr = ADDR_UNSET,
1909 .radio_addr = ADDR_UNSET,
1910 .inputs = {{
1911 .name = name_tv,
1912 .vmux = 1,
1913 .amux = TV,
1914 .tv = 1,
1915 },{
1916 .name = name_comp1,
1917 .vmux = 3,
1918 .amux = LINE2,
1919 },{
1920 .name = name_svideo,
1921 .vmux = 8,
1922 .amux = LINE2,
1923 }},
1924 },
1925 [SAA7134_BOARD_KWORLD_VSTREAM_XPERT] = {
1926 .name = "Kworld/Tevion V-Stream Xpert TV PVR7134",
1927 .audio_clock = 0x00187de7,
1928 .tuner_type = TUNER_PHILIPS_PAL_I,
1929 .radio_type = UNSET,
1930 .tuner_addr = ADDR_UNSET,
1931 .radio_addr = ADDR_UNSET,
1932 .gpiomask = 0x0700,
1933 .inputs = {{
1934 .name = name_tv,
1935 .vmux = 1,
1936 .amux = TV,
1937 .tv = 1,
1938 .gpio = 0x000,
1939 },{
1940 .name = name_comp1,
1941 .vmux = 3,
1942 .amux = LINE1,
1943 .gpio = 0x200, /* gpio by DScaler */
1944 },{
1945 .name = name_svideo,
1946 .vmux = 0,
1947 .amux = LINE1,
1948 .gpio = 0x200,
1949 }},
1950 .radio = {
1951 .name = name_radio,
1952 .amux = LINE1,
1953 .gpio = 0x100,
1954 },
1955 .mute = {
1956 .name = name_mute,
1957 .amux = TV,
1958 .gpio = 0x000,
1959 },
1960 },
Peter Missel10b7a902006-01-23 17:11:06 -02001961 [SAA7134_BOARD_FLYDVBT_DUO_CARDBUS] = {
Hartmut Hackmann2c591942006-08-07 14:03:32 -03001962 .name = "LifeView/Typhoon/Genius FlyDVB-T Duo Cardbus",
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07001963 .audio_clock = 0x00200000,
1964 .tuner_type = TUNER_PHILIPS_TDA8290,
1965 .radio_type = UNSET,
1966 .tuner_addr = ADDR_UNSET,
1967 .radio_addr = ADDR_UNSET,
1968 .mpeg = SAA7134_MPEG_DVB,
Peter Missel10b7a902006-01-23 17:11:06 -02001969 .gpiomask = 0x00200000,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07001970 .inputs = {{
1971 .name = name_tv,
1972 .vmux = 1,
1973 .amux = TV,
Peter Missel10b7a902006-01-23 17:11:06 -02001974 .gpio = 0x200000, /* GPIO21=High for TV input */
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07001975 .tv = 1,
1976 },{
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07001977 .name = name_svideo, /* S-Video signal on S-Video input */
1978 .vmux = 8,
1979 .amux = LINE2,
Peter Missel10b7a902006-01-23 17:11:06 -02001980 },{
1981 .name = name_comp1, /* Composite signal on S-Video input */
1982 .vmux = 0,
1983 .amux = LINE2,
1984 },{
1985 .name = name_comp2, /* Composite input */
1986 .vmux = 3,
1987 .amux = LINE2,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07001988 }},
1989 .radio = {
1990 .name = name_radio,
Peter Missel10b7a902006-01-23 17:11:06 -02001991 .amux = TV,
1992 .gpio = 0x000000, /* GPIO21=Low for FM radio antenna */
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07001993 },
1994 },
1995 [SAA7134_BOARD_VIDEOMATE_TV_GOLD_PLUSII] = {
1996 .name = "Compro VideoMate TV Gold+II",
1997 .audio_clock = 0x002187de7,
1998 .tuner_type = TUNER_LG_PAL_NEW_TAPC,
1999 .radio_type = TUNER_TEA5767,
2000 .tuner_addr = 0x63,
2001 .radio_addr = 0x60,
2002 .gpiomask = 0x8c1880,
2003 .inputs = {{
2004 .name = name_svideo,
2005 .vmux = 0,
2006 .amux = LINE1,
2007 .gpio = 0x800800,
2008 },{
2009 .name = name_comp1,
2010 .vmux = 3,
2011 .amux = LINE1,
2012 .gpio = 0x801000,
2013 },{
2014 .name = name_tv,
2015 .vmux = 1,
2016 .amux = TV,
2017 .tv = 1,
2018 .gpio = 0x800000,
2019 }},
2020 .radio = {
2021 .name = name_radio,
2022 .amux = TV,
2023 .gpio = 0x880000,
2024 },
2025 .mute = {
2026 .name = name_mute,
2027 .amux = LINE2,
2028 .gpio = 0x840000,
2029 },
2030 },
2031 [SAA7134_BOARD_KWORLD_XPERT] = {
2032 /*
2033 FIXME:
2034 - Remote control doesn't initialize properly.
2035 - Audio volume starts muted,
2036 then gradually increases after channel change.
2037 - Overlay scaling problems (application error?)
2038 - Composite S-Video untested.
2039 From: Konrad Rzepecki <hannibal@megapolis.pl>
2040 */
2041 .name = "Kworld Xpert TV PVR7134",
2042 .audio_clock = 0x00187de7,
2043 .tuner_type = TUNER_TENA_9533_DI,
2044 .radio_type = TUNER_TEA5767,
2045 .tuner_addr = 0x61,
2046 .radio_addr = 0x60,
2047 .gpiomask = 0x0700,
2048 .inputs = {{
2049 .name = name_tv,
2050 .vmux = 1,
2051 .amux = TV,
2052 .tv = 1,
2053 .gpio = 0x000,
2054 },{
2055 .name = name_comp1,
2056 .vmux = 3,
2057 .amux = LINE1,
2058 .gpio = 0x200, /* gpio by DScaler */
2059 },{
2060 .name = name_svideo,
2061 .vmux = 0,
2062 .amux = LINE1,
2063 .gpio = 0x200,
2064 }},
2065 .radio = {
2066 .name = name_radio,
2067 .amux = LINE1,
2068 .gpio = 0x100,
2069 },
2070 .mute = {
2071 .name = name_mute,
2072 .amux = TV,
2073 .gpio = 0x000,
2074 },
2075 },
Mauro Carvalho Chehab2f180712005-09-09 13:03:46 -07002076 [SAA7134_BOARD_FLYTV_DIGIMATRIX] = {
2077 .name = "FlyTV mini Asus Digimatrix",
2078 .audio_clock = 0x00200000,
Michael Krufkyf3629be2006-03-11 17:02:01 -03002079 .tuner_type = TUNER_LG_TALN,
Mauro Carvalho Chehab2f180712005-09-09 13:03:46 -07002080 .radio_type = UNSET,
2081 .tuner_addr = ADDR_UNSET,
2082 .radio_addr = ADDR_UNSET,
2083 .inputs = {{
2084 .name = name_tv,
2085 .vmux = 1,
2086 .amux = TV,
2087 .tv = 1,
2088 },{
2089 .name = name_tv_mono,
2090 .vmux = 1,
2091 .amux = LINE2,
2092 .tv = 1,
2093 },{
2094 .name = name_comp1,
2095 .vmux = 0,
2096 .amux = LINE2,
2097 },{
2098 .name = name_comp2,
2099 .vmux = 3,
2100 .amux = LINE2,
2101 },{
2102 .name = name_svideo,
2103 .vmux = 8,
2104 .amux = LINE2,
2105 }},
2106 .radio = {
2107 .name = name_radio, /* radio unconfirmed */
2108 .amux = LINE2,
2109 },
2110 },
Mauro Carvalho Chehab260784d2005-09-09 13:03:49 -07002111 [SAA7134_BOARD_KWORLD_TERMINATOR] = {
2112 /* Kworld V-Stream Studio TV Terminator */
2113 /* "James Webb <jrwebb@qwest.net> */
2114 .name = "V-Stream Studio TV Terminator",
2115 .audio_clock = 0x00187de7,
2116 .tuner_type = TUNER_PHILIPS_TDA8290,
2117 .radio_type = UNSET,
2118 .tuner_addr = ADDR_UNSET,
2119 .radio_addr = ADDR_UNSET,
2120 .gpiomask = 1 << 21,
2121 .inputs = {{
2122 .name = name_tv,
2123 .vmux = 1,
2124 .amux = TV,
2125 .gpio = 0x0000000,
2126 .tv = 1,
2127 },{
2128 .name = name_comp1, /* Composite input */
2129 .vmux = 3,
2130 .amux = LINE2,
2131 .gpio = 0x0000000,
2132 },{
2133 .name = name_svideo, /* S-Video input */
2134 .vmux = 8,
2135 .amux = LINE2,
2136 .gpio = 0x0000000,
2137 }},
2138 .radio = {
2139 .name = name_radio,
2140 .amux = TV,
2141 .gpio = 0x0200000,
2142 },
2143 },
Mauro Carvalho Chehab4279f022005-09-09 13:03:51 -07002144 [SAA7134_BOARD_YUAN_TUN900] = {
2145 /* FIXME:
2146 * S-Video and composite sources untested.
2147 * Radio not working.
2148 * Remote control not yet implemented.
2149 * From : codemaster@webgeeks.be */
2150 .name = "Yuan TUN-900 (saa7135)",
2151 .audio_clock = 0x00187de7,
2152 .tuner_type = TUNER_PHILIPS_TDA8290,
2153 .radio_type = UNSET,
2154 .tuner_addr= ADDR_UNSET,
2155 .radio_addr= ADDR_UNSET,
2156 .gpiomask = 0x00010003,
2157 .inputs = {{
2158 .name = name_tv,
2159 .vmux = 1,
2160 .amux = TV,
2161 .tv = 1,
2162 .gpio = 0x01,
2163 },{
2164 .name = name_comp1,
2165 .vmux = 0,
2166 .amux = LINE2,
2167 .gpio = 0x02,
2168 },{
2169 .name = name_svideo,
2170 .vmux = 6,
2171 .amux = LINE2,
2172 .gpio = 0x02,
2173 }},
2174 .radio = {
2175 .name = name_radio,
2176 .amux = LINE1,
2177 .gpio = 0x00010003,
2178 },
2179 .mute = {
2180 .name = name_mute,
2181 .amux = TV,
2182 .gpio = 0x01,
2183 },
2184 },
Nickolay V. Shmyreva8ff4172005-11-08 21:36:16 -08002185 [SAA7134_BOARD_BEHOLD_409FM] = {
Mauro Carvalho Chehab4ac97912005-11-08 21:37:43 -08002186 /* <http://tuner.beholder.ru>, Sergey <skiv@orel.ru> */
2187 .name = "Beholder BeholdTV 409 FM",
2188 .audio_clock = 0x00187de7,
2189 .tuner_type = TUNER_PHILIPS_FM1216ME_MK3,
2190 .radio_type = UNSET,
2191 .tuner_addr = ADDR_UNSET,
2192 .radio_addr = ADDR_UNSET,
2193 .tda9887_conf = TDA9887_PRESENT,
2194 .inputs = {{
2195 .name = name_tv,
Nickolay V. Shmyreva8ff4172005-11-08 21:36:16 -08002196 .vmux = 3,
2197 .amux = TV,
2198 .tv = 1,
2199 },{
2200 .name = name_comp1,
2201 .vmux = 1,
2202 .amux = LINE1,
Mauro Carvalho Chehab4ac97912005-11-08 21:37:43 -08002203 },{
2204 .name = name_svideo,
Nickolay V. Shmyreva8ff4172005-11-08 21:36:16 -08002205 .vmux = 8,
2206 .amux = LINE1,
Mauro Carvalho Chehab4ac97912005-11-08 21:37:43 -08002207 }},
2208 .radio = {
2209 .name = name_radio,
Nickolay V. Shmyreva8ff4172005-11-08 21:36:16 -08002210 .amux = LINE2,
Trent Piepho657de3c2006-06-20 00:30:57 -03002211 },
Mauro Carvalho Chehab4ac97912005-11-08 21:37:43 -08002212 },
2213 [SAA7134_BOARD_GOTVIEW_7135] = {
Nickolay V. Shmyrevdcd555e2005-11-08 21:36:23 -08002214 /* Mike Baikov <mike@baikov.com> */
Nickolay V. Shmyrev6b961442005-11-08 21:36:22 -08002215 /* Andrey Cvetcov <ays14@yandex.ru> */
Mauro Carvalho Chehab4ac97912005-11-08 21:37:43 -08002216 .name = "GoTView 7135 PCI",
2217 .audio_clock = 0x00187de7,
2218 .tuner_type = TUNER_PHILIPS_FM1216ME_MK3,
2219 .radio_type = UNSET,
2220 .tuner_addr = ADDR_UNSET,
2221 .radio_addr = ADDR_UNSET,
2222 .tda9887_conf = TDA9887_PRESENT,
2223 .gpiomask = 0x00200003,
2224 .inputs = {{
2225 .name = name_tv,
2226 .vmux = 1,
2227 .amux = TV,
2228 .tv = 1,
2229 .gpio = 0x00200003,
2230 },{
2231 .name = name_tv_mono,
2232 .vmux = 1,
2233 .amux = LINE2,
2234 .gpio = 0x00200003,
2235 },{
2236 .name = name_comp1,
2237 .vmux = 3,
2238 .amux = LINE1,
2239 .gpio = 0x00200003,
2240 },{
2241 .name = name_svideo,
2242 .vmux = 8,
2243 .amux = LINE1,
2244 .gpio = 0x00200003,
2245 }},
2246 .radio = {
2247 .name = name_radio,
2248 .amux = LINE2,
2249 .gpio = 0x00200003,
2250 },
2251 .mute = {
2252 .name = name_mute,
2253 .amux = TV,
2254 .gpio = 0x00200003,
2255 },
2256 },
Hartmut Hackmann2cf36ac2005-11-08 21:36:32 -08002257 [SAA7134_BOARD_PHILIPS_EUROPA] = {
2258 .name = "Philips EUROPA V3 reference design",
2259 .audio_clock = 0x00187de7,
2260 .tuner_type = TUNER_PHILIPS_TD1316,
2261 .radio_type = UNSET,
2262 .tuner_addr = 0x61,
2263 .radio_addr = ADDR_UNSET,
Hartmut Hackmann44fd06f2006-02-27 00:09:11 -03002264 .tda9887_conf = TDA9887_PRESENT | TDA9887_PORT1_ACTIVE,
Hartmut Hackmann2cf36ac2005-11-08 21:36:32 -08002265 .mpeg = SAA7134_MPEG_DVB,
2266 .inputs = {{
2267 .name = name_tv,
2268 .vmux = 3,
2269 .amux = TV,
2270 .tv = 1,
2271 },{
2272 .name = name_comp1,
2273 .vmux = 0,
2274 .amux = LINE2,
2275 },{
2276 .name = name_svideo,
2277 .vmux = 8,
2278 .amux = LINE2,
2279 }},
2280 },
2281 [SAA7134_BOARD_VIDEOMATE_DVBT_300] = {
2282 .name = "Compro Videomate DVB-T300",
2283 .audio_clock = 0x00187de7,
2284 .tuner_type = TUNER_PHILIPS_TD1316,
2285 .radio_type = UNSET,
2286 .tuner_addr = 0x61,
2287 .radio_addr = ADDR_UNSET,
Hartmut Hackmann44fd06f2006-02-27 00:09:11 -03002288 .tda9887_conf = TDA9887_PRESENT | TDA9887_PORT1_ACTIVE,
Hartmut Hackmann2cf36ac2005-11-08 21:36:32 -08002289 .mpeg = SAA7134_MPEG_DVB,
2290 .inputs = {{
2291 .name = name_tv,
2292 .vmux = 3,
2293 .amux = TV,
2294 .tv = 1,
2295 },{
2296 .name = name_comp1,
2297 .vmux = 1,
2298 .amux = LINE2,
2299 },{
2300 .name = name_svideo,
2301 .vmux = 8,
2302 .amux = LINE2,
2303 }},
2304 },
2305 [SAA7134_BOARD_VIDEOMATE_DVBT_200] = {
2306 .name = "Compro Videomate DVB-T200",
2307 .tuner_type = TUNER_ABSENT,
2308 .audio_clock = 0x00187de7,
2309 .radio_type = UNSET,
2310 .tuner_addr = ADDR_UNSET,
2311 .radio_addr = ADDR_UNSET,
2312 .mpeg = SAA7134_MPEG_DVB,
2313 .inputs = {{
2314 .name = name_comp1,
2315 .vmux = 0,
2316 .amux = LINE1,
2317 },{
2318 .name = name_svideo,
2319 .vmux = 8,
2320 .amux = LINE1,
2321 }},
2322 },
Mauro Carvalho Chehab4ac97912005-11-08 21:37:43 -08002323 [SAA7134_BOARD_RTD_VFG7350] = {
2324 .name = "RTD Embedded Technologies VFG7350",
2325 .audio_clock = 0x00200000,
2326 .tuner_type = TUNER_ABSENT,
2327 .radio_type = UNSET,
2328 .tuner_addr = ADDR_UNSET,
2329 .radio_addr = ADDR_UNSET,
2330 .inputs = {{
2331 .name = "Composite 0",
2332 .vmux = 0,
2333 .amux = LINE1,
2334 },{
2335 .name = "Composite 1",
2336 .vmux = 1,
2337 .amux = LINE2,
2338 },{
2339 .name = "Composite 2",
2340 .vmux = 2,
2341 .amux = LINE1,
2342 },{
2343 .name = "Composite 3",
2344 .vmux = 3,
2345 .amux = LINE2,
2346 },{
2347 .name = "S-Video 0",
2348 .vmux = 8,
2349 .amux = LINE1,
2350 },{
2351 .name = "S-Video 1",
2352 .vmux = 9,
2353 .amux = LINE2,
2354 }},
2355 .mpeg = SAA7134_MPEG_EMPRESS,
2356 .video_out = CCIR656,
Robert W. Boone2f8d4f52005-11-08 21:37:10 -08002357 .vid_port_opts = ( SET_T_CODE_POLARITY_NON_INVERTED |
2358 SET_CLOCK_NOT_DELAYED |
2359 SET_CLOCK_INVERTED |
2360 SET_VSYNC_OFF ),
Mauro Carvalho Chehab4ac97912005-11-08 21:37:43 -08002361 },
2362 [SAA7134_BOARD_RTD_VFG7330] = {
2363 .name = "RTD Embedded Technologies VFG7330",
2364 .audio_clock = 0x00200000,
2365 .tuner_type = TUNER_ABSENT,
2366 .radio_type = UNSET,
2367 .tuner_addr = ADDR_UNSET,
2368 .radio_addr = ADDR_UNSET,
2369 .inputs = {{
2370 .name = "Composite 0",
2371 .vmux = 0,
2372 .amux = LINE1,
2373 },{
2374 .name = "Composite 1",
2375 .vmux = 1,
2376 .amux = LINE2,
2377 },{
2378 .name = "Composite 2",
2379 .vmux = 2,
2380 .amux = LINE1,
2381 },{
2382 .name = "Composite 3",
2383 .vmux = 3,
2384 .amux = LINE2,
2385 },{
2386 .name = "S-Video 0",
2387 .vmux = 8,
2388 .amux = LINE1,
2389 },{
2390 .name = "S-Video 1",
2391 .vmux = 9,
2392 .amux = LINE2,
2393 }},
2394 },
Mauro Carvalho Chehab058afaf2005-11-08 21:36:49 -08002395 [SAA7134_BOARD_FLYTVPLATINUM_MINI2] = {
2396 .name = "LifeView FlyTV Platinum Mini2",
2397 .audio_clock = 0x00200000,
2398 .tuner_type = TUNER_PHILIPS_TDA8290,
2399 .radio_type = UNSET,
2400 .tuner_addr = ADDR_UNSET,
2401 .radio_addr = ADDR_UNSET,
2402
2403 .inputs = {{
2404 .name = name_tv,
2405 .vmux = 1,
2406 .amux = TV,
2407 .tv = 1,
2408 },{
2409 .name = name_comp1, /* Composite signal on S-Video input */
2410 .vmux = 0,
2411 .amux = LINE2,
2412 },{
2413 .name = name_comp2, /* Composite input */
2414 .vmux = 3,
2415 .amux = LINE2,
2416 },{
2417 .name = name_svideo,
2418 .vmux = 8,
2419 .amux = LINE2,
2420 }},
2421 },
Michael Krufky76bc3a32005-11-08 21:37:27 -08002422 [SAA7134_BOARD_AVERMEDIA_AVERTVHD_A180] = {
Michael Krufkyac113d12005-11-08 21:38:21 -08002423 /* Michael Krufky <mkrufky@m1k.net>
2424 * Uses Alps Electric TDHU2, containing NXT2004 ATSC Decoder
2425 * AFAIK, there is no analog demod, thus,
2426 * no support for analog television.
2427 */
Michael Krufky76bc3a32005-11-08 21:37:27 -08002428 .name = "AVerMedia AVerTVHD MCE A180",
2429 .audio_clock = 0x00187de7,
2430 .tuner_type = TUNER_ABSENT,
2431 .radio_type = UNSET,
2432 .tuner_addr = ADDR_UNSET,
2433 .radio_addr = ADDR_UNSET,
Michael Krufky3b64e8e2005-11-08 21:38:20 -08002434 .mpeg = SAA7134_MPEG_DVB,
Michael Krufky76bc3a32005-11-08 21:37:27 -08002435 .inputs = {{
2436 .name = name_comp1,
2437 .vmux = 3,
2438 .amux = LINE2,
2439 },{
2440 .name = name_svideo,
2441 .vmux = 8,
2442 .amux = LINE2,
2443 }},
2444 },
Pieter Palmerscf1c5d12005-11-08 21:37:40 -08002445 [SAA7134_BOARD_MONSTERTV_MOBILE] = {
2446 .name = "SKNet MonsterTV Mobile",
2447 .audio_clock = 0x00187de7,
2448 .tuner_type = TUNER_PHILIPS_TDA8290,
2449 .radio_type = UNSET,
2450 .tuner_addr = ADDR_UNSET,
2451 .radio_addr = ADDR_UNSET,
2452
2453 .inputs = {{
2454 .name = name_tv,
2455 .vmux = 1,
2456 .amux = TV,
2457 .tv = 1,
2458 },{
2459 .name = name_comp1,
2460 .vmux = 3,
2461 .amux = LINE1,
2462 },{
2463 .name = name_svideo,
2464 .vmux = 6,
2465 .amux = LINE1,
2466 }},
2467 },
Ricardo Cerqueirac2f6f9d2005-11-08 21:37:51 -08002468 [SAA7134_BOARD_PINNACLE_PCTV_110i] = {
Karsten Suehringcb46e3c2006-02-27 00:08:08 -03002469 .name = "Pinnacle PCTV 40i/50i/110i (saa7133)",
Ricardo Cerqueirac2f6f9d2005-11-08 21:37:51 -08002470 .audio_clock = 0x00187de7,
2471 .tuner_type = TUNER_PHILIPS_TDA8290,
2472 .radio_type = UNSET,
2473 .tuner_addr = ADDR_UNSET,
2474 .radio_addr = ADDR_UNSET,
2475 .gpiomask = 0x080200000,
2476 .inputs = {{
2477 .name = name_tv,
2478 .vmux = 4,
2479 .amux = TV,
2480 .tv = 1,
2481 },{
2482 .name = name_comp1,
2483 .vmux = 1,
Karsten Suehringcb46e3c2006-02-27 00:08:08 -03002484 .amux = LINE2,
2485 },{
2486 .name = name_comp2,
2487 .vmux = 0,
Ricardo Cerqueirac2f6f9d2005-11-08 21:37:51 -08002488 .amux = LINE2,
2489 },{
2490 .name = name_svideo,
2491 .vmux = 8,
2492 .amux = LINE2,
2493 }},
2494 .radio = {
2495 .name = name_radio,
2496 .amux = LINE1,
2497 },
2498 },
Hermann Pitton28f02242005-11-08 21:38:03 -08002499 [SAA7134_BOARD_ASUSTeK_P7131_DUAL] = {
2500 .name = "ASUSTeK P7131 Dual",
2501 .audio_clock = 0x00187de7,
2502 .tuner_type = TUNER_PHILIPS_TDA8290,
2503 .radio_type = UNSET,
2504 .tuner_addr = ADDR_UNSET,
2505 .radio_addr = ADDR_UNSET,
2506 .gpiomask = 1 << 21,
Hartmut Hackmannd4b0aba2005-11-08 21:38:44 -08002507 .mpeg = SAA7134_MPEG_DVB,
Hermann Pitton28f02242005-11-08 21:38:03 -08002508 .inputs = {{
2509 .name = name_tv,
2510 .vmux = 1,
2511 .amux = TV,
2512 .tv = 1,
Hartmut Hackmann83646812006-10-12 20:38:51 -03002513 .gpio = 0x0000000,
Hermann Pitton28f02242005-11-08 21:38:03 -08002514 },{
2515 .name = name_comp1,
2516 .vmux = 3,
2517 .amux = LINE2,
Hartmut Hackmann83646812006-10-12 20:38:51 -03002518 .gpio = 0x0200000,
Hermann Pitton28f02242005-11-08 21:38:03 -08002519 },{
Hermann Pitton8387c662006-12-10 21:08:03 -03002520 .name = name_comp2,
2521 .vmux = 0,
2522 .amux = LINE2,
2523 .gpio = 0x0200000,
2524 },{
Hermann Pitton28f02242005-11-08 21:38:03 -08002525 .name = name_svideo,
2526 .vmux = 8,
2527 .amux = LINE2,
Hartmut Hackmann83646812006-10-12 20:38:51 -03002528 .gpio = 0x0200000,
Hermann Pitton28f02242005-11-08 21:38:03 -08002529 }},
2530 .radio = {
2531 .name = name_radio,
2532 .amux = TV,
2533 .gpio = 0x0200000,
2534 },
2535 },
Ricardo Cerqueira17ce1ff2005-11-08 21:38:47 -08002536 [SAA7134_BOARD_SEDNA_PC_TV_CARDBUS] = {
Paul T Zalacfe2e36c2005-11-08 21:38:04 -08002537 /* Paul Tom Zalac <pzalac@gmail.com> */
Pavel Mihaylovc3d93192005-11-08 21:38:43 -08002538 /* Pavel Mihaylov <bin@bash.info> */
Ricardo Cerqueira17ce1ff2005-11-08 21:38:47 -08002539 .name = "Sedna/MuchTV PC TV Cardbus TV/Radio (ITO25 Rev:2B)",
2540 /* Sedna/MuchTV (OEM) Cardbus TV Tuner */
Paul T Zalacfe2e36c2005-11-08 21:38:04 -08002541 .audio_clock = 0x00187de7,
Pavel Mihaylovc3d93192005-11-08 21:38:43 -08002542 .tuner_type = TUNER_PHILIPS_TDA8290,
Paul T Zalacfe2e36c2005-11-08 21:38:04 -08002543 .radio_type = UNSET,
2544 .tuner_addr = ADDR_UNSET,
2545 .radio_addr = ADDR_UNSET,
Pavel Mihaylovc3d93192005-11-08 21:38:43 -08002546 .gpiomask = 0xe880c0,
Paul T Zalacfe2e36c2005-11-08 21:38:04 -08002547 .inputs = {{
Pavel Mihaylovc3d93192005-11-08 21:38:43 -08002548 .name = name_tv,
2549 .vmux = 3,
2550 .amux = TV,
2551 .tv = 1,
2552 },{
Paul T Zalacfe2e36c2005-11-08 21:38:04 -08002553 .name = name_comp1,
2554 .vmux = 1,
Pavel Mihaylovc3d93192005-11-08 21:38:43 -08002555 .amux = LINE1,
2556 },{
2557 .name = name_svideo,
2558 .vmux = 6,
2559 .amux = LINE1,
Paul T Zalacfe2e36c2005-11-08 21:38:04 -08002560 }},
Pavel Mihaylovc3d93192005-11-08 21:38:43 -08002561 .radio = {
2562 .name = name_radio,
2563 .amux = LINE2,
2564 },
Paul T Zalacfe2e36c2005-11-08 21:38:04 -08002565 },
Michael Krufky5d5c9902005-11-08 21:38:08 -08002566 [SAA7134_BOARD_ASUSTEK_DIGIMATRIX_TV] = {
2567 /* "Cyril Lacoux (Yack)" <clacoux@ifeelgood.org> */
2568 .name = "ASUS Digimatrix TV",
2569 .audio_clock = 0x00200000,
2570 .tuner_type = TUNER_PHILIPS_FQ1216ME,
2571 .tda9887_conf = TDA9887_PRESENT,
2572 .radio_type = UNSET,
2573 .tuner_addr = ADDR_UNSET,
2574 .radio_addr = ADDR_UNSET,
2575 .inputs = {{
2576 .name = name_tv,
2577 .vmux = 1,
2578 .amux = TV,
2579 .tv = 1,
2580 },{
2581 .name = name_comp1,
2582 .vmux = 3,
2583 .amux = LINE1,
2584 },{
2585 .name = name_svideo,
2586 .vmux = 8,
2587 .amux = LINE1,
2588 }},
2589 },
Hartmut Hackmann90e9df72005-11-08 21:38:42 -08002590 [SAA7134_BOARD_PHILIPS_TIGER] = {
2591 .name = "Philips Tiger reference design",
2592 .audio_clock = 0x00187de7,
2593 .tuner_type = TUNER_PHILIPS_TDA8290,
2594 .radio_type = UNSET,
2595 .tuner_addr = ADDR_UNSET,
2596 .radio_addr = ADDR_UNSET,
Hartmut Hackmann58ef4f92007-04-27 12:31:12 -03002597 .tuner_config = 0,
Hartmut Hackmann90e9df72005-11-08 21:38:42 -08002598 .mpeg = SAA7134_MPEG_DVB,
Hartmut Hackmannde956c12007-04-27 12:31:12 -03002599 .gpiomask = 0x0200000,
Hartmut Hackmann90e9df72005-11-08 21:38:42 -08002600 .inputs = {{
2601 .name = name_tv,
2602 .vmux = 1,
2603 .amux = TV,
2604 .tv = 1,
2605 },{
2606 .name = name_comp1,
2607 .vmux = 3,
2608 .amux = LINE1,
2609 },{
2610 .name = name_svideo,
2611 .vmux = 8,
2612 .amux = LINE1,
2613 }},
Hartmut Hackmann0f79c362006-01-14 21:26:44 -02002614 .radio = {
2615 .name = name_radio,
2616 .amux = TV,
2617 .gpio = 0x0200000,
2618 },
Hartmut Hackmann90e9df72005-11-08 21:38:42 -08002619 },
Ricardo Cerqueira80d2ad92005-11-13 16:08:01 -08002620 [SAA7134_BOARD_MSI_TVATANYWHERE_PLUS] = {
2621 .name = "MSI TV@Anywhere plus",
2622 .audio_clock = 0x00187de7,
2623 .tuner_type = TUNER_PHILIPS_TDA8290,
2624 .radio_type = UNSET,
2625 .tuner_addr = ADDR_UNSET,
2626 .radio_addr = ADDR_UNSET,
hermann pittone382f622007-01-07 21:19:48 -03002627 .gpiomask = 1 << 21,
Ricardo Cerqueira80d2ad92005-11-13 16:08:01 -08002628 .inputs = {{
2629 .name = name_tv,
2630 .vmux = 1,
2631 .amux = TV,
2632 .tv = 1,
2633 },{
2634 .name = name_comp1,
2635 .vmux = 3,
hermann pittone382f622007-01-07 21:19:48 -03002636 .amux = LINE2, /* unconfirmed, taken from Philips driver */
2637 },{
2638 .name = name_comp2,
2639 .vmux = 0, /* untested, Composite over S-Video */
2640 .amux = LINE2,
Ricardo Cerqueira80d2ad92005-11-13 16:08:01 -08002641 },{
2642 .name = name_svideo,
hermann pittone382f622007-01-07 21:19:48 -03002643 .vmux = 8,
2644 .amux = LINE2,
Ricardo Cerqueira80d2ad92005-11-13 16:08:01 -08002645 }},
2646 .radio = {
2647 .name = name_radio,
hermann pittone382f622007-01-07 21:19:48 -03002648 .amux = TV,
2649 .gpio = 0x0200000,
Ricardo Cerqueira80d2ad92005-11-13 16:08:01 -08002650 },
2651 },
Jörg Schummerf639c9b2006-01-09 15:25:01 -02002652 [SAA7134_BOARD_CINERGY250PCI] = {
2653 /* remote-control does not work. The signal about a
2654 key press comes in via gpio, but the key code
2655 doesn't. Neither does it have an i2c remote control
2656 interface. */
2657 .name = "Terratec Cinergy 250 PCI TV",
2658 .audio_clock = 0x00187de7,
2659 .tuner_type = TUNER_PHILIPS_TDA8290,
2660 .radio_type = UNSET,
2661 .tuner_addr = ADDR_UNSET,
2662 .radio_addr = ADDR_UNSET,
2663 .gpiomask = 0x80200000,
2664 .inputs = {{
2665 .name = name_tv,
2666 .vmux = 1,
2667 .amux = TV,
2668 .tv = 1,
2669 },{
2670 .name = name_svideo, /* NOT tested */
2671 .vmux = 8,
2672 .amux = LINE1,
2673 }},
2674 .radio = {
2675 .name = name_radio,
Hartmut Hackmann58ef4f92007-04-27 12:31:12 -03002676 .amux = TV,
Jörg Schummerf639c9b2006-01-09 15:25:01 -02002677 .gpio = 0x0200000,
2678 },
2679 },
Peter Missel4aa6ba52006-01-09 15:32:45 -02002680 [SAA7134_BOARD_FLYDVB_TRIO] = {
2681 /* LifeView LR319 FlyDVB Trio */
2682 /* Peter Missel <peter.missel@onlinehome.de> */
2683 .name = "LifeView FlyDVB Trio",
2684 .audio_clock = 0x00200000,
2685 .tuner_type = TUNER_PHILIPS_TDA8290,
2686 .radio_type = UNSET,
2687 .tuner_addr = ADDR_UNSET,
2688 .radio_addr = ADDR_UNSET,
2689 .gpiomask = 0x00200000,
Hartmut Hackmann293cdab2006-02-27 21:08:07 -03002690 .mpeg = SAA7134_MPEG_DVB,
Peter Missel4aa6ba52006-01-09 15:32:45 -02002691 .inputs = {{
2692 .name = name_tv, /* Analog broadcast/cable TV */
2693 .vmux = 1,
2694 .amux = TV,
2695 .gpio = 0x200000, /* GPIO21=High for TV input */
2696 .tv = 1,
2697 },{
2698 .name = name_svideo, /* S-Video signal on S-Video input */
2699 .vmux = 8,
2700 .amux = LINE2,
2701 },{
2702 .name = name_comp1, /* Composite signal on S-Video input */
2703 .vmux = 0,
2704 .amux = LINE2,
2705 },{
2706 .name = name_comp2, /* Composite input */
2707 .vmux = 3,
2708 .amux = LINE2,
2709 }},
2710 .radio = {
2711 .name = name_radio,
2712 .amux = TV,
2713 .gpio = 0x000000, /* GPIO21=Low for FM radio antenna */
2714 },
2715 },
Jose Alberto Regueroa78d0bf2006-02-07 06:25:14 -02002716 [SAA7134_BOARD_AVERMEDIA_777] = {
2717 .name = "AverTV DVB-T 777",
2718 .audio_clock = 0x00187de7,
2719 .tuner_type = TUNER_ABSENT,
2720 .radio_type = UNSET,
2721 .tuner_addr = ADDR_UNSET,
2722 .radio_addr = ADDR_UNSET,
2723 .mpeg = SAA7134_MPEG_DVB,
2724 .inputs = {{
2725 .name = name_comp1,
Hartmut Hackmann2174eb92006-03-27 19:15:47 -03002726 .vmux = 1,
Jose Alberto Regueroa78d0bf2006-02-07 06:25:14 -02002727 .amux = LINE1,
2728 },{
2729 .name = name_svideo,
2730 .vmux = 8,
2731 .amux = LINE1,
2732 }},
2733 },
Giampiero Giancipoli3d8466e2006-02-07 06:49:09 -02002734 [SAA7134_BOARD_FLYDVBT_LR301] = {
2735 /* LifeView FlyDVB-T */
2736 /* Giampiero Giancipoli <gianci@libero.it> */
Hartmut Hackmann42e6b3b2006-03-27 19:04:48 -03002737 .name = "LifeView FlyDVB-T / Genius VideoWonder DVB-T",
Giampiero Giancipoli3d8466e2006-02-07 06:49:09 -02002738 .audio_clock = 0x00200000,
2739 .tuner_type = TUNER_ABSENT,
2740 .radio_type = UNSET,
2741 .tuner_addr = ADDR_UNSET,
2742 .radio_addr = ADDR_UNSET,
2743 .mpeg = SAA7134_MPEG_DVB,
2744 .inputs = {{
2745 .name = name_comp1, /* Composite input */
2746 .vmux = 3,
2747 .amux = LINE2,
2748 },{
2749 .name = name_svideo, /* S-Video signal on S-Video input */
2750 .vmux = 8,
2751 .amux = LINE2,
2752 }},
2753 },
Hartmut Hackmanndf42eaf2006-02-07 06:49:10 -02002754 [SAA7134_BOARD_ADS_DUO_CARDBUS_PTV331] = {
2755 .name = "ADS Instant TV Duo Cardbus PTV331",
2756 .audio_clock = 0x00200000,
2757 .tuner_type = TUNER_PHILIPS_TDA8290,
2758 .radio_type = UNSET,
2759 .tuner_addr = ADDR_UNSET,
2760 .radio_addr = ADDR_UNSET,
2761 .mpeg = SAA7134_MPEG_DVB,
2762 .gpiomask = 0x00600000, /* Bit 21 0=Radio, Bit 22 0=TV */
2763 .inputs = {{
2764 .name = name_tv,
2765 .vmux = 1,
2766 .amux = TV,
2767 .tv = 1,
2768 .gpio = 0x00200000,
2769 }},
2770 },
Peter Hartshorn3dfb7292006-02-07 06:49:13 -02002771 [SAA7134_BOARD_TEVION_DVBT_220RF] = {
Adrian Bunk793f2252006-03-08 10:50:06 -03002772 .name = "Tevion/KWorld DVB-T 220RF",
Peter Hartshorn3dfb7292006-02-07 06:49:13 -02002773 .audio_clock = 0x00187de7,
2774 .tuner_type = TUNER_PHILIPS_TDA8290,
2775 .radio_type = UNSET,
2776 .tuner_addr = ADDR_UNSET,
2777 .radio_addr = ADDR_UNSET,
2778 .mpeg = SAA7134_MPEG_DVB,
Simon Farnsworth289ea1f2007-09-10 13:37:26 -03002779 .gpiomask = 1 << 21,
Peter Hartshorn3dfb7292006-02-07 06:49:13 -02002780 .inputs = {{
2781 .name = name_tv,
2782 .vmux = 1,
2783 .amux = TV,
2784 .tv = 1,
2785 },{
2786 .name = name_comp1,
2787 .vmux = 3,
2788 .amux = LINE1,
2789 },{
Simon Farnsworth289ea1f2007-09-10 13:37:26 -03002790 .name = name_comp2,
Peter Hartshorn3dfb7292006-02-07 06:49:13 -02002791 .vmux = 0,
2792 .amux = LINE1,
Simon Farnsworth289ea1f2007-09-10 13:37:26 -03002793 },{
2794 .name = name_svideo,
2795 .vmux = 8,
2796 .amux = LINE1,
Peter Hartshorn3dfb7292006-02-07 06:49:13 -02002797 }},
2798 .radio = {
2799 .name = name_radio,
Simon Farnsworth289ea1f2007-09-10 13:37:26 -03002800 .amux = TV,
2801 .gpio = 0x0200000,
Peter Hartshorn3dfb7292006-02-07 06:49:13 -02002802 },
2803 },
Simon Farnsworthb39423a2007-05-01 10:01:20 -03002804 [SAA7134_BOARD_KWORLD_DVBT_210] = {
2805 .name = "KWorld DVB-T 210",
2806 .audio_clock = 0x00187de7,
2807 .tuner_type = TUNER_PHILIPS_TDA8290,
2808 .radio_type = UNSET,
2809 .tuner_addr = ADDR_UNSET,
2810 .radio_addr = ADDR_UNSET,
2811 .mpeg = SAA7134_MPEG_DVB,
2812 .gpiomask = 1 << 21,
2813 .inputs = {{
2814 .name = name_tv,
2815 .vmux = 1,
2816 .amux = TV,
2817 .tv = 1,
2818 },{
2819 .name = name_comp1,
2820 .vmux = 3,
2821 .amux = LINE1,
2822 },{
2823 .name = name_svideo,
2824 .vmux = 8,
2825 .amux = LINE1,
2826 }},
2827 .radio = {
2828 .name = name_radio,
2829 .amux = TV,
2830 .gpio = 0x0200000,
2831 },
2832 },
Andrew Burri3e1410a2006-02-27 00:08:23 -03002833 [SAA7134_BOARD_KWORLD_ATSC110] = {
Eric Sandeen0ac3a5b2007-10-08 16:13:02 -03002834 .name = "Kworld ATSC110/115",
Andrew Burri3e1410a2006-02-27 00:08:23 -03002835 .audio_clock = 0x00187de7,
2836 .tuner_type = TUNER_PHILIPS_TUV1236D,
2837 .radio_type = UNSET,
2838 .tuner_addr = ADDR_UNSET,
2839 .radio_addr = ADDR_UNSET,
2840 .tda9887_conf = TDA9887_PRESENT,
2841 .mpeg = SAA7134_MPEG_DVB,
2842 .inputs = {{
2843 .name = name_tv,
2844 .vmux = 1,
2845 .amux = TV,
2846 .tv = 1,
Curt Meyers6ba509d2006-02-27 00:08:32 -03002847 },{
2848 .name = name_comp1,
2849 .vmux = 3,
2850 .amux = LINE2,
2851 },{
2852 .name = name_svideo,
2853 .vmux = 8,
2854 .amux = LINE2,
Andrew Burri3e1410a2006-02-27 00:08:23 -03002855 }},
2856 },
Rickard Osser68593af2006-03-11 17:14:12 -03002857 [SAA7134_BOARD_AVERMEDIA_A169_B] = {
2858 /* AVerMedia A169 */
2859 /* Rickard Osser <ricky@osser.se> */
2860 /* This card has two saa7134 chips on it,
2861 but only one of them is currently working. */
2862 .name = "AVerMedia A169 B",
2863 .audio_clock = 0x02187de7,
2864 .tuner_type = TUNER_LG_TALN,
2865 .radio_type = UNSET,
2866 .tuner_addr = ADDR_UNSET,
2867 .radio_addr = ADDR_UNSET,
2868 .tda9887_conf = TDA9887_PRESENT,
2869 .gpiomask = 0x0a60000,
2870 },
2871 [SAA7134_BOARD_AVERMEDIA_A169_B1] = {
2872 /* AVerMedia A169 */
2873 /* Rickard Osser <ricky@osser.se> */
2874 .name = "AVerMedia A169 B1",
2875 .audio_clock = 0x02187de7,
2876 .tuner_type = TUNER_LG_TALN,
2877 .radio_type = UNSET,
2878 .tuner_addr = ADDR_UNSET,
2879 .radio_addr = ADDR_UNSET,
2880 .tda9887_conf = TDA9887_PRESENT,
2881 .gpiomask = 0xca60000,
2882 .inputs = {{
2883 .name = name_tv,
2884 .vmux = 4,
2885 .amux = TV,
2886 .tv = 1,
2887 .gpio = 0x04a61000,
2888 },{
2889 .name = name_comp2, /* Composite SVIDEO (B/W if signal is carried with SVIDEO) */
2890 .vmux = 1,
2891 .amux = LINE2,
2892 },{
2893 .name = name_svideo,
2894 .vmux = 9, /* 9 is correct as S-VIDEO1 according to a169.inf! */
2895 .amux = LINE1,
2896 }},
2897 },
Michael Krufkyba3a5a82006-03-14 19:02:12 -03002898 [SAA7134_BOARD_MD7134_BRIDGE_2] = {
2899 /* This card has two saa7134 chips on it,
2900 but only one of them is currently working.
2901 The programming for the primary decoder is
2902 in SAA7134_BOARD_MD7134 */
2903 .name = "Medion 7134 Bridge #2",
2904 .audio_clock = 0x00187de7,
2905 .radio_type = UNSET,
2906 .tuner_addr = ADDR_UNSET,
2907 .radio_addr = ADDR_UNSET,
2908 },
Hartmut Hackmannd95b8942006-03-27 19:39:30 -03002909 [SAA7134_BOARD_FLYDVBT_HYBRID_CARDBUS] = {
Mauro Carvalho Chehab593f18c2007-10-07 02:17:09 -03002910 .name = "LifeView FlyDVB-T Hybrid Cardbus/MSI TV @nywhere A/D NB",
Hartmut Hackmannd95b8942006-03-27 19:39:30 -03002911 .audio_clock = 0x00200000,
2912 .tuner_type = TUNER_PHILIPS_TDA8290,
2913 .radio_type = UNSET,
2914 .tuner_addr = ADDR_UNSET,
2915 .radio_addr = ADDR_UNSET,
2916 .mpeg = SAA7134_MPEG_DVB,
2917 .gpiomask = 0x00600000, /* Bit 21 0=Radio, Bit 22 0=TV */
2918 .inputs = {{
2919 .name = name_tv,
2920 .vmux = 1,
2921 .amux = TV,
2922 .gpio = 0x200000, /* GPIO21=High for TV input */
2923 .tv = 1,
2924 },{
2925 .name = name_svideo, /* S-Video signal on S-Video input */
2926 .vmux = 8,
2927 .amux = LINE2,
2928 },{
2929 .name = name_comp1, /* Composite signal on S-Video input */
2930 .vmux = 0,
2931 .amux = LINE2,
2932 },{
2933 .name = name_comp2, /* Composite input */
2934 .vmux = 3,
2935 .amux = LINE2,
2936 }},
2937 .radio = {
2938 .name = name_radio,
2939 .amux = TV,
2940 .gpio = 0x000000, /* GPIO21=Low for FM radio antenna */
2941 },
2942 },
Zac Bowlingf49ba8d2006-06-19 19:49:20 -03002943 [SAA7134_BOARD_FLYVIDEO3000_NTSC] = {
2944 /* "Zac Bowling" <zac@zacbowling.com> */
2945 .name = "LifeView FlyVIDEO3000 (NTSC)",
2946 .audio_clock = 0x00200000,
2947 .tuner_type = TUNER_PHILIPS_NTSC,
2948 .radio_type = UNSET,
2949 .tuner_addr = ADDR_UNSET,
2950 .radio_addr = ADDR_UNSET,
2951
2952 .gpiomask = 0xe000,
2953 .inputs = {{
2954 .name = name_tv,
2955 .vmux = 1,
2956 .amux = TV,
2957 .gpio = 0x8000,
2958 .tv = 1,
2959 },{
2960 .name = name_tv_mono,
2961 .vmux = 1,
2962 .amux = LINE2,
2963 .gpio = 0x0000,
2964 .tv = 1,
2965 },{
2966 .name = name_comp1,
2967 .vmux = 0,
2968 .amux = LINE2,
2969 .gpio = 0x4000,
2970 },{
2971 .name = name_comp2,
2972 .vmux = 3,
2973 .amux = LINE2,
2974 .gpio = 0x4000,
2975 },{
2976 .name = name_svideo,
2977 .vmux = 8,
2978 .amux = LINE2,
2979 .gpio = 0x4000,
2980 }},
2981 .radio = {
2982 .name = name_radio,
2983 .amux = LINE2,
2984 .gpio = 0x2000,
2985 },
2986 .mute = {
2987 .name = name_mute,
2988 .amux = TV,
2989 .gpio = 0x8000,
2990 },
2991 },
Hartmut Hackmann5eda2272006-08-07 14:03:32 -03002992 [SAA7134_BOARD_MEDION_MD8800_QUADRO] = {
2993 .name = "Medion Md8800 Quadro",
2994 .audio_clock = 0x00187de7,
2995 .tuner_type = TUNER_PHILIPS_TDA8290,
2996 .radio_type = UNSET,
2997 .tuner_addr = ADDR_UNSET,
2998 .radio_addr = ADDR_UNSET,
2999 .mpeg = SAA7134_MPEG_DVB,
3000 .inputs = {{
3001 .name = name_tv,
3002 .vmux = 1,
3003 .amux = TV,
3004 .tv = 1,
3005 },{
3006 .name = name_comp1,
3007 .vmux = 0,
hermann pitton387a2992007-10-25 21:26:53 -03003008 .amux = LINE1,
Hartmut Hackmann5eda2272006-08-07 14:03:32 -03003009 },{
3010 .name = name_svideo,
3011 .vmux = 8,
hermann pitton387a2992007-10-25 21:26:53 -03003012 .amux = LINE1,
Hartmut Hackmann5eda2272006-08-07 14:03:32 -03003013 }},
3014 },
Igor M. Liplianine2ac28f2006-08-08 09:10:10 -03003015 [SAA7134_BOARD_FLYDVBS_LR300] = {
3016 /* LifeView FlyDVB-s */
3017 /* Igor M. Liplianin <liplianin@tut.by> */
3018 .name = "LifeView FlyDVB-S /Acorp TV134DS",
3019 .audio_clock = 0x00200000,
3020 .tuner_type = TUNER_ABSENT,
3021 .radio_type = UNSET,
3022 .tuner_addr = ADDR_UNSET,
3023 .radio_addr = ADDR_UNSET,
3024 .mpeg = SAA7134_MPEG_DVB,
3025 .inputs = {{
3026 .name = name_comp1, /* Composite input */
3027 .vmux = 3,
3028 .amux = LINE1,
3029 },{
3030 .name = name_svideo, /* S-Video signal on S-Video input */
3031 .vmux = 8,
3032 .amux = LINE1,
3033 }},
3034 },
Michal Majchrowiczb04c1ba2006-09-13 16:42:42 -03003035 [SAA7134_BOARD_PROTEUS_2309] = {
3036 .name = "Proteus Pro 2309",
3037 .audio_clock = 0x00187de7,
3038 .tuner_type = TUNER_PHILIPS_FM1216ME_MK3,
3039 .radio_type = UNSET,
3040 .tuner_addr = ADDR_UNSET,
3041 .radio_addr = ADDR_UNSET,
3042 .tda9887_conf = TDA9887_PRESENT,
3043 .inputs = {{
3044 .name = name_tv,
3045 .vmux = 1,
3046 .amux = LINE2,
3047 .tv = 1,
3048 },{
3049 .name = name_comp1,
3050 .vmux = 0,
3051 .amux = LINE2,
3052 },{
3053 .name = name_comp2,
3054 .vmux = 3,
3055 .amux = LINE2,
3056 },{
3057 .name = name_svideo,
3058 .vmux = 8,
3059 .amux = LINE2,
3060 }},
3061 .mute = {
3062 .name = name_mute,
3063 .amux = LINE1,
3064 },
3065 },
Petr Baudis515c2082006-09-26 16:53:53 -03003066 [SAA7134_BOARD_AVERMEDIA_A16AR] = {
3067 /* Petr Baudis <pasky@ucw.cz> */
3068 .name = "AVerMedia TV Hybrid A16AR",
3069 .audio_clock = 0x187de7,
pasky@ucw.cz0871a882006-11-12 14:24:57 -03003070 .tuner_type = TUNER_PHILIPS_TD1316, /* untested */
Petr Baudis515c2082006-09-26 16:53:53 -03003071 .radio_type = TUNER_TEA5767, /* untested */
3072 .tuner_addr = ADDR_UNSET,
3073 .radio_addr = ADDR_UNSET,
3074 .tda9887_conf = TDA9887_PRESENT,
3075 .mpeg = SAA7134_MPEG_DVB,
3076 .inputs = {{
3077 .name = name_tv,
3078 .vmux = 1,
3079 .amux = TV,
3080 .tv = 1,
3081 },{
3082 .name = name_comp1,
3083 .vmux = 3,
3084 .amux = LINE2,
3085 },{
3086 .name = name_svideo,
3087 .vmux = 8,
3088 .amux = LINE1,
3089 }},
3090 .radio = {
3091 .name = name_radio,
3092 .amux = LINE1,
3093 },
3094 },
Hartmut Hackmanncf146ca2006-10-02 20:49:24 -03003095 [SAA7134_BOARD_ASUS_EUROPA2_HYBRID] = {
3096 .name = "Asus Europa2 OEM",
3097 .audio_clock = 0x00187de7,
3098 .tuner_type = TUNER_PHILIPS_FMD1216ME_MK3,
3099 .radio_type = UNSET,
3100 .tuner_addr = ADDR_UNSET,
3101 .radio_addr = ADDR_UNSET,
3102 .tda9887_conf = TDA9887_PRESENT| TDA9887_PORT1_ACTIVE | TDA9887_PORT2_ACTIVE,
3103 .mpeg = SAA7134_MPEG_DVB,
3104 .inputs = {{
3105 .name = name_tv,
3106 .vmux = 3,
3107 .amux = TV,
3108 .tv = 1,
3109 },{
3110 .name = name_comp1,
3111 .vmux = 4,
3112 .amux = LINE2,
3113 },{
3114 .name = name_svideo,
3115 .vmux = 8,
3116 .amux = LINE2,
3117 }},
3118 .radio = {
3119 .name = name_radio,
3120 .amux = LINE1,
3121 },
3122 },
Hartmut Hackmann587d2fd2006-10-06 19:13:50 -03003123 [SAA7134_BOARD_PINNACLE_PCTV_310i] = {
3124 .name = "Pinnacle PCTV 310i",
3125 .audio_clock = 0x00187de7,
3126 .tuner_type = TUNER_PHILIPS_TDA8290,
3127 .radio_type = UNSET,
3128 .tuner_addr = ADDR_UNSET,
3129 .radio_addr = ADDR_UNSET,
Hartmut Hackmann58ef4f92007-04-27 12:31:12 -03003130 .tuner_config = 1,
Hartmut Hackmann587d2fd2006-10-06 19:13:50 -03003131 .mpeg = SAA7134_MPEG_DVB,
3132 .gpiomask = 0x000200000,
3133 .inputs = {{
3134 .name = name_tv,
3135 .vmux = 4,
3136 .amux = TV,
3137 .tv = 1,
3138 },{
3139 .name = name_comp1,
3140 .vmux = 1,
3141 .amux = LINE2,
3142 },{
3143 .name = name_comp2,
3144 .vmux = 0,
3145 .amux = LINE2,
3146 },{
3147 .name = name_svideo,
3148 .vmux = 8,
3149 .amux = LINE2,
3150 }},
3151 .radio = {
3152 .name = name_radio,
3153 .amux = TV,
3154 .gpio = 0x0200000,
3155 },
3156 },
Mikhail Fedotov3ac706d2006-10-06 20:23:47 -03003157 [SAA7134_BOARD_AVERMEDIA_STUDIO_507] = {
3158 /* Mikhail Fedotov <mo_fedotov@mail.ru> */
3159 .name = "Avermedia AVerTV Studio 507",
3160 .audio_clock = 0x00187de7,
3161 .tuner_type = TUNER_PHILIPS_FM1256_IH3,
3162 .radio_type = UNSET,
3163 .tuner_addr = ADDR_UNSET,
3164 .radio_addr = ADDR_UNSET,
3165 .tda9887_conf = TDA9887_PRESENT,
3166 .gpiomask = 0x03,
3167 .inputs = {{
3168 .name = name_tv,
3169 .vmux = 1,
3170 .amux = TV,
3171 .tv = 1,
3172 .gpio = 0x00,
3173 },{
3174 .name = name_comp1,
3175 .vmux = 0,
3176 .amux = LINE2,
3177 .gpio = 0x00,
3178 },{
3179 .name = name_comp2,
3180 .vmux = 3,
3181 .amux = LINE2,
3182 .gpio = 0x00,
3183 },{
3184 .name = name_svideo,
3185 .vmux = 8,
3186 .amux = LINE2,
3187 .gpio = 0x00,
3188 }},
3189 .radio = {
3190 .name = name_radio,
3191 .amux = LINE2,
3192 .gpio = 0x01,
3193 },
3194 .mute = {
3195 .name = name_mute,
3196 .amux = LINE1,
3197 .gpio = 0x00,
3198 },
3199 },
Hartmut Hackmanncbb94522006-10-30 20:00:16 -03003200 [SAA7134_BOARD_VIDEOMATE_DVBT_200A] = {
3201 /* Francis Barber <fedora@barber-family.id.au> */
3202 .name = "Compro Videomate DVB-T200A",
3203 .audio_clock = 0x00187de7,
3204 .tuner_type = TUNER_ABSENT,
3205 .radio_type = UNSET,
3206 .tuner_addr = ADDR_UNSET,
3207 .radio_addr = ADDR_UNSET,
3208 .tda9887_conf = TDA9887_PRESENT | TDA9887_PORT1_ACTIVE,
3209 .mpeg = SAA7134_MPEG_DVB,
3210 .inputs = {{
3211 .name = name_tv,
3212 .vmux = 3,
3213 .amux = TV,
3214 .tv = 1,
3215 },{
3216 .name = name_comp1,
3217 .vmux = 1,
3218 .amux = LINE2,
3219 },{
3220 .name = name_svideo,
3221 .vmux = 8,
3222 .amux = LINE2,
3223 }},
3224 },
Thomas Gentyc6e53da2006-11-05 14:17:30 -03003225 [SAA7134_BOARD_HAUPPAUGE_HVR1110] = {
3226 /* Thomas Genty <tomlohave@gmail.com> */
3227 .name = "Hauppauge WinTV-HVR1110 DVB-T/Hybrid",
3228 .audio_clock = 0x00187de7,
3229 .tuner_type = TUNER_PHILIPS_TDA8290,
3230 .radio_type = UNSET,
3231 .tuner_addr = ADDR_UNSET,
3232 .radio_addr = ADDR_UNSET,
Michael Krufkyb3aa2262007-12-09 21:13:38 -03003233 .tuner_config = 1,
Thomas Gentyc6e53da2006-11-05 14:17:30 -03003234 .mpeg = SAA7134_MPEG_DVB,
Thomas Gentyc6e53da2006-11-05 14:17:30 -03003235 .inputs = {{
3236 .name = name_tv,
3237 .vmux = 1,
3238 .amux = TV,
3239 .tv = 1,
Thomas Genty177aaaf2006-11-29 21:57:24 -03003240 },{
3241 .name = name_comp1,
3242 .vmux = 3,
3243 .amux = LINE2, /* FIXME: audio doesn't work on svideo/composite */
3244 },{
3245 .name = name_svideo,
3246 .vmux = 8,
3247 .amux = LINE2, /* FIXME: audio doesn't work on svideo/composite */
Thomas Gentyc6e53da2006-11-05 14:17:30 -03003248 }},
3249 .radio = {
3250 .name = name_radio,
3251 .amux = TV,
Thomas Gentyc6e53da2006-11-05 14:17:30 -03003252 },
3253 },
Hartmut Hackmann550a9a52006-11-15 21:31:54 -03003254 [SAA7134_BOARD_CINERGY_HT_PCMCIA] = {
3255 .name = "Terratec Cinergy HT PCMCIA",
3256 .audio_clock = 0x00187de7,
3257 .tuner_type = TUNER_PHILIPS_TDA8290,
3258 .radio_type = UNSET,
3259 .tuner_addr = ADDR_UNSET,
3260 .radio_addr = ADDR_UNSET,
3261 .mpeg = SAA7134_MPEG_DVB,
3262 .inputs = {{
3263 .name = name_tv,
3264 .vmux = 1,
3265 .amux = TV,
3266 .tv = 1,
3267 },{
3268 .name = name_comp1,
3269 .vmux = 0,
3270 .amux = LINE1,
3271 },{
3272 .name = name_svideo,
3273 .vmux = 6,
3274 .amux = LINE1,
3275 }},
3276 },
Steven Walterd1158f42006-12-20 09:29:09 -03003277 [SAA7134_BOARD_ENCORE_ENLTV] = {
Juan Pablo Sormanic36c4592006-12-27 12:46:36 -03003278 /* Steven Walter <stevenrwalter@gmail.com>
3279 Juan Pablo Sormani <sorman@gmail.com> */
Steven Walterd1158f42006-12-20 09:29:09 -03003280 .name = "Encore ENLTV",
Juan Pablo Sormanic36c4592006-12-27 12:46:36 -03003281 .audio_clock = 0x00200000,
Steven Walterd1158f42006-12-20 09:29:09 -03003282 .tuner_type = TUNER_TNF_5335MF,
3283 .radio_type = UNSET,
3284 .tuner_addr = ADDR_UNSET,
3285 .radio_addr = ADDR_UNSET,
3286 .inputs = {{
3287 .name = name_tv,
3288 .vmux = 1,
Juan Pablo Sormanic36c4592006-12-27 12:46:36 -03003289 .amux = 3,
Steven Walterd1158f42006-12-20 09:29:09 -03003290 .tv = 1,
3291 },{
Juan Pablo Sormanic36c4592006-12-27 12:46:36 -03003292 .name = name_tv_mono,
3293 .vmux = 7,
3294 .amux = 4,
3295 .tv = 1,
3296 },{
3297 .name = name_comp1,
3298 .vmux = 3,
3299 .amux = 2,
3300 },{
Steven Walterd1158f42006-12-20 09:29:09 -03003301 .name = name_svideo,
Juan Pablo Sormanic36c4592006-12-27 12:46:36 -03003302 .vmux = 0,
3303 .amux = 2,
Steven Walterd1158f42006-12-20 09:29:09 -03003304 }},
Juan Pablo Sormanic36c4592006-12-27 12:46:36 -03003305 .radio = {
3306 .name = name_radio,
3307 .amux = LINE2,
3308/* .gpio = 0x00300001,*/
3309 .gpio = 0x20000,
3310
3311 },
3312 .mute = {
3313 .name = name_mute,
3314 .amux = 0,
3315 },
3316 },
3317 [SAA7134_BOARD_ENCORE_ENLTV_FM] = {
3318 /* Juan Pablo Sormani <sorman@gmail.com> */
3319 .name = "Encore ENLTV-FM",
3320 .audio_clock = 0x00200000,
3321 .tuner_type = TUNER_PHILIPS_ATSC,
3322 .radio_type = UNSET,
3323 .tuner_addr = ADDR_UNSET,
3324 .radio_addr = ADDR_UNSET,
3325 .inputs = {{
3326 .name = name_tv,
3327 .vmux = 1,
3328 .amux = 3,
3329 .tv = 1,
3330 },{
3331 .name = name_tv_mono,
3332 .vmux = 7,
3333 .amux = 4,
3334 .tv = 1,
3335 },{
3336 .name = name_comp1,
3337 .vmux = 3,
3338 .amux = 2,
3339 },{
3340 .name = name_svideo,
3341 .vmux = 0,
3342 .amux = 2,
3343 }},
3344 .radio = {
3345 .name = name_radio,
3346 .amux = LINE2,
3347 .gpio = 0x20000,
3348
3349 },
3350 .mute = {
3351 .name = name_mute,
3352 .amux = 0,
3353 },
Steven Walterd1158f42006-12-20 09:29:09 -03003354 },
Michael Krufky9de271e2007-01-16 18:36:40 -03003355 [SAA7134_BOARD_CINERGY_HT_PCI] = {
3356 .name = "Terratec Cinergy HT PCI",
3357 .audio_clock = 0x00187de7,
3358 .tuner_type = TUNER_PHILIPS_TDA8290,
3359 .radio_type = UNSET,
3360 .tuner_addr = ADDR_UNSET,
3361 .radio_addr = ADDR_UNSET,
3362 .mpeg = SAA7134_MPEG_DVB,
3363 .inputs = {{
3364 .name = name_tv,
3365 .vmux = 1,
3366 .amux = TV,
3367 .tv = 1,
3368 },{
3369 .name = name_comp1,
3370 .vmux = 0,
3371 .amux = LINE1,
3372 },{
3373 .name = name_svideo,
3374 .vmux = 6,
3375 .amux = LINE1,
3376 }},
3377 },
Hartmut Hackmann58ef4f92007-04-27 12:31:12 -03003378 [SAA7134_BOARD_PHILIPS_TIGER_S] = {
3379 .name = "Philips Tiger - S Reference design",
3380 .audio_clock = 0x00187de7,
3381 .tuner_type = TUNER_PHILIPS_TDA8290,
3382 .radio_type = UNSET,
3383 .tuner_addr = ADDR_UNSET,
3384 .radio_addr = ADDR_UNSET,
3385 .tuner_config = 2,
3386 .mpeg = SAA7134_MPEG_DVB,
3387 .gpiomask = 0x0200000,
3388 .inputs = {{
3389 .name = name_tv,
3390 .vmux = 1,
3391 .amux = TV,
3392 .tv = 1,
3393 },{
3394 .name = name_comp1,
3395 .vmux = 3,
3396 .amux = LINE1,
3397 },{
3398 .name = name_svideo,
3399 .vmux = 8,
3400 .amux = LINE1,
3401 }},
3402 .radio = {
3403 .name = name_radio,
3404 .amux = TV,
3405 .gpio = 0x0200000,
3406 },
3407 },
Markus Rechbergere95d3172007-04-27 12:31:19 -03003408 [SAA7134_BOARD_AVERMEDIA_M102] = {
3409 .name = "Avermedia M102",
3410 .audio_clock = 0x00187de7,
3411 .tuner_type = TUNER_PHILIPS_TDA8290,
3412 .radio_type = UNSET,
3413 .tuner_addr = ADDR_UNSET,
3414 .radio_addr = ADDR_UNSET,
3415 .gpiomask = 1<<21,
3416 .inputs = {{
3417 .name = name_tv,
3418 .vmux = 1,
3419 .amux = TV,
3420 .tv = 1,
3421 },{
3422 .name = name_comp1,
3423 .vmux = 0,
3424 .amux = LINE2,
3425 },{
3426 .name = name_svideo,
3427 .vmux = 6,
3428 .amux = LINE2,
3429 }},
3430 },
Hartmut Hackmanne06cea42007-03-13 20:58:29 -03003431 [SAA7134_BOARD_ASUS_P7131_4871] = {
3432 .name = "ASUS P7131 4871",
3433 .audio_clock = 0x00187de7,
3434 .tuner_type = TUNER_PHILIPS_TDA8290,
3435 .radio_type = UNSET,
3436 .tuner_addr = ADDR_UNSET,
3437 .radio_addr = ADDR_UNSET,
3438 .tuner_config = 2,
3439 .mpeg = SAA7134_MPEG_DVB,
3440 .gpiomask = 0x0200000,
3441 .inputs = {{
3442 .name = name_tv,
3443 .vmux = 1,
3444 .amux = TV,
3445 .tv = 1,
3446 .gpio = 0x0200000,
3447 }},
3448 },
Hartmut Hackmannf3eec0c02007-03-14 20:33:55 -03003449 [SAA7134_BOARD_ASUSTeK_P7131_HYBRID_LNA] = {
3450 .name = "ASUSTeK P7131 Hybrid",
Hartmut Hackmanne06cea42007-03-13 20:58:29 -03003451 .audio_clock = 0x00187de7,
3452 .tuner_type = TUNER_PHILIPS_TDA8290,
3453 .radio_type = UNSET,
3454 .tuner_addr = ADDR_UNSET,
3455 .radio_addr = ADDR_UNSET,
3456 .tuner_config = 2,
3457 .gpiomask = 1 << 21,
3458 .mpeg = SAA7134_MPEG_DVB,
3459 .inputs = {{
3460 .name = name_tv,
3461 .vmux = 1,
3462 .amux = TV,
3463 .tv = 1,
3464 .gpio = 0x0000000,
3465 },{
3466 .name = name_comp1,
3467 .vmux = 3,
3468 .amux = LINE2,
3469 .gpio = 0x0200000,
3470 },{
3471 .name = name_comp2,
3472 .vmux = 0,
3473 .amux = LINE2,
3474 .gpio = 0x0200000,
3475 },{
3476 .name = name_svideo,
3477 .vmux = 8,
3478 .amux = LINE2,
3479 .gpio = 0x0200000,
3480 }},
3481 .radio = {
3482 .name = name_radio,
3483 .amux = TV,
3484 .gpio = 0x0200000,
3485 },
3486 },
James T Klaas53958b32007-05-01 10:48:09 -03003487 [SAA7134_BOARD_SABRENT_TV_PCB05] = {
3488 .name = "Sabrent PCMCIA TV-PCB05",
3489 .audio_clock = 0x00187de7,
3490 .tuner_type = TUNER_PHILIPS_TDA8290,
3491 .radio_type = UNSET,
3492 .tuner_addr = ADDR_UNSET,
3493 .radio_addr = ADDR_UNSET,
3494 .inputs = {{
3495 .name = name_tv,
3496 .vmux = 1,
3497 .amux = TV,
3498 .tv = 1,
3499 },{
3500 .name = name_comp1,
3501 .vmux = 3,
3502 .amux = LINE1,
3503 },{
3504 .name = name_comp2,
3505 .vmux = 0,
3506 .amux = LINE1,
3507 },{
3508 .name = name_svideo,
3509 .vmux = 8,
3510 .amux = LINE1,
3511 }},
3512 .mute = {
3513 .name = name_mute,
3514 .amux = TV,
3515 },
3516 },
Tony Wanaaccb822007-05-10 12:16:47 -03003517 [SAA7134_BOARD_10MOONSTVMASTER3] = {
3518 /* Tony Wan <aloha_cn@hotmail.com> */
3519 .name = "10MOONS TM300 TV Card",
3520 .audio_clock = 0x00200000,
3521 .tuner_type = TUNER_LG_PAL_NEW_TAPC,
3522 .radio_type = UNSET,
3523 .tuner_addr = ADDR_UNSET,
3524 .radio_addr = ADDR_UNSET,
3525 .gpiomask = 0x7000,
3526 .inputs = {{
3527 .name = name_tv,
3528 .vmux = 1,
3529 .amux = LINE2,
3530 .gpio = 0x0000,
3531 .tv = 1,
3532 },{
3533 .name = name_comp1,
3534 .vmux = 3,
3535 .amux = LINE1,
3536 .gpio = 0x2000,
3537 },{
3538 .name = name_svideo,
3539 .vmux = 8,
3540 .amux = LINE1,
3541 .gpio = 0x2000,
3542 }},
3543 .mute = {
3544 .name = name_mute,
3545 .amux = LINE2,
3546 .gpio = 0x3000,
3547 },
3548 },
Edgar Simod90d9f52007-08-20 14:14:50 -03003549 [SAA7134_BOARD_AVERMEDIA_SUPER_007] = {
3550 .name = "Avermedia Super 007",
3551 .audio_clock = 0x00187de7,
3552 .tuner_type = TUNER_PHILIPS_TDA8290,
3553 .radio_type = UNSET,
3554 .tuner_addr = ADDR_UNSET,
3555 .radio_addr = ADDR_UNSET,
3556 .tuner_config = 0,
3557 .mpeg = SAA7134_MPEG_DVB,
3558 .inputs = {{
3559 .name = name_tv, /* FIXME: analog tv untested */
3560 .vmux = 1,
3561 .amux = TV,
3562 .tv = 1,
3563 }},
3564 },
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07003565};
3566
Linus Torvalds1da177e2005-04-16 15:20:36 -07003567const unsigned int saa7134_bcount = ARRAY_SIZE(saa7134_boards);
3568
3569/* ------------------------------------------------------------------ */
3570/* PCI ids + subsystem IDs */
3571
3572struct pci_device_id saa7134_pci_tbl[] = {
3573 {
3574 .vendor = PCI_VENDOR_ID_PHILIPS,
3575 .device = PCI_DEVICE_ID_PHILIPS_SAA7134,
3576 .subvendor = PCI_VENDOR_ID_PHILIPS,
3577 .subdevice = 0x2001,
3578 .driver_data = SAA7134_BOARD_PROTEUS_PRO,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07003579 },{
Linus Torvalds1da177e2005-04-16 15:20:36 -07003580 .vendor = PCI_VENDOR_ID_PHILIPS,
3581 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
3582 .subvendor = PCI_VENDOR_ID_PHILIPS,
3583 .subdevice = 0x2001,
3584 .driver_data = SAA7134_BOARD_PROTEUS_PRO,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07003585 },{
Linus Torvalds1da177e2005-04-16 15:20:36 -07003586 .vendor = PCI_VENDOR_ID_PHILIPS,
3587 .device = PCI_DEVICE_ID_PHILIPS_SAA7134,
3588 .subvendor = PCI_VENDOR_ID_PHILIPS,
3589 .subdevice = 0x6752,
3590 .driver_data = SAA7134_BOARD_EMPRESS,
3591 },{
3592 .vendor = PCI_VENDOR_ID_PHILIPS,
3593 .device = PCI_DEVICE_ID_PHILIPS_SAA7134,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07003594 .subvendor = 0x1131,
3595 .subdevice = 0x4e85,
Linus Torvalds1da177e2005-04-16 15:20:36 -07003596 .driver_data = SAA7134_BOARD_MONSTERTV,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07003597 },{
3598 .vendor = PCI_VENDOR_ID_PHILIPS,
3599 .device = PCI_DEVICE_ID_PHILIPS_SAA7134,
Michael Krufky7df64e82005-11-08 21:36:16 -08003600 .subvendor = 0x153b,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07003601 .subdevice = 0x1142,
3602 .driver_data = SAA7134_BOARD_CINERGY400,
3603 },{
3604 .vendor = PCI_VENDOR_ID_PHILIPS,
3605 .device = PCI_DEVICE_ID_PHILIPS_SAA7134,
Michael Krufky7df64e82005-11-08 21:36:16 -08003606 .subvendor = 0x153b,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07003607 .subdevice = 0x1143,
3608 .driver_data = SAA7134_BOARD_CINERGY600,
3609 },{
3610 .vendor = PCI_VENDOR_ID_PHILIPS,
3611 .device = PCI_DEVICE_ID_PHILIPS_SAA7134,
Michael Krufky7df64e82005-11-08 21:36:16 -08003612 .subvendor = 0x153b,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07003613 .subdevice = 0x1158,
3614 .driver_data = SAA7134_BOARD_CINERGY600_MK3,
3615 },{
Linus Torvalds1da177e2005-04-16 15:20:36 -07003616 .vendor = PCI_VENDOR_ID_PHILIPS,
3617 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
3618 .subvendor = 0x153b,
3619 .subdevice = 0x1162,
3620 .driver_data = SAA7134_BOARD_CINERGY400_CARDBUS,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07003621 },{
Linus Torvalds1da177e2005-04-16 15:20:36 -07003622 .vendor = PCI_VENDOR_ID_PHILIPS,
3623 .device = PCI_DEVICE_ID_PHILIPS_SAA7134,
Zac Bowlingf49ba8d2006-06-19 19:49:20 -03003624 .subvendor = 0x5169,
3625 .subdevice = 0x0138,
3626 .driver_data = SAA7134_BOARD_FLYVIDEO3000_NTSC,
3627 },{
3628 .vendor = PCI_VENDOR_ID_PHILIPS,
3629 .device = PCI_DEVICE_ID_PHILIPS_SAA7134,
Linus Torvalds1da177e2005-04-16 15:20:36 -07003630 .subvendor = 0x5168,
3631 .subdevice = 0x0138,
3632 .driver_data = SAA7134_BOARD_FLYVIDEO3000,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07003633 },{
Linus Torvalds1da177e2005-04-16 15:20:36 -07003634 .vendor = PCI_VENDOR_ID_PHILIPS,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07003635 .device = PCI_DEVICE_ID_PHILIPS_SAA7134,
3636 .subvendor = 0x4e42, /* "Typhoon PCI Capture TV Card" Art.No. 50673 */
3637 .subdevice = 0x0138,
3638 .driver_data = SAA7134_BOARD_FLYVIDEO3000,
3639 },{
Linus Torvalds1da177e2005-04-16 15:20:36 -07003640 .vendor = PCI_VENDOR_ID_PHILIPS,
3641 .device = PCI_DEVICE_ID_PHILIPS_SAA7130,
3642 .subvendor = 0x5168,
3643 .subdevice = 0x0138,
3644 .driver_data = SAA7134_BOARD_FLYVIDEO2000,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07003645 },{
Linus Torvalds1da177e2005-04-16 15:20:36 -07003646 .vendor = PCI_VENDOR_ID_PHILIPS,
Peter Missel10b7a902006-01-23 17:11:06 -02003647 .device = PCI_DEVICE_ID_PHILIPS_SAA7130,
3648 .subvendor = 0x4e42, /* Typhoon */
3649 .subdevice = 0x0138, /* LifeView FlyTV Prime30 OEM */
3650 .driver_data = SAA7134_BOARD_FLYVIDEO2000,
3651 },{
3652 .vendor = PCI_VENDOR_ID_PHILIPS,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07003653 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
Linus Torvalds1da177e2005-04-16 15:20:36 -07003654 .subvendor = 0x5168,
3655 .subdevice = 0x0212, /* minipci, LR212 */
3656 .driver_data = SAA7134_BOARD_FLYTVPLATINUM_MINI,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07003657 },{
Linus Torvalds1da177e2005-04-16 15:20:36 -07003658 .vendor = PCI_VENDOR_ID_PHILIPS,
3659 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
Mauro Carvalho Chehab058afaf2005-11-08 21:36:49 -08003660 .subvendor = 0x14c0,
3661 .subdevice = 0x1212, /* minipci, LR1212 */
3662 .driver_data = SAA7134_BOARD_FLYTVPLATINUM_MINI2,
3663 },{
3664 .vendor = PCI_VENDOR_ID_PHILIPS,
3665 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
Glen Gray2d14f782005-11-08 21:36:12 -08003666 .subvendor = 0x4e42,
3667 .subdevice = 0x0212, /* OEM minipci, LR212 */
3668 .driver_data = SAA7134_BOARD_FLYTVPLATINUM_MINI,
3669 },{
3670 .vendor = PCI_VENDOR_ID_PHILIPS,
3671 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
Peter Missel10e92062005-05-01 08:59:21 -07003672 .subvendor = 0x5168, /* Animation Technologies (LifeView) */
Simon Farnsworthb39423a2007-05-01 10:01:20 -03003673 .subdevice = 0x0214, /* Standard PCI, LR214 Rev E and earlier (SAA7135) */
3674 .driver_data = SAA7134_BOARD_FLYTVPLATINUM_FM,
3675 },{
3676 .vendor = PCI_VENDOR_ID_PHILIPS,
3677 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
3678 .subvendor = 0x5168, /* Animation Technologies (LifeView) */
3679 .subdevice = 0x5214, /* Standard PCI, LR214 Rev F onwards (SAA7131) */
Linus Torvalds1da177e2005-04-16 15:20:36 -07003680 .driver_data = SAA7134_BOARD_FLYTVPLATINUM_FM,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07003681 },{
Linus Torvalds1da177e2005-04-16 15:20:36 -07003682 .vendor = PCI_VENDOR_ID_PHILIPS,
Peter Missel10e92062005-05-01 08:59:21 -07003683 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
3684 .subvendor = 0x1489, /* KYE */
3685 .subdevice = 0x0214, /* Genius VideoWonder ProTV */
3686 .driver_data = SAA7134_BOARD_FLYTVPLATINUM_FM, /* is an LR214WF actually */
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07003687 },{
Peter Missel10e92062005-05-01 08:59:21 -07003688 .vendor = PCI_VENDOR_ID_PHILIPS,
Linus Torvalds1da177e2005-04-16 15:20:36 -07003689 .device = PCI_DEVICE_ID_PHILIPS_SAA7134,
3690 .subvendor = 0x16be,
3691 .subdevice = 0x0003,
3692 .driver_data = SAA7134_BOARD_MD7134,
3693 },{
3694 .vendor = PCI_VENDOR_ID_PHILIPS,
3695 .device = PCI_DEVICE_ID_PHILIPS_SAA7130,
3696 .subvendor = 0x1048,
3697 .subdevice = 0x226b,
3698 .driver_data = SAA7134_BOARD_ELSA,
3699 },{
3700 .vendor = PCI_VENDOR_ID_PHILIPS,
3701 .device = PCI_DEVICE_ID_PHILIPS_SAA7130,
3702 .subvendor = 0x1048,
Michael Krufky9a7871b2006-02-27 15:22:49 -03003703 .subdevice = 0x226a,
Linus Torvalds1da177e2005-04-16 15:20:36 -07003704 .driver_data = SAA7134_BOARD_ELSA_500TV,
3705 },{
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07003706 .vendor = PCI_VENDOR_ID_PHILIPS,
Tamuki Shoichid0456d12006-02-27 00:08:04 -03003707 .device = PCI_DEVICE_ID_PHILIPS_SAA7130,
Michael Krufkyba524292006-02-27 14:38:17 -03003708 .subvendor = 0x1048,
3709 .subdevice = 0x226c,
Tamuki Shoichid0456d12006-02-27 00:08:04 -03003710 .driver_data = SAA7134_BOARD_ELSA_700TV,
3711 },{
3712 .vendor = PCI_VENDOR_ID_PHILIPS,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07003713 .device = PCI_DEVICE_ID_PHILIPS_SAA7134,
3714 .subvendor = PCI_VENDOR_ID_ASUSTEK,
3715 .subdevice = 0x4842,
3716 .driver_data = SAA7134_BOARD_ASUSTeK_TVFM7134,
Linus Torvalds1da177e2005-04-16 15:20:36 -07003717 },{
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07003718 .vendor = PCI_VENDOR_ID_PHILIPS,
3719 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
3720 .subvendor = PCI_VENDOR_ID_ASUSTEK,
3721 .subdevice = 0x4845,
3722 .driver_data = SAA7134_BOARD_ASUSTeK_TVFM7135,
Linus Torvalds1da177e2005-04-16 15:20:36 -07003723 },{
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07003724 .vendor = PCI_VENDOR_ID_PHILIPS,
3725 .device = PCI_DEVICE_ID_PHILIPS_SAA7134,
3726 .subvendor = PCI_VENDOR_ID_ASUSTEK,
3727 .subdevice = 0x4830,
3728 .driver_data = SAA7134_BOARD_ASUSTeK_TVFM7134,
Linus Torvalds1da177e2005-04-16 15:20:36 -07003729 },{
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07003730 .vendor = PCI_VENDOR_ID_PHILIPS,
3731 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
3732 .subvendor = PCI_VENDOR_ID_ASUSTEK,
3733 .subdevice = 0x4843,
3734 .driver_data = SAA7134_BOARD_ASUSTEK_TVFM7133,
3735 },{
3736 .vendor = PCI_VENDOR_ID_PHILIPS,
3737 .device = PCI_DEVICE_ID_PHILIPS_SAA7134,
3738 .subvendor = PCI_VENDOR_ID_ASUSTEK,
3739 .subdevice = 0x4840,
3740 .driver_data = SAA7134_BOARD_ASUSTeK_TVFM7134,
3741 },{
Linus Torvalds1da177e2005-04-16 15:20:36 -07003742 .vendor = PCI_VENDOR_ID_PHILIPS,
3743 .device = PCI_DEVICE_ID_PHILIPS_SAA7134,
3744 .subvendor = PCI_VENDOR_ID_PHILIPS,
3745 .subdevice = 0xfe01,
3746 .driver_data = SAA7134_BOARD_TVSTATION_RDS,
3747 },{
3748 .vendor = PCI_VENDOR_ID_PHILIPS,
3749 .device = PCI_DEVICE_ID_PHILIPS_SAA7134,
3750 .subvendor = 0x1894,
3751 .subdevice = 0xfe01,
3752 .driver_data = SAA7134_BOARD_TVSTATION_RDS,
3753 },{
3754 .vendor = PCI_VENDOR_ID_PHILIPS,
3755 .device = PCI_DEVICE_ID_PHILIPS_SAA7134,
3756 .subvendor = 0x1894,
3757 .subdevice = 0xa006,
3758 .driver_data = SAA7134_BOARD_TVSTATION_DVR,
3759 },{
3760 .vendor = PCI_VENDOR_ID_PHILIPS,
3761 .device = PCI_DEVICE_ID_PHILIPS_SAA7134,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07003762 .subvendor = 0x1131,
3763 .subdevice = 0x7133,
Linus Torvalds1da177e2005-04-16 15:20:36 -07003764 .driver_data = SAA7134_BOARD_VA1000POWER,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07003765 },{
Linus Torvalds1da177e2005-04-16 15:20:36 -07003766 .vendor = PCI_VENDOR_ID_PHILIPS,
3767 .device = PCI_DEVICE_ID_PHILIPS_SAA7130,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07003768 .subvendor = PCI_VENDOR_ID_PHILIPS,
3769 .subdevice = 0x2001,
Linus Torvalds1da177e2005-04-16 15:20:36 -07003770 .driver_data = SAA7134_BOARD_10MOONSTVMASTER,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07003771 },{
Linus Torvalds1da177e2005-04-16 15:20:36 -07003772 .vendor = PCI_VENDOR_ID_PHILIPS,
3773 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07003774 .subvendor = 0x185b,
3775 .subdevice = 0xc100,
Linus Torvalds1da177e2005-04-16 15:20:36 -07003776 .driver_data = SAA7134_BOARD_VIDEOMATE_TV,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07003777 },{
Linus Torvalds1da177e2005-04-16 15:20:36 -07003778 .vendor = PCI_VENDOR_ID_PHILIPS,
3779 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07003780 .subvendor = 0x185b,
3781 .subdevice = 0xc100,
Linus Torvalds1da177e2005-04-16 15:20:36 -07003782 .driver_data = SAA7134_BOARD_VIDEOMATE_TV_GOLD_PLUS,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07003783 },{
Linus Torvalds1da177e2005-04-16 15:20:36 -07003784 .vendor = PCI_VENDOR_ID_PHILIPS,
3785 .device = PCI_DEVICE_ID_PHILIPS_SAA7130,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07003786 .subvendor = PCI_VENDOR_ID_MATROX,
3787 .subdevice = 0x48d0,
Linus Torvalds1da177e2005-04-16 15:20:36 -07003788 .driver_data = SAA7134_BOARD_CRONOS_PLUS,
3789 },{
3790 .vendor = PCI_VENDOR_ID_PHILIPS,
3791 .device = PCI_DEVICE_ID_PHILIPS_SAA7134,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07003792 .subvendor = 0x1461, /* Avermedia Technologies Inc */
3793 .subdevice = 0xa70b,
Linus Torvalds1da177e2005-04-16 15:20:36 -07003794 .driver_data = SAA7134_BOARD_MD2819,
3795 },{
3796 .vendor = PCI_VENDOR_ID_PHILIPS,
3797 .device = PCI_DEVICE_ID_PHILIPS_SAA7130,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07003798 .subvendor = 0x1461, /* Avermedia Technologies Inc */
3799 .subdevice = 0x2115,
Linus Torvalds1da177e2005-04-16 15:20:36 -07003800 .driver_data = SAA7134_BOARD_AVERMEDIA_STUDIO_305,
3801 },{
3802 .vendor = PCI_VENDOR_ID_PHILIPS,
3803 .device = PCI_DEVICE_ID_PHILIPS_SAA7130,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07003804 .subvendor = 0x1461, /* Avermedia Technologies Inc */
3805 .subdevice = 0x2108,
Linus Torvalds1da177e2005-04-16 15:20:36 -07003806 .driver_data = SAA7134_BOARD_AVERMEDIA_305,
3807 },{
3808 .vendor = PCI_VENDOR_ID_PHILIPS,
3809 .device = PCI_DEVICE_ID_PHILIPS_SAA7130,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07003810 .subvendor = 0x1461, /* Avermedia Technologies Inc */
3811 .subdevice = 0x10ff,
Linus Torvalds1da177e2005-04-16 15:20:36 -07003812 .driver_data = SAA7134_BOARD_AVERMEDIA_DVD_EZMAKER,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07003813 },{
Linus Torvalds1da177e2005-04-16 15:20:36 -07003814 /* AVerMedia CardBus */
3815 .vendor = PCI_VENDOR_ID_PHILIPS,
3816 .device = PCI_DEVICE_ID_PHILIPS_SAA7134,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07003817 .subvendor = 0x1461, /* Avermedia Technologies Inc */
3818 .subdevice = 0xd6ee,
Linus Torvalds1da177e2005-04-16 15:20:36 -07003819 .driver_data = SAA7134_BOARD_AVERMEDIA_CARDBUS,
3820 },{
3821 /* TransGear 3000TV */
3822 .vendor = PCI_VENDOR_ID_PHILIPS,
3823 .device = PCI_DEVICE_ID_PHILIPS_SAA7130,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07003824 .subvendor = 0x1461, /* Avermedia Technologies Inc */
3825 .subdevice = 0x050c,
Linus Torvalds1da177e2005-04-16 15:20:36 -07003826 .driver_data = SAA7134_BOARD_TG3000TV,
3827 },{
Linus Torvalds1da177e2005-04-16 15:20:36 -07003828 .vendor = PCI_VENDOR_ID_PHILIPS,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07003829 .device = PCI_DEVICE_ID_PHILIPS_SAA7134,
3830 .subvendor = 0x11bd,
3831 .subdevice = 0x002b,
3832 .driver_data = SAA7134_BOARD_PINNACLE_PCTV_STEREO,
3833 },{
3834 .vendor = PCI_VENDOR_ID_PHILIPS,
3835 .device = PCI_DEVICE_ID_PHILIPS_SAA7134,
3836 .subvendor = 0x11bd,
3837 .subdevice = 0x002d,
3838 .driver_data = SAA7134_BOARD_PINNACLE_300I_DVBT_PAL,
3839 },{
3840 .vendor = PCI_VENDOR_ID_PHILIPS,
3841 .device = PCI_DEVICE_ID_PHILIPS_SAA7134,
3842 .subvendor = 0x1019,
3843 .subdevice = 0x4cb4,
3844 .driver_data = SAA7134_BOARD_ECS_TVP3XP,
3845 },{
3846 .vendor = PCI_VENDOR_ID_PHILIPS,
3847 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
3848 .subvendor = 0x1019,
3849 .subdevice = 0x4cb5,
3850 .driver_data = SAA7134_BOARD_ECS_TVP3XP_4CB5,
3851 },{
3852 .vendor = PCI_VENDOR_ID_PHILIPS,
Simon Farnsworthb39423a2007-05-01 10:01:20 -03003853 .device = PCI_DEVICE_ID_PHILIPS_SAA7134,
3854 .subvendor = 0x1019,
3855 .subdevice = 0x4cb6,
3856 .driver_data = SAA7134_BOARD_ECS_TVP3XP_4CB6,
3857 },{
3858 .vendor = PCI_VENDOR_ID_PHILIPS,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07003859 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
3860 .subvendor = 0x12ab,
3861 .subdevice = 0x0800,
3862 .driver_data = SAA7134_BOARD_UPMOST_PURPLE_TV,
Linus Torvalds1da177e2005-04-16 15:20:36 -07003863 },{
3864 .vendor = PCI_VENDOR_ID_PHILIPS,
3865 .device = PCI_DEVICE_ID_PHILIPS_SAA7130,
Michael Krufky7df64e82005-11-08 21:36:16 -08003866 .subvendor = 0x153b,
Linus Torvalds1da177e2005-04-16 15:20:36 -07003867 .subdevice = 0x1152,
3868 .driver_data = SAA7134_BOARD_CINERGY200,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07003869 },{
Linus Torvalds1da177e2005-04-16 15:20:36 -07003870 .vendor = PCI_VENDOR_ID_PHILIPS,
3871 .device = PCI_DEVICE_ID_PHILIPS_SAA7130,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07003872 .subvendor = 0x185b,
3873 .subdevice = 0xc100,
Linus Torvalds1da177e2005-04-16 15:20:36 -07003874 .driver_data = SAA7134_BOARD_VIDEOMATE_TV_PVR,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07003875 },{
Linus Torvalds1da177e2005-04-16 15:20:36 -07003876 .vendor = PCI_VENDOR_ID_PHILIPS,
Linus Torvalds1da177e2005-04-16 15:20:36 -07003877 .device = PCI_DEVICE_ID_PHILIPS_SAA7134,
3878 .subvendor = 0x1461, /* Avermedia Technologies Inc */
3879 .subdevice = 0x9715,
Mauro Carvalho Chehabac19ecc2005-06-23 22:05:09 -07003880 .driver_data = SAA7134_BOARD_AVERMEDIA_STUDIO_307,
3881 },{
3882 .vendor = PCI_VENDOR_ID_PHILIPS,
3883 .device = PCI_DEVICE_ID_PHILIPS_SAA7134,
3884 .subvendor = 0x1461, /* Avermedia Technologies Inc */
3885 .subdevice = 0xa70a,
Linus Torvalds1da177e2005-04-16 15:20:36 -07003886 .driver_data = SAA7134_BOARD_AVERMEDIA_307,
3887 },{
3888 .vendor = PCI_VENDOR_ID_PHILIPS,
3889 .device = PCI_DEVICE_ID_PHILIPS_SAA7134,
3890 .subvendor = 0x185b,
3891 .subdevice = 0xc200,
3892 .driver_data = SAA7134_BOARD_VIDEOMATE_GOLD_PLUS,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07003893 },{
Linus Torvalds1da177e2005-04-16 15:20:36 -07003894 .vendor = PCI_VENDOR_ID_PHILIPS,
3895 .device = PCI_DEVICE_ID_PHILIPS_SAA7134,
3896 .subvendor = 0x1540,
3897 .subdevice = 0x9524,
3898 .driver_data = SAA7134_BOARD_PROVIDEO_PV952,
3899
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07003900 },{
Linus Torvalds1da177e2005-04-16 15:20:36 -07003901 .vendor = PCI_VENDOR_ID_PHILIPS,
3902 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
3903 .subvendor = 0x5168,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07003904 .subdevice = 0x0502, /* Cardbus version */
Peter Missel10b7a902006-01-23 17:11:06 -02003905 .driver_data = SAA7134_BOARD_FLYDVBT_DUO_CARDBUS,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07003906 },{
3907 .vendor = PCI_VENDOR_ID_PHILIPS,
3908 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
3909 .subvendor = 0x5168,
3910 .subdevice = 0x0306, /* PCI version */
Linus Torvalds1da177e2005-04-16 15:20:36 -07003911 .driver_data = SAA7134_BOARD_FLYDVBTDUO,
Mauro Carvalho Chehabac19ecc2005-06-23 22:05:09 -07003912 },{
3913 .vendor = PCI_VENDOR_ID_PHILIPS,
3914 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
3915 .subvendor = 0x1461, /* Avermedia Technologies Inc */
3916 .subdevice = 0xf31f,
3917 .driver_data = SAA7134_BOARD_AVERMEDIA_GO_007_FM,
3918
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07003919 },{
Mauro Carvalho Chehabac19ecc2005-06-23 22:05:09 -07003920 .vendor = PCI_VENDOR_ID_PHILIPS,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07003921 .device = PCI_DEVICE_ID_PHILIPS_SAA7130,
3922 .subvendor = PCI_VENDOR_ID_PHILIPS,
3923 .subdevice = 0x2004,
3924 .driver_data = SAA7134_BOARD_PHILIPS_TOUGH,
3925 },{
3926 .vendor = PCI_VENDOR_ID_PHILIPS,
3927 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
Mauro Carvalho Chehabac19ecc2005-06-23 22:05:09 -07003928 .subvendor = 0x1421,
3929 .subdevice = 0x0350, /* PCI version */
3930 .driver_data = SAA7134_BOARD_ADS_INSTANT_TV,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07003931 },{
Mauro Carvalho Chehabac19ecc2005-06-23 22:05:09 -07003932 .vendor = PCI_VENDOR_ID_PHILIPS,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07003933 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
Mauro Carvalho Chehabac19ecc2005-06-23 22:05:09 -07003934 .subvendor = 0x1421,
Ricardo Cerqueira41d70c22006-01-09 15:25:34 -02003935 .subdevice = 0x0351, /* PCI version, new revision */
3936 .driver_data = SAA7134_BOARD_ADS_INSTANT_TV,
3937 },{
3938 .vendor = PCI_VENDOR_ID_PHILIPS,
3939 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
3940 .subvendor = 0x1421,
Mauro Carvalho Chehabac19ecc2005-06-23 22:05:09 -07003941 .subdevice = 0x0370, /* cardbus version */
3942 .driver_data = SAA7134_BOARD_ADS_INSTANT_TV,
Hartmut Hackmannd4b0aba2005-11-08 21:38:44 -08003943 },{
3944 .vendor = PCI_VENDOR_ID_PHILIPS,
3945 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
3946 .subvendor = 0x1421,
3947 .subdevice = 0x1370, /* cardbus version */
3948 .driver_data = SAA7134_BOARD_ADS_INSTANT_TV,
Linus Torvalds1da177e2005-04-16 15:20:36 -07003949
Peter Missel10b7a902006-01-23 17:11:06 -02003950 },{
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07003951 .vendor = PCI_VENDOR_ID_PHILIPS,
3952 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
Peter Missel10b7a902006-01-23 17:11:06 -02003953 .subvendor = 0x4e42, /* Typhoon */
3954 .subdevice = 0x0502, /* LifeView LR502 OEM */
3955 .driver_data = SAA7134_BOARD_FLYDVBT_DUO_CARDBUS,
Mauro Carvalho Chehab2f180712005-09-09 13:03:46 -07003956 },{
3957 .vendor = PCI_VENDOR_ID_PHILIPS,
3958 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
3959 .subvendor = 0x1043,
3960 .subdevice = 0x0210, /* mini pci NTSC version */
3961 .driver_data = SAA7134_BOARD_FLYTV_DIGIMATRIX,
3962 },{
3963 .vendor = PCI_VENDOR_ID_PHILIPS,
3964 .device = PCI_DEVICE_ID_PHILIPS_SAA7134,
3965 .subvendor = 0x1043,
3966 .subdevice = 0x0210, /* mini pci PAL/SECAM version */
Michael Krufky5d5c9902005-11-08 21:38:08 -08003967 .driver_data = SAA7134_BOARD_ASUSTEK_DIGIMATRIX_TV,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07003968
3969 },{
Nickolay V. Shmyreva8ff4172005-11-08 21:36:16 -08003970 .vendor = PCI_VENDOR_ID_PHILIPS,
3971 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
3972 .subvendor = 0x0000, /* It shouldn't break anything, since subdevice id seems unique */
3973 .subdevice = 0x4091,
3974 .driver_data = SAA7134_BOARD_BEHOLD_409FM,
Mauro Carvalho Chehab4ac97912005-11-08 21:37:43 -08003975 },{
3976 .vendor = PCI_VENDOR_ID_PHILIPS,
3977 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
3978 .subvendor = 0x5456, /* GoTView */
3979 .subdevice = 0x7135,
3980 .driver_data = SAA7134_BOARD_GOTVIEW_7135,
3981 },{
Hartmut Hackmann2cf36ac2005-11-08 21:36:32 -08003982 .vendor = PCI_VENDOR_ID_PHILIPS,
3983 .device = PCI_DEVICE_ID_PHILIPS_SAA7134,
3984 .subvendor = PCI_VENDOR_ID_PHILIPS,
3985 .subdevice = 0x2004,
3986 .driver_data = SAA7134_BOARD_PHILIPS_EUROPA,
Mauro Carvalho Chehab4ac97912005-11-08 21:37:43 -08003987 },{
Hartmut Hackmann2cf36ac2005-11-08 21:36:32 -08003988 .vendor = PCI_VENDOR_ID_PHILIPS,
3989 .device = PCI_DEVICE_ID_PHILIPS_SAA7134,
3990 .subvendor = 0x185b,
3991 .subdevice = 0xc900,
3992 .driver_data = SAA7134_BOARD_VIDEOMATE_DVBT_300,
Mauro Carvalho Chehab4ac97912005-11-08 21:37:43 -08003993 },{
Hartmut Hackmann2cf36ac2005-11-08 21:36:32 -08003994 .vendor = PCI_VENDOR_ID_PHILIPS,
3995 .device = PCI_DEVICE_ID_PHILIPS_SAA7130,
3996 .subvendor = 0x185b,
3997 .subdevice = 0xc901,
3998 .driver_data = SAA7134_BOARD_VIDEOMATE_DVBT_200,
3999 },{
Mauro Carvalho Chehab4ac97912005-11-08 21:37:43 -08004000 .vendor = PCI_VENDOR_ID_PHILIPS,
4001 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
4002 .subvendor = 0x1435,
4003 .subdevice = 0x7350,
4004 .driver_data = SAA7134_BOARD_RTD_VFG7350,
Nickolay V. Shmyrevbb881f12005-11-08 21:36:35 -08004005 },{
Mauro Carvalho Chehab4ac97912005-11-08 21:37:43 -08004006 .vendor = PCI_VENDOR_ID_PHILIPS,
4007 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
4008 .subvendor = 0x1435,
4009 .subdevice = 0x7330,
4010 .driver_data = SAA7134_BOARD_RTD_VFG7330,
Pieter Palmerscf1c5d12005-11-08 21:37:40 -08004011 },{
Mauro Carvalho Chehab4ac97912005-11-08 21:37:43 -08004012 .vendor = PCI_VENDOR_ID_PHILIPS,
4013 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
4014 .subvendor = 0x1461,
4015 .subdevice = 0x1044,
4016 .driver_data = SAA7134_BOARD_AVERMEDIA_AVERTVHD_A180,
4017 },{
Pieter Palmerscf1c5d12005-11-08 21:37:40 -08004018 .vendor = PCI_VENDOR_ID_PHILIPS,
4019 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
4020 .subvendor = 0x1131,
4021 .subdevice = 0x4ee9,
4022 .driver_data = SAA7134_BOARD_MONSTERTV_MOBILE,
Mauro Carvalho Chehab4ac97912005-11-08 21:37:43 -08004023 },{
Ricardo Cerqueirac2f6f9d2005-11-08 21:37:51 -08004024 .vendor = PCI_VENDOR_ID_PHILIPS,
4025 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
4026 .subvendor = 0x11bd,
4027 .subdevice = 0x002e,
4028 .driver_data = SAA7134_BOARD_PINNACLE_PCTV_110i,
4029 },{
Hermann Pitton28f02242005-11-08 21:38:03 -08004030 .vendor = PCI_VENDOR_ID_PHILIPS,
4031 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
4032 .subvendor = 0x1043,
4033 .subdevice = 0x4862,
4034 .driver_data = SAA7134_BOARD_ASUSTeK_P7131_DUAL,
Pavel Mihaylovc3d93192005-11-08 21:38:43 -08004035 },{
Hartmut Hackmann90e9df72005-11-08 21:38:42 -08004036 .vendor = PCI_VENDOR_ID_PHILIPS,
4037 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
4038 .subvendor = PCI_VENDOR_ID_PHILIPS,
4039 .subdevice = 0x2018,
4040 .driver_data = SAA7134_BOARD_PHILIPS_TIGER,
Hermann Pitton28f02242005-11-08 21:38:03 -08004041 },{
Ricardo Cerqueira80d2ad92005-11-13 16:08:01 -08004042 .vendor = PCI_VENDOR_ID_PHILIPS,
4043 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
4044 .subvendor = 0x1462,
4045 .subdevice = 0x6231,
4046 .driver_data = SAA7134_BOARD_MSI_TVATANYWHERE_PLUS,
4047 },{
Jörg Schummerf639c9b2006-01-09 15:25:01 -02004048 .vendor = PCI_VENDOR_ID_PHILIPS,
4049 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
4050 .subvendor = 0x153b,
4051 .subdevice = 0x1160,
4052 .driver_data = SAA7134_BOARD_CINERGY250PCI,
4053 },{
Peter Missel4aa6ba52006-01-09 15:32:45 -02004054 .vendor = PCI_VENDOR_ID_PHILIPS,
4055 .device = PCI_DEVICE_ID_PHILIPS_SAA7133, /* SAA 7131E */
4056 .subvendor = 0x5168,
4057 .subdevice = 0x0319,
4058 .driver_data = SAA7134_BOARD_FLYDVB_TRIO,
4059 },{
Jose Alberto Regueroa78d0bf2006-02-07 06:25:14 -02004060 .vendor = PCI_VENDOR_ID_PHILIPS,
Hartmut Hackmann1e9bfb92006-08-07 14:03:32 -03004061 .device = PCI_DEVICE_ID_PHILIPS_SAA7134,
Jose Alberto Regueroa78d0bf2006-02-07 06:25:14 -02004062 .subvendor = 0x1461,
4063 .subdevice = 0x2c05,
4064 .driver_data = SAA7134_BOARD_AVERMEDIA_777,
4065 },{
Giampiero Giancipoli3d8466e2006-02-07 06:49:09 -02004066 .vendor = PCI_VENDOR_ID_PHILIPS,
4067 .device = PCI_DEVICE_ID_PHILIPS_SAA7134,
4068 .subvendor = 0x5168,
4069 .subdevice = 0x0301,
4070 .driver_data = SAA7134_BOARD_FLYDVBT_LR301,
4071 },{
Hartmut Hackmanndf42eaf2006-02-07 06:49:10 -02004072 .vendor = PCI_VENDOR_ID_PHILIPS,
4073 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
4074 .subvendor = 0x0331,
4075 .subdevice = 0x1421,
4076 .driver_data = SAA7134_BOARD_ADS_DUO_CARDBUS_PTV331,
4077 },{
Peter Hartshorn3dfb7292006-02-07 06:49:13 -02004078 .vendor = PCI_VENDOR_ID_PHILIPS,
4079 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
4080 .subvendor = 0x17de,
4081 .subdevice = 0x7201,
4082 .driver_data = SAA7134_BOARD_TEVION_DVBT_220RF,
4083 },{
Andrew Burri3e1410a2006-02-27 00:08:23 -03004084 .vendor = PCI_VENDOR_ID_PHILIPS,
Simon Farnsworthb39423a2007-05-01 10:01:20 -03004085 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
4086 .subvendor = 0x17de,
4087 .subdevice = 0x7250,
4088 .driver_data = SAA7134_BOARD_KWORLD_DVBT_210,
4089 },{
4090 .vendor = PCI_VENDOR_ID_PHILIPS,
Andrew Burri3e1410a2006-02-27 00:08:23 -03004091 .device = PCI_DEVICE_ID_PHILIPS_SAA7133, /* SAA7135HL */
4092 .subvendor = 0x17de,
4093 .subdevice = 0x7350,
4094 .driver_data = SAA7134_BOARD_KWORLD_ATSC110,
4095 },{
Rickard Osser68593af2006-03-11 17:14:12 -03004096 .vendor = PCI_VENDOR_ID_PHILIPS,
Eric Sandeen0ac3a5b2007-10-08 16:13:02 -03004097 .device = PCI_DEVICE_ID_PHILIPS_SAA7133, /* SAA7135HL */
4098 .subvendor = 0x17de,
4099 .subdevice = 0x7352,
4100 .driver_data = SAA7134_BOARD_KWORLD_ATSC110, /* ATSC 115 */
4101 },{
4102 .vendor = PCI_VENDOR_ID_PHILIPS,
Rickard Osser68593af2006-03-11 17:14:12 -03004103 .device = PCI_DEVICE_ID_PHILIPS_SAA7134,
4104 .subvendor = 0x1461,
4105 .subdevice = 0x7360,
4106 .driver_data = SAA7134_BOARD_AVERMEDIA_A169_B,
4107 },{
4108 .vendor = PCI_VENDOR_ID_PHILIPS,
4109 .device = PCI_DEVICE_ID_PHILIPS_SAA7134,
4110 .subvendor = 0x1461,
4111 .subdevice = 0x6360,
4112 .driver_data = SAA7134_BOARD_AVERMEDIA_A169_B1,
4113 },{
Michael Krufkyba3a5a82006-03-14 19:02:12 -03004114 .vendor = PCI_VENDOR_ID_PHILIPS,
4115 .device = PCI_DEVICE_ID_PHILIPS_SAA7134,
4116 .subvendor = 0x16be,
4117 .subdevice = 0x0005,
4118 .driver_data = SAA7134_BOARD_MD7134_BRIDGE_2,
4119 },{
Igor M. Liplianine2ac28f2006-08-08 09:10:10 -03004120 .vendor = PCI_VENDOR_ID_PHILIPS,
4121 .device = PCI_DEVICE_ID_PHILIPS_SAA7134,
4122 .subvendor = 0x5168,
4123 .subdevice = 0x0300,
4124 .driver_data = SAA7134_BOARD_FLYDVBS_LR300,
4125 },{
4126 .vendor = PCI_VENDOR_ID_PHILIPS,
4127 .device = PCI_DEVICE_ID_PHILIPS_SAA7134,
4128 .subvendor = 0x4e42,
4129 .subdevice = 0x0300,/* LR300 */
4130 .driver_data = SAA7134_BOARD_FLYDVBS_LR300,
4131 },{
Hartmut Hackmann42e6b3b2006-03-27 19:04:48 -03004132 .vendor = PCI_VENDOR_ID_PHILIPS,
4133 .device = PCI_DEVICE_ID_PHILIPS_SAA7134,
4134 .subvendor = 0x1489,
4135 .subdevice = 0x0301,
4136 .driver_data = SAA7134_BOARD_FLYDVBT_LR301,
4137 },{
4138 .vendor = PCI_VENDOR_ID_PHILIPS,
4139 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
4140 .subvendor = 0x5168, /* Animation Technologies (LifeView) */
4141 .subdevice = 0x0304,
4142 .driver_data = SAA7134_BOARD_FLYTVPLATINUM_FM,
4143 },{
Hartmut Hackmannd95b8942006-03-27 19:39:30 -03004144 .vendor = PCI_VENDOR_ID_PHILIPS,
4145 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
4146 .subvendor = 0x5168,
4147 .subdevice = 0x3306,
4148 .driver_data = SAA7134_BOARD_FLYDVBT_HYBRID_CARDBUS,
4149 },{
4150 .vendor = PCI_VENDOR_ID_PHILIPS,
4151 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
4152 .subvendor = 0x5168,
4153 .subdevice = 0x3502, /* whats the difference to 0x3306 ?*/
4154 .driver_data = SAA7134_BOARD_FLYDVBT_HYBRID_CARDBUS,
4155 },{
Hartmut Hackmann5eda2272006-08-07 14:03:32 -03004156 .vendor = PCI_VENDOR_ID_PHILIPS,
4157 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
4158 .subvendor = 0x16be,
4159 .subdevice = 0x0007,
4160 .driver_data = SAA7134_BOARD_MEDION_MD8800_QUADRO,
4161 },{
4162 .vendor = PCI_VENDOR_ID_PHILIPS,
4163 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
4164 .subvendor = 0x16be,
4165 .subdevice = 0x0008,
4166 .driver_data = SAA7134_BOARD_MEDION_MD8800_QUADRO,
4167 },{
Hartmut Hackmann1e9bfb92006-08-07 14:03:32 -03004168 .vendor = PCI_VENDOR_ID_PHILIPS,
4169 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
4170 .subvendor = 0x1461,
4171 .subdevice = 0x2c05,
4172 .driver_data = SAA7134_BOARD_AVERMEDIA_777,
4173 },{
Hartmut Hackmann2c591942006-08-07 14:03:32 -03004174 .vendor = PCI_VENDOR_ID_PHILIPS,
4175 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
4176 .subvendor = 0x1489,
4177 .subdevice = 0x0502, /* Cardbus version */
4178 .driver_data = SAA7134_BOARD_FLYDVBT_DUO_CARDBUS,
4179 },{
Michal Majchrowiczb04c1ba2006-09-13 16:42:42 -03004180 .vendor = PCI_VENDOR_ID_PHILIPS,
4181 .device = PCI_DEVICE_ID_PHILIPS_SAA7130,
4182 .subvendor = 0x0919, /* Philips Proteus PRO 2309 */
4183 .subdevice = 0x2003,
4184 .driver_data = SAA7134_BOARD_PROTEUS_2309,
4185 },{
Petr Baudis515c2082006-09-26 16:53:53 -03004186 .vendor = PCI_VENDOR_ID_PHILIPS,
4187 .device = PCI_DEVICE_ID_PHILIPS_SAA7134,
4188 .subvendor = 0x1461,
4189 .subdevice = 0x2c00,
4190 .driver_data = SAA7134_BOARD_AVERMEDIA_A16AR,
4191 },{
Hartmut Hackmanncf146ca2006-10-02 20:49:24 -03004192 .vendor = PCI_VENDOR_ID_PHILIPS,
4193 .device = PCI_DEVICE_ID_PHILIPS_SAA7134,
4194 .subvendor = 0x1043,
4195 .subdevice = 0x4860,
4196 .driver_data = SAA7134_BOARD_ASUS_EUROPA2_HYBRID,
4197 },{
Hartmut Hackmann587d2fd2006-10-06 19:13:50 -03004198 .vendor = PCI_VENDOR_ID_PHILIPS,
4199 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
4200 .subvendor = 0x11bd,
4201 .subdevice = 0x002f,
4202 .driver_data = SAA7134_BOARD_PINNACLE_PCTV_310i,
4203 },{
Mikhail Fedotov3ac706d2006-10-06 20:23:47 -03004204 .vendor = PCI_VENDOR_ID_PHILIPS,
4205 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
4206 .subvendor = 0x1461, /* Avermedia Technologies Inc */
4207 .subdevice = 0x9715,
4208 .driver_data = SAA7134_BOARD_AVERMEDIA_STUDIO_507,
4209 },{
Hartmut Hackmann83646812006-10-12 20:38:51 -03004210 .vendor = PCI_VENDOR_ID_PHILIPS,
4211 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
4212 .subvendor = 0x1043,
4213 .subdevice = 0x4876,
Hartmut Hackmannf3eec0c02007-03-14 20:33:55 -03004214 .driver_data = SAA7134_BOARD_ASUSTeK_P7131_HYBRID_LNA,
Hartmut Hackmann83646812006-10-12 20:38:51 -03004215 },{
Thomas Gentyc6e53da2006-11-05 14:17:30 -03004216 .vendor = PCI_VENDOR_ID_PHILIPS,
4217 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
4218 .subvendor = 0x0070,
Michael Krufkyddf12222007-11-15 10:01:11 -03004219 .subdevice = 0x6700,
4220 .driver_data = SAA7134_BOARD_HAUPPAUGE_HVR1110,
4221 },{
4222 .vendor = PCI_VENDOR_ID_PHILIPS,
4223 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
4224 .subvendor = 0x0070,
Thomas Gentyc6e53da2006-11-05 14:17:30 -03004225 .subdevice = 0x6701,
4226 .driver_data = SAA7134_BOARD_HAUPPAUGE_HVR1110,
4227 },{
Hartmut Hackmann550a9a52006-11-15 21:31:54 -03004228 .vendor = PCI_VENDOR_ID_PHILIPS,
4229 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
Michael Krufkyddf12222007-11-15 10:01:11 -03004230 .subvendor = 0x0070,
4231 .subdevice = 0x6702,
4232 .driver_data = SAA7134_BOARD_HAUPPAUGE_HVR1110,
4233 },{
4234 .vendor = PCI_VENDOR_ID_PHILIPS,
4235 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
4236 .subvendor = 0x0070,
4237 .subdevice = 0x6703,
4238 .driver_data = SAA7134_BOARD_HAUPPAUGE_HVR1110,
4239 },{
4240 .vendor = PCI_VENDOR_ID_PHILIPS,
4241 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
4242 .subvendor = 0x0070,
4243 .subdevice = 0x6704,
4244 .driver_data = SAA7134_BOARD_HAUPPAUGE_HVR1110,
4245 },{
4246 .vendor = PCI_VENDOR_ID_PHILIPS,
4247 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
4248 .subvendor = 0x0070,
4249 .subdevice = 0x6705,
4250 .driver_data = SAA7134_BOARD_HAUPPAUGE_HVR1110,
4251 },{
4252 .vendor = PCI_VENDOR_ID_PHILIPS,
4253 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
Hartmut Hackmann550a9a52006-11-15 21:31:54 -03004254 .subvendor = 0x153b,
4255 .subdevice = 0x1172,
4256 .driver_data = SAA7134_BOARD_CINERGY_HT_PCMCIA,
4257 },{
Steven Walterd1158f42006-12-20 09:29:09 -03004258 .vendor = PCI_VENDOR_ID_PHILIPS,
4259 .device = PCI_DEVICE_ID_PHILIPS_SAA7130,
4260 .subvendor = PCI_VENDOR_ID_PHILIPS,
4261 .subdevice = 0x2342,
4262 .driver_data = SAA7134_BOARD_ENCORE_ENLTV,
4263 },{
Juan Pablo Sormanic36c4592006-12-27 12:46:36 -03004264 .vendor = PCI_VENDOR_ID_PHILIPS,
4265 .device = PCI_DEVICE_ID_PHILIPS_SAA7130,
4266 .subvendor = 0x1131,
4267 .subdevice = 0x2341,
4268 .driver_data = SAA7134_BOARD_ENCORE_ENLTV,
4269 },{
4270 .vendor = PCI_VENDOR_ID_PHILIPS,
4271 .device = PCI_DEVICE_ID_PHILIPS_SAA7130,
4272 .subvendor = 0x3016,
4273 .subdevice = 0x2344,
4274 .driver_data = SAA7134_BOARD_ENCORE_ENLTV,
4275 },{
4276 .vendor = PCI_VENDOR_ID_PHILIPS,
4277 .device = PCI_DEVICE_ID_PHILIPS_SAA7130,
4278 .subvendor = 0x1131,
4279 .subdevice = 0x230f,
4280 .driver_data = SAA7134_BOARD_ENCORE_ENLTV_FM,
4281 },{
Michael Krufky9de271e2007-01-16 18:36:40 -03004282 .vendor = PCI_VENDOR_ID_PHILIPS,
4283 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
4284 .subvendor = 0x153b,
4285 .subdevice = 0x1175,
4286 .driver_data = SAA7134_BOARD_CINERGY_HT_PCI,
4287 },{
Markus Rechbergere95d3172007-04-27 12:31:19 -03004288 .vendor = PCI_VENDOR_ID_PHILIPS,
4289 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
4290 .subvendor = 0x1461, /* Avermedia Technologies Inc */
4291 .subdevice = 0xf31e,
4292 .driver_data = SAA7134_BOARD_AVERMEDIA_M102,
4293 },{
Peter Misseldb483672007-04-27 12:31:20 -03004294 .vendor = PCI_VENDOR_ID_PHILIPS,
4295 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
4296 .subvendor = 0x4E42, /* MSI */
4297 .subdevice = 0x0306, /* TV@nywhere DUO */
4298 .driver_data = SAA7134_BOARD_FLYDVBTDUO,
4299 },{
Hartmut Hackmanne06cea42007-03-13 20:58:29 -03004300 .vendor = PCI_VENDOR_ID_PHILIPS,
4301 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
4302 .subvendor = 0x1043,
4303 .subdevice = 0x4871,
4304 .driver_data = SAA7134_BOARD_ASUS_P7131_4871,
4305 },{
4306 .vendor = PCI_VENDOR_ID_PHILIPS,
4307 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
4308 .subvendor = 0x1043,
4309 .subdevice = 0x4857,
4310 .driver_data = SAA7134_BOARD_ASUSTeK_P7131_DUAL,
4311 },{
James T Klaas53958b32007-05-01 10:48:09 -03004312 .vendor = PCI_VENDOR_ID_PHILIPS,
4313 .device = PCI_DEVICE_ID_PHILIPS_SAA7134,
4314 .subvendor = 0x0919, /* SinoVideo PCI 2309 Proteus (7134) */
4315 .subdevice = 0x2003, /* OEM cardbus */
4316 .driver_data = SAA7134_BOARD_SABRENT_TV_PCB05,
4317 },{
Tony Wanaaccb822007-05-10 12:16:47 -03004318 .vendor = PCI_VENDOR_ID_PHILIPS,
4319 .device = PCI_DEVICE_ID_PHILIPS_SAA7130,
4320 .subvendor = PCI_VENDOR_ID_PHILIPS,
4321 .subdevice = 0x2304,
4322 .driver_data = SAA7134_BOARD_10MOONSTVMASTER3,
4323 },{
Edgar Simod90d9f52007-08-20 14:14:50 -03004324 .vendor = PCI_VENDOR_ID_PHILIPS,
4325 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
4326 .subvendor = 0x1461, /* Avermedia Technologies Inc */
4327 .subdevice = 0xf01d, /* AVerTV DVB-T Super 007 */
4328 .driver_data = SAA7134_BOARD_AVERMEDIA_SUPER_007,
4329 },{
Mauro Carvalho Chehab593f18c2007-10-07 02:17:09 -03004330 .vendor = PCI_VENDOR_ID_PHILIPS,
4331 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
4332 .subvendor = 0x4e42,
4333 .subdevice = 0x3502,
4334 .driver_data = SAA7134_BOARD_FLYDVBT_HYBRID_CARDBUS
4335 },{
Linus Torvalds1da177e2005-04-16 15:20:36 -07004336 /* --- boards without eeprom + subsystem ID --- */
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07004337 .vendor = PCI_VENDOR_ID_PHILIPS,
4338 .device = PCI_DEVICE_ID_PHILIPS_SAA7134,
4339 .subvendor = PCI_VENDOR_ID_PHILIPS,
Linus Torvalds1da177e2005-04-16 15:20:36 -07004340 .subdevice = 0,
4341 .driver_data = SAA7134_BOARD_NOAUTO,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07004342 },{
4343 .vendor = PCI_VENDOR_ID_PHILIPS,
4344 .device = PCI_DEVICE_ID_PHILIPS_SAA7130,
4345 .subvendor = PCI_VENDOR_ID_PHILIPS,
Linus Torvalds1da177e2005-04-16 15:20:36 -07004346 .subdevice = 0,
4347 .driver_data = SAA7134_BOARD_NOAUTO,
4348 },{
Linus Torvalds1da177e2005-04-16 15:20:36 -07004349 /* --- default catch --- */
4350 .vendor = PCI_VENDOR_ID_PHILIPS,
4351 .device = PCI_DEVICE_ID_PHILIPS_SAA7130,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07004352 .subvendor = PCI_ANY_ID,
4353 .subdevice = PCI_ANY_ID,
Linus Torvalds1da177e2005-04-16 15:20:36 -07004354 .driver_data = SAA7134_BOARD_UNKNOWN,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07004355 },{
Linus Torvalds1da177e2005-04-16 15:20:36 -07004356 .vendor = PCI_VENDOR_ID_PHILIPS,
4357 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07004358 .subvendor = PCI_ANY_ID,
4359 .subdevice = PCI_ANY_ID,
Linus Torvalds1da177e2005-04-16 15:20:36 -07004360 .driver_data = SAA7134_BOARD_UNKNOWN,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07004361 },{
Linus Torvalds1da177e2005-04-16 15:20:36 -07004362 .vendor = PCI_VENDOR_ID_PHILIPS,
4363 .device = PCI_DEVICE_ID_PHILIPS_SAA7134,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07004364 .subvendor = PCI_ANY_ID,
4365 .subdevice = PCI_ANY_ID,
Linus Torvalds1da177e2005-04-16 15:20:36 -07004366 .driver_data = SAA7134_BOARD_UNKNOWN,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07004367 },{
Linus Torvalds1da177e2005-04-16 15:20:36 -07004368 .vendor = PCI_VENDOR_ID_PHILIPS,
4369 .device = PCI_DEVICE_ID_PHILIPS_SAA7135,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07004370 .subvendor = PCI_ANY_ID,
4371 .subdevice = PCI_ANY_ID,
Linus Torvalds1da177e2005-04-16 15:20:36 -07004372 .driver_data = SAA7134_BOARD_UNKNOWN,
4373 },{
4374 /* --- end of list --- */
4375 }
4376};
4377MODULE_DEVICE_TABLE(pci, saa7134_pci_tbl);
4378
4379/* ----------------------------------------------------------- */
4380/* flyvideo tweaks */
4381
Linus Torvalds1da177e2005-04-16 15:20:36 -07004382
4383static void board_flyvideo(struct saa7134_dev *dev)
4384{
Linus Torvalds1da177e2005-04-16 15:20:36 -07004385 printk("%s: there are different flyvideo cards with different tuners\n"
4386 "%s: out there, you might have to use the tuner=<nr> insmod\n"
4387 "%s: option to override the default value.\n",
4388 dev->name, dev->name, dev->name);
4389}
4390
4391/* ----------------------------------------------------------- */
4392
Michael Krufky993efa72007-11-15 10:34:33 -03004393static void hauppauge_eeprom(struct saa7134_dev *dev, u8 *eeprom_data)
4394{
4395 struct tveeprom tv;
4396
4397 tveeprom_hauppauge_analog(&dev->i2c_client, &tv, eeprom_data);
4398
4399 /* Make sure we support the board model */
4400 switch (tv.model) {
4401 case 67019: /* WinTV-HVR1110 (Retail, IR Blaster, hybrid, FM, SVid/Comp, 3.5mm audio in) */
4402 case 67109: /* WinTV-HVR1000 (Retail, IR Receive, analog, no FM, SVid/Comp, 3.5mm audio in) */
4403 case 67559: /* WinTV-HVR1110 (OEM, no IR, hybrid, FM, SVid/Comp, RCA aud) */
4404 case 67569: /* WinTV-HVR1110 (OEM, no IR, hybrid, FM) */
4405 case 67579: /* WinTV-HVR1110 (OEM, no IR, hybrid, no FM) */
4406 case 67589: /* WinTV-HVR1110 (OEM, no IR, hybrid, no FM, SVid/Comp, RCA aud) */
4407 case 67599: /* WinTV-HVR1110 (OEM, no IR, hybrid, no FM, SVid/Comp, RCA aud) */
4408 break;
4409 default:
4410 printk(KERN_WARNING "%s: warning: "
4411 "unknown hauppauge model #%d\n", dev->name, tv.model);
4412 break;
4413 }
4414
4415 printk(KERN_INFO "%s: hauppauge eeprom: model=%d\n",
4416 dev->name, tv.model);
4417}
4418
4419/* ----------------------------------------------------------- */
4420
Linus Torvalds1da177e2005-04-16 15:20:36 -07004421int saa7134_board_init1(struct saa7134_dev *dev)
4422{
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07004423 /* Always print gpio, often manufacturers encode tuner type and other info. */
Linus Torvalds1da177e2005-04-16 15:20:36 -07004424 saa_writel(SAA7134_GPIO_GPMODE0 >> 2, 0);
4425 dev->gpio_value = saa_readl(SAA7134_GPIO_GPSTATUS0 >> 2);
4426 printk(KERN_INFO "%s: board init: gpio is %x\n", dev->name, dev->gpio_value);
4427
4428 switch (dev->board) {
4429 case SAA7134_BOARD_FLYVIDEO2000:
4430 case SAA7134_BOARD_FLYVIDEO3000:
Zac Bowlingf49ba8d2006-06-19 19:49:20 -03004431 case SAA7134_BOARD_FLYVIDEO3000_NTSC:
Ricardo Cerqueiracb2444d2005-11-08 21:38:47 -08004432 dev->has_remote = SAA7134_REMOTE_GPIO;
Linus Torvalds1da177e2005-04-16 15:20:36 -07004433 board_flyvideo(dev);
4434 break;
Arnaud Patard6af90ab2005-11-08 21:36:55 -08004435 case SAA7134_BOARD_FLYTVPLATINUM_MINI2:
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07004436 case SAA7134_BOARD_FLYTVPLATINUM_FM:
Linus Torvalds1da177e2005-04-16 15:20:36 -07004437 case SAA7134_BOARD_CINERGY400:
4438 case SAA7134_BOARD_CINERGY600:
4439 case SAA7134_BOARD_CINERGY600_MK3:
4440 case SAA7134_BOARD_ECS_TVP3XP:
4441 case SAA7134_BOARD_ECS_TVP3XP_4CB5:
Simon Farnsworthb39423a2007-05-01 10:01:20 -03004442 case SAA7134_BOARD_ECS_TVP3XP_4CB6:
Linus Torvalds1da177e2005-04-16 15:20:36 -07004443 case SAA7134_BOARD_MD2819:
Mauro Carvalho Chehabac19ecc2005-06-23 22:05:09 -07004444 case SAA7134_BOARD_KWORLD_VSTREAM_XPERT:
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07004445 case SAA7134_BOARD_KWORLD_XPERT:
Linus Torvalds1da177e2005-04-16 15:20:36 -07004446 case SAA7134_BOARD_AVERMEDIA_STUDIO_305:
4447 case SAA7134_BOARD_AVERMEDIA_305:
Mauro Carvalho Chehabac19ecc2005-06-23 22:05:09 -07004448 case SAA7134_BOARD_AVERMEDIA_STUDIO_307:
Linus Torvalds1da177e2005-04-16 15:20:36 -07004449 case SAA7134_BOARD_AVERMEDIA_307:
Mikhail Fedotov3ac706d2006-10-06 20:23:47 -03004450 case SAA7134_BOARD_AVERMEDIA_STUDIO_507:
Mauro Carvalho Chehabac19ecc2005-06-23 22:05:09 -07004451 case SAA7134_BOARD_AVERMEDIA_GO_007_FM:
pasky@ucw.cz450efcf2006-11-12 14:22:32 -03004452 case SAA7134_BOARD_AVERMEDIA_777:
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07004453/* case SAA7134_BOARD_SABRENT_SBTTVFM: */ /* not finished yet */
Linus Torvalds1da177e2005-04-16 15:20:36 -07004454 case SAA7134_BOARD_VIDEOMATE_TV_PVR:
Nickolay V. Shmyrev2a9a9a82006-01-09 15:25:33 -02004455 case SAA7134_BOARD_VIDEOMATE_GOLD_PLUS:
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07004456 case SAA7134_BOARD_VIDEOMATE_TV_GOLD_PLUSII:
Nickolay V. Shmyrevfea095f2005-11-08 21:36:47 -08004457 case SAA7134_BOARD_VIDEOMATE_DVBT_300:
Michael Krufkyafce8922005-11-08 21:36:57 -08004458 case SAA7134_BOARD_VIDEOMATE_DVBT_200:
Hartmut Hackmanncbb94522006-10-30 20:00:16 -03004459 case SAA7134_BOARD_VIDEOMATE_DVBT_200A:
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07004460 case SAA7134_BOARD_MANLI_MTV001:
4461 case SAA7134_BOARD_MANLI_MTV002:
Nickolay V. Shmyreva8ff4172005-11-08 21:36:16 -08004462 case SAA7134_BOARD_BEHOLD_409FM:
Linus Torvalds1da177e2005-04-16 15:20:36 -07004463 case SAA7134_BOARD_AVACSSMARTTV:
Nickolay V. Shmyrev6b961442005-11-08 21:36:22 -08004464 case SAA7134_BOARD_GOTVIEW_7135:
James R. Webbdc2286c2005-11-08 21:37:00 -08004465 case SAA7134_BOARD_KWORLD_TERMINATOR:
Ricardo Cerqueira17ce1ff2005-11-08 21:38:47 -08004466 case SAA7134_BOARD_SEDNA_PC_TV_CARDBUS:
Giampiero Giancipoli3d8466e2006-02-07 06:49:09 -02004467 case SAA7134_BOARD_FLYDVBT_LR301:
Hermann Pitton91607232006-12-07 21:45:28 -03004468 case SAA7134_BOARD_ASUSTeK_P7131_DUAL:
Hartmut Hackmannf3eec0c02007-03-14 20:33:55 -03004469 case SAA7134_BOARD_ASUSTeK_P7131_HYBRID_LNA:
Rudo Thomasa8029172006-02-27 00:08:46 -03004470 case SAA7134_BOARD_FLYDVBTDUO:
Michal Majchrowiczb04c1ba2006-09-13 16:42:42 -03004471 case SAA7134_BOARD_PROTEUS_2309:
pasky@ucw.cz29e0f1a2006-11-12 14:23:32 -03004472 case SAA7134_BOARD_AVERMEDIA_A16AR:
Juan Pablo Sormanic36c4592006-12-27 12:46:36 -03004473 case SAA7134_BOARD_ENCORE_ENLTV:
4474 case SAA7134_BOARD_ENCORE_ENLTV_FM:
Tony Wan480f75a2007-05-11 11:33:50 -03004475 case SAA7134_BOARD_10MOONSTVMASTER3:
Ricardo Cerqueiracb2444d2005-11-08 21:38:47 -08004476 dev->has_remote = SAA7134_REMOTE_GPIO;
Linus Torvalds1da177e2005-04-16 15:20:36 -07004477 break;
Igor M. Liplianine2ac28f2006-08-08 09:10:10 -03004478 case SAA7134_BOARD_FLYDVBS_LR300:
4479 saa_writeb(SAA7134_GPIO_GPMODE3, 0x80);
4480 saa_writeb(SAA7134_GPIO_GPSTATUS2, 0x40);
4481 dev->has_remote = SAA7134_REMOTE_GPIO;
4482 break;
Linus Torvalds1da177e2005-04-16 15:20:36 -07004483 case SAA7134_BOARD_MD5044:
4484 printk("%s: seems there are two different versions of the MD5044\n"
Michael Krufkyfd2f2672006-03-11 16:21:36 -03004485 "%s: (with the same ID) out there. If sound doesn't work for\n"
4486 "%s: you try the audio_clock_override=0x200000 insmod option.\n",
4487 dev->name,dev->name,dev->name);
Linus Torvalds1da177e2005-04-16 15:20:36 -07004488 break;
4489 case SAA7134_BOARD_CINERGY400_CARDBUS:
4490 /* power-up tuner chip */
4491 saa_andorl(SAA7134_GPIO_GPMODE0 >> 2, 0x00040000, 0x00040000);
4492 saa_andorl(SAA7134_GPIO_GPSTATUS0 >> 2, 0x00040000, 0x00000000);
Mikhail Gusarov7bbbc0a2006-04-20 13:18:50 -03004493 break;
Hartmut Hackmanndf8cf702006-03-03 12:09:26 -03004494 case SAA7134_BOARD_PINNACLE_300I_DVBT_PAL:
4495 /* this turns the remote control chip off to work around a bug in it */
4496 saa_writeb(SAA7134_GPIO_GPMODE1, 0x80);
4497 saa_writeb(SAA7134_GPIO_GPSTATUS1, 0x80);
4498 break;
Pieter Palmerscf1c5d12005-11-08 21:37:40 -08004499 case SAA7134_BOARD_MONSTERTV_MOBILE:
4500 /* power-up tuner chip */
4501 saa_andorl(SAA7134_GPIO_GPMODE0 >> 2, 0x00040000, 0x00040000);
4502 saa_andorl(SAA7134_GPIO_GPSTATUS0 >> 2, 0x00040000, 0x00000004);
Linus Torvalds1da177e2005-04-16 15:20:36 -07004503 break;
Peter Missel10b7a902006-01-23 17:11:06 -02004504 case SAA7134_BOARD_FLYDVBT_DUO_CARDBUS:
Nickolay V. Shmyrev6b961442005-11-08 21:36:22 -08004505 /* turn the fan on */
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07004506 saa_writeb(SAA7134_GPIO_GPMODE3, 0x08);
4507 saa_writeb(SAA7134_GPIO_GPSTATUS3, 0x06);
4508 break;
Hartmut Hackmanndf42eaf2006-02-07 06:49:10 -02004509 case SAA7134_BOARD_ADS_DUO_CARDBUS_PTV331:
Hartmut Hackmannd95b8942006-03-27 19:39:30 -03004510 case SAA7134_BOARD_FLYDVBT_HYBRID_CARDBUS:
Hartmut Hackmann58ef4f92007-04-27 12:31:12 -03004511 saa_andorl(SAA7134_GPIO_GPMODE0 >> 2, 0x08000000, 0x08000000);
4512 saa_andorl(SAA7134_GPIO_GPSTATUS0 >> 2, 0x08000000, 0x00000000);
Hartmut Hackmanndf42eaf2006-02-07 06:49:10 -02004513 break;
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07004514 case SAA7134_BOARD_AVERMEDIA_CARDBUS:
4515 /* power-up tuner chip */
4516 saa_andorl(SAA7134_GPIO_GPMODE0 >> 2, 0xffffffff, 0xffffffff);
4517 saa_andorl(SAA7134_GPIO_GPSTATUS0 >> 2, 0xffffffff, 0xffffffff);
4518 msleep(1);
4519 break;
Nickolay V. Shmyrevbb881f12005-11-08 21:36:35 -08004520 case SAA7134_BOARD_RTD_VFG7350:
4521
4522 /*
4523 * Make sure Production Test Register at offset 0x1D1 is cleared
4524 * to take chip out of test mode. Clearing bit 4 (TST_EN_AOUT)
4525 * prevents pin 105 from remaining low; keeping pin 105 low
4526 * continually resets the SAA6752 chip.
4527 */
4528
4529 saa_writeb (SAA7134_PRODUCTION_TEST_MODE, 0x00);
4530 break;
Ricardo Cerqueiracb2444d2005-11-08 21:38:47 -08004531 /* i2c remotes */
4532 case SAA7134_BOARD_PINNACLE_PCTV_110i:
Hartmut Hackmann587d2fd2006-10-06 19:13:50 -03004533 case SAA7134_BOARD_PINNACLE_PCTV_310i:
Ricardo Cerqueiracb2444d2005-11-08 21:38:47 -08004534 case SAA7134_BOARD_UPMOST_PURPLE_TV:
Thomas Genty177aaaf2006-11-29 21:57:24 -03004535 case SAA7134_BOARD_HAUPPAUGE_HVR1110:
Ricardo Cerqueiracb2444d2005-11-08 21:38:47 -08004536 dev->has_remote = SAA7134_REMOTE_I2C;
4537 break;
Rickard Osser68593af2006-03-11 17:14:12 -03004538 case SAA7134_BOARD_AVERMEDIA_A169_B:
Michael Krufkyba3a5a82006-03-14 19:02:12 -03004539 case SAA7134_BOARD_MD7134_BRIDGE_2:
Michael Krufky12a219d2006-03-14 16:07:42 -03004540 printk("%s: %s: dual saa713x broadcast decoders\n"
Rickard Osser68593af2006-03-11 17:14:12 -03004541 "%s: Sorry, none of the inputs to this chip are supported yet.\n"
4542 "%s: Dual decoder functionality is disabled for now, use the other chip.\n",
Michael Krufky12a219d2006-03-14 16:07:42 -03004543 dev->name,card(dev).name,dev->name,dev->name);
Rickard Osser68593af2006-03-11 17:14:12 -03004544 break;
Markus Rechbergere95d3172007-04-27 12:31:19 -03004545 case SAA7134_BOARD_AVERMEDIA_M102:
4546 /* enable tuner */
Albert Grahamd2761f22007-12-09 09:44:38 -03004547 dev->has_remote = SAA7134_REMOTE_GPIO;
Markus Rechbergere95d3172007-04-27 12:31:19 -03004548 saa_andorl(SAA7134_GPIO_GPMODE0 >> 2, 0x8c040007, 0x8c040007);
4549 saa_andorl(SAA7134_GPIO_GPSTATUS0 >> 2, 0x0c0007cd, 0x0c0007cd);
4550 break;
Linus Torvalds1da177e2005-04-16 15:20:36 -07004551 }
Linus Torvalds1da177e2005-04-16 15:20:36 -07004552 return 0;
4553}
4554
4555/* stuff which needs working i2c */
4556int saa7134_board_init2(struct saa7134_dev *dev)
4557{
4558 unsigned char buf;
4559 int board;
Hartmut Hackmanncfeb8832007-04-27 12:31:17 -03004560 struct tuner_setup tun_setup;
4561 tun_setup.config = 0;
4562 tun_setup.tuner_callback = saa7134_tuner_callback;
Linus Torvalds1da177e2005-04-16 15:20:36 -07004563
4564 switch (dev->board) {
4565 case SAA7134_BOARD_BMK_MPEX_NOTUNER:
4566 case SAA7134_BOARD_BMK_MPEX_TUNER:
4567 dev->i2c_client.addr = 0x60;
4568 board = (i2c_master_recv(&dev->i2c_client,&buf,0) < 0)
4569 ? SAA7134_BOARD_BMK_MPEX_NOTUNER
4570 : SAA7134_BOARD_BMK_MPEX_TUNER;
4571 if (board == dev->board)
4572 break;
4573 dev->board = board;
4574 printk("%s: board type fixup: %s\n", dev->name,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07004575 saa7134_boards[dev->board].name);
Linus Torvalds1da177e2005-04-16 15:20:36 -07004576 dev->tuner_type = saa7134_boards[dev->board].tuner_type;
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07004577
4578 if (TUNER_ABSENT != dev->tuner_type) {
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07004579 tun_setup.mode_mask = T_RADIO | T_ANALOG_TV | T_DIGITAL_TV;
4580 tun_setup.type = dev->tuner_type;
4581 tun_setup.addr = ADDR_UNSET;
4582
4583 saa7134_i2c_call_clients (dev, TUNER_SET_TYPE_ADDR, &tun_setup);
4584 }
4585 break;
Hartmut Hackmann2cf36ac2005-11-08 21:36:32 -08004586 case SAA7134_BOARD_MD7134:
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07004587 {
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07004588 u8 subaddr;
4589 u8 data[3];
4590 int ret, tuner_t;
4591
4592 struct i2c_msg msg[] = {{.addr=0x50, .flags=0, .buf=&subaddr, .len = 1},
4593 {.addr=0x50, .flags=I2C_M_RD, .buf=data, .len = 3}};
4594 subaddr= 0x14;
4595 tuner_t = 0;
4596 ret = i2c_transfer(&dev->i2c_adap, msg, 2);
4597 if (ret != 2) {
4598 printk(KERN_ERR "EEPROM read failure\n");
4599 } else if ((data[0] != 0) && (data[0] != 0xff)) {
4600 /* old config structure */
4601 subaddr = data[0] + 2;
4602 msg[1].len = 2;
4603 i2c_transfer(&dev->i2c_adap, msg, 2);
4604 tuner_t = (data[0] << 8) + data[1];
4605 switch (tuner_t){
4606 case 0x0103:
4607 dev->tuner_type = TUNER_PHILIPS_PAL;
4608 break;
4609 case 0x010C:
4610 dev->tuner_type = TUNER_PHILIPS_FM1216ME_MK3;
4611 break;
4612 default:
4613 printk(KERN_ERR "%s Cant determine tuner type %x from EEPROM\n", dev->name, tuner_t);
4614 }
4615 } else if ((data[1] != 0) && (data[1] != 0xff)) {
4616 /* new config structure */
4617 subaddr = data[1] + 1;
4618 msg[1].len = 1;
4619 i2c_transfer(&dev->i2c_adap, msg, 2);
4620 subaddr = data[0] + 1;
4621 msg[1].len = 2;
4622 i2c_transfer(&dev->i2c_adap, msg, 2);
4623 tuner_t = (data[1] << 8) + data[0];
4624 switch (tuner_t) {
4625 case 0x0005:
4626 dev->tuner_type = TUNER_PHILIPS_FM1216ME_MK3;
4627 break;
4628 case 0x001d:
4629 dev->tuner_type = TUNER_PHILIPS_FMD1216ME_MK3;
4630 printk(KERN_INFO "%s Board has DVB-T\n", dev->name);
4631 break;
4632 default:
4633 printk(KERN_ERR "%s Cant determine tuner type %x from EEPROM\n", dev->name, tuner_t);
4634 }
4635 } else {
4636 printk(KERN_ERR "%s unexpected config structure\n", dev->name);
4637 }
4638
4639 printk(KERN_INFO "%s Tuner type is %d\n", dev->name, dev->tuner_type);
4640 if (dev->tuner_type == TUNER_PHILIPS_FMD1216ME_MK3) {
Mauro Carvalho Chehab7f171122007-10-18 19:56:47 -03004641 struct v4l2_priv_tun_config tda9887_cfg;
4642
4643 tda9887_cfg.tuner = TUNER_TDA9887;
4644 tda9887_cfg.priv = &dev->tda9887_conf;
4645
4646 dev->tda9887_conf = TDA9887_PRESENT |
4647 TDA9887_PORT1_ACTIVE |
4648 TDA9887_PORT2_ACTIVE;
4649
4650 saa7134_i2c_call_clients(dev, TUNER_SET_CONFIG,
4651 &tda9887_cfg);
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07004652 }
4653
4654 tun_setup.mode_mask = T_RADIO | T_ANALOG_TV | T_DIGITAL_TV;
4655 tun_setup.type = dev->tuner_type;
4656 tun_setup.addr = ADDR_UNSET;
4657
4658 saa7134_i2c_call_clients (dev, TUNER_SET_TYPE_ADDR,&tun_setup);
4659 }
Linus Torvalds1da177e2005-04-16 15:20:36 -07004660 break;
Hartmut Hackmann2cf36ac2005-11-08 21:36:32 -08004661 case SAA7134_BOARD_PHILIPS_EUROPA:
4662 case SAA7134_BOARD_VIDEOMATE_DVBT_300:
Hartmut Hackmanncf146ca2006-10-02 20:49:24 -03004663 case SAA7134_BOARD_ASUS_EUROPA2_HYBRID:
Hartmut Hackmann2cf36ac2005-11-08 21:36:32 -08004664 /* The Philips EUROPA based hybrid boards have the tuner connected through
4665 * the channel decoder. We have to make it transparent to find it
Mauro Carvalho Chehab4ac97912005-11-08 21:37:43 -08004666 */
Hartmut Hackmann2cf36ac2005-11-08 21:36:32 -08004667 {
Hartmut Hackmann2cf36ac2005-11-08 21:36:32 -08004668 u8 data[] = { 0x07, 0x02};
4669 struct i2c_msg msg = {.addr=0x08, .flags=0, .buf=data, .len = sizeof(data)};
4670 i2c_transfer(&dev->i2c_adap, &msg, 1);
4671
4672 tun_setup.mode_mask = T_ANALOG_TV | T_DIGITAL_TV;
4673 tun_setup.type = dev->tuner_type;
4674 tun_setup.addr = dev->tuner_addr;
4675
4676 saa7134_i2c_call_clients (dev, TUNER_SET_TYPE_ADDR,&tun_setup);
Mauro Carvalho Chehab4ac97912005-11-08 21:37:43 -08004677 }
Hartmut Hackmann2cf36ac2005-11-08 21:36:32 -08004678 break;
Hartmut Hackmann90e9df72005-11-08 21:38:42 -08004679 case SAA7134_BOARD_PHILIPS_TIGER:
Hartmut Hackmann58ef4f92007-04-27 12:31:12 -03004680 case SAA7134_BOARD_PHILIPS_TIGER_S:
Edgar Simod90d9f52007-08-20 14:14:50 -03004681 case SAA7134_BOARD_AVERMEDIA_SUPER_007:
Hartmut Hackmann58ef4f92007-04-27 12:31:12 -03004682 {
4683 u8 data[] = { 0x3c, 0x33, 0x60};
Hartmut Hackmann58ef4f92007-04-27 12:31:12 -03004684 struct i2c_msg msg = {.addr=0x08, .flags=0, .buf=data, .len = sizeof(data)};
4685 if(dev->autodetected && (dev->eedata[0x49] == 0x50)) {
4686 dev->board = SAA7134_BOARD_PHILIPS_TIGER_S;
4687 printk(KERN_INFO "%s: Reconfigured board as %s\n",
4688 dev->name, saa7134_boards[dev->board].name);
4689 }
4690 if(dev->board == SAA7134_BOARD_PHILIPS_TIGER_S) {
4691 tun_setup.mode_mask = T_ANALOG_TV | T_DIGITAL_TV;
4692 tun_setup.type = TUNER_PHILIPS_TDA8290;
4693 tun_setup.addr = 0x4b;
4694 tun_setup.config = 2;
Hartmut Hackmann58ef4f92007-04-27 12:31:12 -03004695
4696 saa7134_i2c_call_clients (dev, TUNER_SET_TYPE_ADDR,&tun_setup);
4697 data[2] = 0x68;
4698 }
4699 i2c_transfer(&dev->i2c_adap, &msg, 1);
4700 }
4701 break;
Michael Krufky993efa72007-11-15 10:34:33 -03004702 case SAA7134_BOARD_HAUPPAUGE_HVR1110:
4703 hauppauge_eeprom(dev, dev->eedata+0x80);
4704 /* break intentionally omitted */
Hartmut Hackmann587d2fd2006-10-06 19:13:50 -03004705 case SAA7134_BOARD_PINNACLE_PCTV_310i:
Simon Farnsworthb39423a2007-05-01 10:01:20 -03004706 case SAA7134_BOARD_KWORLD_DVBT_210:
Peter Hartshorn3dfb7292006-02-07 06:49:13 -02004707 case SAA7134_BOARD_TEVION_DVBT_220RF:
Hartmut Hackmannd4b0aba2005-11-08 21:38:44 -08004708 case SAA7134_BOARD_ASUSTeK_P7131_DUAL:
Hartmut Hackmannf3eec0c02007-03-14 20:33:55 -03004709 case SAA7134_BOARD_ASUSTeK_P7131_HYBRID_LNA:
Hartmut Hackmann5eda2272006-08-07 14:03:32 -03004710 case SAA7134_BOARD_MEDION_MD8800_QUADRO:
Peter Hartshorn3dfb7292006-02-07 06:49:13 -02004711 /* this is a hybrid board, initialize to analog mode
4712 * and configure firmware eeprom address
4713 */
Hartmut Hackmann90e9df72005-11-08 21:38:42 -08004714 {
Hartmut Hackmann58ef4f92007-04-27 12:31:12 -03004715 u8 data[] = { 0x3c, 0x33, 0x60};
Hartmut Hackmann90e9df72005-11-08 21:38:42 -08004716 struct i2c_msg msg = {.addr=0x08, .flags=0, .buf=data, .len = sizeof(data)};
4717 i2c_transfer(&dev->i2c_adap, &msg, 1);
4718 }
4719 break;
Nico Sabbi420f32f2006-03-03 12:11:28 -03004720 case SAA7134_BOARD_FLYDVB_TRIO:
Hartmut Hackmann293cdab2006-02-27 21:08:07 -03004721 {
4722 u8 data[] = { 0x3c, 0x33, 0x62};
4723 struct i2c_msg msg = {.addr=0x09, .flags=0, .buf=data, .len = sizeof(data)};
4724 i2c_transfer(&dev->i2c_adap, &msg, 1);
4725 }
4726 break;
Hartmut Hackmanndf42eaf2006-02-07 06:49:10 -02004727 case SAA7134_BOARD_ADS_DUO_CARDBUS_PTV331:
Hartmut Hackmannd95b8942006-03-27 19:39:30 -03004728 case SAA7134_BOARD_FLYDVBT_HYBRID_CARDBUS:
Hartmut Hackmann58ef4f92007-04-27 12:31:12 -03004729 /* initialize analog mode */
Hartmut Hackmanndf42eaf2006-02-07 06:49:10 -02004730 {
Hartmut Hackmann58ef4f92007-04-27 12:31:12 -03004731 u8 data[] = { 0x3c, 0x33, 0x6a};
Hartmut Hackmanndf42eaf2006-02-07 06:49:10 -02004732 struct i2c_msg msg = {.addr=0x08, .flags=0, .buf=data, .len = sizeof(data)};
4733 i2c_transfer(&dev->i2c_adap, &msg, 1);
4734 }
4735 break;
Hartmut Hackmann550a9a52006-11-15 21:31:54 -03004736 case SAA7134_BOARD_CINERGY_HT_PCMCIA:
Michael Krufky9de271e2007-01-16 18:36:40 -03004737 case SAA7134_BOARD_CINERGY_HT_PCI:
Hartmut Hackmann58ef4f92007-04-27 12:31:12 -03004738 /* initialize analog mode */
Hartmut Hackmann550a9a52006-11-15 21:31:54 -03004739 {
Hartmut Hackmann58ef4f92007-04-27 12:31:12 -03004740 u8 data[] = { 0x3c, 0x33, 0x68};
Hartmut Hackmann550a9a52006-11-15 21:31:54 -03004741 struct i2c_msg msg = {.addr=0x08, .flags=0, .buf=data, .len = sizeof(data)};
4742 i2c_transfer(&dev->i2c_adap, &msg, 1);
4743 }
4744 break;
Curt Meyers20b5ee52006-02-27 00:08:39 -03004745 case SAA7134_BOARD_KWORLD_ATSC110:
4746 {
4747 /* enable tuner */
4748 int i;
Michael Krufkyb9ee9ad2006-02-27 00:09:14 -03004749 static const u8 buffer [] = { 0x10,0x12,0x13,0x04,0x16,0x00,0x14,0x04,0x017,0x00 };
Curt Meyers20b5ee52006-02-27 00:08:39 -03004750 dev->i2c_client.addr = 0x0a;
4751 for (i = 0; i < 5; i++)
4752 if (2 != i2c_master_send(&dev->i2c_client,&buffer[i*2],2))
4753 printk(KERN_WARNING "%s: Unable to enable tuner(%i).\n",
4754 dev->name, i);
4755 }
4756 break;
Hartmut Hackmanncbb94522006-10-30 20:00:16 -03004757 case SAA7134_BOARD_VIDEOMATE_DVBT_200:
4758 case SAA7134_BOARD_VIDEOMATE_DVBT_200A:
4759 /* The T200 and the T200A share the same pci id. Consequently,
4760 * we are going to query eeprom to try to find out which one we
4761 * are actually looking at. */
4762
4763 /* Don't do this if the board was specifically selected with an
4764 * insmod option or if we have the default configuration T200*/
4765 if(!dev->autodetected || (dev->eedata[0x41] == 0xd0))
4766 break;
4767 if(dev->eedata[0x41] == 0x02) {
4768 /* Reconfigure board as T200A */
4769 dev->board = SAA7134_BOARD_VIDEOMATE_DVBT_200A;
4770 dev->tuner_type = saa7134_boards[dev->board].tuner_type;
4771 dev->tda9887_conf = saa7134_boards[dev->board].tda9887_conf;
4772 printk(KERN_INFO "%s: Reconfigured board as %s\n",
4773 dev->name, saa7134_boards[dev->board].name);
4774 } else {
4775 printk(KERN_WARNING "%s: Unexpected tuner type info: %x in eeprom\n",
4776 dev->name, dev->eedata[0x41]);
4777 break;
4778 }
4779 break;
Linus Torvalds1da177e2005-04-16 15:20:36 -07004780 }
4781 return 0;
4782}
4783
4784/* ----------------------------------------------------------- */
4785/*
4786 * Local variables:
4787 * c-basic-offset: 8
4788 * End:
4789 */