blob: 88f0b8f06e10942330c69d11b05a0169d7e6a1ab [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>
Mauro Carvalho Chehabbc36a682008-04-22 14:45:27 -030025#include <linux/i2c.h>
26#include <linux/i2c-algo-bit.h>
Linus Torvalds1da177e2005-04-16 15:20:36 -070027
28#include "saa7134-reg.h"
29#include "saa7134.h"
Mauro Carvalho Chehabbc36a682008-04-22 14:45:27 -030030#include "tuner-xc2028.h"
Michael Krufky5e453dc2006-01-09 15:32:31 -020031#include <media/v4l2-common.h>
Michael Krufky993efa72007-11-15 10:34:33 -030032#include <media/tveeprom.h>
Dmitry Belimovb34dddb2008-04-23 14:09:08 -030033#include "tea5767.h"
Michael Krufkyf9996c92009-02-28 17:45:17 -030034#include "tda18271.h"
Linus Torvalds1da177e2005-04-16 15:20:36 -070035
36/* commly used strings */
37static char name_mute[] = "mute";
38static char name_radio[] = "Radio";
39static char name_tv[] = "Television";
40static char name_tv_mono[] = "TV (mono only)";
Stas Sergeevf438d972007-09-17 15:34:09 -030041static char name_comp[] = "Composite";
Linus Torvalds1da177e2005-04-16 15:20:36 -070042static char name_comp1[] = "Composite1";
43static char name_comp2[] = "Composite2";
44static char name_comp3[] = "Composite3";
45static char name_comp4[] = "Composite4";
46static char name_svideo[] = "S-Video";
47
48/* ------------------------------------------------------------------ */
49/* board config info */
50
Mauro Carvalho Chehabc117d052008-04-26 14:05:58 -030051/* If radio_type !=UNSET, radio_addr should be specified
52 */
53
Linus Torvalds1da177e2005-04-16 15:20:36 -070054struct saa7134_board saa7134_boards[] = {
55 [SAA7134_BOARD_UNKNOWN] = {
56 .name = "UNKNOWN/GENERIC",
57 .audio_clock = 0x00187de7,
58 .tuner_type = TUNER_ABSENT,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -070059 .radio_type = UNSET,
60 .tuner_addr = ADDR_UNSET,
61 .radio_addr = ADDR_UNSET,
62
Linus Torvalds1da177e2005-04-16 15:20:36 -070063 .inputs = {{
64 .name = "default",
65 .vmux = 0,
66 .amux = LINE1,
67 }},
68 },
69 [SAA7134_BOARD_PROTEUS_PRO] = {
70 /* /me */
71 .name = "Proteus Pro [philips reference design]",
72 .audio_clock = 0x00187de7,
73 .tuner_type = TUNER_PHILIPS_PAL,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -070074 .radio_type = UNSET,
75 .tuner_addr = ADDR_UNSET,
76 .radio_addr = ADDR_UNSET,
77
Linus Torvalds1da177e2005-04-16 15:20:36 -070078 .inputs = {{
79 .name = name_comp1,
80 .vmux = 0,
81 .amux = LINE1,
82 },{
83 .name = name_tv,
84 .vmux = 1,
85 .amux = TV,
86 .tv = 1,
87 },{
88 .name = name_tv_mono,
89 .vmux = 1,
90 .amux = LINE2,
91 .tv = 1,
92 }},
93 .radio = {
94 .name = name_radio,
95 .amux = LINE2,
96 },
97 },
98 [SAA7134_BOARD_FLYVIDEO3000] = {
99 /* "Marco d'Itri" <md@Linux.IT> */
100 .name = "LifeView FlyVIDEO3000",
101 .audio_clock = 0x00200000,
102 .tuner_type = TUNER_PHILIPS_PAL,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -0700103 .radio_type = UNSET,
104 .tuner_addr = ADDR_UNSET,
105 .radio_addr = ADDR_UNSET,
106
Linus Torvalds1da177e2005-04-16 15:20:36 -0700107 .gpiomask = 0xe000,
108 .inputs = {{
109 .name = name_tv,
110 .vmux = 1,
111 .amux = TV,
112 .gpio = 0x8000,
113 .tv = 1,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -0700114 },{
Linus Torvalds1da177e2005-04-16 15:20:36 -0700115 .name = name_tv_mono,
116 .vmux = 1,
117 .amux = LINE2,
118 .gpio = 0x0000,
119 .tv = 1,
120 },{
121 .name = name_comp1,
122 .vmux = 0,
123 .amux = LINE2,
124 .gpio = 0x4000,
125 },{
126 .name = name_comp2,
127 .vmux = 3,
128 .amux = LINE2,
129 .gpio = 0x4000,
130 },{
131 .name = name_svideo,
132 .vmux = 8,
133 .amux = LINE2,
134 .gpio = 0x4000,
135 }},
136 .radio = {
137 .name = name_radio,
138 .amux = LINE2,
139 .gpio = 0x2000,
140 },
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -0700141 .mute = {
142 .name = name_mute,
143 .amux = TV,
144 .gpio = 0x8000,
145 },
Linus Torvalds1da177e2005-04-16 15:20:36 -0700146 },
147 [SAA7134_BOARD_FLYVIDEO2000] = {
148 /* "TC Wan" <tcwan@cs.usm.my> */
Peter Missel10b7a902006-01-23 17:11:06 -0200149 .name = "LifeView/Typhoon FlyVIDEO2000",
Linus Torvalds1da177e2005-04-16 15:20:36 -0700150 .audio_clock = 0x00200000,
151 .tuner_type = TUNER_LG_PAL_NEW_TAPC,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -0700152 .radio_type = UNSET,
153 .tuner_addr = ADDR_UNSET,
154 .radio_addr = ADDR_UNSET,
155
Linus Torvalds1da177e2005-04-16 15:20:36 -0700156 .gpiomask = 0xe000,
157 .inputs = {{
158 .name = name_tv,
159 .vmux = 1,
160 .amux = LINE2,
161 .gpio = 0x0000,
162 .tv = 1,
163 },{
164 .name = name_comp1,
165 .vmux = 0,
166 .amux = LINE2,
167 .gpio = 0x4000,
168 },{
169 .name = name_comp2,
170 .vmux = 3,
171 .amux = LINE2,
172 .gpio = 0x4000,
173 },{
174 .name = name_svideo,
175 .vmux = 8,
176 .amux = LINE2,
177 .gpio = 0x4000,
178 }},
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -0700179 .radio = {
180 .name = name_radio,
181 .amux = LINE2,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700182 .gpio = 0x2000,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -0700183 },
Linus Torvalds1da177e2005-04-16 15:20:36 -0700184 .mute = {
185 .name = name_mute,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -0700186 .amux = LINE2,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700187 .gpio = 0x8000,
188 },
189 },
190 [SAA7134_BOARD_FLYTVPLATINUM_MINI] = {
191 /* "Arnaud Quette" <aquette@free.fr> */
192 .name = "LifeView FlyTV Platinum Mini",
193 .audio_clock = 0x00200000,
194 .tuner_type = TUNER_PHILIPS_TDA8290,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -0700195 .radio_type = UNSET,
196 .tuner_addr = ADDR_UNSET,
197 .radio_addr = ADDR_UNSET,
198
Linus Torvalds1da177e2005-04-16 15:20:36 -0700199 .inputs = {{
200 .name = name_tv,
201 .vmux = 1,
Mauro Carvalho Chehabac19ecc2005-06-23 22:05:09 -0700202 .amux = TV,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700203 .tv = 1,
204 },{
Glen Gray2d14f782005-11-08 21:36:12 -0800205 .name = name_comp1, /* Composite signal on S-Video input */
Linus Torvalds1da177e2005-04-16 15:20:36 -0700206 .vmux = 0,
207 .amux = LINE2,
208 },{
Glen Gray2d14f782005-11-08 21:36:12 -0800209 .name = name_comp2, /* Composite input */
210 .vmux = 3,
211 .amux = LINE2,
212 },{
Linus Torvalds1da177e2005-04-16 15:20:36 -0700213 .name = name_svideo,
214 .vmux = 8,
215 .amux = LINE2,
216 }},
217 },
218 [SAA7134_BOARD_FLYTVPLATINUM_FM] = {
219 /* LifeView FlyTV Platinum FM (LR214WF) */
220 /* "Peter Missel <peter.missel@onlinehome.de> */
Hartmut Hackmann42e6b3b2006-03-27 19:04:48 -0300221 .name = "LifeView FlyTV Platinum FM / Gold",
Linus Torvalds1da177e2005-04-16 15:20:36 -0700222 .audio_clock = 0x00200000,
223 .tuner_type = TUNER_PHILIPS_TDA8290,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -0700224 .radio_type = UNSET,
225 .tuner_addr = ADDR_UNSET,
226 .radio_addr = ADDR_UNSET,
227
Peter Missel6c9e7372005-05-01 08:59:05 -0700228 .gpiomask = 0x1E000, /* Set GP16 and unused 15,14,13 to Output */
Linus Torvalds1da177e2005-04-16 15:20:36 -0700229 .inputs = {{
230 .name = name_tv,
231 .vmux = 1,
232 .amux = TV,
Peter Missel6c9e7372005-05-01 08:59:05 -0700233 .gpio = 0x10000, /* GP16=1 selects TV input */
Linus Torvalds1da177e2005-04-16 15:20:36 -0700234 .tv = 1,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -0700235 },{
Linus Torvalds1da177e2005-04-16 15:20:36 -0700236/* .name = name_tv_mono,
237 .vmux = 1,
238 .amux = LINE2,
239 .gpio = 0x0000,
240 .tv = 1,
241 },{
242*/ .name = name_comp1, /* Composite signal on S-Video input */
243 .vmux = 0,
244 .amux = LINE2,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -0700245/* .gpio = 0x4000, */
Linus Torvalds1da177e2005-04-16 15:20:36 -0700246 },{
247 .name = name_comp2, /* Composite input */
248 .vmux = 3,
249 .amux = LINE2,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -0700250/* .gpio = 0x4000, */
Linus Torvalds1da177e2005-04-16 15:20:36 -0700251 },{
252 .name = name_svideo, /* S-Video signal on S-Video input */
253 .vmux = 8,
254 .amux = LINE2,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -0700255/* .gpio = 0x4000, */
Linus Torvalds1da177e2005-04-16 15:20:36 -0700256 }},
Peter Missel6c9e7372005-05-01 08:59:05 -0700257 .radio = {
Linus Torvalds1da177e2005-04-16 15:20:36 -0700258 .name = name_radio,
Peter Missel6c9e7372005-05-01 08:59:05 -0700259 .amux = TV,
260 .gpio = 0x00000, /* GP16=0 selects FM radio antenna */
Linus Torvalds1da177e2005-04-16 15:20:36 -0700261 },
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -0700262 .mute = {
263 .name = name_mute,
264 .amux = TV,
265 .gpio = 0x10000,
266 },
Peter Missel6c9e7372005-05-01 08:59:05 -0700267 },
Linus Torvalds1da177e2005-04-16 15:20:36 -0700268 [SAA7134_BOARD_EMPRESS] = {
269 /* "Gert Vervoort" <gert.vervoort@philips.com> */
270 .name = "EMPRESS",
271 .audio_clock = 0x00187de7,
272 .tuner_type = TUNER_PHILIPS_PAL,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -0700273 .radio_type = UNSET,
274 .tuner_addr = ADDR_UNSET,
275 .radio_addr = ADDR_UNSET,
276
Linus Torvalds1da177e2005-04-16 15:20:36 -0700277 .inputs = {{
278 .name = name_comp1,
279 .vmux = 0,
280 .amux = LINE1,
281 },{
282 .name = name_svideo,
283 .vmux = 8,
284 .amux = LINE1,
285 },{
286 .name = name_tv,
287 .vmux = 1,
288 .amux = LINE2,
289 .tv = 1,
290 }},
291 .radio = {
292 .name = name_radio,
293 .amux = LINE2,
294 },
295 .mpeg = SAA7134_MPEG_EMPRESS,
296 .video_out = CCIR656,
297 },
298 [SAA7134_BOARD_MONSTERTV] = {
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -0700299 /* "K.Ohta" <alpha292@bremen.or.jp> */
300 .name = "SKNet Monster TV",
301 .audio_clock = 0x00187de7,
302 .tuner_type = TUNER_PHILIPS_NTSC_M,
303 .radio_type = UNSET,
304 .tuner_addr = ADDR_UNSET,
305 .radio_addr = ADDR_UNSET,
306
307 .inputs = {{
308 .name = name_tv,
309 .vmux = 1,
310 .amux = TV,
311 .tv = 1,
312 },{
313 .name = name_comp1,
314 .vmux = 0,
315 .amux = LINE1,
316 },{
317 .name = name_svideo,
318 .vmux = 8,
319 .amux = LINE1,
320 }},
321 .radio = {
322 .name = name_radio,
323 .amux = LINE2,
324 },
Linus Torvalds1da177e2005-04-16 15:20:36 -0700325 },
326 [SAA7134_BOARD_MD9717] = {
327 .name = "Tevion MD 9717",
328 .audio_clock = 0x00200000,
329 .tuner_type = TUNER_PHILIPS_PAL,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -0700330 .radio_type = UNSET,
331 .tuner_addr = ADDR_UNSET,
332 .radio_addr = ADDR_UNSET,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700333 .inputs = {{
334 .name = name_tv,
335 .vmux = 1,
336 .amux = TV,
337 .tv = 1,
338 },{
339 /* workaround for problems with normal TV sound */
340 .name = name_tv_mono,
341 .vmux = 1,
342 .amux = LINE2,
343 .tv = 1,
344 },{
345 .name = name_comp1,
Hermann Pitton4aa504a2007-11-28 21:50:26 -0300346 .vmux = 0,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700347 .amux = LINE1,
348 },{
349 .name = name_comp2,
350 .vmux = 3,
351 .amux = LINE1,
352 },{
353 .name = name_svideo,
354 .vmux = 8,
355 .amux = LINE1,
356 }},
357 .radio = {
358 .name = name_radio,
359 .amux = LINE2,
360 },
Hermann Pittoncc764662007-11-28 21:54:35 -0300361 .mute = {
362 .name = name_mute,
363 .amux = TV,
364 },
Linus Torvalds1da177e2005-04-16 15:20:36 -0700365 },
366 [SAA7134_BOARD_TVSTATION_RDS] = {
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -0700367 /* Typhoon TV Tuner RDS: Art.Nr. 50694 */
Linus Torvalds1da177e2005-04-16 15:20:36 -0700368 .name = "KNC One TV-Station RDS / Typhoon TV Tuner RDS",
369 .audio_clock = 0x00200000,
370 .tuner_type = TUNER_PHILIPS_FM1216ME_MK3,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -0700371 .radio_type = UNSET,
372 .tuner_addr = ADDR_UNSET,
373 .radio_addr = ADDR_UNSET,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700374 .tda9887_conf = TDA9887_PRESENT,
375 .inputs = {{
376 .name = name_tv,
377 .vmux = 1,
378 .amux = TV,
379 .tv = 1,
380 },{
381 .name = name_tv_mono,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -0700382 .vmux = 1,
383 .amux = LINE2,
384 .tv = 1,
385 },{
Linus Torvalds1da177e2005-04-16 15:20:36 -0700386
387 .name = name_svideo,
388 .vmux = 8,
389 .amux = LINE1,
390 },{
391 .name = name_comp1,
392 .vmux = 3,
393 .amux = LINE1,
394 },{
395
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -0700396 .name = "CVid over SVid",
397 .vmux = 0,
398 .amux = LINE1,
399 }},
Linus Torvalds1da177e2005-04-16 15:20:36 -0700400 .radio = {
401 .name = name_radio,
402 .amux = LINE2,
403 },
404 },
405 [SAA7134_BOARD_TVSTATION_DVR] = {
406 .name = "KNC One TV-Station DVR",
407 .audio_clock = 0x00200000,
408 .tuner_type = TUNER_PHILIPS_FM1216ME_MK3,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -0700409 .radio_type = UNSET,
410 .tuner_addr = ADDR_UNSET,
411 .radio_addr = ADDR_UNSET,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700412 .tda9887_conf = TDA9887_PRESENT,
413 .gpiomask = 0x820000,
414 .inputs = {{
415 .name = name_tv,
416 .vmux = 1,
Rafał Bilskiaac0ca62007-06-20 05:36:26 -0300417 .amux = TV,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700418 .tv = 1,
419 .gpio = 0x20000,
420 },{
421 .name = name_svideo,
422 .vmux = 8,
423 .amux = LINE1,
424 .gpio = 0x20000,
425 },{
426 .name = name_comp1,
427 .vmux = 3,
428 .amux = LINE1,
429 .gpio = 0x20000,
430 }},
431 .radio = {
432 .name = name_radio,
433 .amux = LINE2,
434 .gpio = 0x20000,
435 },
436 .mpeg = SAA7134_MPEG_EMPRESS,
437 .video_out = CCIR656,
438 },
439 [SAA7134_BOARD_CINERGY400] = {
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -0700440 .name = "Terratec Cinergy 400 TV",
441 .audio_clock = 0x00200000,
442 .tuner_type = TUNER_PHILIPS_PAL,
443 .radio_type = UNSET,
444 .tuner_addr = ADDR_UNSET,
445 .radio_addr = ADDR_UNSET,
446 .inputs = {{
447 .name = name_tv,
448 .vmux = 1,
449 .amux = TV,
450 .tv = 1,
451 },{
452 .name = name_comp1,
453 .vmux = 4,
454 .amux = LINE1,
455 },{
456 .name = name_svideo,
457 .vmux = 8,
458 .amux = LINE1,
459 },{
460 .name = name_comp2, /* CVideo over SVideo Connector */
461 .vmux = 0,
462 .amux = LINE1,
463 }}
464 },
Linus Torvalds1da177e2005-04-16 15:20:36 -0700465 [SAA7134_BOARD_MD5044] = {
466 .name = "Medion 5044",
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -0700467 .audio_clock = 0x00187de7, /* was: 0x00200000, */
Linus Torvalds1da177e2005-04-16 15:20:36 -0700468 .tuner_type = TUNER_PHILIPS_FM1216ME_MK3,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -0700469 .radio_type = UNSET,
470 .tuner_addr = ADDR_UNSET,
471 .radio_addr = ADDR_UNSET,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700472 .tda9887_conf = TDA9887_PRESENT,
473 .inputs = {{
474 .name = name_tv,
475 .vmux = 1,
476 .amux = TV,
477 .tv = 1,
478 },{
479 /* workaround for problems with normal TV sound */
480 .name = name_tv_mono,
481 .vmux = 1,
482 .amux = LINE2,
483 .tv = 1,
484 },{
485 .name = name_comp1,
486 .vmux = 0,
487 .amux = LINE2,
488 },{
489 .name = name_comp2,
490 .vmux = 3,
491 .amux = LINE2,
492 },{
493 .name = name_svideo,
494 .vmux = 8,
495 .amux = LINE2,
496 }},
497 .radio = {
498 .name = name_radio,
499 .amux = LINE2,
500 },
501 },
502 [SAA7134_BOARD_KWORLD] = {
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -0700503 .name = "Kworld/KuroutoShikou SAA7130-TVPCI",
Linus Torvalds1da177e2005-04-16 15:20:36 -0700504 .audio_clock = 0x00187de7,
505 .tuner_type = TUNER_PHILIPS_NTSC_M,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -0700506 .radio_type = UNSET,
507 .tuner_addr = ADDR_UNSET,
508 .radio_addr = ADDR_UNSET,
509 .inputs = {{
510 .name = name_svideo,
511 .vmux = 8,
512 .amux = LINE1,
513 },{
514 .name = name_comp1,
515 .vmux = 3,
516 .amux = LINE1,
517 },{
518 .name = name_tv,
519 .vmux = 1,
520 .amux = LINE2,
521 .tv = 1,
522 }},
523 },
Linus Torvalds1da177e2005-04-16 15:20:36 -0700524 [SAA7134_BOARD_CINERGY600] = {
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -0700525 .name = "Terratec Cinergy 600 TV",
526 .audio_clock = 0x00200000,
527 .tuner_type = TUNER_PHILIPS_PAL,
528 .radio_type = UNSET,
529 .tuner_addr = ADDR_UNSET,
530 .radio_addr = ADDR_UNSET,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700531 .tda9887_conf = TDA9887_PRESENT,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -0700532 .inputs = {{
533 .name = name_tv,
534 .vmux = 1,
535 .amux = TV,
536 .tv = 1,
537 },{
538 .name = name_comp1,
539 .vmux = 4,
540 .amux = LINE1,
541 },{
542 .name = name_svideo,
543 .vmux = 8,
544 .amux = LINE1,
545 },{
546 .name = name_comp2, /* CVideo over SVideo Connector */
547 .vmux = 0,
548 .amux = LINE1,
549 }},
Linus Torvalds1da177e2005-04-16 15:20:36 -0700550 .radio = {
551 .name = name_radio,
552 .amux = LINE2,
Michael Krufky67ac9a42006-03-14 16:18:49 -0300553 },
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -0700554 },
Linus Torvalds1da177e2005-04-16 15:20:36 -0700555 [SAA7134_BOARD_MD7134] = {
556 .name = "Medion 7134",
Linus Torvalds1da177e2005-04-16 15:20:36 -0700557 .audio_clock = 0x00187de7,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -0700558 .tuner_type = TUNER_PHILIPS_FMD1216ME_MK3,
559 .radio_type = UNSET,
560 .tuner_addr = ADDR_UNSET,
561 .radio_addr = ADDR_UNSET,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700562 .tda9887_conf = TDA9887_PRESENT,
563 .mpeg = SAA7134_MPEG_DVB,
564 .inputs = {{
565 .name = name_tv,
566 .vmux = 1,
567 .amux = TV,
568 .tv = 1,
569 },{
570 .name = name_comp1,
571 .vmux = 0,
572 .amux = LINE1,
573 },{
574 .name = name_svideo,
575 .vmux = 8,
576 .amux = LINE1,
577 }},
578 .radio = {
579 .name = name_radio,
580 .amux = LINE2,
Hermann Pittoncc764662007-11-28 21:54:35 -0300581 },
582 .mute = {
583 .name = name_mute,
584 .amux = TV,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700585 },
586 },
587 [SAA7134_BOARD_TYPHOON_90031] = {
588 /* aka Typhoon "TV+Radio", Art.Nr 90031 */
589 /* Tom Zoerner <tomzo at users sourceforge net> */
590 .name = "Typhoon TV+Radio 90031",
591 .audio_clock = 0x00200000,
592 .tuner_type = TUNER_PHILIPS_PAL,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -0700593 .radio_type = UNSET,
594 .tuner_addr = ADDR_UNSET,
595 .radio_addr = ADDR_UNSET,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700596 .tda9887_conf = TDA9887_PRESENT,
597 .inputs = {{
598 .name = name_tv,
599 .vmux = 1,
600 .amux = TV,
601 .tv = 1,
602 },{
603 .name = name_comp1,
604 .vmux = 3,
605 .amux = LINE1,
606 },{
607 .name = name_svideo,
608 .vmux = 8,
609 .amux = LINE1,
610 }},
611 .radio = {
612 .name = name_radio,
613 .amux = LINE2,
614 },
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -0700615 },
Linus Torvalds1da177e2005-04-16 15:20:36 -0700616 [SAA7134_BOARD_ELSA] = {
617 .name = "ELSA EX-VISION 300TV",
618 .audio_clock = 0x00187de7,
619 .tuner_type = TUNER_HITACHI_NTSC,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -0700620 .radio_type = UNSET,
621 .tuner_addr = ADDR_UNSET,
622 .radio_addr = ADDR_UNSET,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700623 .inputs = {{
624 .name = name_svideo,
625 .vmux = 8,
626 .amux = LINE1,
627 },{
628 .name = name_comp1,
629 .vmux = 0,
630 .amux = LINE1,
631 },{
632 .name = name_tv,
633 .vmux = 4,
634 .amux = LINE2,
635 .tv = 1,
636 }},
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -0700637 },
Linus Torvalds1da177e2005-04-16 15:20:36 -0700638 [SAA7134_BOARD_ELSA_500TV] = {
639 .name = "ELSA EX-VISION 500TV",
640 .audio_clock = 0x00187de7,
641 .tuner_type = TUNER_HITACHI_NTSC,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -0700642 .radio_type = UNSET,
643 .tuner_addr = ADDR_UNSET,
644 .radio_addr = ADDR_UNSET,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700645 .inputs = {{
646 .name = name_svideo,
647 .vmux = 7,
648 .amux = LINE1,
649 },{
650 .name = name_tv,
651 .vmux = 8,
652 .amux = TV,
653 .tv = 1,
654 },{
655 .name = name_tv_mono,
656 .vmux = 8,
657 .amux = LINE2,
658 .tv = 1,
659 }},
Linus Torvalds1da177e2005-04-16 15:20:36 -0700660 },
Tamuki Shoichid0456d12006-02-27 00:08:04 -0300661 [SAA7134_BOARD_ELSA_700TV] = {
662 .name = "ELSA EX-VISION 700TV",
663 .audio_clock = 0x00187de7,
664 .tuner_type = TUNER_HITACHI_NTSC,
665 .radio_type = UNSET,
666 .tuner_addr = ADDR_UNSET,
667 .radio_addr = ADDR_UNSET,
668 .inputs = {{
669 .name = name_tv,
670 .vmux = 4,
671 .amux = LINE2,
672 .tv = 1,
673 },{
674 .name = name_comp1,
675 .vmux = 6,
676 .amux = LINE1,
677 },{
678 .name = name_svideo,
679 .vmux = 7,
680 .amux = LINE1,
681 }},
682 .mute = {
683 .name = name_mute,
684 .amux = TV,
685 },
686 },
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -0700687 [SAA7134_BOARD_ASUSTeK_TVFM7134] = {
688 .name = "ASUS TV-FM 7134",
689 .audio_clock = 0x00187de7,
690 .tuner_type = TUNER_PHILIPS_FM1216ME_MK3,
691 .radio_type = UNSET,
692 .tuner_addr = ADDR_UNSET,
693 .radio_addr = ADDR_UNSET,
694 .tda9887_conf = TDA9887_PRESENT,
695 .inputs = {{
696 .name = name_tv,
697 .vmux = 1,
698 .amux = TV,
699 .tv = 1,
700 },{
701 .name = name_comp1,
702 .vmux = 4,
703 .amux = LINE2,
704 },{
705 .name = name_svideo,
706 .vmux = 6,
707 .amux = LINE2,
708 }},
709 .radio = {
710 .name = name_radio,
711 .amux = LINE1,
712 },
713 },
714 [SAA7134_BOARD_ASUSTeK_TVFM7135] = {
715 .name = "ASUS TV-FM 7135",
716 .audio_clock = 0x00187de7,
717 .tuner_type = TUNER_PHILIPS_TDA8290,
718 .radio_type = UNSET,
719 .tuner_addr = ADDR_UNSET,
720 .radio_addr = ADDR_UNSET,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700721 .gpiomask = 0x200000,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -0700722 .inputs = {{
723 .name = name_tv,
724 .vmux = 1,
725 .amux = TV,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700726 .gpio = 0x0000,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -0700727 .tv = 1,
728 },{
729 .name = name_comp1,
730 .vmux = 4,
731 .amux = LINE2,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700732 .gpio = 0x0000,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -0700733 },{
734 .name = name_svideo,
735 .vmux = 6,
736 .amux = LINE2,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700737 .gpio = 0x0000,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -0700738 }},
739 .radio = {
740 .name = name_radio,
741 .amux = TV,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700742 .gpio = 0x200000,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -0700743 },
744 .mute = {
745 .name = name_mute,
746 .gpio = 0x0000,
747 },
748
Linus Torvalds1da177e2005-04-16 15:20:36 -0700749 },
750 [SAA7134_BOARD_VA1000POWER] = {
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -0700751 .name = "AOPEN VA1000 POWER",
Linus Torvalds1da177e2005-04-16 15:20:36 -0700752 .audio_clock = 0x00187de7,
753 .tuner_type = TUNER_PHILIPS_NTSC,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -0700754 .radio_type = UNSET,
755 .tuner_addr = ADDR_UNSET,
756 .radio_addr = ADDR_UNSET,
757 .inputs = {{
758 .name = name_svideo,
759 .vmux = 8,
760 .amux = LINE1,
761 },{
762 .name = name_comp1,
763 .vmux = 3,
764 .amux = LINE1,
765 },{
766 .name = name_tv,
767 .vmux = 1,
768 .amux = LINE2,
769 .tv = 1,
770 }},
Linus Torvalds1da177e2005-04-16 15:20:36 -0700771 },
772 [SAA7134_BOARD_10MOONSTVMASTER] = {
773 /* "lilicheng" <llc@linuxfans.org> */
774 .name = "10MOONS PCI TV CAPTURE CARD",
775 .audio_clock = 0x00200000,
776 .tuner_type = TUNER_LG_PAL_NEW_TAPC,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -0700777 .radio_type = UNSET,
778 .tuner_addr = ADDR_UNSET,
779 .radio_addr = ADDR_UNSET,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700780 .gpiomask = 0xe000,
781 .inputs = {{
782 .name = name_tv,
783 .vmux = 1,
784 .amux = LINE2,
785 .gpio = 0x0000,
786 .tv = 1,
787 },{
788 .name = name_comp1,
789 .vmux = 0,
790 .amux = LINE2,
791 .gpio = 0x4000,
792 },{
793 .name = name_comp2,
794 .vmux = 3,
795 .amux = LINE2,
796 .gpio = 0x4000,
797 },{
798 .name = name_svideo,
799 .vmux = 8,
800 .amux = LINE2,
801 .gpio = 0x4000,
802 }},
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -0700803 .radio = {
804 .name = name_radio,
805 .amux = LINE2,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700806 .gpio = 0x2000,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -0700807 },
Linus Torvalds1da177e2005-04-16 15:20:36 -0700808 .mute = {
809 .name = name_mute,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -0700810 .amux = LINE2,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700811 .gpio = 0x8000,
812 },
813 },
814 [SAA7134_BOARD_BMK_MPEX_NOTUNER] = {
815 /* "Andrew de Quincey" <adq@lidskialf.net> */
816 .name = "BMK MPEX No Tuner",
817 .audio_clock = 0x200000,
818 .tuner_type = TUNER_ABSENT,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -0700819 .radio_type = UNSET,
820 .tuner_addr = ADDR_UNSET,
821 .radio_addr = ADDR_UNSET,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700822 .inputs = {{
823 .name = name_comp1,
824 .vmux = 4,
825 .amux = LINE1,
826 },{
827 .name = name_comp2,
828 .vmux = 3,
829 .amux = LINE1,
830 },{
831 .name = name_comp3,
832 .vmux = 0,
833 .amux = LINE1,
834 },{
835 .name = name_comp4,
836 .vmux = 1,
837 .amux = LINE1,
838 },{
839 .name = name_svideo,
840 .vmux = 8,
841 .amux = LINE1,
842 }},
843 .mpeg = SAA7134_MPEG_EMPRESS,
844 .video_out = CCIR656,
845 },
846 [SAA7134_BOARD_VIDEOMATE_TV] = {
847 .name = "Compro VideoMate TV",
848 .audio_clock = 0x00187de7,
849 .tuner_type = TUNER_PHILIPS_NTSC_M,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -0700850 .radio_type = UNSET,
851 .tuner_addr = ADDR_UNSET,
852 .radio_addr = ADDR_UNSET,
853 .inputs = {{
854 .name = name_svideo,
855 .vmux = 8,
856 .amux = LINE1,
857 },{
858 .name = name_comp1,
859 .vmux = 3,
860 .amux = LINE1,
861 },{
862 .name = name_tv,
863 .vmux = 1,
864 .amux = LINE2,
865 .tv = 1,
866 }},
867 },
868 [SAA7134_BOARD_VIDEOMATE_TV_GOLD_PLUS] = {
Linus Torvalds1da177e2005-04-16 15:20:36 -0700869 .name = "Compro VideoMate TV Gold+",
870 .audio_clock = 0x00187de7,
871 .tuner_type = TUNER_PHILIPS_NTSC_M,
872 .gpiomask = 0x800c0000,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -0700873 .radio_type = UNSET,
874 .tuner_addr = ADDR_UNSET,
875 .radio_addr = ADDR_UNSET,
876 .inputs = {{
877 .name = name_svideo,
878 .vmux = 8,
879 .amux = LINE1,
880 .gpio = 0x06c00012,
881 },{
882 .name = name_comp1,
883 .vmux = 3,
884 .amux = LINE1,
885 .gpio = 0x0ac20012,
886 },{
887 .name = name_tv,
888 .vmux = 1,
889 .amux = LINE2,
890 .gpio = 0x08c20012,
891 .tv = 1,
892 }}, /* radio and probably mute is missing */
893 },
Linus Torvalds1da177e2005-04-16 15:20:36 -0700894 [SAA7134_BOARD_CRONOS_PLUS] = {
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -0700895 /*
896 gpio pins:
897 0 .. 3 BASE_ID
898 4 .. 7 PROTECT_ID
899 8 .. 11 USER_OUT
900 12 .. 13 USER_IN
901 14 .. 15 VIDIN_SEL
902 */
Linus Torvalds1da177e2005-04-16 15:20:36 -0700903 .name = "Matrox CronosPlus",
904 .tuner_type = TUNER_ABSENT,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -0700905 .radio_type = UNSET,
906 .tuner_addr = ADDR_UNSET,
907 .radio_addr = ADDR_UNSET,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700908 .gpiomask = 0xcf00,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -0700909 .inputs = {{
910 .name = name_comp1,
911 .vmux = 0,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700912 .gpio = 2 << 14,
913 },{
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -0700914 .name = name_comp2,
915 .vmux = 0,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700916 .gpio = 1 << 14,
917 },{
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -0700918 .name = name_comp3,
919 .vmux = 0,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700920 .gpio = 0 << 14,
921 },{
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -0700922 .name = name_comp4,
923 .vmux = 0,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700924 .gpio = 3 << 14,
925 },{
926 .name = name_svideo,
927 .vmux = 8,
928 .gpio = 2 << 14,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -0700929 }},
930 },
Linus Torvalds1da177e2005-04-16 15:20:36 -0700931 [SAA7134_BOARD_MD2819] = {
932 .name = "AverMedia M156 / Medion 2819",
933 .audio_clock = 0x00187de7,
934 .tuner_type = TUNER_PHILIPS_FM1216ME_MK3,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -0700935 .radio_type = UNSET,
936 .tuner_addr = ADDR_UNSET,
937 .radio_addr = ADDR_UNSET,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700938 .tda9887_conf = TDA9887_PRESENT,
Hermann Pittonad1ef132008-01-20 19:32:39 -0300939 .gpiomask = 0x03,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700940 .inputs = {{
941 .name = name_tv,
942 .vmux = 1,
943 .amux = TV,
944 .tv = 1,
Hermann Pittonad1ef132008-01-20 19:32:39 -0300945 .gpio = 0x00,
946 }, {
Linus Torvalds1da177e2005-04-16 15:20:36 -0700947 .name = name_comp1,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700948 .vmux = 3,
Hermann Pittonad1ef132008-01-20 19:32:39 -0300949 .amux = LINE1,
950 .gpio = 0x02,
951 }, {
952 .name = name_comp2,
953 .vmux = 0,
954 .amux = LINE1,
955 .gpio = 0x02,
956 }, {
Linus Torvalds1da177e2005-04-16 15:20:36 -0700957 .name = name_svideo,
958 .vmux = 8,
Hermann Pittonad1ef132008-01-20 19:32:39 -0300959 .amux = LINE1,
960 .gpio = 0x02,
961 } },
Linus Torvalds1da177e2005-04-16 15:20:36 -0700962 .radio = {
963 .name = name_radio,
Hermann Pittonad1ef132008-01-20 19:32:39 -0300964 .amux = LINE1,
965 .gpio = 0x01,
966 },
967 .mute = {
968 .name = name_mute,
969 .amux = TV,
970 .gpio = 0x00,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700971 },
972 },
973 [SAA7134_BOARD_BMK_MPEX_TUNER] = {
974 /* "Greg Wickham <greg.wickham@grangenet.net> */
975 .name = "BMK MPEX Tuner",
976 .audio_clock = 0x200000,
977 .tuner_type = TUNER_PHILIPS_PAL,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -0700978 .radio_type = UNSET,
979 .tuner_addr = ADDR_UNSET,
980 .radio_addr = ADDR_UNSET,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700981 .inputs = {{
982 .name = name_comp1,
983 .vmux = 1,
984 .amux = LINE1,
985 },{
986 .name = name_svideo,
987 .vmux = 8,
988 .amux = LINE1,
989 },{
990 .name = name_tv,
991 .vmux = 3,
992 .amux = TV,
993 .tv = 1,
994 }},
995 .mpeg = SAA7134_MPEG_EMPRESS,
996 .video_out = CCIR656,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -0700997 },
998 [SAA7134_BOARD_ASUSTEK_TVFM7133] = {
999 .name = "ASUS TV-FM 7133",
1000 .audio_clock = 0x00187de7,
1001 /* probably wrong, the 7133 one is the NTSC version ...
1002 * .tuner_type = TUNER_PHILIPS_FM1236_MK3 */
1003 .tuner_type = TUNER_LG_NTSC_NEW_TAPC,
1004 .radio_type = UNSET,
1005 .tuner_addr = ADDR_UNSET,
1006 .radio_addr = ADDR_UNSET,
1007 .tda9887_conf = TDA9887_PRESENT,
1008 .inputs = {{
1009 .name = name_tv,
1010 .vmux = 1,
1011 .amux = TV,
1012 .tv = 1,
1013
Linus Torvalds1da177e2005-04-16 15:20:36 -07001014 },{
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07001015 .name = name_comp1,
1016 .vmux = 4,
1017 .amux = LINE2,
1018 },{
1019 .name = name_svideo,
1020 .vmux = 6,
1021 .amux = LINE2,
1022 }},
1023 .radio = {
1024 .name = name_radio,
1025 .amux = LINE1,
1026 },
1027 },
Linus Torvalds1da177e2005-04-16 15:20:36 -07001028 [SAA7134_BOARD_PINNACLE_PCTV_STEREO] = {
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07001029 .name = "Pinnacle PCTV Stereo (saa7134)",
1030 .audio_clock = 0x00187de7,
1031 .tuner_type = TUNER_MT2032,
1032 .radio_type = UNSET,
1033 .tuner_addr = ADDR_UNSET,
1034 .radio_addr = ADDR_UNSET,
Hartmut Hackmanndf8cf702006-03-03 12:09:26 -03001035 .tda9887_conf = TDA9887_PRESENT | TDA9887_INTERCARRIER | TDA9887_PORT2_INACTIVE,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07001036 .inputs = {{
1037 .name = name_tv,
1038 .vmux = 3,
1039 .amux = TV,
1040 .tv = 1,
1041 },{
1042 .name = name_comp1,
1043 .vmux = 0,
1044 .amux = LINE2,
1045 },{
1046 .name = name_comp2,
1047 .vmux = 1,
1048 .amux = LINE2,
1049 },{
1050 .name = name_svideo,
1051 .vmux = 8,
1052 .amux = LINE2,
1053 }},
1054 },
Linus Torvalds1da177e2005-04-16 15:20:36 -07001055 [SAA7134_BOARD_MANLI_MTV002] = {
1056 /* Ognjen Nastic <ognjen@logosoft.ba> */
Dmitry Belimovb34dddb2008-04-23 14:09:08 -03001057 .name = "Manli MuchTV M-TV002",
Linus Torvalds1da177e2005-04-16 15:20:36 -07001058 .audio_clock = 0x00200000,
1059 .tuner_type = TUNER_PHILIPS_PAL,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07001060 .radio_type = UNSET,
1061 .tuner_addr = ADDR_UNSET,
1062 .radio_addr = ADDR_UNSET,
Linus Torvalds1da177e2005-04-16 15:20:36 -07001063 .inputs = {{
1064 .name = name_svideo,
1065 .vmux = 8,
1066 .amux = LINE1,
1067 },{
1068 .name = name_comp1,
1069 .vmux = 1,
1070 .amux = LINE1,
1071 },{
1072 .name = name_tv,
1073 .vmux = 3,
1074 .amux = LINE2,
1075 .tv = 1,
1076 }},
1077 .radio = {
1078 .name = name_radio,
1079 .amux = LINE2,
1080 },
Linus Torvalds1da177e2005-04-16 15:20:36 -07001081 },
1082 [SAA7134_BOARD_MANLI_MTV001] = {
1083 /* Ognjen Nastic <ognjen@logosoft.ba> UNTESTED */
Dmitry Belimovb34dddb2008-04-23 14:09:08 -03001084 .name = "Manli MuchTV M-TV001",
Linus Torvalds1da177e2005-04-16 15:20:36 -07001085 .audio_clock = 0x00200000,
1086 .tuner_type = TUNER_PHILIPS_PAL,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07001087 .radio_type = UNSET,
1088 .tuner_addr = ADDR_UNSET,
1089 .radio_addr = ADDR_UNSET,
Linus Torvalds1da177e2005-04-16 15:20:36 -07001090 .inputs = {{
1091 .name = name_svideo,
1092 .vmux = 8,
1093 .amux = LINE1,
1094 },{
1095 .name = name_comp1,
1096 .vmux = 1,
1097 .amux = LINE1,
1098 },{
1099 .name = name_tv,
1100 .vmux = 3,
1101 .amux = LINE2,
1102 .tv = 1,
1103 }},
Mauro Carvalho Chehabac19ecc2005-06-23 22:05:09 -07001104 .mute = {
1105 .name = name_mute,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07001106 .amux = LINE1,
Mauro Carvalho Chehabac19ecc2005-06-23 22:05:09 -07001107 },
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07001108 },
Linus Torvalds1da177e2005-04-16 15:20:36 -07001109 [SAA7134_BOARD_TG3000TV] = {
1110 /* TransGear 3000TV */
1111 .name = "Nagase Sangyo TransGear 3000TV",
1112 .audio_clock = 0x00187de7,
1113 .tuner_type = TUNER_PHILIPS_NTSC_M,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07001114 .radio_type = UNSET,
1115 .tuner_addr = ADDR_UNSET,
1116 .radio_addr = ADDR_UNSET,
Linus Torvalds1da177e2005-04-16 15:20:36 -07001117 .inputs = {{
1118 .name = name_tv,
1119 .vmux = 1,
1120 .amux = LINE2,
1121 .tv = 1,
1122 },{
1123 .name = name_comp1,
1124 .vmux = 3,
1125 .amux = LINE2,
1126 },{
1127 .name = name_svideo,
1128 .vmux = 8,
1129 .amux = LINE2,
1130 }},
1131 },
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07001132 [SAA7134_BOARD_ECS_TVP3XP] = {
1133 .name = "Elitegroup ECS TVP3XP FM1216 Tuner Card(PAL-BG,FM) ",
1134 .audio_clock = 0x187de7, /* xtal 32.1 MHz */
1135 .tuner_type = TUNER_PHILIPS_PAL,
1136 .radio_type = UNSET,
1137 .tuner_addr = ADDR_UNSET,
1138 .radio_addr = ADDR_UNSET,
1139 .inputs = {{
1140 .name = name_tv,
1141 .vmux = 1,
1142 .amux = TV,
1143 .tv = 1,
1144 },{
1145 .name = name_tv_mono,
1146 .vmux = 1,
1147 .amux = LINE2,
1148 .tv = 1,
1149 },{
1150 .name = name_comp1,
1151 .vmux = 3,
1152 .amux = LINE1,
1153 },{
1154 .name = name_svideo,
1155 .vmux = 8,
1156 .amux = LINE1,
Linus Torvalds1da177e2005-04-16 15:20:36 -07001157 },{
1158 .name = "CVid over SVid",
1159 .vmux = 0,
1160 .amux = LINE1,
1161 }},
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07001162 .radio = {
1163 .name = name_radio,
1164 .amux = LINE2,
1165 },
1166 },
1167 [SAA7134_BOARD_ECS_TVP3XP_4CB5] = {
1168 .name = "Elitegroup ECS TVP3XP FM1236 Tuner Card (NTSC,FM)",
1169 .audio_clock = 0x187de7,
1170 .tuner_type = TUNER_PHILIPS_NTSC,
1171 .radio_type = UNSET,
1172 .tuner_addr = ADDR_UNSET,
1173 .radio_addr = ADDR_UNSET,
1174 .inputs = {{
1175 .name = name_tv,
1176 .vmux = 1,
1177 .amux = TV,
1178 .tv = 1,
1179 },{
1180 .name = name_tv_mono,
1181 .vmux = 1,
1182 .amux = LINE2,
1183 .tv = 1,
1184 },{
1185 .name = name_comp1,
1186 .vmux = 3,
1187 .amux = LINE1,
1188 },{
1189 .name = name_svideo,
1190 .vmux = 8,
1191 .amux = LINE1,
1192 },{
1193 .name = "CVid over SVid",
1194 .vmux = 0,
1195 .amux = LINE1,
1196 }},
1197 .radio = {
1198 .name = name_radio,
1199 .amux = LINE2,
1200 },
1201 },
Simon Farnsworthb39423a2007-05-01 10:01:20 -03001202 [SAA7134_BOARD_ECS_TVP3XP_4CB6] = {
1203 /* Barry Scott <barry.scott@onelan.co.uk> */
1204 .name = "Elitegroup ECS TVP3XP FM1246 Tuner Card (PAL,FM)",
1205 .audio_clock = 0x187de7,
1206 .tuner_type = TUNER_PHILIPS_PAL_I,
1207 .radio_type = UNSET,
1208 .tuner_addr = ADDR_UNSET,
1209 .radio_addr = ADDR_UNSET,
1210 .inputs = {{
1211 .name = name_tv,
1212 .vmux = 1,
1213 .amux = TV,
1214 .tv = 1,
1215 },{
1216 .name = name_tv_mono,
1217 .vmux = 1,
1218 .amux = LINE2,
1219 .tv = 1,
1220 },{
1221 .name = name_comp1,
1222 .vmux = 3,
1223 .amux = LINE1,
1224 },{
1225 .name = name_svideo,
1226 .vmux = 8,
1227 .amux = LINE1,
1228 },{
1229 .name = "CVid over SVid",
1230 .vmux = 0,
1231 .amux = LINE1,
1232 }},
1233 .radio = {
1234 .name = name_radio,
1235 .amux = LINE2,
1236 },
1237 },
Linus Torvalds1da177e2005-04-16 15:20:36 -07001238 [SAA7134_BOARD_AVACSSMARTTV] = {
1239 /* Roman Pszonczenko <romka@kolos.math.uni.lodz.pl> */
1240 .name = "AVACS SmartTV",
1241 .audio_clock = 0x00187de7,
1242 .tuner_type = TUNER_PHILIPS_PAL,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07001243 .radio_type = UNSET,
1244 .tuner_addr = ADDR_UNSET,
1245 .radio_addr = ADDR_UNSET,
Linus Torvalds1da177e2005-04-16 15:20:36 -07001246 .inputs = {{
1247 .name = name_tv,
1248 .vmux = 1,
1249 .amux = TV,
1250 .tv = 1,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07001251 },{
Linus Torvalds1da177e2005-04-16 15:20:36 -07001252 .name = name_tv_mono,
1253 .vmux = 1,
1254 .amux = LINE2,
1255 .tv = 1,
1256 },{
1257 .name = name_comp1,
1258 .vmux = 0,
1259 .amux = LINE2,
1260 },{
1261 .name = name_comp2,
1262 .vmux = 3,
1263 .amux = LINE2,
1264 },{
1265 .name = name_svideo,
1266 .vmux = 8,
1267 .amux = LINE2,
1268 }},
1269 .radio = {
1270 .name = name_radio,
1271 .amux = LINE2,
1272 .gpio = 0x200000,
1273 },
1274 },
1275 [SAA7134_BOARD_AVERMEDIA_DVD_EZMAKER] = {
1276 /* Michael Smith <msmith@cbnco.com> */
1277 .name = "AVerMedia DVD EZMaker",
1278 .audio_clock = 0x00187de7,
1279 .tuner_type = TUNER_ABSENT,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07001280 .radio_type = UNSET,
1281 .tuner_addr = ADDR_UNSET,
1282 .radio_addr = ADDR_UNSET,
Linus Torvalds1da177e2005-04-16 15:20:36 -07001283 .inputs = {{
1284 .name = name_comp1,
1285 .vmux = 3,
1286 },{
1287 .name = name_svideo,
1288 .vmux = 8,
1289 }},
1290 },
Massimo Piccionie2fc00c2008-07-11 13:48:02 -03001291 [SAA7134_BOARD_AVERMEDIA_M103] = {
1292 /* Massimo Piccioni <dafastidio@libero.it> */
1293 .name = "AVerMedia MiniPCI DVB-T Hybrid M103",
1294 .audio_clock = 0x187de7,
1295 .tuner_type = TUNER_XC2028,
1296 .radio_type = UNSET,
1297 .tuner_addr = ADDR_UNSET,
1298 .radio_addr = ADDR_UNSET,
1299 .mpeg = SAA7134_MPEG_DVB,
1300 .inputs = {{
1301 .name = name_tv,
1302 .vmux = 1,
1303 .amux = TV,
1304 .tv = 1,
1305 } },
1306 },
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07001307 [SAA7134_BOARD_NOVAC_PRIMETV7133] = {
1308 /* toshii@netbsd.org */
1309 .name = "Noval Prime TV 7133",
1310 .audio_clock = 0x00200000,
1311 .tuner_type = TUNER_ALPS_TSBH1_NTSC,
1312 .radio_type = UNSET,
1313 .tuner_addr = ADDR_UNSET,
1314 .radio_addr = ADDR_UNSET,
1315 .inputs = {{
1316 .name = name_comp1,
1317 .vmux = 3,
1318 },{
1319 .name = name_tv,
1320 .vmux = 1,
1321 .amux = TV,
1322 .tv = 1,
1323 },{
1324 .name = name_svideo,
1325 .vmux = 8,
1326 }},
1327 },
Linus Torvalds1da177e2005-04-16 15:20:36 -07001328 [SAA7134_BOARD_AVERMEDIA_STUDIO_305] = {
1329 .name = "AverMedia AverTV Studio 305",
1330 .audio_clock = 0x00187de7,
1331 .tuner_type = TUNER_PHILIPS_FM1256_IH3,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07001332 .radio_type = UNSET,
1333 .tuner_addr = ADDR_UNSET,
1334 .radio_addr = ADDR_UNSET,
Linus Torvalds1da177e2005-04-16 15:20:36 -07001335 .tda9887_conf = TDA9887_PRESENT,
Linus Torvalds1da177e2005-04-16 15:20:36 -07001336 .inputs = {{
1337 .name = name_tv,
1338 .vmux = 1,
1339 .amux = LINE2,
1340 .tv = 1,
1341 },{
1342 .name = name_comp1,
1343 .vmux = 0,
1344 .amux = LINE2,
1345 },{
1346 .name = name_comp2,
1347 .vmux = 3,
1348 .amux = LINE2,
1349 },{
1350 .name = name_svideo,
1351 .vmux = 8,
1352 .amux = LINE2,
1353 }},
1354 .radio = {
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07001355 .name = name_radio,
1356 .amux = LINE2,
1357 },
Linus Torvalds1da177e2005-04-16 15:20:36 -07001358 .mute = {
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07001359 .name = name_mute,
1360 .amux = LINE1,
Linus Torvalds1da177e2005-04-16 15:20:36 -07001361 },
1362 },
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07001363 [SAA7134_BOARD_UPMOST_PURPLE_TV] = {
1364 .name = "UPMOST PURPLE TV",
1365 .audio_clock = 0x00187de7,
1366 .tuner_type = TUNER_PHILIPS_FM1236_MK3,
1367 .radio_type = UNSET,
1368 .tuner_addr = ADDR_UNSET,
1369 .radio_addr = ADDR_UNSET,
1370 .tda9887_conf = TDA9887_PRESENT,
1371 .inputs = {{
1372 .name = name_tv,
1373 .vmux = 7,
1374 .amux = TV,
1375 .tv = 1,
1376 },{
1377 .name = name_svideo,
1378 .vmux = 7,
1379 .amux = LINE1,
1380 }},
Linus Torvalds1da177e2005-04-16 15:20:36 -07001381 },
1382 [SAA7134_BOARD_ITEMS_MTV005] = {
1383 /* Norman Jonas <normanjonas@arcor.de> */
1384 .name = "Items MuchTV Plus / IT-005",
1385 .audio_clock = 0x00187de7,
1386 .tuner_type = TUNER_PHILIPS_PAL,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07001387 .radio_type = UNSET,
1388 .tuner_addr = ADDR_UNSET,
1389 .radio_addr = ADDR_UNSET,
Linus Torvalds1da177e2005-04-16 15:20:36 -07001390 .inputs = {{
1391 .name = name_tv,
1392 .vmux = 3,
1393 .amux = TV,
1394 .tv = 1,
1395 },{
1396 .name = name_comp1,
1397 .vmux = 1,
1398 .amux = LINE1,
1399 },{
1400 .name = name_svideo,
1401 .vmux = 8,
1402 .amux = LINE1,
1403 }},
1404 .radio = {
1405 .name = name_radio,
1406 .amux = LINE2,
1407 },
1408 },
1409 [SAA7134_BOARD_CINERGY200] = {
1410 .name = "Terratec Cinergy 200 TV",
1411 .audio_clock = 0x00200000,
1412 .tuner_type = TUNER_PHILIPS_PAL,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07001413 .radio_type = UNSET,
1414 .tuner_addr = ADDR_UNSET,
1415 .radio_addr = ADDR_UNSET,
Linus Torvalds1da177e2005-04-16 15:20:36 -07001416 .inputs = {{
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07001417 .name = name_tv,
Linus Torvalds1da177e2005-04-16 15:20:36 -07001418 .vmux = 1,
1419 .amux = LINE2,
1420 .tv = 1,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07001421 },{
1422 .name = name_comp1,
1423 .vmux = 4,
1424 .amux = LINE1,
1425 },{
1426 .name = name_svideo,
1427 .vmux = 8,
1428 .amux = LINE1,
1429 },{
1430 .name = name_comp2, /* CVideo over SVideo Connector */
1431 .vmux = 0,
1432 .amux = LINE1,
Linus Torvalds1da177e2005-04-16 15:20:36 -07001433 }},
1434 .mute = {
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07001435 .name = name_mute,
1436 .amux = LINE2,
Linus Torvalds1da177e2005-04-16 15:20:36 -07001437 },
1438 },
1439 [SAA7134_BOARD_VIDEOMATE_TV_PVR] = {
1440 /* Alain St-Denis <alain@topaze.homeip.net> */
1441 .name = "Compro VideoMate TV PVR/FM",
1442 .audio_clock = 0x00187de7,
1443 .tuner_type = TUNER_PHILIPS_NTSC_M,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07001444 .radio_type = UNSET,
1445 .tuner_addr = ADDR_UNSET,
1446 .radio_addr = ADDR_UNSET,
Linus Torvalds1da177e2005-04-16 15:20:36 -07001447 .gpiomask = 0x808c0080,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07001448 .inputs = {{
1449 .name = name_svideo,
1450 .vmux = 8,
1451 .amux = LINE1,
Linus Torvalds1da177e2005-04-16 15:20:36 -07001452 .gpio = 0x00080,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07001453 },{
1454 .name = name_comp1,
1455 .vmux = 3,
1456 .amux = LINE1,
Linus Torvalds1da177e2005-04-16 15:20:36 -07001457 .gpio = 0x00080,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07001458 },{
1459 .name = name_tv,
1460 .vmux = 1,
1461 .amux = LINE2_LEFT,
1462 .tv = 1,
Linus Torvalds1da177e2005-04-16 15:20:36 -07001463 .gpio = 0x00080,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07001464 }},
Linus Torvalds1da177e2005-04-16 15:20:36 -07001465 .radio = {
1466 .name = name_radio,
1467 .amux = LINE2,
1468 .gpio = 0x80000,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07001469 },
Linus Torvalds1da177e2005-04-16 15:20:36 -07001470 .mute = {
1471 .name = name_mute,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07001472 .amux = LINE2,
Linus Torvalds1da177e2005-04-16 15:20:36 -07001473 .gpio = 0x40000,
1474 },
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07001475 },
1476 [SAA7134_BOARD_SABRENT_SBTTVFM] = {
Linus Torvalds1da177e2005-04-16 15:20:36 -07001477 /* Michael Rodriguez-Torrent <mrtorrent@asu.edu> */
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07001478 .name = "Sabrent SBT-TVFM (saa7130)",
1479 .audio_clock = 0x00187de7,
1480 .tuner_type = TUNER_PHILIPS_NTSC_M,
1481 .radio_type = UNSET,
1482 .tuner_addr = ADDR_UNSET,
1483 .radio_addr = ADDR_UNSET,
1484 .inputs = {{
Linus Torvalds1da177e2005-04-16 15:20:36 -07001485 .name = name_comp1,
1486 .vmux = 1,
Mauro Carvalho Chehab6a989d72005-09-09 13:03:57 -07001487 .amux = LINE1,
Linus Torvalds1da177e2005-04-16 15:20:36 -07001488 },{
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07001489 .name = name_tv,
1490 .vmux = 3,
1491 .amux = LINE2,
1492 .tv = 1,
1493 },{
1494 .name = name_svideo,
1495 .vmux = 8,
Mauro Carvalho Chehab6a989d72005-09-09 13:03:57 -07001496 .amux = LINE1,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07001497 }},
1498 .radio = {
1499 .name = name_radio,
1500 .amux = LINE2,
1501 },
1502 },
Linus Torvalds1da177e2005-04-16 15:20:36 -07001503 [SAA7134_BOARD_ZOLID_XPERT_TV7134] = {
1504 /* Helge Jensen <helge.jensen@slog.dk> */
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07001505 .name = ":Zolid Xpert TV7134",
Linus Torvalds1da177e2005-04-16 15:20:36 -07001506 .audio_clock = 0x00187de7,
1507 .tuner_type = TUNER_PHILIPS_NTSC,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07001508 .radio_type = UNSET,
1509 .tuner_addr = ADDR_UNSET,
1510 .radio_addr = ADDR_UNSET,
1511 .inputs = {{
Linus Torvalds1da177e2005-04-16 15:20:36 -07001512 .name = name_svideo,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07001513 .vmux = 8,
1514 .amux = LINE1,
1515 },{
1516 .name = name_comp1,
1517 .vmux = 3,
1518 .amux = LINE1,
1519 },{
1520 .name = name_tv,
1521 .vmux = 1,
1522 .amux = LINE2,
1523 .tv = 1,
1524 }},
Linus Torvalds1da177e2005-04-16 15:20:36 -07001525 },
1526 [SAA7134_BOARD_EMPIRE_PCI_TV_RADIO_LE] = {
1527 /* "Matteo Az" <matte.az@nospam.libero.it> ;-) */
1528 .name = "Empire PCI TV-Radio LE",
1529 .audio_clock = 0x00187de7,
1530 .tuner_type = TUNER_PHILIPS_PAL,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07001531 .radio_type = UNSET,
1532 .tuner_addr = ADDR_UNSET,
1533 .radio_addr = ADDR_UNSET,
Linus Torvalds1da177e2005-04-16 15:20:36 -07001534 .gpiomask = 0x4000,
1535 .inputs = {{
1536 .name = name_tv_mono,
1537 .vmux = 1,
1538 .amux = LINE2,
1539 .gpio = 0x8000,
1540 .tv = 1,
1541 },{
1542 .name = name_comp1,
1543 .vmux = 3,
1544 .amux = LINE1,
1545 .gpio = 0x8000,
1546 },{
1547 .name = name_svideo,
1548 .vmux = 6,
1549 .amux = LINE1,
1550 .gpio = 0x8000,
1551 }},
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07001552 .radio = {
1553 .name = name_radio,
1554 .amux = LINE1,
1555 .gpio = 0x8000,
1556 },
Linus Torvalds1da177e2005-04-16 15:20:36 -07001557 .mute = {
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07001558 .name = name_mute,
1559 .amux = TV,
1560 .gpio =0x8000,
1561 }
Linus Torvalds1da177e2005-04-16 15:20:36 -07001562 },
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07001563 [SAA7134_BOARD_AVERMEDIA_STUDIO_307] = {
Linus Torvalds1da177e2005-04-16 15:20:36 -07001564 /*
1565 Nickolay V. Shmyrev <nshmyrev@yandex.ru>
1566 Lots of thanks to Andrey Zolotarev <zolotarev_andrey@mail.ru>
1567 */
1568 .name = "Avermedia AVerTV Studio 307",
1569 .audio_clock = 0x00187de7,
1570 .tuner_type = TUNER_PHILIPS_FM1256_IH3,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07001571 .radio_type = UNSET,
1572 .tuner_addr = ADDR_UNSET,
1573 .radio_addr = ADDR_UNSET,
Linus Torvalds1da177e2005-04-16 15:20:36 -07001574 .tda9887_conf = TDA9887_PRESENT,
1575 .gpiomask = 0x03,
1576 .inputs = {{
1577 .name = name_tv,
1578 .vmux = 1,
1579 .amux = TV,
1580 .tv = 1,
1581 .gpio = 0x00,
1582 },{
Stas Sergeevf438d972007-09-17 15:34:09 -03001583 .name = name_comp,
Linus Torvalds1da177e2005-04-16 15:20:36 -07001584 .vmux = 3,
Stas Sergeevf5e4fee2007-09-02 03:56:18 -03001585 .amux = LINE1,
1586 .gpio = 0x02,
Linus Torvalds1da177e2005-04-16 15:20:36 -07001587 },{
1588 .name = name_svideo,
1589 .vmux = 8,
Stas Sergeevf5e4fee2007-09-02 03:56:18 -03001590 .amux = LINE1,
1591 .gpio = 0x02,
Linus Torvalds1da177e2005-04-16 15:20:36 -07001592 }},
1593 .radio = {
1594 .name = name_radio,
1595 .amux = LINE1,
1596 .gpio = 0x01,
1597 },
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07001598 .mute = {
1599 .name = name_mute,
1600 .amux = LINE1,
1601 .gpio = 0x00,
1602 },
1603 },
1604 [SAA7134_BOARD_AVERMEDIA_GO_007_FM] = {
Mauro Carvalho Chehabac19ecc2005-06-23 22:05:09 -07001605 .name = "Avermedia AVerTV GO 007 FM",
1606 .audio_clock = 0x00187de7,
1607 .tuner_type = TUNER_PHILIPS_TDA8290,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07001608 .radio_type = UNSET,
1609 .tuner_addr = ADDR_UNSET,
1610 .radio_addr = ADDR_UNSET,
Mauro Carvalho Chehabac19ecc2005-06-23 22:05:09 -07001611 .gpiomask = 0x00300003,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07001612 /* .gpiomask = 0x8c240003, */
Mauro Carvalho Chehabac19ecc2005-06-23 22:05:09 -07001613 .inputs = {{
1614 .name = name_tv,
1615 .vmux = 1,
1616 .amux = TV,
1617 .tv = 1,
1618 .gpio = 0x01,
1619 },{
1620 .name = name_comp1,
1621 .vmux = 0,
Damian Minkovfbc84082007-03-29 08:47:39 -03001622 .amux = LINE1,
Mauro Carvalho Chehabac19ecc2005-06-23 22:05:09 -07001623 .gpio = 0x02,
1624 },{
1625 .name = name_svideo,
1626 .vmux = 6,
Damian Minkovfbc84082007-03-29 08:47:39 -03001627 .amux = LINE1,
Mauro Carvalho Chehabac19ecc2005-06-23 22:05:09 -07001628 .gpio = 0x02,
1629 }},
1630 .radio = {
1631 .name = name_radio,
1632 .amux = LINE1,
1633 .gpio = 0x00300001,
1634 },
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07001635 .mute = {
1636 .name = name_mute,
1637 .amux = TV,
1638 .gpio = 0x01,
1639 },
1640 },
Linus Torvalds1da177e2005-04-16 15:20:36 -07001641 [SAA7134_BOARD_AVERMEDIA_CARDBUS] = {
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07001642 /* Kees.Blom@cwi.nl */
1643 .name = "AVerMedia Cardbus TV/Radio (E500)",
1644 .audio_clock = 0x187de7,
1645 .tuner_type = TUNER_PHILIPS_TDA8290,
1646 .radio_type = UNSET,
1647 .tuner_addr = ADDR_UNSET,
1648 .radio_addr = ADDR_UNSET,
Linus Torvalds1da177e2005-04-16 15:20:36 -07001649 .inputs = {{
1650 .name = name_tv,
1651 .vmux = 1,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07001652 .amux = TV,
Linus Torvalds1da177e2005-04-16 15:20:36 -07001653 .tv = 1,
1654 },{
1655 .name = name_comp1,
1656 .vmux = 3,
1657 .amux = LINE2,
1658 },{
1659 .name = name_svideo,
1660 .vmux = 8,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07001661 .amux = LINE1,
Linus Torvalds1da177e2005-04-16 15:20:36 -07001662 }},
1663 .radio = {
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07001664 .name = name_radio,
Linus Torvalds1da177e2005-04-16 15:20:36 -07001665 .amux = LINE1,
1666 },
1667 },
1668 [SAA7134_BOARD_CINERGY400_CARDBUS] = {
1669 .name = "Terratec Cinergy 400 mobile",
1670 .audio_clock = 0x187de7,
1671 .tuner_type = TUNER_ALPS_TSBE5_PAL,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07001672 .radio_type = UNSET,
1673 .tuner_addr = ADDR_UNSET,
1674 .radio_addr = ADDR_UNSET,
1675 .tda9887_conf = TDA9887_PRESENT,
Linus Torvalds1da177e2005-04-16 15:20:36 -07001676 .inputs = {{
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07001677 .name = name_tv,
Linus Torvalds1da177e2005-04-16 15:20:36 -07001678 .vmux = 1,
1679 .amux = TV,
1680 .tv = 1,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07001681 },{
Linus Torvalds1da177e2005-04-16 15:20:36 -07001682 .name = name_tv_mono,
1683 .vmux = 1,
1684 .amux = LINE2,
1685 .tv = 1,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07001686 },{
1687 .name = name_comp1,
1688 .vmux = 3,
1689 .amux = LINE1,
1690 },{
1691 .name = name_svideo,
1692 .vmux = 8,
1693 .amux = LINE1,
Linus Torvalds1da177e2005-04-16 15:20:36 -07001694 }},
1695 },
1696 [SAA7134_BOARD_CINERGY600_MK3] = {
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07001697 .name = "Terratec Cinergy 600 TV MK3",
1698 .audio_clock = 0x00200000,
Linus Torvalds1da177e2005-04-16 15:20:36 -07001699 .tuner_type = TUNER_PHILIPS_FM1216ME_MK3,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07001700 .radio_type = UNSET,
1701 .tuner_addr = ADDR_UNSET,
1702 .radio_addr = ADDR_UNSET,
1703 .tda9887_conf = TDA9887_PRESENT,
1704 .inputs = {{
1705 .name = name_tv,
1706 .vmux = 1,
1707 .amux = TV,
1708 .tv = 1,
1709 },{
1710 .name = name_comp1,
1711 .vmux = 4,
1712 .amux = LINE1,
1713 },{
1714 .name = name_svideo,
1715 .vmux = 8,
1716 .amux = LINE1,
1717 },{
1718 .name = name_comp2, /* CVideo over SVideo Connector */
1719 .vmux = 0,
1720 .amux = LINE1,
1721 }},
Linus Torvalds1da177e2005-04-16 15:20:36 -07001722 .radio = {
1723 .name = name_radio,
1724 .amux = LINE2,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07001725 },
1726 },
1727 [SAA7134_BOARD_VIDEOMATE_GOLD_PLUS] = {
1728 /* Dylan Walkden <dylan_walkden@hotmail.com> */
1729 .name = "Compro VideoMate Gold+ Pal",
1730 .audio_clock = 0x00187de7,
1731 .tuner_type = TUNER_PHILIPS_PAL,
1732 .radio_type = UNSET,
1733 .tuner_addr = ADDR_UNSET,
1734 .radio_addr = ADDR_UNSET,
1735 .gpiomask = 0x1ce780,
1736 .inputs = {{
1737 .name = name_svideo,
1738 .vmux = 0, /* CVideo over SVideo Connector - ok? */
1739 .amux = LINE1,
1740 .gpio = 0x008080,
1741 },{
1742 .name = name_comp1,
1743 .vmux = 3,
1744 .amux = LINE1,
1745 .gpio = 0x008080,
1746 },{
1747 .name = name_tv,
1748 .vmux = 1,
1749 .amux = TV,
1750 .tv = 1,
1751 .gpio = 0x008080,
1752 }},
1753 .radio = {
1754 .name = name_radio,
1755 .amux = LINE2,
1756 .gpio = 0x80000,
1757 },
1758 .mute = {
1759 .name = name_mute,
1760 .amux = LINE2,
1761 .gpio = 0x0c8000,
1762 },
1763 },
Linus Torvalds1da177e2005-04-16 15:20:36 -07001764 [SAA7134_BOARD_PINNACLE_300I_DVBT_PAL] = {
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07001765 .name = "Pinnacle PCTV 300i DVB-T + PAL",
1766 .audio_clock = 0x00187de7,
1767 .tuner_type = TUNER_MT2032,
1768 .radio_type = UNSET,
1769 .tuner_addr = ADDR_UNSET,
1770 .radio_addr = ADDR_UNSET,
Hartmut Hackmanndf8cf702006-03-03 12:09:26 -03001771 .tda9887_conf = TDA9887_PRESENT | TDA9887_INTERCARRIER | TDA9887_PORT2_INACTIVE,
Linus Torvalds1da177e2005-04-16 15:20:36 -07001772 .mpeg = SAA7134_MPEG_DVB,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07001773 .inputs = {{
1774 .name = name_tv,
1775 .vmux = 3,
1776 .amux = TV,
1777 .tv = 1,
1778 },{
1779 .name = name_comp1,
1780 .vmux = 0,
1781 .amux = LINE2,
1782 },{
1783 .name = name_comp2,
1784 .vmux = 1,
1785 .amux = LINE2,
1786 },{
1787 .name = name_svideo,
1788 .vmux = 8,
1789 .amux = LINE2,
1790 }},
1791 },
Linus Torvalds1da177e2005-04-16 15:20:36 -07001792 [SAA7134_BOARD_PROVIDEO_PV952] = {
1793 /* andreas.kretschmer@web.de */
1794 .name = "ProVideo PV952",
1795 .audio_clock = 0x00187de7,
1796 .tuner_type = TUNER_PHILIPS_FM1216ME_MK3,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07001797 .radio_type = UNSET,
1798 .tuner_addr = ADDR_UNSET,
1799 .radio_addr = ADDR_UNSET,
Linus Torvalds1da177e2005-04-16 15:20:36 -07001800 .tda9887_conf = TDA9887_PRESENT,
1801 .inputs = {{
1802 .name = name_comp1,
1803 .vmux = 0,
1804 .amux = LINE1,
1805 },{
1806 .name = name_tv,
1807 .vmux = 1,
1808 .amux = TV,
1809 .tv = 1,
1810 },{
1811 .name = name_tv_mono,
1812 .vmux = 1,
1813 .amux = LINE2,
1814 .tv = 1,
1815 }},
1816 .radio = {
1817 .name = name_radio,
1818 .amux = LINE2,
1819 },
1820 },
1821 [SAA7134_BOARD_AVERMEDIA_305] = {
1822 /* much like the "studio" version but without radio
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07001823 * and another tuner (sirspiritus@yandex.ru) */
Linus Torvalds1da177e2005-04-16 15:20:36 -07001824 .name = "AverMedia AverTV/305",
1825 .audio_clock = 0x00187de7,
1826 .tuner_type = TUNER_PHILIPS_FQ1216ME,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07001827 .radio_type = UNSET,
1828 .tuner_addr = ADDR_UNSET,
1829 .radio_addr = ADDR_UNSET,
Linus Torvalds1da177e2005-04-16 15:20:36 -07001830 .tda9887_conf = TDA9887_PRESENT,
Linus Torvalds1da177e2005-04-16 15:20:36 -07001831 .inputs = {{
1832 .name = name_tv,
1833 .vmux = 1,
1834 .amux = LINE2,
1835 .tv = 1,
1836 },{
1837 .name = name_comp1,
1838 .vmux = 0,
1839 .amux = LINE2,
1840 },{
1841 .name = name_comp2,
1842 .vmux = 3,
1843 .amux = LINE2,
1844 },{
1845 .name = name_svideo,
1846 .vmux = 8,
1847 .amux = LINE2,
1848 }},
1849 .mute = {
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07001850 .name = name_mute,
1851 .amux = LINE1,
Linus Torvalds1da177e2005-04-16 15:20:36 -07001852 },
1853 },
1854 [SAA7134_BOARD_FLYDVBTDUO] = {
1855 /* LifeView FlyDVB-T DUO */
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07001856 /* "Nico Sabbi <nsabbi@tiscali.it> Hartmut Hackmann hartmut.hackmann@t-online.de*/
Peter Misseldb483672007-04-27 12:31:20 -03001857 .name = "LifeView FlyDVB-T DUO / MSI TV@nywhere Duo",
Linus Torvalds1da177e2005-04-16 15:20:36 -07001858 .audio_clock = 0x00200000,
1859 .tuner_type = TUNER_PHILIPS_TDA8290,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07001860 .radio_type = UNSET,
1861 .tuner_addr = ADDR_UNSET,
1862 .radio_addr = ADDR_UNSET,
Peter Missel7c7fea62007-04-27 12:31:14 -03001863 .gpiomask = 0x00200000,
Michael Krufky8ce47da2007-04-27 12:31:14 -03001864 .mpeg = SAA7134_MPEG_DVB,
Linus Torvalds1da177e2005-04-16 15:20:36 -07001865 .inputs = {{
1866 .name = name_tv,
1867 .vmux = 1,
1868 .amux = TV,
Peter Missel7c7fea62007-04-27 12:31:14 -03001869 .gpio = 0x200000, /* GPIO21=High for TV input */
Linus Torvalds1da177e2005-04-16 15:20:36 -07001870 .tv = 1,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07001871 },{
Linus Torvalds1da177e2005-04-16 15:20:36 -07001872 .name = name_comp1, /* Composite signal on S-Video input */
1873 .vmux = 0,
1874 .amux = LINE2,
Linus Torvalds1da177e2005-04-16 15:20:36 -07001875 },{
1876 .name = name_comp2, /* Composite input */
1877 .vmux = 3,
1878 .amux = LINE2,
Linus Torvalds1da177e2005-04-16 15:20:36 -07001879 },{
1880 .name = name_svideo, /* S-Video signal on S-Video input */
1881 .vmux = 8,
1882 .amux = LINE2,
Linus Torvalds1da177e2005-04-16 15:20:36 -07001883 }},
Peter Missel7c7fea62007-04-27 12:31:14 -03001884 .radio = {
1885 .name = name_radio,
1886 .amux = TV,
1887 .gpio = 0x000000, /* GPIO21=Low for FM radio antenna */
1888 },
Linus Torvalds1da177e2005-04-16 15:20:36 -07001889 },
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07001890 [SAA7134_BOARD_PHILIPS_TOUGH] = {
1891 .name = "Philips TOUGH DVB-T reference design",
1892 .tuner_type = TUNER_ABSENT,
Mauro Carvalho Chehabac19ecc2005-06-23 22:05:09 -07001893 .audio_clock = 0x00187de7,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07001894 .radio_type = UNSET,
1895 .tuner_addr = ADDR_UNSET,
1896 .radio_addr = ADDR_UNSET,
1897 .mpeg = SAA7134_MPEG_DVB,
1898 .inputs = {{
1899 .name = name_comp1,
1900 .vmux = 0,
1901 .amux = LINE1,
1902 },{
1903 .name = name_svideo,
1904 .vmux = 8,
1905 .amux = LINE1,
1906 }},
Mauro Carvalho Chehabac19ecc2005-06-23 22:05:09 -07001907 },
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07001908 [SAA7134_BOARD_AVERMEDIA_307] = {
1909 /*
1910 Davydov Vladimir <vladimir@iqmedia.com>
1911 */
1912 .name = "Avermedia AVerTV 307",
1913 .audio_clock = 0x00187de7,
1914 .tuner_type = TUNER_PHILIPS_FQ1216ME,
1915 .radio_type = UNSET,
1916 .tuner_addr = ADDR_UNSET,
1917 .radio_addr = ADDR_UNSET,
1918 .tda9887_conf = TDA9887_PRESENT,
1919 .inputs = {{
1920 .name = name_tv,
1921 .vmux = 1,
1922 .amux = TV,
1923 .tv = 1,
1924 },{
1925 .name = name_comp1,
1926 .vmux = 0,
1927 .amux = LINE1,
1928 },{
1929 .name = name_comp2,
1930 .vmux = 3,
1931 .amux = LINE1,
1932 },{
1933 .name = name_svideo,
1934 .vmux = 8,
1935 .amux = LINE1,
1936 }},
1937 },
1938 [SAA7134_BOARD_ADS_INSTANT_TV] = {
1939 .name = "ADS Tech Instant TV (saa7135)",
1940 .audio_clock = 0x00187de7,
1941 .tuner_type = TUNER_PHILIPS_TDA8290,
1942 .radio_type = UNSET,
1943 .tuner_addr = ADDR_UNSET,
1944 .radio_addr = ADDR_UNSET,
1945 .inputs = {{
1946 .name = name_tv,
1947 .vmux = 1,
1948 .amux = TV,
1949 .tv = 1,
1950 },{
1951 .name = name_comp1,
1952 .vmux = 3,
1953 .amux = LINE2,
1954 },{
1955 .name = name_svideo,
1956 .vmux = 8,
1957 .amux = LINE2,
1958 }},
1959 },
1960 [SAA7134_BOARD_KWORLD_VSTREAM_XPERT] = {
1961 .name = "Kworld/Tevion V-Stream Xpert TV PVR7134",
1962 .audio_clock = 0x00187de7,
1963 .tuner_type = TUNER_PHILIPS_PAL_I,
1964 .radio_type = UNSET,
1965 .tuner_addr = ADDR_UNSET,
1966 .radio_addr = ADDR_UNSET,
1967 .gpiomask = 0x0700,
1968 .inputs = {{
1969 .name = name_tv,
1970 .vmux = 1,
1971 .amux = TV,
1972 .tv = 1,
1973 .gpio = 0x000,
1974 },{
1975 .name = name_comp1,
1976 .vmux = 3,
1977 .amux = LINE1,
1978 .gpio = 0x200, /* gpio by DScaler */
1979 },{
1980 .name = name_svideo,
1981 .vmux = 0,
1982 .amux = LINE1,
1983 .gpio = 0x200,
1984 }},
1985 .radio = {
1986 .name = name_radio,
1987 .amux = LINE1,
1988 .gpio = 0x100,
1989 },
1990 .mute = {
1991 .name = name_mute,
1992 .amux = TV,
1993 .gpio = 0x000,
1994 },
1995 },
Peter Missel10b7a902006-01-23 17:11:06 -02001996 [SAA7134_BOARD_FLYDVBT_DUO_CARDBUS] = {
Hartmut Hackmann2c591942006-08-07 14:03:32 -03001997 .name = "LifeView/Typhoon/Genius FlyDVB-T Duo Cardbus",
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07001998 .audio_clock = 0x00200000,
1999 .tuner_type = TUNER_PHILIPS_TDA8290,
2000 .radio_type = UNSET,
2001 .tuner_addr = ADDR_UNSET,
2002 .radio_addr = ADDR_UNSET,
2003 .mpeg = SAA7134_MPEG_DVB,
Peter Missel10b7a902006-01-23 17:11:06 -02002004 .gpiomask = 0x00200000,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07002005 .inputs = {{
2006 .name = name_tv,
2007 .vmux = 1,
2008 .amux = TV,
Peter Missel10b7a902006-01-23 17:11:06 -02002009 .gpio = 0x200000, /* GPIO21=High for TV input */
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07002010 .tv = 1,
2011 },{
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07002012 .name = name_svideo, /* S-Video signal on S-Video input */
2013 .vmux = 8,
2014 .amux = LINE2,
Peter Missel10b7a902006-01-23 17:11:06 -02002015 },{
2016 .name = name_comp1, /* Composite signal on S-Video input */
2017 .vmux = 0,
2018 .amux = LINE2,
2019 },{
2020 .name = name_comp2, /* Composite input */
2021 .vmux = 3,
2022 .amux = LINE2,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07002023 }},
2024 .radio = {
2025 .name = name_radio,
Peter Missel10b7a902006-01-23 17:11:06 -02002026 .amux = TV,
2027 .gpio = 0x000000, /* GPIO21=Low for FM radio antenna */
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07002028 },
2029 },
2030 [SAA7134_BOARD_VIDEOMATE_TV_GOLD_PLUSII] = {
2031 .name = "Compro VideoMate TV Gold+II",
2032 .audio_clock = 0x002187de7,
2033 .tuner_type = TUNER_LG_PAL_NEW_TAPC,
2034 .radio_type = TUNER_TEA5767,
2035 .tuner_addr = 0x63,
2036 .radio_addr = 0x60,
2037 .gpiomask = 0x8c1880,
2038 .inputs = {{
2039 .name = name_svideo,
2040 .vmux = 0,
2041 .amux = LINE1,
2042 .gpio = 0x800800,
2043 },{
2044 .name = name_comp1,
2045 .vmux = 3,
2046 .amux = LINE1,
2047 .gpio = 0x801000,
2048 },{
2049 .name = name_tv,
2050 .vmux = 1,
2051 .amux = TV,
2052 .tv = 1,
2053 .gpio = 0x800000,
2054 }},
2055 .radio = {
2056 .name = name_radio,
2057 .amux = TV,
2058 .gpio = 0x880000,
2059 },
2060 .mute = {
2061 .name = name_mute,
2062 .amux = LINE2,
2063 .gpio = 0x840000,
2064 },
2065 },
2066 [SAA7134_BOARD_KWORLD_XPERT] = {
2067 /*
2068 FIXME:
2069 - Remote control doesn't initialize properly.
2070 - Audio volume starts muted,
2071 then gradually increases after channel change.
2072 - Overlay scaling problems (application error?)
2073 - Composite S-Video untested.
2074 From: Konrad Rzepecki <hannibal@megapolis.pl>
2075 */
2076 .name = "Kworld Xpert TV PVR7134",
2077 .audio_clock = 0x00187de7,
2078 .tuner_type = TUNER_TENA_9533_DI,
2079 .radio_type = TUNER_TEA5767,
2080 .tuner_addr = 0x61,
2081 .radio_addr = 0x60,
2082 .gpiomask = 0x0700,
2083 .inputs = {{
2084 .name = name_tv,
2085 .vmux = 1,
2086 .amux = TV,
2087 .tv = 1,
2088 .gpio = 0x000,
2089 },{
2090 .name = name_comp1,
2091 .vmux = 3,
2092 .amux = LINE1,
2093 .gpio = 0x200, /* gpio by DScaler */
2094 },{
2095 .name = name_svideo,
2096 .vmux = 0,
2097 .amux = LINE1,
2098 .gpio = 0x200,
2099 }},
2100 .radio = {
2101 .name = name_radio,
2102 .amux = LINE1,
2103 .gpio = 0x100,
2104 },
2105 .mute = {
2106 .name = name_mute,
2107 .amux = TV,
2108 .gpio = 0x000,
2109 },
2110 },
Mauro Carvalho Chehab2f180712005-09-09 13:03:46 -07002111 [SAA7134_BOARD_FLYTV_DIGIMATRIX] = {
2112 .name = "FlyTV mini Asus Digimatrix",
2113 .audio_clock = 0x00200000,
Michael Krufkyf3629be2006-03-11 17:02:01 -03002114 .tuner_type = TUNER_LG_TALN,
Mauro Carvalho Chehab2f180712005-09-09 13:03:46 -07002115 .radio_type = UNSET,
2116 .tuner_addr = ADDR_UNSET,
2117 .radio_addr = ADDR_UNSET,
2118 .inputs = {{
2119 .name = name_tv,
2120 .vmux = 1,
2121 .amux = TV,
2122 .tv = 1,
2123 },{
2124 .name = name_tv_mono,
2125 .vmux = 1,
2126 .amux = LINE2,
2127 .tv = 1,
2128 },{
2129 .name = name_comp1,
2130 .vmux = 0,
2131 .amux = LINE2,
2132 },{
2133 .name = name_comp2,
2134 .vmux = 3,
2135 .amux = LINE2,
2136 },{
2137 .name = name_svideo,
2138 .vmux = 8,
2139 .amux = LINE2,
2140 }},
2141 .radio = {
2142 .name = name_radio, /* radio unconfirmed */
2143 .amux = LINE2,
2144 },
2145 },
Mauro Carvalho Chehab260784d2005-09-09 13:03:49 -07002146 [SAA7134_BOARD_KWORLD_TERMINATOR] = {
2147 /* Kworld V-Stream Studio TV Terminator */
2148 /* "James Webb <jrwebb@qwest.net> */
2149 .name = "V-Stream Studio TV Terminator",
2150 .audio_clock = 0x00187de7,
2151 .tuner_type = TUNER_PHILIPS_TDA8290,
2152 .radio_type = UNSET,
2153 .tuner_addr = ADDR_UNSET,
2154 .radio_addr = ADDR_UNSET,
2155 .gpiomask = 1 << 21,
2156 .inputs = {{
2157 .name = name_tv,
2158 .vmux = 1,
2159 .amux = TV,
2160 .gpio = 0x0000000,
2161 .tv = 1,
2162 },{
2163 .name = name_comp1, /* Composite input */
2164 .vmux = 3,
2165 .amux = LINE2,
2166 .gpio = 0x0000000,
2167 },{
2168 .name = name_svideo, /* S-Video input */
2169 .vmux = 8,
2170 .amux = LINE2,
2171 .gpio = 0x0000000,
2172 }},
2173 .radio = {
2174 .name = name_radio,
2175 .amux = TV,
2176 .gpio = 0x0200000,
2177 },
2178 },
Mauro Carvalho Chehab4279f022005-09-09 13:03:51 -07002179 [SAA7134_BOARD_YUAN_TUN900] = {
2180 /* FIXME:
2181 * S-Video and composite sources untested.
2182 * Radio not working.
2183 * Remote control not yet implemented.
2184 * From : codemaster@webgeeks.be */
2185 .name = "Yuan TUN-900 (saa7135)",
2186 .audio_clock = 0x00187de7,
2187 .tuner_type = TUNER_PHILIPS_TDA8290,
2188 .radio_type = UNSET,
2189 .tuner_addr= ADDR_UNSET,
2190 .radio_addr= ADDR_UNSET,
2191 .gpiomask = 0x00010003,
2192 .inputs = {{
2193 .name = name_tv,
2194 .vmux = 1,
2195 .amux = TV,
2196 .tv = 1,
2197 .gpio = 0x01,
2198 },{
2199 .name = name_comp1,
2200 .vmux = 0,
2201 .amux = LINE2,
2202 .gpio = 0x02,
2203 },{
2204 .name = name_svideo,
2205 .vmux = 6,
2206 .amux = LINE2,
2207 .gpio = 0x02,
2208 }},
2209 .radio = {
2210 .name = name_radio,
2211 .amux = LINE1,
2212 .gpio = 0x00010003,
2213 },
2214 .mute = {
2215 .name = name_mute,
2216 .amux = TV,
2217 .gpio = 0x01,
2218 },
2219 },
Nickolay V. Shmyreva8ff4172005-11-08 21:36:16 -08002220 [SAA7134_BOARD_BEHOLD_409FM] = {
Mauro Carvalho Chehab4ac97912005-11-08 21:37:43 -08002221 /* <http://tuner.beholder.ru>, Sergey <skiv@orel.ru> */
Dmitry Belimovb34dddb2008-04-23 14:09:08 -03002222 /* Beholder Intl. Ltd. 2008 */
2223 /*Dmitry Belimov <d.belimov@gmail.com> */
Mauro Carvalho Chehab4ac97912005-11-08 21:37:43 -08002224 .name = "Beholder BeholdTV 409 FM",
2225 .audio_clock = 0x00187de7,
2226 .tuner_type = TUNER_PHILIPS_FM1216ME_MK3,
2227 .radio_type = UNSET,
2228 .tuner_addr = ADDR_UNSET,
2229 .radio_addr = ADDR_UNSET,
2230 .tda9887_conf = TDA9887_PRESENT,
Dmitry Belimovb34dddb2008-04-23 14:09:08 -03002231 .gpiomask = 0x00008000,
Mauro Carvalho Chehab4ac97912005-11-08 21:37:43 -08002232 .inputs = {{
2233 .name = name_tv,
Nickolay V. Shmyreva8ff4172005-11-08 21:36:16 -08002234 .vmux = 3,
2235 .amux = TV,
2236 .tv = 1,
2237 },{
2238 .name = name_comp1,
2239 .vmux = 1,
2240 .amux = LINE1,
Mauro Carvalho Chehab4ac97912005-11-08 21:37:43 -08002241 },{
2242 .name = name_svideo,
Nickolay V. Shmyreva8ff4172005-11-08 21:36:16 -08002243 .vmux = 8,
2244 .amux = LINE1,
Mauro Carvalho Chehab4ac97912005-11-08 21:37:43 -08002245 }},
2246 .radio = {
2247 .name = name_radio,
Nickolay V. Shmyreva8ff4172005-11-08 21:36:16 -08002248 .amux = LINE2,
Trent Piepho657de3c2006-06-20 00:30:57 -03002249 },
Mauro Carvalho Chehab4ac97912005-11-08 21:37:43 -08002250 },
2251 [SAA7134_BOARD_GOTVIEW_7135] = {
Nickolay V. Shmyrevdcd555e2005-11-08 21:36:23 -08002252 /* Mike Baikov <mike@baikov.com> */
Nickolay V. Shmyrev6b961442005-11-08 21:36:22 -08002253 /* Andrey Cvetcov <ays14@yandex.ru> */
Mauro Carvalho Chehab4ac97912005-11-08 21:37:43 -08002254 .name = "GoTView 7135 PCI",
2255 .audio_clock = 0x00187de7,
2256 .tuner_type = TUNER_PHILIPS_FM1216ME_MK3,
2257 .radio_type = UNSET,
2258 .tuner_addr = ADDR_UNSET,
2259 .radio_addr = ADDR_UNSET,
2260 .tda9887_conf = TDA9887_PRESENT,
2261 .gpiomask = 0x00200003,
2262 .inputs = {{
2263 .name = name_tv,
2264 .vmux = 1,
2265 .amux = TV,
2266 .tv = 1,
2267 .gpio = 0x00200003,
2268 },{
2269 .name = name_tv_mono,
2270 .vmux = 1,
2271 .amux = LINE2,
2272 .gpio = 0x00200003,
2273 },{
2274 .name = name_comp1,
2275 .vmux = 3,
2276 .amux = LINE1,
2277 .gpio = 0x00200003,
2278 },{
2279 .name = name_svideo,
2280 .vmux = 8,
2281 .amux = LINE1,
2282 .gpio = 0x00200003,
2283 }},
2284 .radio = {
2285 .name = name_radio,
2286 .amux = LINE2,
2287 .gpio = 0x00200003,
2288 },
2289 .mute = {
2290 .name = name_mute,
2291 .amux = TV,
2292 .gpio = 0x00200003,
2293 },
2294 },
Hartmut Hackmann2cf36ac2005-11-08 21:36:32 -08002295 [SAA7134_BOARD_PHILIPS_EUROPA] = {
2296 .name = "Philips EUROPA V3 reference design",
2297 .audio_clock = 0x00187de7,
2298 .tuner_type = TUNER_PHILIPS_TD1316,
2299 .radio_type = UNSET,
2300 .tuner_addr = 0x61,
2301 .radio_addr = ADDR_UNSET,
Hartmut Hackmann44fd06f2006-02-27 00:09:11 -03002302 .tda9887_conf = TDA9887_PRESENT | TDA9887_PORT1_ACTIVE,
Hartmut Hackmann2cf36ac2005-11-08 21:36:32 -08002303 .mpeg = SAA7134_MPEG_DVB,
2304 .inputs = {{
2305 .name = name_tv,
2306 .vmux = 3,
2307 .amux = TV,
2308 .tv = 1,
2309 },{
2310 .name = name_comp1,
2311 .vmux = 0,
2312 .amux = LINE2,
2313 },{
2314 .name = name_svideo,
2315 .vmux = 8,
2316 .amux = LINE2,
2317 }},
2318 },
2319 [SAA7134_BOARD_VIDEOMATE_DVBT_300] = {
2320 .name = "Compro Videomate DVB-T300",
2321 .audio_clock = 0x00187de7,
2322 .tuner_type = TUNER_PHILIPS_TD1316,
2323 .radio_type = UNSET,
2324 .tuner_addr = 0x61,
2325 .radio_addr = ADDR_UNSET,
Hartmut Hackmann44fd06f2006-02-27 00:09:11 -03002326 .tda9887_conf = TDA9887_PRESENT | TDA9887_PORT1_ACTIVE,
Hartmut Hackmann2cf36ac2005-11-08 21:36:32 -08002327 .mpeg = SAA7134_MPEG_DVB,
2328 .inputs = {{
2329 .name = name_tv,
2330 .vmux = 3,
2331 .amux = TV,
2332 .tv = 1,
2333 },{
2334 .name = name_comp1,
2335 .vmux = 1,
2336 .amux = LINE2,
2337 },{
2338 .name = name_svideo,
2339 .vmux = 8,
2340 .amux = LINE2,
2341 }},
2342 },
2343 [SAA7134_BOARD_VIDEOMATE_DVBT_200] = {
2344 .name = "Compro Videomate DVB-T200",
2345 .tuner_type = TUNER_ABSENT,
2346 .audio_clock = 0x00187de7,
2347 .radio_type = UNSET,
2348 .tuner_addr = ADDR_UNSET,
2349 .radio_addr = ADDR_UNSET,
2350 .mpeg = SAA7134_MPEG_DVB,
2351 .inputs = {{
2352 .name = name_comp1,
2353 .vmux = 0,
2354 .amux = LINE1,
2355 },{
2356 .name = name_svideo,
2357 .vmux = 8,
2358 .amux = LINE1,
2359 }},
2360 },
Mauro Carvalho Chehab4ac97912005-11-08 21:37:43 -08002361 [SAA7134_BOARD_RTD_VFG7350] = {
2362 .name = "RTD Embedded Technologies VFG7350",
2363 .audio_clock = 0x00200000,
2364 .tuner_type = TUNER_ABSENT,
2365 .radio_type = UNSET,
2366 .tuner_addr = ADDR_UNSET,
2367 .radio_addr = ADDR_UNSET,
2368 .inputs = {{
2369 .name = "Composite 0",
2370 .vmux = 0,
2371 .amux = LINE1,
2372 },{
2373 .name = "Composite 1",
2374 .vmux = 1,
2375 .amux = LINE2,
2376 },{
2377 .name = "Composite 2",
2378 .vmux = 2,
2379 .amux = LINE1,
2380 },{
2381 .name = "Composite 3",
2382 .vmux = 3,
2383 .amux = LINE2,
2384 },{
2385 .name = "S-Video 0",
2386 .vmux = 8,
2387 .amux = LINE1,
2388 },{
2389 .name = "S-Video 1",
2390 .vmux = 9,
2391 .amux = LINE2,
2392 }},
2393 .mpeg = SAA7134_MPEG_EMPRESS,
2394 .video_out = CCIR656,
Robert W. Boone2f8d4f52005-11-08 21:37:10 -08002395 .vid_port_opts = ( SET_T_CODE_POLARITY_NON_INVERTED |
2396 SET_CLOCK_NOT_DELAYED |
2397 SET_CLOCK_INVERTED |
2398 SET_VSYNC_OFF ),
Mauro Carvalho Chehab4ac97912005-11-08 21:37:43 -08002399 },
2400 [SAA7134_BOARD_RTD_VFG7330] = {
2401 .name = "RTD Embedded Technologies VFG7330",
2402 .audio_clock = 0x00200000,
2403 .tuner_type = TUNER_ABSENT,
2404 .radio_type = UNSET,
2405 .tuner_addr = ADDR_UNSET,
2406 .radio_addr = ADDR_UNSET,
2407 .inputs = {{
2408 .name = "Composite 0",
2409 .vmux = 0,
2410 .amux = LINE1,
2411 },{
2412 .name = "Composite 1",
2413 .vmux = 1,
2414 .amux = LINE2,
2415 },{
2416 .name = "Composite 2",
2417 .vmux = 2,
2418 .amux = LINE1,
2419 },{
2420 .name = "Composite 3",
2421 .vmux = 3,
2422 .amux = LINE2,
2423 },{
2424 .name = "S-Video 0",
2425 .vmux = 8,
2426 .amux = LINE1,
2427 },{
2428 .name = "S-Video 1",
2429 .vmux = 9,
2430 .amux = LINE2,
2431 }},
2432 },
Mauro Carvalho Chehab058afaf2005-11-08 21:36:49 -08002433 [SAA7134_BOARD_FLYTVPLATINUM_MINI2] = {
2434 .name = "LifeView FlyTV Platinum Mini2",
2435 .audio_clock = 0x00200000,
2436 .tuner_type = TUNER_PHILIPS_TDA8290,
2437 .radio_type = UNSET,
2438 .tuner_addr = ADDR_UNSET,
2439 .radio_addr = ADDR_UNSET,
2440
2441 .inputs = {{
2442 .name = name_tv,
2443 .vmux = 1,
2444 .amux = TV,
2445 .tv = 1,
2446 },{
2447 .name = name_comp1, /* Composite signal on S-Video input */
2448 .vmux = 0,
2449 .amux = LINE2,
2450 },{
2451 .name = name_comp2, /* Composite input */
2452 .vmux = 3,
2453 .amux = LINE2,
2454 },{
2455 .name = name_svideo,
2456 .vmux = 8,
2457 .amux = LINE2,
2458 }},
2459 },
Michael Krufky76bc3a32005-11-08 21:37:27 -08002460 [SAA7134_BOARD_AVERMEDIA_AVERTVHD_A180] = {
Michael Krufkyac113d12005-11-08 21:38:21 -08002461 /* Michael Krufky <mkrufky@m1k.net>
2462 * Uses Alps Electric TDHU2, containing NXT2004 ATSC Decoder
2463 * AFAIK, there is no analog demod, thus,
2464 * no support for analog television.
2465 */
Michael Krufky76bc3a32005-11-08 21:37:27 -08002466 .name = "AVerMedia AVerTVHD MCE A180",
2467 .audio_clock = 0x00187de7,
2468 .tuner_type = TUNER_ABSENT,
2469 .radio_type = UNSET,
2470 .tuner_addr = ADDR_UNSET,
2471 .radio_addr = ADDR_UNSET,
Michael Krufky3b64e8e2005-11-08 21:38:20 -08002472 .mpeg = SAA7134_MPEG_DVB,
Michael Krufky76bc3a32005-11-08 21:37:27 -08002473 .inputs = {{
2474 .name = name_comp1,
2475 .vmux = 3,
2476 .amux = LINE2,
2477 },{
2478 .name = name_svideo,
2479 .vmux = 8,
2480 .amux = LINE2,
2481 }},
2482 },
Pieter Palmerscf1c5d12005-11-08 21:37:40 -08002483 [SAA7134_BOARD_MONSTERTV_MOBILE] = {
2484 .name = "SKNet MonsterTV Mobile",
2485 .audio_clock = 0x00187de7,
2486 .tuner_type = TUNER_PHILIPS_TDA8290,
2487 .radio_type = UNSET,
2488 .tuner_addr = ADDR_UNSET,
2489 .radio_addr = ADDR_UNSET,
2490
2491 .inputs = {{
2492 .name = name_tv,
2493 .vmux = 1,
2494 .amux = TV,
2495 .tv = 1,
2496 },{
2497 .name = name_comp1,
2498 .vmux = 3,
2499 .amux = LINE1,
2500 },{
2501 .name = name_svideo,
2502 .vmux = 6,
2503 .amux = LINE1,
2504 }},
2505 },
Ricardo Cerqueirac2f6f9d2005-11-08 21:37:51 -08002506 [SAA7134_BOARD_PINNACLE_PCTV_110i] = {
Karsten Suehringcb46e3c2006-02-27 00:08:08 -03002507 .name = "Pinnacle PCTV 40i/50i/110i (saa7133)",
Ricardo Cerqueirac2f6f9d2005-11-08 21:37:51 -08002508 .audio_clock = 0x00187de7,
2509 .tuner_type = TUNER_PHILIPS_TDA8290,
2510 .radio_type = UNSET,
2511 .tuner_addr = ADDR_UNSET,
2512 .radio_addr = ADDR_UNSET,
2513 .gpiomask = 0x080200000,
Yuri Funduryaneec25fa2008-02-17 01:22:37 -03002514 .inputs = { {
2515 .name = name_tv,
2516 .vmux = 4,
2517 .amux = TV,
2518 .tv = 1,
2519 }, {
2520 .name = name_comp1,
2521 .vmux = 1,
2522 .amux = LINE2,
2523 }, {
2524 .name = name_comp2,
2525 .vmux = 0,
2526 .amux = LINE2,
2527 }, {
2528 .name = name_svideo,
2529 .vmux = 8,
2530 .amux = LINE2,
2531 } },
Ricardo Cerqueirac2f6f9d2005-11-08 21:37:51 -08002532 .radio = {
Yuri Funduryaneec25fa2008-02-17 01:22:37 -03002533 .name = name_radio,
2534 .amux = TV,
2535 .gpio = 0x0200000,
Ricardo Cerqueirac2f6f9d2005-11-08 21:37:51 -08002536 },
2537 },
Hermann Pitton28f02242005-11-08 21:38:03 -08002538 [SAA7134_BOARD_ASUSTeK_P7131_DUAL] = {
2539 .name = "ASUSTeK P7131 Dual",
2540 .audio_clock = 0x00187de7,
2541 .tuner_type = TUNER_PHILIPS_TDA8290,
2542 .radio_type = UNSET,
2543 .tuner_addr = ADDR_UNSET,
2544 .radio_addr = ADDR_UNSET,
2545 .gpiomask = 1 << 21,
Hartmut Hackmannd4b0aba2005-11-08 21:38:44 -08002546 .mpeg = SAA7134_MPEG_DVB,
Hermann Pitton28f02242005-11-08 21:38:03 -08002547 .inputs = {{
2548 .name = name_tv,
2549 .vmux = 1,
2550 .amux = TV,
2551 .tv = 1,
Hartmut Hackmann83646812006-10-12 20:38:51 -03002552 .gpio = 0x0000000,
Hermann Pitton28f02242005-11-08 21:38:03 -08002553 },{
2554 .name = name_comp1,
2555 .vmux = 3,
2556 .amux = LINE2,
Hartmut Hackmann83646812006-10-12 20:38:51 -03002557 .gpio = 0x0200000,
Hermann Pitton28f02242005-11-08 21:38:03 -08002558 },{
Hermann Pitton8387c662006-12-10 21:08:03 -03002559 .name = name_comp2,
2560 .vmux = 0,
2561 .amux = LINE2,
2562 .gpio = 0x0200000,
2563 },{
Hermann Pitton28f02242005-11-08 21:38:03 -08002564 .name = name_svideo,
2565 .vmux = 8,
2566 .amux = LINE2,
Hartmut Hackmann83646812006-10-12 20:38:51 -03002567 .gpio = 0x0200000,
Hermann Pitton28f02242005-11-08 21:38:03 -08002568 }},
2569 .radio = {
2570 .name = name_radio,
2571 .amux = TV,
2572 .gpio = 0x0200000,
2573 },
2574 },
Ricardo Cerqueira17ce1ff2005-11-08 21:38:47 -08002575 [SAA7134_BOARD_SEDNA_PC_TV_CARDBUS] = {
Paul T Zalacfe2e36c2005-11-08 21:38:04 -08002576 /* Paul Tom Zalac <pzalac@gmail.com> */
Pavel Mihaylovc3d93192005-11-08 21:38:43 -08002577 /* Pavel Mihaylov <bin@bash.info> */
Ricardo Cerqueira17ce1ff2005-11-08 21:38:47 -08002578 .name = "Sedna/MuchTV PC TV Cardbus TV/Radio (ITO25 Rev:2B)",
2579 /* Sedna/MuchTV (OEM) Cardbus TV Tuner */
Paul T Zalacfe2e36c2005-11-08 21:38:04 -08002580 .audio_clock = 0x00187de7,
Pavel Mihaylovc3d93192005-11-08 21:38:43 -08002581 .tuner_type = TUNER_PHILIPS_TDA8290,
Paul T Zalacfe2e36c2005-11-08 21:38:04 -08002582 .radio_type = UNSET,
2583 .tuner_addr = ADDR_UNSET,
2584 .radio_addr = ADDR_UNSET,
Pavel Mihaylovc3d93192005-11-08 21:38:43 -08002585 .gpiomask = 0xe880c0,
Paul T Zalacfe2e36c2005-11-08 21:38:04 -08002586 .inputs = {{
Pavel Mihaylovc3d93192005-11-08 21:38:43 -08002587 .name = name_tv,
2588 .vmux = 3,
2589 .amux = TV,
2590 .tv = 1,
2591 },{
Paul T Zalacfe2e36c2005-11-08 21:38:04 -08002592 .name = name_comp1,
2593 .vmux = 1,
Pavel Mihaylovc3d93192005-11-08 21:38:43 -08002594 .amux = LINE1,
2595 },{
2596 .name = name_svideo,
2597 .vmux = 6,
2598 .amux = LINE1,
Paul T Zalacfe2e36c2005-11-08 21:38:04 -08002599 }},
Pavel Mihaylovc3d93192005-11-08 21:38:43 -08002600 .radio = {
2601 .name = name_radio,
2602 .amux = LINE2,
2603 },
Paul T Zalacfe2e36c2005-11-08 21:38:04 -08002604 },
Michael Krufky5d5c9902005-11-08 21:38:08 -08002605 [SAA7134_BOARD_ASUSTEK_DIGIMATRIX_TV] = {
2606 /* "Cyril Lacoux (Yack)" <clacoux@ifeelgood.org> */
2607 .name = "ASUS Digimatrix TV",
2608 .audio_clock = 0x00200000,
2609 .tuner_type = TUNER_PHILIPS_FQ1216ME,
2610 .tda9887_conf = TDA9887_PRESENT,
2611 .radio_type = UNSET,
2612 .tuner_addr = ADDR_UNSET,
2613 .radio_addr = ADDR_UNSET,
2614 .inputs = {{
2615 .name = name_tv,
2616 .vmux = 1,
2617 .amux = TV,
2618 .tv = 1,
2619 },{
2620 .name = name_comp1,
2621 .vmux = 3,
2622 .amux = LINE1,
2623 },{
2624 .name = name_svideo,
2625 .vmux = 8,
2626 .amux = LINE1,
2627 }},
2628 },
Hartmut Hackmann90e9df72005-11-08 21:38:42 -08002629 [SAA7134_BOARD_PHILIPS_TIGER] = {
2630 .name = "Philips Tiger reference design",
2631 .audio_clock = 0x00187de7,
2632 .tuner_type = TUNER_PHILIPS_TDA8290,
2633 .radio_type = UNSET,
2634 .tuner_addr = ADDR_UNSET,
2635 .radio_addr = ADDR_UNSET,
Hartmut Hackmann58ef4f92007-04-27 12:31:12 -03002636 .tuner_config = 0,
Hartmut Hackmann90e9df72005-11-08 21:38:42 -08002637 .mpeg = SAA7134_MPEG_DVB,
Hartmut Hackmannde956c12007-04-27 12:31:12 -03002638 .gpiomask = 0x0200000,
Hartmut Hackmann90e9df72005-11-08 21:38:42 -08002639 .inputs = {{
2640 .name = name_tv,
2641 .vmux = 1,
2642 .amux = TV,
2643 .tv = 1,
2644 },{
2645 .name = name_comp1,
2646 .vmux = 3,
2647 .amux = LINE1,
2648 },{
2649 .name = name_svideo,
2650 .vmux = 8,
2651 .amux = LINE1,
2652 }},
Hartmut Hackmann0f79c362006-01-14 21:26:44 -02002653 .radio = {
2654 .name = name_radio,
2655 .amux = TV,
2656 .gpio = 0x0200000,
2657 },
Hartmut Hackmann90e9df72005-11-08 21:38:42 -08002658 },
Ricardo Cerqueira80d2ad92005-11-13 16:08:01 -08002659 [SAA7134_BOARD_MSI_TVATANYWHERE_PLUS] = {
2660 .name = "MSI TV@Anywhere plus",
2661 .audio_clock = 0x00187de7,
2662 .tuner_type = TUNER_PHILIPS_TDA8290,
2663 .radio_type = UNSET,
2664 .tuner_addr = ADDR_UNSET,
2665 .radio_addr = ADDR_UNSET,
hermann pittone382f622007-01-07 21:19:48 -03002666 .gpiomask = 1 << 21,
Ricardo Cerqueira80d2ad92005-11-13 16:08:01 -08002667 .inputs = {{
2668 .name = name_tv,
2669 .vmux = 1,
2670 .amux = TV,
2671 .tv = 1,
2672 },{
2673 .name = name_comp1,
2674 .vmux = 3,
hermann pittone382f622007-01-07 21:19:48 -03002675 .amux = LINE2, /* unconfirmed, taken from Philips driver */
2676 },{
2677 .name = name_comp2,
2678 .vmux = 0, /* untested, Composite over S-Video */
2679 .amux = LINE2,
Ricardo Cerqueira80d2ad92005-11-13 16:08:01 -08002680 },{
2681 .name = name_svideo,
hermann pittone382f622007-01-07 21:19:48 -03002682 .vmux = 8,
2683 .amux = LINE2,
Ricardo Cerqueira80d2ad92005-11-13 16:08:01 -08002684 }},
2685 .radio = {
2686 .name = name_radio,
hermann pittone382f622007-01-07 21:19:48 -03002687 .amux = TV,
2688 .gpio = 0x0200000,
Ricardo Cerqueira80d2ad92005-11-13 16:08:01 -08002689 },
2690 },
Jörg Schummerf639c9b2006-01-09 15:25:01 -02002691 [SAA7134_BOARD_CINERGY250PCI] = {
2692 /* remote-control does not work. The signal about a
2693 key press comes in via gpio, but the key code
2694 doesn't. Neither does it have an i2c remote control
2695 interface. */
2696 .name = "Terratec Cinergy 250 PCI TV",
2697 .audio_clock = 0x00187de7,
2698 .tuner_type = TUNER_PHILIPS_TDA8290,
2699 .radio_type = UNSET,
2700 .tuner_addr = ADDR_UNSET,
2701 .radio_addr = ADDR_UNSET,
2702 .gpiomask = 0x80200000,
2703 .inputs = {{
2704 .name = name_tv,
2705 .vmux = 1,
2706 .amux = TV,
2707 .tv = 1,
2708 },{
2709 .name = name_svideo, /* NOT tested */
2710 .vmux = 8,
2711 .amux = LINE1,
2712 }},
2713 .radio = {
2714 .name = name_radio,
Hartmut Hackmann58ef4f92007-04-27 12:31:12 -03002715 .amux = TV,
Jörg Schummerf639c9b2006-01-09 15:25:01 -02002716 .gpio = 0x0200000,
2717 },
2718 },
Peter Missel4aa6ba52006-01-09 15:32:45 -02002719 [SAA7134_BOARD_FLYDVB_TRIO] = {
2720 /* LifeView LR319 FlyDVB Trio */
2721 /* Peter Missel <peter.missel@onlinehome.de> */
2722 .name = "LifeView FlyDVB Trio",
2723 .audio_clock = 0x00200000,
2724 .tuner_type = TUNER_PHILIPS_TDA8290,
2725 .radio_type = UNSET,
2726 .tuner_addr = ADDR_UNSET,
2727 .radio_addr = ADDR_UNSET,
2728 .gpiomask = 0x00200000,
Hartmut Hackmann293cdab2006-02-27 21:08:07 -03002729 .mpeg = SAA7134_MPEG_DVB,
Peter Missel4aa6ba52006-01-09 15:32:45 -02002730 .inputs = {{
2731 .name = name_tv, /* Analog broadcast/cable TV */
2732 .vmux = 1,
2733 .amux = TV,
2734 .gpio = 0x200000, /* GPIO21=High for TV input */
2735 .tv = 1,
2736 },{
2737 .name = name_svideo, /* S-Video signal on S-Video input */
2738 .vmux = 8,
2739 .amux = LINE2,
2740 },{
2741 .name = name_comp1, /* Composite signal on S-Video input */
2742 .vmux = 0,
2743 .amux = LINE2,
2744 },{
2745 .name = name_comp2, /* Composite input */
2746 .vmux = 3,
2747 .amux = LINE2,
2748 }},
2749 .radio = {
2750 .name = name_radio,
2751 .amux = TV,
2752 .gpio = 0x000000, /* GPIO21=Low for FM radio antenna */
2753 },
2754 },
Jose Alberto Regueroa78d0bf2006-02-07 06:25:14 -02002755 [SAA7134_BOARD_AVERMEDIA_777] = {
2756 .name = "AverTV DVB-T 777",
2757 .audio_clock = 0x00187de7,
2758 .tuner_type = TUNER_ABSENT,
2759 .radio_type = UNSET,
2760 .tuner_addr = ADDR_UNSET,
2761 .radio_addr = ADDR_UNSET,
2762 .mpeg = SAA7134_MPEG_DVB,
2763 .inputs = {{
2764 .name = name_comp1,
Hartmut Hackmann2174eb92006-03-27 19:15:47 -03002765 .vmux = 1,
Jose Alberto Regueroa78d0bf2006-02-07 06:25:14 -02002766 .amux = LINE1,
2767 },{
2768 .name = name_svideo,
2769 .vmux = 8,
2770 .amux = LINE1,
2771 }},
2772 },
Giampiero Giancipoli3d8466e2006-02-07 06:49:09 -02002773 [SAA7134_BOARD_FLYDVBT_LR301] = {
2774 /* LifeView FlyDVB-T */
2775 /* Giampiero Giancipoli <gianci@libero.it> */
Hartmut Hackmann42e6b3b2006-03-27 19:04:48 -03002776 .name = "LifeView FlyDVB-T / Genius VideoWonder DVB-T",
Giampiero Giancipoli3d8466e2006-02-07 06:49:09 -02002777 .audio_clock = 0x00200000,
2778 .tuner_type = TUNER_ABSENT,
2779 .radio_type = UNSET,
2780 .tuner_addr = ADDR_UNSET,
2781 .radio_addr = ADDR_UNSET,
2782 .mpeg = SAA7134_MPEG_DVB,
2783 .inputs = {{
2784 .name = name_comp1, /* Composite input */
2785 .vmux = 3,
2786 .amux = LINE2,
2787 },{
2788 .name = name_svideo, /* S-Video signal on S-Video input */
2789 .vmux = 8,
2790 .amux = LINE2,
2791 }},
2792 },
Hartmut Hackmanndf42eaf2006-02-07 06:49:10 -02002793 [SAA7134_BOARD_ADS_DUO_CARDBUS_PTV331] = {
2794 .name = "ADS Instant TV Duo Cardbus PTV331",
2795 .audio_clock = 0x00200000,
2796 .tuner_type = TUNER_PHILIPS_TDA8290,
2797 .radio_type = UNSET,
2798 .tuner_addr = ADDR_UNSET,
2799 .radio_addr = ADDR_UNSET,
2800 .mpeg = SAA7134_MPEG_DVB,
2801 .gpiomask = 0x00600000, /* Bit 21 0=Radio, Bit 22 0=TV */
2802 .inputs = {{
2803 .name = name_tv,
2804 .vmux = 1,
2805 .amux = TV,
2806 .tv = 1,
2807 .gpio = 0x00200000,
2808 }},
2809 },
Peter Hartshorn3dfb7292006-02-07 06:49:13 -02002810 [SAA7134_BOARD_TEVION_DVBT_220RF] = {
Adrian Bunk793f2252006-03-08 10:50:06 -03002811 .name = "Tevion/KWorld DVB-T 220RF",
Peter Hartshorn3dfb7292006-02-07 06:49:13 -02002812 .audio_clock = 0x00187de7,
2813 .tuner_type = TUNER_PHILIPS_TDA8290,
2814 .radio_type = UNSET,
2815 .tuner_addr = ADDR_UNSET,
2816 .radio_addr = ADDR_UNSET,
2817 .mpeg = SAA7134_MPEG_DVB,
Simon Farnsworth289ea1f2007-09-10 13:37:26 -03002818 .gpiomask = 1 << 21,
Peter Hartshorn3dfb7292006-02-07 06:49:13 -02002819 .inputs = {{
2820 .name = name_tv,
2821 .vmux = 1,
2822 .amux = TV,
2823 .tv = 1,
2824 },{
2825 .name = name_comp1,
2826 .vmux = 3,
2827 .amux = LINE1,
2828 },{
Simon Farnsworth289ea1f2007-09-10 13:37:26 -03002829 .name = name_comp2,
Peter Hartshorn3dfb7292006-02-07 06:49:13 -02002830 .vmux = 0,
2831 .amux = LINE1,
Simon Farnsworth289ea1f2007-09-10 13:37:26 -03002832 },{
2833 .name = name_svideo,
2834 .vmux = 8,
2835 .amux = LINE1,
Peter Hartshorn3dfb7292006-02-07 06:49:13 -02002836 }},
2837 .radio = {
2838 .name = name_radio,
Simon Farnsworth289ea1f2007-09-10 13:37:26 -03002839 .amux = TV,
2840 .gpio = 0x0200000,
Peter Hartshorn3dfb7292006-02-07 06:49:13 -02002841 },
2842 },
Simon Farnsworthb39423a2007-05-01 10:01:20 -03002843 [SAA7134_BOARD_KWORLD_DVBT_210] = {
2844 .name = "KWorld DVB-T 210",
2845 .audio_clock = 0x00187de7,
2846 .tuner_type = TUNER_PHILIPS_TDA8290,
2847 .radio_type = UNSET,
2848 .tuner_addr = ADDR_UNSET,
2849 .radio_addr = ADDR_UNSET,
2850 .mpeg = SAA7134_MPEG_DVB,
2851 .gpiomask = 1 << 21,
2852 .inputs = {{
2853 .name = name_tv,
2854 .vmux = 1,
2855 .amux = TV,
2856 .tv = 1,
2857 },{
2858 .name = name_comp1,
2859 .vmux = 3,
2860 .amux = LINE1,
2861 },{
2862 .name = name_svideo,
2863 .vmux = 8,
2864 .amux = LINE1,
2865 }},
2866 .radio = {
2867 .name = name_radio,
2868 .amux = TV,
2869 .gpio = 0x0200000,
2870 },
2871 },
Andrew Burri3e1410a2006-02-27 00:08:23 -03002872 [SAA7134_BOARD_KWORLD_ATSC110] = {
Eric Sandeen0ac3a5b2007-10-08 16:13:02 -03002873 .name = "Kworld ATSC110/115",
Andrew Burri3e1410a2006-02-27 00:08:23 -03002874 .audio_clock = 0x00187de7,
2875 .tuner_type = TUNER_PHILIPS_TUV1236D,
2876 .radio_type = UNSET,
2877 .tuner_addr = ADDR_UNSET,
2878 .radio_addr = ADDR_UNSET,
2879 .tda9887_conf = TDA9887_PRESENT,
2880 .mpeg = SAA7134_MPEG_DVB,
2881 .inputs = {{
2882 .name = name_tv,
2883 .vmux = 1,
2884 .amux = TV,
2885 .tv = 1,
Curt Meyers6ba509d2006-02-27 00:08:32 -03002886 },{
2887 .name = name_comp1,
2888 .vmux = 3,
2889 .amux = LINE2,
2890 },{
2891 .name = name_svideo,
2892 .vmux = 8,
2893 .amux = LINE2,
Andrew Burri3e1410a2006-02-27 00:08:23 -03002894 }},
2895 },
Rickard Osser68593af2006-03-11 17:14:12 -03002896 [SAA7134_BOARD_AVERMEDIA_A169_B] = {
2897 /* AVerMedia A169 */
2898 /* Rickard Osser <ricky@osser.se> */
2899 /* This card has two saa7134 chips on it,
2900 but only one of them is currently working. */
2901 .name = "AVerMedia A169 B",
2902 .audio_clock = 0x02187de7,
2903 .tuner_type = TUNER_LG_TALN,
2904 .radio_type = UNSET,
2905 .tuner_addr = ADDR_UNSET,
2906 .radio_addr = ADDR_UNSET,
2907 .tda9887_conf = TDA9887_PRESENT,
2908 .gpiomask = 0x0a60000,
2909 },
2910 [SAA7134_BOARD_AVERMEDIA_A169_B1] = {
2911 /* AVerMedia A169 */
2912 /* Rickard Osser <ricky@osser.se> */
2913 .name = "AVerMedia A169 B1",
2914 .audio_clock = 0x02187de7,
2915 .tuner_type = TUNER_LG_TALN,
2916 .radio_type = UNSET,
2917 .tuner_addr = ADDR_UNSET,
2918 .radio_addr = ADDR_UNSET,
2919 .tda9887_conf = TDA9887_PRESENT,
2920 .gpiomask = 0xca60000,
2921 .inputs = {{
2922 .name = name_tv,
2923 .vmux = 4,
2924 .amux = TV,
2925 .tv = 1,
2926 .gpio = 0x04a61000,
2927 },{
2928 .name = name_comp2, /* Composite SVIDEO (B/W if signal is carried with SVIDEO) */
2929 .vmux = 1,
2930 .amux = LINE2,
2931 },{
2932 .name = name_svideo,
2933 .vmux = 9, /* 9 is correct as S-VIDEO1 according to a169.inf! */
2934 .amux = LINE1,
2935 }},
2936 },
Michael Krufkyba3a5a82006-03-14 19:02:12 -03002937 [SAA7134_BOARD_MD7134_BRIDGE_2] = {
Hartmut Hackmann637afdb2008-04-22 14:46:08 -03002938 /* The second saa7134 on this card only serves as DVB-S host bridge */
Michael Krufkyba3a5a82006-03-14 19:02:12 -03002939 .name = "Medion 7134 Bridge #2",
2940 .audio_clock = 0x00187de7,
2941 .radio_type = UNSET,
2942 .tuner_addr = ADDR_UNSET,
2943 .radio_addr = ADDR_UNSET,
Hartmut Hackmann637afdb2008-04-22 14:46:08 -03002944 .mpeg = SAA7134_MPEG_DVB,
Michael Krufkyba3a5a82006-03-14 19:02:12 -03002945 },
Hartmut Hackmannd95b8942006-03-27 19:39:30 -03002946 [SAA7134_BOARD_FLYDVBT_HYBRID_CARDBUS] = {
Mauro Carvalho Chehab593f18c2007-10-07 02:17:09 -03002947 .name = "LifeView FlyDVB-T Hybrid Cardbus/MSI TV @nywhere A/D NB",
Hartmut Hackmannd95b8942006-03-27 19:39:30 -03002948 .audio_clock = 0x00200000,
2949 .tuner_type = TUNER_PHILIPS_TDA8290,
2950 .radio_type = UNSET,
2951 .tuner_addr = ADDR_UNSET,
2952 .radio_addr = ADDR_UNSET,
2953 .mpeg = SAA7134_MPEG_DVB,
2954 .gpiomask = 0x00600000, /* Bit 21 0=Radio, Bit 22 0=TV */
2955 .inputs = {{
2956 .name = name_tv,
2957 .vmux = 1,
2958 .amux = TV,
2959 .gpio = 0x200000, /* GPIO21=High for TV input */
2960 .tv = 1,
2961 },{
2962 .name = name_svideo, /* S-Video signal on S-Video input */
2963 .vmux = 8,
2964 .amux = LINE2,
2965 },{
2966 .name = name_comp1, /* Composite signal on S-Video input */
2967 .vmux = 0,
2968 .amux = LINE2,
2969 },{
2970 .name = name_comp2, /* Composite input */
2971 .vmux = 3,
2972 .amux = LINE2,
2973 }},
2974 .radio = {
2975 .name = name_radio,
2976 .amux = TV,
2977 .gpio = 0x000000, /* GPIO21=Low for FM radio antenna */
2978 },
2979 },
Zac Bowlingf49ba8d2006-06-19 19:49:20 -03002980 [SAA7134_BOARD_FLYVIDEO3000_NTSC] = {
2981 /* "Zac Bowling" <zac@zacbowling.com> */
2982 .name = "LifeView FlyVIDEO3000 (NTSC)",
2983 .audio_clock = 0x00200000,
2984 .tuner_type = TUNER_PHILIPS_NTSC,
2985 .radio_type = UNSET,
2986 .tuner_addr = ADDR_UNSET,
2987 .radio_addr = ADDR_UNSET,
2988
2989 .gpiomask = 0xe000,
2990 .inputs = {{
2991 .name = name_tv,
2992 .vmux = 1,
2993 .amux = TV,
2994 .gpio = 0x8000,
2995 .tv = 1,
2996 },{
2997 .name = name_tv_mono,
2998 .vmux = 1,
2999 .amux = LINE2,
3000 .gpio = 0x0000,
3001 .tv = 1,
3002 },{
3003 .name = name_comp1,
3004 .vmux = 0,
3005 .amux = LINE2,
3006 .gpio = 0x4000,
3007 },{
3008 .name = name_comp2,
3009 .vmux = 3,
3010 .amux = LINE2,
3011 .gpio = 0x4000,
3012 },{
3013 .name = name_svideo,
3014 .vmux = 8,
3015 .amux = LINE2,
3016 .gpio = 0x4000,
3017 }},
3018 .radio = {
3019 .name = name_radio,
3020 .amux = LINE2,
3021 .gpio = 0x2000,
3022 },
3023 .mute = {
3024 .name = name_mute,
3025 .amux = TV,
3026 .gpio = 0x8000,
3027 },
3028 },
Hartmut Hackmann5eda2272006-08-07 14:03:32 -03003029 [SAA7134_BOARD_MEDION_MD8800_QUADRO] = {
3030 .name = "Medion Md8800 Quadro",
3031 .audio_clock = 0x00187de7,
3032 .tuner_type = TUNER_PHILIPS_TDA8290,
3033 .radio_type = UNSET,
3034 .tuner_addr = ADDR_UNSET,
3035 .radio_addr = ADDR_UNSET,
3036 .mpeg = SAA7134_MPEG_DVB,
3037 .inputs = {{
3038 .name = name_tv,
3039 .vmux = 1,
3040 .amux = TV,
3041 .tv = 1,
3042 },{
3043 .name = name_comp1,
3044 .vmux = 0,
hermann pitton387a2992007-10-25 21:26:53 -03003045 .amux = LINE1,
Hartmut Hackmann5eda2272006-08-07 14:03:32 -03003046 },{
3047 .name = name_svideo,
3048 .vmux = 8,
hermann pitton387a2992007-10-25 21:26:53 -03003049 .amux = LINE1,
Hartmut Hackmann5eda2272006-08-07 14:03:32 -03003050 }},
3051 },
Igor M. Liplianine2ac28f2006-08-08 09:10:10 -03003052 [SAA7134_BOARD_FLYDVBS_LR300] = {
3053 /* LifeView FlyDVB-s */
3054 /* Igor M. Liplianin <liplianin@tut.by> */
3055 .name = "LifeView FlyDVB-S /Acorp TV134DS",
3056 .audio_clock = 0x00200000,
3057 .tuner_type = TUNER_ABSENT,
3058 .radio_type = UNSET,
3059 .tuner_addr = ADDR_UNSET,
3060 .radio_addr = ADDR_UNSET,
3061 .mpeg = SAA7134_MPEG_DVB,
3062 .inputs = {{
3063 .name = name_comp1, /* Composite input */
3064 .vmux = 3,
3065 .amux = LINE1,
3066 },{
3067 .name = name_svideo, /* S-Video signal on S-Video input */
3068 .vmux = 8,
3069 .amux = LINE1,
3070 }},
3071 },
Michal Majchrowiczb04c1ba2006-09-13 16:42:42 -03003072 [SAA7134_BOARD_PROTEUS_2309] = {
3073 .name = "Proteus Pro 2309",
3074 .audio_clock = 0x00187de7,
3075 .tuner_type = TUNER_PHILIPS_FM1216ME_MK3,
3076 .radio_type = UNSET,
3077 .tuner_addr = ADDR_UNSET,
3078 .radio_addr = ADDR_UNSET,
3079 .tda9887_conf = TDA9887_PRESENT,
3080 .inputs = {{
3081 .name = name_tv,
3082 .vmux = 1,
3083 .amux = LINE2,
3084 .tv = 1,
3085 },{
3086 .name = name_comp1,
3087 .vmux = 0,
3088 .amux = LINE2,
3089 },{
3090 .name = name_comp2,
3091 .vmux = 3,
3092 .amux = LINE2,
3093 },{
3094 .name = name_svideo,
3095 .vmux = 8,
3096 .amux = LINE2,
3097 }},
3098 .mute = {
3099 .name = name_mute,
3100 .amux = LINE1,
3101 },
3102 },
Petr Baudis515c2082006-09-26 16:53:53 -03003103 [SAA7134_BOARD_AVERMEDIA_A16AR] = {
3104 /* Petr Baudis <pasky@ucw.cz> */
3105 .name = "AVerMedia TV Hybrid A16AR",
3106 .audio_clock = 0x187de7,
pasky@ucw.cz0871a882006-11-12 14:24:57 -03003107 .tuner_type = TUNER_PHILIPS_TD1316, /* untested */
Petr Baudis515c2082006-09-26 16:53:53 -03003108 .radio_type = TUNER_TEA5767, /* untested */
3109 .tuner_addr = ADDR_UNSET,
Mauro Carvalho Chehabc117d052008-04-26 14:05:58 -03003110 .radio_addr = 0x60,
Petr Baudis515c2082006-09-26 16:53:53 -03003111 .tda9887_conf = TDA9887_PRESENT,
3112 .mpeg = SAA7134_MPEG_DVB,
3113 .inputs = {{
3114 .name = name_tv,
3115 .vmux = 1,
3116 .amux = TV,
3117 .tv = 1,
3118 },{
3119 .name = name_comp1,
3120 .vmux = 3,
3121 .amux = LINE2,
3122 },{
3123 .name = name_svideo,
3124 .vmux = 8,
3125 .amux = LINE1,
3126 }},
3127 .radio = {
3128 .name = name_radio,
3129 .amux = LINE1,
3130 },
3131 },
Hartmut Hackmanncf146ca2006-10-02 20:49:24 -03003132 [SAA7134_BOARD_ASUS_EUROPA2_HYBRID] = {
3133 .name = "Asus Europa2 OEM",
3134 .audio_clock = 0x00187de7,
3135 .tuner_type = TUNER_PHILIPS_FMD1216ME_MK3,
3136 .radio_type = UNSET,
3137 .tuner_addr = ADDR_UNSET,
3138 .radio_addr = ADDR_UNSET,
3139 .tda9887_conf = TDA9887_PRESENT| TDA9887_PORT1_ACTIVE | TDA9887_PORT2_ACTIVE,
3140 .mpeg = SAA7134_MPEG_DVB,
3141 .inputs = {{
3142 .name = name_tv,
3143 .vmux = 3,
3144 .amux = TV,
3145 .tv = 1,
3146 },{
3147 .name = name_comp1,
3148 .vmux = 4,
3149 .amux = LINE2,
3150 },{
3151 .name = name_svideo,
3152 .vmux = 8,
3153 .amux = LINE2,
3154 }},
3155 .radio = {
3156 .name = name_radio,
3157 .amux = LINE1,
3158 },
3159 },
Hartmut Hackmann587d2fd2006-10-06 19:13:50 -03003160 [SAA7134_BOARD_PINNACLE_PCTV_310i] = {
3161 .name = "Pinnacle PCTV 310i",
3162 .audio_clock = 0x00187de7,
3163 .tuner_type = TUNER_PHILIPS_TDA8290,
3164 .radio_type = UNSET,
3165 .tuner_addr = ADDR_UNSET,
3166 .radio_addr = ADDR_UNSET,
Hartmut Hackmann58ef4f92007-04-27 12:31:12 -03003167 .tuner_config = 1,
Hartmut Hackmann587d2fd2006-10-06 19:13:50 -03003168 .mpeg = SAA7134_MPEG_DVB,
3169 .gpiomask = 0x000200000,
3170 .inputs = {{
3171 .name = name_tv,
3172 .vmux = 4,
3173 .amux = TV,
3174 .tv = 1,
3175 },{
3176 .name = name_comp1,
3177 .vmux = 1,
3178 .amux = LINE2,
3179 },{
3180 .name = name_comp2,
3181 .vmux = 0,
3182 .amux = LINE2,
3183 },{
3184 .name = name_svideo,
3185 .vmux = 8,
3186 .amux = LINE2,
3187 }},
3188 .radio = {
3189 .name = name_radio,
3190 .amux = TV,
3191 .gpio = 0x0200000,
3192 },
3193 },
Mikhail Fedotov3ac706d2006-10-06 20:23:47 -03003194 [SAA7134_BOARD_AVERMEDIA_STUDIO_507] = {
3195 /* Mikhail Fedotov <mo_fedotov@mail.ru> */
3196 .name = "Avermedia AVerTV Studio 507",
3197 .audio_clock = 0x00187de7,
3198 .tuner_type = TUNER_PHILIPS_FM1256_IH3,
3199 .radio_type = UNSET,
3200 .tuner_addr = ADDR_UNSET,
3201 .radio_addr = ADDR_UNSET,
3202 .tda9887_conf = TDA9887_PRESENT,
3203 .gpiomask = 0x03,
3204 .inputs = {{
3205 .name = name_tv,
3206 .vmux = 1,
3207 .amux = TV,
3208 .tv = 1,
3209 .gpio = 0x00,
3210 },{
3211 .name = name_comp1,
3212 .vmux = 0,
3213 .amux = LINE2,
3214 .gpio = 0x00,
3215 },{
3216 .name = name_comp2,
3217 .vmux = 3,
3218 .amux = LINE2,
3219 .gpio = 0x00,
3220 },{
3221 .name = name_svideo,
3222 .vmux = 8,
3223 .amux = LINE2,
3224 .gpio = 0x00,
3225 }},
3226 .radio = {
3227 .name = name_radio,
3228 .amux = LINE2,
3229 .gpio = 0x01,
3230 },
3231 .mute = {
3232 .name = name_mute,
3233 .amux = LINE1,
3234 .gpio = 0x00,
3235 },
3236 },
Hartmut Hackmanncbb94522006-10-30 20:00:16 -03003237 [SAA7134_BOARD_VIDEOMATE_DVBT_200A] = {
3238 /* Francis Barber <fedora@barber-family.id.au> */
3239 .name = "Compro Videomate DVB-T200A",
3240 .audio_clock = 0x00187de7,
3241 .tuner_type = TUNER_ABSENT,
3242 .radio_type = UNSET,
3243 .tuner_addr = ADDR_UNSET,
3244 .radio_addr = ADDR_UNSET,
3245 .tda9887_conf = TDA9887_PRESENT | TDA9887_PORT1_ACTIVE,
3246 .mpeg = SAA7134_MPEG_DVB,
3247 .inputs = {{
3248 .name = name_tv,
3249 .vmux = 3,
3250 .amux = TV,
3251 .tv = 1,
3252 },{
3253 .name = name_comp1,
3254 .vmux = 1,
3255 .amux = LINE2,
3256 },{
3257 .name = name_svideo,
3258 .vmux = 8,
3259 .amux = LINE2,
3260 }},
3261 },
Thomas Gentyc6e53da2006-11-05 14:17:30 -03003262 [SAA7134_BOARD_HAUPPAUGE_HVR1110] = {
3263 /* Thomas Genty <tomlohave@gmail.com> */
David Bentham8acdbcf2008-09-28 16:29:51 -03003264 /* David Bentham <db260179@hotmail.com> */
Thomas Gentyc6e53da2006-11-05 14:17:30 -03003265 .name = "Hauppauge WinTV-HVR1110 DVB-T/Hybrid",
3266 .audio_clock = 0x00187de7,
3267 .tuner_type = TUNER_PHILIPS_TDA8290,
3268 .radio_type = UNSET,
3269 .tuner_addr = ADDR_UNSET,
3270 .radio_addr = ADDR_UNSET,
Michael Krufkyb3aa2262007-12-09 21:13:38 -03003271 .tuner_config = 1,
Thomas Gentyc6e53da2006-11-05 14:17:30 -03003272 .mpeg = SAA7134_MPEG_DVB,
David Bentham8acdbcf2008-09-28 16:29:51 -03003273 .gpiomask = 0x0200100,
Thomas Gentyc6e53da2006-11-05 14:17:30 -03003274 .inputs = {{
3275 .name = name_tv,
3276 .vmux = 1,
3277 .amux = TV,
3278 .tv = 1,
David Bentham8acdbcf2008-09-28 16:29:51 -03003279 .gpio = 0x0000100,
3280 }, {
3281 .name = name_comp1,
3282 .vmux = 3,
3283 .amux = LINE1,
3284 }, {
3285 .name = name_svideo,
3286 .vmux = 8,
3287 .amux = LINE1,
3288 } },
Thomas Gentyc6e53da2006-11-05 14:17:30 -03003289 .radio = {
3290 .name = name_radio,
David Bentham8acdbcf2008-09-28 16:29:51 -03003291 .amux = TV,
3292 .gpio = 0x0200100,
Thomas Gentyc6e53da2006-11-05 14:17:30 -03003293 },
3294 },
Michael Krufkyf9996c92009-02-28 17:45:17 -03003295 [SAA7134_BOARD_HAUPPAUGE_HVR1150] = {
3296 .name = "Hauppauge WinTV-HVR1150",
3297 .audio_clock = 0x00187de7,
3298 .tuner_type = TUNER_PHILIPS_TDA8290,
3299 .radio_type = UNSET,
3300 .tuner_addr = ADDR_UNSET,
3301 .radio_addr = ADDR_UNSET,
3302 .tuner_config = 3,
3303 .gpiomask = 0x0800100, /* GPIO 21 is an INPUT */
3304 .inputs = {{
3305 .name = name_tv,
3306 .vmux = 1,
3307 .amux = TV,
3308 .tv = 1,
3309 .gpio = 0x0000100,
3310 }, {
3311 .name = name_comp1,
3312 .vmux = 3,
3313 .amux = LINE1,
3314 }, {
3315 .name = name_svideo,
3316 .vmux = 8,
3317 .amux = LINE1,
3318 } },
3319 .radio = {
3320 .name = name_radio,
3321 .amux = TV,
3322 .gpio = 0x0800100, /* GPIO 23 HI for FM */
3323 },
3324 },
3325 [SAA7134_BOARD_HAUPPAUGE_HVR1110R3] = {
3326 .name = "Hauppauge WinTV-HVR1110r3",
3327 .audio_clock = 0x00187de7,
3328 .tuner_type = TUNER_PHILIPS_TDA8290,
3329 .radio_type = UNSET,
3330 .tuner_addr = ADDR_UNSET,
3331 .radio_addr = ADDR_UNSET,
3332 .tuner_config = 3,
3333 .gpiomask = 0x0800100, /* GPIO 21 is an INPUT */
3334 .inputs = {{
3335 .name = name_tv,
3336 .vmux = 1,
3337 .amux = TV,
3338 .tv = 1,
3339 .gpio = 0x0000100,
3340 }, {
3341 .name = name_comp1,
3342 .vmux = 3,
3343 .amux = LINE1,
3344 }, {
3345 .name = name_svideo,
3346 .vmux = 8,
3347 .amux = LINE1,
3348 } },
3349 .radio = {
3350 .name = name_radio,
3351 .amux = TV,
3352 .gpio = 0x0800100, /* GPIO 23 HI for FM */
3353 },
3354 },
Hartmut Hackmann550a9a52006-11-15 21:31:54 -03003355 [SAA7134_BOARD_CINERGY_HT_PCMCIA] = {
3356 .name = "Terratec Cinergy HT PCMCIA",
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 },
Steven Walterd1158f42006-12-20 09:29:09 -03003378 [SAA7134_BOARD_ENCORE_ENLTV] = {
Juan Pablo Sormanic36c4592006-12-27 12:46:36 -03003379 /* Steven Walter <stevenrwalter@gmail.com>
3380 Juan Pablo Sormani <sorman@gmail.com> */
Steven Walterd1158f42006-12-20 09:29:09 -03003381 .name = "Encore ENLTV",
Juan Pablo Sormanic36c4592006-12-27 12:46:36 -03003382 .audio_clock = 0x00200000,
Steven Walterd1158f42006-12-20 09:29:09 -03003383 .tuner_type = TUNER_TNF_5335MF,
3384 .radio_type = UNSET,
3385 .tuner_addr = ADDR_UNSET,
3386 .radio_addr = ADDR_UNSET,
3387 .inputs = {{
3388 .name = name_tv,
3389 .vmux = 1,
Juan Pablo Sormanic36c4592006-12-27 12:46:36 -03003390 .amux = 3,
Steven Walterd1158f42006-12-20 09:29:09 -03003391 .tv = 1,
3392 },{
Juan Pablo Sormanic36c4592006-12-27 12:46:36 -03003393 .name = name_tv_mono,
3394 .vmux = 7,
3395 .amux = 4,
3396 .tv = 1,
3397 },{
3398 .name = name_comp1,
3399 .vmux = 3,
3400 .amux = 2,
3401 },{
Steven Walterd1158f42006-12-20 09:29:09 -03003402 .name = name_svideo,
Juan Pablo Sormanic36c4592006-12-27 12:46:36 -03003403 .vmux = 0,
3404 .amux = 2,
Steven Walterd1158f42006-12-20 09:29:09 -03003405 }},
Juan Pablo Sormanic36c4592006-12-27 12:46:36 -03003406 .radio = {
3407 .name = name_radio,
3408 .amux = LINE2,
3409/* .gpio = 0x00300001,*/
3410 .gpio = 0x20000,
3411
3412 },
3413 .mute = {
3414 .name = name_mute,
3415 .amux = 0,
3416 },
3417 },
3418 [SAA7134_BOARD_ENCORE_ENLTV_FM] = {
3419 /* Juan Pablo Sormani <sorman@gmail.com> */
3420 .name = "Encore ENLTV-FM",
3421 .audio_clock = 0x00200000,
Michael Krufkyab8b8702008-04-22 14:46:05 -03003422 .tuner_type = TUNER_PHILIPS_FCV1236D,
Juan Pablo Sormanic36c4592006-12-27 12:46:36 -03003423 .radio_type = UNSET,
3424 .tuner_addr = ADDR_UNSET,
3425 .radio_addr = ADDR_UNSET,
3426 .inputs = {{
3427 .name = name_tv,
3428 .vmux = 1,
3429 .amux = 3,
3430 .tv = 1,
3431 },{
3432 .name = name_tv_mono,
3433 .vmux = 7,
3434 .amux = 4,
3435 .tv = 1,
3436 },{
3437 .name = name_comp1,
3438 .vmux = 3,
3439 .amux = 2,
3440 },{
3441 .name = name_svideo,
3442 .vmux = 0,
3443 .amux = 2,
3444 }},
3445 .radio = {
3446 .name = name_radio,
3447 .amux = LINE2,
3448 .gpio = 0x20000,
3449
3450 },
3451 .mute = {
3452 .name = name_mute,
3453 .amux = 0,
3454 },
Steven Walterd1158f42006-12-20 09:29:09 -03003455 },
Mauro Carvalho Chehabbf1ece62008-06-26 17:03:00 -03003456 [SAA7134_BOARD_ENCORE_ENLTV_FM53] = {
3457 .name = "Encore ENLTV-FM v5.3",
3458 .audio_clock = 0x00200000,
3459 .tuner_type = TUNER_TNF_5335MF,
3460 .radio_type = UNSET,
3461 .tuner_addr = ADDR_UNSET,
3462 .radio_addr = ADDR_UNSET,
3463 .gpiomask = 0x7000,
3464 .inputs = { {
3465 .name = name_tv,
3466 .vmux = 1,
3467 .amux = 1,
3468 .tv = 1,
3469 .gpio = 0x50000,
3470 }, {
3471 .name = name_comp1,
3472 .vmux = 3,
3473 .amux = 2,
3474 .gpio = 0x2000,
3475 }, {
3476 .name = name_svideo,
3477 .vmux = 8,
3478 .amux = 2,
3479 .gpio = 0x2000,
3480 } },
3481 .radio = {
3482 .name = name_radio,
3483 .vmux = 1,
3484 .amux = 1,
3485 },
3486 .mute = {
3487 .name = name_mute,
3488 .gpio = 0xf000,
3489 .amux = 0,
3490 },
3491 },
Michael Krufky9de271e2007-01-16 18:36:40 -03003492 [SAA7134_BOARD_CINERGY_HT_PCI] = {
3493 .name = "Terratec Cinergy HT PCI",
3494 .audio_clock = 0x00187de7,
3495 .tuner_type = TUNER_PHILIPS_TDA8290,
3496 .radio_type = UNSET,
3497 .tuner_addr = ADDR_UNSET,
3498 .radio_addr = ADDR_UNSET,
3499 .mpeg = SAA7134_MPEG_DVB,
3500 .inputs = {{
3501 .name = name_tv,
3502 .vmux = 1,
3503 .amux = TV,
3504 .tv = 1,
3505 },{
3506 .name = name_comp1,
3507 .vmux = 0,
3508 .amux = LINE1,
3509 },{
3510 .name = name_svideo,
3511 .vmux = 6,
3512 .amux = LINE1,
3513 }},
3514 },
Hartmut Hackmann58ef4f92007-04-27 12:31:12 -03003515 [SAA7134_BOARD_PHILIPS_TIGER_S] = {
3516 .name = "Philips Tiger - S Reference design",
3517 .audio_clock = 0x00187de7,
3518 .tuner_type = TUNER_PHILIPS_TDA8290,
3519 .radio_type = UNSET,
3520 .tuner_addr = ADDR_UNSET,
3521 .radio_addr = ADDR_UNSET,
3522 .tuner_config = 2,
3523 .mpeg = SAA7134_MPEG_DVB,
3524 .gpiomask = 0x0200000,
3525 .inputs = {{
3526 .name = name_tv,
3527 .vmux = 1,
3528 .amux = TV,
3529 .tv = 1,
3530 },{
3531 .name = name_comp1,
3532 .vmux = 3,
3533 .amux = LINE1,
3534 },{
3535 .name = name_svideo,
3536 .vmux = 8,
3537 .amux = LINE1,
3538 }},
3539 .radio = {
3540 .name = name_radio,
3541 .amux = TV,
3542 .gpio = 0x0200000,
3543 },
3544 },
Markus Rechbergere95d3172007-04-27 12:31:19 -03003545 [SAA7134_BOARD_AVERMEDIA_M102] = {
3546 .name = "Avermedia M102",
3547 .audio_clock = 0x00187de7,
3548 .tuner_type = TUNER_PHILIPS_TDA8290,
3549 .radio_type = UNSET,
3550 .tuner_addr = ADDR_UNSET,
3551 .radio_addr = ADDR_UNSET,
3552 .gpiomask = 1<<21,
3553 .inputs = {{
3554 .name = name_tv,
3555 .vmux = 1,
3556 .amux = TV,
3557 .tv = 1,
3558 },{
3559 .name = name_comp1,
3560 .vmux = 0,
3561 .amux = LINE2,
3562 },{
3563 .name = name_svideo,
3564 .vmux = 6,
3565 .amux = LINE2,
3566 }},
3567 },
Hartmut Hackmanne06cea42007-03-13 20:58:29 -03003568 [SAA7134_BOARD_ASUS_P7131_4871] = {
3569 .name = "ASUS P7131 4871",
3570 .audio_clock = 0x00187de7,
3571 .tuner_type = TUNER_PHILIPS_TDA8290,
3572 .radio_type = UNSET,
3573 .tuner_addr = ADDR_UNSET,
3574 .radio_addr = ADDR_UNSET,
3575 .tuner_config = 2,
3576 .mpeg = SAA7134_MPEG_DVB,
3577 .gpiomask = 0x0200000,
3578 .inputs = {{
3579 .name = name_tv,
3580 .vmux = 1,
3581 .amux = TV,
3582 .tv = 1,
3583 .gpio = 0x0200000,
3584 }},
3585 },
Hartmut Hackmannf3eec0c02007-03-14 20:33:55 -03003586 [SAA7134_BOARD_ASUSTeK_P7131_HYBRID_LNA] = {
3587 .name = "ASUSTeK P7131 Hybrid",
Hartmut Hackmanne06cea42007-03-13 20:58:29 -03003588 .audio_clock = 0x00187de7,
3589 .tuner_type = TUNER_PHILIPS_TDA8290,
3590 .radio_type = UNSET,
3591 .tuner_addr = ADDR_UNSET,
3592 .radio_addr = ADDR_UNSET,
3593 .tuner_config = 2,
3594 .gpiomask = 1 << 21,
3595 .mpeg = SAA7134_MPEG_DVB,
3596 .inputs = {{
3597 .name = name_tv,
3598 .vmux = 1,
3599 .amux = TV,
3600 .tv = 1,
3601 .gpio = 0x0000000,
3602 },{
3603 .name = name_comp1,
3604 .vmux = 3,
3605 .amux = LINE2,
3606 .gpio = 0x0200000,
3607 },{
3608 .name = name_comp2,
3609 .vmux = 0,
3610 .amux = LINE2,
3611 .gpio = 0x0200000,
3612 },{
3613 .name = name_svideo,
3614 .vmux = 8,
3615 .amux = LINE2,
3616 .gpio = 0x0200000,
3617 }},
3618 .radio = {
3619 .name = name_radio,
3620 .amux = TV,
3621 .gpio = 0x0200000,
3622 },
Hermann Pitton0b17d0e2008-07-12 12:27:59 -03003623 },
3624 [SAA7134_BOARD_ASUSTeK_P7131_ANALOG] = {
3625 .name = "ASUSTeK P7131 Analog",
3626 .audio_clock = 0x00187de7,
3627 .tuner_type = TUNER_PHILIPS_TDA8290,
3628 .radio_type = UNSET,
3629 .tuner_addr = ADDR_UNSET,
3630 .radio_addr = ADDR_UNSET,
3631 .gpiomask = 1 << 21,
3632 .inputs = {{
3633 .name = name_tv,
3634 .vmux = 1,
3635 .amux = TV,
3636 .tv = 1,
3637 .gpio = 0x0000000,
3638 }, {
3639 .name = name_comp1,
3640 .vmux = 3,
3641 .amux = LINE2,
3642 }, {
3643 .name = name_comp2,
3644 .vmux = 0,
3645 .amux = LINE2,
3646 }, {
3647 .name = name_svideo,
3648 .vmux = 8,
3649 .amux = LINE2,
3650 } },
3651 .radio = {
3652 .name = name_radio,
3653 .amux = TV,
3654 .gpio = 0x0200000,
3655 },
Hartmut Hackmanne06cea42007-03-13 20:58:29 -03003656 },
James T Klaas53958b32007-05-01 10:48:09 -03003657 [SAA7134_BOARD_SABRENT_TV_PCB05] = {
3658 .name = "Sabrent PCMCIA TV-PCB05",
3659 .audio_clock = 0x00187de7,
3660 .tuner_type = TUNER_PHILIPS_TDA8290,
3661 .radio_type = UNSET,
3662 .tuner_addr = ADDR_UNSET,
3663 .radio_addr = ADDR_UNSET,
3664 .inputs = {{
3665 .name = name_tv,
3666 .vmux = 1,
3667 .amux = TV,
3668 .tv = 1,
3669 },{
3670 .name = name_comp1,
3671 .vmux = 3,
3672 .amux = LINE1,
3673 },{
3674 .name = name_comp2,
3675 .vmux = 0,
3676 .amux = LINE1,
3677 },{
3678 .name = name_svideo,
3679 .vmux = 8,
3680 .amux = LINE1,
3681 }},
3682 .mute = {
3683 .name = name_mute,
3684 .amux = TV,
3685 },
3686 },
Tony Wanaaccb822007-05-10 12:16:47 -03003687 [SAA7134_BOARD_10MOONSTVMASTER3] = {
3688 /* Tony Wan <aloha_cn@hotmail.com> */
3689 .name = "10MOONS TM300 TV Card",
3690 .audio_clock = 0x00200000,
3691 .tuner_type = TUNER_LG_PAL_NEW_TAPC,
3692 .radio_type = UNSET,
3693 .tuner_addr = ADDR_UNSET,
3694 .radio_addr = ADDR_UNSET,
3695 .gpiomask = 0x7000,
3696 .inputs = {{
3697 .name = name_tv,
3698 .vmux = 1,
3699 .amux = LINE2,
3700 .gpio = 0x0000,
3701 .tv = 1,
3702 },{
3703 .name = name_comp1,
3704 .vmux = 3,
3705 .amux = LINE1,
3706 .gpio = 0x2000,
3707 },{
3708 .name = name_svideo,
3709 .vmux = 8,
3710 .amux = LINE1,
3711 .gpio = 0x2000,
3712 }},
3713 .mute = {
3714 .name = name_mute,
3715 .amux = LINE2,
3716 .gpio = 0x3000,
3717 },
3718 },
Edgar Simod90d9f52007-08-20 14:14:50 -03003719 [SAA7134_BOARD_AVERMEDIA_SUPER_007] = {
3720 .name = "Avermedia Super 007",
3721 .audio_clock = 0x00187de7,
3722 .tuner_type = TUNER_PHILIPS_TDA8290,
3723 .radio_type = UNSET,
3724 .tuner_addr = ADDR_UNSET,
3725 .radio_addr = ADDR_UNSET,
3726 .tuner_config = 0,
3727 .mpeg = SAA7134_MPEG_DVB,
3728 .inputs = {{
3729 .name = name_tv, /* FIXME: analog tv untested */
3730 .vmux = 1,
3731 .amux = TV,
3732 .tv = 1,
3733 }},
3734 },
Mauro Carvalho Chehab36f6bb92008-06-26 17:03:00 -03003735 [SAA7134_BOARD_AVERMEDIA_M135A] = {
3736 .name = "Avermedia PCI pure analog (M135A)",
3737 .audio_clock = 0x00187de7,
3738 .tuner_type = TUNER_PHILIPS_TDA8290,
3739 .radio_type = UNSET,
3740 .tuner_addr = ADDR_UNSET,
3741 .radio_addr = ADDR_UNSET,
3742 .tuner_config = 2,
3743 .gpiomask = 0x020200000,
3744 .inputs = {{
3745 .name = name_tv,
3746 .vmux = 1,
3747 .amux = TV,
3748 .tv = 1,
3749 }, {
3750 .name = name_comp1,
3751 .vmux = 3,
3752 .amux = LINE1,
3753 }, {
3754 .name = name_svideo,
3755 .vmux = 8,
3756 .amux = LINE1,
3757 } },
3758 .radio = {
3759 .name = name_radio,
3760 .amux = TV,
3761 .gpio = 0x00200000,
3762 },
3763 .mute = {
3764 .name = name_mute,
3765 .amux = TV,
3766 .gpio = 0x01,
3767 },
3768 },
Andrey J. Melnikoff (TEMHOTA)e8018c92008-01-07 05:17:39 -03003769 [SAA7134_BOARD_BEHOLD_401] = {
Dmitry Belimovb34dddb2008-04-23 14:09:08 -03003770 /* Beholder Intl. Ltd. 2008 */
3771 /*Dmitry Belimov <d.belimov@gmail.com> */
Andrey J. Melnikoff (TEMHOTA)e8018c92008-01-07 05:17:39 -03003772 .name = "Beholder BeholdTV 401",
3773 .audio_clock = 0x00187de7,
3774 .tuner_type = TUNER_PHILIPS_FQ1216ME,
3775 .radio_type = UNSET,
3776 .tuner_addr = ADDR_UNSET,
3777 .radio_addr = ADDR_UNSET,
Dmitry Belimovb34dddb2008-04-23 14:09:08 -03003778 .gpiomask = 0x00008000,
Andrey J. Melnikoff (TEMHOTA)e8018c92008-01-07 05:17:39 -03003779 .inputs = {{
3780 .name = name_svideo,
3781 .vmux = 8,
3782 .amux = LINE1,
3783 },{
3784 .name = name_comp1,
3785 .vmux = 1,
3786 .amux = LINE1,
3787 },{
3788 .name = name_tv,
3789 .vmux = 3,
3790 .amux = LINE2,
3791 .tv = 1,
3792 }},
3793 .mute = {
3794 .name = name_mute,
3795 .amux = LINE1,
3796 },
3797 },
3798 [SAA7134_BOARD_BEHOLD_403] = {
Dmitry Belimovb34dddb2008-04-23 14:09:08 -03003799 /* Beholder Intl. Ltd. 2008 */
3800 /*Dmitry Belimov <d.belimov@gmail.com> */
Andrey J. Melnikoff (TEMHOTA)e8018c92008-01-07 05:17:39 -03003801 .name = "Beholder BeholdTV 403",
3802 .audio_clock = 0x00187de7,
3803 .tuner_type = TUNER_PHILIPS_FQ1216ME,
3804 .radio_type = UNSET,
3805 .tuner_addr = ADDR_UNSET,
3806 .radio_addr = ADDR_UNSET,
Dmitry Belimovb34dddb2008-04-23 14:09:08 -03003807 .gpiomask = 0x00008000,
Andrey J. Melnikoff (TEMHOTA)e8018c92008-01-07 05:17:39 -03003808 .inputs = {{
3809 .name = name_svideo,
3810 .vmux = 8,
3811 .amux = LINE1,
3812 },{
3813 .name = name_comp1,
3814 .vmux = 1,
3815 .amux = LINE1,
3816 },{
3817 .name = name_tv,
3818 .vmux = 3,
3819 .amux = LINE2,
3820 .tv = 1,
3821 }},
3822 },
3823 [SAA7134_BOARD_BEHOLD_403FM] = {
Dmitry Belimovb34dddb2008-04-23 14:09:08 -03003824 /* Beholder Intl. Ltd. 2008 */
3825 /*Dmitry Belimov <d.belimov@gmail.com> */
Andrey J. Melnikoff (TEMHOTA)e8018c92008-01-07 05:17:39 -03003826 .name = "Beholder BeholdTV 403 FM",
3827 .audio_clock = 0x00187de7,
3828 .tuner_type = TUNER_PHILIPS_FQ1216ME,
3829 .radio_type = UNSET,
3830 .tuner_addr = ADDR_UNSET,
3831 .radio_addr = ADDR_UNSET,
Dmitry Belimovb34dddb2008-04-23 14:09:08 -03003832 .gpiomask = 0x00008000,
Andrey J. Melnikoff (TEMHOTA)e8018c92008-01-07 05:17:39 -03003833 .inputs = {{
3834 .name = name_svideo,
3835 .vmux = 8,
3836 .amux = LINE1,
3837 },{
3838 .name = name_comp1,
3839 .vmux = 1,
3840 .amux = LINE1,
3841 },{
3842 .name = name_tv,
3843 .vmux = 3,
3844 .amux = LINE2,
3845 .tv = 1,
3846 }},
3847 .radio = {
3848 .name = name_radio,
3849 .amux = LINE2,
3850 },
3851 },
3852 [SAA7134_BOARD_BEHOLD_405] = {
Dmitry Belimovb34dddb2008-04-23 14:09:08 -03003853 /* Beholder Intl. Ltd. 2008 */
3854 /*Dmitry Belimov <d.belimov@gmail.com> */
Andrey J. Melnikoff (TEMHOTA)e8018c92008-01-07 05:17:39 -03003855 .name = "Beholder BeholdTV 405",
3856 .audio_clock = 0x00187de7,
3857 .tuner_type = TUNER_PHILIPS_FM1216ME_MK3,
3858 .radio_type = UNSET,
3859 .tuner_addr = ADDR_UNSET,
3860 .radio_addr = ADDR_UNSET,
3861 .tda9887_conf = TDA9887_PRESENT,
Dmitry Belimovb34dddb2008-04-23 14:09:08 -03003862 .gpiomask = 0x00008000,
Andrey J. Melnikoff (TEMHOTA)e8018c92008-01-07 05:17:39 -03003863 .inputs = {{
3864 .name = name_svideo,
3865 .vmux = 8,
3866 .amux = LINE1,
3867 },{
3868 .name = name_comp1,
3869 .vmux = 3,
3870 .amux = LINE1,
3871 },{
3872 .name = name_tv,
3873 .vmux = 3,
3874 .amux = LINE2,
3875 .tv = 1,
3876 }},
3877 },
3878 [SAA7134_BOARD_BEHOLD_405FM] = {
3879 /* Sergey <skiv@orel.ru> */
Dmitry Belimovb34dddb2008-04-23 14:09:08 -03003880 /* Beholder Intl. Ltd. 2008 */
3881 /*Dmitry Belimov <d.belimov@gmail.com> */
Andrey J. Melnikoff (TEMHOTA)e8018c92008-01-07 05:17:39 -03003882 .name = "Beholder BeholdTV 405 FM",
3883 .audio_clock = 0x00187de7,
3884 .tuner_type = TUNER_PHILIPS_FM1216ME_MK3,
3885 .radio_type = UNSET,
3886 .tuner_addr = ADDR_UNSET,
3887 .radio_addr = ADDR_UNSET,
3888 .tda9887_conf = TDA9887_PRESENT,
Dmitry Belimovb34dddb2008-04-23 14:09:08 -03003889 .gpiomask = 0x00008000,
Andrey J. Melnikoff (TEMHOTA)e8018c92008-01-07 05:17:39 -03003890 .inputs = {{
3891 .name = name_svideo,
3892 .vmux = 8,
3893 .amux = LINE1,
3894 },{
3895 .name = name_comp1,
3896 .vmux = 3,
3897 .amux = LINE1,
3898 },{
3899 .name = name_tv,
3900 .vmux = 3,
3901 .amux = LINE2,
3902 .tv = 1,
3903 }},
3904 .radio = {
3905 .name = name_radio,
3906 .amux = LINE2,
3907 },
3908 },
Mauro Carvalho Chehab1434bc02008-01-07 05:20:04 -03003909 [SAA7134_BOARD_BEHOLD_407] = {
Dmitry Belimovb34dddb2008-04-23 14:09:08 -03003910 /* Beholder Intl. Ltd. 2008 */
3911 /*Dmitry Belimov <d.belimov@gmail.com> */
Mauro Carvalho Chehab1434bc02008-01-07 05:20:04 -03003912 .name = "Beholder BeholdTV 407",
3913 .audio_clock = 0x00187de7,
3914 .tuner_type = TUNER_PHILIPS_FM1216ME_MK3,
3915 .radio_type = UNSET,
3916 .tuner_addr = ADDR_UNSET,
3917 .radio_addr = ADDR_UNSET,
3918 .tda9887_conf = TDA9887_PRESENT,
Dmitry Belimovb34dddb2008-04-23 14:09:08 -03003919 .gpiomask = 0x00008000,
Mauro Carvalho Chehab1434bc02008-01-07 05:20:04 -03003920 .inputs = {{
3921 .name = name_svideo,
3922 .vmux = 8,
3923 .amux = LINE1,
3924 .gpio = 0xc0c000,
3925 },{
3926 .name = name_comp1,
3927 .vmux = 1,
3928 .amux = LINE1,
3929 .gpio = 0xc0c000,
3930 },{
3931 .name = name_tv,
3932 .vmux = 3,
3933 .amux = TV,
3934 .tv = 1,
3935 .gpio = 0xc0c000,
3936 }},
3937 },
Andrey J. Melnikoff (TEMHOTA)e8018c92008-01-07 05:17:39 -03003938 [SAA7134_BOARD_BEHOLD_407FM] = {
Dmitry Belimovb34dddb2008-04-23 14:09:08 -03003939 /* Beholder Intl. Ltd. 2008 */
3940 /*Dmitry Belimov <d.belimov@gmail.com> */
Andrey J. Melnikoff (TEMHOTA)e8018c92008-01-07 05:17:39 -03003941 .name = "Beholder BeholdTV 407 FM",
3942 .audio_clock = 0x00187de7,
3943 .tuner_type = TUNER_PHILIPS_FM1216ME_MK3,
3944 .radio_type = UNSET,
3945 .tuner_addr = ADDR_UNSET,
3946 .radio_addr = ADDR_UNSET,
3947 .tda9887_conf = TDA9887_PRESENT,
Dmitry Belimovb34dddb2008-04-23 14:09:08 -03003948 .gpiomask = 0x00008000,
Andrey J. Melnikoff (TEMHOTA)e8018c92008-01-07 05:17:39 -03003949 .inputs = {{
3950 .name = name_svideo,
3951 .vmux = 8,
3952 .amux = LINE1,
3953 .gpio = 0xc0c000,
3954 },{
3955 .name = name_comp1,
3956 .vmux = 1,
3957 .amux = LINE1,
3958 .gpio = 0xc0c000,
3959 },{
3960 .name = name_tv,
3961 .vmux = 3,
3962 .amux = TV,
3963 .tv = 1,
3964 .gpio = 0xc0c000,
3965 }},
3966 .radio = {
3967 .name = name_radio,
3968 .amux = LINE2,
3969 .gpio = 0xc0c000,
3970 },
3971 },
3972 [SAA7134_BOARD_BEHOLD_409] = {
Dmitry Belimovb34dddb2008-04-23 14:09:08 -03003973 /* Beholder Intl. Ltd. 2008 */
3974 /*Dmitry Belimov <d.belimov@gmail.com> */
Andrey J. Melnikoff (TEMHOTA)e8018c92008-01-07 05:17:39 -03003975 .name = "Beholder BeholdTV 409",
3976 .audio_clock = 0x00187de7,
3977 .tuner_type = TUNER_PHILIPS_FM1216ME_MK3,
3978 .radio_type = UNSET,
3979 .tuner_addr = ADDR_UNSET,
3980 .radio_addr = ADDR_UNSET,
3981 .tda9887_conf = TDA9887_PRESENT,
Dmitry Belimovb34dddb2008-04-23 14:09:08 -03003982 .gpiomask = 0x00008000,
Andrey J. Melnikoff (TEMHOTA)e8018c92008-01-07 05:17:39 -03003983 .inputs = {{
3984 .name = name_tv,
3985 .vmux = 3,
3986 .amux = TV,
3987 .tv = 1,
3988 },{
3989 .name = name_comp1,
3990 .vmux = 1,
3991 .amux = LINE1,
3992 },{
3993 .name = name_svideo,
3994 .vmux = 8,
3995 .amux = LINE1,
3996 }},
3997 },
3998 [SAA7134_BOARD_BEHOLD_505FM] = {
Dmitry Belimovb34dddb2008-04-23 14:09:08 -03003999 /* Beholder Intl. Ltd. 2008 */
4000 /*Dmitry Belimov <d.belimov@gmail.com> */
Andrey J. Melnikoff (TEMHOTA)e8018c92008-01-07 05:17:39 -03004001 .name = "Beholder BeholdTV 505 FM/RDS",
4002 .audio_clock = 0x00200000,
4003 .tuner_type = TUNER_PHILIPS_FM1216ME_MK3,
4004 .radio_type = UNSET,
4005 .tuner_addr = ADDR_UNSET,
4006 .radio_addr = ADDR_UNSET,
4007 .tda9887_conf = TDA9887_PRESENT,
Dmitry Belimovb34dddb2008-04-23 14:09:08 -03004008 .gpiomask = 0x00008000,
Andrey J. Melnikoff (TEMHOTA)e8018c92008-01-07 05:17:39 -03004009 .inputs = {{
4010 .name = name_tv,
4011 .vmux = 3,
4012 .amux = LINE2,
4013 .tv = 1,
4014 },{
4015 .name = name_comp1,
4016 .vmux = 1,
4017 .amux = LINE1,
4018 },{
4019 .name = name_svideo,
4020 .vmux = 8,
4021 .amux = LINE1,
4022 }},
4023 .mute = {
4024 .name = name_mute,
4025 .amux = LINE1,
4026 },
4027 .radio = {
4028 .name = name_radio,
4029 .amux = LINE2,
4030 },
4031 },
4032 [SAA7134_BOARD_BEHOLD_507_9FM] = {
Dmitry Belimovb34dddb2008-04-23 14:09:08 -03004033 /* Beholder Intl. Ltd. 2008 */
4034 /*Dmitry Belimov <d.belimov@gmail.com> */
Andrey J. Melnikoff (TEMHOTA)e8018c92008-01-07 05:17:39 -03004035 .name = "Beholder BeholdTV 507 FM/RDS / BeholdTV 509 FM",
4036 .audio_clock = 0x00187de7,
4037 .tuner_type = TUNER_PHILIPS_FM1216ME_MK3,
4038 .radio_type = UNSET,
4039 .tuner_addr = ADDR_UNSET,
4040 .radio_addr = ADDR_UNSET,
4041 .tda9887_conf = TDA9887_PRESENT,
Dmitry Belimovb34dddb2008-04-23 14:09:08 -03004042 .gpiomask = 0x00008000,
Andrey J. Melnikoff (TEMHOTA)e8018c92008-01-07 05:17:39 -03004043 .inputs = {{
4044 .name = name_tv,
4045 .vmux = 3,
4046 .amux = TV,
4047 .tv = 1,
4048 },{
4049 .name = name_comp1,
4050 .vmux = 1,
4051 .amux = LINE1,
4052 },{
4053 .name = name_svideo,
4054 .vmux = 8,
4055 .amux = LINE1,
4056 }},
4057 .radio = {
4058 .name = name_radio,
4059 .amux = LINE2,
4060 },
4061 },
4062 [SAA7134_BOARD_BEHOLD_COLUMBUS_TVFM] = {
Dmitry Belimovb34dddb2008-04-23 14:09:08 -03004063 /* Beholder Intl. Ltd. 2008 */
4064 /*Dmitry Belimov <d.belimov@gmail.com> */
Andrey J. Melnikoff (TEMHOTA)e8018c92008-01-07 05:17:39 -03004065 .name = "Beholder BeholdTV Columbus TVFM",
4066 .audio_clock = 0x00187de7,
4067 .tuner_type = TUNER_ALPS_TSBE5_PAL,
4068 .radio_type = UNSET,
4069 .tuner_addr = ADDR_UNSET,
4070 .radio_addr = ADDR_UNSET,
4071 .tda9887_conf = TDA9887_PRESENT,
Dmitry Belimovb34dddb2008-04-23 14:09:08 -03004072 .gpiomask = 0x000A8004,
Andrey J. Melnikoff (TEMHOTA)e8018c92008-01-07 05:17:39 -03004073 .inputs = {{
4074 .name = name_tv,
4075 .vmux = 3,
4076 .amux = TV,
4077 .tv = 1,
Dmitry Belimovb34dddb2008-04-23 14:09:08 -03004078 .gpio = 0x000A8004,
4079 }, {
Andrey J. Melnikoff (TEMHOTA)e8018c92008-01-07 05:17:39 -03004080 .name = name_comp1,
4081 .vmux = 1,
4082 .amux = LINE1,
Dmitry Belimovb34dddb2008-04-23 14:09:08 -03004083 .gpio = 0x000A8000,
4084 }, {
Andrey J. Melnikoff (TEMHOTA)e8018c92008-01-07 05:17:39 -03004085 .name = name_svideo,
4086 .vmux = 8,
4087 .amux = LINE1,
Dmitry Belimovb34dddb2008-04-23 14:09:08 -03004088 .gpio = 0x000A8000,
4089 } },
Andrey J. Melnikoff (TEMHOTA)e8018c92008-01-07 05:17:39 -03004090 .radio = {
4091 .name = name_radio,
4092 .amux = LINE2,
Dmitry Belimovb34dddb2008-04-23 14:09:08 -03004093 .gpio = 0x000A8000,
Andrey J. Melnikoff (TEMHOTA)e8018c92008-01-07 05:17:39 -03004094 },
4095 },
4096 [SAA7134_BOARD_BEHOLD_607_9FM] = {
4097 /* Andrey Melnikoff <temnota@kmv.ru> */
4098 .name = "Beholder BeholdTV 607 / BeholdTV 609",
4099 .audio_clock = 0x00187de7,
4100 .tuner_type = TUNER_PHILIPS_FM1216ME_MK3,
4101 .radio_type = UNSET,
4102 .tuner_addr = ADDR_UNSET,
4103 .radio_addr = ADDR_UNSET,
4104 .tda9887_conf = TDA9887_PRESENT,
4105 .inputs = {{
4106 .name = name_tv,
4107 .vmux = 3,
4108 .amux = TV,
4109 .tv = 1,
4110 },{
4111 .name = name_comp1,
4112 .vmux = 1,
4113 .amux = LINE1,
4114 },{
4115 .name = name_svideo,
4116 .vmux = 8,
4117 .amux = LINE1,
4118 }},
4119 .radio = {
4120 .name = name_radio,
4121 .amux = LINE2,
4122 },
4123 },
4124 [SAA7134_BOARD_BEHOLD_M6] = {
4125 /* Igor Kuznetsov <igk@igk.ru> */
4126 /* Andrey Melnikoff <temnota@kmv.ru> */
Dmitry Belimov878cf2a2008-06-10 14:22:00 -03004127 /* Beholder Intl. Ltd. Dmitry Belimov <d.belimov@gmail.com> */
4128 .name = "Beholder BeholdTV M6",
Andrey J. Melnikoff (TEMHOTA)e8018c92008-01-07 05:17:39 -03004129 .audio_clock = 0x00187de7,
4130 .tuner_type = TUNER_PHILIPS_FM1216ME_MK3,
4131 .radio_type = UNSET,
4132 .tuner_addr = ADDR_UNSET,
4133 .radio_addr = ADDR_UNSET,
4134 .tda9887_conf = TDA9887_PRESENT,
Dmitry Belimov878cf2a2008-06-10 14:22:00 -03004135 .inputs = { {
Andrey J. Melnikoff (TEMHOTA)e8018c92008-01-07 05:17:39 -03004136 .name = name_tv,
4137 .vmux = 3,
4138 .amux = TV,
4139 .tv = 1,
Dmitry Belimov878cf2a2008-06-10 14:22:00 -03004140 }, {
Andrey J. Melnikoff (TEMHOTA)e8018c92008-01-07 05:17:39 -03004141 .name = name_comp1,
4142 .vmux = 1,
4143 .amux = LINE1,
Dmitry Belimov878cf2a2008-06-10 14:22:00 -03004144 }, {
Andrey J. Melnikoff (TEMHOTA)e8018c92008-01-07 05:17:39 -03004145 .name = name_svideo,
4146 .vmux = 8,
4147 .amux = LINE1,
Dmitry Belimov878cf2a2008-06-10 14:22:00 -03004148 } },
Andrey J. Melnikoff (TEMHOTA)e8018c92008-01-07 05:17:39 -03004149 .radio = {
4150 .name = name_radio,
4151 .amux = LINE2,
4152 },
4153 .mpeg = SAA7134_MPEG_EMPRESS,
Dmitry Belimov878cf2a2008-06-10 14:22:00 -03004154 .video_out = CCIR656,
4155 .vid_port_opts = (SET_T_CODE_POLARITY_NON_INVERTED |
4156 SET_CLOCK_NOT_DELAYED |
4157 SET_CLOCK_INVERTED |
4158 SET_VSYNC_OFF),
4159 },
4160 [SAA7134_BOARD_BEHOLD_M63] = {
4161 /* Igor Kuznetsov <igk@igk.ru> */
4162 /* Andrey Melnikoff <temnota@kmv.ru> */
4163 /* Beholder Intl. Ltd. Dmitry Belimov <d.belimov@gmail.com> */
4164 .name = "Beholder BeholdTV M63",
4165 .audio_clock = 0x00187de7,
4166 .tuner_type = TUNER_PHILIPS_FM1216ME_MK3,
4167 .radio_type = UNSET,
4168 .tuner_addr = ADDR_UNSET,
4169 .radio_addr = ADDR_UNSET,
4170 .tda9887_conf = TDA9887_PRESENT,
4171 .inputs = { {
4172 .name = name_tv,
4173 .vmux = 3,
4174 .amux = TV,
4175 .tv = 1,
4176 }, {
4177 .name = name_comp1,
4178 .vmux = 1,
4179 .amux = LINE1,
4180 }, {
4181 .name = name_svideo,
4182 .vmux = 8,
4183 .amux = LINE1,
4184 } },
4185 .radio = {
4186 .name = name_radio,
4187 .amux = LINE2,
4188 },
4189 .mpeg = SAA7134_MPEG_EMPRESS,
4190 .video_out = CCIR656,
4191 .vid_port_opts = (SET_T_CODE_POLARITY_NON_INVERTED |
4192 SET_CLOCK_NOT_DELAYED |
4193 SET_CLOCK_INVERTED |
4194 SET_VSYNC_OFF),
4195 },
4196 [SAA7134_BOARD_BEHOLD_M6_EXTRA] = {
4197 /* Igor Kuznetsov <igk@igk.ru> */
4198 /* Andrey Melnikoff <temnota@kmv.ru> */
4199 /* Beholder Intl. Ltd. Dmitry Belimov <d.belimov@gmail.com> */
4200 .name = "Beholder BeholdTV M6 Extra",
4201 .audio_clock = 0x00187de7,
4202 /* FIXME: Must be PHILIPS_FM1216ME_MK5*/
4203 .tuner_type = TUNER_PHILIPS_FM1216ME_MK3,
4204 .radio_type = UNSET,
4205 .tuner_addr = ADDR_UNSET,
4206 .radio_addr = ADDR_UNSET,
4207 .tda9887_conf = TDA9887_PRESENT,
4208 .inputs = { {
4209 .name = name_tv,
4210 .vmux = 3,
4211 .amux = TV,
4212 .tv = 1,
4213 }, {
4214 .name = name_comp1,
4215 .vmux = 1,
4216 .amux = LINE1,
4217 }, {
4218 .name = name_svideo,
4219 .vmux = 8,
4220 .amux = LINE1,
4221 } },
4222 .radio = {
4223 .name = name_radio,
4224 .amux = LINE2,
4225 },
4226 .mpeg = SAA7134_MPEG_EMPRESS,
4227 .video_out = CCIR656,
4228 .vid_port_opts = (SET_T_CODE_POLARITY_NON_INVERTED |
4229 SET_CLOCK_NOT_DELAYED |
4230 SET_CLOCK_INVERTED |
4231 SET_VSYNC_OFF),
Andrey J. Melnikoff (TEMHOTA)e8018c92008-01-07 05:17:39 -03004232 },
Hermann Pitton4ba24372008-01-20 19:27:51 -03004233 [SAA7134_BOARD_TWINHAN_DTV_DVB_3056] = {
4234 .name = "Twinhan Hybrid DTV-DVB 3056 PCI",
4235 .audio_clock = 0x00187de7,
4236 .tuner_type = TUNER_PHILIPS_TDA8290,
4237 .radio_type = UNSET,
4238 .tuner_addr = ADDR_UNSET,
4239 .radio_addr = ADDR_UNSET,
4240 .tuner_config = 2,
4241 .mpeg = SAA7134_MPEG_DVB,
4242 .gpiomask = 0x0200000,
4243 .inputs = {{
4244 .name = name_tv,
4245 .vmux = 1,
4246 .amux = TV,
4247 .tv = 1,
4248 }, {
4249 .name = name_comp1,
4250 .vmux = 3,
4251 .amux = LINE1,
4252 }, {
4253 .name = name_svideo,
4254 .vmux = 8, /* untested */
4255 .amux = LINE1,
4256 } },
4257 .radio = {
4258 .name = name_radio,
4259 .amux = TV,
4260 .gpio = 0x0200000,
4261 },
4262 },
Adrian Pardinif0ba3562008-02-11 12:40:53 -03004263 [SAA7134_BOARD_GENIUS_TVGO_A11MCE] = {
4264 /* Adrian Pardini <pardo.bsso@gmail.com> */
4265 .name = "Genius TVGO AM11MCE",
4266 .audio_clock = 0x00200000,
4267 .tuner_type = TUNER_TNF_5335MF,
4268 .radio_type = UNSET,
4269 .tuner_addr = ADDR_UNSET,
4270 .radio_addr = ADDR_UNSET,
4271 .gpiomask = 0xf000,
4272 .inputs = {{
4273 .name = name_tv_mono,
4274 .vmux = 1,
4275 .amux = LINE2,
4276 .gpio = 0x0000,
4277 .tv = 1,
4278 }, {
4279 .name = name_comp1,
4280 .vmux = 3,
4281 .amux = LINE1,
4282 .gpio = 0x2000,
4283 .tv = 1
4284 }, {
4285 .name = name_svideo,
4286 .vmux = 8,
4287 .amux = LINE1,
4288 .gpio = 0x2000,
4289 } },
4290 .radio = {
4291 .name = name_radio,
4292 .amux = LINE2,
4293 .gpio = 0x1000,
4294 },
4295 .mute = {
4296 .name = name_mute,
4297 .amux = LINE2,
4298 .gpio = 0x6000,
4299 },
4300 },
Hartmut Hackmann6ab465a2008-04-22 14:42:11 -03004301 [SAA7134_BOARD_PHILIPS_SNAKE] = {
4302 .name = "NXP Snake DVB-S reference design",
4303 .audio_clock = 0x00200000,
4304 .tuner_type = TUNER_ABSENT,
4305 .radio_type = UNSET,
4306 .tuner_addr = ADDR_UNSET,
4307 .radio_addr = ADDR_UNSET,
4308 .mpeg = SAA7134_MPEG_DVB,
4309 .inputs = {{
4310 .name = name_comp1,
4311 .vmux = 3,
4312 .amux = LINE1,
4313 }, {
4314 .name = name_svideo,
4315 .vmux = 8,
4316 .amux = LINE1,
4317 } },
4318 },
Hermann Pitton7b5b3f12008-04-22 14:42:12 -03004319 [SAA7134_BOARD_CREATIX_CTX953] = {
4320 .name = "Medion/Creatix CTX953 Hybrid",
4321 .audio_clock = 0x00187de7,
4322 .tuner_type = TUNER_PHILIPS_TDA8290,
4323 .radio_type = UNSET,
4324 .tuner_addr = ADDR_UNSET,
4325 .radio_addr = ADDR_UNSET,
4326 .tuner_config = 0,
4327 .mpeg = SAA7134_MPEG_DVB,
4328 .inputs = {{
4329 .name = name_tv,
4330 .vmux = 1,
4331 .amux = TV,
4332 .tv = 1,
4333 }, {
4334 .name = name_comp1,
4335 .vmux = 0,
4336 .amux = LINE1,
4337 }, {
4338 .name = name_svideo,
4339 .vmux = 8,
4340 .amux = LINE1,
4341 } },
4342 },
Russell Kliese6a6179b62008-04-22 14:42:12 -03004343 [SAA7134_BOARD_MSI_TVANYWHERE_AD11] = {
4344 .name = "MSI TV@nywhere A/D v1.1",
4345 .audio_clock = 0x00187de7,
4346 .tuner_type = TUNER_PHILIPS_TDA8290,
4347 .radio_type = UNSET,
4348 .tuner_addr = ADDR_UNSET,
4349 .radio_addr = ADDR_UNSET,
4350 .tuner_config = 2,
4351 .mpeg = SAA7134_MPEG_DVB,
4352 .gpiomask = 0x0200000,
4353 .inputs = { {
4354 .name = name_tv,
4355 .vmux = 1,
4356 .amux = TV,
4357 .tv = 1,
4358 }, {
4359 .name = name_comp1,
4360 .vmux = 3,
4361 .amux = LINE1,
4362 }, {
4363 .name = name_svideo,
4364 .vmux = 8,
4365 .amux = LINE1,
4366 } },
4367 .radio = {
4368 .name = name_radio,
4369 .amux = TV,
4370 .gpio = 0x0200000,
4371 },
4372 },
Mauro Carvalho Chehabbc36a682008-04-22 14:45:27 -03004373 [SAA7134_BOARD_AVERMEDIA_CARDBUS_506] = {
Mauro Carvalho Chehabd9ae6dd2008-04-22 14:46:06 -03004374 .name = "AVerMedia Cardbus TV/Radio (E506R)",
4375 .audio_clock = 0x187de7,
4376 .tuner_type = TUNER_XC2028,
Mauro Carvalho Chehab6e741712008-04-22 14:46:07 -03004377 .radio_type = UNSET,
Mauro Carvalho Chehabd9ae6dd2008-04-22 14:46:06 -03004378 .tuner_addr = ADDR_UNSET,
4379 .radio_addr = ADDR_UNSET,
Mauro Carvalho Chehabbc36a682008-04-22 14:45:27 -03004380 .mpeg = SAA7134_MPEG_DVB,
Mauro Carvalho Chehabbc36a682008-04-22 14:45:27 -03004381 .inputs = {{
4382 .name = name_tv,
4383 .vmux = 1,
4384 .amux = TV,
4385 .tv = 1,
4386 }, {
Tim Farrington31489362009-01-15 09:58:55 -03004387 .name = name_comp1,
4388 .vmux = 3,
Tim Farringtone5e4cd82008-06-29 11:54:08 -03004389 .amux = LINE1,
Mauro Carvalho Chehabbc36a682008-04-22 14:45:27 -03004390 }, {
4391 .name = name_svideo,
4392 .vmux = 8,
Tim Farrington31489362009-01-15 09:58:55 -03004393 .amux = LINE2,
Mauro Carvalho Chehabbc36a682008-04-22 14:45:27 -03004394 } },
4395 .radio = {
4396 .name = name_radio,
4397 .amux = TV,
4398 },
4399 },
4400 [SAA7134_BOARD_AVERMEDIA_A16D] = {
4401 .name = "AVerMedia Hybrid TV/Radio (A16D)",
4402 .audio_clock = 0x187de7,
4403 .tuner_type = TUNER_XC2028,
Mauro Carvalho Chehab6e741712008-04-22 14:46:07 -03004404 .radio_type = UNSET,
Mauro Carvalho Chehabd9ae6dd2008-04-22 14:46:06 -03004405 .tuner_addr = ADDR_UNSET,
4406 .radio_addr = ADDR_UNSET,
Hans Verkuilf87086e2008-07-18 00:50:58 -03004407 .mpeg = SAA7134_MPEG_DVB,
Mauro Carvalho Chehabbc36a682008-04-22 14:45:27 -03004408 .inputs = {{
4409 .name = name_tv,
4410 .vmux = 1,
4411 .amux = TV,
4412 .tv = 1,
4413 }, {
4414 .name = name_svideo,
4415 .vmux = 8,
4416 .amux = LINE1,
Dan Taylor9c7ecaf2008-06-27 13:29:41 -03004417 }, {
4418 .name = name_comp,
4419 .vmux = 0,
4420 .amux = LINE1,
Mauro Carvalho Chehabbc36a682008-04-22 14:45:27 -03004421 } },
4422 .radio = {
4423 .name = name_radio,
Tim Farrington6e501a32008-06-15 13:33:42 -03004424 .amux = TV,
Mauro Carvalho Chehabbc36a682008-04-22 14:45:27 -03004425 },
4426 },
4427 [SAA7134_BOARD_AVERMEDIA_M115] = {
4428 .name = "Avermedia M115",
4429 .audio_clock = 0x187de7,
4430 .tuner_type = TUNER_XC2028,
Mauro Carvalho Chehab6e741712008-04-22 14:46:07 -03004431 .radio_type = UNSET,
Mauro Carvalho Chehabd9ae6dd2008-04-22 14:46:06 -03004432 .tuner_addr = ADDR_UNSET,
4433 .radio_addr = ADDR_UNSET,
Mauro Carvalho Chehabbc36a682008-04-22 14:45:27 -03004434 .inputs = {{
4435 .name = name_tv,
4436 .vmux = 1,
4437 .amux = TV,
4438 .tv = 1,
4439 }, {
4440 .name = name_comp1,
4441 .vmux = 3,
4442 .amux = LINE1,
4443 }, {
4444 .name = name_svideo,
4445 .vmux = 8,
4446 .amux = LINE2,
4447 } },
4448 },
4449 [SAA7134_BOARD_VIDEOMATE_T750] = {
4450 /* John Newbigin <jn@it.swin.edu.au> */
4451 .name = "Compro VideoMate T750",
4452 .audio_clock = 0x00187de7,
4453 .tuner_type = TUNER_XC2028,
Mauro Carvalho Chehab6e741712008-04-22 14:46:07 -03004454 .radio_type = UNSET,
Mauro Carvalho Chehabd9ae6dd2008-04-22 14:46:06 -03004455 .tuner_addr = ADDR_UNSET,
4456 .radio_addr = ADDR_UNSET,
Mauro Carvalho Chehabbc36a682008-04-22 14:45:27 -03004457 .mpeg = SAA7134_MPEG_DVB,
4458 .inputs = {{
4459 .name = name_tv,
4460 .vmux = 3,
4461 .amux = TV,
4462 .tv = 1,
4463 }, {
4464 .name = name_comp1,
4465 .vmux = 1,
4466 .amux = LINE2,
4467 }, {
4468 .name = name_svideo,
4469 .vmux = 8,
4470 .amux = LINE2,
4471 } },
4472 .radio = {
4473 .name = name_radio,
4474 .amux = TV,
4475 }
Matthias Schwarzottfc9d8ed2008-04-08 21:45:08 -03004476 },
4477 [SAA7134_BOARD_AVERMEDIA_A700_PRO] = {
4478 /* Matthias Schwarzott <zzam@gentoo.org> */
4479 .name = "Avermedia DVB-S Pro A700",
4480 .audio_clock = 0x00187de7,
4481 .tuner_type = TUNER_ABSENT,
4482 .radio_type = UNSET,
4483 .tuner_addr = ADDR_UNSET,
4484 .radio_addr = ADDR_UNSET,
Matthias Schwarzott04574182009-02-24 12:35:16 -03004485 .mpeg = SAA7134_MPEG_DVB,
Matthias Schwarzottfc9d8ed2008-04-08 21:45:08 -03004486 .inputs = { {
4487 .name = name_comp,
4488 .vmux = 1,
4489 .amux = LINE1,
4490 }, {
4491 .name = name_svideo,
4492 .vmux = 6,
4493 .amux = LINE1,
4494 } },
4495 },
4496 [SAA7134_BOARD_AVERMEDIA_A700_HYBRID] = {
4497 /* Matthias Schwarzott <zzam@gentoo.org> */
4498 .name = "Avermedia DVB-S Hybrid+FM A700",
4499 .audio_clock = 0x00187de7,
4500 .tuner_type = TUNER_ABSENT, /* TUNER_XC2028 */
4501 .radio_type = UNSET,
4502 .tuner_addr = ADDR_UNSET,
4503 .radio_addr = ADDR_UNSET,
Matthias Schwarzott04574182009-02-24 12:35:16 -03004504 .mpeg = SAA7134_MPEG_DVB,
Matthias Schwarzottfc9d8ed2008-04-08 21:45:08 -03004505 .inputs = { {
4506 .name = name_comp,
4507 .vmux = 1,
4508 .amux = LINE1,
4509 }, {
4510 .name = name_svideo,
4511 .vmux = 6,
4512 .amux = LINE1,
4513 } },
4514 },
Igor Kuznetsov02505272008-04-26 14:53:48 -03004515 [SAA7134_BOARD_BEHOLD_H6] = {
4516 /* Igor Kuznetsov <igk@igk.ru> */
4517 .name = "Beholder BeholdTV H6",
4518 .audio_clock = 0x00187de7,
4519 .tuner_type = TUNER_PHILIPS_FMD1216ME_MK3,
4520 .radio_type = UNSET,
4521 .tuner_addr = ADDR_UNSET,
4522 .radio_addr = ADDR_UNSET,
4523 .tda9887_conf = TDA9887_PRESENT,
Dmitri Belimovf204ae42008-12-23 03:51:38 -03004524 .mpeg = SAA7134_MPEG_DVB,
Igor Kuznetsov02505272008-04-26 14:53:48 -03004525 .inputs = {{
4526 .name = name_tv,
4527 .vmux = 3,
4528 .amux = TV,
4529 .tv = 1,
4530 }, {
4531 .name = name_comp1,
4532 .vmux = 1,
4533 .amux = LINE1,
4534 }, {
4535 .name = name_svideo,
4536 .vmux = 8,
4537 .amux = LINE1,
4538 } },
4539 .radio = {
4540 .name = name_radio,
4541 .amux = LINE2,
4542 },
Igor Kuznetsov02505272008-04-26 14:53:48 -03004543 },
hermann pitton301e9d62008-09-14 17:49:14 -03004544 [SAA7134_BOARD_ASUSTeK_TIGER_3IN1] = {
4545 .name = "Asus Tiger 3in1",
4546 .audio_clock = 0x00187de7,
4547 .tuner_type = TUNER_PHILIPS_TDA8290,
4548 .radio_type = UNSET,
4549 .tuner_addr = ADDR_UNSET,
4550 .radio_addr = ADDR_UNSET,
4551 .tuner_config = 2,
4552 .gpiomask = 1 << 21,
4553 .mpeg = SAA7134_MPEG_DVB,
4554 .inputs = {{
4555 .name = name_tv,
4556 .vmux = 1,
4557 .amux = TV,
4558 .tv = 1,
4559 }, {
4560 .name = name_comp,
4561 .vmux = 0,
4562 .amux = LINE2,
4563 }, {
4564 .name = name_svideo,
4565 .vmux = 8,
4566 .amux = LINE2,
4567 } },
4568 .radio = {
4569 .name = name_radio,
4570 .amux = TV,
4571 .gpio = 0x0200000,
4572 },
4573 },
Mauro Carvalho Chehab9b000192008-06-26 17:03:00 -03004574 [SAA7134_BOARD_REAL_ANGEL_220] = {
4575 .name = "Zogis Real Angel 220",
4576 .audio_clock = 0x00187de7,
4577 .tuner_type = TUNER_TNF_5335MF,
4578 .radio_type = UNSET,
4579 .tuner_addr = ADDR_UNSET,
4580 .radio_addr = ADDR_UNSET,
4581 .gpiomask = 0x801a8087,
4582 .inputs = { {
4583 .name = name_tv,
4584 .vmux = 3,
4585 .amux = LINE2,
4586 .tv = 1,
4587 .gpio = 0x624000,
Hermann Pitton028165a2008-10-04 21:37:36 -03004588 }, {
Mauro Carvalho Chehab9b000192008-06-26 17:03:00 -03004589 .name = name_comp1,
4590 .vmux = 1,
4591 .amux = LINE1,
4592 .gpio = 0x624000,
4593 }, {
4594 .name = name_svideo,
4595 .vmux = 1,
4596 .amux = LINE1,
4597 .gpio = 0x624000,
4598 } },
4599 .radio = {
4600 .name = name_radio,
4601 .amux = LINE2,
4602 .gpio = 0x624001,
4603 },
4604 .mute = {
4605 .name = name_mute,
4606 .amux = TV,
4607 },
4608 },
Adam Gloverf689d902008-05-06 03:20:27 -03004609 [SAA7134_BOARD_ADS_INSTANT_HDTV_PCI] = {
4610 .name = "ADS Tech Instant HDTV",
4611 .audio_clock = 0x00187de7,
4612 .tuner_type = TUNER_PHILIPS_TUV1236D,
4613 .radio_type = UNSET,
4614 .tuner_addr = ADDR_UNSET,
4615 .radio_addr = ADDR_UNSET,
4616 .tda9887_conf = TDA9887_PRESENT,
4617 .mpeg = SAA7134_MPEG_DVB,
4618 .inputs = { {
4619 .name = name_tv,
4620 .vmux = 1,
4621 .amux = TV,
4622 .tv = 1,
4623 }, {
4624 .name = name_comp,
Hermann Pitton028165a2008-10-04 21:37:36 -03004625 .vmux = 4,
4626 .amux = LINE1,
Adam Gloverf689d902008-05-06 03:20:27 -03004627 }, {
4628 .name = name_svideo,
4629 .vmux = 8,
4630 .amux = LINE1,
4631 } },
4632 },
Hermann Pitton028165a2008-10-04 21:37:36 -03004633 [SAA7134_BOARD_ASUSTeK_TIGER] = {
4634 .name = "Asus Tiger Rev:1.00",
4635 .audio_clock = 0x00187de7,
4636 .tuner_type = TUNER_PHILIPS_TDA8290,
4637 .radio_type = UNSET,
4638 .tuner_addr = ADDR_UNSET,
4639 .radio_addr = ADDR_UNSET,
4640 .tuner_config = 0,
4641 .mpeg = SAA7134_MPEG_DVB,
4642 .gpiomask = 0x0200000,
4643 .inputs = { {
4644 .name = name_tv,
4645 .vmux = 1,
4646 .amux = TV,
4647 .tv = 1,
4648 }, {
4649 .name = name_comp1,
4650 .vmux = 3,
4651 .amux = LINE2,
4652 }, {
4653 .name = name_comp2,
4654 .vmux = 0,
4655 .amux = LINE2,
4656 }, {
4657 .name = name_svideo,
4658 .vmux = 8,
4659 .amux = LINE2,
4660 } },
4661 .radio = {
4662 .name = name_radio,
4663 .amux = TV,
4664 .gpio = 0x0200000,
4665 },
4666 },
Mauro Carvalho Chehab26d5f3a2008-12-07 13:19:29 -03004667 [SAA7134_BOARD_KWORLD_PLUS_TV_ANALOG] = {
4668 .name = "Kworld Plus TV Analog Lite PCI",
4669 .audio_clock = 0x00187de7,
4670 .tuner_type = TUNER_YMEC_TVF_5533MF,
4671 .radio_type = TUNER_TEA5767,
4672 .tuner_addr = ADDR_UNSET,
Hans Verkuilfac69862009-01-17 12:17:14 -03004673 .radio_addr = 0x60,
Mauro Carvalho Chehab26d5f3a2008-12-07 13:19:29 -03004674 .gpiomask = 0x80000700,
4675 .inputs = { {
4676 .name = name_tv,
4677 .vmux = 1,
4678 .amux = LINE2,
4679 .tv = 1,
4680 .gpio = 0x100,
4681 }, {
4682 .name = name_comp1,
4683 .vmux = 3,
4684 .amux = LINE1,
4685 .gpio = 0x200,
4686 }, {
4687 .name = name_svideo,
4688 .vmux = 8,
4689 .amux = LINE1,
4690 .gpio = 0x200,
4691 } },
4692 .radio = {
4693 .name = name_radio,
4694 .vmux = 1,
4695 .amux = LINE1,
4696 .gpio = 0x100,
4697 },
4698 .mute = {
4699 .name = name_mute,
4700 .vmux = 8,
4701 .amux = 2,
4702 },
4703 },
Pham Thanh Nam6a2d8022008-12-30 23:26:09 -03004704 [SAA7134_BOARD_AVERMEDIA_GO_007_FM_PLUS] = {
4705 .name = "Avermedia AVerTV GO 007 FM Plus",
4706 .audio_clock = 0x00187de7,
4707 .tuner_type = TUNER_PHILIPS_TDA8290,
4708 .radio_type = UNSET,
4709 .tuner_addr = ADDR_UNSET,
4710 .radio_addr = ADDR_UNSET,
4711 .gpiomask = 0x00300003,
4712 /* .gpiomask = 0x8c240003, */
4713 .inputs = { {
4714 .name = name_tv,
4715 .vmux = 1,
4716 .amux = TV,
4717 .tv = 1,
4718 .gpio = 0x01,
4719 }, {
4720 .name = name_svideo,
4721 .vmux = 6,
4722 .amux = LINE1,
4723 .gpio = 0x02,
4724 } },
4725 .radio = {
4726 .name = name_radio,
4727 .amux = TV,
4728 .gpio = 0x00300001,
4729 },
4730 .mute = {
4731 .name = name_mute,
4732 .amux = TV,
4733 .gpio = 0x01,
4734 },
4735 },
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07004736};
4737
Linus Torvalds1da177e2005-04-16 15:20:36 -07004738const unsigned int saa7134_bcount = ARRAY_SIZE(saa7134_boards);
4739
4740/* ------------------------------------------------------------------ */
4741/* PCI ids + subsystem IDs */
4742
4743struct pci_device_id saa7134_pci_tbl[] = {
4744 {
4745 .vendor = PCI_VENDOR_ID_PHILIPS,
4746 .device = PCI_DEVICE_ID_PHILIPS_SAA7134,
4747 .subvendor = PCI_VENDOR_ID_PHILIPS,
4748 .subdevice = 0x2001,
4749 .driver_data = SAA7134_BOARD_PROTEUS_PRO,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07004750 },{
Linus Torvalds1da177e2005-04-16 15:20:36 -07004751 .vendor = PCI_VENDOR_ID_PHILIPS,
4752 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
4753 .subvendor = PCI_VENDOR_ID_PHILIPS,
4754 .subdevice = 0x2001,
4755 .driver_data = SAA7134_BOARD_PROTEUS_PRO,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07004756 },{
Linus Torvalds1da177e2005-04-16 15:20:36 -07004757 .vendor = PCI_VENDOR_ID_PHILIPS,
4758 .device = PCI_DEVICE_ID_PHILIPS_SAA7134,
4759 .subvendor = PCI_VENDOR_ID_PHILIPS,
4760 .subdevice = 0x6752,
4761 .driver_data = SAA7134_BOARD_EMPRESS,
4762 },{
4763 .vendor = PCI_VENDOR_ID_PHILIPS,
4764 .device = PCI_DEVICE_ID_PHILIPS_SAA7134,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07004765 .subvendor = 0x1131,
4766 .subdevice = 0x4e85,
Linus Torvalds1da177e2005-04-16 15:20:36 -07004767 .driver_data = SAA7134_BOARD_MONSTERTV,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07004768 },{
4769 .vendor = PCI_VENDOR_ID_PHILIPS,
4770 .device = PCI_DEVICE_ID_PHILIPS_SAA7134,
Michael Krufky7df64e82005-11-08 21:36:16 -08004771 .subvendor = 0x153b,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07004772 .subdevice = 0x1142,
4773 .driver_data = SAA7134_BOARD_CINERGY400,
4774 },{
4775 .vendor = PCI_VENDOR_ID_PHILIPS,
4776 .device = PCI_DEVICE_ID_PHILIPS_SAA7134,
Michael Krufky7df64e82005-11-08 21:36:16 -08004777 .subvendor = 0x153b,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07004778 .subdevice = 0x1143,
4779 .driver_data = SAA7134_BOARD_CINERGY600,
4780 },{
4781 .vendor = PCI_VENDOR_ID_PHILIPS,
4782 .device = PCI_DEVICE_ID_PHILIPS_SAA7134,
Michael Krufky7df64e82005-11-08 21:36:16 -08004783 .subvendor = 0x153b,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07004784 .subdevice = 0x1158,
4785 .driver_data = SAA7134_BOARD_CINERGY600_MK3,
4786 },{
Linus Torvalds1da177e2005-04-16 15:20:36 -07004787 .vendor = PCI_VENDOR_ID_PHILIPS,
4788 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
4789 .subvendor = 0x153b,
4790 .subdevice = 0x1162,
4791 .driver_data = SAA7134_BOARD_CINERGY400_CARDBUS,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07004792 },{
Linus Torvalds1da177e2005-04-16 15:20:36 -07004793 .vendor = PCI_VENDOR_ID_PHILIPS,
4794 .device = PCI_DEVICE_ID_PHILIPS_SAA7134,
Zac Bowlingf49ba8d2006-06-19 19:49:20 -03004795 .subvendor = 0x5169,
4796 .subdevice = 0x0138,
4797 .driver_data = SAA7134_BOARD_FLYVIDEO3000_NTSC,
4798 },{
4799 .vendor = PCI_VENDOR_ID_PHILIPS,
4800 .device = PCI_DEVICE_ID_PHILIPS_SAA7134,
Linus Torvalds1da177e2005-04-16 15:20:36 -07004801 .subvendor = 0x5168,
4802 .subdevice = 0x0138,
4803 .driver_data = SAA7134_BOARD_FLYVIDEO3000,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07004804 },{
Linus Torvalds1da177e2005-04-16 15:20:36 -07004805 .vendor = PCI_VENDOR_ID_PHILIPS,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07004806 .device = PCI_DEVICE_ID_PHILIPS_SAA7134,
4807 .subvendor = 0x4e42, /* "Typhoon PCI Capture TV Card" Art.No. 50673 */
4808 .subdevice = 0x0138,
4809 .driver_data = SAA7134_BOARD_FLYVIDEO3000,
4810 },{
Linus Torvalds1da177e2005-04-16 15:20:36 -07004811 .vendor = PCI_VENDOR_ID_PHILIPS,
4812 .device = PCI_DEVICE_ID_PHILIPS_SAA7130,
4813 .subvendor = 0x5168,
4814 .subdevice = 0x0138,
4815 .driver_data = SAA7134_BOARD_FLYVIDEO2000,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07004816 },{
Linus Torvalds1da177e2005-04-16 15:20:36 -07004817 .vendor = PCI_VENDOR_ID_PHILIPS,
Peter Missel10b7a902006-01-23 17:11:06 -02004818 .device = PCI_DEVICE_ID_PHILIPS_SAA7130,
4819 .subvendor = 0x4e42, /* Typhoon */
4820 .subdevice = 0x0138, /* LifeView FlyTV Prime30 OEM */
4821 .driver_data = SAA7134_BOARD_FLYVIDEO2000,
4822 },{
4823 .vendor = PCI_VENDOR_ID_PHILIPS,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07004824 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
Linus Torvalds1da177e2005-04-16 15:20:36 -07004825 .subvendor = 0x5168,
4826 .subdevice = 0x0212, /* minipci, LR212 */
4827 .driver_data = SAA7134_BOARD_FLYTVPLATINUM_MINI,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07004828 },{
Linus Torvalds1da177e2005-04-16 15:20:36 -07004829 .vendor = PCI_VENDOR_ID_PHILIPS,
4830 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
Mauro Carvalho Chehab058afaf2005-11-08 21:36:49 -08004831 .subvendor = 0x14c0,
4832 .subdevice = 0x1212, /* minipci, LR1212 */
4833 .driver_data = SAA7134_BOARD_FLYTVPLATINUM_MINI2,
4834 },{
4835 .vendor = PCI_VENDOR_ID_PHILIPS,
4836 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
Glen Gray2d14f782005-11-08 21:36:12 -08004837 .subvendor = 0x4e42,
4838 .subdevice = 0x0212, /* OEM minipci, LR212 */
4839 .driver_data = SAA7134_BOARD_FLYTVPLATINUM_MINI,
4840 },{
4841 .vendor = PCI_VENDOR_ID_PHILIPS,
4842 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
Peter Missel10e92062005-05-01 08:59:21 -07004843 .subvendor = 0x5168, /* Animation Technologies (LifeView) */
Simon Farnsworthb39423a2007-05-01 10:01:20 -03004844 .subdevice = 0x0214, /* Standard PCI, LR214 Rev E and earlier (SAA7135) */
4845 .driver_data = SAA7134_BOARD_FLYTVPLATINUM_FM,
4846 },{
4847 .vendor = PCI_VENDOR_ID_PHILIPS,
4848 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
4849 .subvendor = 0x5168, /* Animation Technologies (LifeView) */
4850 .subdevice = 0x5214, /* Standard PCI, LR214 Rev F onwards (SAA7131) */
Linus Torvalds1da177e2005-04-16 15:20:36 -07004851 .driver_data = SAA7134_BOARD_FLYTVPLATINUM_FM,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07004852 },{
Linus Torvalds1da177e2005-04-16 15:20:36 -07004853 .vendor = PCI_VENDOR_ID_PHILIPS,
Peter Missel10e92062005-05-01 08:59:21 -07004854 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
4855 .subvendor = 0x1489, /* KYE */
4856 .subdevice = 0x0214, /* Genius VideoWonder ProTV */
4857 .driver_data = SAA7134_BOARD_FLYTVPLATINUM_FM, /* is an LR214WF actually */
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07004858 },{
Peter Missel10e92062005-05-01 08:59:21 -07004859 .vendor = PCI_VENDOR_ID_PHILIPS,
Linus Torvalds1da177e2005-04-16 15:20:36 -07004860 .device = PCI_DEVICE_ID_PHILIPS_SAA7134,
4861 .subvendor = 0x16be,
4862 .subdevice = 0x0003,
4863 .driver_data = SAA7134_BOARD_MD7134,
4864 },{
4865 .vendor = PCI_VENDOR_ID_PHILIPS,
Hermann Pittona5525682008-12-05 19:49:34 -03004866 .device = PCI_DEVICE_ID_PHILIPS_SAA7134,
4867 .subvendor = 0x16be, /* CTX946 analog TV, HW mpeg, DVB-T */
4868 .subdevice = 0x5000, /* only analog TV and DVB-T for now */
4869 .driver_data = SAA7134_BOARD_MD7134,
4870 }, {
4871 .vendor = PCI_VENDOR_ID_PHILIPS,
Linus Torvalds1da177e2005-04-16 15:20:36 -07004872 .device = PCI_DEVICE_ID_PHILIPS_SAA7130,
4873 .subvendor = 0x1048,
4874 .subdevice = 0x226b,
4875 .driver_data = SAA7134_BOARD_ELSA,
4876 },{
4877 .vendor = PCI_VENDOR_ID_PHILIPS,
4878 .device = PCI_DEVICE_ID_PHILIPS_SAA7130,
4879 .subvendor = 0x1048,
Michael Krufky9a7871b2006-02-27 15:22:49 -03004880 .subdevice = 0x226a,
Linus Torvalds1da177e2005-04-16 15:20:36 -07004881 .driver_data = SAA7134_BOARD_ELSA_500TV,
4882 },{
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07004883 .vendor = PCI_VENDOR_ID_PHILIPS,
Tamuki Shoichid0456d12006-02-27 00:08:04 -03004884 .device = PCI_DEVICE_ID_PHILIPS_SAA7130,
Michael Krufkyba524292006-02-27 14:38:17 -03004885 .subvendor = 0x1048,
4886 .subdevice = 0x226c,
Tamuki Shoichid0456d12006-02-27 00:08:04 -03004887 .driver_data = SAA7134_BOARD_ELSA_700TV,
4888 },{
4889 .vendor = PCI_VENDOR_ID_PHILIPS,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07004890 .device = PCI_DEVICE_ID_PHILIPS_SAA7134,
4891 .subvendor = PCI_VENDOR_ID_ASUSTEK,
4892 .subdevice = 0x4842,
4893 .driver_data = SAA7134_BOARD_ASUSTeK_TVFM7134,
Linus Torvalds1da177e2005-04-16 15:20:36 -07004894 },{
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07004895 .vendor = PCI_VENDOR_ID_PHILIPS,
4896 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
4897 .subvendor = PCI_VENDOR_ID_ASUSTEK,
4898 .subdevice = 0x4845,
4899 .driver_data = SAA7134_BOARD_ASUSTeK_TVFM7135,
Linus Torvalds1da177e2005-04-16 15:20:36 -07004900 },{
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07004901 .vendor = PCI_VENDOR_ID_PHILIPS,
4902 .device = PCI_DEVICE_ID_PHILIPS_SAA7134,
4903 .subvendor = PCI_VENDOR_ID_ASUSTEK,
4904 .subdevice = 0x4830,
4905 .driver_data = SAA7134_BOARD_ASUSTeK_TVFM7134,
Linus Torvalds1da177e2005-04-16 15:20:36 -07004906 },{
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07004907 .vendor = PCI_VENDOR_ID_PHILIPS,
4908 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
4909 .subvendor = PCI_VENDOR_ID_ASUSTEK,
4910 .subdevice = 0x4843,
4911 .driver_data = SAA7134_BOARD_ASUSTEK_TVFM7133,
4912 },{
4913 .vendor = PCI_VENDOR_ID_PHILIPS,
4914 .device = PCI_DEVICE_ID_PHILIPS_SAA7134,
4915 .subvendor = PCI_VENDOR_ID_ASUSTEK,
4916 .subdevice = 0x4840,
4917 .driver_data = SAA7134_BOARD_ASUSTeK_TVFM7134,
4918 },{
Linus Torvalds1da177e2005-04-16 15:20:36 -07004919 .vendor = PCI_VENDOR_ID_PHILIPS,
4920 .device = PCI_DEVICE_ID_PHILIPS_SAA7134,
4921 .subvendor = PCI_VENDOR_ID_PHILIPS,
4922 .subdevice = 0xfe01,
4923 .driver_data = SAA7134_BOARD_TVSTATION_RDS,
4924 },{
4925 .vendor = PCI_VENDOR_ID_PHILIPS,
4926 .device = PCI_DEVICE_ID_PHILIPS_SAA7134,
4927 .subvendor = 0x1894,
4928 .subdevice = 0xfe01,
4929 .driver_data = SAA7134_BOARD_TVSTATION_RDS,
4930 },{
4931 .vendor = PCI_VENDOR_ID_PHILIPS,
4932 .device = PCI_DEVICE_ID_PHILIPS_SAA7134,
4933 .subvendor = 0x1894,
4934 .subdevice = 0xa006,
4935 .driver_data = SAA7134_BOARD_TVSTATION_DVR,
4936 },{
4937 .vendor = PCI_VENDOR_ID_PHILIPS,
4938 .device = PCI_DEVICE_ID_PHILIPS_SAA7134,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07004939 .subvendor = 0x1131,
4940 .subdevice = 0x7133,
Linus Torvalds1da177e2005-04-16 15:20:36 -07004941 .driver_data = SAA7134_BOARD_VA1000POWER,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07004942 },{
Linus Torvalds1da177e2005-04-16 15:20:36 -07004943 .vendor = PCI_VENDOR_ID_PHILIPS,
4944 .device = PCI_DEVICE_ID_PHILIPS_SAA7130,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07004945 .subvendor = PCI_VENDOR_ID_PHILIPS,
4946 .subdevice = 0x2001,
Linus Torvalds1da177e2005-04-16 15:20:36 -07004947 .driver_data = SAA7134_BOARD_10MOONSTVMASTER,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07004948 },{
Linus Torvalds1da177e2005-04-16 15:20:36 -07004949 .vendor = PCI_VENDOR_ID_PHILIPS,
4950 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07004951 .subvendor = 0x185b,
4952 .subdevice = 0xc100,
Linus Torvalds1da177e2005-04-16 15:20:36 -07004953 .driver_data = SAA7134_BOARD_VIDEOMATE_TV,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07004954 },{
Linus Torvalds1da177e2005-04-16 15:20:36 -07004955 .vendor = PCI_VENDOR_ID_PHILIPS,
4956 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07004957 .subvendor = 0x185b,
4958 .subdevice = 0xc100,
Linus Torvalds1da177e2005-04-16 15:20:36 -07004959 .driver_data = SAA7134_BOARD_VIDEOMATE_TV_GOLD_PLUS,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07004960 },{
Linus Torvalds1da177e2005-04-16 15:20:36 -07004961 .vendor = PCI_VENDOR_ID_PHILIPS,
4962 .device = PCI_DEVICE_ID_PHILIPS_SAA7130,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07004963 .subvendor = PCI_VENDOR_ID_MATROX,
4964 .subdevice = 0x48d0,
Linus Torvalds1da177e2005-04-16 15:20:36 -07004965 .driver_data = SAA7134_BOARD_CRONOS_PLUS,
4966 },{
4967 .vendor = PCI_VENDOR_ID_PHILIPS,
4968 .device = PCI_DEVICE_ID_PHILIPS_SAA7134,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07004969 .subvendor = 0x1461, /* Avermedia Technologies Inc */
4970 .subdevice = 0xa70b,
Linus Torvalds1da177e2005-04-16 15:20:36 -07004971 .driver_data = SAA7134_BOARD_MD2819,
4972 },{
4973 .vendor = PCI_VENDOR_ID_PHILIPS,
Matthias Schwarzottfc9d8ed2008-04-08 21:45:08 -03004974 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
4975 .subvendor = 0x1461, /* Avermedia Technologies Inc */
4976 .subdevice = 0xa7a1,
4977 .driver_data = SAA7134_BOARD_AVERMEDIA_A700_PRO,
4978 }, {
4979 .vendor = PCI_VENDOR_ID_PHILIPS,
4980 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
4981 .subvendor = 0x1461, /* Avermedia Technologies Inc */
4982 .subdevice = 0xa7a2,
4983 .driver_data = SAA7134_BOARD_AVERMEDIA_A700_HYBRID,
4984 }, {
4985 .vendor = PCI_VENDOR_ID_PHILIPS,
Linus Torvalds1da177e2005-04-16 15:20:36 -07004986 .device = PCI_DEVICE_ID_PHILIPS_SAA7130,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07004987 .subvendor = 0x1461, /* Avermedia Technologies Inc */
4988 .subdevice = 0x2115,
Linus Torvalds1da177e2005-04-16 15:20:36 -07004989 .driver_data = SAA7134_BOARD_AVERMEDIA_STUDIO_305,
4990 },{
4991 .vendor = PCI_VENDOR_ID_PHILIPS,
4992 .device = PCI_DEVICE_ID_PHILIPS_SAA7130,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07004993 .subvendor = 0x1461, /* Avermedia Technologies Inc */
4994 .subdevice = 0x2108,
Linus Torvalds1da177e2005-04-16 15:20:36 -07004995 .driver_data = SAA7134_BOARD_AVERMEDIA_305,
4996 },{
4997 .vendor = PCI_VENDOR_ID_PHILIPS,
4998 .device = PCI_DEVICE_ID_PHILIPS_SAA7130,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07004999 .subvendor = 0x1461, /* Avermedia Technologies Inc */
5000 .subdevice = 0x10ff,
Linus Torvalds1da177e2005-04-16 15:20:36 -07005001 .driver_data = SAA7134_BOARD_AVERMEDIA_DVD_EZMAKER,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07005002 },{
Linus Torvalds1da177e2005-04-16 15:20:36 -07005003 /* AVerMedia CardBus */
5004 .vendor = PCI_VENDOR_ID_PHILIPS,
5005 .device = PCI_DEVICE_ID_PHILIPS_SAA7134,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07005006 .subvendor = 0x1461, /* Avermedia Technologies Inc */
5007 .subdevice = 0xd6ee,
Linus Torvalds1da177e2005-04-16 15:20:36 -07005008 .driver_data = SAA7134_BOARD_AVERMEDIA_CARDBUS,
5009 },{
5010 /* TransGear 3000TV */
5011 .vendor = PCI_VENDOR_ID_PHILIPS,
5012 .device = PCI_DEVICE_ID_PHILIPS_SAA7130,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07005013 .subvendor = 0x1461, /* Avermedia Technologies Inc */
5014 .subdevice = 0x050c,
Linus Torvalds1da177e2005-04-16 15:20:36 -07005015 .driver_data = SAA7134_BOARD_TG3000TV,
5016 },{
Linus Torvalds1da177e2005-04-16 15:20:36 -07005017 .vendor = PCI_VENDOR_ID_PHILIPS,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07005018 .device = PCI_DEVICE_ID_PHILIPS_SAA7134,
5019 .subvendor = 0x11bd,
5020 .subdevice = 0x002b,
5021 .driver_data = SAA7134_BOARD_PINNACLE_PCTV_STEREO,
5022 },{
5023 .vendor = PCI_VENDOR_ID_PHILIPS,
5024 .device = PCI_DEVICE_ID_PHILIPS_SAA7134,
5025 .subvendor = 0x11bd,
5026 .subdevice = 0x002d,
5027 .driver_data = SAA7134_BOARD_PINNACLE_300I_DVBT_PAL,
5028 },{
5029 .vendor = PCI_VENDOR_ID_PHILIPS,
5030 .device = PCI_DEVICE_ID_PHILIPS_SAA7134,
5031 .subvendor = 0x1019,
5032 .subdevice = 0x4cb4,
5033 .driver_data = SAA7134_BOARD_ECS_TVP3XP,
5034 },{
5035 .vendor = PCI_VENDOR_ID_PHILIPS,
5036 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
5037 .subvendor = 0x1019,
5038 .subdevice = 0x4cb5,
5039 .driver_data = SAA7134_BOARD_ECS_TVP3XP_4CB5,
5040 },{
5041 .vendor = PCI_VENDOR_ID_PHILIPS,
Simon Farnsworthb39423a2007-05-01 10:01:20 -03005042 .device = PCI_DEVICE_ID_PHILIPS_SAA7134,
5043 .subvendor = 0x1019,
5044 .subdevice = 0x4cb6,
5045 .driver_data = SAA7134_BOARD_ECS_TVP3XP_4CB6,
5046 },{
5047 .vendor = PCI_VENDOR_ID_PHILIPS,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07005048 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
5049 .subvendor = 0x12ab,
5050 .subdevice = 0x0800,
5051 .driver_data = SAA7134_BOARD_UPMOST_PURPLE_TV,
Linus Torvalds1da177e2005-04-16 15:20:36 -07005052 },{
5053 .vendor = PCI_VENDOR_ID_PHILIPS,
5054 .device = PCI_DEVICE_ID_PHILIPS_SAA7130,
Michael Krufky7df64e82005-11-08 21:36:16 -08005055 .subvendor = 0x153b,
Linus Torvalds1da177e2005-04-16 15:20:36 -07005056 .subdevice = 0x1152,
5057 .driver_data = SAA7134_BOARD_CINERGY200,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07005058 },{
Linus Torvalds1da177e2005-04-16 15:20:36 -07005059 .vendor = PCI_VENDOR_ID_PHILIPS,
5060 .device = PCI_DEVICE_ID_PHILIPS_SAA7130,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07005061 .subvendor = 0x185b,
5062 .subdevice = 0xc100,
Linus Torvalds1da177e2005-04-16 15:20:36 -07005063 .driver_data = SAA7134_BOARD_VIDEOMATE_TV_PVR,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07005064 },{
Linus Torvalds1da177e2005-04-16 15:20:36 -07005065 .vendor = PCI_VENDOR_ID_PHILIPS,
Linus Torvalds1da177e2005-04-16 15:20:36 -07005066 .device = PCI_DEVICE_ID_PHILIPS_SAA7134,
5067 .subvendor = 0x1461, /* Avermedia Technologies Inc */
5068 .subdevice = 0x9715,
Mauro Carvalho Chehabac19ecc2005-06-23 22:05:09 -07005069 .driver_data = SAA7134_BOARD_AVERMEDIA_STUDIO_307,
5070 },{
5071 .vendor = PCI_VENDOR_ID_PHILIPS,
5072 .device = PCI_DEVICE_ID_PHILIPS_SAA7134,
5073 .subvendor = 0x1461, /* Avermedia Technologies Inc */
5074 .subdevice = 0xa70a,
Linus Torvalds1da177e2005-04-16 15:20:36 -07005075 .driver_data = SAA7134_BOARD_AVERMEDIA_307,
5076 },{
5077 .vendor = PCI_VENDOR_ID_PHILIPS,
5078 .device = PCI_DEVICE_ID_PHILIPS_SAA7134,
5079 .subvendor = 0x185b,
5080 .subdevice = 0xc200,
5081 .driver_data = SAA7134_BOARD_VIDEOMATE_GOLD_PLUS,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07005082 },{
Linus Torvalds1da177e2005-04-16 15:20:36 -07005083 .vendor = PCI_VENDOR_ID_PHILIPS,
5084 .device = PCI_DEVICE_ID_PHILIPS_SAA7134,
5085 .subvendor = 0x1540,
5086 .subdevice = 0x9524,
5087 .driver_data = SAA7134_BOARD_PROVIDEO_PV952,
5088
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07005089 },{
Linus Torvalds1da177e2005-04-16 15:20:36 -07005090 .vendor = PCI_VENDOR_ID_PHILIPS,
5091 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
5092 .subvendor = 0x5168,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07005093 .subdevice = 0x0502, /* Cardbus version */
Peter Missel10b7a902006-01-23 17:11:06 -02005094 .driver_data = SAA7134_BOARD_FLYDVBT_DUO_CARDBUS,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07005095 },{
5096 .vendor = PCI_VENDOR_ID_PHILIPS,
5097 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
5098 .subvendor = 0x5168,
5099 .subdevice = 0x0306, /* PCI version */
Linus Torvalds1da177e2005-04-16 15:20:36 -07005100 .driver_data = SAA7134_BOARD_FLYDVBTDUO,
Mauro Carvalho Chehabac19ecc2005-06-23 22:05:09 -07005101 },{
5102 .vendor = PCI_VENDOR_ID_PHILIPS,
5103 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
5104 .subvendor = 0x1461, /* Avermedia Technologies Inc */
5105 .subdevice = 0xf31f,
5106 .driver_data = SAA7134_BOARD_AVERMEDIA_GO_007_FM,
5107
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07005108 },{
Mauro Carvalho Chehabac19ecc2005-06-23 22:05:09 -07005109 .vendor = PCI_VENDOR_ID_PHILIPS,
Mauro Carvalho Chehab36f6bb92008-06-26 17:03:00 -03005110 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
5111 .subvendor = 0x1461, /* Avermedia Technologies Inc */
5112 .subdevice = 0xf11d,
5113 .driver_data = SAA7134_BOARD_AVERMEDIA_M135A,
5114 }, {
5115 .vendor = PCI_VENDOR_ID_PHILIPS,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07005116 .device = PCI_DEVICE_ID_PHILIPS_SAA7130,
5117 .subvendor = PCI_VENDOR_ID_PHILIPS,
5118 .subdevice = 0x2004,
5119 .driver_data = SAA7134_BOARD_PHILIPS_TOUGH,
5120 },{
5121 .vendor = PCI_VENDOR_ID_PHILIPS,
5122 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
Mauro Carvalho Chehabac19ecc2005-06-23 22:05:09 -07005123 .subvendor = 0x1421,
5124 .subdevice = 0x0350, /* PCI version */
5125 .driver_data = SAA7134_BOARD_ADS_INSTANT_TV,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07005126 },{
Mauro Carvalho Chehabac19ecc2005-06-23 22:05:09 -07005127 .vendor = PCI_VENDOR_ID_PHILIPS,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07005128 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
Mauro Carvalho Chehabac19ecc2005-06-23 22:05:09 -07005129 .subvendor = 0x1421,
Ricardo Cerqueira41d70c22006-01-09 15:25:34 -02005130 .subdevice = 0x0351, /* PCI version, new revision */
5131 .driver_data = SAA7134_BOARD_ADS_INSTANT_TV,
5132 },{
5133 .vendor = PCI_VENDOR_ID_PHILIPS,
5134 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
5135 .subvendor = 0x1421,
Mauro Carvalho Chehabac19ecc2005-06-23 22:05:09 -07005136 .subdevice = 0x0370, /* cardbus version */
5137 .driver_data = SAA7134_BOARD_ADS_INSTANT_TV,
Hartmut Hackmannd4b0aba2005-11-08 21:38:44 -08005138 },{
5139 .vendor = PCI_VENDOR_ID_PHILIPS,
5140 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
5141 .subvendor = 0x1421,
5142 .subdevice = 0x1370, /* cardbus version */
5143 .driver_data = SAA7134_BOARD_ADS_INSTANT_TV,
Linus Torvalds1da177e2005-04-16 15:20:36 -07005144
Peter Missel10b7a902006-01-23 17:11:06 -02005145 },{
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07005146 .vendor = PCI_VENDOR_ID_PHILIPS,
5147 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
Peter Missel10b7a902006-01-23 17:11:06 -02005148 .subvendor = 0x4e42, /* Typhoon */
5149 .subdevice = 0x0502, /* LifeView LR502 OEM */
5150 .driver_data = SAA7134_BOARD_FLYDVBT_DUO_CARDBUS,
Mauro Carvalho Chehab2f180712005-09-09 13:03:46 -07005151 },{
5152 .vendor = PCI_VENDOR_ID_PHILIPS,
5153 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
5154 .subvendor = 0x1043,
5155 .subdevice = 0x0210, /* mini pci NTSC version */
5156 .driver_data = SAA7134_BOARD_FLYTV_DIGIMATRIX,
5157 },{
5158 .vendor = PCI_VENDOR_ID_PHILIPS,
5159 .device = PCI_DEVICE_ID_PHILIPS_SAA7134,
5160 .subvendor = 0x1043,
5161 .subdevice = 0x0210, /* mini pci PAL/SECAM version */
Michael Krufky5d5c9902005-11-08 21:38:08 -08005162 .driver_data = SAA7134_BOARD_ASUSTEK_DIGIMATRIX_TV,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07005163
5164 },{
Nickolay V. Shmyreva8ff4172005-11-08 21:36:16 -08005165 .vendor = PCI_VENDOR_ID_PHILIPS,
5166 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
5167 .subvendor = 0x0000, /* It shouldn't break anything, since subdevice id seems unique */
5168 .subdevice = 0x4091,
5169 .driver_data = SAA7134_BOARD_BEHOLD_409FM,
Mauro Carvalho Chehab4ac97912005-11-08 21:37:43 -08005170 },{
5171 .vendor = PCI_VENDOR_ID_PHILIPS,
5172 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
5173 .subvendor = 0x5456, /* GoTView */
5174 .subdevice = 0x7135,
5175 .driver_data = SAA7134_BOARD_GOTVIEW_7135,
5176 },{
Hartmut Hackmann2cf36ac2005-11-08 21:36:32 -08005177 .vendor = PCI_VENDOR_ID_PHILIPS,
5178 .device = PCI_DEVICE_ID_PHILIPS_SAA7134,
5179 .subvendor = PCI_VENDOR_ID_PHILIPS,
5180 .subdevice = 0x2004,
5181 .driver_data = SAA7134_BOARD_PHILIPS_EUROPA,
Mauro Carvalho Chehab4ac97912005-11-08 21:37:43 -08005182 },{
Hartmut Hackmann2cf36ac2005-11-08 21:36:32 -08005183 .vendor = PCI_VENDOR_ID_PHILIPS,
5184 .device = PCI_DEVICE_ID_PHILIPS_SAA7134,
5185 .subvendor = 0x185b,
5186 .subdevice = 0xc900,
5187 .driver_data = SAA7134_BOARD_VIDEOMATE_DVBT_300,
Mauro Carvalho Chehab4ac97912005-11-08 21:37:43 -08005188 },{
Hartmut Hackmann2cf36ac2005-11-08 21:36:32 -08005189 .vendor = PCI_VENDOR_ID_PHILIPS,
5190 .device = PCI_DEVICE_ID_PHILIPS_SAA7130,
5191 .subvendor = 0x185b,
5192 .subdevice = 0xc901,
5193 .driver_data = SAA7134_BOARD_VIDEOMATE_DVBT_200,
5194 },{
Mauro Carvalho Chehab4ac97912005-11-08 21:37:43 -08005195 .vendor = PCI_VENDOR_ID_PHILIPS,
5196 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
5197 .subvendor = 0x1435,
5198 .subdevice = 0x7350,
5199 .driver_data = SAA7134_BOARD_RTD_VFG7350,
Nickolay V. Shmyrevbb881f12005-11-08 21:36:35 -08005200 },{
Mauro Carvalho Chehab4ac97912005-11-08 21:37:43 -08005201 .vendor = PCI_VENDOR_ID_PHILIPS,
5202 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
5203 .subvendor = 0x1435,
5204 .subdevice = 0x7330,
5205 .driver_data = SAA7134_BOARD_RTD_VFG7330,
Pieter Palmerscf1c5d12005-11-08 21:37:40 -08005206 },{
Mauro Carvalho Chehab4ac97912005-11-08 21:37:43 -08005207 .vendor = PCI_VENDOR_ID_PHILIPS,
5208 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
5209 .subvendor = 0x1461,
5210 .subdevice = 0x1044,
5211 .driver_data = SAA7134_BOARD_AVERMEDIA_AVERTVHD_A180,
5212 },{
Pieter Palmerscf1c5d12005-11-08 21:37:40 -08005213 .vendor = PCI_VENDOR_ID_PHILIPS,
5214 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
5215 .subvendor = 0x1131,
5216 .subdevice = 0x4ee9,
5217 .driver_data = SAA7134_BOARD_MONSTERTV_MOBILE,
Mauro Carvalho Chehab4ac97912005-11-08 21:37:43 -08005218 },{
Ricardo Cerqueirac2f6f9d2005-11-08 21:37:51 -08005219 .vendor = PCI_VENDOR_ID_PHILIPS,
5220 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
5221 .subvendor = 0x11bd,
5222 .subdevice = 0x002e,
5223 .driver_data = SAA7134_BOARD_PINNACLE_PCTV_110i,
5224 },{
Hermann Pitton28f02242005-11-08 21:38:03 -08005225 .vendor = PCI_VENDOR_ID_PHILIPS,
5226 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
5227 .subvendor = 0x1043,
5228 .subdevice = 0x4862,
5229 .driver_data = SAA7134_BOARD_ASUSTeK_P7131_DUAL,
Pavel Mihaylovc3d93192005-11-08 21:38:43 -08005230 },{
Hartmut Hackmann90e9df72005-11-08 21:38:42 -08005231 .vendor = PCI_VENDOR_ID_PHILIPS,
5232 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
5233 .subvendor = PCI_VENDOR_ID_PHILIPS,
5234 .subdevice = 0x2018,
5235 .driver_data = SAA7134_BOARD_PHILIPS_TIGER,
Hermann Pitton28f02242005-11-08 21:38:03 -08005236 },{
Ricardo Cerqueira80d2ad92005-11-13 16:08:01 -08005237 .vendor = PCI_VENDOR_ID_PHILIPS,
5238 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
5239 .subvendor = 0x1462,
Hermann Pittonb6667e52008-01-12 14:43:48 -03005240 .subdevice = 0x6231, /* tda8275a, ks003 IR */
5241 .driver_data = SAA7134_BOARD_MSI_TVATANYWHERE_PLUS,
5242 },{
5243 .vendor = PCI_VENDOR_ID_PHILIPS,
5244 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
5245 .subvendor = 0x1462,
5246 .subdevice = 0x8624, /* tda8275, ks003 IR */
Ricardo Cerqueira80d2ad92005-11-13 16:08:01 -08005247 .driver_data = SAA7134_BOARD_MSI_TVATANYWHERE_PLUS,
5248 },{
Jörg Schummerf639c9b2006-01-09 15:25:01 -02005249 .vendor = PCI_VENDOR_ID_PHILIPS,
5250 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
5251 .subvendor = 0x153b,
5252 .subdevice = 0x1160,
5253 .driver_data = SAA7134_BOARD_CINERGY250PCI,
5254 },{
Peter Missel4aa6ba52006-01-09 15:32:45 -02005255 .vendor = PCI_VENDOR_ID_PHILIPS,
5256 .device = PCI_DEVICE_ID_PHILIPS_SAA7133, /* SAA 7131E */
5257 .subvendor = 0x5168,
5258 .subdevice = 0x0319,
5259 .driver_data = SAA7134_BOARD_FLYDVB_TRIO,
5260 },{
Jose Alberto Regueroa78d0bf2006-02-07 06:25:14 -02005261 .vendor = PCI_VENDOR_ID_PHILIPS,
Hartmut Hackmann1e9bfb92006-08-07 14:03:32 -03005262 .device = PCI_DEVICE_ID_PHILIPS_SAA7134,
Jose Alberto Regueroa78d0bf2006-02-07 06:25:14 -02005263 .subvendor = 0x1461,
5264 .subdevice = 0x2c05,
5265 .driver_data = SAA7134_BOARD_AVERMEDIA_777,
5266 },{
Giampiero Giancipoli3d8466e2006-02-07 06:49:09 -02005267 .vendor = PCI_VENDOR_ID_PHILIPS,
5268 .device = PCI_DEVICE_ID_PHILIPS_SAA7134,
5269 .subvendor = 0x5168,
5270 .subdevice = 0x0301,
5271 .driver_data = SAA7134_BOARD_FLYDVBT_LR301,
5272 },{
Hartmut Hackmanndf42eaf2006-02-07 06:49:10 -02005273 .vendor = PCI_VENDOR_ID_PHILIPS,
5274 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
5275 .subvendor = 0x0331,
5276 .subdevice = 0x1421,
5277 .driver_data = SAA7134_BOARD_ADS_DUO_CARDBUS_PTV331,
5278 },{
Peter Hartshorn3dfb7292006-02-07 06:49:13 -02005279 .vendor = PCI_VENDOR_ID_PHILIPS,
5280 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
5281 .subvendor = 0x17de,
5282 .subdevice = 0x7201,
5283 .driver_data = SAA7134_BOARD_TEVION_DVBT_220RF,
5284 },{
Andrew Burri3e1410a2006-02-27 00:08:23 -03005285 .vendor = PCI_VENDOR_ID_PHILIPS,
Simon Farnsworthb39423a2007-05-01 10:01:20 -03005286 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
5287 .subvendor = 0x17de,
5288 .subdevice = 0x7250,
5289 .driver_data = SAA7134_BOARD_KWORLD_DVBT_210,
5290 },{
5291 .vendor = PCI_VENDOR_ID_PHILIPS,
Andrew Burri3e1410a2006-02-27 00:08:23 -03005292 .device = PCI_DEVICE_ID_PHILIPS_SAA7133, /* SAA7135HL */
5293 .subvendor = 0x17de,
5294 .subdevice = 0x7350,
5295 .driver_data = SAA7134_BOARD_KWORLD_ATSC110,
5296 },{
Rickard Osser68593af2006-03-11 17:14:12 -03005297 .vendor = PCI_VENDOR_ID_PHILIPS,
Eric Sandeen0ac3a5b2007-10-08 16:13:02 -03005298 .device = PCI_DEVICE_ID_PHILIPS_SAA7133, /* SAA7135HL */
5299 .subvendor = 0x17de,
5300 .subdevice = 0x7352,
5301 .driver_data = SAA7134_BOARD_KWORLD_ATSC110, /* ATSC 115 */
5302 },{
5303 .vendor = PCI_VENDOR_ID_PHILIPS,
Rickard Osser68593af2006-03-11 17:14:12 -03005304 .device = PCI_DEVICE_ID_PHILIPS_SAA7134,
5305 .subvendor = 0x1461,
5306 .subdevice = 0x7360,
5307 .driver_data = SAA7134_BOARD_AVERMEDIA_A169_B,
5308 },{
5309 .vendor = PCI_VENDOR_ID_PHILIPS,
5310 .device = PCI_DEVICE_ID_PHILIPS_SAA7134,
5311 .subvendor = 0x1461,
5312 .subdevice = 0x6360,
5313 .driver_data = SAA7134_BOARD_AVERMEDIA_A169_B1,
5314 },{
Michael Krufkyba3a5a82006-03-14 19:02:12 -03005315 .vendor = PCI_VENDOR_ID_PHILIPS,
5316 .device = PCI_DEVICE_ID_PHILIPS_SAA7134,
5317 .subvendor = 0x16be,
5318 .subdevice = 0x0005,
5319 .driver_data = SAA7134_BOARD_MD7134_BRIDGE_2,
5320 },{
Igor M. Liplianine2ac28f2006-08-08 09:10:10 -03005321 .vendor = PCI_VENDOR_ID_PHILIPS,
5322 .device = PCI_DEVICE_ID_PHILIPS_SAA7134,
5323 .subvendor = 0x5168,
5324 .subdevice = 0x0300,
5325 .driver_data = SAA7134_BOARD_FLYDVBS_LR300,
5326 },{
5327 .vendor = PCI_VENDOR_ID_PHILIPS,
5328 .device = PCI_DEVICE_ID_PHILIPS_SAA7134,
5329 .subvendor = 0x4e42,
5330 .subdevice = 0x0300,/* LR300 */
5331 .driver_data = SAA7134_BOARD_FLYDVBS_LR300,
5332 },{
Hartmut Hackmann42e6b3b2006-03-27 19:04:48 -03005333 .vendor = PCI_VENDOR_ID_PHILIPS,
5334 .device = PCI_DEVICE_ID_PHILIPS_SAA7134,
5335 .subvendor = 0x1489,
5336 .subdevice = 0x0301,
5337 .driver_data = SAA7134_BOARD_FLYDVBT_LR301,
5338 },{
5339 .vendor = PCI_VENDOR_ID_PHILIPS,
5340 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
5341 .subvendor = 0x5168, /* Animation Technologies (LifeView) */
5342 .subdevice = 0x0304,
5343 .driver_data = SAA7134_BOARD_FLYTVPLATINUM_FM,
5344 },{
Hartmut Hackmannd95b8942006-03-27 19:39:30 -03005345 .vendor = PCI_VENDOR_ID_PHILIPS,
5346 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
5347 .subvendor = 0x5168,
5348 .subdevice = 0x3306,
5349 .driver_data = SAA7134_BOARD_FLYDVBT_HYBRID_CARDBUS,
5350 },{
5351 .vendor = PCI_VENDOR_ID_PHILIPS,
5352 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
5353 .subvendor = 0x5168,
5354 .subdevice = 0x3502, /* whats the difference to 0x3306 ?*/
5355 .driver_data = SAA7134_BOARD_FLYDVBT_HYBRID_CARDBUS,
5356 },{
Hartmut Hackmann5eda2272006-08-07 14:03:32 -03005357 .vendor = PCI_VENDOR_ID_PHILIPS,
5358 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
Hermann Pitton29e4e052008-01-20 19:49:51 -03005359 .subvendor = 0x5168,
5360 .subdevice = 0x3307, /* FlyDVB-T Hybrid Mini PCI */
5361 .driver_data = SAA7134_BOARD_FLYDVBT_HYBRID_CARDBUS,
5362 }, {
5363 .vendor = PCI_VENDOR_ID_PHILIPS,
5364 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
Hartmut Hackmann5eda2272006-08-07 14:03:32 -03005365 .subvendor = 0x16be,
5366 .subdevice = 0x0007,
5367 .driver_data = SAA7134_BOARD_MEDION_MD8800_QUADRO,
5368 },{
5369 .vendor = PCI_VENDOR_ID_PHILIPS,
5370 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
5371 .subvendor = 0x16be,
5372 .subdevice = 0x0008,
5373 .driver_data = SAA7134_BOARD_MEDION_MD8800_QUADRO,
5374 },{
Hartmut Hackmann1e9bfb92006-08-07 14:03:32 -03005375 .vendor = PCI_VENDOR_ID_PHILIPS,
5376 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
Hermann Pitton728b92a2008-01-20 19:42:01 -03005377 .subvendor = 0x16be,
5378 .subdevice = 0x000d, /* triple CTX948_V1.1.1 */
5379 .driver_data = SAA7134_BOARD_MEDION_MD8800_QUADRO,
5380 }, {
5381 .vendor = PCI_VENDOR_ID_PHILIPS,
5382 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
Hartmut Hackmann1e9bfb92006-08-07 14:03:32 -03005383 .subvendor = 0x1461,
5384 .subdevice = 0x2c05,
5385 .driver_data = SAA7134_BOARD_AVERMEDIA_777,
5386 },{
Hartmut Hackmann2c591942006-08-07 14:03:32 -03005387 .vendor = PCI_VENDOR_ID_PHILIPS,
5388 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
5389 .subvendor = 0x1489,
5390 .subdevice = 0x0502, /* Cardbus version */
5391 .driver_data = SAA7134_BOARD_FLYDVBT_DUO_CARDBUS,
5392 },{
Michal Majchrowiczb04c1ba2006-09-13 16:42:42 -03005393 .vendor = PCI_VENDOR_ID_PHILIPS,
5394 .device = PCI_DEVICE_ID_PHILIPS_SAA7130,
5395 .subvendor = 0x0919, /* Philips Proteus PRO 2309 */
5396 .subdevice = 0x2003,
5397 .driver_data = SAA7134_BOARD_PROTEUS_2309,
5398 },{
Petr Baudis515c2082006-09-26 16:53:53 -03005399 .vendor = PCI_VENDOR_ID_PHILIPS,
5400 .device = PCI_DEVICE_ID_PHILIPS_SAA7134,
5401 .subvendor = 0x1461,
5402 .subdevice = 0x2c00,
5403 .driver_data = SAA7134_BOARD_AVERMEDIA_A16AR,
5404 },{
Hartmut Hackmanncf146ca2006-10-02 20:49:24 -03005405 .vendor = PCI_VENDOR_ID_PHILIPS,
5406 .device = PCI_DEVICE_ID_PHILIPS_SAA7134,
5407 .subvendor = 0x1043,
5408 .subdevice = 0x4860,
5409 .driver_data = SAA7134_BOARD_ASUS_EUROPA2_HYBRID,
5410 },{
Hartmut Hackmann587d2fd2006-10-06 19:13:50 -03005411 .vendor = PCI_VENDOR_ID_PHILIPS,
5412 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
5413 .subvendor = 0x11bd,
5414 .subdevice = 0x002f,
5415 .driver_data = SAA7134_BOARD_PINNACLE_PCTV_310i,
5416 },{
Mikhail Fedotov3ac706d2006-10-06 20:23:47 -03005417 .vendor = PCI_VENDOR_ID_PHILIPS,
5418 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
5419 .subvendor = 0x1461, /* Avermedia Technologies Inc */
5420 .subdevice = 0x9715,
5421 .driver_data = SAA7134_BOARD_AVERMEDIA_STUDIO_507,
5422 },{
Hartmut Hackmann83646812006-10-12 20:38:51 -03005423 .vendor = PCI_VENDOR_ID_PHILIPS,
5424 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
5425 .subvendor = 0x1043,
5426 .subdevice = 0x4876,
Hartmut Hackmannf3eec0c02007-03-14 20:33:55 -03005427 .driver_data = SAA7134_BOARD_ASUSTeK_P7131_HYBRID_LNA,
Hartmut Hackmann83646812006-10-12 20:38:51 -03005428 },{
Thomas Gentyc6e53da2006-11-05 14:17:30 -03005429 .vendor = PCI_VENDOR_ID_PHILIPS,
5430 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
5431 .subvendor = 0x0070,
Michael Krufkyddf12222007-11-15 10:01:11 -03005432 .subdevice = 0x6700,
5433 .driver_data = SAA7134_BOARD_HAUPPAUGE_HVR1110,
5434 },{
5435 .vendor = PCI_VENDOR_ID_PHILIPS,
5436 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
5437 .subvendor = 0x0070,
Thomas Gentyc6e53da2006-11-05 14:17:30 -03005438 .subdevice = 0x6701,
5439 .driver_data = SAA7134_BOARD_HAUPPAUGE_HVR1110,
5440 },{
Hartmut Hackmann550a9a52006-11-15 21:31:54 -03005441 .vendor = PCI_VENDOR_ID_PHILIPS,
5442 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
Michael Krufkyddf12222007-11-15 10:01:11 -03005443 .subvendor = 0x0070,
5444 .subdevice = 0x6702,
5445 .driver_data = SAA7134_BOARD_HAUPPAUGE_HVR1110,
5446 },{
5447 .vendor = PCI_VENDOR_ID_PHILIPS,
5448 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
5449 .subvendor = 0x0070,
5450 .subdevice = 0x6703,
5451 .driver_data = SAA7134_BOARD_HAUPPAUGE_HVR1110,
5452 },{
5453 .vendor = PCI_VENDOR_ID_PHILIPS,
5454 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
5455 .subvendor = 0x0070,
5456 .subdevice = 0x6704,
5457 .driver_data = SAA7134_BOARD_HAUPPAUGE_HVR1110,
5458 },{
5459 .vendor = PCI_VENDOR_ID_PHILIPS,
5460 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
5461 .subvendor = 0x0070,
5462 .subdevice = 0x6705,
5463 .driver_data = SAA7134_BOARD_HAUPPAUGE_HVR1110,
5464 },{
5465 .vendor = PCI_VENDOR_ID_PHILIPS,
5466 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
Michael Krufkyf9996c92009-02-28 17:45:17 -03005467 .subvendor = 0x0070,
5468 .subdevice = 0x6706,
5469 .driver_data = SAA7134_BOARD_HAUPPAUGE_HVR1150,
5470 },{
5471 .vendor = PCI_VENDOR_ID_PHILIPS,
5472 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
5473 .subvendor = 0x0070,
5474 .subdevice = 0x6707,
5475 .driver_data = SAA7134_BOARD_HAUPPAUGE_HVR1110R3,
5476 },{
5477 .vendor = PCI_VENDOR_ID_PHILIPS,
5478 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
5479 .subvendor = 0x0070,
5480 .subdevice = 0x6708,
5481 .driver_data = SAA7134_BOARD_HAUPPAUGE_HVR1150,
5482 },{
5483 .vendor = PCI_VENDOR_ID_PHILIPS,
5484 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
5485 .subvendor = 0x0070,
5486 .subdevice = 0x6709,
5487 .driver_data = SAA7134_BOARD_HAUPPAUGE_HVR1110R3,
5488 },{
5489 .vendor = PCI_VENDOR_ID_PHILIPS,
5490 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
5491 .subvendor = 0x0070,
5492 .subdevice = 0x670a,
5493 .driver_data = SAA7134_BOARD_HAUPPAUGE_HVR1110R3,
5494 },{
5495 .vendor = PCI_VENDOR_ID_PHILIPS,
5496 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
Hartmut Hackmann550a9a52006-11-15 21:31:54 -03005497 .subvendor = 0x153b,
5498 .subdevice = 0x1172,
5499 .driver_data = SAA7134_BOARD_CINERGY_HT_PCMCIA,
5500 },{
Steven Walterd1158f42006-12-20 09:29:09 -03005501 .vendor = PCI_VENDOR_ID_PHILIPS,
5502 .device = PCI_DEVICE_ID_PHILIPS_SAA7130,
5503 .subvendor = PCI_VENDOR_ID_PHILIPS,
5504 .subdevice = 0x2342,
5505 .driver_data = SAA7134_BOARD_ENCORE_ENLTV,
5506 },{
Juan Pablo Sormanic36c4592006-12-27 12:46:36 -03005507 .vendor = PCI_VENDOR_ID_PHILIPS,
5508 .device = PCI_DEVICE_ID_PHILIPS_SAA7130,
5509 .subvendor = 0x1131,
5510 .subdevice = 0x2341,
5511 .driver_data = SAA7134_BOARD_ENCORE_ENLTV,
5512 },{
5513 .vendor = PCI_VENDOR_ID_PHILIPS,
5514 .device = PCI_DEVICE_ID_PHILIPS_SAA7130,
5515 .subvendor = 0x3016,
5516 .subdevice = 0x2344,
5517 .driver_data = SAA7134_BOARD_ENCORE_ENLTV,
5518 },{
5519 .vendor = PCI_VENDOR_ID_PHILIPS,
5520 .device = PCI_DEVICE_ID_PHILIPS_SAA7130,
5521 .subvendor = 0x1131,
5522 .subdevice = 0x230f,
5523 .driver_data = SAA7134_BOARD_ENCORE_ENLTV_FM,
5524 },{
Michael Krufky9de271e2007-01-16 18:36:40 -03005525 .vendor = PCI_VENDOR_ID_PHILIPS,
Mauro Carvalho Chehabbf1ece62008-06-26 17:03:00 -03005526 .device = PCI_DEVICE_ID_PHILIPS_SAA7130,
5527 .subvendor = 0x1a7f,
5528 .subdevice = 0x2008,
5529 .driver_data = SAA7134_BOARD_ENCORE_ENLTV_FM53,
5530 }, {
5531 .vendor = PCI_VENDOR_ID_PHILIPS,
Michael Krufky9de271e2007-01-16 18:36:40 -03005532 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
5533 .subvendor = 0x153b,
5534 .subdevice = 0x1175,
5535 .driver_data = SAA7134_BOARD_CINERGY_HT_PCI,
5536 },{
Markus Rechbergere95d3172007-04-27 12:31:19 -03005537 .vendor = PCI_VENDOR_ID_PHILIPS,
5538 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
5539 .subvendor = 0x1461, /* Avermedia Technologies Inc */
5540 .subdevice = 0xf31e,
5541 .driver_data = SAA7134_BOARD_AVERMEDIA_M102,
5542 },{
Peter Misseldb483672007-04-27 12:31:20 -03005543 .vendor = PCI_VENDOR_ID_PHILIPS,
5544 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
5545 .subvendor = 0x4E42, /* MSI */
5546 .subdevice = 0x0306, /* TV@nywhere DUO */
5547 .driver_data = SAA7134_BOARD_FLYDVBTDUO,
5548 },{
Hartmut Hackmanne06cea42007-03-13 20:58:29 -03005549 .vendor = PCI_VENDOR_ID_PHILIPS,
5550 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
5551 .subvendor = 0x1043,
5552 .subdevice = 0x4871,
5553 .driver_data = SAA7134_BOARD_ASUS_P7131_4871,
5554 },{
5555 .vendor = PCI_VENDOR_ID_PHILIPS,
5556 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
5557 .subvendor = 0x1043,
Hermann Pitton028165a2008-10-04 21:37:36 -03005558 .subdevice = 0x4857, /* REV:1.00 */
5559 .driver_data = SAA7134_BOARD_ASUSTeK_TIGER,
Hartmut Hackmanne06cea42007-03-13 20:58:29 -03005560 },{
James T Klaas53958b32007-05-01 10:48:09 -03005561 .vendor = PCI_VENDOR_ID_PHILIPS,
5562 .device = PCI_DEVICE_ID_PHILIPS_SAA7134,
5563 .subvendor = 0x0919, /* SinoVideo PCI 2309 Proteus (7134) */
5564 .subdevice = 0x2003, /* OEM cardbus */
5565 .driver_data = SAA7134_BOARD_SABRENT_TV_PCB05,
5566 },{
Tony Wanaaccb822007-05-10 12:16:47 -03005567 .vendor = PCI_VENDOR_ID_PHILIPS,
5568 .device = PCI_DEVICE_ID_PHILIPS_SAA7130,
5569 .subvendor = PCI_VENDOR_ID_PHILIPS,
5570 .subdevice = 0x2304,
5571 .driver_data = SAA7134_BOARD_10MOONSTVMASTER3,
5572 },{
Edgar Simod90d9f52007-08-20 14:14:50 -03005573 .vendor = PCI_VENDOR_ID_PHILIPS,
5574 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
5575 .subvendor = 0x1461, /* Avermedia Technologies Inc */
5576 .subdevice = 0xf01d, /* AVerTV DVB-T Super 007 */
5577 .driver_data = SAA7134_BOARD_AVERMEDIA_SUPER_007,
5578 },{
Mauro Carvalho Chehab593f18c2007-10-07 02:17:09 -03005579 .vendor = PCI_VENDOR_ID_PHILIPS,
Andrey J. Melnikoff (TEMHOTA)e8018c92008-01-07 05:17:39 -03005580 .device = PCI_DEVICE_ID_PHILIPS_SAA7130,
Andrey J. Melnikoff (TEMHOTA)e8018c92008-01-07 05:17:39 -03005581 .subvendor = 0x0000,
5582 .subdevice = 0x4016,
5583 .driver_data = SAA7134_BOARD_BEHOLD_401,
5584 },{
5585 .vendor = PCI_VENDOR_ID_PHILIPS,
5586 .device = PCI_DEVICE_ID_PHILIPS_SAA7134,
Andrey J. Melnikoff (TEMHOTA)e8018c92008-01-07 05:17:39 -03005587 .subvendor = 0x0000,
5588 .subdevice = 0x4036,
5589 .driver_data = SAA7134_BOARD_BEHOLD_403,
5590 },{
5591 .vendor = PCI_VENDOR_ID_PHILIPS,
5592 .device = PCI_DEVICE_ID_PHILIPS_SAA7134,
5593 .subvendor = 0x0000,
5594 .subdevice = 0x4037,
5595 .driver_data = SAA7134_BOARD_BEHOLD_403FM,
5596 },{
5597 .vendor = PCI_VENDOR_ID_PHILIPS,
5598 .device = PCI_DEVICE_ID_PHILIPS_SAA7130,
5599 .subvendor = 0x0000,
5600 .subdevice = 0x4050,
5601 .driver_data = SAA7134_BOARD_BEHOLD_405,
5602 },{
5603 .vendor = PCI_VENDOR_ID_PHILIPS,
5604 .device = PCI_DEVICE_ID_PHILIPS_SAA7130,
5605 .subvendor = 0x0000,
5606 .subdevice = 0x4051,
5607 .driver_data = SAA7134_BOARD_BEHOLD_405FM,
5608 },{
5609 .vendor = PCI_VENDOR_ID_PHILIPS,
5610 .device = PCI_DEVICE_ID_PHILIPS_SAA7134,
5611 .subvendor = 0x0000,
5612 .subdevice = 0x4070,
5613 .driver_data = SAA7134_BOARD_BEHOLD_407,
5614 },{
5615 .vendor = PCI_VENDOR_ID_PHILIPS,
5616 .device = PCI_DEVICE_ID_PHILIPS_SAA7134,
5617 .subvendor = 0x0000,
5618 .subdevice = 0x4071,
5619 .driver_data = SAA7134_BOARD_BEHOLD_407FM,
5620 },{
5621 .vendor = PCI_VENDOR_ID_PHILIPS,
5622 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
5623 .subvendor = 0x0000,
5624 .subdevice = 0x4090,
5625 .driver_data = SAA7134_BOARD_BEHOLD_409,
5626 },{
5627 .vendor = PCI_VENDOR_ID_PHILIPS,
5628 .device = PCI_DEVICE_ID_PHILIPS_SAA7130,
5629 .subvendor = 0x0000,
5630 .subdevice = 0x5051,
5631 .driver_data = SAA7134_BOARD_BEHOLD_505FM,
5632 },{
5633 .vendor = PCI_VENDOR_ID_PHILIPS,
5634 .device = PCI_DEVICE_ID_PHILIPS_SAA7130,
5635 .subvendor = 0x0000,
5636 .subdevice = 0x505B,
5637 .driver_data = SAA7134_BOARD_BEHOLD_505FM,
5638 },{
5639 .vendor = PCI_VENDOR_ID_PHILIPS,
5640 .device = PCI_DEVICE_ID_PHILIPS_SAA7130,
5641 .subvendor = 0x5ace,
5642 .subdevice = 0x5050,
5643 .driver_data = SAA7134_BOARD_BEHOLD_505FM,
5644 },{
5645 .vendor = PCI_VENDOR_ID_PHILIPS,
5646 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
5647 .subvendor = 0x0000,
5648 .subdevice = 0x5071,
5649 .driver_data = SAA7134_BOARD_BEHOLD_507_9FM,
5650 },{
5651 .vendor = PCI_VENDOR_ID_PHILIPS,
5652 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
5653 .subvendor = 0x0000,
5654 .subdevice = 0x507B,
5655 .driver_data = SAA7134_BOARD_BEHOLD_507_9FM,
5656 },{
5657 .vendor = PCI_VENDOR_ID_PHILIPS,
5658 .device = PCI_DEVICE_ID_PHILIPS_SAA7134,
5659 .subvendor = 0x5ace,
5660 .subdevice = 0x5070,
5661 .driver_data = SAA7134_BOARD_BEHOLD_507_9FM,
5662 },{
5663 .vendor = PCI_VENDOR_ID_PHILIPS,
5664 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
5665 .subvendor = 0x5ace,
5666 .subdevice = 0x5090,
5667 .driver_data = SAA7134_BOARD_BEHOLD_507_9FM,
5668 },{
5669 .vendor = PCI_VENDOR_ID_PHILIPS,
5670 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
5671 .subvendor = 0x0000,
5672 .subdevice = 0x5201,
5673 .driver_data = SAA7134_BOARD_BEHOLD_COLUMBUS_TVFM,
5674 },{
5675 .vendor = PCI_VENDOR_ID_PHILIPS,
5676 .device = PCI_DEVICE_ID_PHILIPS_SAA7134,
5677 .subvendor = 0x5ace,
5678 .subdevice = 0x6070,
5679 .driver_data = SAA7134_BOARD_BEHOLD_607_9FM,
5680 },{
5681 .vendor = PCI_VENDOR_ID_PHILIPS,
5682 .device = PCI_DEVICE_ID_PHILIPS_SAA7134,
5683 .subvendor = 0x5ace,
5684 .subdevice = 0x6071,
5685 .driver_data = SAA7134_BOARD_BEHOLD_607_9FM,
5686 },{
5687 .vendor = PCI_VENDOR_ID_PHILIPS,
5688 .device = PCI_DEVICE_ID_PHILIPS_SAA7134,
5689 .subvendor = 0x5ace,
5690 .subdevice = 0x6072,
5691 .driver_data = SAA7134_BOARD_BEHOLD_607_9FM,
5692 },{
5693 .vendor = PCI_VENDOR_ID_PHILIPS,
5694 .device = PCI_DEVICE_ID_PHILIPS_SAA7134,
5695 .subvendor = 0x5ace,
5696 .subdevice = 0x6073,
5697 .driver_data = SAA7134_BOARD_BEHOLD_607_9FM,
5698 },{
5699 .vendor = PCI_VENDOR_ID_PHILIPS,
5700 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
5701 .subvendor = 0x5ace,
5702 .subdevice = 0x6090,
5703 .driver_data = SAA7134_BOARD_BEHOLD_607_9FM,
5704 },{
5705 .vendor = PCI_VENDOR_ID_PHILIPS,
5706 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
5707 .subvendor = 0x5ace,
5708 .subdevice = 0x6091,
5709 .driver_data = SAA7134_BOARD_BEHOLD_607_9FM,
5710 },{
5711 .vendor = PCI_VENDOR_ID_PHILIPS,
5712 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
5713 .subvendor = 0x5ace,
5714 .subdevice = 0x6092,
5715 .driver_data = SAA7134_BOARD_BEHOLD_607_9FM,
5716 },{
5717 .vendor = PCI_VENDOR_ID_PHILIPS,
5718 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
5719 .subvendor = 0x5ace,
5720 .subdevice = 0x6093,
5721 .driver_data = SAA7134_BOARD_BEHOLD_607_9FM,
5722 },{
5723 .vendor = PCI_VENDOR_ID_PHILIPS,
5724 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
5725 .subvendor = 0x5ace,
5726 .subdevice = 0x6190,
5727 .driver_data = SAA7134_BOARD_BEHOLD_M6,
5728 },{
5729 .vendor = PCI_VENDOR_ID_PHILIPS,
5730 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
5731 .subvendor = 0x5ace,
5732 .subdevice = 0x6193,
Dmitry Belimov878cf2a2008-06-10 14:22:00 -03005733 .driver_data = SAA7134_BOARD_BEHOLD_M6_EXTRA,
Igor Kuznetsov5fe95e02008-04-26 14:59:08 -03005734 }, {
5735 .vendor = PCI_VENDOR_ID_PHILIPS,
5736 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
5737 .subvendor = 0x5ace,
5738 .subdevice = 0x6191,
Dmitry Belimov878cf2a2008-06-10 14:22:00 -03005739 .driver_data = SAA7134_BOARD_BEHOLD_M63,
Andrey J. Melnikoff (TEMHOTA)e8018c92008-01-07 05:17:39 -03005740 },{
5741 .vendor = PCI_VENDOR_ID_PHILIPS,
Mauro Carvalho Chehab593f18c2007-10-07 02:17:09 -03005742 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
5743 .subvendor = 0x4e42,
5744 .subdevice = 0x3502,
Hermann Pitton4ba24372008-01-20 19:27:51 -03005745 .driver_data = SAA7134_BOARD_FLYDVBT_HYBRID_CARDBUS,
5746 }, {
5747 .vendor = PCI_VENDOR_ID_PHILIPS,
5748 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
5749 .subvendor = 0x1822, /*Twinhan Technology Co. Ltd*/
5750 .subdevice = 0x0022,
5751 .driver_data = SAA7134_BOARD_TWINHAN_DTV_DVB_3056,
Hermann Pitton7b5b3f12008-04-22 14:42:12 -03005752 }, {
5753 .vendor = PCI_VENDOR_ID_PHILIPS,
5754 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
5755 .subvendor = 0x16be,
5756 .subdevice = 0x0010, /* Medion version CTX953_V.1.4.3 */
5757 .driver_data = SAA7134_BOARD_CREATIX_CTX953,
Russell Kliese6a6179b62008-04-22 14:42:12 -03005758 }, {
5759 .vendor = PCI_VENDOR_ID_PHILIPS,
5760 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
5761 .subvendor = 0x1462, /* MSI */
5762 .subdevice = 0x8625, /* TV@nywhere A/D v1.1 */
5763 .driver_data = SAA7134_BOARD_MSI_TVANYWHERE_AD11,
Mauro Carvalho Chehab593f18c2007-10-07 02:17:09 -03005764 },{
Mauro Carvalho Chehabbc36a682008-04-22 14:45:27 -03005765 .vendor = PCI_VENDOR_ID_PHILIPS,
5766 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
5767 .subvendor = 0x1461, /* Avermedia Technologies Inc */
5768 .subdevice = 0xf436,
5769 .driver_data = SAA7134_BOARD_AVERMEDIA_CARDBUS_506,
5770 }, {
5771 .vendor = PCI_VENDOR_ID_PHILIPS,
5772 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
5773 .subvendor = 0x1461, /* Avermedia Technologies Inc */
5774 .subdevice = 0xf936,
5775 .driver_data = SAA7134_BOARD_AVERMEDIA_A16D,
5776 }, {
5777 .vendor = PCI_VENDOR_ID_PHILIPS,
5778 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
5779 .subvendor = 0x1461, /* Avermedia Technologies Inc */
5780 .subdevice = 0xa836,
5781 .driver_data = SAA7134_BOARD_AVERMEDIA_M115,
5782 }, {
5783 .vendor = PCI_VENDOR_ID_PHILIPS,
5784 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
5785 .subvendor = 0x185b,
5786 .subdevice = 0xc900,
5787 .driver_data = SAA7134_BOARD_VIDEOMATE_T750,
5788 }, {
Igor Kuznetsov02505272008-04-26 14:53:48 -03005789 .vendor = PCI_VENDOR_ID_PHILIPS,
Adam Gloverf689d902008-05-06 03:20:27 -03005790 .device = PCI_DEVICE_ID_PHILIPS_SAA7133, /* SAA7135HL */
5791 .subvendor = 0x1421,
5792 .subdevice = 0x0380,
5793 .driver_data = SAA7134_BOARD_ADS_INSTANT_HDTV_PCI,
5794 }, {
5795 .vendor = PCI_VENDOR_ID_PHILIPS,
Igor Kuznetsov02505272008-04-26 14:53:48 -03005796 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
Daniel Gimpelevichbfda3a02008-06-28 01:45:26 -03005797 .subvendor = 0x5169,
5798 .subdevice = 0x1502,
5799 .driver_data = SAA7134_BOARD_FLYTVPLATINUM_MINI,
5800 }, {
5801 .vendor = PCI_VENDOR_ID_PHILIPS,
5802 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
Igor Kuznetsov02505272008-04-26 14:53:48 -03005803 .subvendor = 0x5ace,
5804 .subdevice = 0x6290,
5805 .driver_data = SAA7134_BOARD_BEHOLD_H6,
5806 }, {
Massimo Piccionie2fc00c2008-07-11 13:48:02 -03005807 .vendor = PCI_VENDOR_ID_PHILIPS,
5808 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
5809 .subvendor = 0x1461, /* Avermedia Technologies Inc */
5810 .subdevice = 0xf636,
5811 .driver_data = SAA7134_BOARD_AVERMEDIA_M103,
5812 }, {
hermann pitton301e9d62008-09-14 17:49:14 -03005813 .vendor = PCI_VENDOR_ID_PHILIPS,
5814 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
5815 .subvendor = 0x1043,
5816 .subdevice = 0x4878, /* REV:1.02G */
5817 .driver_data = SAA7134_BOARD_ASUSTeK_TIGER_3IN1,
5818 }, {
Mauro Carvalho Chehab26d5f3a2008-12-07 13:19:29 -03005819 .vendor = PCI_VENDOR_ID_PHILIPS,
5820 .device = PCI_DEVICE_ID_PHILIPS_SAA7134,
5821 .subvendor = 0x17de,
5822 .subdevice = 0x7128,
5823 .driver_data = SAA7134_BOARD_KWORLD_PLUS_TV_ANALOG,
5824 }, {
Pham Thanh Nam4a87d7c2008-12-31 06:57:19 -03005825 .vendor = PCI_VENDOR_ID_PHILIPS,
5826 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
5827 .subvendor = 0x1461, /* Avermedia Technologies Inc */
5828 .subdevice = 0xf31d,
5829 .driver_data = SAA7134_BOARD_AVERMEDIA_GO_007_FM_PLUS,
5830
5831 }, {
Linus Torvalds1da177e2005-04-16 15:20:36 -07005832 /* --- boards without eeprom + subsystem ID --- */
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07005833 .vendor = PCI_VENDOR_ID_PHILIPS,
5834 .device = PCI_DEVICE_ID_PHILIPS_SAA7134,
5835 .subvendor = PCI_VENDOR_ID_PHILIPS,
Linus Torvalds1da177e2005-04-16 15:20:36 -07005836 .subdevice = 0,
5837 .driver_data = SAA7134_BOARD_NOAUTO,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07005838 },{
5839 .vendor = PCI_VENDOR_ID_PHILIPS,
5840 .device = PCI_DEVICE_ID_PHILIPS_SAA7130,
5841 .subvendor = PCI_VENDOR_ID_PHILIPS,
Linus Torvalds1da177e2005-04-16 15:20:36 -07005842 .subdevice = 0,
5843 .driver_data = SAA7134_BOARD_NOAUTO,
5844 },{
Linus Torvalds1da177e2005-04-16 15:20:36 -07005845 /* --- default catch --- */
5846 .vendor = PCI_VENDOR_ID_PHILIPS,
5847 .device = PCI_DEVICE_ID_PHILIPS_SAA7130,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07005848 .subvendor = PCI_ANY_ID,
5849 .subdevice = PCI_ANY_ID,
Linus Torvalds1da177e2005-04-16 15:20:36 -07005850 .driver_data = SAA7134_BOARD_UNKNOWN,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07005851 },{
Linus Torvalds1da177e2005-04-16 15:20:36 -07005852 .vendor = PCI_VENDOR_ID_PHILIPS,
5853 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07005854 .subvendor = PCI_ANY_ID,
5855 .subdevice = PCI_ANY_ID,
Linus Torvalds1da177e2005-04-16 15:20:36 -07005856 .driver_data = SAA7134_BOARD_UNKNOWN,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07005857 },{
Linus Torvalds1da177e2005-04-16 15:20:36 -07005858 .vendor = PCI_VENDOR_ID_PHILIPS,
5859 .device = PCI_DEVICE_ID_PHILIPS_SAA7134,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07005860 .subvendor = PCI_ANY_ID,
5861 .subdevice = PCI_ANY_ID,
Linus Torvalds1da177e2005-04-16 15:20:36 -07005862 .driver_data = SAA7134_BOARD_UNKNOWN,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07005863 },{
Linus Torvalds1da177e2005-04-16 15:20:36 -07005864 .vendor = PCI_VENDOR_ID_PHILIPS,
5865 .device = PCI_DEVICE_ID_PHILIPS_SAA7135,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07005866 .subvendor = PCI_ANY_ID,
5867 .subdevice = PCI_ANY_ID,
Linus Torvalds1da177e2005-04-16 15:20:36 -07005868 .driver_data = SAA7134_BOARD_UNKNOWN,
5869 },{
5870 /* --- end of list --- */
5871 }
5872};
5873MODULE_DEVICE_TABLE(pci, saa7134_pci_tbl);
5874
5875/* ----------------------------------------------------------- */
5876/* flyvideo tweaks */
5877
Linus Torvalds1da177e2005-04-16 15:20:36 -07005878
5879static void board_flyvideo(struct saa7134_dev *dev)
5880{
Linus Torvalds1da177e2005-04-16 15:20:36 -07005881 printk("%s: there are different flyvideo cards with different tuners\n"
5882 "%s: out there, you might have to use the tuner=<nr> insmod\n"
5883 "%s: option to override the default value.\n",
5884 dev->name, dev->name, dev->name);
5885}
5886
Mauro Carvalho Chehabbc36a682008-04-22 14:45:27 -03005887static int saa7134_xc2028_callback(struct saa7134_dev *dev,
5888 int command, int arg)
5889{
5890 switch (command) {
5891 case XC2028_TUNER_RESET:
Tim Farrington6e501a32008-06-15 13:33:42 -03005892 saa_andorl(SAA7134_GPIO_GPSTATUS0 >> 2, 0x00008000, 0x00000000);
5893 saa_andorl(SAA7134_GPIO_GPSTATUS0 >> 2, 0x00008000, 0x00008000);
5894 switch (dev->board) {
5895 case SAA7134_BOARD_AVERMEDIA_CARDBUS_506:
Massimo Piccionie2fc00c2008-07-11 13:48:02 -03005896 case SAA7134_BOARD_AVERMEDIA_M103:
Tim Farrington6e501a32008-06-15 13:33:42 -03005897 saa7134_set_gpio(dev, 23, 0);
5898 msleep(10);
5899 saa7134_set_gpio(dev, 23, 1);
5900 break;
5901 case SAA7134_BOARD_AVERMEDIA_A16D:
5902 saa7134_set_gpio(dev, 21, 0);
5903 msleep(10);
5904 saa7134_set_gpio(dev, 21, 1);
5905 break;
5906 }
5907 return 0;
Mauro Carvalho Chehabbc36a682008-04-22 14:45:27 -03005908 }
5909 return -EINVAL;
5910}
5911
5912
Michael Krufkyf9996c92009-02-28 17:45:17 -03005913static int saa7134_tda8290_827x_callback(struct saa7134_dev *dev,
5914 int command, int arg)
Mauro Carvalho Chehabbc36a682008-04-22 14:45:27 -03005915{
5916 u8 sync_control;
5917
5918 switch (command) {
5919 case 0: /* switch LNA gain through GPIO 22*/
5920 saa7134_set_gpio(dev, 22, arg) ;
5921 break;
5922 case 1: /* vsync output at GPIO22. 50 / 60Hz */
5923 saa_andorb(SAA7134_VIDEO_PORT_CTRL3, 0x80, 0x80);
5924 saa_andorb(SAA7134_VIDEO_PORT_CTRL6, 0x0f, 0x03);
5925 if (arg == 1)
5926 sync_control = 11;
5927 else
5928 sync_control = 17;
5929 saa_writeb(SAA7134_VGATE_START, sync_control);
5930 saa_writeb(SAA7134_VGATE_STOP, sync_control + 1);
5931 saa_andorb(SAA7134_MISC_VGATE_MSB, 0x03, 0x00);
5932 break;
5933 default:
5934 return -EINVAL;
5935 }
5936
5937 return 0;
5938}
5939
Michael Krufkyf9996c92009-02-28 17:45:17 -03005940static inline int saa7134_tda18271_hvr11x0_toggle_agc(struct saa7134_dev *dev,
5941 enum tda18271_mode mode)
5942{
5943 /* toggle AGC switch through GPIO 26 */
5944 switch (mode) {
5945 case TDA18271_ANALOG:
5946 saa7134_set_gpio(dev, 26, 0);
5947 break;
5948 case TDA18271_DIGITAL:
5949 saa7134_set_gpio(dev, 26, 1);
5950 break;
5951 default:
5952 return -EINVAL;
5953 }
5954 return 0;
5955}
5956
5957static int saa7134_tda8290_18271_callback(struct saa7134_dev *dev,
5958 int command, int arg)
5959{
5960 int ret = 0;
5961
5962 switch (command) {
5963 case TDA18271_CALLBACK_CMD_AGC_ENABLE: /* 0 */
5964 switch (dev->board) {
5965 case SAA7134_BOARD_HAUPPAUGE_HVR1150:
5966 case SAA7134_BOARD_HAUPPAUGE_HVR1110R3:
5967 ret = saa7134_tda18271_hvr11x0_toggle_agc(dev, arg);
5968 break;
5969 default:
5970 break;
5971 }
5972 break;
5973 default:
5974 ret = -EINVAL;
5975 break;
5976 }
5977 return ret;
5978}
5979
5980static int saa7134_tda8290_callback(struct saa7134_dev *dev,
5981 int command, int arg)
5982{
5983 int ret;
5984
5985 switch (dev->board) {
5986 case SAA7134_BOARD_HAUPPAUGE_HVR1150:
5987 case SAA7134_BOARD_HAUPPAUGE_HVR1110R3:
5988 /* tda8290 + tda18271 */
5989 ret = saa7134_tda8290_18271_callback(dev, command, arg);
5990 break;
5991 default:
5992 /* tda8290 + tda827x */
5993 ret = saa7134_tda8290_827x_callback(dev, command, arg);
5994 break;
5995 }
5996 return ret;
5997}
5998
Michael Krufkyd7cba042008-09-12 13:31:45 -03005999int saa7134_tuner_callback(void *priv, int component, int command, int arg)
Mauro Carvalho Chehabbc36a682008-04-22 14:45:27 -03006000{
Hartmut Hackmann0fea03f2008-04-22 14:46:10 -03006001 struct saa7134_dev *dev = priv;
Hartmut Hackmann7bff4b42008-04-22 14:46:08 -03006002 if (dev != NULL) {
6003 switch (dev->tuner_type) {
6004 case TUNER_PHILIPS_TDA8290:
6005 return saa7134_tda8290_callback(dev, command, arg);
6006 case TUNER_XC2028:
6007 return saa7134_xc2028_callback(dev, command, arg);
6008 }
Mauro Carvalho Chehab0be51b42008-04-22 14:46:10 -03006009 } else {
6010 printk(KERN_ERR "saa7134: Error - device struct undefined.\n");
6011 return -EINVAL;
Mauro Carvalho Chehabbc36a682008-04-22 14:45:27 -03006012 }
6013 return -EINVAL;
6014}
6015EXPORT_SYMBOL(saa7134_tuner_callback);
6016
Linus Torvalds1da177e2005-04-16 15:20:36 -07006017/* ----------------------------------------------------------- */
6018
Michael Krufky993efa72007-11-15 10:34:33 -03006019static void hauppauge_eeprom(struct saa7134_dev *dev, u8 *eeprom_data)
6020{
6021 struct tveeprom tv;
6022
6023 tveeprom_hauppauge_analog(&dev->i2c_client, &tv, eeprom_data);
6024
6025 /* Make sure we support the board model */
6026 switch (tv.model) {
6027 case 67019: /* WinTV-HVR1110 (Retail, IR Blaster, hybrid, FM, SVid/Comp, 3.5mm audio in) */
6028 case 67109: /* WinTV-HVR1000 (Retail, IR Receive, analog, no FM, SVid/Comp, 3.5mm audio in) */
Michael Krufkyf9996c92009-02-28 17:45:17 -03006029 case 67201: /* WinTV-HVR1150 (Retail, IR Receive, hybrid, FM, SVid/Comp, 3.5mm audio in) */
6030 case 67301: /* WinTV-HVR1000 (Retail, IR Receive, analog, no FM, SVid/Comp, 3.5mm audio in) */
6031 case 67209: /* WinTV-HVR1110 (Retail, IR Receive, hybrid, FM, SVid/Comp, 3.5mm audio in) */
Michael Krufky993efa72007-11-15 10:34:33 -03006032 case 67559: /* WinTV-HVR1110 (OEM, no IR, hybrid, FM, SVid/Comp, RCA aud) */
6033 case 67569: /* WinTV-HVR1110 (OEM, no IR, hybrid, FM) */
6034 case 67579: /* WinTV-HVR1110 (OEM, no IR, hybrid, no FM) */
6035 case 67589: /* WinTV-HVR1110 (OEM, no IR, hybrid, no FM, SVid/Comp, RCA aud) */
6036 case 67599: /* WinTV-HVR1110 (OEM, no IR, hybrid, no FM, SVid/Comp, RCA aud) */
Michael Krufkyf9996c92009-02-28 17:45:17 -03006037 case 67651: /* WinTV-HVR1150 (OEM, no IR, hybrid, FM, SVid/Comp, RCA aud) */
6038 case 67659: /* WinTV-HVR1110 (OEM, no IR, hybrid, FM, SVid/Comp, RCA aud) */
Michael Krufky993efa72007-11-15 10:34:33 -03006039 break;
6040 default:
6041 printk(KERN_WARNING "%s: warning: "
6042 "unknown hauppauge model #%d\n", dev->name, tv.model);
6043 break;
6044 }
6045
6046 printk(KERN_INFO "%s: hauppauge eeprom: model=%d\n",
6047 dev->name, tv.model);
6048}
6049
6050/* ----------------------------------------------------------- */
6051
Linus Torvalds1da177e2005-04-16 15:20:36 -07006052int saa7134_board_init1(struct saa7134_dev *dev)
6053{
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07006054 /* Always print gpio, often manufacturers encode tuner type and other info. */
Linus Torvalds1da177e2005-04-16 15:20:36 -07006055 saa_writel(SAA7134_GPIO_GPMODE0 >> 2, 0);
6056 dev->gpio_value = saa_readl(SAA7134_GPIO_GPSTATUS0 >> 2);
6057 printk(KERN_INFO "%s: board init: gpio is %x\n", dev->name, dev->gpio_value);
6058
6059 switch (dev->board) {
6060 case SAA7134_BOARD_FLYVIDEO2000:
6061 case SAA7134_BOARD_FLYVIDEO3000:
Zac Bowlingf49ba8d2006-06-19 19:49:20 -03006062 case SAA7134_BOARD_FLYVIDEO3000_NTSC:
Ricardo Cerqueiracb2444d2005-11-08 21:38:47 -08006063 dev->has_remote = SAA7134_REMOTE_GPIO;
Linus Torvalds1da177e2005-04-16 15:20:36 -07006064 board_flyvideo(dev);
6065 break;
Arnaud Patard6af90ab2005-11-08 21:36:55 -08006066 case SAA7134_BOARD_FLYTVPLATINUM_MINI2:
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07006067 case SAA7134_BOARD_FLYTVPLATINUM_FM:
Linus Torvalds1da177e2005-04-16 15:20:36 -07006068 case SAA7134_BOARD_CINERGY400:
6069 case SAA7134_BOARD_CINERGY600:
6070 case SAA7134_BOARD_CINERGY600_MK3:
6071 case SAA7134_BOARD_ECS_TVP3XP:
6072 case SAA7134_BOARD_ECS_TVP3XP_4CB5:
Simon Farnsworthb39423a2007-05-01 10:01:20 -03006073 case SAA7134_BOARD_ECS_TVP3XP_4CB6:
Linus Torvalds1da177e2005-04-16 15:20:36 -07006074 case SAA7134_BOARD_MD2819:
Mauro Carvalho Chehabac19ecc2005-06-23 22:05:09 -07006075 case SAA7134_BOARD_KWORLD_VSTREAM_XPERT:
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07006076 case SAA7134_BOARD_KWORLD_XPERT:
Linus Torvalds1da177e2005-04-16 15:20:36 -07006077 case SAA7134_BOARD_AVERMEDIA_STUDIO_305:
6078 case SAA7134_BOARD_AVERMEDIA_305:
Mauro Carvalho Chehabac19ecc2005-06-23 22:05:09 -07006079 case SAA7134_BOARD_AVERMEDIA_STUDIO_307:
Linus Torvalds1da177e2005-04-16 15:20:36 -07006080 case SAA7134_BOARD_AVERMEDIA_307:
Mikhail Fedotov3ac706d2006-10-06 20:23:47 -03006081 case SAA7134_BOARD_AVERMEDIA_STUDIO_507:
Mauro Carvalho Chehabac19ecc2005-06-23 22:05:09 -07006082 case SAA7134_BOARD_AVERMEDIA_GO_007_FM:
pasky@ucw.cz450efcf2006-11-12 14:22:32 -03006083 case SAA7134_BOARD_AVERMEDIA_777:
Mauro Carvalho Chehab36f6bb92008-06-26 17:03:00 -03006084 case SAA7134_BOARD_AVERMEDIA_M135A:
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07006085/* case SAA7134_BOARD_SABRENT_SBTTVFM: */ /* not finished yet */
Linus Torvalds1da177e2005-04-16 15:20:36 -07006086 case SAA7134_BOARD_VIDEOMATE_TV_PVR:
Nickolay V. Shmyrev2a9a9a82006-01-09 15:25:33 -02006087 case SAA7134_BOARD_VIDEOMATE_GOLD_PLUS:
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07006088 case SAA7134_BOARD_VIDEOMATE_TV_GOLD_PLUSII:
Nickolay V. Shmyrevfea095f2005-11-08 21:36:47 -08006089 case SAA7134_BOARD_VIDEOMATE_DVBT_300:
Michael Krufkyafce8922005-11-08 21:36:57 -08006090 case SAA7134_BOARD_VIDEOMATE_DVBT_200:
Hartmut Hackmanncbb94522006-10-30 20:00:16 -03006091 case SAA7134_BOARD_VIDEOMATE_DVBT_200A:
Mauro Carvalho Chehabbc36a682008-04-22 14:45:27 -03006092 case SAA7134_BOARD_VIDEOMATE_T750:
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07006093 case SAA7134_BOARD_MANLI_MTV001:
6094 case SAA7134_BOARD_MANLI_MTV002:
Nickolay V. Shmyreva8ff4172005-11-08 21:36:16 -08006095 case SAA7134_BOARD_BEHOLD_409FM:
Linus Torvalds1da177e2005-04-16 15:20:36 -07006096 case SAA7134_BOARD_AVACSSMARTTV:
Nickolay V. Shmyrev6b961442005-11-08 21:36:22 -08006097 case SAA7134_BOARD_GOTVIEW_7135:
James R. Webbdc2286c2005-11-08 21:37:00 -08006098 case SAA7134_BOARD_KWORLD_TERMINATOR:
Ricardo Cerqueira17ce1ff2005-11-08 21:38:47 -08006099 case SAA7134_BOARD_SEDNA_PC_TV_CARDBUS:
Giampiero Giancipoli3d8466e2006-02-07 06:49:09 -02006100 case SAA7134_BOARD_FLYDVBT_LR301:
Hermann Pitton91607232006-12-07 21:45:28 -03006101 case SAA7134_BOARD_ASUSTeK_P7131_DUAL:
Hartmut Hackmannf3eec0c02007-03-14 20:33:55 -03006102 case SAA7134_BOARD_ASUSTeK_P7131_HYBRID_LNA:
Hermann Pitton0b17d0e2008-07-12 12:27:59 -03006103 case SAA7134_BOARD_ASUSTeK_P7131_ANALOG:
Rudo Thomasa8029172006-02-27 00:08:46 -03006104 case SAA7134_BOARD_FLYDVBTDUO:
Michal Majchrowiczb04c1ba2006-09-13 16:42:42 -03006105 case SAA7134_BOARD_PROTEUS_2309:
pasky@ucw.cz29e0f1a2006-11-12 14:23:32 -03006106 case SAA7134_BOARD_AVERMEDIA_A16AR:
Juan Pablo Sormanic36c4592006-12-27 12:46:36 -03006107 case SAA7134_BOARD_ENCORE_ENLTV:
6108 case SAA7134_BOARD_ENCORE_ENLTV_FM:
Mauro Carvalho Chehabbf1ece62008-06-26 17:03:00 -03006109 case SAA7134_BOARD_ENCORE_ENLTV_FM53:
Tony Wan480f75a2007-05-11 11:33:50 -03006110 case SAA7134_BOARD_10MOONSTVMASTER3:
Andrey J. Melnikoff (TEMHOTA)e8018c92008-01-07 05:17:39 -03006111 case SAA7134_BOARD_BEHOLD_401:
6112 case SAA7134_BOARD_BEHOLD_403:
6113 case SAA7134_BOARD_BEHOLD_403FM:
6114 case SAA7134_BOARD_BEHOLD_405:
6115 case SAA7134_BOARD_BEHOLD_405FM:
6116 case SAA7134_BOARD_BEHOLD_407:
6117 case SAA7134_BOARD_BEHOLD_407FM:
6118 case SAA7134_BOARD_BEHOLD_409:
6119 case SAA7134_BOARD_BEHOLD_505FM:
6120 case SAA7134_BOARD_BEHOLD_507_9FM:
Adrian Pardinif0ba3562008-02-11 12:40:53 -03006121 case SAA7134_BOARD_GENIUS_TVGO_A11MCE:
Mauro Carvalho Chehab9b000192008-06-26 17:03:00 -03006122 case SAA7134_BOARD_REAL_ANGEL_220:
Mauro Carvalho Chehab26d5f3a2008-12-07 13:19:29 -03006123 case SAA7134_BOARD_KWORLD_PLUS_TV_ANALOG:
Pham Thanh Nam6a2d8022008-12-30 23:26:09 -03006124 case SAA7134_BOARD_AVERMEDIA_GO_007_FM_PLUS:
Ricardo Cerqueiracb2444d2005-11-08 21:38:47 -08006125 dev->has_remote = SAA7134_REMOTE_GPIO;
Linus Torvalds1da177e2005-04-16 15:20:36 -07006126 break;
Igor M. Liplianine2ac28f2006-08-08 09:10:10 -03006127 case SAA7134_BOARD_FLYDVBS_LR300:
6128 saa_writeb(SAA7134_GPIO_GPMODE3, 0x80);
6129 saa_writeb(SAA7134_GPIO_GPSTATUS2, 0x40);
6130 dev->has_remote = SAA7134_REMOTE_GPIO;
6131 break;
Linus Torvalds1da177e2005-04-16 15:20:36 -07006132 case SAA7134_BOARD_MD5044:
6133 printk("%s: seems there are two different versions of the MD5044\n"
Michael Krufkyfd2f2672006-03-11 16:21:36 -03006134 "%s: (with the same ID) out there. If sound doesn't work for\n"
6135 "%s: you try the audio_clock_override=0x200000 insmod option.\n",
6136 dev->name,dev->name,dev->name);
Linus Torvalds1da177e2005-04-16 15:20:36 -07006137 break;
6138 case SAA7134_BOARD_CINERGY400_CARDBUS:
6139 /* power-up tuner chip */
6140 saa_andorl(SAA7134_GPIO_GPMODE0 >> 2, 0x00040000, 0x00040000);
6141 saa_andorl(SAA7134_GPIO_GPSTATUS0 >> 2, 0x00040000, 0x00000000);
Mikhail Gusarov7bbbc0a2006-04-20 13:18:50 -03006142 break;
Hartmut Hackmanndf8cf702006-03-03 12:09:26 -03006143 case SAA7134_BOARD_PINNACLE_300I_DVBT_PAL:
6144 /* this turns the remote control chip off to work around a bug in it */
6145 saa_writeb(SAA7134_GPIO_GPMODE1, 0x80);
6146 saa_writeb(SAA7134_GPIO_GPSTATUS1, 0x80);
6147 break;
Pieter Palmerscf1c5d12005-11-08 21:37:40 -08006148 case SAA7134_BOARD_MONSTERTV_MOBILE:
6149 /* power-up tuner chip */
6150 saa_andorl(SAA7134_GPIO_GPMODE0 >> 2, 0x00040000, 0x00040000);
6151 saa_andorl(SAA7134_GPIO_GPSTATUS0 >> 2, 0x00040000, 0x00000004);
Linus Torvalds1da177e2005-04-16 15:20:36 -07006152 break;
Peter Missel10b7a902006-01-23 17:11:06 -02006153 case SAA7134_BOARD_FLYDVBT_DUO_CARDBUS:
Nickolay V. Shmyrev6b961442005-11-08 21:36:22 -08006154 /* turn the fan on */
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07006155 saa_writeb(SAA7134_GPIO_GPMODE3, 0x08);
6156 saa_writeb(SAA7134_GPIO_GPSTATUS3, 0x06);
6157 break;
Hartmut Hackmanndf42eaf2006-02-07 06:49:10 -02006158 case SAA7134_BOARD_ADS_DUO_CARDBUS_PTV331:
Hartmut Hackmannd95b8942006-03-27 19:39:30 -03006159 case SAA7134_BOARD_FLYDVBT_HYBRID_CARDBUS:
Hartmut Hackmann58ef4f92007-04-27 12:31:12 -03006160 saa_andorl(SAA7134_GPIO_GPMODE0 >> 2, 0x08000000, 0x08000000);
6161 saa_andorl(SAA7134_GPIO_GPSTATUS0 >> 2, 0x08000000, 0x00000000);
Hartmut Hackmanndf42eaf2006-02-07 06:49:10 -02006162 break;
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07006163 case SAA7134_BOARD_AVERMEDIA_CARDBUS:
Mauro Carvalho Chehabbc36a682008-04-22 14:45:27 -03006164 case SAA7134_BOARD_AVERMEDIA_M115:
Mauro Carvalho Chehab95a2fdb2008-03-28 17:52:44 -03006165 /* power-down tuner chip */
6166 saa_andorl(SAA7134_GPIO_GPMODE0 >> 2, 0xffffffff, 0);
6167 saa_andorl(SAA7134_GPIO_GPSTATUS0 >> 2, 0xffffffff, 0);
6168 msleep(10);
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07006169 /* power-up tuner chip */
6170 saa_andorl(SAA7134_GPIO_GPMODE0 >> 2, 0xffffffff, 0xffffffff);
6171 saa_andorl(SAA7134_GPIO_GPSTATUS0 >> 2, 0xffffffff, 0xffffffff);
Mauro Carvalho Chehab95a2fdb2008-03-28 17:52:44 -03006172 msleep(10);
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07006173 break;
Tim Farrington6e501a32008-06-15 13:33:42 -03006174 case SAA7134_BOARD_AVERMEDIA_CARDBUS_506:
Oldřich Jedličkacb3bf502009-02-12 03:43:11 -03006175 saa7134_set_gpio(dev, 23, 0);
6176 msleep(10);
6177 saa7134_set_gpio(dev, 23, 1);
6178 dev->has_remote = SAA7134_REMOTE_I2C;
6179 break;
Massimo Piccionie2fc00c2008-07-11 13:48:02 -03006180 case SAA7134_BOARD_AVERMEDIA_M103:
Tim Farrington6e501a32008-06-15 13:33:42 -03006181 saa7134_set_gpio(dev, 23, 0);
6182 msleep(10);
6183 saa7134_set_gpio(dev, 23, 1);
6184 break;
6185 case SAA7134_BOARD_AVERMEDIA_A16D:
6186 saa7134_set_gpio(dev, 21, 0);
6187 msleep(10);
6188 saa7134_set_gpio(dev, 21, 1);
6189 msleep(1);
6190 dev->has_remote = SAA7134_REMOTE_GPIO;
6191 break;
Dmitry Belimovb34dddb2008-04-23 14:09:08 -03006192 case SAA7134_BOARD_BEHOLD_COLUMBUS_TVFM:
6193 /* power-down tuner chip */
6194 saa_andorl(SAA7134_GPIO_GPMODE0 >> 2, 0x000A8004, 0x000A8004);
6195 saa_andorl(SAA7134_GPIO_GPSTATUS0 >> 2, 0x000A8004, 0);
6196 msleep(10);
6197 /* power-up tuner chip */
6198 saa_andorl(SAA7134_GPIO_GPMODE0 >> 2, 0x000A8004, 0x000A8004);
6199 saa_andorl(SAA7134_GPIO_GPSTATUS0 >> 2, 0x000A8004, 0x000A8004);
6200 msleep(10);
6201 /* remote via GPIO */
6202 dev->has_remote = SAA7134_REMOTE_GPIO;
6203 break;
Nickolay V. Shmyrevbb881f12005-11-08 21:36:35 -08006204 case SAA7134_BOARD_RTD_VFG7350:
6205
6206 /*
6207 * Make sure Production Test Register at offset 0x1D1 is cleared
6208 * to take chip out of test mode. Clearing bit 4 (TST_EN_AOUT)
6209 * prevents pin 105 from remaining low; keeping pin 105 low
6210 * continually resets the SAA6752 chip.
6211 */
6212
6213 saa_writeb (SAA7134_PRODUCTION_TEST_MODE, 0x00);
6214 break;
Michael Krufkyf9996c92009-02-28 17:45:17 -03006215 case SAA7134_BOARD_HAUPPAUGE_HVR1150:
6216 case SAA7134_BOARD_HAUPPAUGE_HVR1110R3:
6217 /* GPIO 26 high for digital, low for analog */
6218 saa7134_set_gpio(dev, 26, 0);
6219 msleep(1);
6220
6221 saa7134_set_gpio(dev, 22, 0);
6222 msleep(10);
6223 saa7134_set_gpio(dev, 22, 1);
6224 break;
Ricardo Cerqueiracb2444d2005-11-08 21:38:47 -08006225 /* i2c remotes */
6226 case SAA7134_BOARD_PINNACLE_PCTV_110i:
Hartmut Hackmann587d2fd2006-10-06 19:13:50 -03006227 case SAA7134_BOARD_PINNACLE_PCTV_310i:
Ricardo Cerqueiracb2444d2005-11-08 21:38:47 -08006228 case SAA7134_BOARD_UPMOST_PURPLE_TV:
Brian Rogersba340b42008-10-13 08:37:06 -03006229 case SAA7134_BOARD_MSI_TVATANYWHERE_PLUS:
Thomas Genty177aaaf2006-11-29 21:57:24 -03006230 case SAA7134_BOARD_HAUPPAUGE_HVR1110:
Andrey J. Melnikoff (TEMHOTA)e8018c92008-01-07 05:17:39 -03006231 case SAA7134_BOARD_BEHOLD_607_9FM:
6232 case SAA7134_BOARD_BEHOLD_M6:
Dmitry Belimov878cf2a2008-06-10 14:22:00 -03006233 case SAA7134_BOARD_BEHOLD_M63:
6234 case SAA7134_BOARD_BEHOLD_M6_EXTRA:
Dmitri Belimovf204ae42008-12-23 03:51:38 -03006235 case SAA7134_BOARD_BEHOLD_H6:
Ricardo Cerqueiracb2444d2005-11-08 21:38:47 -08006236 dev->has_remote = SAA7134_REMOTE_I2C;
6237 break;
Rickard Osser68593af2006-03-11 17:14:12 -03006238 case SAA7134_BOARD_AVERMEDIA_A169_B:
Michael Krufky12a219d2006-03-14 16:07:42 -03006239 printk("%s: %s: dual saa713x broadcast decoders\n"
Rickard Osser68593af2006-03-11 17:14:12 -03006240 "%s: Sorry, none of the inputs to this chip are supported yet.\n"
6241 "%s: Dual decoder functionality is disabled for now, use the other chip.\n",
Michael Krufky12a219d2006-03-14 16:07:42 -03006242 dev->name,card(dev).name,dev->name,dev->name);
Rickard Osser68593af2006-03-11 17:14:12 -03006243 break;
Markus Rechbergere95d3172007-04-27 12:31:19 -03006244 case SAA7134_BOARD_AVERMEDIA_M102:
6245 /* enable tuner */
Albert Grahamd2761f22007-12-09 09:44:38 -03006246 dev->has_remote = SAA7134_REMOTE_GPIO;
Markus Rechbergere95d3172007-04-27 12:31:19 -03006247 saa_andorl(SAA7134_GPIO_GPMODE0 >> 2, 0x8c040007, 0x8c040007);
6248 saa_andorl(SAA7134_GPIO_GPSTATUS0 >> 2, 0x0c0007cd, 0x0c0007cd);
6249 break;
Matthias Schwarzottfc9d8ed2008-04-08 21:45:08 -03006250 case SAA7134_BOARD_AVERMEDIA_A700_HYBRID:
Matthias Schwarzott04574182009-02-24 12:35:16 -03006251 printk("%s: %s: hybrid analog/dvb card\n"
6252 "%s: Sorry, of the analog inputs, only analog s-video and composite "
6253 "are supported for now.\n",
6254 dev->name, card(dev).name, dev->name);
6255 case SAA7134_BOARD_AVERMEDIA_A700_PRO:
Matthias Schwarzottfc9d8ed2008-04-08 21:45:08 -03006256 /* write windows gpio values */
6257 saa_andorl(SAA7134_GPIO_GPMODE0 >> 2, 0x80040100, 0x80040100);
6258 saa_andorl(SAA7134_GPIO_GPSTATUS0 >> 2, 0x80040100, 0x00040100);
Matthias Schwarzottfc9d8ed2008-04-08 21:45:08 -03006259 break;
Linus Torvalds1da177e2005-04-16 15:20:36 -07006260 }
Linus Torvalds1da177e2005-04-16 15:20:36 -07006261 return 0;
6262}
6263
Mauro Carvalho Chehabc117d052008-04-26 14:05:58 -03006264static void saa7134_tuner_setup(struct saa7134_dev *dev)
6265{
6266 struct tuner_setup tun_setup;
6267 unsigned int mode_mask = T_RADIO |
6268 T_ANALOG_TV |
6269 T_DIGITAL_TV;
6270
6271 memset(&tun_setup, 0, sizeof(tun_setup));
6272 tun_setup.tuner_callback = saa7134_tuner_callback;
6273
6274 if (saa7134_boards[dev->board].radio_type != UNSET) {
6275 tun_setup.type = saa7134_boards[dev->board].radio_type;
6276 tun_setup.addr = saa7134_boards[dev->board].radio_addr;
6277
6278 tun_setup.mode_mask = T_RADIO;
6279
Hans Verkuilfac69862009-01-17 12:17:14 -03006280 saa_call_all(dev, tuner, s_type_addr, &tun_setup);
Mauro Carvalho Chehabc117d052008-04-26 14:05:58 -03006281 mode_mask &= ~T_RADIO;
6282 }
6283
6284 if ((dev->tuner_type != TUNER_ABSENT) && (dev->tuner_type != UNSET)) {
6285 tun_setup.type = dev->tuner_type;
6286 tun_setup.addr = dev->tuner_addr;
6287 tun_setup.config = saa7134_boards[dev->board].tuner_config;
6288 tun_setup.tuner_callback = saa7134_tuner_callback;
6289
6290 tun_setup.mode_mask = mode_mask;
6291
Hans Verkuilfac69862009-01-17 12:17:14 -03006292 saa_call_all(dev, tuner, s_type_addr, &tun_setup);
Mauro Carvalho Chehabc117d052008-04-26 14:05:58 -03006293 }
6294
6295 if (dev->tda9887_conf) {
6296 struct v4l2_priv_tun_config tda9887_cfg;
6297
6298 tda9887_cfg.tuner = TUNER_TDA9887;
6299 tda9887_cfg.priv = &dev->tda9887_conf;
6300
Hans Verkuilfac69862009-01-17 12:17:14 -03006301 saa_call_all(dev, tuner, s_config, &tda9887_cfg);
Mauro Carvalho Chehabc117d052008-04-26 14:05:58 -03006302 }
6303
6304 if (dev->tuner_type == TUNER_XC2028) {
6305 struct v4l2_priv_tun_config xc2028_cfg;
6306 struct xc2028_ctrl ctl;
6307
Oldrich Jedlickabdf398e2008-11-13 22:03:00 -03006308 memset(&xc2028_cfg, 0, sizeof(xc2028_cfg));
Mauro Carvalho Chehabc117d052008-04-26 14:05:58 -03006309 memset(&ctl, 0, sizeof(ctl));
6310
6311 ctl.fname = XC2028_DEFAULT_FIRMWARE;
6312 ctl.max_len = 64;
6313
6314 switch (dev->board) {
6315 case SAA7134_BOARD_AVERMEDIA_A16D:
Tim Farrington6e501a32008-06-15 13:33:42 -03006316 case SAA7134_BOARD_AVERMEDIA_CARDBUS_506:
Massimo Piccionie2fc00c2008-07-11 13:48:02 -03006317 case SAA7134_BOARD_AVERMEDIA_M103:
Mauro Carvalho Chehabc117d052008-04-26 14:05:58 -03006318 ctl.demod = XC3028_FE_ZARLINK456;
6319 break;
6320 default:
6321 ctl.demod = XC3028_FE_OREN538;
6322 ctl.mts = 1;
6323 }
6324
6325 xc2028_cfg.tuner = TUNER_XC2028;
6326 xc2028_cfg.priv = &ctl;
6327
Hans Verkuilfac69862009-01-17 12:17:14 -03006328 saa_call_all(dev, tuner, s_config, &xc2028_cfg);
Mauro Carvalho Chehabc117d052008-04-26 14:05:58 -03006329 }
6330}
6331
Linus Torvalds1da177e2005-04-16 15:20:36 -07006332/* stuff which needs working i2c */
6333int saa7134_board_init2(struct saa7134_dev *dev)
6334{
6335 unsigned char buf;
6336 int board;
Mauro Carvalho Chehabc117d052008-04-26 14:05:58 -03006337
Mauro Carvalho Chehabb9348352009-02-08 09:33:15 -03006338 /* Put here the code that enables the chips that are needed
6339 for analog mode and doesn't depend on the tuner attachment.
6340 It is also a good idea to get tuner type from eeprom, etc before
6341 initializing tuner, since we can avoid loading tuner driver
6342 on devices that has TUNER_ABSENT
6343 */
Linus Torvalds1da177e2005-04-16 15:20:36 -07006344 switch (dev->board) {
6345 case SAA7134_BOARD_BMK_MPEX_NOTUNER:
6346 case SAA7134_BOARD_BMK_MPEX_TUNER:
Mauro Carvalho Chehabb9348352009-02-08 09:33:15 -03006347 /* Checks if the device has a tuner at 0x60 addr
6348 If the device doesn't have a tuner, TUNER_ABSENT
6349 will be used at tuner_type, avoiding loading tuner
6350 without needing it
6351 */
Linus Torvalds1da177e2005-04-16 15:20:36 -07006352 dev->i2c_client.addr = 0x60;
Mauro Carvalho Chehabc117d052008-04-26 14:05:58 -03006353 board = (i2c_master_recv(&dev->i2c_client, &buf, 0) < 0)
Linus Torvalds1da177e2005-04-16 15:20:36 -07006354 ? SAA7134_BOARD_BMK_MPEX_NOTUNER
6355 : SAA7134_BOARD_BMK_MPEX_TUNER;
6356 if (board == dev->board)
6357 break;
6358 dev->board = board;
6359 printk("%s: board type fixup: %s\n", dev->name,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07006360 saa7134_boards[dev->board].name);
Linus Torvalds1da177e2005-04-16 15:20:36 -07006361 dev->tuner_type = saa7134_boards[dev->board].tuner_type;
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07006362
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07006363 break;
Hartmut Hackmann2cf36ac2005-11-08 21:36:32 -08006364 case SAA7134_BOARD_MD7134:
Mauro Carvalho Chehabc117d052008-04-26 14:05:58 -03006365 {
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07006366 u8 subaddr;
6367 u8 data[3];
6368 int ret, tuner_t;
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07006369 struct i2c_msg msg[] = {{.addr=0x50, .flags=0, .buf=&subaddr, .len = 1},
6370 {.addr=0x50, .flags=I2C_M_RD, .buf=data, .len = 3}};
Mauro Carvalho Chehabb9348352009-02-08 09:33:15 -03006371
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07006372 subaddr= 0x14;
6373 tuner_t = 0;
Mauro Carvalho Chehabb9348352009-02-08 09:33:15 -03006374
6375 /* Retrieve device data from eeprom, checking for the
6376 proper tuner_type.
6377 */
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07006378 ret = i2c_transfer(&dev->i2c_adap, msg, 2);
6379 if (ret != 2) {
6380 printk(KERN_ERR "EEPROM read failure\n");
6381 } else if ((data[0] != 0) && (data[0] != 0xff)) {
6382 /* old config structure */
6383 subaddr = data[0] + 2;
6384 msg[1].len = 2;
6385 i2c_transfer(&dev->i2c_adap, msg, 2);
6386 tuner_t = (data[0] << 8) + data[1];
6387 switch (tuner_t){
6388 case 0x0103:
6389 dev->tuner_type = TUNER_PHILIPS_PAL;
6390 break;
6391 case 0x010C:
6392 dev->tuner_type = TUNER_PHILIPS_FM1216ME_MK3;
6393 break;
6394 default:
6395 printk(KERN_ERR "%s Cant determine tuner type %x from EEPROM\n", dev->name, tuner_t);
6396 }
6397 } else if ((data[1] != 0) && (data[1] != 0xff)) {
6398 /* new config structure */
6399 subaddr = data[1] + 1;
6400 msg[1].len = 1;
6401 i2c_transfer(&dev->i2c_adap, msg, 2);
6402 subaddr = data[0] + 1;
6403 msg[1].len = 2;
6404 i2c_transfer(&dev->i2c_adap, msg, 2);
6405 tuner_t = (data[1] << 8) + data[0];
6406 switch (tuner_t) {
6407 case 0x0005:
6408 dev->tuner_type = TUNER_PHILIPS_FM1216ME_MK3;
6409 break;
6410 case 0x001d:
6411 dev->tuner_type = TUNER_PHILIPS_FMD1216ME_MK3;
6412 printk(KERN_INFO "%s Board has DVB-T\n", dev->name);
6413 break;
6414 default:
6415 printk(KERN_ERR "%s Cant determine tuner type %x from EEPROM\n", dev->name, tuner_t);
6416 }
6417 } else {
6418 printk(KERN_ERR "%s unexpected config structure\n", dev->name);
6419 }
6420
6421 printk(KERN_INFO "%s Tuner type is %d\n", dev->name, dev->tuner_type);
Linus Torvalds1da177e2005-04-16 15:20:36 -07006422 break;
Mauro Carvalho Chehabc117d052008-04-26 14:05:58 -03006423 }
Hartmut Hackmann2cf36ac2005-11-08 21:36:32 -08006424 case SAA7134_BOARD_PHILIPS_EUROPA:
Hartmut Hackmann6ab465a2008-04-22 14:42:11 -03006425 if (dev->autodetected && (dev->eedata[0x41] == 0x1c)) {
6426 /* Reconfigure board as Snake reference design */
6427 dev->board = SAA7134_BOARD_PHILIPS_SNAKE;
6428 dev->tuner_type = saa7134_boards[dev->board].tuner_type;
6429 printk(KERN_INFO "%s: Reconfigured board as %s\n",
6430 dev->name, saa7134_boards[dev->board].name);
6431 break;
6432 }
Mauro Carvalho Chehabb9348352009-02-08 09:33:15 -03006433 /* break intentionally omitted */
Hartmut Hackmann2cf36ac2005-11-08 21:36:32 -08006434 case SAA7134_BOARD_VIDEOMATE_DVBT_300:
Hartmut Hackmanncf146ca2006-10-02 20:49:24 -03006435 case SAA7134_BOARD_ASUS_EUROPA2_HYBRID:
Mauro Carvalho Chehabc117d052008-04-26 14:05:58 -03006436 {
6437
Mauro Carvalho Chehabb9348352009-02-08 09:33:15 -03006438 /* The Philips EUROPA based hybrid boards have the tuner
6439 connected through the channel decoder. We have to make it
6440 transparent to find it
Mauro Carvalho Chehab4ac97912005-11-08 21:37:43 -08006441 */
Hartmut Hackmann2cf36ac2005-11-08 21:36:32 -08006442 u8 data[] = { 0x07, 0x02};
6443 struct i2c_msg msg = {.addr=0x08, .flags=0, .buf=data, .len = sizeof(data)};
6444 i2c_transfer(&dev->i2c_adap, &msg, 1);
6445
Hartmut Hackmann2cf36ac2005-11-08 21:36:32 -08006446 break;
Mauro Carvalho Chehabc117d052008-04-26 14:05:58 -03006447 }
Hartmut Hackmann90e9df72005-11-08 21:38:42 -08006448 case SAA7134_BOARD_PHILIPS_TIGER:
Hartmut Hackmann58ef4f92007-04-27 12:31:12 -03006449 case SAA7134_BOARD_PHILIPS_TIGER_S:
Mauro Carvalho Chehabc117d052008-04-26 14:05:58 -03006450 {
Hartmut Hackmann58ef4f92007-04-27 12:31:12 -03006451 u8 data[] = { 0x3c, 0x33, 0x60};
Hartmut Hackmann58ef4f92007-04-27 12:31:12 -03006452 struct i2c_msg msg = {.addr=0x08, .flags=0, .buf=data, .len = sizeof(data)};
Mauro Carvalho Chehabc117d052008-04-26 14:05:58 -03006453 if (dev->autodetected && (dev->eedata[0x49] == 0x50)) {
Hartmut Hackmann58ef4f92007-04-27 12:31:12 -03006454 dev->board = SAA7134_BOARD_PHILIPS_TIGER_S;
6455 printk(KERN_INFO "%s: Reconfigured board as %s\n",
6456 dev->name, saa7134_boards[dev->board].name);
6457 }
Mauro Carvalho Chehabc117d052008-04-26 14:05:58 -03006458 if (dev->board == SAA7134_BOARD_PHILIPS_TIGER_S) {
6459 dev->tuner_type = TUNER_PHILIPS_TDA8290;
Hartmut Hackmann58ef4f92007-04-27 12:31:12 -03006460
Hartmut Hackmann58ef4f92007-04-27 12:31:12 -03006461 data[2] = 0x68;
Mauro Carvalho Chehabc117d052008-04-26 14:05:58 -03006462 i2c_transfer(&dev->i2c_adap, &msg, 1);
Mauro Carvalho Chehabb9348352009-02-08 09:33:15 -03006463 break;
Hartmut Hackmann58ef4f92007-04-27 12:31:12 -03006464 }
6465 i2c_transfer(&dev->i2c_adap, &msg, 1);
Hartmut Hackmann58ef4f92007-04-27 12:31:12 -03006466 break;
Mauro Carvalho Chehabc117d052008-04-26 14:05:58 -03006467 }
Mauro Carvalho Chehabb9348352009-02-08 09:33:15 -03006468 case SAA7134_BOARD_ASUSTeK_TVFM7135:
6469 /* The card below is detected as card=53, but is different */
Hermann Pitton0b17d0e2008-07-12 12:27:59 -03006470 if (dev->autodetected && (dev->eedata[0x27] == 0x03)) {
6471 dev->board = SAA7134_BOARD_ASUSTeK_P7131_ANALOG;
6472 printk(KERN_INFO "%s: P7131 analog only, using "
6473 "entry of %s\n",
6474 dev->name, saa7134_boards[dev->board].name);
6475 }
6476 break;
Michael Krufkyf9996c92009-02-28 17:45:17 -03006477 case SAA7134_BOARD_HAUPPAUGE_HVR1150:
6478 case SAA7134_BOARD_HAUPPAUGE_HVR1110R3:
6479 hauppauge_eeprom(dev, dev->eedata+0x80);
6480 break;
Michael Krufky993efa72007-11-15 10:34:33 -03006481 case SAA7134_BOARD_HAUPPAUGE_HVR1110:
6482 hauppauge_eeprom(dev, dev->eedata+0x80);
6483 /* break intentionally omitted */
Hartmut Hackmann587d2fd2006-10-06 19:13:50 -03006484 case SAA7134_BOARD_PINNACLE_PCTV_310i:
Simon Farnsworthb39423a2007-05-01 10:01:20 -03006485 case SAA7134_BOARD_KWORLD_DVBT_210:
Peter Hartshorn3dfb7292006-02-07 06:49:13 -02006486 case SAA7134_BOARD_TEVION_DVBT_220RF:
Hermann Pitton028165a2008-10-04 21:37:36 -03006487 case SAA7134_BOARD_ASUSTeK_TIGER:
Hartmut Hackmannd4b0aba2005-11-08 21:38:44 -08006488 case SAA7134_BOARD_ASUSTeK_P7131_DUAL:
Hartmut Hackmannf3eec0c02007-03-14 20:33:55 -03006489 case SAA7134_BOARD_ASUSTeK_P7131_HYBRID_LNA:
Hartmut Hackmann5eda2272006-08-07 14:03:32 -03006490 case SAA7134_BOARD_MEDION_MD8800_QUADRO:
Hermann Pitton4ba24372008-01-20 19:27:51 -03006491 case SAA7134_BOARD_AVERMEDIA_SUPER_007:
6492 case SAA7134_BOARD_TWINHAN_DTV_DVB_3056:
Hermann Pitton7b5b3f12008-04-22 14:42:12 -03006493 case SAA7134_BOARD_CREATIX_CTX953:
Mauro Carvalho Chehabc117d052008-04-26 14:05:58 -03006494 {
Peter Hartshorn3dfb7292006-02-07 06:49:13 -02006495 /* this is a hybrid board, initialize to analog mode
6496 * and configure firmware eeprom address
6497 */
Hartmut Hackmann58ef4f92007-04-27 12:31:12 -03006498 u8 data[] = { 0x3c, 0x33, 0x60};
Hartmut Hackmann90e9df72005-11-08 21:38:42 -08006499 struct i2c_msg msg = {.addr=0x08, .flags=0, .buf=data, .len = sizeof(data)};
6500 i2c_transfer(&dev->i2c_adap, &msg, 1);
Hartmut Hackmann90e9df72005-11-08 21:38:42 -08006501 break;
Mauro Carvalho Chehabc117d052008-04-26 14:05:58 -03006502 }
hermann pitton301e9d62008-09-14 17:49:14 -03006503 case SAA7134_BOARD_ASUSTeK_TIGER_3IN1:
6504 {
6505 u8 data[] = { 0x3c, 0x33, 0x60};
6506 struct i2c_msg msg = {.addr = 0x0b, .flags = 0, .buf = data,
6507 .len = sizeof(data)};
6508 i2c_transfer(&dev->i2c_adap, &msg, 1);
6509 break;
6510 }
Nico Sabbi420f32f2006-03-03 12:11:28 -03006511 case SAA7134_BOARD_FLYDVB_TRIO:
Mauro Carvalho Chehabc117d052008-04-26 14:05:58 -03006512 {
Hartmut Hackmann293cdab2006-02-27 21:08:07 -03006513 u8 data[] = { 0x3c, 0x33, 0x62};
6514 struct i2c_msg msg = {.addr=0x09, .flags=0, .buf=data, .len = sizeof(data)};
6515 i2c_transfer(&dev->i2c_adap, &msg, 1);
Hartmut Hackmann293cdab2006-02-27 21:08:07 -03006516 break;
Mauro Carvalho Chehabc117d052008-04-26 14:05:58 -03006517 }
Hartmut Hackmanndf42eaf2006-02-07 06:49:10 -02006518 case SAA7134_BOARD_ADS_DUO_CARDBUS_PTV331:
Hartmut Hackmannd95b8942006-03-27 19:39:30 -03006519 case SAA7134_BOARD_FLYDVBT_HYBRID_CARDBUS:
Mauro Carvalho Chehabc117d052008-04-26 14:05:58 -03006520 {
Hartmut Hackmann58ef4f92007-04-27 12:31:12 -03006521 /* initialize analog mode */
Hartmut Hackmann58ef4f92007-04-27 12:31:12 -03006522 u8 data[] = { 0x3c, 0x33, 0x6a};
Hartmut Hackmanndf42eaf2006-02-07 06:49:10 -02006523 struct i2c_msg msg = {.addr=0x08, .flags=0, .buf=data, .len = sizeof(data)};
6524 i2c_transfer(&dev->i2c_adap, &msg, 1);
Hartmut Hackmanndf42eaf2006-02-07 06:49:10 -02006525 break;
Mauro Carvalho Chehabc117d052008-04-26 14:05:58 -03006526 }
Hartmut Hackmann550a9a52006-11-15 21:31:54 -03006527 case SAA7134_BOARD_CINERGY_HT_PCMCIA:
Michael Krufky9de271e2007-01-16 18:36:40 -03006528 case SAA7134_BOARD_CINERGY_HT_PCI:
Mauro Carvalho Chehabc117d052008-04-26 14:05:58 -03006529 {
Hartmut Hackmann58ef4f92007-04-27 12:31:12 -03006530 /* initialize analog mode */
Hartmut Hackmann58ef4f92007-04-27 12:31:12 -03006531 u8 data[] = { 0x3c, 0x33, 0x68};
Hartmut Hackmann550a9a52006-11-15 21:31:54 -03006532 struct i2c_msg msg = {.addr=0x08, .flags=0, .buf=data, .len = sizeof(data)};
6533 i2c_transfer(&dev->i2c_adap, &msg, 1);
Hartmut Hackmann550a9a52006-11-15 21:31:54 -03006534 break;
Mauro Carvalho Chehabc117d052008-04-26 14:05:58 -03006535 }
Hartmut Hackmanncbb94522006-10-30 20:00:16 -03006536 case SAA7134_BOARD_VIDEOMATE_DVBT_200:
6537 case SAA7134_BOARD_VIDEOMATE_DVBT_200A:
6538 /* The T200 and the T200A share the same pci id. Consequently,
6539 * we are going to query eeprom to try to find out which one we
6540 * are actually looking at. */
6541
6542 /* Don't do this if the board was specifically selected with an
6543 * insmod option or if we have the default configuration T200*/
Mauro Carvalho Chehabb9348352009-02-08 09:33:15 -03006544 if (!dev->autodetected || (dev->eedata[0x41] == 0xd0))
Hartmut Hackmanncbb94522006-10-30 20:00:16 -03006545 break;
Mauro Carvalho Chehabb9348352009-02-08 09:33:15 -03006546 if (dev->eedata[0x41] == 0x02) {
Hartmut Hackmanncbb94522006-10-30 20:00:16 -03006547 /* Reconfigure board as T200A */
6548 dev->board = SAA7134_BOARD_VIDEOMATE_DVBT_200A;
6549 dev->tuner_type = saa7134_boards[dev->board].tuner_type;
6550 dev->tda9887_conf = saa7134_boards[dev->board].tda9887_conf;
6551 printk(KERN_INFO "%s: Reconfigured board as %s\n",
6552 dev->name, saa7134_boards[dev->board].name);
6553 } else {
6554 printk(KERN_WARNING "%s: Unexpected tuner type info: %x in eeprom\n",
6555 dev->name, dev->eedata[0x41]);
6556 break;
6557 }
6558 break;
Mauro Carvalho Chehabb9348352009-02-08 09:33:15 -03006559 case SAA7134_BOARD_ADS_INSTANT_HDTV_PCI:
6560 case SAA7134_BOARD_KWORLD_ATSC110:
6561 {
6562 struct i2c_msg msg = { .addr = 0x0a, .flags = 0 };
6563 int i;
6564 static u8 buffer[][2] = {
6565 { 0x10, 0x12 },
6566 { 0x13, 0x04 },
6567 { 0x16, 0x00 },
6568 { 0x14, 0x04 },
6569 { 0x17, 0x00 },
6570 };
6571
6572 for (i = 0; i < ARRAY_SIZE(buffer); i++) {
6573 msg.buf = &buffer[i][0];
6574 msg.len = ARRAY_SIZE(buffer[0]);
6575 if (i2c_transfer(&dev->i2c_adap, &msg, 1) != 1)
6576 printk(KERN_WARNING
6577 "%s: Unable to enable tuner(%i).\n",
6578 dev->name, i);
6579 }
6580 break;
6581 }
6582 } /* switch() */
6583
6584 /* initialize tuner */
6585 if (TUNER_ABSENT != dev->tuner_type) {
6586 int has_demod = (dev->tda9887_conf & TDA9887_PRESENT);
6587
6588 /* Note: radio tuner address is always filled in,
6589 so we do not need to probe for a radio tuner device. */
6590 if (dev->radio_type != UNSET)
6591 v4l2_i2c_new_subdev(&dev->i2c_adap,
6592 "tuner", "tuner", dev->radio_addr);
6593 if (has_demod)
6594 v4l2_i2c_new_probed_subdev(&dev->i2c_adap, "tuner",
6595 "tuner", v4l2_i2c_tuner_addrs(ADDRS_DEMOD));
6596 if (dev->tuner_addr == ADDR_UNSET) {
6597 enum v4l2_i2c_tuner_type type =
6598 has_demod ? ADDRS_TV_WITH_DEMOD : ADDRS_TV;
6599
6600 v4l2_i2c_new_probed_subdev(&dev->i2c_adap, "tuner",
6601 "tuner", v4l2_i2c_tuner_addrs(type));
6602 } else {
6603 v4l2_i2c_new_subdev(&dev->i2c_adap,
6604 "tuner", "tuner", dev->tuner_addr);
6605 }
6606 }
6607
6608 saa7134_tuner_setup(dev);
6609
6610 switch (dev->board) {
Dmitry Belimovb34dddb2008-04-23 14:09:08 -03006611 case SAA7134_BOARD_BEHOLD_COLUMBUS_TVFM:
Mauro Carvalho Chehabc117d052008-04-26 14:05:58 -03006612 {
Dmitry Belimovb34dddb2008-04-23 14:09:08 -03006613 struct v4l2_priv_tun_config tea5767_cfg;
6614 struct tea5767_ctrl ctl;
6615
6616 dev->i2c_client.addr = 0xC0;
6617 /* set TEA5767(analog FM) defines */
6618 memset(&ctl, 0, sizeof(ctl));
6619 ctl.xtal_freq = TEA5767_HIGH_LO_13MHz;
6620 tea5767_cfg.tuner = TUNER_TEA5767;
6621 tea5767_cfg.priv = &ctl;
Hans Verkuilfac69862009-01-17 12:17:14 -03006622 saa_call_all(dev, tuner, s_config, &tea5767_cfg);
Dmitry Belimovb34dddb2008-04-23 14:09:08 -03006623 break;
Linus Torvalds1da177e2005-04-16 15:20:36 -07006624 }
Mauro Carvalho Chehabc117d052008-04-26 14:05:58 -03006625 } /* switch() */
Mauro Carvalho Chehabbc36a682008-04-22 14:45:27 -03006626
Linus Torvalds1da177e2005-04-16 15:20:36 -07006627 return 0;
6628}