blob: 7d7f383b404f93b3e25e3b54854b40d596bfbaaa [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 },
Andrey J. Melnikoff (TEMHOTA)e8018c92008-01-07 05:17:39 -03003565 [SAA7134_BOARD_BEHOLD_401] = {
3566 .name = "Beholder BeholdTV 401",
3567 .audio_clock = 0x00187de7,
3568 .tuner_type = TUNER_PHILIPS_FQ1216ME,
3569 .radio_type = UNSET,
3570 .tuner_addr = ADDR_UNSET,
3571 .radio_addr = ADDR_UNSET,
3572 .inputs = {{
3573 .name = name_svideo,
3574 .vmux = 8,
3575 .amux = LINE1,
3576 },{
3577 .name = name_comp1,
3578 .vmux = 1,
3579 .amux = LINE1,
3580 },{
3581 .name = name_tv,
3582 .vmux = 3,
3583 .amux = LINE2,
3584 .tv = 1,
3585 }},
3586 .mute = {
3587 .name = name_mute,
3588 .amux = LINE1,
3589 },
3590 },
3591 [SAA7134_BOARD_BEHOLD_403] = {
3592 .name = "Beholder BeholdTV 403",
3593 .audio_clock = 0x00187de7,
3594 .tuner_type = TUNER_PHILIPS_FQ1216ME,
3595 .radio_type = UNSET,
3596 .tuner_addr = ADDR_UNSET,
3597 .radio_addr = ADDR_UNSET,
3598 .inputs = {{
3599 .name = name_svideo,
3600 .vmux = 8,
3601 .amux = LINE1,
3602 },{
3603 .name = name_comp1,
3604 .vmux = 1,
3605 .amux = LINE1,
3606 },{
3607 .name = name_tv,
3608 .vmux = 3,
3609 .amux = LINE2,
3610 .tv = 1,
3611 }},
3612 },
3613 [SAA7134_BOARD_BEHOLD_403FM] = {
3614 .name = "Beholder BeholdTV 403 FM",
3615 .audio_clock = 0x00187de7,
3616 .tuner_type = TUNER_PHILIPS_FQ1216ME,
3617 .radio_type = UNSET,
3618 .tuner_addr = ADDR_UNSET,
3619 .radio_addr = ADDR_UNSET,
3620 .inputs = {{
3621 .name = name_svideo,
3622 .vmux = 8,
3623 .amux = LINE1,
3624 },{
3625 .name = name_comp1,
3626 .vmux = 1,
3627 .amux = LINE1,
3628 },{
3629 .name = name_tv,
3630 .vmux = 3,
3631 .amux = LINE2,
3632 .tv = 1,
3633 }},
3634 .radio = {
3635 .name = name_radio,
3636 .amux = LINE2,
3637 },
3638 },
3639 [SAA7134_BOARD_BEHOLD_405] = {
3640 .name = "Beholder BeholdTV 405",
3641 .audio_clock = 0x00187de7,
3642 .tuner_type = TUNER_PHILIPS_FM1216ME_MK3,
3643 .radio_type = UNSET,
3644 .tuner_addr = ADDR_UNSET,
3645 .radio_addr = ADDR_UNSET,
3646 .tda9887_conf = TDA9887_PRESENT,
3647 .inputs = {{
3648 .name = name_svideo,
3649 .vmux = 8,
3650 .amux = LINE1,
3651 },{
3652 .name = name_comp1,
3653 .vmux = 3,
3654 .amux = LINE1,
3655 },{
3656 .name = name_tv,
3657 .vmux = 3,
3658 .amux = LINE2,
3659 .tv = 1,
3660 }},
3661 },
3662 [SAA7134_BOARD_BEHOLD_405FM] = {
3663 /* Sergey <skiv@orel.ru> */
3664 .name = "Beholder BeholdTV 405 FM",
3665 .audio_clock = 0x00187de7,
3666 .tuner_type = TUNER_PHILIPS_FM1216ME_MK3,
3667 .radio_type = UNSET,
3668 .tuner_addr = ADDR_UNSET,
3669 .radio_addr = ADDR_UNSET,
3670 .tda9887_conf = TDA9887_PRESENT,
3671 .inputs = {{
3672 .name = name_svideo,
3673 .vmux = 8,
3674 .amux = LINE1,
3675 },{
3676 .name = name_comp1,
3677 .vmux = 3,
3678 .amux = LINE1,
3679 },{
3680 .name = name_tv,
3681 .vmux = 3,
3682 .amux = LINE2,
3683 .tv = 1,
3684 }},
3685 .radio = {
3686 .name = name_radio,
3687 .amux = LINE2,
3688 },
3689 },
Mauro Carvalho Chehab1434bc02008-01-07 05:20:04 -03003690 [SAA7134_BOARD_BEHOLD_407] = {
3691 .name = "Beholder BeholdTV 407",
3692 .audio_clock = 0x00187de7,
3693 .tuner_type = TUNER_PHILIPS_FM1216ME_MK3,
3694 .radio_type = UNSET,
3695 .tuner_addr = ADDR_UNSET,
3696 .radio_addr = ADDR_UNSET,
3697 .tda9887_conf = TDA9887_PRESENT,
3698 .gpiomask = 0xc0c000,
3699 .inputs = {{
3700 .name = name_svideo,
3701 .vmux = 8,
3702 .amux = LINE1,
3703 .gpio = 0xc0c000,
3704 },{
3705 .name = name_comp1,
3706 .vmux = 1,
3707 .amux = LINE1,
3708 .gpio = 0xc0c000,
3709 },{
3710 .name = name_tv,
3711 .vmux = 3,
3712 .amux = TV,
3713 .tv = 1,
3714 .gpio = 0xc0c000,
3715 }},
3716 },
Andrey J. Melnikoff (TEMHOTA)e8018c92008-01-07 05:17:39 -03003717 [SAA7134_BOARD_BEHOLD_407FM] = {
3718 .name = "Beholder BeholdTV 407 FM",
3719 .audio_clock = 0x00187de7,
3720 .tuner_type = TUNER_PHILIPS_FM1216ME_MK3,
3721 .radio_type = UNSET,
3722 .tuner_addr = ADDR_UNSET,
3723 .radio_addr = ADDR_UNSET,
3724 .tda9887_conf = TDA9887_PRESENT,
3725 .gpiomask = 0xc0c000,
3726 .inputs = {{
3727 .name = name_svideo,
3728 .vmux = 8,
3729 .amux = LINE1,
3730 .gpio = 0xc0c000,
3731 },{
3732 .name = name_comp1,
3733 .vmux = 1,
3734 .amux = LINE1,
3735 .gpio = 0xc0c000,
3736 },{
3737 .name = name_tv,
3738 .vmux = 3,
3739 .amux = TV,
3740 .tv = 1,
3741 .gpio = 0xc0c000,
3742 }},
3743 .radio = {
3744 .name = name_radio,
3745 .amux = LINE2,
3746 .gpio = 0xc0c000,
3747 },
3748 },
3749 [SAA7134_BOARD_BEHOLD_409] = {
3750 .name = "Beholder BeholdTV 409",
3751 .audio_clock = 0x00187de7,
3752 .tuner_type = TUNER_PHILIPS_FM1216ME_MK3,
3753 .radio_type = UNSET,
3754 .tuner_addr = ADDR_UNSET,
3755 .radio_addr = ADDR_UNSET,
3756 .tda9887_conf = TDA9887_PRESENT,
3757 .inputs = {{
3758 .name = name_tv,
3759 .vmux = 3,
3760 .amux = TV,
3761 .tv = 1,
3762 },{
3763 .name = name_comp1,
3764 .vmux = 1,
3765 .amux = LINE1,
3766 },{
3767 .name = name_svideo,
3768 .vmux = 8,
3769 .amux = LINE1,
3770 }},
3771 },
3772 [SAA7134_BOARD_BEHOLD_505FM] = {
3773 .name = "Beholder BeholdTV 505 FM/RDS",
3774 .audio_clock = 0x00200000,
3775 .tuner_type = TUNER_PHILIPS_FM1216ME_MK3,
3776 .radio_type = UNSET,
3777 .tuner_addr = ADDR_UNSET,
3778 .radio_addr = ADDR_UNSET,
3779 .tda9887_conf = TDA9887_PRESENT,
3780 .inputs = {{
3781 .name = name_tv,
3782 .vmux = 3,
3783 .amux = LINE2,
3784 .tv = 1,
3785 },{
3786 .name = name_comp1,
3787 .vmux = 1,
3788 .amux = LINE1,
3789 },{
3790 .name = name_svideo,
3791 .vmux = 8,
3792 .amux = LINE1,
3793 }},
3794 .mute = {
3795 .name = name_mute,
3796 .amux = LINE1,
3797 },
3798 .radio = {
3799 .name = name_radio,
3800 .amux = LINE2,
3801 },
3802 },
3803 [SAA7134_BOARD_BEHOLD_507_9FM] = {
3804 .name = "Beholder BeholdTV 507 FM/RDS / BeholdTV 509 FM",
3805 .audio_clock = 0x00187de7,
3806 .tuner_type = TUNER_PHILIPS_FM1216ME_MK3,
3807 .radio_type = UNSET,
3808 .tuner_addr = ADDR_UNSET,
3809 .radio_addr = ADDR_UNSET,
3810 .tda9887_conf = TDA9887_PRESENT,
3811 .inputs = {{
3812 .name = name_tv,
3813 .vmux = 3,
3814 .amux = TV,
3815 .tv = 1,
3816 },{
3817 .name = name_comp1,
3818 .vmux = 1,
3819 .amux = LINE1,
3820 },{
3821 .name = name_svideo,
3822 .vmux = 8,
3823 .amux = LINE1,
3824 }},
3825 .radio = {
3826 .name = name_radio,
3827 .amux = LINE2,
3828 },
3829 },
3830 [SAA7134_BOARD_BEHOLD_COLUMBUS_TVFM] = {
3831 .name = "Beholder BeholdTV Columbus TVFM",
3832 .audio_clock = 0x00187de7,
3833 .tuner_type = TUNER_ALPS_TSBE5_PAL,
3834 .radio_type = UNSET,
3835 .tuner_addr = ADDR_UNSET,
3836 .radio_addr = ADDR_UNSET,
3837 .tda9887_conf = TDA9887_PRESENT,
3838 .inputs = {{
3839 .name = name_tv,
3840 .vmux = 3,
3841 .amux = TV,
3842 .tv = 1,
3843 },{
3844 .name = name_comp1,
3845 .vmux = 1,
3846 .amux = LINE1,
3847 },{
3848 .name = name_svideo,
3849 .vmux = 8,
3850 .amux = LINE1,
3851 }},
3852 .radio = {
3853 .name = name_radio,
3854 .amux = LINE2,
3855 },
3856 },
3857 [SAA7134_BOARD_BEHOLD_607_9FM] = {
3858 /* Andrey Melnikoff <temnota@kmv.ru> */
3859 .name = "Beholder BeholdTV 607 / BeholdTV 609",
3860 .audio_clock = 0x00187de7,
3861 .tuner_type = TUNER_PHILIPS_FM1216ME_MK3,
3862 .radio_type = UNSET,
3863 .tuner_addr = ADDR_UNSET,
3864 .radio_addr = ADDR_UNSET,
3865 .tda9887_conf = TDA9887_PRESENT,
3866 .inputs = {{
3867 .name = name_tv,
3868 .vmux = 3,
3869 .amux = TV,
3870 .tv = 1,
3871 },{
3872 .name = name_comp1,
3873 .vmux = 1,
3874 .amux = LINE1,
3875 },{
3876 .name = name_svideo,
3877 .vmux = 8,
3878 .amux = LINE1,
3879 }},
3880 .radio = {
3881 .name = name_radio,
3882 .amux = LINE2,
3883 },
3884 },
3885 [SAA7134_BOARD_BEHOLD_M6] = {
3886 /* Igor Kuznetsov <igk@igk.ru> */
3887 /* Andrey Melnikoff <temnota@kmv.ru> */
3888 .name = "Beholder BeholdTV M6 / BeholdTV M6 Extra",
3889 .audio_clock = 0x00187de7,
3890 .tuner_type = TUNER_PHILIPS_FM1216ME_MK3,
3891 .radio_type = UNSET,
3892 .tuner_addr = ADDR_UNSET,
3893 .radio_addr = ADDR_UNSET,
3894 .tda9887_conf = TDA9887_PRESENT,
3895 .inputs = {{
3896 .name = name_tv,
3897 .vmux = 3,
3898 .amux = TV,
3899 .tv = 1,
3900 },{
3901 .name = name_comp1,
3902 .vmux = 1,
3903 .amux = LINE1,
3904 },{
3905 .name = name_svideo,
3906 .vmux = 8,
3907 .amux = LINE1,
3908 }},
3909 .radio = {
3910 .name = name_radio,
3911 .amux = LINE2,
3912 },
3913 .mpeg = SAA7134_MPEG_EMPRESS,
3914 },
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07003915};
3916
Linus Torvalds1da177e2005-04-16 15:20:36 -07003917const unsigned int saa7134_bcount = ARRAY_SIZE(saa7134_boards);
3918
3919/* ------------------------------------------------------------------ */
3920/* PCI ids + subsystem IDs */
3921
3922struct pci_device_id saa7134_pci_tbl[] = {
3923 {
3924 .vendor = PCI_VENDOR_ID_PHILIPS,
3925 .device = PCI_DEVICE_ID_PHILIPS_SAA7134,
3926 .subvendor = PCI_VENDOR_ID_PHILIPS,
3927 .subdevice = 0x2001,
3928 .driver_data = SAA7134_BOARD_PROTEUS_PRO,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07003929 },{
Linus Torvalds1da177e2005-04-16 15:20:36 -07003930 .vendor = PCI_VENDOR_ID_PHILIPS,
3931 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
3932 .subvendor = PCI_VENDOR_ID_PHILIPS,
3933 .subdevice = 0x2001,
3934 .driver_data = SAA7134_BOARD_PROTEUS_PRO,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07003935 },{
Linus Torvalds1da177e2005-04-16 15:20:36 -07003936 .vendor = PCI_VENDOR_ID_PHILIPS,
3937 .device = PCI_DEVICE_ID_PHILIPS_SAA7134,
3938 .subvendor = PCI_VENDOR_ID_PHILIPS,
3939 .subdevice = 0x6752,
3940 .driver_data = SAA7134_BOARD_EMPRESS,
3941 },{
3942 .vendor = PCI_VENDOR_ID_PHILIPS,
3943 .device = PCI_DEVICE_ID_PHILIPS_SAA7134,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07003944 .subvendor = 0x1131,
3945 .subdevice = 0x4e85,
Linus Torvalds1da177e2005-04-16 15:20:36 -07003946 .driver_data = SAA7134_BOARD_MONSTERTV,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07003947 },{
3948 .vendor = PCI_VENDOR_ID_PHILIPS,
3949 .device = PCI_DEVICE_ID_PHILIPS_SAA7134,
Michael Krufky7df64e82005-11-08 21:36:16 -08003950 .subvendor = 0x153b,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07003951 .subdevice = 0x1142,
3952 .driver_data = SAA7134_BOARD_CINERGY400,
3953 },{
3954 .vendor = PCI_VENDOR_ID_PHILIPS,
3955 .device = PCI_DEVICE_ID_PHILIPS_SAA7134,
Michael Krufky7df64e82005-11-08 21:36:16 -08003956 .subvendor = 0x153b,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07003957 .subdevice = 0x1143,
3958 .driver_data = SAA7134_BOARD_CINERGY600,
3959 },{
3960 .vendor = PCI_VENDOR_ID_PHILIPS,
3961 .device = PCI_DEVICE_ID_PHILIPS_SAA7134,
Michael Krufky7df64e82005-11-08 21:36:16 -08003962 .subvendor = 0x153b,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07003963 .subdevice = 0x1158,
3964 .driver_data = SAA7134_BOARD_CINERGY600_MK3,
3965 },{
Linus Torvalds1da177e2005-04-16 15:20:36 -07003966 .vendor = PCI_VENDOR_ID_PHILIPS,
3967 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
3968 .subvendor = 0x153b,
3969 .subdevice = 0x1162,
3970 .driver_data = SAA7134_BOARD_CINERGY400_CARDBUS,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07003971 },{
Linus Torvalds1da177e2005-04-16 15:20:36 -07003972 .vendor = PCI_VENDOR_ID_PHILIPS,
3973 .device = PCI_DEVICE_ID_PHILIPS_SAA7134,
Zac Bowlingf49ba8d2006-06-19 19:49:20 -03003974 .subvendor = 0x5169,
3975 .subdevice = 0x0138,
3976 .driver_data = SAA7134_BOARD_FLYVIDEO3000_NTSC,
3977 },{
3978 .vendor = PCI_VENDOR_ID_PHILIPS,
3979 .device = PCI_DEVICE_ID_PHILIPS_SAA7134,
Linus Torvalds1da177e2005-04-16 15:20:36 -07003980 .subvendor = 0x5168,
3981 .subdevice = 0x0138,
3982 .driver_data = SAA7134_BOARD_FLYVIDEO3000,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07003983 },{
Linus Torvalds1da177e2005-04-16 15:20:36 -07003984 .vendor = PCI_VENDOR_ID_PHILIPS,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07003985 .device = PCI_DEVICE_ID_PHILIPS_SAA7134,
3986 .subvendor = 0x4e42, /* "Typhoon PCI Capture TV Card" Art.No. 50673 */
3987 .subdevice = 0x0138,
3988 .driver_data = SAA7134_BOARD_FLYVIDEO3000,
3989 },{
Linus Torvalds1da177e2005-04-16 15:20:36 -07003990 .vendor = PCI_VENDOR_ID_PHILIPS,
3991 .device = PCI_DEVICE_ID_PHILIPS_SAA7130,
3992 .subvendor = 0x5168,
3993 .subdevice = 0x0138,
3994 .driver_data = SAA7134_BOARD_FLYVIDEO2000,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07003995 },{
Linus Torvalds1da177e2005-04-16 15:20:36 -07003996 .vendor = PCI_VENDOR_ID_PHILIPS,
Peter Missel10b7a902006-01-23 17:11:06 -02003997 .device = PCI_DEVICE_ID_PHILIPS_SAA7130,
3998 .subvendor = 0x4e42, /* Typhoon */
3999 .subdevice = 0x0138, /* LifeView FlyTV Prime30 OEM */
4000 .driver_data = SAA7134_BOARD_FLYVIDEO2000,
4001 },{
4002 .vendor = PCI_VENDOR_ID_PHILIPS,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07004003 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
Linus Torvalds1da177e2005-04-16 15:20:36 -07004004 .subvendor = 0x5168,
4005 .subdevice = 0x0212, /* minipci, LR212 */
4006 .driver_data = SAA7134_BOARD_FLYTVPLATINUM_MINI,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07004007 },{
Linus Torvalds1da177e2005-04-16 15:20:36 -07004008 .vendor = PCI_VENDOR_ID_PHILIPS,
4009 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
Mauro Carvalho Chehab058afaf2005-11-08 21:36:49 -08004010 .subvendor = 0x14c0,
4011 .subdevice = 0x1212, /* minipci, LR1212 */
4012 .driver_data = SAA7134_BOARD_FLYTVPLATINUM_MINI2,
4013 },{
4014 .vendor = PCI_VENDOR_ID_PHILIPS,
4015 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
Glen Gray2d14f782005-11-08 21:36:12 -08004016 .subvendor = 0x4e42,
4017 .subdevice = 0x0212, /* OEM minipci, LR212 */
4018 .driver_data = SAA7134_BOARD_FLYTVPLATINUM_MINI,
4019 },{
4020 .vendor = PCI_VENDOR_ID_PHILIPS,
4021 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
Peter Missel10e92062005-05-01 08:59:21 -07004022 .subvendor = 0x5168, /* Animation Technologies (LifeView) */
Simon Farnsworthb39423a2007-05-01 10:01:20 -03004023 .subdevice = 0x0214, /* Standard PCI, LR214 Rev E and earlier (SAA7135) */
4024 .driver_data = SAA7134_BOARD_FLYTVPLATINUM_FM,
4025 },{
4026 .vendor = PCI_VENDOR_ID_PHILIPS,
4027 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
4028 .subvendor = 0x5168, /* Animation Technologies (LifeView) */
4029 .subdevice = 0x5214, /* Standard PCI, LR214 Rev F onwards (SAA7131) */
Linus Torvalds1da177e2005-04-16 15:20:36 -07004030 .driver_data = SAA7134_BOARD_FLYTVPLATINUM_FM,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07004031 },{
Linus Torvalds1da177e2005-04-16 15:20:36 -07004032 .vendor = PCI_VENDOR_ID_PHILIPS,
Peter Missel10e92062005-05-01 08:59:21 -07004033 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
4034 .subvendor = 0x1489, /* KYE */
4035 .subdevice = 0x0214, /* Genius VideoWonder ProTV */
4036 .driver_data = SAA7134_BOARD_FLYTVPLATINUM_FM, /* is an LR214WF actually */
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07004037 },{
Peter Missel10e92062005-05-01 08:59:21 -07004038 .vendor = PCI_VENDOR_ID_PHILIPS,
Linus Torvalds1da177e2005-04-16 15:20:36 -07004039 .device = PCI_DEVICE_ID_PHILIPS_SAA7134,
4040 .subvendor = 0x16be,
4041 .subdevice = 0x0003,
4042 .driver_data = SAA7134_BOARD_MD7134,
4043 },{
4044 .vendor = PCI_VENDOR_ID_PHILIPS,
4045 .device = PCI_DEVICE_ID_PHILIPS_SAA7130,
4046 .subvendor = 0x1048,
4047 .subdevice = 0x226b,
4048 .driver_data = SAA7134_BOARD_ELSA,
4049 },{
4050 .vendor = PCI_VENDOR_ID_PHILIPS,
4051 .device = PCI_DEVICE_ID_PHILIPS_SAA7130,
4052 .subvendor = 0x1048,
Michael Krufky9a7871b2006-02-27 15:22:49 -03004053 .subdevice = 0x226a,
Linus Torvalds1da177e2005-04-16 15:20:36 -07004054 .driver_data = SAA7134_BOARD_ELSA_500TV,
4055 },{
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07004056 .vendor = PCI_VENDOR_ID_PHILIPS,
Tamuki Shoichid0456d12006-02-27 00:08:04 -03004057 .device = PCI_DEVICE_ID_PHILIPS_SAA7130,
Michael Krufkyba524292006-02-27 14:38:17 -03004058 .subvendor = 0x1048,
4059 .subdevice = 0x226c,
Tamuki Shoichid0456d12006-02-27 00:08:04 -03004060 .driver_data = SAA7134_BOARD_ELSA_700TV,
4061 },{
4062 .vendor = PCI_VENDOR_ID_PHILIPS,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07004063 .device = PCI_DEVICE_ID_PHILIPS_SAA7134,
4064 .subvendor = PCI_VENDOR_ID_ASUSTEK,
4065 .subdevice = 0x4842,
4066 .driver_data = SAA7134_BOARD_ASUSTeK_TVFM7134,
Linus Torvalds1da177e2005-04-16 15:20:36 -07004067 },{
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07004068 .vendor = PCI_VENDOR_ID_PHILIPS,
4069 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
4070 .subvendor = PCI_VENDOR_ID_ASUSTEK,
4071 .subdevice = 0x4845,
4072 .driver_data = SAA7134_BOARD_ASUSTeK_TVFM7135,
Linus Torvalds1da177e2005-04-16 15:20:36 -07004073 },{
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07004074 .vendor = PCI_VENDOR_ID_PHILIPS,
4075 .device = PCI_DEVICE_ID_PHILIPS_SAA7134,
4076 .subvendor = PCI_VENDOR_ID_ASUSTEK,
4077 .subdevice = 0x4830,
4078 .driver_data = SAA7134_BOARD_ASUSTeK_TVFM7134,
Linus Torvalds1da177e2005-04-16 15:20:36 -07004079 },{
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07004080 .vendor = PCI_VENDOR_ID_PHILIPS,
4081 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
4082 .subvendor = PCI_VENDOR_ID_ASUSTEK,
4083 .subdevice = 0x4843,
4084 .driver_data = SAA7134_BOARD_ASUSTEK_TVFM7133,
4085 },{
4086 .vendor = PCI_VENDOR_ID_PHILIPS,
4087 .device = PCI_DEVICE_ID_PHILIPS_SAA7134,
4088 .subvendor = PCI_VENDOR_ID_ASUSTEK,
4089 .subdevice = 0x4840,
4090 .driver_data = SAA7134_BOARD_ASUSTeK_TVFM7134,
4091 },{
Linus Torvalds1da177e2005-04-16 15:20:36 -07004092 .vendor = PCI_VENDOR_ID_PHILIPS,
4093 .device = PCI_DEVICE_ID_PHILIPS_SAA7134,
4094 .subvendor = PCI_VENDOR_ID_PHILIPS,
4095 .subdevice = 0xfe01,
4096 .driver_data = SAA7134_BOARD_TVSTATION_RDS,
4097 },{
4098 .vendor = PCI_VENDOR_ID_PHILIPS,
4099 .device = PCI_DEVICE_ID_PHILIPS_SAA7134,
4100 .subvendor = 0x1894,
4101 .subdevice = 0xfe01,
4102 .driver_data = SAA7134_BOARD_TVSTATION_RDS,
4103 },{
4104 .vendor = PCI_VENDOR_ID_PHILIPS,
4105 .device = PCI_DEVICE_ID_PHILIPS_SAA7134,
4106 .subvendor = 0x1894,
4107 .subdevice = 0xa006,
4108 .driver_data = SAA7134_BOARD_TVSTATION_DVR,
4109 },{
4110 .vendor = PCI_VENDOR_ID_PHILIPS,
4111 .device = PCI_DEVICE_ID_PHILIPS_SAA7134,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07004112 .subvendor = 0x1131,
4113 .subdevice = 0x7133,
Linus Torvalds1da177e2005-04-16 15:20:36 -07004114 .driver_data = SAA7134_BOARD_VA1000POWER,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07004115 },{
Linus Torvalds1da177e2005-04-16 15:20:36 -07004116 .vendor = PCI_VENDOR_ID_PHILIPS,
4117 .device = PCI_DEVICE_ID_PHILIPS_SAA7130,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07004118 .subvendor = PCI_VENDOR_ID_PHILIPS,
4119 .subdevice = 0x2001,
Linus Torvalds1da177e2005-04-16 15:20:36 -07004120 .driver_data = SAA7134_BOARD_10MOONSTVMASTER,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07004121 },{
Linus Torvalds1da177e2005-04-16 15:20:36 -07004122 .vendor = PCI_VENDOR_ID_PHILIPS,
4123 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07004124 .subvendor = 0x185b,
4125 .subdevice = 0xc100,
Linus Torvalds1da177e2005-04-16 15:20:36 -07004126 .driver_data = SAA7134_BOARD_VIDEOMATE_TV,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07004127 },{
Linus Torvalds1da177e2005-04-16 15:20:36 -07004128 .vendor = PCI_VENDOR_ID_PHILIPS,
4129 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07004130 .subvendor = 0x185b,
4131 .subdevice = 0xc100,
Linus Torvalds1da177e2005-04-16 15:20:36 -07004132 .driver_data = SAA7134_BOARD_VIDEOMATE_TV_GOLD_PLUS,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07004133 },{
Linus Torvalds1da177e2005-04-16 15:20:36 -07004134 .vendor = PCI_VENDOR_ID_PHILIPS,
4135 .device = PCI_DEVICE_ID_PHILIPS_SAA7130,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07004136 .subvendor = PCI_VENDOR_ID_MATROX,
4137 .subdevice = 0x48d0,
Linus Torvalds1da177e2005-04-16 15:20:36 -07004138 .driver_data = SAA7134_BOARD_CRONOS_PLUS,
4139 },{
4140 .vendor = PCI_VENDOR_ID_PHILIPS,
4141 .device = PCI_DEVICE_ID_PHILIPS_SAA7134,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07004142 .subvendor = 0x1461, /* Avermedia Technologies Inc */
4143 .subdevice = 0xa70b,
Linus Torvalds1da177e2005-04-16 15:20:36 -07004144 .driver_data = SAA7134_BOARD_MD2819,
4145 },{
4146 .vendor = PCI_VENDOR_ID_PHILIPS,
4147 .device = PCI_DEVICE_ID_PHILIPS_SAA7130,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07004148 .subvendor = 0x1461, /* Avermedia Technologies Inc */
4149 .subdevice = 0x2115,
Linus Torvalds1da177e2005-04-16 15:20:36 -07004150 .driver_data = SAA7134_BOARD_AVERMEDIA_STUDIO_305,
4151 },{
4152 .vendor = PCI_VENDOR_ID_PHILIPS,
4153 .device = PCI_DEVICE_ID_PHILIPS_SAA7130,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07004154 .subvendor = 0x1461, /* Avermedia Technologies Inc */
4155 .subdevice = 0x2108,
Linus Torvalds1da177e2005-04-16 15:20:36 -07004156 .driver_data = SAA7134_BOARD_AVERMEDIA_305,
4157 },{
4158 .vendor = PCI_VENDOR_ID_PHILIPS,
4159 .device = PCI_DEVICE_ID_PHILIPS_SAA7130,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07004160 .subvendor = 0x1461, /* Avermedia Technologies Inc */
4161 .subdevice = 0x10ff,
Linus Torvalds1da177e2005-04-16 15:20:36 -07004162 .driver_data = SAA7134_BOARD_AVERMEDIA_DVD_EZMAKER,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07004163 },{
Linus Torvalds1da177e2005-04-16 15:20:36 -07004164 /* AVerMedia CardBus */
4165 .vendor = PCI_VENDOR_ID_PHILIPS,
4166 .device = PCI_DEVICE_ID_PHILIPS_SAA7134,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07004167 .subvendor = 0x1461, /* Avermedia Technologies Inc */
4168 .subdevice = 0xd6ee,
Linus Torvalds1da177e2005-04-16 15:20:36 -07004169 .driver_data = SAA7134_BOARD_AVERMEDIA_CARDBUS,
4170 },{
4171 /* TransGear 3000TV */
4172 .vendor = PCI_VENDOR_ID_PHILIPS,
4173 .device = PCI_DEVICE_ID_PHILIPS_SAA7130,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07004174 .subvendor = 0x1461, /* Avermedia Technologies Inc */
4175 .subdevice = 0x050c,
Linus Torvalds1da177e2005-04-16 15:20:36 -07004176 .driver_data = SAA7134_BOARD_TG3000TV,
4177 },{
Linus Torvalds1da177e2005-04-16 15:20:36 -07004178 .vendor = PCI_VENDOR_ID_PHILIPS,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07004179 .device = PCI_DEVICE_ID_PHILIPS_SAA7134,
4180 .subvendor = 0x11bd,
4181 .subdevice = 0x002b,
4182 .driver_data = SAA7134_BOARD_PINNACLE_PCTV_STEREO,
4183 },{
4184 .vendor = PCI_VENDOR_ID_PHILIPS,
4185 .device = PCI_DEVICE_ID_PHILIPS_SAA7134,
4186 .subvendor = 0x11bd,
4187 .subdevice = 0x002d,
4188 .driver_data = SAA7134_BOARD_PINNACLE_300I_DVBT_PAL,
4189 },{
4190 .vendor = PCI_VENDOR_ID_PHILIPS,
4191 .device = PCI_DEVICE_ID_PHILIPS_SAA7134,
4192 .subvendor = 0x1019,
4193 .subdevice = 0x4cb4,
4194 .driver_data = SAA7134_BOARD_ECS_TVP3XP,
4195 },{
4196 .vendor = PCI_VENDOR_ID_PHILIPS,
4197 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
4198 .subvendor = 0x1019,
4199 .subdevice = 0x4cb5,
4200 .driver_data = SAA7134_BOARD_ECS_TVP3XP_4CB5,
4201 },{
4202 .vendor = PCI_VENDOR_ID_PHILIPS,
Simon Farnsworthb39423a2007-05-01 10:01:20 -03004203 .device = PCI_DEVICE_ID_PHILIPS_SAA7134,
4204 .subvendor = 0x1019,
4205 .subdevice = 0x4cb6,
4206 .driver_data = SAA7134_BOARD_ECS_TVP3XP_4CB6,
4207 },{
4208 .vendor = PCI_VENDOR_ID_PHILIPS,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07004209 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
4210 .subvendor = 0x12ab,
4211 .subdevice = 0x0800,
4212 .driver_data = SAA7134_BOARD_UPMOST_PURPLE_TV,
Linus Torvalds1da177e2005-04-16 15:20:36 -07004213 },{
4214 .vendor = PCI_VENDOR_ID_PHILIPS,
4215 .device = PCI_DEVICE_ID_PHILIPS_SAA7130,
Michael Krufky7df64e82005-11-08 21:36:16 -08004216 .subvendor = 0x153b,
Linus Torvalds1da177e2005-04-16 15:20:36 -07004217 .subdevice = 0x1152,
4218 .driver_data = SAA7134_BOARD_CINERGY200,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07004219 },{
Linus Torvalds1da177e2005-04-16 15:20:36 -07004220 .vendor = PCI_VENDOR_ID_PHILIPS,
4221 .device = PCI_DEVICE_ID_PHILIPS_SAA7130,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07004222 .subvendor = 0x185b,
4223 .subdevice = 0xc100,
Linus Torvalds1da177e2005-04-16 15:20:36 -07004224 .driver_data = SAA7134_BOARD_VIDEOMATE_TV_PVR,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07004225 },{
Linus Torvalds1da177e2005-04-16 15:20:36 -07004226 .vendor = PCI_VENDOR_ID_PHILIPS,
Linus Torvalds1da177e2005-04-16 15:20:36 -07004227 .device = PCI_DEVICE_ID_PHILIPS_SAA7134,
4228 .subvendor = 0x1461, /* Avermedia Technologies Inc */
4229 .subdevice = 0x9715,
Mauro Carvalho Chehabac19ecc2005-06-23 22:05:09 -07004230 .driver_data = SAA7134_BOARD_AVERMEDIA_STUDIO_307,
4231 },{
4232 .vendor = PCI_VENDOR_ID_PHILIPS,
4233 .device = PCI_DEVICE_ID_PHILIPS_SAA7134,
4234 .subvendor = 0x1461, /* Avermedia Technologies Inc */
4235 .subdevice = 0xa70a,
Linus Torvalds1da177e2005-04-16 15:20:36 -07004236 .driver_data = SAA7134_BOARD_AVERMEDIA_307,
4237 },{
4238 .vendor = PCI_VENDOR_ID_PHILIPS,
4239 .device = PCI_DEVICE_ID_PHILIPS_SAA7134,
4240 .subvendor = 0x185b,
4241 .subdevice = 0xc200,
4242 .driver_data = SAA7134_BOARD_VIDEOMATE_GOLD_PLUS,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07004243 },{
Linus Torvalds1da177e2005-04-16 15:20:36 -07004244 .vendor = PCI_VENDOR_ID_PHILIPS,
4245 .device = PCI_DEVICE_ID_PHILIPS_SAA7134,
4246 .subvendor = 0x1540,
4247 .subdevice = 0x9524,
4248 .driver_data = SAA7134_BOARD_PROVIDEO_PV952,
4249
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07004250 },{
Linus Torvalds1da177e2005-04-16 15:20:36 -07004251 .vendor = PCI_VENDOR_ID_PHILIPS,
4252 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
4253 .subvendor = 0x5168,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07004254 .subdevice = 0x0502, /* Cardbus version */
Peter Missel10b7a902006-01-23 17:11:06 -02004255 .driver_data = SAA7134_BOARD_FLYDVBT_DUO_CARDBUS,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07004256 },{
4257 .vendor = PCI_VENDOR_ID_PHILIPS,
4258 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
4259 .subvendor = 0x5168,
4260 .subdevice = 0x0306, /* PCI version */
Linus Torvalds1da177e2005-04-16 15:20:36 -07004261 .driver_data = SAA7134_BOARD_FLYDVBTDUO,
Mauro Carvalho Chehabac19ecc2005-06-23 22:05:09 -07004262 },{
4263 .vendor = PCI_VENDOR_ID_PHILIPS,
4264 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
4265 .subvendor = 0x1461, /* Avermedia Technologies Inc */
4266 .subdevice = 0xf31f,
4267 .driver_data = SAA7134_BOARD_AVERMEDIA_GO_007_FM,
4268
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07004269 },{
Mauro Carvalho Chehabac19ecc2005-06-23 22:05:09 -07004270 .vendor = PCI_VENDOR_ID_PHILIPS,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07004271 .device = PCI_DEVICE_ID_PHILIPS_SAA7130,
4272 .subvendor = PCI_VENDOR_ID_PHILIPS,
4273 .subdevice = 0x2004,
4274 .driver_data = SAA7134_BOARD_PHILIPS_TOUGH,
4275 },{
4276 .vendor = PCI_VENDOR_ID_PHILIPS,
4277 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
Mauro Carvalho Chehabac19ecc2005-06-23 22:05:09 -07004278 .subvendor = 0x1421,
4279 .subdevice = 0x0350, /* PCI version */
4280 .driver_data = SAA7134_BOARD_ADS_INSTANT_TV,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07004281 },{
Mauro Carvalho Chehabac19ecc2005-06-23 22:05:09 -07004282 .vendor = PCI_VENDOR_ID_PHILIPS,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07004283 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
Mauro Carvalho Chehabac19ecc2005-06-23 22:05:09 -07004284 .subvendor = 0x1421,
Ricardo Cerqueira41d70c22006-01-09 15:25:34 -02004285 .subdevice = 0x0351, /* PCI version, new revision */
4286 .driver_data = SAA7134_BOARD_ADS_INSTANT_TV,
4287 },{
4288 .vendor = PCI_VENDOR_ID_PHILIPS,
4289 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
4290 .subvendor = 0x1421,
Mauro Carvalho Chehabac19ecc2005-06-23 22:05:09 -07004291 .subdevice = 0x0370, /* cardbus version */
4292 .driver_data = SAA7134_BOARD_ADS_INSTANT_TV,
Hartmut Hackmannd4b0aba2005-11-08 21:38:44 -08004293 },{
4294 .vendor = PCI_VENDOR_ID_PHILIPS,
4295 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
4296 .subvendor = 0x1421,
4297 .subdevice = 0x1370, /* cardbus version */
4298 .driver_data = SAA7134_BOARD_ADS_INSTANT_TV,
Linus Torvalds1da177e2005-04-16 15:20:36 -07004299
Peter Missel10b7a902006-01-23 17:11:06 -02004300 },{
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07004301 .vendor = PCI_VENDOR_ID_PHILIPS,
4302 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
Peter Missel10b7a902006-01-23 17:11:06 -02004303 .subvendor = 0x4e42, /* Typhoon */
4304 .subdevice = 0x0502, /* LifeView LR502 OEM */
4305 .driver_data = SAA7134_BOARD_FLYDVBT_DUO_CARDBUS,
Mauro Carvalho Chehab2f180712005-09-09 13:03:46 -07004306 },{
4307 .vendor = PCI_VENDOR_ID_PHILIPS,
4308 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
4309 .subvendor = 0x1043,
4310 .subdevice = 0x0210, /* mini pci NTSC version */
4311 .driver_data = SAA7134_BOARD_FLYTV_DIGIMATRIX,
4312 },{
4313 .vendor = PCI_VENDOR_ID_PHILIPS,
4314 .device = PCI_DEVICE_ID_PHILIPS_SAA7134,
4315 .subvendor = 0x1043,
4316 .subdevice = 0x0210, /* mini pci PAL/SECAM version */
Michael Krufky5d5c9902005-11-08 21:38:08 -08004317 .driver_data = SAA7134_BOARD_ASUSTEK_DIGIMATRIX_TV,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07004318
4319 },{
Nickolay V. Shmyreva8ff4172005-11-08 21:36:16 -08004320 .vendor = PCI_VENDOR_ID_PHILIPS,
4321 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
4322 .subvendor = 0x0000, /* It shouldn't break anything, since subdevice id seems unique */
4323 .subdevice = 0x4091,
4324 .driver_data = SAA7134_BOARD_BEHOLD_409FM,
Mauro Carvalho Chehab4ac97912005-11-08 21:37:43 -08004325 },{
4326 .vendor = PCI_VENDOR_ID_PHILIPS,
4327 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
4328 .subvendor = 0x5456, /* GoTView */
4329 .subdevice = 0x7135,
4330 .driver_data = SAA7134_BOARD_GOTVIEW_7135,
4331 },{
Hartmut Hackmann2cf36ac2005-11-08 21:36:32 -08004332 .vendor = PCI_VENDOR_ID_PHILIPS,
4333 .device = PCI_DEVICE_ID_PHILIPS_SAA7134,
4334 .subvendor = PCI_VENDOR_ID_PHILIPS,
4335 .subdevice = 0x2004,
4336 .driver_data = SAA7134_BOARD_PHILIPS_EUROPA,
Mauro Carvalho Chehab4ac97912005-11-08 21:37:43 -08004337 },{
Hartmut Hackmann2cf36ac2005-11-08 21:36:32 -08004338 .vendor = PCI_VENDOR_ID_PHILIPS,
4339 .device = PCI_DEVICE_ID_PHILIPS_SAA7134,
4340 .subvendor = 0x185b,
4341 .subdevice = 0xc900,
4342 .driver_data = SAA7134_BOARD_VIDEOMATE_DVBT_300,
Mauro Carvalho Chehab4ac97912005-11-08 21:37:43 -08004343 },{
Hartmut Hackmann2cf36ac2005-11-08 21:36:32 -08004344 .vendor = PCI_VENDOR_ID_PHILIPS,
4345 .device = PCI_DEVICE_ID_PHILIPS_SAA7130,
4346 .subvendor = 0x185b,
4347 .subdevice = 0xc901,
4348 .driver_data = SAA7134_BOARD_VIDEOMATE_DVBT_200,
4349 },{
Mauro Carvalho Chehab4ac97912005-11-08 21:37:43 -08004350 .vendor = PCI_VENDOR_ID_PHILIPS,
4351 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
4352 .subvendor = 0x1435,
4353 .subdevice = 0x7350,
4354 .driver_data = SAA7134_BOARD_RTD_VFG7350,
Nickolay V. Shmyrevbb881f12005-11-08 21:36:35 -08004355 },{
Mauro Carvalho Chehab4ac97912005-11-08 21:37:43 -08004356 .vendor = PCI_VENDOR_ID_PHILIPS,
4357 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
4358 .subvendor = 0x1435,
4359 .subdevice = 0x7330,
4360 .driver_data = SAA7134_BOARD_RTD_VFG7330,
Pieter Palmerscf1c5d12005-11-08 21:37:40 -08004361 },{
Mauro Carvalho Chehab4ac97912005-11-08 21:37:43 -08004362 .vendor = PCI_VENDOR_ID_PHILIPS,
4363 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
4364 .subvendor = 0x1461,
4365 .subdevice = 0x1044,
4366 .driver_data = SAA7134_BOARD_AVERMEDIA_AVERTVHD_A180,
4367 },{
Pieter Palmerscf1c5d12005-11-08 21:37:40 -08004368 .vendor = PCI_VENDOR_ID_PHILIPS,
4369 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
4370 .subvendor = 0x1131,
4371 .subdevice = 0x4ee9,
4372 .driver_data = SAA7134_BOARD_MONSTERTV_MOBILE,
Mauro Carvalho Chehab4ac97912005-11-08 21:37:43 -08004373 },{
Ricardo Cerqueirac2f6f9d2005-11-08 21:37:51 -08004374 .vendor = PCI_VENDOR_ID_PHILIPS,
4375 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
4376 .subvendor = 0x11bd,
4377 .subdevice = 0x002e,
4378 .driver_data = SAA7134_BOARD_PINNACLE_PCTV_110i,
4379 },{
Hermann Pitton28f02242005-11-08 21:38:03 -08004380 .vendor = PCI_VENDOR_ID_PHILIPS,
4381 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
4382 .subvendor = 0x1043,
4383 .subdevice = 0x4862,
4384 .driver_data = SAA7134_BOARD_ASUSTeK_P7131_DUAL,
Pavel Mihaylovc3d93192005-11-08 21:38:43 -08004385 },{
Hartmut Hackmann90e9df72005-11-08 21:38:42 -08004386 .vendor = PCI_VENDOR_ID_PHILIPS,
4387 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
4388 .subvendor = PCI_VENDOR_ID_PHILIPS,
4389 .subdevice = 0x2018,
4390 .driver_data = SAA7134_BOARD_PHILIPS_TIGER,
Hermann Pitton28f02242005-11-08 21:38:03 -08004391 },{
Ricardo Cerqueira80d2ad92005-11-13 16:08:01 -08004392 .vendor = PCI_VENDOR_ID_PHILIPS,
4393 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
4394 .subvendor = 0x1462,
Hermann Pittonb6667e52008-01-12 14:43:48 -03004395 .subdevice = 0x6231, /* tda8275a, ks003 IR */
4396 .driver_data = SAA7134_BOARD_MSI_TVATANYWHERE_PLUS,
4397 },{
4398 .vendor = PCI_VENDOR_ID_PHILIPS,
4399 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
4400 .subvendor = 0x1462,
4401 .subdevice = 0x8624, /* tda8275, ks003 IR */
Ricardo Cerqueira80d2ad92005-11-13 16:08:01 -08004402 .driver_data = SAA7134_BOARD_MSI_TVATANYWHERE_PLUS,
4403 },{
Jörg Schummerf639c9b2006-01-09 15:25:01 -02004404 .vendor = PCI_VENDOR_ID_PHILIPS,
4405 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
4406 .subvendor = 0x153b,
4407 .subdevice = 0x1160,
4408 .driver_data = SAA7134_BOARD_CINERGY250PCI,
4409 },{
Peter Missel4aa6ba52006-01-09 15:32:45 -02004410 .vendor = PCI_VENDOR_ID_PHILIPS,
4411 .device = PCI_DEVICE_ID_PHILIPS_SAA7133, /* SAA 7131E */
4412 .subvendor = 0x5168,
4413 .subdevice = 0x0319,
4414 .driver_data = SAA7134_BOARD_FLYDVB_TRIO,
4415 },{
Jose Alberto Regueroa78d0bf2006-02-07 06:25:14 -02004416 .vendor = PCI_VENDOR_ID_PHILIPS,
Hartmut Hackmann1e9bfb92006-08-07 14:03:32 -03004417 .device = PCI_DEVICE_ID_PHILIPS_SAA7134,
Jose Alberto Regueroa78d0bf2006-02-07 06:25:14 -02004418 .subvendor = 0x1461,
4419 .subdevice = 0x2c05,
4420 .driver_data = SAA7134_BOARD_AVERMEDIA_777,
4421 },{
Giampiero Giancipoli3d8466e2006-02-07 06:49:09 -02004422 .vendor = PCI_VENDOR_ID_PHILIPS,
4423 .device = PCI_DEVICE_ID_PHILIPS_SAA7134,
4424 .subvendor = 0x5168,
4425 .subdevice = 0x0301,
4426 .driver_data = SAA7134_BOARD_FLYDVBT_LR301,
4427 },{
Hartmut Hackmanndf42eaf2006-02-07 06:49:10 -02004428 .vendor = PCI_VENDOR_ID_PHILIPS,
4429 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
4430 .subvendor = 0x0331,
4431 .subdevice = 0x1421,
4432 .driver_data = SAA7134_BOARD_ADS_DUO_CARDBUS_PTV331,
4433 },{
Peter Hartshorn3dfb7292006-02-07 06:49:13 -02004434 .vendor = PCI_VENDOR_ID_PHILIPS,
4435 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
4436 .subvendor = 0x17de,
4437 .subdevice = 0x7201,
4438 .driver_data = SAA7134_BOARD_TEVION_DVBT_220RF,
4439 },{
Andrew Burri3e1410a2006-02-27 00:08:23 -03004440 .vendor = PCI_VENDOR_ID_PHILIPS,
Simon Farnsworthb39423a2007-05-01 10:01:20 -03004441 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
4442 .subvendor = 0x17de,
4443 .subdevice = 0x7250,
4444 .driver_data = SAA7134_BOARD_KWORLD_DVBT_210,
4445 },{
4446 .vendor = PCI_VENDOR_ID_PHILIPS,
Andrew Burri3e1410a2006-02-27 00:08:23 -03004447 .device = PCI_DEVICE_ID_PHILIPS_SAA7133, /* SAA7135HL */
4448 .subvendor = 0x17de,
4449 .subdevice = 0x7350,
4450 .driver_data = SAA7134_BOARD_KWORLD_ATSC110,
4451 },{
Rickard Osser68593af2006-03-11 17:14:12 -03004452 .vendor = PCI_VENDOR_ID_PHILIPS,
Eric Sandeen0ac3a5b2007-10-08 16:13:02 -03004453 .device = PCI_DEVICE_ID_PHILIPS_SAA7133, /* SAA7135HL */
4454 .subvendor = 0x17de,
4455 .subdevice = 0x7352,
4456 .driver_data = SAA7134_BOARD_KWORLD_ATSC110, /* ATSC 115 */
4457 },{
4458 .vendor = PCI_VENDOR_ID_PHILIPS,
Rickard Osser68593af2006-03-11 17:14:12 -03004459 .device = PCI_DEVICE_ID_PHILIPS_SAA7134,
4460 .subvendor = 0x1461,
4461 .subdevice = 0x7360,
4462 .driver_data = SAA7134_BOARD_AVERMEDIA_A169_B,
4463 },{
4464 .vendor = PCI_VENDOR_ID_PHILIPS,
4465 .device = PCI_DEVICE_ID_PHILIPS_SAA7134,
4466 .subvendor = 0x1461,
4467 .subdevice = 0x6360,
4468 .driver_data = SAA7134_BOARD_AVERMEDIA_A169_B1,
4469 },{
Michael Krufkyba3a5a82006-03-14 19:02:12 -03004470 .vendor = PCI_VENDOR_ID_PHILIPS,
4471 .device = PCI_DEVICE_ID_PHILIPS_SAA7134,
4472 .subvendor = 0x16be,
4473 .subdevice = 0x0005,
4474 .driver_data = SAA7134_BOARD_MD7134_BRIDGE_2,
4475 },{
Igor M. Liplianine2ac28f2006-08-08 09:10:10 -03004476 .vendor = PCI_VENDOR_ID_PHILIPS,
4477 .device = PCI_DEVICE_ID_PHILIPS_SAA7134,
4478 .subvendor = 0x5168,
4479 .subdevice = 0x0300,
4480 .driver_data = SAA7134_BOARD_FLYDVBS_LR300,
4481 },{
4482 .vendor = PCI_VENDOR_ID_PHILIPS,
4483 .device = PCI_DEVICE_ID_PHILIPS_SAA7134,
4484 .subvendor = 0x4e42,
4485 .subdevice = 0x0300,/* LR300 */
4486 .driver_data = SAA7134_BOARD_FLYDVBS_LR300,
4487 },{
Hartmut Hackmann42e6b3b2006-03-27 19:04:48 -03004488 .vendor = PCI_VENDOR_ID_PHILIPS,
4489 .device = PCI_DEVICE_ID_PHILIPS_SAA7134,
4490 .subvendor = 0x1489,
4491 .subdevice = 0x0301,
4492 .driver_data = SAA7134_BOARD_FLYDVBT_LR301,
4493 },{
4494 .vendor = PCI_VENDOR_ID_PHILIPS,
4495 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
4496 .subvendor = 0x5168, /* Animation Technologies (LifeView) */
4497 .subdevice = 0x0304,
4498 .driver_data = SAA7134_BOARD_FLYTVPLATINUM_FM,
4499 },{
Hartmut Hackmannd95b8942006-03-27 19:39:30 -03004500 .vendor = PCI_VENDOR_ID_PHILIPS,
4501 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
4502 .subvendor = 0x5168,
4503 .subdevice = 0x3306,
4504 .driver_data = SAA7134_BOARD_FLYDVBT_HYBRID_CARDBUS,
4505 },{
4506 .vendor = PCI_VENDOR_ID_PHILIPS,
4507 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
4508 .subvendor = 0x5168,
4509 .subdevice = 0x3502, /* whats the difference to 0x3306 ?*/
4510 .driver_data = SAA7134_BOARD_FLYDVBT_HYBRID_CARDBUS,
4511 },{
Hartmut Hackmann5eda2272006-08-07 14:03:32 -03004512 .vendor = PCI_VENDOR_ID_PHILIPS,
4513 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
4514 .subvendor = 0x16be,
4515 .subdevice = 0x0007,
4516 .driver_data = SAA7134_BOARD_MEDION_MD8800_QUADRO,
4517 },{
4518 .vendor = PCI_VENDOR_ID_PHILIPS,
4519 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
4520 .subvendor = 0x16be,
4521 .subdevice = 0x0008,
4522 .driver_data = SAA7134_BOARD_MEDION_MD8800_QUADRO,
4523 },{
Hartmut Hackmann1e9bfb92006-08-07 14:03:32 -03004524 .vendor = PCI_VENDOR_ID_PHILIPS,
4525 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
4526 .subvendor = 0x1461,
4527 .subdevice = 0x2c05,
4528 .driver_data = SAA7134_BOARD_AVERMEDIA_777,
4529 },{
Hartmut Hackmann2c591942006-08-07 14:03:32 -03004530 .vendor = PCI_VENDOR_ID_PHILIPS,
4531 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
4532 .subvendor = 0x1489,
4533 .subdevice = 0x0502, /* Cardbus version */
4534 .driver_data = SAA7134_BOARD_FLYDVBT_DUO_CARDBUS,
4535 },{
Michal Majchrowiczb04c1ba2006-09-13 16:42:42 -03004536 .vendor = PCI_VENDOR_ID_PHILIPS,
4537 .device = PCI_DEVICE_ID_PHILIPS_SAA7130,
4538 .subvendor = 0x0919, /* Philips Proteus PRO 2309 */
4539 .subdevice = 0x2003,
4540 .driver_data = SAA7134_BOARD_PROTEUS_2309,
4541 },{
Petr Baudis515c2082006-09-26 16:53:53 -03004542 .vendor = PCI_VENDOR_ID_PHILIPS,
4543 .device = PCI_DEVICE_ID_PHILIPS_SAA7134,
4544 .subvendor = 0x1461,
4545 .subdevice = 0x2c00,
4546 .driver_data = SAA7134_BOARD_AVERMEDIA_A16AR,
4547 },{
Hartmut Hackmanncf146ca2006-10-02 20:49:24 -03004548 .vendor = PCI_VENDOR_ID_PHILIPS,
4549 .device = PCI_DEVICE_ID_PHILIPS_SAA7134,
4550 .subvendor = 0x1043,
4551 .subdevice = 0x4860,
4552 .driver_data = SAA7134_BOARD_ASUS_EUROPA2_HYBRID,
4553 },{
Hartmut Hackmann587d2fd2006-10-06 19:13:50 -03004554 .vendor = PCI_VENDOR_ID_PHILIPS,
4555 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
4556 .subvendor = 0x11bd,
4557 .subdevice = 0x002f,
4558 .driver_data = SAA7134_BOARD_PINNACLE_PCTV_310i,
4559 },{
Mikhail Fedotov3ac706d2006-10-06 20:23:47 -03004560 .vendor = PCI_VENDOR_ID_PHILIPS,
4561 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
4562 .subvendor = 0x1461, /* Avermedia Technologies Inc */
4563 .subdevice = 0x9715,
4564 .driver_data = SAA7134_BOARD_AVERMEDIA_STUDIO_507,
4565 },{
Hartmut Hackmann83646812006-10-12 20:38:51 -03004566 .vendor = PCI_VENDOR_ID_PHILIPS,
4567 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
4568 .subvendor = 0x1043,
4569 .subdevice = 0x4876,
Hartmut Hackmannf3eec0c02007-03-14 20:33:55 -03004570 .driver_data = SAA7134_BOARD_ASUSTeK_P7131_HYBRID_LNA,
Hartmut Hackmann83646812006-10-12 20:38:51 -03004571 },{
Thomas Gentyc6e53da2006-11-05 14:17:30 -03004572 .vendor = PCI_VENDOR_ID_PHILIPS,
4573 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
4574 .subvendor = 0x0070,
Michael Krufkyddf12222007-11-15 10:01:11 -03004575 .subdevice = 0x6700,
4576 .driver_data = SAA7134_BOARD_HAUPPAUGE_HVR1110,
4577 },{
4578 .vendor = PCI_VENDOR_ID_PHILIPS,
4579 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
4580 .subvendor = 0x0070,
Thomas Gentyc6e53da2006-11-05 14:17:30 -03004581 .subdevice = 0x6701,
4582 .driver_data = SAA7134_BOARD_HAUPPAUGE_HVR1110,
4583 },{
Hartmut Hackmann550a9a52006-11-15 21:31:54 -03004584 .vendor = PCI_VENDOR_ID_PHILIPS,
4585 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
Michael Krufkyddf12222007-11-15 10:01:11 -03004586 .subvendor = 0x0070,
4587 .subdevice = 0x6702,
4588 .driver_data = SAA7134_BOARD_HAUPPAUGE_HVR1110,
4589 },{
4590 .vendor = PCI_VENDOR_ID_PHILIPS,
4591 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
4592 .subvendor = 0x0070,
4593 .subdevice = 0x6703,
4594 .driver_data = SAA7134_BOARD_HAUPPAUGE_HVR1110,
4595 },{
4596 .vendor = PCI_VENDOR_ID_PHILIPS,
4597 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
4598 .subvendor = 0x0070,
4599 .subdevice = 0x6704,
4600 .driver_data = SAA7134_BOARD_HAUPPAUGE_HVR1110,
4601 },{
4602 .vendor = PCI_VENDOR_ID_PHILIPS,
4603 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
4604 .subvendor = 0x0070,
4605 .subdevice = 0x6705,
4606 .driver_data = SAA7134_BOARD_HAUPPAUGE_HVR1110,
4607 },{
4608 .vendor = PCI_VENDOR_ID_PHILIPS,
4609 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
Hartmut Hackmann550a9a52006-11-15 21:31:54 -03004610 .subvendor = 0x153b,
4611 .subdevice = 0x1172,
4612 .driver_data = SAA7134_BOARD_CINERGY_HT_PCMCIA,
4613 },{
Steven Walterd1158f42006-12-20 09:29:09 -03004614 .vendor = PCI_VENDOR_ID_PHILIPS,
4615 .device = PCI_DEVICE_ID_PHILIPS_SAA7130,
4616 .subvendor = PCI_VENDOR_ID_PHILIPS,
4617 .subdevice = 0x2342,
4618 .driver_data = SAA7134_BOARD_ENCORE_ENLTV,
4619 },{
Juan Pablo Sormanic36c4592006-12-27 12:46:36 -03004620 .vendor = PCI_VENDOR_ID_PHILIPS,
4621 .device = PCI_DEVICE_ID_PHILIPS_SAA7130,
4622 .subvendor = 0x1131,
4623 .subdevice = 0x2341,
4624 .driver_data = SAA7134_BOARD_ENCORE_ENLTV,
4625 },{
4626 .vendor = PCI_VENDOR_ID_PHILIPS,
4627 .device = PCI_DEVICE_ID_PHILIPS_SAA7130,
4628 .subvendor = 0x3016,
4629 .subdevice = 0x2344,
4630 .driver_data = SAA7134_BOARD_ENCORE_ENLTV,
4631 },{
4632 .vendor = PCI_VENDOR_ID_PHILIPS,
4633 .device = PCI_DEVICE_ID_PHILIPS_SAA7130,
4634 .subvendor = 0x1131,
4635 .subdevice = 0x230f,
4636 .driver_data = SAA7134_BOARD_ENCORE_ENLTV_FM,
4637 },{
Michael Krufky9de271e2007-01-16 18:36:40 -03004638 .vendor = PCI_VENDOR_ID_PHILIPS,
4639 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
4640 .subvendor = 0x153b,
4641 .subdevice = 0x1175,
4642 .driver_data = SAA7134_BOARD_CINERGY_HT_PCI,
4643 },{
Markus Rechbergere95d3172007-04-27 12:31:19 -03004644 .vendor = PCI_VENDOR_ID_PHILIPS,
4645 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
4646 .subvendor = 0x1461, /* Avermedia Technologies Inc */
4647 .subdevice = 0xf31e,
4648 .driver_data = SAA7134_BOARD_AVERMEDIA_M102,
4649 },{
Peter Misseldb483672007-04-27 12:31:20 -03004650 .vendor = PCI_VENDOR_ID_PHILIPS,
4651 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
4652 .subvendor = 0x4E42, /* MSI */
4653 .subdevice = 0x0306, /* TV@nywhere DUO */
4654 .driver_data = SAA7134_BOARD_FLYDVBTDUO,
4655 },{
Hartmut Hackmanne06cea42007-03-13 20:58:29 -03004656 .vendor = PCI_VENDOR_ID_PHILIPS,
4657 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
4658 .subvendor = 0x1043,
4659 .subdevice = 0x4871,
4660 .driver_data = SAA7134_BOARD_ASUS_P7131_4871,
4661 },{
4662 .vendor = PCI_VENDOR_ID_PHILIPS,
4663 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
4664 .subvendor = 0x1043,
4665 .subdevice = 0x4857,
4666 .driver_data = SAA7134_BOARD_ASUSTeK_P7131_DUAL,
4667 },{
James T Klaas53958b32007-05-01 10:48:09 -03004668 .vendor = PCI_VENDOR_ID_PHILIPS,
4669 .device = PCI_DEVICE_ID_PHILIPS_SAA7134,
4670 .subvendor = 0x0919, /* SinoVideo PCI 2309 Proteus (7134) */
4671 .subdevice = 0x2003, /* OEM cardbus */
4672 .driver_data = SAA7134_BOARD_SABRENT_TV_PCB05,
4673 },{
Tony Wanaaccb822007-05-10 12:16:47 -03004674 .vendor = PCI_VENDOR_ID_PHILIPS,
4675 .device = PCI_DEVICE_ID_PHILIPS_SAA7130,
4676 .subvendor = PCI_VENDOR_ID_PHILIPS,
4677 .subdevice = 0x2304,
4678 .driver_data = SAA7134_BOARD_10MOONSTVMASTER3,
4679 },{
Edgar Simod90d9f52007-08-20 14:14:50 -03004680 .vendor = PCI_VENDOR_ID_PHILIPS,
4681 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
4682 .subvendor = 0x1461, /* Avermedia Technologies Inc */
4683 .subdevice = 0xf01d, /* AVerTV DVB-T Super 007 */
4684 .driver_data = SAA7134_BOARD_AVERMEDIA_SUPER_007,
4685 },{
Mauro Carvalho Chehab593f18c2007-10-07 02:17:09 -03004686 .vendor = PCI_VENDOR_ID_PHILIPS,
Andrey J. Melnikoff (TEMHOTA)e8018c92008-01-07 05:17:39 -03004687 .device = PCI_DEVICE_ID_PHILIPS_SAA7130,
Andrey J. Melnikoff (TEMHOTA)e8018c92008-01-07 05:17:39 -03004688 .subvendor = 0x0000,
4689 .subdevice = 0x4016,
4690 .driver_data = SAA7134_BOARD_BEHOLD_401,
4691 },{
4692 .vendor = PCI_VENDOR_ID_PHILIPS,
4693 .device = PCI_DEVICE_ID_PHILIPS_SAA7134,
Andrey J. Melnikoff (TEMHOTA)e8018c92008-01-07 05:17:39 -03004694 .subvendor = 0x0000,
4695 .subdevice = 0x4036,
4696 .driver_data = SAA7134_BOARD_BEHOLD_403,
4697 },{
4698 .vendor = PCI_VENDOR_ID_PHILIPS,
4699 .device = PCI_DEVICE_ID_PHILIPS_SAA7134,
4700 .subvendor = 0x0000,
4701 .subdevice = 0x4037,
4702 .driver_data = SAA7134_BOARD_BEHOLD_403FM,
4703 },{
4704 .vendor = PCI_VENDOR_ID_PHILIPS,
4705 .device = PCI_DEVICE_ID_PHILIPS_SAA7130,
4706 .subvendor = 0x0000,
4707 .subdevice = 0x4050,
4708 .driver_data = SAA7134_BOARD_BEHOLD_405,
4709 },{
4710 .vendor = PCI_VENDOR_ID_PHILIPS,
4711 .device = PCI_DEVICE_ID_PHILIPS_SAA7130,
4712 .subvendor = 0x0000,
4713 .subdevice = 0x4051,
4714 .driver_data = SAA7134_BOARD_BEHOLD_405FM,
4715 },{
4716 .vendor = PCI_VENDOR_ID_PHILIPS,
4717 .device = PCI_DEVICE_ID_PHILIPS_SAA7134,
4718 .subvendor = 0x0000,
4719 .subdevice = 0x4070,
4720 .driver_data = SAA7134_BOARD_BEHOLD_407,
4721 },{
4722 .vendor = PCI_VENDOR_ID_PHILIPS,
4723 .device = PCI_DEVICE_ID_PHILIPS_SAA7134,
4724 .subvendor = 0x0000,
4725 .subdevice = 0x4071,
4726 .driver_data = SAA7134_BOARD_BEHOLD_407FM,
4727 },{
4728 .vendor = PCI_VENDOR_ID_PHILIPS,
4729 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
4730 .subvendor = 0x0000,
4731 .subdevice = 0x4090,
4732 .driver_data = SAA7134_BOARD_BEHOLD_409,
4733 },{
4734 .vendor = PCI_VENDOR_ID_PHILIPS,
4735 .device = PCI_DEVICE_ID_PHILIPS_SAA7130,
4736 .subvendor = 0x0000,
4737 .subdevice = 0x5051,
4738 .driver_data = SAA7134_BOARD_BEHOLD_505FM,
4739 },{
4740 .vendor = PCI_VENDOR_ID_PHILIPS,
4741 .device = PCI_DEVICE_ID_PHILIPS_SAA7130,
4742 .subvendor = 0x0000,
4743 .subdevice = 0x505B,
4744 .driver_data = SAA7134_BOARD_BEHOLD_505FM,
4745 },{
4746 .vendor = PCI_VENDOR_ID_PHILIPS,
4747 .device = PCI_DEVICE_ID_PHILIPS_SAA7130,
4748 .subvendor = 0x5ace,
4749 .subdevice = 0x5050,
4750 .driver_data = SAA7134_BOARD_BEHOLD_505FM,
4751 },{
4752 .vendor = PCI_VENDOR_ID_PHILIPS,
4753 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
4754 .subvendor = 0x0000,
4755 .subdevice = 0x5071,
4756 .driver_data = SAA7134_BOARD_BEHOLD_507_9FM,
4757 },{
4758 .vendor = PCI_VENDOR_ID_PHILIPS,
4759 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
4760 .subvendor = 0x0000,
4761 .subdevice = 0x507B,
4762 .driver_data = SAA7134_BOARD_BEHOLD_507_9FM,
4763 },{
4764 .vendor = PCI_VENDOR_ID_PHILIPS,
4765 .device = PCI_DEVICE_ID_PHILIPS_SAA7134,
4766 .subvendor = 0x5ace,
4767 .subdevice = 0x5070,
4768 .driver_data = SAA7134_BOARD_BEHOLD_507_9FM,
4769 },{
4770 .vendor = PCI_VENDOR_ID_PHILIPS,
4771 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
4772 .subvendor = 0x5ace,
4773 .subdevice = 0x5090,
4774 .driver_data = SAA7134_BOARD_BEHOLD_507_9FM,
4775 },{
4776 .vendor = PCI_VENDOR_ID_PHILIPS,
4777 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
4778 .subvendor = 0x0000,
4779 .subdevice = 0x5201,
4780 .driver_data = SAA7134_BOARD_BEHOLD_COLUMBUS_TVFM,
4781 },{
4782 .vendor = PCI_VENDOR_ID_PHILIPS,
4783 .device = PCI_DEVICE_ID_PHILIPS_SAA7134,
4784 .subvendor = 0x5ace,
4785 .subdevice = 0x6070,
4786 .driver_data = SAA7134_BOARD_BEHOLD_607_9FM,
4787 },{
4788 .vendor = PCI_VENDOR_ID_PHILIPS,
4789 .device = PCI_DEVICE_ID_PHILIPS_SAA7134,
4790 .subvendor = 0x5ace,
4791 .subdevice = 0x6071,
4792 .driver_data = SAA7134_BOARD_BEHOLD_607_9FM,
4793 },{
4794 .vendor = PCI_VENDOR_ID_PHILIPS,
4795 .device = PCI_DEVICE_ID_PHILIPS_SAA7134,
4796 .subvendor = 0x5ace,
4797 .subdevice = 0x6072,
4798 .driver_data = SAA7134_BOARD_BEHOLD_607_9FM,
4799 },{
4800 .vendor = PCI_VENDOR_ID_PHILIPS,
4801 .device = PCI_DEVICE_ID_PHILIPS_SAA7134,
4802 .subvendor = 0x5ace,
4803 .subdevice = 0x6073,
4804 .driver_data = SAA7134_BOARD_BEHOLD_607_9FM,
4805 },{
4806 .vendor = PCI_VENDOR_ID_PHILIPS,
4807 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
4808 .subvendor = 0x5ace,
4809 .subdevice = 0x6090,
4810 .driver_data = SAA7134_BOARD_BEHOLD_607_9FM,
4811 },{
4812 .vendor = PCI_VENDOR_ID_PHILIPS,
4813 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
4814 .subvendor = 0x5ace,
4815 .subdevice = 0x6091,
4816 .driver_data = SAA7134_BOARD_BEHOLD_607_9FM,
4817 },{
4818 .vendor = PCI_VENDOR_ID_PHILIPS,
4819 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
4820 .subvendor = 0x5ace,
4821 .subdevice = 0x6092,
4822 .driver_data = SAA7134_BOARD_BEHOLD_607_9FM,
4823 },{
4824 .vendor = PCI_VENDOR_ID_PHILIPS,
4825 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
4826 .subvendor = 0x5ace,
4827 .subdevice = 0x6093,
4828 .driver_data = SAA7134_BOARD_BEHOLD_607_9FM,
4829 },{
4830 .vendor = PCI_VENDOR_ID_PHILIPS,
4831 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
4832 .subvendor = 0x5ace,
4833 .subdevice = 0x6190,
4834 .driver_data = SAA7134_BOARD_BEHOLD_M6,
4835 },{
4836 .vendor = PCI_VENDOR_ID_PHILIPS,
4837 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
4838 .subvendor = 0x5ace,
4839 .subdevice = 0x6193,
4840 .driver_data = SAA7134_BOARD_BEHOLD_M6,
4841 },{
4842 .vendor = PCI_VENDOR_ID_PHILIPS,
Mauro Carvalho Chehab593f18c2007-10-07 02:17:09 -03004843 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
4844 .subvendor = 0x4e42,
4845 .subdevice = 0x3502,
4846 .driver_data = SAA7134_BOARD_FLYDVBT_HYBRID_CARDBUS
4847 },{
Linus Torvalds1da177e2005-04-16 15:20:36 -07004848 /* --- boards without eeprom + subsystem ID --- */
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07004849 .vendor = PCI_VENDOR_ID_PHILIPS,
4850 .device = PCI_DEVICE_ID_PHILIPS_SAA7134,
4851 .subvendor = PCI_VENDOR_ID_PHILIPS,
Linus Torvalds1da177e2005-04-16 15:20:36 -07004852 .subdevice = 0,
4853 .driver_data = SAA7134_BOARD_NOAUTO,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07004854 },{
4855 .vendor = PCI_VENDOR_ID_PHILIPS,
4856 .device = PCI_DEVICE_ID_PHILIPS_SAA7130,
4857 .subvendor = PCI_VENDOR_ID_PHILIPS,
Linus Torvalds1da177e2005-04-16 15:20:36 -07004858 .subdevice = 0,
4859 .driver_data = SAA7134_BOARD_NOAUTO,
4860 },{
Linus Torvalds1da177e2005-04-16 15:20:36 -07004861 /* --- default catch --- */
4862 .vendor = PCI_VENDOR_ID_PHILIPS,
4863 .device = PCI_DEVICE_ID_PHILIPS_SAA7130,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07004864 .subvendor = PCI_ANY_ID,
4865 .subdevice = PCI_ANY_ID,
Linus Torvalds1da177e2005-04-16 15:20:36 -07004866 .driver_data = SAA7134_BOARD_UNKNOWN,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07004867 },{
Linus Torvalds1da177e2005-04-16 15:20:36 -07004868 .vendor = PCI_VENDOR_ID_PHILIPS,
4869 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07004870 .subvendor = PCI_ANY_ID,
4871 .subdevice = PCI_ANY_ID,
Linus Torvalds1da177e2005-04-16 15:20:36 -07004872 .driver_data = SAA7134_BOARD_UNKNOWN,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07004873 },{
Linus Torvalds1da177e2005-04-16 15:20:36 -07004874 .vendor = PCI_VENDOR_ID_PHILIPS,
4875 .device = PCI_DEVICE_ID_PHILIPS_SAA7134,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07004876 .subvendor = PCI_ANY_ID,
4877 .subdevice = PCI_ANY_ID,
Linus Torvalds1da177e2005-04-16 15:20:36 -07004878 .driver_data = SAA7134_BOARD_UNKNOWN,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07004879 },{
Linus Torvalds1da177e2005-04-16 15:20:36 -07004880 .vendor = PCI_VENDOR_ID_PHILIPS,
4881 .device = PCI_DEVICE_ID_PHILIPS_SAA7135,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07004882 .subvendor = PCI_ANY_ID,
4883 .subdevice = PCI_ANY_ID,
Linus Torvalds1da177e2005-04-16 15:20:36 -07004884 .driver_data = SAA7134_BOARD_UNKNOWN,
4885 },{
4886 /* --- end of list --- */
4887 }
4888};
4889MODULE_DEVICE_TABLE(pci, saa7134_pci_tbl);
4890
4891/* ----------------------------------------------------------- */
4892/* flyvideo tweaks */
4893
Linus Torvalds1da177e2005-04-16 15:20:36 -07004894
4895static void board_flyvideo(struct saa7134_dev *dev)
4896{
Linus Torvalds1da177e2005-04-16 15:20:36 -07004897 printk("%s: there are different flyvideo cards with different tuners\n"
4898 "%s: out there, you might have to use the tuner=<nr> insmod\n"
4899 "%s: option to override the default value.\n",
4900 dev->name, dev->name, dev->name);
4901}
4902
4903/* ----------------------------------------------------------- */
4904
Michael Krufky993efa72007-11-15 10:34:33 -03004905static void hauppauge_eeprom(struct saa7134_dev *dev, u8 *eeprom_data)
4906{
4907 struct tveeprom tv;
4908
4909 tveeprom_hauppauge_analog(&dev->i2c_client, &tv, eeprom_data);
4910
4911 /* Make sure we support the board model */
4912 switch (tv.model) {
4913 case 67019: /* WinTV-HVR1110 (Retail, IR Blaster, hybrid, FM, SVid/Comp, 3.5mm audio in) */
4914 case 67109: /* WinTV-HVR1000 (Retail, IR Receive, analog, no FM, SVid/Comp, 3.5mm audio in) */
4915 case 67559: /* WinTV-HVR1110 (OEM, no IR, hybrid, FM, SVid/Comp, RCA aud) */
4916 case 67569: /* WinTV-HVR1110 (OEM, no IR, hybrid, FM) */
4917 case 67579: /* WinTV-HVR1110 (OEM, no IR, hybrid, no FM) */
4918 case 67589: /* WinTV-HVR1110 (OEM, no IR, hybrid, no FM, SVid/Comp, RCA aud) */
4919 case 67599: /* WinTV-HVR1110 (OEM, no IR, hybrid, no FM, SVid/Comp, RCA aud) */
4920 break;
4921 default:
4922 printk(KERN_WARNING "%s: warning: "
4923 "unknown hauppauge model #%d\n", dev->name, tv.model);
4924 break;
4925 }
4926
4927 printk(KERN_INFO "%s: hauppauge eeprom: model=%d\n",
4928 dev->name, tv.model);
4929}
4930
4931/* ----------------------------------------------------------- */
4932
Linus Torvalds1da177e2005-04-16 15:20:36 -07004933int saa7134_board_init1(struct saa7134_dev *dev)
4934{
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07004935 /* Always print gpio, often manufacturers encode tuner type and other info. */
Linus Torvalds1da177e2005-04-16 15:20:36 -07004936 saa_writel(SAA7134_GPIO_GPMODE0 >> 2, 0);
4937 dev->gpio_value = saa_readl(SAA7134_GPIO_GPSTATUS0 >> 2);
4938 printk(KERN_INFO "%s: board init: gpio is %x\n", dev->name, dev->gpio_value);
4939
4940 switch (dev->board) {
4941 case SAA7134_BOARD_FLYVIDEO2000:
4942 case SAA7134_BOARD_FLYVIDEO3000:
Zac Bowlingf49ba8d2006-06-19 19:49:20 -03004943 case SAA7134_BOARD_FLYVIDEO3000_NTSC:
Ricardo Cerqueiracb2444d2005-11-08 21:38:47 -08004944 dev->has_remote = SAA7134_REMOTE_GPIO;
Linus Torvalds1da177e2005-04-16 15:20:36 -07004945 board_flyvideo(dev);
4946 break;
Arnaud Patard6af90ab2005-11-08 21:36:55 -08004947 case SAA7134_BOARD_FLYTVPLATINUM_MINI2:
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07004948 case SAA7134_BOARD_FLYTVPLATINUM_FM:
Linus Torvalds1da177e2005-04-16 15:20:36 -07004949 case SAA7134_BOARD_CINERGY400:
4950 case SAA7134_BOARD_CINERGY600:
4951 case SAA7134_BOARD_CINERGY600_MK3:
4952 case SAA7134_BOARD_ECS_TVP3XP:
4953 case SAA7134_BOARD_ECS_TVP3XP_4CB5:
Simon Farnsworthb39423a2007-05-01 10:01:20 -03004954 case SAA7134_BOARD_ECS_TVP3XP_4CB6:
Linus Torvalds1da177e2005-04-16 15:20:36 -07004955 case SAA7134_BOARD_MD2819:
Mauro Carvalho Chehabac19ecc2005-06-23 22:05:09 -07004956 case SAA7134_BOARD_KWORLD_VSTREAM_XPERT:
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07004957 case SAA7134_BOARD_KWORLD_XPERT:
Linus Torvalds1da177e2005-04-16 15:20:36 -07004958 case SAA7134_BOARD_AVERMEDIA_STUDIO_305:
4959 case SAA7134_BOARD_AVERMEDIA_305:
Mauro Carvalho Chehabac19ecc2005-06-23 22:05:09 -07004960 case SAA7134_BOARD_AVERMEDIA_STUDIO_307:
Linus Torvalds1da177e2005-04-16 15:20:36 -07004961 case SAA7134_BOARD_AVERMEDIA_307:
Mikhail Fedotov3ac706d2006-10-06 20:23:47 -03004962 case SAA7134_BOARD_AVERMEDIA_STUDIO_507:
Mauro Carvalho Chehabac19ecc2005-06-23 22:05:09 -07004963 case SAA7134_BOARD_AVERMEDIA_GO_007_FM:
pasky@ucw.cz450efcf2006-11-12 14:22:32 -03004964 case SAA7134_BOARD_AVERMEDIA_777:
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07004965/* case SAA7134_BOARD_SABRENT_SBTTVFM: */ /* not finished yet */
Linus Torvalds1da177e2005-04-16 15:20:36 -07004966 case SAA7134_BOARD_VIDEOMATE_TV_PVR:
Nickolay V. Shmyrev2a9a9a82006-01-09 15:25:33 -02004967 case SAA7134_BOARD_VIDEOMATE_GOLD_PLUS:
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07004968 case SAA7134_BOARD_VIDEOMATE_TV_GOLD_PLUSII:
Nickolay V. Shmyrevfea095f2005-11-08 21:36:47 -08004969 case SAA7134_BOARD_VIDEOMATE_DVBT_300:
Michael Krufkyafce8922005-11-08 21:36:57 -08004970 case SAA7134_BOARD_VIDEOMATE_DVBT_200:
Hartmut Hackmanncbb94522006-10-30 20:00:16 -03004971 case SAA7134_BOARD_VIDEOMATE_DVBT_200A:
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07004972 case SAA7134_BOARD_MANLI_MTV001:
4973 case SAA7134_BOARD_MANLI_MTV002:
Nickolay V. Shmyreva8ff4172005-11-08 21:36:16 -08004974 case SAA7134_BOARD_BEHOLD_409FM:
Linus Torvalds1da177e2005-04-16 15:20:36 -07004975 case SAA7134_BOARD_AVACSSMARTTV:
Nickolay V. Shmyrev6b961442005-11-08 21:36:22 -08004976 case SAA7134_BOARD_GOTVIEW_7135:
James R. Webbdc2286c2005-11-08 21:37:00 -08004977 case SAA7134_BOARD_KWORLD_TERMINATOR:
Ricardo Cerqueira17ce1ff2005-11-08 21:38:47 -08004978 case SAA7134_BOARD_SEDNA_PC_TV_CARDBUS:
Giampiero Giancipoli3d8466e2006-02-07 06:49:09 -02004979 case SAA7134_BOARD_FLYDVBT_LR301:
Hermann Pitton91607232006-12-07 21:45:28 -03004980 case SAA7134_BOARD_ASUSTeK_P7131_DUAL:
Hartmut Hackmannf3eec0c02007-03-14 20:33:55 -03004981 case SAA7134_BOARD_ASUSTeK_P7131_HYBRID_LNA:
Rudo Thomasa8029172006-02-27 00:08:46 -03004982 case SAA7134_BOARD_FLYDVBTDUO:
Michal Majchrowiczb04c1ba2006-09-13 16:42:42 -03004983 case SAA7134_BOARD_PROTEUS_2309:
pasky@ucw.cz29e0f1a2006-11-12 14:23:32 -03004984 case SAA7134_BOARD_AVERMEDIA_A16AR:
Juan Pablo Sormanic36c4592006-12-27 12:46:36 -03004985 case SAA7134_BOARD_ENCORE_ENLTV:
4986 case SAA7134_BOARD_ENCORE_ENLTV_FM:
Tony Wan480f75a2007-05-11 11:33:50 -03004987 case SAA7134_BOARD_10MOONSTVMASTER3:
Andrey J. Melnikoff (TEMHOTA)e8018c92008-01-07 05:17:39 -03004988 case SAA7134_BOARD_BEHOLD_401:
4989 case SAA7134_BOARD_BEHOLD_403:
4990 case SAA7134_BOARD_BEHOLD_403FM:
4991 case SAA7134_BOARD_BEHOLD_405:
4992 case SAA7134_BOARD_BEHOLD_405FM:
4993 case SAA7134_BOARD_BEHOLD_407:
4994 case SAA7134_BOARD_BEHOLD_407FM:
4995 case SAA7134_BOARD_BEHOLD_409:
4996 case SAA7134_BOARD_BEHOLD_505FM:
4997 case SAA7134_BOARD_BEHOLD_507_9FM:
Ricardo Cerqueiracb2444d2005-11-08 21:38:47 -08004998 dev->has_remote = SAA7134_REMOTE_GPIO;
Linus Torvalds1da177e2005-04-16 15:20:36 -07004999 break;
Igor M. Liplianine2ac28f2006-08-08 09:10:10 -03005000 case SAA7134_BOARD_FLYDVBS_LR300:
5001 saa_writeb(SAA7134_GPIO_GPMODE3, 0x80);
5002 saa_writeb(SAA7134_GPIO_GPSTATUS2, 0x40);
5003 dev->has_remote = SAA7134_REMOTE_GPIO;
5004 break;
Linus Torvalds1da177e2005-04-16 15:20:36 -07005005 case SAA7134_BOARD_MD5044:
5006 printk("%s: seems there are two different versions of the MD5044\n"
Michael Krufkyfd2f2672006-03-11 16:21:36 -03005007 "%s: (with the same ID) out there. If sound doesn't work for\n"
5008 "%s: you try the audio_clock_override=0x200000 insmod option.\n",
5009 dev->name,dev->name,dev->name);
Linus Torvalds1da177e2005-04-16 15:20:36 -07005010 break;
5011 case SAA7134_BOARD_CINERGY400_CARDBUS:
5012 /* power-up tuner chip */
5013 saa_andorl(SAA7134_GPIO_GPMODE0 >> 2, 0x00040000, 0x00040000);
5014 saa_andorl(SAA7134_GPIO_GPSTATUS0 >> 2, 0x00040000, 0x00000000);
Mikhail Gusarov7bbbc0a2006-04-20 13:18:50 -03005015 break;
Hartmut Hackmanndf8cf702006-03-03 12:09:26 -03005016 case SAA7134_BOARD_PINNACLE_300I_DVBT_PAL:
5017 /* this turns the remote control chip off to work around a bug in it */
5018 saa_writeb(SAA7134_GPIO_GPMODE1, 0x80);
5019 saa_writeb(SAA7134_GPIO_GPSTATUS1, 0x80);
5020 break;
Pieter Palmerscf1c5d12005-11-08 21:37:40 -08005021 case SAA7134_BOARD_MONSTERTV_MOBILE:
5022 /* power-up tuner chip */
5023 saa_andorl(SAA7134_GPIO_GPMODE0 >> 2, 0x00040000, 0x00040000);
5024 saa_andorl(SAA7134_GPIO_GPSTATUS0 >> 2, 0x00040000, 0x00000004);
Linus Torvalds1da177e2005-04-16 15:20:36 -07005025 break;
Peter Missel10b7a902006-01-23 17:11:06 -02005026 case SAA7134_BOARD_FLYDVBT_DUO_CARDBUS:
Nickolay V. Shmyrev6b961442005-11-08 21:36:22 -08005027 /* turn the fan on */
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07005028 saa_writeb(SAA7134_GPIO_GPMODE3, 0x08);
5029 saa_writeb(SAA7134_GPIO_GPSTATUS3, 0x06);
5030 break;
Hartmut Hackmanndf42eaf2006-02-07 06:49:10 -02005031 case SAA7134_BOARD_ADS_DUO_CARDBUS_PTV331:
Hartmut Hackmannd95b8942006-03-27 19:39:30 -03005032 case SAA7134_BOARD_FLYDVBT_HYBRID_CARDBUS:
Hartmut Hackmann58ef4f92007-04-27 12:31:12 -03005033 saa_andorl(SAA7134_GPIO_GPMODE0 >> 2, 0x08000000, 0x08000000);
5034 saa_andorl(SAA7134_GPIO_GPSTATUS0 >> 2, 0x08000000, 0x00000000);
Hartmut Hackmanndf42eaf2006-02-07 06:49:10 -02005035 break;
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07005036 case SAA7134_BOARD_AVERMEDIA_CARDBUS:
Andrey J. Melnikoff (TEMHOTA)e8018c92008-01-07 05:17:39 -03005037 case SAA7134_BOARD_BEHOLD_COLUMBUS_TVFM:
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07005038 /* power-up tuner chip */
5039 saa_andorl(SAA7134_GPIO_GPMODE0 >> 2, 0xffffffff, 0xffffffff);
5040 saa_andorl(SAA7134_GPIO_GPSTATUS0 >> 2, 0xffffffff, 0xffffffff);
5041 msleep(1);
5042 break;
Nickolay V. Shmyrevbb881f12005-11-08 21:36:35 -08005043 case SAA7134_BOARD_RTD_VFG7350:
5044
5045 /*
5046 * Make sure Production Test Register at offset 0x1D1 is cleared
5047 * to take chip out of test mode. Clearing bit 4 (TST_EN_AOUT)
5048 * prevents pin 105 from remaining low; keeping pin 105 low
5049 * continually resets the SAA6752 chip.
5050 */
5051
5052 saa_writeb (SAA7134_PRODUCTION_TEST_MODE, 0x00);
5053 break;
Ricardo Cerqueiracb2444d2005-11-08 21:38:47 -08005054 /* i2c remotes */
5055 case SAA7134_BOARD_PINNACLE_PCTV_110i:
Hartmut Hackmann587d2fd2006-10-06 19:13:50 -03005056 case SAA7134_BOARD_PINNACLE_PCTV_310i:
Ricardo Cerqueiracb2444d2005-11-08 21:38:47 -08005057 case SAA7134_BOARD_UPMOST_PURPLE_TV:
Thomas Genty177aaaf2006-11-29 21:57:24 -03005058 case SAA7134_BOARD_HAUPPAUGE_HVR1110:
Andrey J. Melnikoff (TEMHOTA)e8018c92008-01-07 05:17:39 -03005059 case SAA7134_BOARD_BEHOLD_607_9FM:
5060 case SAA7134_BOARD_BEHOLD_M6:
Ricardo Cerqueiracb2444d2005-11-08 21:38:47 -08005061 dev->has_remote = SAA7134_REMOTE_I2C;
5062 break;
Rickard Osser68593af2006-03-11 17:14:12 -03005063 case SAA7134_BOARD_AVERMEDIA_A169_B:
Michael Krufkyba3a5a82006-03-14 19:02:12 -03005064 case SAA7134_BOARD_MD7134_BRIDGE_2:
Michael Krufky12a219d2006-03-14 16:07:42 -03005065 printk("%s: %s: dual saa713x broadcast decoders\n"
Rickard Osser68593af2006-03-11 17:14:12 -03005066 "%s: Sorry, none of the inputs to this chip are supported yet.\n"
5067 "%s: Dual decoder functionality is disabled for now, use the other chip.\n",
Michael Krufky12a219d2006-03-14 16:07:42 -03005068 dev->name,card(dev).name,dev->name,dev->name);
Rickard Osser68593af2006-03-11 17:14:12 -03005069 break;
Markus Rechbergere95d3172007-04-27 12:31:19 -03005070 case SAA7134_BOARD_AVERMEDIA_M102:
5071 /* enable tuner */
Albert Grahamd2761f22007-12-09 09:44:38 -03005072 dev->has_remote = SAA7134_REMOTE_GPIO;
Markus Rechbergere95d3172007-04-27 12:31:19 -03005073 saa_andorl(SAA7134_GPIO_GPMODE0 >> 2, 0x8c040007, 0x8c040007);
5074 saa_andorl(SAA7134_GPIO_GPSTATUS0 >> 2, 0x0c0007cd, 0x0c0007cd);
5075 break;
Linus Torvalds1da177e2005-04-16 15:20:36 -07005076 }
Linus Torvalds1da177e2005-04-16 15:20:36 -07005077 return 0;
5078}
5079
5080/* stuff which needs working i2c */
5081int saa7134_board_init2(struct saa7134_dev *dev)
5082{
5083 unsigned char buf;
5084 int board;
Hartmut Hackmanncfeb8832007-04-27 12:31:17 -03005085 struct tuner_setup tun_setup;
5086 tun_setup.config = 0;
5087 tun_setup.tuner_callback = saa7134_tuner_callback;
Linus Torvalds1da177e2005-04-16 15:20:36 -07005088
5089 switch (dev->board) {
5090 case SAA7134_BOARD_BMK_MPEX_NOTUNER:
5091 case SAA7134_BOARD_BMK_MPEX_TUNER:
5092 dev->i2c_client.addr = 0x60;
5093 board = (i2c_master_recv(&dev->i2c_client,&buf,0) < 0)
5094 ? SAA7134_BOARD_BMK_MPEX_NOTUNER
5095 : SAA7134_BOARD_BMK_MPEX_TUNER;
5096 if (board == dev->board)
5097 break;
5098 dev->board = board;
5099 printk("%s: board type fixup: %s\n", dev->name,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07005100 saa7134_boards[dev->board].name);
Linus Torvalds1da177e2005-04-16 15:20:36 -07005101 dev->tuner_type = saa7134_boards[dev->board].tuner_type;
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07005102
5103 if (TUNER_ABSENT != dev->tuner_type) {
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07005104 tun_setup.mode_mask = T_RADIO | T_ANALOG_TV | T_DIGITAL_TV;
5105 tun_setup.type = dev->tuner_type;
5106 tun_setup.addr = ADDR_UNSET;
5107
5108 saa7134_i2c_call_clients (dev, TUNER_SET_TYPE_ADDR, &tun_setup);
5109 }
5110 break;
Hartmut Hackmann2cf36ac2005-11-08 21:36:32 -08005111 case SAA7134_BOARD_MD7134:
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07005112 {
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07005113 u8 subaddr;
5114 u8 data[3];
5115 int ret, tuner_t;
5116
5117 struct i2c_msg msg[] = {{.addr=0x50, .flags=0, .buf=&subaddr, .len = 1},
5118 {.addr=0x50, .flags=I2C_M_RD, .buf=data, .len = 3}};
5119 subaddr= 0x14;
5120 tuner_t = 0;
5121 ret = i2c_transfer(&dev->i2c_adap, msg, 2);
5122 if (ret != 2) {
5123 printk(KERN_ERR "EEPROM read failure\n");
5124 } else if ((data[0] != 0) && (data[0] != 0xff)) {
5125 /* old config structure */
5126 subaddr = data[0] + 2;
5127 msg[1].len = 2;
5128 i2c_transfer(&dev->i2c_adap, msg, 2);
5129 tuner_t = (data[0] << 8) + data[1];
5130 switch (tuner_t){
5131 case 0x0103:
5132 dev->tuner_type = TUNER_PHILIPS_PAL;
5133 break;
5134 case 0x010C:
5135 dev->tuner_type = TUNER_PHILIPS_FM1216ME_MK3;
5136 break;
5137 default:
5138 printk(KERN_ERR "%s Cant determine tuner type %x from EEPROM\n", dev->name, tuner_t);
5139 }
5140 } else if ((data[1] != 0) && (data[1] != 0xff)) {
5141 /* new config structure */
5142 subaddr = data[1] + 1;
5143 msg[1].len = 1;
5144 i2c_transfer(&dev->i2c_adap, msg, 2);
5145 subaddr = data[0] + 1;
5146 msg[1].len = 2;
5147 i2c_transfer(&dev->i2c_adap, msg, 2);
5148 tuner_t = (data[1] << 8) + data[0];
5149 switch (tuner_t) {
5150 case 0x0005:
5151 dev->tuner_type = TUNER_PHILIPS_FM1216ME_MK3;
5152 break;
5153 case 0x001d:
5154 dev->tuner_type = TUNER_PHILIPS_FMD1216ME_MK3;
5155 printk(KERN_INFO "%s Board has DVB-T\n", dev->name);
5156 break;
5157 default:
5158 printk(KERN_ERR "%s Cant determine tuner type %x from EEPROM\n", dev->name, tuner_t);
5159 }
5160 } else {
5161 printk(KERN_ERR "%s unexpected config structure\n", dev->name);
5162 }
5163
5164 printk(KERN_INFO "%s Tuner type is %d\n", dev->name, dev->tuner_type);
5165 if (dev->tuner_type == TUNER_PHILIPS_FMD1216ME_MK3) {
Mauro Carvalho Chehab7f171122007-10-18 19:56:47 -03005166 struct v4l2_priv_tun_config tda9887_cfg;
5167
5168 tda9887_cfg.tuner = TUNER_TDA9887;
5169 tda9887_cfg.priv = &dev->tda9887_conf;
5170
5171 dev->tda9887_conf = TDA9887_PRESENT |
5172 TDA9887_PORT1_ACTIVE |
5173 TDA9887_PORT2_ACTIVE;
5174
5175 saa7134_i2c_call_clients(dev, TUNER_SET_CONFIG,
5176 &tda9887_cfg);
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07005177 }
5178
5179 tun_setup.mode_mask = T_RADIO | T_ANALOG_TV | T_DIGITAL_TV;
5180 tun_setup.type = dev->tuner_type;
5181 tun_setup.addr = ADDR_UNSET;
5182
5183 saa7134_i2c_call_clients (dev, TUNER_SET_TYPE_ADDR,&tun_setup);
5184 }
Linus Torvalds1da177e2005-04-16 15:20:36 -07005185 break;
Hartmut Hackmann2cf36ac2005-11-08 21:36:32 -08005186 case SAA7134_BOARD_PHILIPS_EUROPA:
5187 case SAA7134_BOARD_VIDEOMATE_DVBT_300:
Hartmut Hackmanncf146ca2006-10-02 20:49:24 -03005188 case SAA7134_BOARD_ASUS_EUROPA2_HYBRID:
Hartmut Hackmann2cf36ac2005-11-08 21:36:32 -08005189 /* The Philips EUROPA based hybrid boards have the tuner connected through
5190 * the channel decoder. We have to make it transparent to find it
Mauro Carvalho Chehab4ac97912005-11-08 21:37:43 -08005191 */
Hartmut Hackmann2cf36ac2005-11-08 21:36:32 -08005192 {
Hartmut Hackmann2cf36ac2005-11-08 21:36:32 -08005193 u8 data[] = { 0x07, 0x02};
5194 struct i2c_msg msg = {.addr=0x08, .flags=0, .buf=data, .len = sizeof(data)};
5195 i2c_transfer(&dev->i2c_adap, &msg, 1);
5196
5197 tun_setup.mode_mask = T_ANALOG_TV | T_DIGITAL_TV;
5198 tun_setup.type = dev->tuner_type;
5199 tun_setup.addr = dev->tuner_addr;
5200
5201 saa7134_i2c_call_clients (dev, TUNER_SET_TYPE_ADDR,&tun_setup);
Mauro Carvalho Chehab4ac97912005-11-08 21:37:43 -08005202 }
Hartmut Hackmann2cf36ac2005-11-08 21:36:32 -08005203 break;
Hartmut Hackmann90e9df72005-11-08 21:38:42 -08005204 case SAA7134_BOARD_PHILIPS_TIGER:
Hartmut Hackmann58ef4f92007-04-27 12:31:12 -03005205 case SAA7134_BOARD_PHILIPS_TIGER_S:
5206 {
5207 u8 data[] = { 0x3c, 0x33, 0x60};
Hartmut Hackmann58ef4f92007-04-27 12:31:12 -03005208 struct i2c_msg msg = {.addr=0x08, .flags=0, .buf=data, .len = sizeof(data)};
5209 if(dev->autodetected && (dev->eedata[0x49] == 0x50)) {
5210 dev->board = SAA7134_BOARD_PHILIPS_TIGER_S;
5211 printk(KERN_INFO "%s: Reconfigured board as %s\n",
5212 dev->name, saa7134_boards[dev->board].name);
5213 }
5214 if(dev->board == SAA7134_BOARD_PHILIPS_TIGER_S) {
5215 tun_setup.mode_mask = T_ANALOG_TV | T_DIGITAL_TV;
5216 tun_setup.type = TUNER_PHILIPS_TDA8290;
5217 tun_setup.addr = 0x4b;
5218 tun_setup.config = 2;
Hartmut Hackmann58ef4f92007-04-27 12:31:12 -03005219
5220 saa7134_i2c_call_clients (dev, TUNER_SET_TYPE_ADDR,&tun_setup);
5221 data[2] = 0x68;
5222 }
5223 i2c_transfer(&dev->i2c_adap, &msg, 1);
5224 }
5225 break;
Michael Krufky993efa72007-11-15 10:34:33 -03005226 case SAA7134_BOARD_HAUPPAUGE_HVR1110:
5227 hauppauge_eeprom(dev, dev->eedata+0x80);
5228 /* break intentionally omitted */
Hartmut Hackmann587d2fd2006-10-06 19:13:50 -03005229 case SAA7134_BOARD_PINNACLE_PCTV_310i:
Simon Farnsworthb39423a2007-05-01 10:01:20 -03005230 case SAA7134_BOARD_KWORLD_DVBT_210:
Peter Hartshorn3dfb7292006-02-07 06:49:13 -02005231 case SAA7134_BOARD_TEVION_DVBT_220RF:
Hartmut Hackmannd4b0aba2005-11-08 21:38:44 -08005232 case SAA7134_BOARD_ASUSTeK_P7131_DUAL:
Hartmut Hackmannf3eec0c02007-03-14 20:33:55 -03005233 case SAA7134_BOARD_ASUSTeK_P7131_HYBRID_LNA:
Hartmut Hackmann5eda2272006-08-07 14:03:32 -03005234 case SAA7134_BOARD_MEDION_MD8800_QUADRO:
Hermann Pittona28cb822008-01-12 14:31:03 -03005235 case SAA7134_BOARD_AVERMEDIA_SUPER_007:
Peter Hartshorn3dfb7292006-02-07 06:49:13 -02005236 /* this is a hybrid board, initialize to analog mode
5237 * and configure firmware eeprom address
5238 */
Hartmut Hackmann90e9df72005-11-08 21:38:42 -08005239 {
Hartmut Hackmann58ef4f92007-04-27 12:31:12 -03005240 u8 data[] = { 0x3c, 0x33, 0x60};
Hartmut Hackmann90e9df72005-11-08 21:38:42 -08005241 struct i2c_msg msg = {.addr=0x08, .flags=0, .buf=data, .len = sizeof(data)};
5242 i2c_transfer(&dev->i2c_adap, &msg, 1);
5243 }
5244 break;
Nico Sabbi420f32f2006-03-03 12:11:28 -03005245 case SAA7134_BOARD_FLYDVB_TRIO:
Hartmut Hackmann293cdab2006-02-27 21:08:07 -03005246 {
5247 u8 data[] = { 0x3c, 0x33, 0x62};
5248 struct i2c_msg msg = {.addr=0x09, .flags=0, .buf=data, .len = sizeof(data)};
5249 i2c_transfer(&dev->i2c_adap, &msg, 1);
5250 }
5251 break;
Hartmut Hackmanndf42eaf2006-02-07 06:49:10 -02005252 case SAA7134_BOARD_ADS_DUO_CARDBUS_PTV331:
Hartmut Hackmannd95b8942006-03-27 19:39:30 -03005253 case SAA7134_BOARD_FLYDVBT_HYBRID_CARDBUS:
Hartmut Hackmann58ef4f92007-04-27 12:31:12 -03005254 /* initialize analog mode */
Hartmut Hackmanndf42eaf2006-02-07 06:49:10 -02005255 {
Hartmut Hackmann58ef4f92007-04-27 12:31:12 -03005256 u8 data[] = { 0x3c, 0x33, 0x6a};
Hartmut Hackmanndf42eaf2006-02-07 06:49:10 -02005257 struct i2c_msg msg = {.addr=0x08, .flags=0, .buf=data, .len = sizeof(data)};
5258 i2c_transfer(&dev->i2c_adap, &msg, 1);
5259 }
5260 break;
Hartmut Hackmann550a9a52006-11-15 21:31:54 -03005261 case SAA7134_BOARD_CINERGY_HT_PCMCIA:
Michael Krufky9de271e2007-01-16 18:36:40 -03005262 case SAA7134_BOARD_CINERGY_HT_PCI:
Hartmut Hackmann58ef4f92007-04-27 12:31:12 -03005263 /* initialize analog mode */
Hartmut Hackmann550a9a52006-11-15 21:31:54 -03005264 {
Hartmut Hackmann58ef4f92007-04-27 12:31:12 -03005265 u8 data[] = { 0x3c, 0x33, 0x68};
Hartmut Hackmann550a9a52006-11-15 21:31:54 -03005266 struct i2c_msg msg = {.addr=0x08, .flags=0, .buf=data, .len = sizeof(data)};
5267 i2c_transfer(&dev->i2c_adap, &msg, 1);
5268 }
5269 break;
Curt Meyers20b5ee52006-02-27 00:08:39 -03005270 case SAA7134_BOARD_KWORLD_ATSC110:
5271 {
5272 /* enable tuner */
5273 int i;
Michael Krufkyb9ee9ad2006-02-27 00:09:14 -03005274 static const u8 buffer [] = { 0x10,0x12,0x13,0x04,0x16,0x00,0x14,0x04,0x017,0x00 };
Curt Meyers20b5ee52006-02-27 00:08:39 -03005275 dev->i2c_client.addr = 0x0a;
5276 for (i = 0; i < 5; i++)
5277 if (2 != i2c_master_send(&dev->i2c_client,&buffer[i*2],2))
5278 printk(KERN_WARNING "%s: Unable to enable tuner(%i).\n",
5279 dev->name, i);
5280 }
5281 break;
Hartmut Hackmanncbb94522006-10-30 20:00:16 -03005282 case SAA7134_BOARD_VIDEOMATE_DVBT_200:
5283 case SAA7134_BOARD_VIDEOMATE_DVBT_200A:
5284 /* The T200 and the T200A share the same pci id. Consequently,
5285 * we are going to query eeprom to try to find out which one we
5286 * are actually looking at. */
5287
5288 /* Don't do this if the board was specifically selected with an
5289 * insmod option or if we have the default configuration T200*/
5290 if(!dev->autodetected || (dev->eedata[0x41] == 0xd0))
5291 break;
5292 if(dev->eedata[0x41] == 0x02) {
5293 /* Reconfigure board as T200A */
5294 dev->board = SAA7134_BOARD_VIDEOMATE_DVBT_200A;
5295 dev->tuner_type = saa7134_boards[dev->board].tuner_type;
5296 dev->tda9887_conf = saa7134_boards[dev->board].tda9887_conf;
5297 printk(KERN_INFO "%s: Reconfigured board as %s\n",
5298 dev->name, saa7134_boards[dev->board].name);
5299 } else {
5300 printk(KERN_WARNING "%s: Unexpected tuner type info: %x in eeprom\n",
5301 dev->name, dev->eedata[0x41]);
5302 break;
5303 }
5304 break;
Linus Torvalds1da177e2005-04-16 15:20:36 -07005305 }
5306 return 0;
5307}
5308
5309/* ----------------------------------------------------------- */
5310/*
5311 * Local variables:
5312 * c-basic-offset: 8
5313 * End:
5314 */