blob: 74467c18e69a135f1fe79a42a2e7e0892f8ea5de [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"
Dmitri Belimov2012c872009-08-26 01:01:12 -030035#include "xc5000.h"
Linus Torvalds1da177e2005-04-16 15:20:36 -070036
37/* commly used strings */
38static char name_mute[] = "mute";
39static char name_radio[] = "Radio";
40static char name_tv[] = "Television";
41static char name_tv_mono[] = "TV (mono only)";
Stas Sergeevf438d972007-09-17 15:34:09 -030042static char name_comp[] = "Composite";
Linus Torvalds1da177e2005-04-16 15:20:36 -070043static char name_comp1[] = "Composite1";
44static char name_comp2[] = "Composite2";
45static char name_comp3[] = "Composite3";
46static char name_comp4[] = "Composite4";
47static char name_svideo[] = "S-Video";
48
49/* ------------------------------------------------------------------ */
50/* board config info */
51
Mauro Carvalho Chehabc117d052008-04-26 14:05:58 -030052/* If radio_type !=UNSET, radio_addr should be specified
53 */
54
Linus Torvalds1da177e2005-04-16 15:20:36 -070055struct saa7134_board saa7134_boards[] = {
56 [SAA7134_BOARD_UNKNOWN] = {
57 .name = "UNKNOWN/GENERIC",
58 .audio_clock = 0x00187de7,
59 .tuner_type = TUNER_ABSENT,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -070060 .radio_type = UNSET,
61 .tuner_addr = ADDR_UNSET,
62 .radio_addr = ADDR_UNSET,
63
Linus Torvalds1da177e2005-04-16 15:20:36 -070064 .inputs = {{
65 .name = "default",
66 .vmux = 0,
67 .amux = LINE1,
68 }},
69 },
70 [SAA7134_BOARD_PROTEUS_PRO] = {
71 /* /me */
72 .name = "Proteus Pro [philips reference design]",
73 .audio_clock = 0x00187de7,
74 .tuner_type = TUNER_PHILIPS_PAL,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -070075 .radio_type = UNSET,
76 .tuner_addr = ADDR_UNSET,
77 .radio_addr = ADDR_UNSET,
78
Linus Torvalds1da177e2005-04-16 15:20:36 -070079 .inputs = {{
80 .name = name_comp1,
81 .vmux = 0,
82 .amux = LINE1,
83 },{
84 .name = name_tv,
85 .vmux = 1,
86 .amux = TV,
87 .tv = 1,
88 },{
89 .name = name_tv_mono,
90 .vmux = 1,
91 .amux = LINE2,
92 .tv = 1,
93 }},
94 .radio = {
95 .name = name_radio,
96 .amux = LINE2,
97 },
98 },
99 [SAA7134_BOARD_FLYVIDEO3000] = {
100 /* "Marco d'Itri" <md@Linux.IT> */
101 .name = "LifeView FlyVIDEO3000",
102 .audio_clock = 0x00200000,
103 .tuner_type = TUNER_PHILIPS_PAL,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -0700104 .radio_type = UNSET,
105 .tuner_addr = ADDR_UNSET,
106 .radio_addr = ADDR_UNSET,
107
Linus Torvalds1da177e2005-04-16 15:20:36 -0700108 .gpiomask = 0xe000,
109 .inputs = {{
110 .name = name_tv,
111 .vmux = 1,
112 .amux = TV,
113 .gpio = 0x8000,
114 .tv = 1,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -0700115 },{
Linus Torvalds1da177e2005-04-16 15:20:36 -0700116 .name = name_tv_mono,
117 .vmux = 1,
118 .amux = LINE2,
119 .gpio = 0x0000,
120 .tv = 1,
121 },{
122 .name = name_comp1,
123 .vmux = 0,
124 .amux = LINE2,
125 .gpio = 0x4000,
126 },{
127 .name = name_comp2,
128 .vmux = 3,
129 .amux = LINE2,
130 .gpio = 0x4000,
131 },{
132 .name = name_svideo,
133 .vmux = 8,
134 .amux = LINE2,
135 .gpio = 0x4000,
136 }},
137 .radio = {
138 .name = name_radio,
139 .amux = LINE2,
140 .gpio = 0x2000,
141 },
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -0700142 .mute = {
143 .name = name_mute,
144 .amux = TV,
145 .gpio = 0x8000,
146 },
Linus Torvalds1da177e2005-04-16 15:20:36 -0700147 },
148 [SAA7134_BOARD_FLYVIDEO2000] = {
149 /* "TC Wan" <tcwan@cs.usm.my> */
Peter Missel10b7a902006-01-23 17:11:06 -0200150 .name = "LifeView/Typhoon FlyVIDEO2000",
Linus Torvalds1da177e2005-04-16 15:20:36 -0700151 .audio_clock = 0x00200000,
152 .tuner_type = TUNER_LG_PAL_NEW_TAPC,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -0700153 .radio_type = UNSET,
154 .tuner_addr = ADDR_UNSET,
155 .radio_addr = ADDR_UNSET,
156
Linus Torvalds1da177e2005-04-16 15:20:36 -0700157 .gpiomask = 0xe000,
158 .inputs = {{
159 .name = name_tv,
160 .vmux = 1,
161 .amux = LINE2,
162 .gpio = 0x0000,
163 .tv = 1,
164 },{
165 .name = name_comp1,
166 .vmux = 0,
167 .amux = LINE2,
168 .gpio = 0x4000,
169 },{
170 .name = name_comp2,
171 .vmux = 3,
172 .amux = LINE2,
173 .gpio = 0x4000,
174 },{
175 .name = name_svideo,
176 .vmux = 8,
177 .amux = LINE2,
178 .gpio = 0x4000,
179 }},
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -0700180 .radio = {
181 .name = name_radio,
182 .amux = LINE2,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700183 .gpio = 0x2000,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -0700184 },
Linus Torvalds1da177e2005-04-16 15:20:36 -0700185 .mute = {
186 .name = name_mute,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -0700187 .amux = LINE2,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700188 .gpio = 0x8000,
189 },
190 },
191 [SAA7134_BOARD_FLYTVPLATINUM_MINI] = {
192 /* "Arnaud Quette" <aquette@free.fr> */
193 .name = "LifeView FlyTV Platinum Mini",
194 .audio_clock = 0x00200000,
195 .tuner_type = TUNER_PHILIPS_TDA8290,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -0700196 .radio_type = UNSET,
197 .tuner_addr = ADDR_UNSET,
198 .radio_addr = ADDR_UNSET,
199
Linus Torvalds1da177e2005-04-16 15:20:36 -0700200 .inputs = {{
201 .name = name_tv,
202 .vmux = 1,
Mauro Carvalho Chehabac19ecc2005-06-23 22:05:09 -0700203 .amux = TV,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700204 .tv = 1,
205 },{
Glen Gray2d14f782005-11-08 21:36:12 -0800206 .name = name_comp1, /* Composite signal on S-Video input */
Linus Torvalds1da177e2005-04-16 15:20:36 -0700207 .vmux = 0,
208 .amux = LINE2,
209 },{
Glen Gray2d14f782005-11-08 21:36:12 -0800210 .name = name_comp2, /* Composite input */
211 .vmux = 3,
212 .amux = LINE2,
213 },{
Linus Torvalds1da177e2005-04-16 15:20:36 -0700214 .name = name_svideo,
215 .vmux = 8,
216 .amux = LINE2,
217 }},
218 },
219 [SAA7134_BOARD_FLYTVPLATINUM_FM] = {
220 /* LifeView FlyTV Platinum FM (LR214WF) */
221 /* "Peter Missel <peter.missel@onlinehome.de> */
Hartmut Hackmann42e6b3b2006-03-27 19:04:48 -0300222 .name = "LifeView FlyTV Platinum FM / Gold",
Linus Torvalds1da177e2005-04-16 15:20:36 -0700223 .audio_clock = 0x00200000,
224 .tuner_type = TUNER_PHILIPS_TDA8290,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -0700225 .radio_type = UNSET,
226 .tuner_addr = ADDR_UNSET,
227 .radio_addr = ADDR_UNSET,
228
Peter Missel6c9e7372005-05-01 08:59:05 -0700229 .gpiomask = 0x1E000, /* Set GP16 and unused 15,14,13 to Output */
Linus Torvalds1da177e2005-04-16 15:20:36 -0700230 .inputs = {{
231 .name = name_tv,
232 .vmux = 1,
233 .amux = TV,
Peter Missel6c9e7372005-05-01 08:59:05 -0700234 .gpio = 0x10000, /* GP16=1 selects TV input */
Linus Torvalds1da177e2005-04-16 15:20:36 -0700235 .tv = 1,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -0700236 },{
Linus Torvalds1da177e2005-04-16 15:20:36 -0700237/* .name = name_tv_mono,
238 .vmux = 1,
239 .amux = LINE2,
240 .gpio = 0x0000,
241 .tv = 1,
242 },{
243*/ .name = name_comp1, /* Composite signal on S-Video input */
244 .vmux = 0,
245 .amux = LINE2,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -0700246/* .gpio = 0x4000, */
Linus Torvalds1da177e2005-04-16 15:20:36 -0700247 },{
248 .name = name_comp2, /* Composite input */
249 .vmux = 3,
250 .amux = LINE2,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -0700251/* .gpio = 0x4000, */
Linus Torvalds1da177e2005-04-16 15:20:36 -0700252 },{
253 .name = name_svideo, /* S-Video signal on S-Video input */
254 .vmux = 8,
255 .amux = LINE2,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -0700256/* .gpio = 0x4000, */
Linus Torvalds1da177e2005-04-16 15:20:36 -0700257 }},
Peter Missel6c9e7372005-05-01 08:59:05 -0700258 .radio = {
Linus Torvalds1da177e2005-04-16 15:20:36 -0700259 .name = name_radio,
Peter Missel6c9e7372005-05-01 08:59:05 -0700260 .amux = TV,
261 .gpio = 0x00000, /* GP16=0 selects FM radio antenna */
Linus Torvalds1da177e2005-04-16 15:20:36 -0700262 },
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -0700263 .mute = {
264 .name = name_mute,
265 .amux = TV,
266 .gpio = 0x10000,
267 },
Peter Missel6c9e7372005-05-01 08:59:05 -0700268 },
Eugene Yudin23389b82009-08-29 09:32:11 -0300269 [SAA7134_BOARD_ROVERMEDIA_LINK_PRO_FM] = {
270 /* RoverMedia TV Link Pro FM (LR138 REV:I) */
271 /* Eugene Yudin <Eugene.Yudin@gmail.com> */
272 .name = "RoverMedia TV Link Pro FM",
273 .audio_clock = 0x00200000,
274 .tuner_type = TUNER_PHILIPS_FM1216ME_MK3, /* TCL MFPE05 2 */
275 .radio_type = UNSET,
276 .tuner_addr = ADDR_UNSET,
277 .radio_addr = ADDR_UNSET,
278 .tda9887_conf = TDA9887_PRESENT,
279 .gpiomask = 0xe000,
280 .inputs = { {
281 .name = name_tv,
282 .vmux = 1,
283 .amux = TV,
284 .gpio = 0x8000,
285 .tv = 1,
286 }, {
287 .name = name_tv_mono,
288 .vmux = 1,
289 .amux = LINE2,
290 .gpio = 0x0000,
291 .tv = 1,
292 }, {
293 .name = name_comp1,
294 .vmux = 0,
295 .amux = LINE2,
296 .gpio = 0x4000,
297 }, {
298 .name = name_comp2,
299 .vmux = 3,
300 .amux = LINE2,
301 .gpio = 0x4000,
302 }, {
303 .name = name_svideo,
304 .vmux = 8,
305 .amux = LINE2,
306 .gpio = 0x4000,
307 } },
308 .radio = {
309 .name = name_radio,
310 .amux = LINE2,
311 .gpio = 0x2000,
312 },
313 .mute = {
314 .name = name_mute,
315 .amux = TV,
316 .gpio = 0x8000,
317 },
318 },
Linus Torvalds1da177e2005-04-16 15:20:36 -0700319 [SAA7134_BOARD_EMPRESS] = {
320 /* "Gert Vervoort" <gert.vervoort@philips.com> */
321 .name = "EMPRESS",
322 .audio_clock = 0x00187de7,
323 .tuner_type = TUNER_PHILIPS_PAL,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -0700324 .radio_type = UNSET,
325 .tuner_addr = ADDR_UNSET,
326 .radio_addr = ADDR_UNSET,
Hans Verkuil195784b2009-03-28 09:27:02 -0300327 .empress_addr = 0x20,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -0700328
Linus Torvalds1da177e2005-04-16 15:20:36 -0700329 .inputs = {{
330 .name = name_comp1,
331 .vmux = 0,
332 .amux = LINE1,
333 },{
334 .name = name_svideo,
335 .vmux = 8,
336 .amux = LINE1,
337 },{
338 .name = name_tv,
339 .vmux = 1,
340 .amux = LINE2,
341 .tv = 1,
342 }},
343 .radio = {
344 .name = name_radio,
345 .amux = LINE2,
346 },
347 .mpeg = SAA7134_MPEG_EMPRESS,
348 .video_out = CCIR656,
349 },
350 [SAA7134_BOARD_MONSTERTV] = {
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -0700351 /* "K.Ohta" <alpha292@bremen.or.jp> */
352 .name = "SKNet Monster TV",
353 .audio_clock = 0x00187de7,
354 .tuner_type = TUNER_PHILIPS_NTSC_M,
355 .radio_type = UNSET,
356 .tuner_addr = ADDR_UNSET,
357 .radio_addr = ADDR_UNSET,
358
359 .inputs = {{
360 .name = name_tv,
361 .vmux = 1,
362 .amux = TV,
363 .tv = 1,
364 },{
365 .name = name_comp1,
366 .vmux = 0,
367 .amux = LINE1,
368 },{
369 .name = name_svideo,
370 .vmux = 8,
371 .amux = LINE1,
372 }},
373 .radio = {
374 .name = name_radio,
375 .amux = LINE2,
376 },
Linus Torvalds1da177e2005-04-16 15:20:36 -0700377 },
378 [SAA7134_BOARD_MD9717] = {
379 .name = "Tevion MD 9717",
380 .audio_clock = 0x00200000,
381 .tuner_type = TUNER_PHILIPS_PAL,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -0700382 .radio_type = UNSET,
383 .tuner_addr = ADDR_UNSET,
384 .radio_addr = ADDR_UNSET,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700385 .inputs = {{
386 .name = name_tv,
387 .vmux = 1,
388 .amux = TV,
389 .tv = 1,
390 },{
391 /* workaround for problems with normal TV sound */
392 .name = name_tv_mono,
393 .vmux = 1,
394 .amux = LINE2,
395 .tv = 1,
396 },{
397 .name = name_comp1,
Hermann Pitton4aa504a2007-11-28 21:50:26 -0300398 .vmux = 0,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700399 .amux = LINE1,
400 },{
401 .name = name_comp2,
402 .vmux = 3,
403 .amux = LINE1,
404 },{
405 .name = name_svideo,
406 .vmux = 8,
407 .amux = LINE1,
408 }},
409 .radio = {
410 .name = name_radio,
411 .amux = LINE2,
412 },
Hermann Pittoncc764662007-11-28 21:54:35 -0300413 .mute = {
414 .name = name_mute,
415 .amux = TV,
416 },
Linus Torvalds1da177e2005-04-16 15:20:36 -0700417 },
418 [SAA7134_BOARD_TVSTATION_RDS] = {
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -0700419 /* Typhoon TV Tuner RDS: Art.Nr. 50694 */
Linus Torvalds1da177e2005-04-16 15:20:36 -0700420 .name = "KNC One TV-Station RDS / Typhoon TV Tuner RDS",
421 .audio_clock = 0x00200000,
422 .tuner_type = TUNER_PHILIPS_FM1216ME_MK3,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -0700423 .radio_type = UNSET,
424 .tuner_addr = ADDR_UNSET,
425 .radio_addr = ADDR_UNSET,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700426 .tda9887_conf = TDA9887_PRESENT,
427 .inputs = {{
428 .name = name_tv,
429 .vmux = 1,
430 .amux = TV,
431 .tv = 1,
432 },{
433 .name = name_tv_mono,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -0700434 .vmux = 1,
435 .amux = LINE2,
436 .tv = 1,
437 },{
Linus Torvalds1da177e2005-04-16 15:20:36 -0700438
439 .name = name_svideo,
440 .vmux = 8,
441 .amux = LINE1,
442 },{
443 .name = name_comp1,
444 .vmux = 3,
445 .amux = LINE1,
446 },{
447
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -0700448 .name = "CVid over SVid",
449 .vmux = 0,
450 .amux = LINE1,
451 }},
Linus Torvalds1da177e2005-04-16 15:20:36 -0700452 .radio = {
453 .name = name_radio,
454 .amux = LINE2,
455 },
456 },
457 [SAA7134_BOARD_TVSTATION_DVR] = {
458 .name = "KNC One TV-Station DVR",
459 .audio_clock = 0x00200000,
460 .tuner_type = TUNER_PHILIPS_FM1216ME_MK3,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -0700461 .radio_type = UNSET,
462 .tuner_addr = ADDR_UNSET,
463 .radio_addr = ADDR_UNSET,
Hans Verkuil195784b2009-03-28 09:27:02 -0300464 .empress_addr = 0x20,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700465 .tda9887_conf = TDA9887_PRESENT,
466 .gpiomask = 0x820000,
467 .inputs = {{
468 .name = name_tv,
469 .vmux = 1,
Rafał Bilskiaac0ca62007-06-20 05:36:26 -0300470 .amux = TV,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700471 .tv = 1,
472 .gpio = 0x20000,
473 },{
474 .name = name_svideo,
475 .vmux = 8,
476 .amux = LINE1,
477 .gpio = 0x20000,
478 },{
479 .name = name_comp1,
480 .vmux = 3,
481 .amux = LINE1,
482 .gpio = 0x20000,
483 }},
484 .radio = {
485 .name = name_radio,
486 .amux = LINE2,
487 .gpio = 0x20000,
488 },
489 .mpeg = SAA7134_MPEG_EMPRESS,
490 .video_out = CCIR656,
491 },
492 [SAA7134_BOARD_CINERGY400] = {
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -0700493 .name = "Terratec Cinergy 400 TV",
494 .audio_clock = 0x00200000,
495 .tuner_type = TUNER_PHILIPS_PAL,
496 .radio_type = UNSET,
497 .tuner_addr = ADDR_UNSET,
498 .radio_addr = ADDR_UNSET,
499 .inputs = {{
500 .name = name_tv,
501 .vmux = 1,
502 .amux = TV,
503 .tv = 1,
504 },{
505 .name = name_comp1,
506 .vmux = 4,
507 .amux = LINE1,
508 },{
509 .name = name_svideo,
510 .vmux = 8,
511 .amux = LINE1,
512 },{
513 .name = name_comp2, /* CVideo over SVideo Connector */
514 .vmux = 0,
515 .amux = LINE1,
516 }}
517 },
Linus Torvalds1da177e2005-04-16 15:20:36 -0700518 [SAA7134_BOARD_MD5044] = {
519 .name = "Medion 5044",
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -0700520 .audio_clock = 0x00187de7, /* was: 0x00200000, */
Linus Torvalds1da177e2005-04-16 15:20:36 -0700521 .tuner_type = TUNER_PHILIPS_FM1216ME_MK3,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -0700522 .radio_type = UNSET,
523 .tuner_addr = ADDR_UNSET,
524 .radio_addr = ADDR_UNSET,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700525 .tda9887_conf = TDA9887_PRESENT,
526 .inputs = {{
527 .name = name_tv,
528 .vmux = 1,
529 .amux = TV,
530 .tv = 1,
531 },{
532 /* workaround for problems with normal TV sound */
533 .name = name_tv_mono,
534 .vmux = 1,
535 .amux = LINE2,
536 .tv = 1,
537 },{
538 .name = name_comp1,
539 .vmux = 0,
540 .amux = LINE2,
541 },{
542 .name = name_comp2,
543 .vmux = 3,
544 .amux = LINE2,
545 },{
546 .name = name_svideo,
547 .vmux = 8,
548 .amux = LINE2,
549 }},
550 .radio = {
551 .name = name_radio,
552 .amux = LINE2,
553 },
554 },
555 [SAA7134_BOARD_KWORLD] = {
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -0700556 .name = "Kworld/KuroutoShikou SAA7130-TVPCI",
Linus Torvalds1da177e2005-04-16 15:20:36 -0700557 .audio_clock = 0x00187de7,
558 .tuner_type = TUNER_PHILIPS_NTSC_M,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -0700559 .radio_type = UNSET,
560 .tuner_addr = ADDR_UNSET,
561 .radio_addr = ADDR_UNSET,
562 .inputs = {{
563 .name = name_svideo,
564 .vmux = 8,
565 .amux = LINE1,
566 },{
567 .name = name_comp1,
568 .vmux = 3,
569 .amux = LINE1,
570 },{
571 .name = name_tv,
572 .vmux = 1,
573 .amux = LINE2,
574 .tv = 1,
575 }},
576 },
Linus Torvalds1da177e2005-04-16 15:20:36 -0700577 [SAA7134_BOARD_CINERGY600] = {
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -0700578 .name = "Terratec Cinergy 600 TV",
579 .audio_clock = 0x00200000,
580 .tuner_type = TUNER_PHILIPS_PAL,
581 .radio_type = UNSET,
582 .tuner_addr = ADDR_UNSET,
583 .radio_addr = ADDR_UNSET,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700584 .tda9887_conf = TDA9887_PRESENT,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -0700585 .inputs = {{
586 .name = name_tv,
587 .vmux = 1,
588 .amux = TV,
589 .tv = 1,
590 },{
591 .name = name_comp1,
592 .vmux = 4,
593 .amux = LINE1,
594 },{
595 .name = name_svideo,
596 .vmux = 8,
597 .amux = LINE1,
598 },{
599 .name = name_comp2, /* CVideo over SVideo Connector */
600 .vmux = 0,
601 .amux = LINE1,
602 }},
Linus Torvalds1da177e2005-04-16 15:20:36 -0700603 .radio = {
604 .name = name_radio,
605 .amux = LINE2,
Michael Krufky67ac9a42006-03-14 16:18:49 -0300606 },
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -0700607 },
Linus Torvalds1da177e2005-04-16 15:20:36 -0700608 [SAA7134_BOARD_MD7134] = {
609 .name = "Medion 7134",
Linus Torvalds1da177e2005-04-16 15:20:36 -0700610 .audio_clock = 0x00187de7,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -0700611 .tuner_type = TUNER_PHILIPS_FMD1216ME_MK3,
612 .radio_type = UNSET,
613 .tuner_addr = ADDR_UNSET,
614 .radio_addr = ADDR_UNSET,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700615 .tda9887_conf = TDA9887_PRESENT,
616 .mpeg = SAA7134_MPEG_DVB,
617 .inputs = {{
618 .name = name_tv,
619 .vmux = 1,
620 .amux = TV,
621 .tv = 1,
622 },{
623 .name = name_comp1,
624 .vmux = 0,
625 .amux = LINE1,
626 },{
627 .name = name_svideo,
628 .vmux = 8,
629 .amux = LINE1,
630 }},
631 .radio = {
632 .name = name_radio,
633 .amux = LINE2,
Hermann Pittoncc764662007-11-28 21:54:35 -0300634 },
635 .mute = {
636 .name = name_mute,
637 .amux = TV,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700638 },
639 },
640 [SAA7134_BOARD_TYPHOON_90031] = {
641 /* aka Typhoon "TV+Radio", Art.Nr 90031 */
642 /* Tom Zoerner <tomzo at users sourceforge net> */
643 .name = "Typhoon TV+Radio 90031",
644 .audio_clock = 0x00200000,
645 .tuner_type = TUNER_PHILIPS_PAL,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -0700646 .radio_type = UNSET,
647 .tuner_addr = ADDR_UNSET,
648 .radio_addr = ADDR_UNSET,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700649 .tda9887_conf = TDA9887_PRESENT,
650 .inputs = {{
651 .name = name_tv,
652 .vmux = 1,
653 .amux = TV,
654 .tv = 1,
655 },{
656 .name = name_comp1,
657 .vmux = 3,
658 .amux = LINE1,
659 },{
660 .name = name_svideo,
661 .vmux = 8,
662 .amux = LINE1,
663 }},
664 .radio = {
665 .name = name_radio,
666 .amux = LINE2,
667 },
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -0700668 },
Linus Torvalds1da177e2005-04-16 15:20:36 -0700669 [SAA7134_BOARD_ELSA] = {
670 .name = "ELSA EX-VISION 300TV",
671 .audio_clock = 0x00187de7,
672 .tuner_type = TUNER_HITACHI_NTSC,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -0700673 .radio_type = UNSET,
674 .tuner_addr = ADDR_UNSET,
675 .radio_addr = ADDR_UNSET,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700676 .inputs = {{
677 .name = name_svideo,
678 .vmux = 8,
679 .amux = LINE1,
680 },{
681 .name = name_comp1,
682 .vmux = 0,
683 .amux = LINE1,
684 },{
685 .name = name_tv,
686 .vmux = 4,
687 .amux = LINE2,
688 .tv = 1,
689 }},
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -0700690 },
Linus Torvalds1da177e2005-04-16 15:20:36 -0700691 [SAA7134_BOARD_ELSA_500TV] = {
692 .name = "ELSA EX-VISION 500TV",
693 .audio_clock = 0x00187de7,
694 .tuner_type = TUNER_HITACHI_NTSC,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -0700695 .radio_type = UNSET,
696 .tuner_addr = ADDR_UNSET,
697 .radio_addr = ADDR_UNSET,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700698 .inputs = {{
699 .name = name_svideo,
700 .vmux = 7,
701 .amux = LINE1,
702 },{
703 .name = name_tv,
704 .vmux = 8,
705 .amux = TV,
706 .tv = 1,
707 },{
708 .name = name_tv_mono,
709 .vmux = 8,
710 .amux = LINE2,
711 .tv = 1,
712 }},
Linus Torvalds1da177e2005-04-16 15:20:36 -0700713 },
Tamuki Shoichid0456d12006-02-27 00:08:04 -0300714 [SAA7134_BOARD_ELSA_700TV] = {
715 .name = "ELSA EX-VISION 700TV",
716 .audio_clock = 0x00187de7,
717 .tuner_type = TUNER_HITACHI_NTSC,
718 .radio_type = UNSET,
719 .tuner_addr = ADDR_UNSET,
720 .radio_addr = ADDR_UNSET,
721 .inputs = {{
722 .name = name_tv,
723 .vmux = 4,
724 .amux = LINE2,
725 .tv = 1,
726 },{
727 .name = name_comp1,
728 .vmux = 6,
729 .amux = LINE1,
730 },{
731 .name = name_svideo,
732 .vmux = 7,
733 .amux = LINE1,
734 }},
735 .mute = {
736 .name = name_mute,
737 .amux = TV,
738 },
739 },
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -0700740 [SAA7134_BOARD_ASUSTeK_TVFM7134] = {
741 .name = "ASUS TV-FM 7134",
742 .audio_clock = 0x00187de7,
743 .tuner_type = TUNER_PHILIPS_FM1216ME_MK3,
744 .radio_type = UNSET,
745 .tuner_addr = ADDR_UNSET,
746 .radio_addr = ADDR_UNSET,
747 .tda9887_conf = TDA9887_PRESENT,
748 .inputs = {{
749 .name = name_tv,
750 .vmux = 1,
751 .amux = TV,
752 .tv = 1,
753 },{
754 .name = name_comp1,
755 .vmux = 4,
756 .amux = LINE2,
757 },{
758 .name = name_svideo,
759 .vmux = 6,
760 .amux = LINE2,
761 }},
762 .radio = {
763 .name = name_radio,
764 .amux = LINE1,
765 },
766 },
767 [SAA7134_BOARD_ASUSTeK_TVFM7135] = {
768 .name = "ASUS TV-FM 7135",
769 .audio_clock = 0x00187de7,
770 .tuner_type = TUNER_PHILIPS_TDA8290,
771 .radio_type = UNSET,
772 .tuner_addr = ADDR_UNSET,
773 .radio_addr = ADDR_UNSET,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700774 .gpiomask = 0x200000,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -0700775 .inputs = {{
776 .name = name_tv,
777 .vmux = 1,
778 .amux = TV,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700779 .gpio = 0x0000,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -0700780 .tv = 1,
781 },{
782 .name = name_comp1,
783 .vmux = 4,
784 .amux = LINE2,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700785 .gpio = 0x0000,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -0700786 },{
787 .name = name_svideo,
788 .vmux = 6,
789 .amux = LINE2,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700790 .gpio = 0x0000,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -0700791 }},
792 .radio = {
793 .name = name_radio,
794 .amux = TV,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700795 .gpio = 0x200000,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -0700796 },
797 .mute = {
798 .name = name_mute,
799 .gpio = 0x0000,
800 },
801
Linus Torvalds1da177e2005-04-16 15:20:36 -0700802 },
803 [SAA7134_BOARD_VA1000POWER] = {
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -0700804 .name = "AOPEN VA1000 POWER",
Linus Torvalds1da177e2005-04-16 15:20:36 -0700805 .audio_clock = 0x00187de7,
806 .tuner_type = TUNER_PHILIPS_NTSC,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -0700807 .radio_type = UNSET,
808 .tuner_addr = ADDR_UNSET,
809 .radio_addr = ADDR_UNSET,
810 .inputs = {{
811 .name = name_svideo,
812 .vmux = 8,
813 .amux = LINE1,
814 },{
815 .name = name_comp1,
816 .vmux = 3,
817 .amux = LINE1,
818 },{
819 .name = name_tv,
820 .vmux = 1,
821 .amux = LINE2,
822 .tv = 1,
823 }},
Linus Torvalds1da177e2005-04-16 15:20:36 -0700824 },
825 [SAA7134_BOARD_10MOONSTVMASTER] = {
826 /* "lilicheng" <llc@linuxfans.org> */
827 .name = "10MOONS PCI TV CAPTURE CARD",
828 .audio_clock = 0x00200000,
829 .tuner_type = TUNER_LG_PAL_NEW_TAPC,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -0700830 .radio_type = UNSET,
831 .tuner_addr = ADDR_UNSET,
832 .radio_addr = ADDR_UNSET,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700833 .gpiomask = 0xe000,
834 .inputs = {{
835 .name = name_tv,
836 .vmux = 1,
837 .amux = LINE2,
838 .gpio = 0x0000,
839 .tv = 1,
840 },{
841 .name = name_comp1,
842 .vmux = 0,
843 .amux = LINE2,
844 .gpio = 0x4000,
845 },{
846 .name = name_comp2,
847 .vmux = 3,
848 .amux = LINE2,
849 .gpio = 0x4000,
850 },{
851 .name = name_svideo,
852 .vmux = 8,
853 .amux = LINE2,
854 .gpio = 0x4000,
855 }},
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -0700856 .radio = {
857 .name = name_radio,
858 .amux = LINE2,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700859 .gpio = 0x2000,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -0700860 },
Linus Torvalds1da177e2005-04-16 15:20:36 -0700861 .mute = {
862 .name = name_mute,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -0700863 .amux = LINE2,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700864 .gpio = 0x8000,
865 },
866 },
867 [SAA7134_BOARD_BMK_MPEX_NOTUNER] = {
868 /* "Andrew de Quincey" <adq@lidskialf.net> */
869 .name = "BMK MPEX No Tuner",
870 .audio_clock = 0x200000,
871 .tuner_type = TUNER_ABSENT,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -0700872 .radio_type = UNSET,
873 .tuner_addr = ADDR_UNSET,
874 .radio_addr = ADDR_UNSET,
Hans Verkuil195784b2009-03-28 09:27:02 -0300875 .empress_addr = 0x20,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700876 .inputs = {{
877 .name = name_comp1,
878 .vmux = 4,
879 .amux = LINE1,
880 },{
881 .name = name_comp2,
882 .vmux = 3,
883 .amux = LINE1,
884 },{
885 .name = name_comp3,
886 .vmux = 0,
887 .amux = LINE1,
888 },{
889 .name = name_comp4,
890 .vmux = 1,
891 .amux = LINE1,
892 },{
893 .name = name_svideo,
894 .vmux = 8,
895 .amux = LINE1,
896 }},
897 .mpeg = SAA7134_MPEG_EMPRESS,
898 .video_out = CCIR656,
899 },
900 [SAA7134_BOARD_VIDEOMATE_TV] = {
901 .name = "Compro VideoMate TV",
902 .audio_clock = 0x00187de7,
903 .tuner_type = TUNER_PHILIPS_NTSC_M,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -0700904 .radio_type = UNSET,
905 .tuner_addr = ADDR_UNSET,
906 .radio_addr = ADDR_UNSET,
907 .inputs = {{
908 .name = name_svideo,
909 .vmux = 8,
910 .amux = LINE1,
911 },{
912 .name = name_comp1,
913 .vmux = 3,
914 .amux = LINE1,
915 },{
916 .name = name_tv,
917 .vmux = 1,
918 .amux = LINE2,
919 .tv = 1,
920 }},
921 },
922 [SAA7134_BOARD_VIDEOMATE_TV_GOLD_PLUS] = {
Linus Torvalds1da177e2005-04-16 15:20:36 -0700923 .name = "Compro VideoMate TV Gold+",
924 .audio_clock = 0x00187de7,
925 .tuner_type = TUNER_PHILIPS_NTSC_M,
926 .gpiomask = 0x800c0000,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -0700927 .radio_type = UNSET,
928 .tuner_addr = ADDR_UNSET,
929 .radio_addr = ADDR_UNSET,
930 .inputs = {{
931 .name = name_svideo,
932 .vmux = 8,
933 .amux = LINE1,
934 .gpio = 0x06c00012,
935 },{
936 .name = name_comp1,
937 .vmux = 3,
938 .amux = LINE1,
939 .gpio = 0x0ac20012,
940 },{
941 .name = name_tv,
942 .vmux = 1,
943 .amux = LINE2,
944 .gpio = 0x08c20012,
945 .tv = 1,
946 }}, /* radio and probably mute is missing */
947 },
Linus Torvalds1da177e2005-04-16 15:20:36 -0700948 [SAA7134_BOARD_CRONOS_PLUS] = {
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -0700949 /*
950 gpio pins:
951 0 .. 3 BASE_ID
952 4 .. 7 PROTECT_ID
953 8 .. 11 USER_OUT
954 12 .. 13 USER_IN
955 14 .. 15 VIDIN_SEL
956 */
Linus Torvalds1da177e2005-04-16 15:20:36 -0700957 .name = "Matrox CronosPlus",
958 .tuner_type = TUNER_ABSENT,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -0700959 .radio_type = UNSET,
960 .tuner_addr = ADDR_UNSET,
961 .radio_addr = ADDR_UNSET,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700962 .gpiomask = 0xcf00,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -0700963 .inputs = {{
964 .name = name_comp1,
965 .vmux = 0,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700966 .gpio = 2 << 14,
967 },{
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -0700968 .name = name_comp2,
969 .vmux = 0,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700970 .gpio = 1 << 14,
971 },{
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -0700972 .name = name_comp3,
973 .vmux = 0,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700974 .gpio = 0 << 14,
975 },{
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -0700976 .name = name_comp4,
977 .vmux = 0,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700978 .gpio = 3 << 14,
979 },{
980 .name = name_svideo,
981 .vmux = 8,
982 .gpio = 2 << 14,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -0700983 }},
984 },
Linus Torvalds1da177e2005-04-16 15:20:36 -0700985 [SAA7134_BOARD_MD2819] = {
986 .name = "AverMedia M156 / Medion 2819",
987 .audio_clock = 0x00187de7,
988 .tuner_type = TUNER_PHILIPS_FM1216ME_MK3,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -0700989 .radio_type = UNSET,
990 .tuner_addr = ADDR_UNSET,
991 .radio_addr = ADDR_UNSET,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700992 .tda9887_conf = TDA9887_PRESENT,
Hermann Pittonad1ef132008-01-20 19:32:39 -0300993 .gpiomask = 0x03,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700994 .inputs = {{
995 .name = name_tv,
996 .vmux = 1,
997 .amux = TV,
998 .tv = 1,
Hermann Pittonad1ef132008-01-20 19:32:39 -0300999 .gpio = 0x00,
1000 }, {
Linus Torvalds1da177e2005-04-16 15:20:36 -07001001 .name = name_comp1,
Linus Torvalds1da177e2005-04-16 15:20:36 -07001002 .vmux = 3,
Hermann Pittonad1ef132008-01-20 19:32:39 -03001003 .amux = LINE1,
1004 .gpio = 0x02,
1005 }, {
1006 .name = name_comp2,
1007 .vmux = 0,
1008 .amux = LINE1,
1009 .gpio = 0x02,
1010 }, {
Linus Torvalds1da177e2005-04-16 15:20:36 -07001011 .name = name_svideo,
1012 .vmux = 8,
Hermann Pittonad1ef132008-01-20 19:32:39 -03001013 .amux = LINE1,
1014 .gpio = 0x02,
1015 } },
Linus Torvalds1da177e2005-04-16 15:20:36 -07001016 .radio = {
1017 .name = name_radio,
Hermann Pittonad1ef132008-01-20 19:32:39 -03001018 .amux = LINE1,
1019 .gpio = 0x01,
1020 },
1021 .mute = {
1022 .name = name_mute,
1023 .amux = TV,
1024 .gpio = 0x00,
Linus Torvalds1da177e2005-04-16 15:20:36 -07001025 },
1026 },
1027 [SAA7134_BOARD_BMK_MPEX_TUNER] = {
1028 /* "Greg Wickham <greg.wickham@grangenet.net> */
1029 .name = "BMK MPEX Tuner",
1030 .audio_clock = 0x200000,
1031 .tuner_type = TUNER_PHILIPS_PAL,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07001032 .radio_type = UNSET,
1033 .tuner_addr = ADDR_UNSET,
1034 .radio_addr = ADDR_UNSET,
Hans Verkuil195784b2009-03-28 09:27:02 -03001035 .empress_addr = 0x20,
Linus Torvalds1da177e2005-04-16 15:20:36 -07001036 .inputs = {{
1037 .name = name_comp1,
1038 .vmux = 1,
1039 .amux = LINE1,
1040 },{
1041 .name = name_svideo,
1042 .vmux = 8,
1043 .amux = LINE1,
1044 },{
1045 .name = name_tv,
1046 .vmux = 3,
1047 .amux = TV,
1048 .tv = 1,
1049 }},
1050 .mpeg = SAA7134_MPEG_EMPRESS,
1051 .video_out = CCIR656,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07001052 },
1053 [SAA7134_BOARD_ASUSTEK_TVFM7133] = {
1054 .name = "ASUS TV-FM 7133",
1055 .audio_clock = 0x00187de7,
1056 /* probably wrong, the 7133 one is the NTSC version ...
1057 * .tuner_type = TUNER_PHILIPS_FM1236_MK3 */
1058 .tuner_type = TUNER_LG_NTSC_NEW_TAPC,
1059 .radio_type = UNSET,
1060 .tuner_addr = ADDR_UNSET,
1061 .radio_addr = ADDR_UNSET,
1062 .tda9887_conf = TDA9887_PRESENT,
1063 .inputs = {{
1064 .name = name_tv,
1065 .vmux = 1,
1066 .amux = TV,
1067 .tv = 1,
1068
Linus Torvalds1da177e2005-04-16 15:20:36 -07001069 },{
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07001070 .name = name_comp1,
1071 .vmux = 4,
1072 .amux = LINE2,
1073 },{
1074 .name = name_svideo,
1075 .vmux = 6,
1076 .amux = LINE2,
1077 }},
1078 .radio = {
1079 .name = name_radio,
1080 .amux = LINE1,
1081 },
1082 },
Linus Torvalds1da177e2005-04-16 15:20:36 -07001083 [SAA7134_BOARD_PINNACLE_PCTV_STEREO] = {
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07001084 .name = "Pinnacle PCTV Stereo (saa7134)",
1085 .audio_clock = 0x00187de7,
1086 .tuner_type = TUNER_MT2032,
1087 .radio_type = UNSET,
1088 .tuner_addr = ADDR_UNSET,
1089 .radio_addr = ADDR_UNSET,
Hartmut Hackmanndf8cf702006-03-03 12:09:26 -03001090 .tda9887_conf = TDA9887_PRESENT | TDA9887_INTERCARRIER | TDA9887_PORT2_INACTIVE,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07001091 .inputs = {{
1092 .name = name_tv,
1093 .vmux = 3,
1094 .amux = TV,
1095 .tv = 1,
1096 },{
1097 .name = name_comp1,
1098 .vmux = 0,
1099 .amux = LINE2,
1100 },{
1101 .name = name_comp2,
1102 .vmux = 1,
1103 .amux = LINE2,
1104 },{
1105 .name = name_svideo,
1106 .vmux = 8,
1107 .amux = LINE2,
1108 }},
1109 },
Linus Torvalds1da177e2005-04-16 15:20:36 -07001110 [SAA7134_BOARD_MANLI_MTV002] = {
1111 /* Ognjen Nastic <ognjen@logosoft.ba> */
Dmitry Belimovb34dddb2008-04-23 14:09:08 -03001112 .name = "Manli MuchTV M-TV002",
Linus Torvalds1da177e2005-04-16 15:20:36 -07001113 .audio_clock = 0x00200000,
1114 .tuner_type = TUNER_PHILIPS_PAL,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07001115 .radio_type = UNSET,
1116 .tuner_addr = ADDR_UNSET,
1117 .radio_addr = ADDR_UNSET,
Linus Torvalds1da177e2005-04-16 15:20:36 -07001118 .inputs = {{
1119 .name = name_svideo,
1120 .vmux = 8,
1121 .amux = LINE1,
1122 },{
1123 .name = name_comp1,
1124 .vmux = 1,
1125 .amux = LINE1,
1126 },{
1127 .name = name_tv,
1128 .vmux = 3,
1129 .amux = LINE2,
1130 .tv = 1,
1131 }},
1132 .radio = {
1133 .name = name_radio,
1134 .amux = LINE2,
1135 },
Linus Torvalds1da177e2005-04-16 15:20:36 -07001136 },
1137 [SAA7134_BOARD_MANLI_MTV001] = {
1138 /* Ognjen Nastic <ognjen@logosoft.ba> UNTESTED */
Dmitry Belimovb34dddb2008-04-23 14:09:08 -03001139 .name = "Manli MuchTV M-TV001",
Linus Torvalds1da177e2005-04-16 15:20:36 -07001140 .audio_clock = 0x00200000,
1141 .tuner_type = TUNER_PHILIPS_PAL,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07001142 .radio_type = UNSET,
1143 .tuner_addr = ADDR_UNSET,
1144 .radio_addr = ADDR_UNSET,
Linus Torvalds1da177e2005-04-16 15:20:36 -07001145 .inputs = {{
1146 .name = name_svideo,
1147 .vmux = 8,
1148 .amux = LINE1,
1149 },{
1150 .name = name_comp1,
1151 .vmux = 1,
1152 .amux = LINE1,
1153 },{
1154 .name = name_tv,
1155 .vmux = 3,
1156 .amux = LINE2,
1157 .tv = 1,
1158 }},
Mauro Carvalho Chehabac19ecc2005-06-23 22:05:09 -07001159 .mute = {
1160 .name = name_mute,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07001161 .amux = LINE1,
Mauro Carvalho Chehabac19ecc2005-06-23 22:05:09 -07001162 },
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07001163 },
Linus Torvalds1da177e2005-04-16 15:20:36 -07001164 [SAA7134_BOARD_TG3000TV] = {
1165 /* TransGear 3000TV */
1166 .name = "Nagase Sangyo TransGear 3000TV",
1167 .audio_clock = 0x00187de7,
1168 .tuner_type = TUNER_PHILIPS_NTSC_M,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07001169 .radio_type = UNSET,
1170 .tuner_addr = ADDR_UNSET,
1171 .radio_addr = ADDR_UNSET,
Linus Torvalds1da177e2005-04-16 15:20:36 -07001172 .inputs = {{
1173 .name = name_tv,
1174 .vmux = 1,
1175 .amux = LINE2,
1176 .tv = 1,
1177 },{
1178 .name = name_comp1,
1179 .vmux = 3,
1180 .amux = LINE2,
1181 },{
1182 .name = name_svideo,
1183 .vmux = 8,
1184 .amux = LINE2,
1185 }},
1186 },
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07001187 [SAA7134_BOARD_ECS_TVP3XP] = {
1188 .name = "Elitegroup ECS TVP3XP FM1216 Tuner Card(PAL-BG,FM) ",
1189 .audio_clock = 0x187de7, /* xtal 32.1 MHz */
1190 .tuner_type = TUNER_PHILIPS_PAL,
1191 .radio_type = UNSET,
1192 .tuner_addr = ADDR_UNSET,
1193 .radio_addr = ADDR_UNSET,
1194 .inputs = {{
1195 .name = name_tv,
1196 .vmux = 1,
1197 .amux = TV,
1198 .tv = 1,
1199 },{
1200 .name = name_tv_mono,
1201 .vmux = 1,
1202 .amux = LINE2,
1203 .tv = 1,
1204 },{
1205 .name = name_comp1,
1206 .vmux = 3,
1207 .amux = LINE1,
1208 },{
1209 .name = name_svideo,
1210 .vmux = 8,
1211 .amux = LINE1,
Linus Torvalds1da177e2005-04-16 15:20:36 -07001212 },{
1213 .name = "CVid over SVid",
1214 .vmux = 0,
1215 .amux = LINE1,
1216 }},
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07001217 .radio = {
1218 .name = name_radio,
1219 .amux = LINE2,
1220 },
1221 },
1222 [SAA7134_BOARD_ECS_TVP3XP_4CB5] = {
1223 .name = "Elitegroup ECS TVP3XP FM1236 Tuner Card (NTSC,FM)",
1224 .audio_clock = 0x187de7,
1225 .tuner_type = TUNER_PHILIPS_NTSC,
1226 .radio_type = UNSET,
1227 .tuner_addr = ADDR_UNSET,
1228 .radio_addr = ADDR_UNSET,
1229 .inputs = {{
1230 .name = name_tv,
1231 .vmux = 1,
1232 .amux = TV,
1233 .tv = 1,
1234 },{
1235 .name = name_tv_mono,
1236 .vmux = 1,
1237 .amux = LINE2,
1238 .tv = 1,
1239 },{
1240 .name = name_comp1,
1241 .vmux = 3,
1242 .amux = LINE1,
1243 },{
1244 .name = name_svideo,
1245 .vmux = 8,
1246 .amux = LINE1,
1247 },{
1248 .name = "CVid over SVid",
1249 .vmux = 0,
1250 .amux = LINE1,
1251 }},
1252 .radio = {
1253 .name = name_radio,
1254 .amux = LINE2,
1255 },
1256 },
Simon Farnsworthb39423a2007-05-01 10:01:20 -03001257 [SAA7134_BOARD_ECS_TVP3XP_4CB6] = {
1258 /* Barry Scott <barry.scott@onelan.co.uk> */
1259 .name = "Elitegroup ECS TVP3XP FM1246 Tuner Card (PAL,FM)",
1260 .audio_clock = 0x187de7,
1261 .tuner_type = TUNER_PHILIPS_PAL_I,
1262 .radio_type = UNSET,
1263 .tuner_addr = ADDR_UNSET,
1264 .radio_addr = ADDR_UNSET,
1265 .inputs = {{
1266 .name = name_tv,
1267 .vmux = 1,
1268 .amux = TV,
1269 .tv = 1,
1270 },{
1271 .name = name_tv_mono,
1272 .vmux = 1,
1273 .amux = LINE2,
1274 .tv = 1,
1275 },{
1276 .name = name_comp1,
1277 .vmux = 3,
1278 .amux = LINE1,
1279 },{
1280 .name = name_svideo,
1281 .vmux = 8,
1282 .amux = LINE1,
1283 },{
1284 .name = "CVid over SVid",
1285 .vmux = 0,
1286 .amux = LINE1,
1287 }},
1288 .radio = {
1289 .name = name_radio,
1290 .amux = LINE2,
1291 },
1292 },
Linus Torvalds1da177e2005-04-16 15:20:36 -07001293 [SAA7134_BOARD_AVACSSMARTTV] = {
1294 /* Roman Pszonczenko <romka@kolos.math.uni.lodz.pl> */
1295 .name = "AVACS SmartTV",
1296 .audio_clock = 0x00187de7,
1297 .tuner_type = TUNER_PHILIPS_PAL,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07001298 .radio_type = UNSET,
1299 .tuner_addr = ADDR_UNSET,
1300 .radio_addr = ADDR_UNSET,
Linus Torvalds1da177e2005-04-16 15:20:36 -07001301 .inputs = {{
1302 .name = name_tv,
1303 .vmux = 1,
1304 .amux = TV,
1305 .tv = 1,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07001306 },{
Linus Torvalds1da177e2005-04-16 15:20:36 -07001307 .name = name_tv_mono,
1308 .vmux = 1,
1309 .amux = LINE2,
1310 .tv = 1,
1311 },{
1312 .name = name_comp1,
1313 .vmux = 0,
1314 .amux = LINE2,
1315 },{
1316 .name = name_comp2,
1317 .vmux = 3,
1318 .amux = LINE2,
1319 },{
1320 .name = name_svideo,
1321 .vmux = 8,
1322 .amux = LINE2,
1323 }},
1324 .radio = {
1325 .name = name_radio,
1326 .amux = LINE2,
1327 .gpio = 0x200000,
1328 },
1329 },
1330 [SAA7134_BOARD_AVERMEDIA_DVD_EZMAKER] = {
1331 /* Michael Smith <msmith@cbnco.com> */
1332 .name = "AVerMedia DVD EZMaker",
1333 .audio_clock = 0x00187de7,
1334 .tuner_type = TUNER_ABSENT,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07001335 .radio_type = UNSET,
1336 .tuner_addr = ADDR_UNSET,
1337 .radio_addr = ADDR_UNSET,
Linus Torvalds1da177e2005-04-16 15:20:36 -07001338 .inputs = {{
1339 .name = name_comp1,
1340 .vmux = 3,
1341 },{
1342 .name = name_svideo,
1343 .vmux = 8,
1344 }},
1345 },
Massimo Piccionie2fc00c2008-07-11 13:48:02 -03001346 [SAA7134_BOARD_AVERMEDIA_M103] = {
1347 /* Massimo Piccioni <dafastidio@libero.it> */
1348 .name = "AVerMedia MiniPCI DVB-T Hybrid M103",
1349 .audio_clock = 0x187de7,
1350 .tuner_type = TUNER_XC2028,
1351 .radio_type = UNSET,
1352 .tuner_addr = ADDR_UNSET,
1353 .radio_addr = ADDR_UNSET,
1354 .mpeg = SAA7134_MPEG_DVB,
1355 .inputs = {{
1356 .name = name_tv,
1357 .vmux = 1,
1358 .amux = TV,
1359 .tv = 1,
1360 } },
1361 },
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07001362 [SAA7134_BOARD_NOVAC_PRIMETV7133] = {
1363 /* toshii@netbsd.org */
1364 .name = "Noval Prime TV 7133",
1365 .audio_clock = 0x00200000,
1366 .tuner_type = TUNER_ALPS_TSBH1_NTSC,
1367 .radio_type = UNSET,
1368 .tuner_addr = ADDR_UNSET,
1369 .radio_addr = ADDR_UNSET,
1370 .inputs = {{
1371 .name = name_comp1,
1372 .vmux = 3,
1373 },{
1374 .name = name_tv,
1375 .vmux = 1,
1376 .amux = TV,
1377 .tv = 1,
1378 },{
1379 .name = name_svideo,
1380 .vmux = 8,
1381 }},
1382 },
Linus Torvalds1da177e2005-04-16 15:20:36 -07001383 [SAA7134_BOARD_AVERMEDIA_STUDIO_305] = {
1384 .name = "AverMedia AverTV Studio 305",
1385 .audio_clock = 0x00187de7,
1386 .tuner_type = TUNER_PHILIPS_FM1256_IH3,
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 .tda9887_conf = TDA9887_PRESENT,
Linus Torvalds1da177e2005-04-16 15:20:36 -07001391 .inputs = {{
1392 .name = name_tv,
1393 .vmux = 1,
1394 .amux = LINE2,
1395 .tv = 1,
1396 },{
1397 .name = name_comp1,
1398 .vmux = 0,
1399 .amux = LINE2,
1400 },{
1401 .name = name_comp2,
1402 .vmux = 3,
1403 .amux = LINE2,
1404 },{
1405 .name = name_svideo,
1406 .vmux = 8,
1407 .amux = LINE2,
1408 }},
1409 .radio = {
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07001410 .name = name_radio,
1411 .amux = LINE2,
1412 },
Linus Torvalds1da177e2005-04-16 15:20:36 -07001413 .mute = {
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07001414 .name = name_mute,
1415 .amux = LINE1,
Linus Torvalds1da177e2005-04-16 15:20:36 -07001416 },
1417 },
Vasiliy Temnikov5a5e1da2009-08-26 22:10:55 -03001418 [SAA7134_BOARD_AVERMEDIA_STUDIO_505] = {
1419 /* Vasiliy Temnikov <vaka@newmail.ru> */
1420 .name = "AverMedia AverTV Studio 505",
1421 .audio_clock = 0x00187de7,
1422 .tuner_type = TUNER_PHILIPS_FM1216ME_MK3,
1423 .radio_type = UNSET,
1424 .tuner_addr = ADDR_UNSET,
1425 .radio_addr = ADDR_UNSET,
1426 .tda9887_conf = TDA9887_PRESENT,
1427 .inputs = { {
1428 .name = name_tv,
1429 .vmux = 1,
1430 .amux = LINE2,
1431 .tv = 1,
1432 }, {
1433 .name = name_comp1,
1434 .vmux = 0,
1435 .amux = LINE2,
1436 }, {
1437 .name = name_comp2,
1438 .vmux = 3,
1439 .amux = LINE2,
1440 },{
1441 .name = name_svideo,
1442 .vmux = 8,
1443 .amux = LINE2,
1444 } },
1445 .radio = {
1446 .name = name_radio,
1447 .amux = LINE2,
1448 },
1449 .mute = {
1450 .name = name_mute,
1451 .amux = LINE1,
1452 },
1453 },
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07001454 [SAA7134_BOARD_UPMOST_PURPLE_TV] = {
1455 .name = "UPMOST PURPLE TV",
1456 .audio_clock = 0x00187de7,
1457 .tuner_type = TUNER_PHILIPS_FM1236_MK3,
1458 .radio_type = UNSET,
1459 .tuner_addr = ADDR_UNSET,
1460 .radio_addr = ADDR_UNSET,
1461 .tda9887_conf = TDA9887_PRESENT,
1462 .inputs = {{
1463 .name = name_tv,
1464 .vmux = 7,
1465 .amux = TV,
1466 .tv = 1,
1467 },{
1468 .name = name_svideo,
1469 .vmux = 7,
1470 .amux = LINE1,
1471 }},
Linus Torvalds1da177e2005-04-16 15:20:36 -07001472 },
1473 [SAA7134_BOARD_ITEMS_MTV005] = {
1474 /* Norman Jonas <normanjonas@arcor.de> */
1475 .name = "Items MuchTV Plus / IT-005",
1476 .audio_clock = 0x00187de7,
1477 .tuner_type = TUNER_PHILIPS_PAL,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07001478 .radio_type = UNSET,
1479 .tuner_addr = ADDR_UNSET,
1480 .radio_addr = ADDR_UNSET,
Linus Torvalds1da177e2005-04-16 15:20:36 -07001481 .inputs = {{
1482 .name = name_tv,
1483 .vmux = 3,
1484 .amux = TV,
1485 .tv = 1,
1486 },{
1487 .name = name_comp1,
1488 .vmux = 1,
1489 .amux = LINE1,
1490 },{
1491 .name = name_svideo,
1492 .vmux = 8,
1493 .amux = LINE1,
1494 }},
1495 .radio = {
1496 .name = name_radio,
1497 .amux = LINE2,
1498 },
1499 },
1500 [SAA7134_BOARD_CINERGY200] = {
1501 .name = "Terratec Cinergy 200 TV",
1502 .audio_clock = 0x00200000,
1503 .tuner_type = TUNER_PHILIPS_PAL,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07001504 .radio_type = UNSET,
1505 .tuner_addr = ADDR_UNSET,
1506 .radio_addr = ADDR_UNSET,
Linus Torvalds1da177e2005-04-16 15:20:36 -07001507 .inputs = {{
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07001508 .name = name_tv,
Linus Torvalds1da177e2005-04-16 15:20:36 -07001509 .vmux = 1,
1510 .amux = LINE2,
1511 .tv = 1,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07001512 },{
1513 .name = name_comp1,
1514 .vmux = 4,
1515 .amux = LINE1,
1516 },{
1517 .name = name_svideo,
1518 .vmux = 8,
1519 .amux = LINE1,
1520 },{
1521 .name = name_comp2, /* CVideo over SVideo Connector */
1522 .vmux = 0,
1523 .amux = LINE1,
Linus Torvalds1da177e2005-04-16 15:20:36 -07001524 }},
1525 .mute = {
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07001526 .name = name_mute,
1527 .amux = LINE2,
Linus Torvalds1da177e2005-04-16 15:20:36 -07001528 },
1529 },
1530 [SAA7134_BOARD_VIDEOMATE_TV_PVR] = {
1531 /* Alain St-Denis <alain@topaze.homeip.net> */
1532 .name = "Compro VideoMate TV PVR/FM",
1533 .audio_clock = 0x00187de7,
1534 .tuner_type = TUNER_PHILIPS_NTSC_M,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07001535 .radio_type = UNSET,
1536 .tuner_addr = ADDR_UNSET,
1537 .radio_addr = ADDR_UNSET,
Linus Torvalds1da177e2005-04-16 15:20:36 -07001538 .gpiomask = 0x808c0080,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07001539 .inputs = {{
1540 .name = name_svideo,
1541 .vmux = 8,
1542 .amux = LINE1,
Linus Torvalds1da177e2005-04-16 15:20:36 -07001543 .gpio = 0x00080,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07001544 },{
1545 .name = name_comp1,
1546 .vmux = 3,
1547 .amux = LINE1,
Linus Torvalds1da177e2005-04-16 15:20:36 -07001548 .gpio = 0x00080,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07001549 },{
1550 .name = name_tv,
1551 .vmux = 1,
1552 .amux = LINE2_LEFT,
1553 .tv = 1,
Linus Torvalds1da177e2005-04-16 15:20:36 -07001554 .gpio = 0x00080,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07001555 }},
Linus Torvalds1da177e2005-04-16 15:20:36 -07001556 .radio = {
1557 .name = name_radio,
1558 .amux = LINE2,
1559 .gpio = 0x80000,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07001560 },
Linus Torvalds1da177e2005-04-16 15:20:36 -07001561 .mute = {
1562 .name = name_mute,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07001563 .amux = LINE2,
Linus Torvalds1da177e2005-04-16 15:20:36 -07001564 .gpio = 0x40000,
1565 },
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07001566 },
1567 [SAA7134_BOARD_SABRENT_SBTTVFM] = {
Linus Torvalds1da177e2005-04-16 15:20:36 -07001568 /* Michael Rodriguez-Torrent <mrtorrent@asu.edu> */
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07001569 .name = "Sabrent SBT-TVFM (saa7130)",
1570 .audio_clock = 0x00187de7,
1571 .tuner_type = TUNER_PHILIPS_NTSC_M,
1572 .radio_type = UNSET,
1573 .tuner_addr = ADDR_UNSET,
1574 .radio_addr = ADDR_UNSET,
1575 .inputs = {{
Linus Torvalds1da177e2005-04-16 15:20:36 -07001576 .name = name_comp1,
1577 .vmux = 1,
Mauro Carvalho Chehab6a989d72005-09-09 13:03:57 -07001578 .amux = LINE1,
Linus Torvalds1da177e2005-04-16 15:20:36 -07001579 },{
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07001580 .name = name_tv,
1581 .vmux = 3,
1582 .amux = LINE2,
1583 .tv = 1,
1584 },{
1585 .name = name_svideo,
1586 .vmux = 8,
Mauro Carvalho Chehab6a989d72005-09-09 13:03:57 -07001587 .amux = LINE1,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07001588 }},
1589 .radio = {
1590 .name = name_radio,
1591 .amux = LINE2,
1592 },
1593 },
Linus Torvalds1da177e2005-04-16 15:20:36 -07001594 [SAA7134_BOARD_ZOLID_XPERT_TV7134] = {
1595 /* Helge Jensen <helge.jensen@slog.dk> */
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07001596 .name = ":Zolid Xpert TV7134",
Linus Torvalds1da177e2005-04-16 15:20:36 -07001597 .audio_clock = 0x00187de7,
1598 .tuner_type = TUNER_PHILIPS_NTSC,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07001599 .radio_type = UNSET,
1600 .tuner_addr = ADDR_UNSET,
1601 .radio_addr = ADDR_UNSET,
1602 .inputs = {{
Linus Torvalds1da177e2005-04-16 15:20:36 -07001603 .name = name_svideo,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07001604 .vmux = 8,
1605 .amux = LINE1,
1606 },{
1607 .name = name_comp1,
1608 .vmux = 3,
1609 .amux = LINE1,
1610 },{
1611 .name = name_tv,
1612 .vmux = 1,
1613 .amux = LINE2,
1614 .tv = 1,
1615 }},
Linus Torvalds1da177e2005-04-16 15:20:36 -07001616 },
1617 [SAA7134_BOARD_EMPIRE_PCI_TV_RADIO_LE] = {
1618 /* "Matteo Az" <matte.az@nospam.libero.it> ;-) */
1619 .name = "Empire PCI TV-Radio LE",
1620 .audio_clock = 0x00187de7,
1621 .tuner_type = TUNER_PHILIPS_PAL,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07001622 .radio_type = UNSET,
1623 .tuner_addr = ADDR_UNSET,
1624 .radio_addr = ADDR_UNSET,
Linus Torvalds1da177e2005-04-16 15:20:36 -07001625 .gpiomask = 0x4000,
1626 .inputs = {{
1627 .name = name_tv_mono,
1628 .vmux = 1,
1629 .amux = LINE2,
1630 .gpio = 0x8000,
1631 .tv = 1,
1632 },{
1633 .name = name_comp1,
1634 .vmux = 3,
1635 .amux = LINE1,
1636 .gpio = 0x8000,
1637 },{
1638 .name = name_svideo,
1639 .vmux = 6,
1640 .amux = LINE1,
1641 .gpio = 0x8000,
1642 }},
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07001643 .radio = {
1644 .name = name_radio,
1645 .amux = LINE1,
1646 .gpio = 0x8000,
1647 },
Linus Torvalds1da177e2005-04-16 15:20:36 -07001648 .mute = {
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07001649 .name = name_mute,
1650 .amux = TV,
1651 .gpio =0x8000,
1652 }
Linus Torvalds1da177e2005-04-16 15:20:36 -07001653 },
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07001654 [SAA7134_BOARD_AVERMEDIA_STUDIO_307] = {
Linus Torvalds1da177e2005-04-16 15:20:36 -07001655 /*
1656 Nickolay V. Shmyrev <nshmyrev@yandex.ru>
1657 Lots of thanks to Andrey Zolotarev <zolotarev_andrey@mail.ru>
1658 */
1659 .name = "Avermedia AVerTV Studio 307",
1660 .audio_clock = 0x00187de7,
1661 .tuner_type = TUNER_PHILIPS_FM1256_IH3,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07001662 .radio_type = UNSET,
1663 .tuner_addr = ADDR_UNSET,
1664 .radio_addr = ADDR_UNSET,
Linus Torvalds1da177e2005-04-16 15:20:36 -07001665 .tda9887_conf = TDA9887_PRESENT,
1666 .gpiomask = 0x03,
1667 .inputs = {{
1668 .name = name_tv,
1669 .vmux = 1,
1670 .amux = TV,
1671 .tv = 1,
1672 .gpio = 0x00,
1673 },{
Stas Sergeevf438d972007-09-17 15:34:09 -03001674 .name = name_comp,
Linus Torvalds1da177e2005-04-16 15:20:36 -07001675 .vmux = 3,
Stas Sergeevf5e4fee2007-09-02 03:56:18 -03001676 .amux = LINE1,
1677 .gpio = 0x02,
Linus Torvalds1da177e2005-04-16 15:20:36 -07001678 },{
1679 .name = name_svideo,
1680 .vmux = 8,
Stas Sergeevf5e4fee2007-09-02 03:56:18 -03001681 .amux = LINE1,
1682 .gpio = 0x02,
Linus Torvalds1da177e2005-04-16 15:20:36 -07001683 }},
1684 .radio = {
1685 .name = name_radio,
1686 .amux = LINE1,
1687 .gpio = 0x01,
1688 },
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07001689 .mute = {
1690 .name = name_mute,
1691 .amux = LINE1,
1692 .gpio = 0x00,
1693 },
1694 },
1695 [SAA7134_BOARD_AVERMEDIA_GO_007_FM] = {
Mauro Carvalho Chehabac19ecc2005-06-23 22:05:09 -07001696 .name = "Avermedia AVerTV GO 007 FM",
1697 .audio_clock = 0x00187de7,
1698 .tuner_type = TUNER_PHILIPS_TDA8290,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07001699 .radio_type = UNSET,
1700 .tuner_addr = ADDR_UNSET,
1701 .radio_addr = ADDR_UNSET,
Mauro Carvalho Chehabac19ecc2005-06-23 22:05:09 -07001702 .gpiomask = 0x00300003,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07001703 /* .gpiomask = 0x8c240003, */
Mauro Carvalho Chehabac19ecc2005-06-23 22:05:09 -07001704 .inputs = {{
1705 .name = name_tv,
1706 .vmux = 1,
1707 .amux = TV,
1708 .tv = 1,
1709 .gpio = 0x01,
1710 },{
1711 .name = name_comp1,
1712 .vmux = 0,
Damian Minkovfbc84082007-03-29 08:47:39 -03001713 .amux = LINE1,
Mauro Carvalho Chehabac19ecc2005-06-23 22:05:09 -07001714 .gpio = 0x02,
1715 },{
1716 .name = name_svideo,
1717 .vmux = 6,
Damian Minkovfbc84082007-03-29 08:47:39 -03001718 .amux = LINE1,
Mauro Carvalho Chehabac19ecc2005-06-23 22:05:09 -07001719 .gpio = 0x02,
1720 }},
1721 .radio = {
1722 .name = name_radio,
hermann pitton46058122009-08-04 20:11:43 -03001723 .amux = TV,
Mauro Carvalho Chehabac19ecc2005-06-23 22:05:09 -07001724 .gpio = 0x00300001,
1725 },
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07001726 .mute = {
1727 .name = name_mute,
1728 .amux = TV,
1729 .gpio = 0x01,
1730 },
1731 },
Linus Torvalds1da177e2005-04-16 15:20:36 -07001732 [SAA7134_BOARD_AVERMEDIA_CARDBUS] = {
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07001733 /* Kees.Blom@cwi.nl */
1734 .name = "AVerMedia Cardbus TV/Radio (E500)",
1735 .audio_clock = 0x187de7,
1736 .tuner_type = TUNER_PHILIPS_TDA8290,
1737 .radio_type = UNSET,
1738 .tuner_addr = ADDR_UNSET,
1739 .radio_addr = ADDR_UNSET,
Linus Torvalds1da177e2005-04-16 15:20:36 -07001740 .inputs = {{
1741 .name = name_tv,
1742 .vmux = 1,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07001743 .amux = TV,
Linus Torvalds1da177e2005-04-16 15:20:36 -07001744 .tv = 1,
1745 },{
1746 .name = name_comp1,
1747 .vmux = 3,
1748 .amux = LINE2,
1749 },{
1750 .name = name_svideo,
1751 .vmux = 8,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07001752 .amux = LINE1,
Linus Torvalds1da177e2005-04-16 15:20:36 -07001753 }},
1754 .radio = {
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07001755 .name = name_radio,
Linus Torvalds1da177e2005-04-16 15:20:36 -07001756 .amux = LINE1,
1757 },
1758 },
Oldřich Jedličkad46de9d2009-04-14 15:47:17 -03001759 [SAA7134_BOARD_AVERMEDIA_CARDBUS_501] = {
1760 /* Oldrich Jedlicka <oldium.pro@seznam.cz> */
1761 .name = "AVerMedia Cardbus TV/Radio (E501R)",
1762 .audio_clock = 0x187de7,
1763 .tuner_type = TUNER_ALPS_TSBE5_PAL,
1764 .radio_type = TUNER_TEA5767,
1765 .tuner_addr = 0x61,
1766 .radio_addr = 0x60,
1767 .tda9887_conf = TDA9887_PRESENT,
1768 .gpiomask = 0x08000000,
1769 .inputs = { {
1770 .name = name_tv,
1771 .vmux = 1,
1772 .amux = TV,
1773 .tv = 1,
1774 .gpio = 0x08000000,
1775 }, {
1776 .name = name_comp1,
1777 .vmux = 3,
1778 .amux = LINE1,
1779 .gpio = 0x08000000,
1780 }, {
1781 .name = name_svideo,
1782 .vmux = 8,
1783 .amux = LINE1,
1784 .gpio = 0x08000000,
1785 } },
1786 .radio = {
1787 .name = name_radio,
1788 .amux = LINE2,
1789 .gpio = 0x00000000,
1790 },
1791 },
Linus Torvalds1da177e2005-04-16 15:20:36 -07001792 [SAA7134_BOARD_CINERGY400_CARDBUS] = {
1793 .name = "Terratec Cinergy 400 mobile",
1794 .audio_clock = 0x187de7,
1795 .tuner_type = TUNER_ALPS_TSBE5_PAL,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07001796 .radio_type = UNSET,
1797 .tuner_addr = ADDR_UNSET,
1798 .radio_addr = ADDR_UNSET,
1799 .tda9887_conf = TDA9887_PRESENT,
Linus Torvalds1da177e2005-04-16 15:20:36 -07001800 .inputs = {{
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07001801 .name = name_tv,
Linus Torvalds1da177e2005-04-16 15:20:36 -07001802 .vmux = 1,
1803 .amux = TV,
1804 .tv = 1,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07001805 },{
Linus Torvalds1da177e2005-04-16 15:20:36 -07001806 .name = name_tv_mono,
1807 .vmux = 1,
1808 .amux = LINE2,
1809 .tv = 1,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07001810 },{
1811 .name = name_comp1,
1812 .vmux = 3,
1813 .amux = LINE1,
1814 },{
1815 .name = name_svideo,
1816 .vmux = 8,
1817 .amux = LINE1,
Linus Torvalds1da177e2005-04-16 15:20:36 -07001818 }},
1819 },
1820 [SAA7134_BOARD_CINERGY600_MK3] = {
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07001821 .name = "Terratec Cinergy 600 TV MK3",
1822 .audio_clock = 0x00200000,
Linus Torvalds1da177e2005-04-16 15:20:36 -07001823 .tuner_type = TUNER_PHILIPS_FM1216ME_MK3,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07001824 .radio_type = UNSET,
1825 .tuner_addr = ADDR_UNSET,
1826 .radio_addr = ADDR_UNSET,
Hans Verkuil2983baf2009-03-29 06:26:27 -03001827 .rds_addr = 0x10,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07001828 .tda9887_conf = TDA9887_PRESENT,
1829 .inputs = {{
1830 .name = name_tv,
1831 .vmux = 1,
1832 .amux = TV,
1833 .tv = 1,
1834 },{
1835 .name = name_comp1,
1836 .vmux = 4,
1837 .amux = LINE1,
1838 },{
1839 .name = name_svideo,
1840 .vmux = 8,
1841 .amux = LINE1,
1842 },{
1843 .name = name_comp2, /* CVideo over SVideo Connector */
1844 .vmux = 0,
1845 .amux = LINE1,
1846 }},
Linus Torvalds1da177e2005-04-16 15:20:36 -07001847 .radio = {
1848 .name = name_radio,
1849 .amux = LINE2,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07001850 },
1851 },
1852 [SAA7134_BOARD_VIDEOMATE_GOLD_PLUS] = {
1853 /* Dylan Walkden <dylan_walkden@hotmail.com> */
1854 .name = "Compro VideoMate Gold+ Pal",
1855 .audio_clock = 0x00187de7,
1856 .tuner_type = TUNER_PHILIPS_PAL,
1857 .radio_type = UNSET,
1858 .tuner_addr = ADDR_UNSET,
1859 .radio_addr = ADDR_UNSET,
1860 .gpiomask = 0x1ce780,
1861 .inputs = {{
1862 .name = name_svideo,
1863 .vmux = 0, /* CVideo over SVideo Connector - ok? */
1864 .amux = LINE1,
1865 .gpio = 0x008080,
1866 },{
1867 .name = name_comp1,
1868 .vmux = 3,
1869 .amux = LINE1,
1870 .gpio = 0x008080,
1871 },{
1872 .name = name_tv,
1873 .vmux = 1,
1874 .amux = TV,
1875 .tv = 1,
1876 .gpio = 0x008080,
1877 }},
1878 .radio = {
1879 .name = name_radio,
1880 .amux = LINE2,
1881 .gpio = 0x80000,
1882 },
1883 .mute = {
1884 .name = name_mute,
1885 .amux = LINE2,
1886 .gpio = 0x0c8000,
1887 },
1888 },
Linus Torvalds1da177e2005-04-16 15:20:36 -07001889 [SAA7134_BOARD_PINNACLE_300I_DVBT_PAL] = {
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07001890 .name = "Pinnacle PCTV 300i DVB-T + PAL",
1891 .audio_clock = 0x00187de7,
1892 .tuner_type = TUNER_MT2032,
1893 .radio_type = UNSET,
1894 .tuner_addr = ADDR_UNSET,
1895 .radio_addr = ADDR_UNSET,
Hartmut Hackmanndf8cf702006-03-03 12:09:26 -03001896 .tda9887_conf = TDA9887_PRESENT | TDA9887_INTERCARRIER | TDA9887_PORT2_INACTIVE,
Linus Torvalds1da177e2005-04-16 15:20:36 -07001897 .mpeg = SAA7134_MPEG_DVB,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07001898 .inputs = {{
1899 .name = name_tv,
1900 .vmux = 3,
1901 .amux = TV,
1902 .tv = 1,
1903 },{
1904 .name = name_comp1,
1905 .vmux = 0,
1906 .amux = LINE2,
1907 },{
1908 .name = name_comp2,
1909 .vmux = 1,
1910 .amux = LINE2,
1911 },{
1912 .name = name_svideo,
1913 .vmux = 8,
1914 .amux = LINE2,
1915 }},
1916 },
Linus Torvalds1da177e2005-04-16 15:20:36 -07001917 [SAA7134_BOARD_PROVIDEO_PV952] = {
1918 /* andreas.kretschmer@web.de */
1919 .name = "ProVideo PV952",
1920 .audio_clock = 0x00187de7,
1921 .tuner_type = TUNER_PHILIPS_FM1216ME_MK3,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07001922 .radio_type = UNSET,
1923 .tuner_addr = ADDR_UNSET,
1924 .radio_addr = ADDR_UNSET,
Linus Torvalds1da177e2005-04-16 15:20:36 -07001925 .tda9887_conf = TDA9887_PRESENT,
1926 .inputs = {{
1927 .name = name_comp1,
1928 .vmux = 0,
1929 .amux = LINE1,
1930 },{
1931 .name = name_tv,
1932 .vmux = 1,
1933 .amux = TV,
1934 .tv = 1,
1935 },{
1936 .name = name_tv_mono,
1937 .vmux = 1,
1938 .amux = LINE2,
1939 .tv = 1,
1940 }},
1941 .radio = {
1942 .name = name_radio,
1943 .amux = LINE2,
1944 },
1945 },
1946 [SAA7134_BOARD_AVERMEDIA_305] = {
1947 /* much like the "studio" version but without radio
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07001948 * and another tuner (sirspiritus@yandex.ru) */
Linus Torvalds1da177e2005-04-16 15:20:36 -07001949 .name = "AverMedia AverTV/305",
1950 .audio_clock = 0x00187de7,
1951 .tuner_type = TUNER_PHILIPS_FQ1216ME,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07001952 .radio_type = UNSET,
1953 .tuner_addr = ADDR_UNSET,
1954 .radio_addr = ADDR_UNSET,
Linus Torvalds1da177e2005-04-16 15:20:36 -07001955 .tda9887_conf = TDA9887_PRESENT,
Linus Torvalds1da177e2005-04-16 15:20:36 -07001956 .inputs = {{
1957 .name = name_tv,
1958 .vmux = 1,
1959 .amux = LINE2,
1960 .tv = 1,
1961 },{
1962 .name = name_comp1,
1963 .vmux = 0,
1964 .amux = LINE2,
1965 },{
1966 .name = name_comp2,
1967 .vmux = 3,
1968 .amux = LINE2,
1969 },{
1970 .name = name_svideo,
1971 .vmux = 8,
1972 .amux = LINE2,
1973 }},
1974 .mute = {
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07001975 .name = name_mute,
1976 .amux = LINE1,
Linus Torvalds1da177e2005-04-16 15:20:36 -07001977 },
1978 },
1979 [SAA7134_BOARD_FLYDVBTDUO] = {
1980 /* LifeView FlyDVB-T DUO */
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07001981 /* "Nico Sabbi <nsabbi@tiscali.it> Hartmut Hackmann hartmut.hackmann@t-online.de*/
Peter Misseldb483672007-04-27 12:31:20 -03001982 .name = "LifeView FlyDVB-T DUO / MSI TV@nywhere Duo",
Linus Torvalds1da177e2005-04-16 15:20:36 -07001983 .audio_clock = 0x00200000,
1984 .tuner_type = TUNER_PHILIPS_TDA8290,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07001985 .radio_type = UNSET,
1986 .tuner_addr = ADDR_UNSET,
1987 .radio_addr = ADDR_UNSET,
Peter Missel7c7fea62007-04-27 12:31:14 -03001988 .gpiomask = 0x00200000,
Michael Krufky8ce47da2007-04-27 12:31:14 -03001989 .mpeg = SAA7134_MPEG_DVB,
Linus Torvalds1da177e2005-04-16 15:20:36 -07001990 .inputs = {{
1991 .name = name_tv,
1992 .vmux = 1,
1993 .amux = TV,
Peter Missel7c7fea62007-04-27 12:31:14 -03001994 .gpio = 0x200000, /* GPIO21=High for TV input */
Linus Torvalds1da177e2005-04-16 15:20:36 -07001995 .tv = 1,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07001996 },{
Linus Torvalds1da177e2005-04-16 15:20:36 -07001997 .name = name_comp1, /* Composite signal on S-Video input */
1998 .vmux = 0,
1999 .amux = LINE2,
Linus Torvalds1da177e2005-04-16 15:20:36 -07002000 },{
2001 .name = name_comp2, /* Composite input */
2002 .vmux = 3,
2003 .amux = LINE2,
Linus Torvalds1da177e2005-04-16 15:20:36 -07002004 },{
2005 .name = name_svideo, /* S-Video signal on S-Video input */
2006 .vmux = 8,
2007 .amux = LINE2,
Linus Torvalds1da177e2005-04-16 15:20:36 -07002008 }},
Peter Missel7c7fea62007-04-27 12:31:14 -03002009 .radio = {
2010 .name = name_radio,
2011 .amux = TV,
2012 .gpio = 0x000000, /* GPIO21=Low for FM radio antenna */
2013 },
Linus Torvalds1da177e2005-04-16 15:20:36 -07002014 },
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07002015 [SAA7134_BOARD_PHILIPS_TOUGH] = {
2016 .name = "Philips TOUGH DVB-T reference design",
2017 .tuner_type = TUNER_ABSENT,
Mauro Carvalho Chehabac19ecc2005-06-23 22:05:09 -07002018 .audio_clock = 0x00187de7,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07002019 .radio_type = UNSET,
2020 .tuner_addr = ADDR_UNSET,
2021 .radio_addr = ADDR_UNSET,
2022 .mpeg = SAA7134_MPEG_DVB,
2023 .inputs = {{
2024 .name = name_comp1,
2025 .vmux = 0,
2026 .amux = LINE1,
2027 },{
2028 .name = name_svideo,
2029 .vmux = 8,
2030 .amux = LINE1,
2031 }},
Mauro Carvalho Chehabac19ecc2005-06-23 22:05:09 -07002032 },
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07002033 [SAA7134_BOARD_AVERMEDIA_307] = {
2034 /*
2035 Davydov Vladimir <vladimir@iqmedia.com>
2036 */
2037 .name = "Avermedia AVerTV 307",
2038 .audio_clock = 0x00187de7,
2039 .tuner_type = TUNER_PHILIPS_FQ1216ME,
2040 .radio_type = UNSET,
2041 .tuner_addr = ADDR_UNSET,
2042 .radio_addr = ADDR_UNSET,
2043 .tda9887_conf = TDA9887_PRESENT,
2044 .inputs = {{
2045 .name = name_tv,
2046 .vmux = 1,
2047 .amux = TV,
2048 .tv = 1,
2049 },{
2050 .name = name_comp1,
2051 .vmux = 0,
2052 .amux = LINE1,
2053 },{
2054 .name = name_comp2,
2055 .vmux = 3,
2056 .amux = LINE1,
2057 },{
2058 .name = name_svideo,
2059 .vmux = 8,
2060 .amux = LINE1,
2061 }},
2062 },
2063 [SAA7134_BOARD_ADS_INSTANT_TV] = {
2064 .name = "ADS Tech Instant TV (saa7135)",
2065 .audio_clock = 0x00187de7,
2066 .tuner_type = TUNER_PHILIPS_TDA8290,
2067 .radio_type = UNSET,
2068 .tuner_addr = ADDR_UNSET,
2069 .radio_addr = ADDR_UNSET,
2070 .inputs = {{
2071 .name = name_tv,
2072 .vmux = 1,
2073 .amux = TV,
2074 .tv = 1,
2075 },{
2076 .name = name_comp1,
2077 .vmux = 3,
2078 .amux = LINE2,
2079 },{
2080 .name = name_svideo,
2081 .vmux = 8,
2082 .amux = LINE2,
2083 }},
2084 },
2085 [SAA7134_BOARD_KWORLD_VSTREAM_XPERT] = {
2086 .name = "Kworld/Tevion V-Stream Xpert TV PVR7134",
2087 .audio_clock = 0x00187de7,
2088 .tuner_type = TUNER_PHILIPS_PAL_I,
2089 .radio_type = UNSET,
2090 .tuner_addr = ADDR_UNSET,
2091 .radio_addr = ADDR_UNSET,
2092 .gpiomask = 0x0700,
2093 .inputs = {{
2094 .name = name_tv,
2095 .vmux = 1,
2096 .amux = TV,
2097 .tv = 1,
2098 .gpio = 0x000,
2099 },{
2100 .name = name_comp1,
2101 .vmux = 3,
2102 .amux = LINE1,
2103 .gpio = 0x200, /* gpio by DScaler */
2104 },{
2105 .name = name_svideo,
2106 .vmux = 0,
2107 .amux = LINE1,
2108 .gpio = 0x200,
2109 }},
2110 .radio = {
2111 .name = name_radio,
2112 .amux = LINE1,
2113 .gpio = 0x100,
2114 },
2115 .mute = {
2116 .name = name_mute,
2117 .amux = TV,
2118 .gpio = 0x000,
2119 },
2120 },
Peter Missel10b7a902006-01-23 17:11:06 -02002121 [SAA7134_BOARD_FLYDVBT_DUO_CARDBUS] = {
Hartmut Hackmann2c591942006-08-07 14:03:32 -03002122 .name = "LifeView/Typhoon/Genius FlyDVB-T Duo Cardbus",
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07002123 .audio_clock = 0x00200000,
2124 .tuner_type = TUNER_PHILIPS_TDA8290,
2125 .radio_type = UNSET,
2126 .tuner_addr = ADDR_UNSET,
2127 .radio_addr = ADDR_UNSET,
2128 .mpeg = SAA7134_MPEG_DVB,
Peter Missel10b7a902006-01-23 17:11:06 -02002129 .gpiomask = 0x00200000,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07002130 .inputs = {{
2131 .name = name_tv,
2132 .vmux = 1,
2133 .amux = TV,
Peter Missel10b7a902006-01-23 17:11:06 -02002134 .gpio = 0x200000, /* GPIO21=High for TV input */
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07002135 .tv = 1,
2136 },{
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07002137 .name = name_svideo, /* S-Video signal on S-Video input */
2138 .vmux = 8,
2139 .amux = LINE2,
Peter Missel10b7a902006-01-23 17:11:06 -02002140 },{
2141 .name = name_comp1, /* Composite signal on S-Video input */
2142 .vmux = 0,
2143 .amux = LINE2,
2144 },{
2145 .name = name_comp2, /* Composite input */
2146 .vmux = 3,
2147 .amux = LINE2,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07002148 }},
2149 .radio = {
2150 .name = name_radio,
Peter Missel10b7a902006-01-23 17:11:06 -02002151 .amux = TV,
2152 .gpio = 0x000000, /* GPIO21=Low for FM radio antenna */
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07002153 },
2154 },
2155 [SAA7134_BOARD_VIDEOMATE_TV_GOLD_PLUSII] = {
2156 .name = "Compro VideoMate TV Gold+II",
2157 .audio_clock = 0x002187de7,
2158 .tuner_type = TUNER_LG_PAL_NEW_TAPC,
2159 .radio_type = TUNER_TEA5767,
2160 .tuner_addr = 0x63,
2161 .radio_addr = 0x60,
2162 .gpiomask = 0x8c1880,
2163 .inputs = {{
2164 .name = name_svideo,
2165 .vmux = 0,
2166 .amux = LINE1,
2167 .gpio = 0x800800,
2168 },{
2169 .name = name_comp1,
2170 .vmux = 3,
2171 .amux = LINE1,
2172 .gpio = 0x801000,
2173 },{
2174 .name = name_tv,
2175 .vmux = 1,
2176 .amux = TV,
2177 .tv = 1,
2178 .gpio = 0x800000,
2179 }},
2180 .radio = {
2181 .name = name_radio,
2182 .amux = TV,
2183 .gpio = 0x880000,
2184 },
2185 .mute = {
2186 .name = name_mute,
2187 .amux = LINE2,
2188 .gpio = 0x840000,
2189 },
2190 },
2191 [SAA7134_BOARD_KWORLD_XPERT] = {
2192 /*
2193 FIXME:
2194 - Remote control doesn't initialize properly.
2195 - Audio volume starts muted,
2196 then gradually increases after channel change.
2197 - Overlay scaling problems (application error?)
2198 - Composite S-Video untested.
2199 From: Konrad Rzepecki <hannibal@megapolis.pl>
2200 */
2201 .name = "Kworld Xpert TV PVR7134",
2202 .audio_clock = 0x00187de7,
2203 .tuner_type = TUNER_TENA_9533_DI,
2204 .radio_type = TUNER_TEA5767,
2205 .tuner_addr = 0x61,
2206 .radio_addr = 0x60,
2207 .gpiomask = 0x0700,
2208 .inputs = {{
2209 .name = name_tv,
2210 .vmux = 1,
2211 .amux = TV,
2212 .tv = 1,
2213 .gpio = 0x000,
2214 },{
2215 .name = name_comp1,
2216 .vmux = 3,
2217 .amux = LINE1,
2218 .gpio = 0x200, /* gpio by DScaler */
2219 },{
2220 .name = name_svideo,
2221 .vmux = 0,
2222 .amux = LINE1,
2223 .gpio = 0x200,
2224 }},
2225 .radio = {
2226 .name = name_radio,
2227 .amux = LINE1,
2228 .gpio = 0x100,
2229 },
2230 .mute = {
2231 .name = name_mute,
2232 .amux = TV,
2233 .gpio = 0x000,
2234 },
2235 },
Mauro Carvalho Chehab2f180712005-09-09 13:03:46 -07002236 [SAA7134_BOARD_FLYTV_DIGIMATRIX] = {
2237 .name = "FlyTV mini Asus Digimatrix",
2238 .audio_clock = 0x00200000,
Michael Krufkyf3629be2006-03-11 17:02:01 -03002239 .tuner_type = TUNER_LG_TALN,
Mauro Carvalho Chehab2f180712005-09-09 13:03:46 -07002240 .radio_type = UNSET,
2241 .tuner_addr = ADDR_UNSET,
2242 .radio_addr = ADDR_UNSET,
2243 .inputs = {{
2244 .name = name_tv,
2245 .vmux = 1,
2246 .amux = TV,
2247 .tv = 1,
2248 },{
2249 .name = name_tv_mono,
2250 .vmux = 1,
2251 .amux = LINE2,
2252 .tv = 1,
2253 },{
2254 .name = name_comp1,
2255 .vmux = 0,
2256 .amux = LINE2,
2257 },{
2258 .name = name_comp2,
2259 .vmux = 3,
2260 .amux = LINE2,
2261 },{
2262 .name = name_svideo,
2263 .vmux = 8,
2264 .amux = LINE2,
2265 }},
2266 .radio = {
2267 .name = name_radio, /* radio unconfirmed */
2268 .amux = LINE2,
2269 },
2270 },
Mauro Carvalho Chehab260784d2005-09-09 13:03:49 -07002271 [SAA7134_BOARD_KWORLD_TERMINATOR] = {
2272 /* Kworld V-Stream Studio TV Terminator */
2273 /* "James Webb <jrwebb@qwest.net> */
2274 .name = "V-Stream Studio TV Terminator",
2275 .audio_clock = 0x00187de7,
2276 .tuner_type = TUNER_PHILIPS_TDA8290,
2277 .radio_type = UNSET,
2278 .tuner_addr = ADDR_UNSET,
2279 .radio_addr = ADDR_UNSET,
2280 .gpiomask = 1 << 21,
2281 .inputs = {{
2282 .name = name_tv,
2283 .vmux = 1,
2284 .amux = TV,
2285 .gpio = 0x0000000,
2286 .tv = 1,
2287 },{
2288 .name = name_comp1, /* Composite input */
2289 .vmux = 3,
2290 .amux = LINE2,
2291 .gpio = 0x0000000,
2292 },{
2293 .name = name_svideo, /* S-Video input */
2294 .vmux = 8,
2295 .amux = LINE2,
2296 .gpio = 0x0000000,
2297 }},
2298 .radio = {
2299 .name = name_radio,
2300 .amux = TV,
2301 .gpio = 0x0200000,
2302 },
2303 },
Mauro Carvalho Chehab4279f022005-09-09 13:03:51 -07002304 [SAA7134_BOARD_YUAN_TUN900] = {
2305 /* FIXME:
2306 * S-Video and composite sources untested.
2307 * Radio not working.
2308 * Remote control not yet implemented.
2309 * From : codemaster@webgeeks.be */
2310 .name = "Yuan TUN-900 (saa7135)",
2311 .audio_clock = 0x00187de7,
2312 .tuner_type = TUNER_PHILIPS_TDA8290,
2313 .radio_type = UNSET,
2314 .tuner_addr= ADDR_UNSET,
2315 .radio_addr= ADDR_UNSET,
2316 .gpiomask = 0x00010003,
2317 .inputs = {{
2318 .name = name_tv,
2319 .vmux = 1,
2320 .amux = TV,
2321 .tv = 1,
2322 .gpio = 0x01,
2323 },{
2324 .name = name_comp1,
2325 .vmux = 0,
2326 .amux = LINE2,
2327 .gpio = 0x02,
2328 },{
2329 .name = name_svideo,
2330 .vmux = 6,
2331 .amux = LINE2,
2332 .gpio = 0x02,
2333 }},
2334 .radio = {
2335 .name = name_radio,
2336 .amux = LINE1,
2337 .gpio = 0x00010003,
2338 },
2339 .mute = {
2340 .name = name_mute,
2341 .amux = TV,
2342 .gpio = 0x01,
2343 },
2344 },
Nickolay V. Shmyreva8ff4172005-11-08 21:36:16 -08002345 [SAA7134_BOARD_BEHOLD_409FM] = {
Mauro Carvalho Chehab4ac97912005-11-08 21:37:43 -08002346 /* <http://tuner.beholder.ru>, Sergey <skiv@orel.ru> */
Dmitry Belimovb34dddb2008-04-23 14:09:08 -03002347 /* Beholder Intl. Ltd. 2008 */
2348 /*Dmitry Belimov <d.belimov@gmail.com> */
Mauro Carvalho Chehab4ac97912005-11-08 21:37:43 -08002349 .name = "Beholder BeholdTV 409 FM",
2350 .audio_clock = 0x00187de7,
2351 .tuner_type = TUNER_PHILIPS_FM1216ME_MK3,
2352 .radio_type = UNSET,
2353 .tuner_addr = ADDR_UNSET,
2354 .radio_addr = ADDR_UNSET,
2355 .tda9887_conf = TDA9887_PRESENT,
Dmitry Belimovb34dddb2008-04-23 14:09:08 -03002356 .gpiomask = 0x00008000,
Mauro Carvalho Chehab4ac97912005-11-08 21:37:43 -08002357 .inputs = {{
2358 .name = name_tv,
Nickolay V. Shmyreva8ff4172005-11-08 21:36:16 -08002359 .vmux = 3,
2360 .amux = TV,
2361 .tv = 1,
2362 },{
2363 .name = name_comp1,
2364 .vmux = 1,
2365 .amux = LINE1,
Mauro Carvalho Chehab4ac97912005-11-08 21:37:43 -08002366 },{
2367 .name = name_svideo,
Nickolay V. Shmyreva8ff4172005-11-08 21:36:16 -08002368 .vmux = 8,
2369 .amux = LINE1,
Mauro Carvalho Chehab4ac97912005-11-08 21:37:43 -08002370 }},
2371 .radio = {
2372 .name = name_radio,
Nickolay V. Shmyreva8ff4172005-11-08 21:36:16 -08002373 .amux = LINE2,
Trent Piepho657de3c2006-06-20 00:30:57 -03002374 },
Mauro Carvalho Chehab4ac97912005-11-08 21:37:43 -08002375 },
2376 [SAA7134_BOARD_GOTVIEW_7135] = {
Nickolay V. Shmyrevdcd555e2005-11-08 21:36:23 -08002377 /* Mike Baikov <mike@baikov.com> */
Nickolay V. Shmyrev6b961442005-11-08 21:36:22 -08002378 /* Andrey Cvetcov <ays14@yandex.ru> */
Mauro Carvalho Chehab4ac97912005-11-08 21:37:43 -08002379 .name = "GoTView 7135 PCI",
2380 .audio_clock = 0x00187de7,
2381 .tuner_type = TUNER_PHILIPS_FM1216ME_MK3,
2382 .radio_type = UNSET,
2383 .tuner_addr = ADDR_UNSET,
2384 .radio_addr = ADDR_UNSET,
2385 .tda9887_conf = TDA9887_PRESENT,
2386 .gpiomask = 0x00200003,
2387 .inputs = {{
2388 .name = name_tv,
2389 .vmux = 1,
2390 .amux = TV,
2391 .tv = 1,
2392 .gpio = 0x00200003,
2393 },{
2394 .name = name_tv_mono,
2395 .vmux = 1,
2396 .amux = LINE2,
2397 .gpio = 0x00200003,
2398 },{
2399 .name = name_comp1,
2400 .vmux = 3,
2401 .amux = LINE1,
2402 .gpio = 0x00200003,
2403 },{
2404 .name = name_svideo,
2405 .vmux = 8,
2406 .amux = LINE1,
2407 .gpio = 0x00200003,
2408 }},
2409 .radio = {
2410 .name = name_radio,
2411 .amux = LINE2,
2412 .gpio = 0x00200003,
2413 },
2414 .mute = {
2415 .name = name_mute,
2416 .amux = TV,
2417 .gpio = 0x00200003,
2418 },
2419 },
Hartmut Hackmann2cf36ac2005-11-08 21:36:32 -08002420 [SAA7134_BOARD_PHILIPS_EUROPA] = {
2421 .name = "Philips EUROPA V3 reference design",
2422 .audio_clock = 0x00187de7,
2423 .tuner_type = TUNER_PHILIPS_TD1316,
2424 .radio_type = UNSET,
2425 .tuner_addr = 0x61,
2426 .radio_addr = ADDR_UNSET,
Hartmut Hackmann44fd06f2006-02-27 00:09:11 -03002427 .tda9887_conf = TDA9887_PRESENT | TDA9887_PORT1_ACTIVE,
Hartmut Hackmann2cf36ac2005-11-08 21:36:32 -08002428 .mpeg = SAA7134_MPEG_DVB,
2429 .inputs = {{
2430 .name = name_tv,
2431 .vmux = 3,
2432 .amux = TV,
2433 .tv = 1,
2434 },{
2435 .name = name_comp1,
2436 .vmux = 0,
2437 .amux = LINE2,
2438 },{
2439 .name = name_svideo,
2440 .vmux = 8,
2441 .amux = LINE2,
2442 }},
2443 },
2444 [SAA7134_BOARD_VIDEOMATE_DVBT_300] = {
2445 .name = "Compro Videomate DVB-T300",
2446 .audio_clock = 0x00187de7,
2447 .tuner_type = TUNER_PHILIPS_TD1316,
2448 .radio_type = UNSET,
2449 .tuner_addr = 0x61,
2450 .radio_addr = ADDR_UNSET,
Hartmut Hackmann44fd06f2006-02-27 00:09:11 -03002451 .tda9887_conf = TDA9887_PRESENT | TDA9887_PORT1_ACTIVE,
Hartmut Hackmann2cf36ac2005-11-08 21:36:32 -08002452 .mpeg = SAA7134_MPEG_DVB,
2453 .inputs = {{
2454 .name = name_tv,
2455 .vmux = 3,
2456 .amux = TV,
2457 .tv = 1,
2458 },{
2459 .name = name_comp1,
2460 .vmux = 1,
2461 .amux = LINE2,
2462 },{
2463 .name = name_svideo,
2464 .vmux = 8,
2465 .amux = LINE2,
2466 }},
2467 },
2468 [SAA7134_BOARD_VIDEOMATE_DVBT_200] = {
2469 .name = "Compro Videomate DVB-T200",
2470 .tuner_type = TUNER_ABSENT,
2471 .audio_clock = 0x00187de7,
2472 .radio_type = UNSET,
2473 .tuner_addr = ADDR_UNSET,
2474 .radio_addr = ADDR_UNSET,
2475 .mpeg = SAA7134_MPEG_DVB,
2476 .inputs = {{
2477 .name = name_comp1,
2478 .vmux = 0,
2479 .amux = LINE1,
2480 },{
2481 .name = name_svideo,
2482 .vmux = 8,
2483 .amux = LINE1,
2484 }},
2485 },
Mauro Carvalho Chehab4ac97912005-11-08 21:37:43 -08002486 [SAA7134_BOARD_RTD_VFG7350] = {
2487 .name = "RTD Embedded Technologies VFG7350",
2488 .audio_clock = 0x00200000,
2489 .tuner_type = TUNER_ABSENT,
2490 .radio_type = UNSET,
2491 .tuner_addr = ADDR_UNSET,
2492 .radio_addr = ADDR_UNSET,
Hans Verkuil195784b2009-03-28 09:27:02 -03002493 .empress_addr = 0x21,
Mauro Carvalho Chehab4ac97912005-11-08 21:37:43 -08002494 .inputs = {{
2495 .name = "Composite 0",
2496 .vmux = 0,
2497 .amux = LINE1,
2498 },{
2499 .name = "Composite 1",
2500 .vmux = 1,
2501 .amux = LINE2,
2502 },{
2503 .name = "Composite 2",
2504 .vmux = 2,
2505 .amux = LINE1,
2506 },{
2507 .name = "Composite 3",
2508 .vmux = 3,
2509 .amux = LINE2,
2510 },{
2511 .name = "S-Video 0",
2512 .vmux = 8,
2513 .amux = LINE1,
2514 },{
2515 .name = "S-Video 1",
2516 .vmux = 9,
2517 .amux = LINE2,
2518 }},
2519 .mpeg = SAA7134_MPEG_EMPRESS,
2520 .video_out = CCIR656,
Robert W. Boone2f8d4f52005-11-08 21:37:10 -08002521 .vid_port_opts = ( SET_T_CODE_POLARITY_NON_INVERTED |
2522 SET_CLOCK_NOT_DELAYED |
2523 SET_CLOCK_INVERTED |
2524 SET_VSYNC_OFF ),
Mauro Carvalho Chehab4ac97912005-11-08 21:37:43 -08002525 },
2526 [SAA7134_BOARD_RTD_VFG7330] = {
2527 .name = "RTD Embedded Technologies VFG7330",
2528 .audio_clock = 0x00200000,
2529 .tuner_type = TUNER_ABSENT,
2530 .radio_type = UNSET,
2531 .tuner_addr = ADDR_UNSET,
2532 .radio_addr = ADDR_UNSET,
2533 .inputs = {{
2534 .name = "Composite 0",
2535 .vmux = 0,
2536 .amux = LINE1,
2537 },{
2538 .name = "Composite 1",
2539 .vmux = 1,
2540 .amux = LINE2,
2541 },{
2542 .name = "Composite 2",
2543 .vmux = 2,
2544 .amux = LINE1,
2545 },{
2546 .name = "Composite 3",
2547 .vmux = 3,
2548 .amux = LINE2,
2549 },{
2550 .name = "S-Video 0",
2551 .vmux = 8,
2552 .amux = LINE1,
2553 },{
2554 .name = "S-Video 1",
2555 .vmux = 9,
2556 .amux = LINE2,
2557 }},
2558 },
Mauro Carvalho Chehab058afaf2005-11-08 21:36:49 -08002559 [SAA7134_BOARD_FLYTVPLATINUM_MINI2] = {
2560 .name = "LifeView FlyTV Platinum Mini2",
2561 .audio_clock = 0x00200000,
2562 .tuner_type = TUNER_PHILIPS_TDA8290,
2563 .radio_type = UNSET,
2564 .tuner_addr = ADDR_UNSET,
2565 .radio_addr = ADDR_UNSET,
2566
2567 .inputs = {{
2568 .name = name_tv,
2569 .vmux = 1,
2570 .amux = TV,
2571 .tv = 1,
2572 },{
2573 .name = name_comp1, /* Composite signal on S-Video input */
2574 .vmux = 0,
2575 .amux = LINE2,
2576 },{
2577 .name = name_comp2, /* Composite input */
2578 .vmux = 3,
2579 .amux = LINE2,
2580 },{
2581 .name = name_svideo,
2582 .vmux = 8,
2583 .amux = LINE2,
2584 }},
2585 },
Michael Krufky76bc3a32005-11-08 21:37:27 -08002586 [SAA7134_BOARD_AVERMEDIA_AVERTVHD_A180] = {
Michael Krufkyac113d12005-11-08 21:38:21 -08002587 /* Michael Krufky <mkrufky@m1k.net>
2588 * Uses Alps Electric TDHU2, containing NXT2004 ATSC Decoder
2589 * AFAIK, there is no analog demod, thus,
2590 * no support for analog television.
2591 */
Michael Krufky76bc3a32005-11-08 21:37:27 -08002592 .name = "AVerMedia AVerTVHD MCE A180",
2593 .audio_clock = 0x00187de7,
2594 .tuner_type = TUNER_ABSENT,
2595 .radio_type = UNSET,
2596 .tuner_addr = ADDR_UNSET,
2597 .radio_addr = ADDR_UNSET,
Michael Krufky3b64e8e2005-11-08 21:38:20 -08002598 .mpeg = SAA7134_MPEG_DVB,
Michael Krufky76bc3a32005-11-08 21:37:27 -08002599 .inputs = {{
2600 .name = name_comp1,
2601 .vmux = 3,
2602 .amux = LINE2,
2603 },{
2604 .name = name_svideo,
2605 .vmux = 8,
2606 .amux = LINE2,
2607 }},
2608 },
Pieter Palmerscf1c5d12005-11-08 21:37:40 -08002609 [SAA7134_BOARD_MONSTERTV_MOBILE] = {
2610 .name = "SKNet MonsterTV Mobile",
2611 .audio_clock = 0x00187de7,
2612 .tuner_type = TUNER_PHILIPS_TDA8290,
2613 .radio_type = UNSET,
2614 .tuner_addr = ADDR_UNSET,
2615 .radio_addr = ADDR_UNSET,
2616
2617 .inputs = {{
2618 .name = name_tv,
2619 .vmux = 1,
2620 .amux = TV,
2621 .tv = 1,
2622 },{
2623 .name = name_comp1,
2624 .vmux = 3,
2625 .amux = LINE1,
2626 },{
2627 .name = name_svideo,
2628 .vmux = 6,
2629 .amux = LINE1,
2630 }},
2631 },
Ricardo Cerqueirac2f6f9d2005-11-08 21:37:51 -08002632 [SAA7134_BOARD_PINNACLE_PCTV_110i] = {
Karsten Suehringcb46e3c2006-02-27 00:08:08 -03002633 .name = "Pinnacle PCTV 40i/50i/110i (saa7133)",
Ricardo Cerqueirac2f6f9d2005-11-08 21:37:51 -08002634 .audio_clock = 0x00187de7,
2635 .tuner_type = TUNER_PHILIPS_TDA8290,
2636 .radio_type = UNSET,
2637 .tuner_addr = ADDR_UNSET,
2638 .radio_addr = ADDR_UNSET,
2639 .gpiomask = 0x080200000,
Yuri Funduryaneec25fa2008-02-17 01:22:37 -03002640 .inputs = { {
2641 .name = name_tv,
2642 .vmux = 4,
2643 .amux = TV,
2644 .tv = 1,
2645 }, {
2646 .name = name_comp1,
2647 .vmux = 1,
2648 .amux = LINE2,
2649 }, {
2650 .name = name_comp2,
2651 .vmux = 0,
2652 .amux = LINE2,
2653 }, {
2654 .name = name_svideo,
2655 .vmux = 8,
2656 .amux = LINE2,
2657 } },
Ricardo Cerqueirac2f6f9d2005-11-08 21:37:51 -08002658 .radio = {
Yuri Funduryaneec25fa2008-02-17 01:22:37 -03002659 .name = name_radio,
2660 .amux = TV,
2661 .gpio = 0x0200000,
Ricardo Cerqueirac2f6f9d2005-11-08 21:37:51 -08002662 },
2663 },
Hermann Pitton28f02242005-11-08 21:38:03 -08002664 [SAA7134_BOARD_ASUSTeK_P7131_DUAL] = {
2665 .name = "ASUSTeK P7131 Dual",
2666 .audio_clock = 0x00187de7,
2667 .tuner_type = TUNER_PHILIPS_TDA8290,
2668 .radio_type = UNSET,
2669 .tuner_addr = ADDR_UNSET,
2670 .radio_addr = ADDR_UNSET,
2671 .gpiomask = 1 << 21,
Hartmut Hackmannd4b0aba2005-11-08 21:38:44 -08002672 .mpeg = SAA7134_MPEG_DVB,
Hermann Pitton28f02242005-11-08 21:38:03 -08002673 .inputs = {{
2674 .name = name_tv,
2675 .vmux = 1,
2676 .amux = TV,
2677 .tv = 1,
Hartmut Hackmann83646812006-10-12 20:38:51 -03002678 .gpio = 0x0000000,
Hermann Pitton28f02242005-11-08 21:38:03 -08002679 },{
2680 .name = name_comp1,
2681 .vmux = 3,
2682 .amux = LINE2,
Hartmut Hackmann83646812006-10-12 20:38:51 -03002683 .gpio = 0x0200000,
Hermann Pitton28f02242005-11-08 21:38:03 -08002684 },{
Hermann Pitton8387c662006-12-10 21:08:03 -03002685 .name = name_comp2,
2686 .vmux = 0,
2687 .amux = LINE2,
2688 .gpio = 0x0200000,
2689 },{
Hermann Pitton28f02242005-11-08 21:38:03 -08002690 .name = name_svideo,
2691 .vmux = 8,
2692 .amux = LINE2,
Hartmut Hackmann83646812006-10-12 20:38:51 -03002693 .gpio = 0x0200000,
Hermann Pitton28f02242005-11-08 21:38:03 -08002694 }},
2695 .radio = {
2696 .name = name_radio,
2697 .amux = TV,
2698 .gpio = 0x0200000,
2699 },
2700 },
Ricardo Cerqueira17ce1ff2005-11-08 21:38:47 -08002701 [SAA7134_BOARD_SEDNA_PC_TV_CARDBUS] = {
Paul T Zalacfe2e36c2005-11-08 21:38:04 -08002702 /* Paul Tom Zalac <pzalac@gmail.com> */
Pavel Mihaylovc3d93192005-11-08 21:38:43 -08002703 /* Pavel Mihaylov <bin@bash.info> */
Ricardo Cerqueira17ce1ff2005-11-08 21:38:47 -08002704 .name = "Sedna/MuchTV PC TV Cardbus TV/Radio (ITO25 Rev:2B)",
2705 /* Sedna/MuchTV (OEM) Cardbus TV Tuner */
Paul T Zalacfe2e36c2005-11-08 21:38:04 -08002706 .audio_clock = 0x00187de7,
Pavel Mihaylovc3d93192005-11-08 21:38:43 -08002707 .tuner_type = TUNER_PHILIPS_TDA8290,
Paul T Zalacfe2e36c2005-11-08 21:38:04 -08002708 .radio_type = UNSET,
2709 .tuner_addr = ADDR_UNSET,
2710 .radio_addr = ADDR_UNSET,
Pavel Mihaylovc3d93192005-11-08 21:38:43 -08002711 .gpiomask = 0xe880c0,
Paul T Zalacfe2e36c2005-11-08 21:38:04 -08002712 .inputs = {{
Pavel Mihaylovc3d93192005-11-08 21:38:43 -08002713 .name = name_tv,
2714 .vmux = 3,
2715 .amux = TV,
2716 .tv = 1,
2717 },{
Paul T Zalacfe2e36c2005-11-08 21:38:04 -08002718 .name = name_comp1,
2719 .vmux = 1,
Pavel Mihaylovc3d93192005-11-08 21:38:43 -08002720 .amux = LINE1,
2721 },{
2722 .name = name_svideo,
2723 .vmux = 6,
2724 .amux = LINE1,
Paul T Zalacfe2e36c2005-11-08 21:38:04 -08002725 }},
Pavel Mihaylovc3d93192005-11-08 21:38:43 -08002726 .radio = {
2727 .name = name_radio,
2728 .amux = LINE2,
2729 },
Paul T Zalacfe2e36c2005-11-08 21:38:04 -08002730 },
Michael Krufky5d5c9902005-11-08 21:38:08 -08002731 [SAA7134_BOARD_ASUSTEK_DIGIMATRIX_TV] = {
2732 /* "Cyril Lacoux (Yack)" <clacoux@ifeelgood.org> */
2733 .name = "ASUS Digimatrix TV",
2734 .audio_clock = 0x00200000,
2735 .tuner_type = TUNER_PHILIPS_FQ1216ME,
2736 .tda9887_conf = TDA9887_PRESENT,
2737 .radio_type = UNSET,
2738 .tuner_addr = ADDR_UNSET,
2739 .radio_addr = ADDR_UNSET,
2740 .inputs = {{
2741 .name = name_tv,
2742 .vmux = 1,
2743 .amux = TV,
2744 .tv = 1,
2745 },{
2746 .name = name_comp1,
2747 .vmux = 3,
2748 .amux = LINE1,
2749 },{
2750 .name = name_svideo,
2751 .vmux = 8,
2752 .amux = LINE1,
2753 }},
2754 },
Hartmut Hackmann90e9df72005-11-08 21:38:42 -08002755 [SAA7134_BOARD_PHILIPS_TIGER] = {
2756 .name = "Philips Tiger reference design",
2757 .audio_clock = 0x00187de7,
2758 .tuner_type = TUNER_PHILIPS_TDA8290,
2759 .radio_type = UNSET,
2760 .tuner_addr = ADDR_UNSET,
2761 .radio_addr = ADDR_UNSET,
Hartmut Hackmann58ef4f92007-04-27 12:31:12 -03002762 .tuner_config = 0,
Hartmut Hackmann90e9df72005-11-08 21:38:42 -08002763 .mpeg = SAA7134_MPEG_DVB,
Hartmut Hackmannde956c12007-04-27 12:31:12 -03002764 .gpiomask = 0x0200000,
Hartmut Hackmann90e9df72005-11-08 21:38:42 -08002765 .inputs = {{
2766 .name = name_tv,
2767 .vmux = 1,
2768 .amux = TV,
2769 .tv = 1,
2770 },{
2771 .name = name_comp1,
2772 .vmux = 3,
2773 .amux = LINE1,
2774 },{
2775 .name = name_svideo,
2776 .vmux = 8,
2777 .amux = LINE1,
2778 }},
Hartmut Hackmann0f79c362006-01-14 21:26:44 -02002779 .radio = {
2780 .name = name_radio,
2781 .amux = TV,
2782 .gpio = 0x0200000,
2783 },
Hartmut Hackmann90e9df72005-11-08 21:38:42 -08002784 },
Ricardo Cerqueira80d2ad92005-11-13 16:08:01 -08002785 [SAA7134_BOARD_MSI_TVATANYWHERE_PLUS] = {
2786 .name = "MSI TV@Anywhere plus",
2787 .audio_clock = 0x00187de7,
2788 .tuner_type = TUNER_PHILIPS_TDA8290,
2789 .radio_type = UNSET,
2790 .tuner_addr = ADDR_UNSET,
2791 .radio_addr = ADDR_UNSET,
hermann pittone382f622007-01-07 21:19:48 -03002792 .gpiomask = 1 << 21,
Ricardo Cerqueira80d2ad92005-11-13 16:08:01 -08002793 .inputs = {{
2794 .name = name_tv,
2795 .vmux = 1,
2796 .amux = TV,
2797 .tv = 1,
2798 },{
2799 .name = name_comp1,
2800 .vmux = 3,
hermann pittone382f622007-01-07 21:19:48 -03002801 .amux = LINE2, /* unconfirmed, taken from Philips driver */
2802 },{
2803 .name = name_comp2,
2804 .vmux = 0, /* untested, Composite over S-Video */
2805 .amux = LINE2,
Ricardo Cerqueira80d2ad92005-11-13 16:08:01 -08002806 },{
2807 .name = name_svideo,
hermann pittone382f622007-01-07 21:19:48 -03002808 .vmux = 8,
2809 .amux = LINE2,
Ricardo Cerqueira80d2ad92005-11-13 16:08:01 -08002810 }},
2811 .radio = {
2812 .name = name_radio,
hermann pittone382f622007-01-07 21:19:48 -03002813 .amux = TV,
2814 .gpio = 0x0200000,
Ricardo Cerqueira80d2ad92005-11-13 16:08:01 -08002815 },
2816 },
Jörg Schummerf639c9b2006-01-09 15:25:01 -02002817 [SAA7134_BOARD_CINERGY250PCI] = {
2818 /* remote-control does not work. The signal about a
2819 key press comes in via gpio, but the key code
2820 doesn't. Neither does it have an i2c remote control
2821 interface. */
2822 .name = "Terratec Cinergy 250 PCI TV",
2823 .audio_clock = 0x00187de7,
2824 .tuner_type = TUNER_PHILIPS_TDA8290,
2825 .radio_type = UNSET,
2826 .tuner_addr = ADDR_UNSET,
2827 .radio_addr = ADDR_UNSET,
2828 .gpiomask = 0x80200000,
2829 .inputs = {{
2830 .name = name_tv,
2831 .vmux = 1,
2832 .amux = TV,
2833 .tv = 1,
2834 },{
2835 .name = name_svideo, /* NOT tested */
2836 .vmux = 8,
2837 .amux = LINE1,
2838 }},
2839 .radio = {
2840 .name = name_radio,
Hartmut Hackmann58ef4f92007-04-27 12:31:12 -03002841 .amux = TV,
Jörg Schummerf639c9b2006-01-09 15:25:01 -02002842 .gpio = 0x0200000,
2843 },
2844 },
Peter Missel4aa6ba52006-01-09 15:32:45 -02002845 [SAA7134_BOARD_FLYDVB_TRIO] = {
2846 /* LifeView LR319 FlyDVB Trio */
2847 /* Peter Missel <peter.missel@onlinehome.de> */
2848 .name = "LifeView FlyDVB Trio",
2849 .audio_clock = 0x00200000,
2850 .tuner_type = TUNER_PHILIPS_TDA8290,
2851 .radio_type = UNSET,
2852 .tuner_addr = ADDR_UNSET,
2853 .radio_addr = ADDR_UNSET,
2854 .gpiomask = 0x00200000,
Hartmut Hackmann293cdab2006-02-27 21:08:07 -03002855 .mpeg = SAA7134_MPEG_DVB,
Peter Missel4aa6ba52006-01-09 15:32:45 -02002856 .inputs = {{
2857 .name = name_tv, /* Analog broadcast/cable TV */
2858 .vmux = 1,
2859 .amux = TV,
2860 .gpio = 0x200000, /* GPIO21=High for TV input */
2861 .tv = 1,
2862 },{
2863 .name = name_svideo, /* S-Video signal on S-Video input */
2864 .vmux = 8,
2865 .amux = LINE2,
2866 },{
2867 .name = name_comp1, /* Composite signal on S-Video input */
2868 .vmux = 0,
2869 .amux = LINE2,
2870 },{
2871 .name = name_comp2, /* Composite input */
2872 .vmux = 3,
2873 .amux = LINE2,
2874 }},
2875 .radio = {
2876 .name = name_radio,
2877 .amux = TV,
2878 .gpio = 0x000000, /* GPIO21=Low for FM radio antenna */
2879 },
2880 },
Jose Alberto Regueroa78d0bf2006-02-07 06:25:14 -02002881 [SAA7134_BOARD_AVERMEDIA_777] = {
2882 .name = "AverTV DVB-T 777",
2883 .audio_clock = 0x00187de7,
2884 .tuner_type = TUNER_ABSENT,
2885 .radio_type = UNSET,
2886 .tuner_addr = ADDR_UNSET,
2887 .radio_addr = ADDR_UNSET,
2888 .mpeg = SAA7134_MPEG_DVB,
2889 .inputs = {{
2890 .name = name_comp1,
Hartmut Hackmann2174eb92006-03-27 19:15:47 -03002891 .vmux = 1,
Jose Alberto Regueroa78d0bf2006-02-07 06:25:14 -02002892 .amux = LINE1,
2893 },{
2894 .name = name_svideo,
2895 .vmux = 8,
2896 .amux = LINE1,
2897 }},
2898 },
Giampiero Giancipoli3d8466e2006-02-07 06:49:09 -02002899 [SAA7134_BOARD_FLYDVBT_LR301] = {
2900 /* LifeView FlyDVB-T */
2901 /* Giampiero Giancipoli <gianci@libero.it> */
Hartmut Hackmann42e6b3b2006-03-27 19:04:48 -03002902 .name = "LifeView FlyDVB-T / Genius VideoWonder DVB-T",
Giampiero Giancipoli3d8466e2006-02-07 06:49:09 -02002903 .audio_clock = 0x00200000,
2904 .tuner_type = TUNER_ABSENT,
2905 .radio_type = UNSET,
2906 .tuner_addr = ADDR_UNSET,
2907 .radio_addr = ADDR_UNSET,
2908 .mpeg = SAA7134_MPEG_DVB,
2909 .inputs = {{
2910 .name = name_comp1, /* Composite input */
2911 .vmux = 3,
2912 .amux = LINE2,
2913 },{
2914 .name = name_svideo, /* S-Video signal on S-Video input */
2915 .vmux = 8,
2916 .amux = LINE2,
2917 }},
2918 },
Hartmut Hackmanndf42eaf2006-02-07 06:49:10 -02002919 [SAA7134_BOARD_ADS_DUO_CARDBUS_PTV331] = {
2920 .name = "ADS Instant TV Duo Cardbus PTV331",
2921 .audio_clock = 0x00200000,
2922 .tuner_type = TUNER_PHILIPS_TDA8290,
2923 .radio_type = UNSET,
2924 .tuner_addr = ADDR_UNSET,
2925 .radio_addr = ADDR_UNSET,
2926 .mpeg = SAA7134_MPEG_DVB,
2927 .gpiomask = 0x00600000, /* Bit 21 0=Radio, Bit 22 0=TV */
2928 .inputs = {{
2929 .name = name_tv,
2930 .vmux = 1,
2931 .amux = TV,
2932 .tv = 1,
2933 .gpio = 0x00200000,
2934 }},
2935 },
Peter Hartshorn3dfb7292006-02-07 06:49:13 -02002936 [SAA7134_BOARD_TEVION_DVBT_220RF] = {
Adrian Bunk793f2252006-03-08 10:50:06 -03002937 .name = "Tevion/KWorld DVB-T 220RF",
Peter Hartshorn3dfb7292006-02-07 06:49:13 -02002938 .audio_clock = 0x00187de7,
2939 .tuner_type = TUNER_PHILIPS_TDA8290,
2940 .radio_type = UNSET,
2941 .tuner_addr = ADDR_UNSET,
2942 .radio_addr = ADDR_UNSET,
2943 .mpeg = SAA7134_MPEG_DVB,
Simon Farnsworth289ea1f2007-09-10 13:37:26 -03002944 .gpiomask = 1 << 21,
Peter Hartshorn3dfb7292006-02-07 06:49:13 -02002945 .inputs = {{
2946 .name = name_tv,
2947 .vmux = 1,
2948 .amux = TV,
2949 .tv = 1,
2950 },{
2951 .name = name_comp1,
2952 .vmux = 3,
2953 .amux = LINE1,
2954 },{
Simon Farnsworth289ea1f2007-09-10 13:37:26 -03002955 .name = name_comp2,
Peter Hartshorn3dfb7292006-02-07 06:49:13 -02002956 .vmux = 0,
2957 .amux = LINE1,
Simon Farnsworth289ea1f2007-09-10 13:37:26 -03002958 },{
2959 .name = name_svideo,
2960 .vmux = 8,
2961 .amux = LINE1,
Peter Hartshorn3dfb7292006-02-07 06:49:13 -02002962 }},
2963 .radio = {
2964 .name = name_radio,
Simon Farnsworth289ea1f2007-09-10 13:37:26 -03002965 .amux = TV,
2966 .gpio = 0x0200000,
Peter Hartshorn3dfb7292006-02-07 06:49:13 -02002967 },
2968 },
Simon Farnsworthb39423a2007-05-01 10:01:20 -03002969 [SAA7134_BOARD_KWORLD_DVBT_210] = {
2970 .name = "KWorld DVB-T 210",
2971 .audio_clock = 0x00187de7,
2972 .tuner_type = TUNER_PHILIPS_TDA8290,
2973 .radio_type = UNSET,
2974 .tuner_addr = ADDR_UNSET,
2975 .radio_addr = ADDR_UNSET,
2976 .mpeg = SAA7134_MPEG_DVB,
2977 .gpiomask = 1 << 21,
2978 .inputs = {{
2979 .name = name_tv,
2980 .vmux = 1,
2981 .amux = TV,
2982 .tv = 1,
2983 },{
2984 .name = name_comp1,
2985 .vmux = 3,
2986 .amux = LINE1,
2987 },{
2988 .name = name_svideo,
2989 .vmux = 8,
2990 .amux = LINE1,
2991 }},
2992 .radio = {
2993 .name = name_radio,
2994 .amux = TV,
2995 .gpio = 0x0200000,
2996 },
2997 },
Andrew Burri3e1410a2006-02-27 00:08:23 -03002998 [SAA7134_BOARD_KWORLD_ATSC110] = {
Eric Sandeen0ac3a5b2007-10-08 16:13:02 -03002999 .name = "Kworld ATSC110/115",
Andrew Burri3e1410a2006-02-27 00:08:23 -03003000 .audio_clock = 0x00187de7,
3001 .tuner_type = TUNER_PHILIPS_TUV1236D,
3002 .radio_type = UNSET,
3003 .tuner_addr = ADDR_UNSET,
3004 .radio_addr = ADDR_UNSET,
3005 .tda9887_conf = TDA9887_PRESENT,
3006 .mpeg = SAA7134_MPEG_DVB,
3007 .inputs = {{
3008 .name = name_tv,
3009 .vmux = 1,
3010 .amux = TV,
3011 .tv = 1,
Curt Meyers6ba509d2006-02-27 00:08:32 -03003012 },{
3013 .name = name_comp1,
3014 .vmux = 3,
3015 .amux = LINE2,
3016 },{
3017 .name = name_svideo,
3018 .vmux = 8,
3019 .amux = LINE2,
Andrew Burri3e1410a2006-02-27 00:08:23 -03003020 }},
3021 },
Rickard Osser68593af2006-03-11 17:14:12 -03003022 [SAA7134_BOARD_AVERMEDIA_A169_B] = {
3023 /* AVerMedia A169 */
3024 /* Rickard Osser <ricky@osser.se> */
3025 /* This card has two saa7134 chips on it,
3026 but only one of them is currently working. */
3027 .name = "AVerMedia A169 B",
3028 .audio_clock = 0x02187de7,
3029 .tuner_type = TUNER_LG_TALN,
3030 .radio_type = UNSET,
3031 .tuner_addr = ADDR_UNSET,
3032 .radio_addr = ADDR_UNSET,
3033 .tda9887_conf = TDA9887_PRESENT,
3034 .gpiomask = 0x0a60000,
3035 },
3036 [SAA7134_BOARD_AVERMEDIA_A169_B1] = {
3037 /* AVerMedia A169 */
3038 /* Rickard Osser <ricky@osser.se> */
3039 .name = "AVerMedia A169 B1",
3040 .audio_clock = 0x02187de7,
3041 .tuner_type = TUNER_LG_TALN,
3042 .radio_type = UNSET,
3043 .tuner_addr = ADDR_UNSET,
3044 .radio_addr = ADDR_UNSET,
3045 .tda9887_conf = TDA9887_PRESENT,
3046 .gpiomask = 0xca60000,
3047 .inputs = {{
3048 .name = name_tv,
3049 .vmux = 4,
3050 .amux = TV,
3051 .tv = 1,
3052 .gpio = 0x04a61000,
3053 },{
3054 .name = name_comp2, /* Composite SVIDEO (B/W if signal is carried with SVIDEO) */
3055 .vmux = 1,
3056 .amux = LINE2,
3057 },{
3058 .name = name_svideo,
3059 .vmux = 9, /* 9 is correct as S-VIDEO1 according to a169.inf! */
3060 .amux = LINE1,
3061 }},
3062 },
Michael Krufkyba3a5a82006-03-14 19:02:12 -03003063 [SAA7134_BOARD_MD7134_BRIDGE_2] = {
Hartmut Hackmann637afdb2008-04-22 14:46:08 -03003064 /* The second saa7134 on this card only serves as DVB-S host bridge */
Michael Krufkyba3a5a82006-03-14 19:02:12 -03003065 .name = "Medion 7134 Bridge #2",
3066 .audio_clock = 0x00187de7,
3067 .radio_type = UNSET,
3068 .tuner_addr = ADDR_UNSET,
3069 .radio_addr = ADDR_UNSET,
Hartmut Hackmann637afdb2008-04-22 14:46:08 -03003070 .mpeg = SAA7134_MPEG_DVB,
Michael Krufkyba3a5a82006-03-14 19:02:12 -03003071 },
Hartmut Hackmannd95b8942006-03-27 19:39:30 -03003072 [SAA7134_BOARD_FLYDVBT_HYBRID_CARDBUS] = {
Mauro Carvalho Chehab593f18c2007-10-07 02:17:09 -03003073 .name = "LifeView FlyDVB-T Hybrid Cardbus/MSI TV @nywhere A/D NB",
Hartmut Hackmannd95b8942006-03-27 19:39:30 -03003074 .audio_clock = 0x00200000,
3075 .tuner_type = TUNER_PHILIPS_TDA8290,
3076 .radio_type = UNSET,
3077 .tuner_addr = ADDR_UNSET,
3078 .radio_addr = ADDR_UNSET,
3079 .mpeg = SAA7134_MPEG_DVB,
3080 .gpiomask = 0x00600000, /* Bit 21 0=Radio, Bit 22 0=TV */
3081 .inputs = {{
3082 .name = name_tv,
3083 .vmux = 1,
3084 .amux = TV,
3085 .gpio = 0x200000, /* GPIO21=High for TV input */
3086 .tv = 1,
3087 },{
3088 .name = name_svideo, /* S-Video signal on S-Video input */
3089 .vmux = 8,
3090 .amux = LINE2,
3091 },{
3092 .name = name_comp1, /* Composite signal on S-Video input */
3093 .vmux = 0,
3094 .amux = LINE2,
3095 },{
3096 .name = name_comp2, /* Composite input */
3097 .vmux = 3,
3098 .amux = LINE2,
3099 }},
3100 .radio = {
3101 .name = name_radio,
3102 .amux = TV,
3103 .gpio = 0x000000, /* GPIO21=Low for FM radio antenna */
3104 },
3105 },
Zac Bowlingf49ba8d2006-06-19 19:49:20 -03003106 [SAA7134_BOARD_FLYVIDEO3000_NTSC] = {
3107 /* "Zac Bowling" <zac@zacbowling.com> */
3108 .name = "LifeView FlyVIDEO3000 (NTSC)",
3109 .audio_clock = 0x00200000,
3110 .tuner_type = TUNER_PHILIPS_NTSC,
3111 .radio_type = UNSET,
3112 .tuner_addr = ADDR_UNSET,
3113 .radio_addr = ADDR_UNSET,
3114
3115 .gpiomask = 0xe000,
3116 .inputs = {{
3117 .name = name_tv,
3118 .vmux = 1,
3119 .amux = TV,
3120 .gpio = 0x8000,
3121 .tv = 1,
3122 },{
3123 .name = name_tv_mono,
3124 .vmux = 1,
3125 .amux = LINE2,
3126 .gpio = 0x0000,
3127 .tv = 1,
3128 },{
3129 .name = name_comp1,
3130 .vmux = 0,
3131 .amux = LINE2,
3132 .gpio = 0x4000,
3133 },{
3134 .name = name_comp2,
3135 .vmux = 3,
3136 .amux = LINE2,
3137 .gpio = 0x4000,
3138 },{
3139 .name = name_svideo,
3140 .vmux = 8,
3141 .amux = LINE2,
3142 .gpio = 0x4000,
3143 }},
3144 .radio = {
3145 .name = name_radio,
3146 .amux = LINE2,
3147 .gpio = 0x2000,
3148 },
3149 .mute = {
3150 .name = name_mute,
3151 .amux = TV,
3152 .gpio = 0x8000,
3153 },
3154 },
Hartmut Hackmann5eda2272006-08-07 14:03:32 -03003155 [SAA7134_BOARD_MEDION_MD8800_QUADRO] = {
3156 .name = "Medion Md8800 Quadro",
3157 .audio_clock = 0x00187de7,
3158 .tuner_type = TUNER_PHILIPS_TDA8290,
3159 .radio_type = UNSET,
3160 .tuner_addr = ADDR_UNSET,
3161 .radio_addr = ADDR_UNSET,
3162 .mpeg = SAA7134_MPEG_DVB,
3163 .inputs = {{
3164 .name = name_tv,
3165 .vmux = 1,
3166 .amux = TV,
3167 .tv = 1,
3168 },{
3169 .name = name_comp1,
3170 .vmux = 0,
hermann pitton387a2992007-10-25 21:26:53 -03003171 .amux = LINE1,
Hartmut Hackmann5eda2272006-08-07 14:03:32 -03003172 },{
3173 .name = name_svideo,
3174 .vmux = 8,
hermann pitton387a2992007-10-25 21:26:53 -03003175 .amux = LINE1,
Hartmut Hackmann5eda2272006-08-07 14:03:32 -03003176 }},
3177 },
Igor M. Liplianine2ac28f2006-08-08 09:10:10 -03003178 [SAA7134_BOARD_FLYDVBS_LR300] = {
3179 /* LifeView FlyDVB-s */
3180 /* Igor M. Liplianin <liplianin@tut.by> */
3181 .name = "LifeView FlyDVB-S /Acorp TV134DS",
3182 .audio_clock = 0x00200000,
3183 .tuner_type = TUNER_ABSENT,
3184 .radio_type = UNSET,
3185 .tuner_addr = ADDR_UNSET,
3186 .radio_addr = ADDR_UNSET,
3187 .mpeg = SAA7134_MPEG_DVB,
3188 .inputs = {{
3189 .name = name_comp1, /* Composite input */
3190 .vmux = 3,
3191 .amux = LINE1,
3192 },{
3193 .name = name_svideo, /* S-Video signal on S-Video input */
3194 .vmux = 8,
3195 .amux = LINE1,
3196 }},
3197 },
Michal Majchrowiczb04c1ba2006-09-13 16:42:42 -03003198 [SAA7134_BOARD_PROTEUS_2309] = {
3199 .name = "Proteus Pro 2309",
3200 .audio_clock = 0x00187de7,
3201 .tuner_type = TUNER_PHILIPS_FM1216ME_MK3,
3202 .radio_type = UNSET,
3203 .tuner_addr = ADDR_UNSET,
3204 .radio_addr = ADDR_UNSET,
3205 .tda9887_conf = TDA9887_PRESENT,
3206 .inputs = {{
3207 .name = name_tv,
3208 .vmux = 1,
3209 .amux = LINE2,
3210 .tv = 1,
3211 },{
3212 .name = name_comp1,
3213 .vmux = 0,
3214 .amux = LINE2,
3215 },{
3216 .name = name_comp2,
3217 .vmux = 3,
3218 .amux = LINE2,
3219 },{
3220 .name = name_svideo,
3221 .vmux = 8,
3222 .amux = LINE2,
3223 }},
3224 .mute = {
3225 .name = name_mute,
3226 .amux = LINE1,
3227 },
3228 },
Petr Baudis515c2082006-09-26 16:53:53 -03003229 [SAA7134_BOARD_AVERMEDIA_A16AR] = {
3230 /* Petr Baudis <pasky@ucw.cz> */
3231 .name = "AVerMedia TV Hybrid A16AR",
3232 .audio_clock = 0x187de7,
pasky@ucw.cz0871a882006-11-12 14:24:57 -03003233 .tuner_type = TUNER_PHILIPS_TD1316, /* untested */
Petr Baudis515c2082006-09-26 16:53:53 -03003234 .radio_type = TUNER_TEA5767, /* untested */
3235 .tuner_addr = ADDR_UNSET,
Mauro Carvalho Chehabc117d052008-04-26 14:05:58 -03003236 .radio_addr = 0x60,
Petr Baudis515c2082006-09-26 16:53:53 -03003237 .tda9887_conf = TDA9887_PRESENT,
3238 .mpeg = SAA7134_MPEG_DVB,
3239 .inputs = {{
3240 .name = name_tv,
3241 .vmux = 1,
3242 .amux = TV,
3243 .tv = 1,
3244 },{
3245 .name = name_comp1,
3246 .vmux = 3,
3247 .amux = LINE2,
3248 },{
3249 .name = name_svideo,
3250 .vmux = 8,
3251 .amux = LINE1,
3252 }},
3253 .radio = {
3254 .name = name_radio,
3255 .amux = LINE1,
3256 },
3257 },
Hartmut Hackmanncf146ca2006-10-02 20:49:24 -03003258 [SAA7134_BOARD_ASUS_EUROPA2_HYBRID] = {
3259 .name = "Asus Europa2 OEM",
3260 .audio_clock = 0x00187de7,
3261 .tuner_type = TUNER_PHILIPS_FMD1216ME_MK3,
3262 .radio_type = UNSET,
3263 .tuner_addr = ADDR_UNSET,
3264 .radio_addr = ADDR_UNSET,
3265 .tda9887_conf = TDA9887_PRESENT| TDA9887_PORT1_ACTIVE | TDA9887_PORT2_ACTIVE,
3266 .mpeg = SAA7134_MPEG_DVB,
3267 .inputs = {{
3268 .name = name_tv,
3269 .vmux = 3,
3270 .amux = TV,
3271 .tv = 1,
3272 },{
3273 .name = name_comp1,
3274 .vmux = 4,
3275 .amux = LINE2,
3276 },{
3277 .name = name_svideo,
3278 .vmux = 8,
3279 .amux = LINE2,
3280 }},
3281 .radio = {
3282 .name = name_radio,
3283 .amux = LINE1,
3284 },
3285 },
Hartmut Hackmann587d2fd2006-10-06 19:13:50 -03003286 [SAA7134_BOARD_PINNACLE_PCTV_310i] = {
3287 .name = "Pinnacle PCTV 310i",
3288 .audio_clock = 0x00187de7,
3289 .tuner_type = TUNER_PHILIPS_TDA8290,
3290 .radio_type = UNSET,
3291 .tuner_addr = ADDR_UNSET,
3292 .radio_addr = ADDR_UNSET,
Hartmut Hackmann58ef4f92007-04-27 12:31:12 -03003293 .tuner_config = 1,
Hartmut Hackmann587d2fd2006-10-06 19:13:50 -03003294 .mpeg = SAA7134_MPEG_DVB,
3295 .gpiomask = 0x000200000,
3296 .inputs = {{
3297 .name = name_tv,
3298 .vmux = 4,
3299 .amux = TV,
3300 .tv = 1,
3301 },{
3302 .name = name_comp1,
3303 .vmux = 1,
3304 .amux = LINE2,
3305 },{
3306 .name = name_comp2,
3307 .vmux = 0,
3308 .amux = LINE2,
3309 },{
3310 .name = name_svideo,
3311 .vmux = 8,
3312 .amux = LINE2,
3313 }},
3314 .radio = {
3315 .name = name_radio,
3316 .amux = TV,
3317 .gpio = 0x0200000,
3318 },
3319 },
Mikhail Fedotov3ac706d2006-10-06 20:23:47 -03003320 [SAA7134_BOARD_AVERMEDIA_STUDIO_507] = {
3321 /* Mikhail Fedotov <mo_fedotov@mail.ru> */
3322 .name = "Avermedia AVerTV Studio 507",
3323 .audio_clock = 0x00187de7,
3324 .tuner_type = TUNER_PHILIPS_FM1256_IH3,
3325 .radio_type = UNSET,
3326 .tuner_addr = ADDR_UNSET,
3327 .radio_addr = ADDR_UNSET,
3328 .tda9887_conf = TDA9887_PRESENT,
3329 .gpiomask = 0x03,
3330 .inputs = {{
3331 .name = name_tv,
3332 .vmux = 1,
3333 .amux = TV,
3334 .tv = 1,
3335 .gpio = 0x00,
3336 },{
3337 .name = name_comp1,
3338 .vmux = 0,
3339 .amux = LINE2,
3340 .gpio = 0x00,
3341 },{
3342 .name = name_comp2,
3343 .vmux = 3,
3344 .amux = LINE2,
3345 .gpio = 0x00,
3346 },{
3347 .name = name_svideo,
3348 .vmux = 8,
3349 .amux = LINE2,
3350 .gpio = 0x00,
3351 }},
3352 .radio = {
3353 .name = name_radio,
3354 .amux = LINE2,
3355 .gpio = 0x01,
3356 },
3357 .mute = {
3358 .name = name_mute,
3359 .amux = LINE1,
3360 .gpio = 0x00,
3361 },
3362 },
Hartmut Hackmanncbb94522006-10-30 20:00:16 -03003363 [SAA7134_BOARD_VIDEOMATE_DVBT_200A] = {
3364 /* Francis Barber <fedora@barber-family.id.au> */
3365 .name = "Compro Videomate DVB-T200A",
3366 .audio_clock = 0x00187de7,
3367 .tuner_type = TUNER_ABSENT,
3368 .radio_type = UNSET,
3369 .tuner_addr = ADDR_UNSET,
3370 .radio_addr = ADDR_UNSET,
3371 .tda9887_conf = TDA9887_PRESENT | TDA9887_PORT1_ACTIVE,
3372 .mpeg = SAA7134_MPEG_DVB,
3373 .inputs = {{
3374 .name = name_tv,
3375 .vmux = 3,
3376 .amux = TV,
3377 .tv = 1,
3378 },{
3379 .name = name_comp1,
3380 .vmux = 1,
3381 .amux = LINE2,
3382 },{
3383 .name = name_svideo,
3384 .vmux = 8,
3385 .amux = LINE2,
3386 }},
3387 },
Thomas Gentyc6e53da2006-11-05 14:17:30 -03003388 [SAA7134_BOARD_HAUPPAUGE_HVR1110] = {
3389 /* Thomas Genty <tomlohave@gmail.com> */
David Bentham8acdbcf2008-09-28 16:29:51 -03003390 /* David Bentham <db260179@hotmail.com> */
Thomas Gentyc6e53da2006-11-05 14:17:30 -03003391 .name = "Hauppauge WinTV-HVR1110 DVB-T/Hybrid",
3392 .audio_clock = 0x00187de7,
3393 .tuner_type = TUNER_PHILIPS_TDA8290,
3394 .radio_type = UNSET,
3395 .tuner_addr = ADDR_UNSET,
3396 .radio_addr = ADDR_UNSET,
Michael Krufkyb3aa2262007-12-09 21:13:38 -03003397 .tuner_config = 1,
Thomas Gentyc6e53da2006-11-05 14:17:30 -03003398 .mpeg = SAA7134_MPEG_DVB,
David Bentham8acdbcf2008-09-28 16:29:51 -03003399 .gpiomask = 0x0200100,
Thomas Gentyc6e53da2006-11-05 14:17:30 -03003400 .inputs = {{
3401 .name = name_tv,
3402 .vmux = 1,
3403 .amux = TV,
3404 .tv = 1,
David Bentham8acdbcf2008-09-28 16:29:51 -03003405 .gpio = 0x0000100,
3406 }, {
3407 .name = name_comp1,
3408 .vmux = 3,
3409 .amux = LINE1,
3410 }, {
3411 .name = name_svideo,
3412 .vmux = 8,
3413 .amux = LINE1,
3414 } },
Thomas Gentyc6e53da2006-11-05 14:17:30 -03003415 .radio = {
3416 .name = name_radio,
David Bentham8acdbcf2008-09-28 16:29:51 -03003417 .amux = TV,
3418 .gpio = 0x0200100,
Thomas Gentyc6e53da2006-11-05 14:17:30 -03003419 },
3420 },
Michael Krufkyb5f05062009-08-03 16:51:33 -03003421 [SAA7134_BOARD_HAUPPAUGE_HVR1150] = {
3422 .name = "Hauppauge WinTV-HVR1150 ATSC/QAM-Hybrid",
Michael Krufkyf9996c92009-02-28 17:45:17 -03003423 .audio_clock = 0x00187de7,
3424 .tuner_type = TUNER_PHILIPS_TDA8290,
3425 .radio_type = UNSET,
3426 .tuner_addr = ADDR_UNSET,
3427 .radio_addr = ADDR_UNSET,
3428 .tuner_config = 3,
Michael Krufky3abdedd2009-01-19 01:10:49 -03003429 .mpeg = SAA7134_MPEG_DVB,
3430 .ts_type = SAA7134_MPEG_TS_SERIAL,
Michael Krufky22370ef2009-11-04 14:23:57 -03003431 .ts_force_val = 1,
Michael Krufkyf9996c92009-02-28 17:45:17 -03003432 .gpiomask = 0x0800100, /* GPIO 21 is an INPUT */
3433 .inputs = {{
3434 .name = name_tv,
3435 .vmux = 1,
3436 .amux = TV,
3437 .tv = 1,
3438 .gpio = 0x0000100,
3439 }, {
3440 .name = name_comp1,
3441 .vmux = 3,
3442 .amux = LINE1,
3443 }, {
3444 .name = name_svideo,
3445 .vmux = 8,
3446 .amux = LINE1,
3447 } },
3448 .radio = {
3449 .name = name_radio,
3450 .amux = TV,
3451 .gpio = 0x0800100, /* GPIO 23 HI for FM */
3452 },
3453 },
Michael Krufky0e316ec2009-08-03 16:51:33 -03003454 [SAA7134_BOARD_HAUPPAUGE_HVR1120] = {
3455 .name = "Hauppauge WinTV-HVR1120 DVB-T/Hybrid",
Michael Krufkyf9996c92009-02-28 17:45:17 -03003456 .audio_clock = 0x00187de7,
3457 .tuner_type = TUNER_PHILIPS_TDA8290,
3458 .radio_type = UNSET,
3459 .tuner_addr = ADDR_UNSET,
3460 .radio_addr = ADDR_UNSET,
3461 .tuner_config = 3,
Michael Krufky1bc7f512009-01-19 01:10:49 -03003462 .mpeg = SAA7134_MPEG_DVB,
3463 .ts_type = SAA7134_MPEG_TS_SERIAL,
Michael Krufkyf9996c92009-02-28 17:45:17 -03003464 .gpiomask = 0x0800100, /* GPIO 21 is an INPUT */
3465 .inputs = {{
3466 .name = name_tv,
3467 .vmux = 1,
3468 .amux = TV,
3469 .tv = 1,
3470 .gpio = 0x0000100,
3471 }, {
3472 .name = name_comp1,
3473 .vmux = 3,
3474 .amux = LINE1,
3475 }, {
3476 .name = name_svideo,
3477 .vmux = 8,
3478 .amux = LINE1,
3479 } },
3480 .radio = {
3481 .name = name_radio,
3482 .amux = TV,
3483 .gpio = 0x0800100, /* GPIO 23 HI for FM */
3484 },
3485 },
Hartmut Hackmann550a9a52006-11-15 21:31:54 -03003486 [SAA7134_BOARD_CINERGY_HT_PCMCIA] = {
3487 .name = "Terratec Cinergy HT PCMCIA",
3488 .audio_clock = 0x00187de7,
3489 .tuner_type = TUNER_PHILIPS_TDA8290,
3490 .radio_type = UNSET,
3491 .tuner_addr = ADDR_UNSET,
3492 .radio_addr = ADDR_UNSET,
3493 .mpeg = SAA7134_MPEG_DVB,
3494 .inputs = {{
3495 .name = name_tv,
3496 .vmux = 1,
3497 .amux = TV,
3498 .tv = 1,
3499 },{
3500 .name = name_comp1,
3501 .vmux = 0,
3502 .amux = LINE1,
3503 },{
3504 .name = name_svideo,
3505 .vmux = 6,
3506 .amux = LINE1,
3507 }},
3508 },
Steven Walterd1158f42006-12-20 09:29:09 -03003509 [SAA7134_BOARD_ENCORE_ENLTV] = {
Juan Pablo Sormanic36c4592006-12-27 12:46:36 -03003510 /* Steven Walter <stevenrwalter@gmail.com>
3511 Juan Pablo Sormani <sorman@gmail.com> */
Steven Walterd1158f42006-12-20 09:29:09 -03003512 .name = "Encore ENLTV",
Juan Pablo Sormanic36c4592006-12-27 12:46:36 -03003513 .audio_clock = 0x00200000,
Steven Walterd1158f42006-12-20 09:29:09 -03003514 .tuner_type = TUNER_TNF_5335MF,
3515 .radio_type = UNSET,
3516 .tuner_addr = ADDR_UNSET,
3517 .radio_addr = ADDR_UNSET,
3518 .inputs = {{
3519 .name = name_tv,
3520 .vmux = 1,
Juan Pablo Sormanic36c4592006-12-27 12:46:36 -03003521 .amux = 3,
Steven Walterd1158f42006-12-20 09:29:09 -03003522 .tv = 1,
3523 },{
Juan Pablo Sormanic36c4592006-12-27 12:46:36 -03003524 .name = name_tv_mono,
3525 .vmux = 7,
3526 .amux = 4,
3527 .tv = 1,
3528 },{
3529 .name = name_comp1,
3530 .vmux = 3,
3531 .amux = 2,
3532 },{
Steven Walterd1158f42006-12-20 09:29:09 -03003533 .name = name_svideo,
Juan Pablo Sormanic36c4592006-12-27 12:46:36 -03003534 .vmux = 0,
3535 .amux = 2,
Steven Walterd1158f42006-12-20 09:29:09 -03003536 }},
Juan Pablo Sormanic36c4592006-12-27 12:46:36 -03003537 .radio = {
3538 .name = name_radio,
3539 .amux = LINE2,
3540/* .gpio = 0x00300001,*/
3541 .gpio = 0x20000,
3542
3543 },
3544 .mute = {
3545 .name = name_mute,
3546 .amux = 0,
3547 },
3548 },
3549 [SAA7134_BOARD_ENCORE_ENLTV_FM] = {
3550 /* Juan Pablo Sormani <sorman@gmail.com> */
3551 .name = "Encore ENLTV-FM",
3552 .audio_clock = 0x00200000,
Michael Krufkyab8b8702008-04-22 14:46:05 -03003553 .tuner_type = TUNER_PHILIPS_FCV1236D,
Juan Pablo Sormanic36c4592006-12-27 12:46:36 -03003554 .radio_type = UNSET,
3555 .tuner_addr = ADDR_UNSET,
3556 .radio_addr = ADDR_UNSET,
3557 .inputs = {{
3558 .name = name_tv,
3559 .vmux = 1,
3560 .amux = 3,
3561 .tv = 1,
3562 },{
3563 .name = name_tv_mono,
3564 .vmux = 7,
3565 .amux = 4,
3566 .tv = 1,
3567 },{
3568 .name = name_comp1,
3569 .vmux = 3,
3570 .amux = 2,
3571 },{
3572 .name = name_svideo,
3573 .vmux = 0,
3574 .amux = 2,
3575 }},
3576 .radio = {
3577 .name = name_radio,
3578 .amux = LINE2,
3579 .gpio = 0x20000,
3580
3581 },
3582 .mute = {
3583 .name = name_mute,
3584 .amux = 0,
3585 },
Steven Walterd1158f42006-12-20 09:29:09 -03003586 },
Mauro Carvalho Chehabbf1ece62008-06-26 17:03:00 -03003587 [SAA7134_BOARD_ENCORE_ENLTV_FM53] = {
3588 .name = "Encore ENLTV-FM v5.3",
3589 .audio_clock = 0x00200000,
3590 .tuner_type = TUNER_TNF_5335MF,
3591 .radio_type = UNSET,
3592 .tuner_addr = ADDR_UNSET,
3593 .radio_addr = ADDR_UNSET,
3594 .gpiomask = 0x7000,
3595 .inputs = { {
3596 .name = name_tv,
3597 .vmux = 1,
3598 .amux = 1,
3599 .tv = 1,
3600 .gpio = 0x50000,
3601 }, {
3602 .name = name_comp1,
3603 .vmux = 3,
3604 .amux = 2,
3605 .gpio = 0x2000,
3606 }, {
3607 .name = name_svideo,
3608 .vmux = 8,
3609 .amux = 2,
3610 .gpio = 0x2000,
3611 } },
3612 .radio = {
3613 .name = name_radio,
3614 .vmux = 1,
3615 .amux = 1,
3616 },
3617 .mute = {
3618 .name = name_mute,
3619 .gpio = 0xf000,
3620 .amux = 0,
3621 },
3622 },
Mauro Carvalho Chehabd642f2f2011-01-19 16:25:17 -02003623 [SAA7134_BOARD_ENCORE_ENLTV_FM3] = {
3624 .name = "Encore ENLTV-FM 3",
3625 .audio_clock = 0x02187de7,
3626 .tuner_type = TUNER_TENA_TNF_5337,
3627 .radio_type = TUNER_TEA5767,
3628 .tuner_addr = 0x61,
3629 .radio_addr = 0x60,
3630 .inputs = { {
3631 .name = name_tv,
3632 .vmux = 1,
3633 .amux = LINE2,
3634 .tv = 1,
3635 }, {
3636 .name = name_comp1,
3637 .vmux = 3,
3638 .amux = LINE1,
3639 }, {
3640 .name = name_svideo,
3641 .vmux = 8,
3642 .amux = LINE1,
3643 } },
3644 .radio = {
3645 .name = name_radio,
3646 .vmux = 1,
3647 .amux = LINE1,
3648 },
3649 .mute = {
3650 .name = name_mute,
3651 .amux = LINE1,
3652 .gpio = 0x43000,
3653 },
3654 },
Michael Krufky9de271e2007-01-16 18:36:40 -03003655 [SAA7134_BOARD_CINERGY_HT_PCI] = {
3656 .name = "Terratec Cinergy HT PCI",
3657 .audio_clock = 0x00187de7,
3658 .tuner_type = TUNER_PHILIPS_TDA8290,
3659 .radio_type = UNSET,
3660 .tuner_addr = ADDR_UNSET,
3661 .radio_addr = ADDR_UNSET,
3662 .mpeg = SAA7134_MPEG_DVB,
3663 .inputs = {{
3664 .name = name_tv,
3665 .vmux = 1,
3666 .amux = TV,
3667 .tv = 1,
3668 },{
3669 .name = name_comp1,
3670 .vmux = 0,
3671 .amux = LINE1,
3672 },{
3673 .name = name_svideo,
3674 .vmux = 6,
3675 .amux = LINE1,
3676 }},
3677 },
Hartmut Hackmann58ef4f92007-04-27 12:31:12 -03003678 [SAA7134_BOARD_PHILIPS_TIGER_S] = {
3679 .name = "Philips Tiger - S Reference design",
3680 .audio_clock = 0x00187de7,
3681 .tuner_type = TUNER_PHILIPS_TDA8290,
3682 .radio_type = UNSET,
3683 .tuner_addr = ADDR_UNSET,
3684 .radio_addr = ADDR_UNSET,
3685 .tuner_config = 2,
3686 .mpeg = SAA7134_MPEG_DVB,
3687 .gpiomask = 0x0200000,
3688 .inputs = {{
3689 .name = name_tv,
3690 .vmux = 1,
3691 .amux = TV,
3692 .tv = 1,
3693 },{
3694 .name = name_comp1,
3695 .vmux = 3,
3696 .amux = LINE1,
3697 },{
3698 .name = name_svideo,
3699 .vmux = 8,
3700 .amux = LINE1,
3701 }},
3702 .radio = {
3703 .name = name_radio,
3704 .amux = TV,
3705 .gpio = 0x0200000,
3706 },
3707 },
Markus Rechbergere95d3172007-04-27 12:31:19 -03003708 [SAA7134_BOARD_AVERMEDIA_M102] = {
3709 .name = "Avermedia M102",
3710 .audio_clock = 0x00187de7,
3711 .tuner_type = TUNER_PHILIPS_TDA8290,
3712 .radio_type = UNSET,
3713 .tuner_addr = ADDR_UNSET,
3714 .radio_addr = ADDR_UNSET,
3715 .gpiomask = 1<<21,
3716 .inputs = {{
3717 .name = name_tv,
3718 .vmux = 1,
3719 .amux = TV,
3720 .tv = 1,
3721 },{
3722 .name = name_comp1,
3723 .vmux = 0,
3724 .amux = LINE2,
3725 },{
3726 .name = name_svideo,
3727 .vmux = 6,
3728 .amux = LINE2,
3729 }},
3730 },
Hartmut Hackmanne06cea42007-03-13 20:58:29 -03003731 [SAA7134_BOARD_ASUS_P7131_4871] = {
3732 .name = "ASUS P7131 4871",
3733 .audio_clock = 0x00187de7,
3734 .tuner_type = TUNER_PHILIPS_TDA8290,
3735 .radio_type = UNSET,
3736 .tuner_addr = ADDR_UNSET,
3737 .radio_addr = ADDR_UNSET,
3738 .tuner_config = 2,
3739 .mpeg = SAA7134_MPEG_DVB,
3740 .gpiomask = 0x0200000,
3741 .inputs = {{
3742 .name = name_tv,
3743 .vmux = 1,
3744 .amux = TV,
3745 .tv = 1,
3746 .gpio = 0x0200000,
3747 }},
3748 },
Hartmut Hackmannf3eec0c02007-03-14 20:33:55 -03003749 [SAA7134_BOARD_ASUSTeK_P7131_HYBRID_LNA] = {
3750 .name = "ASUSTeK P7131 Hybrid",
Hartmut Hackmanne06cea42007-03-13 20:58:29 -03003751 .audio_clock = 0x00187de7,
3752 .tuner_type = TUNER_PHILIPS_TDA8290,
3753 .radio_type = UNSET,
3754 .tuner_addr = ADDR_UNSET,
3755 .radio_addr = ADDR_UNSET,
3756 .tuner_config = 2,
3757 .gpiomask = 1 << 21,
3758 .mpeg = SAA7134_MPEG_DVB,
3759 .inputs = {{
3760 .name = name_tv,
3761 .vmux = 1,
3762 .amux = TV,
3763 .tv = 1,
3764 .gpio = 0x0000000,
3765 },{
3766 .name = name_comp1,
3767 .vmux = 3,
3768 .amux = LINE2,
3769 .gpio = 0x0200000,
3770 },{
3771 .name = name_comp2,
3772 .vmux = 0,
3773 .amux = LINE2,
3774 .gpio = 0x0200000,
3775 },{
3776 .name = name_svideo,
3777 .vmux = 8,
3778 .amux = LINE2,
3779 .gpio = 0x0200000,
3780 }},
3781 .radio = {
3782 .name = name_radio,
3783 .amux = TV,
3784 .gpio = 0x0200000,
3785 },
Mauro Carvalho Chehabdfb4ba12009-08-20 10:13:40 -03003786 },
3787 [SAA7134_BOARD_ASUSTeK_P7131_ANALOG] = {
Hermann Pitton0b17d0e2008-07-12 12:27:59 -03003788 .name = "ASUSTeK P7131 Analog",
3789 .audio_clock = 0x00187de7,
3790 .tuner_type = TUNER_PHILIPS_TDA8290,
3791 .radio_type = UNSET,
3792 .tuner_addr = ADDR_UNSET,
3793 .radio_addr = ADDR_UNSET,
3794 .gpiomask = 1 << 21,
3795 .inputs = {{
3796 .name = name_tv,
3797 .vmux = 1,
3798 .amux = TV,
3799 .tv = 1,
3800 .gpio = 0x0000000,
3801 }, {
3802 .name = name_comp1,
3803 .vmux = 3,
3804 .amux = LINE2,
3805 }, {
3806 .name = name_comp2,
3807 .vmux = 0,
3808 .amux = LINE2,
3809 }, {
3810 .name = name_svideo,
3811 .vmux = 8,
3812 .amux = LINE2,
3813 } },
3814 .radio = {
3815 .name = name_radio,
3816 .amux = TV,
3817 .gpio = 0x0200000,
3818 },
Hartmut Hackmanne06cea42007-03-13 20:58:29 -03003819 },
James T Klaas53958b32007-05-01 10:48:09 -03003820 [SAA7134_BOARD_SABRENT_TV_PCB05] = {
3821 .name = "Sabrent PCMCIA TV-PCB05",
3822 .audio_clock = 0x00187de7,
3823 .tuner_type = TUNER_PHILIPS_TDA8290,
3824 .radio_type = UNSET,
3825 .tuner_addr = ADDR_UNSET,
3826 .radio_addr = ADDR_UNSET,
3827 .inputs = {{
3828 .name = name_tv,
3829 .vmux = 1,
3830 .amux = TV,
3831 .tv = 1,
3832 },{
3833 .name = name_comp1,
3834 .vmux = 3,
3835 .amux = LINE1,
3836 },{
3837 .name = name_comp2,
3838 .vmux = 0,
3839 .amux = LINE1,
3840 },{
3841 .name = name_svideo,
3842 .vmux = 8,
3843 .amux = LINE1,
3844 }},
3845 .mute = {
3846 .name = name_mute,
3847 .amux = TV,
3848 },
3849 },
Tony Wanaaccb822007-05-10 12:16:47 -03003850 [SAA7134_BOARD_10MOONSTVMASTER3] = {
3851 /* Tony Wan <aloha_cn@hotmail.com> */
3852 .name = "10MOONS TM300 TV Card",
3853 .audio_clock = 0x00200000,
3854 .tuner_type = TUNER_LG_PAL_NEW_TAPC,
3855 .radio_type = UNSET,
3856 .tuner_addr = ADDR_UNSET,
3857 .radio_addr = ADDR_UNSET,
3858 .gpiomask = 0x7000,
3859 .inputs = {{
3860 .name = name_tv,
3861 .vmux = 1,
3862 .amux = LINE2,
3863 .gpio = 0x0000,
3864 .tv = 1,
3865 },{
3866 .name = name_comp1,
3867 .vmux = 3,
3868 .amux = LINE1,
3869 .gpio = 0x2000,
3870 },{
3871 .name = name_svideo,
3872 .vmux = 8,
3873 .amux = LINE1,
3874 .gpio = 0x2000,
3875 }},
3876 .mute = {
3877 .name = name_mute,
3878 .amux = LINE2,
3879 .gpio = 0x3000,
3880 },
3881 },
Edgar Simod90d9f52007-08-20 14:14:50 -03003882 [SAA7134_BOARD_AVERMEDIA_SUPER_007] = {
3883 .name = "Avermedia Super 007",
3884 .audio_clock = 0x00187de7,
3885 .tuner_type = TUNER_PHILIPS_TDA8290,
3886 .radio_type = UNSET,
3887 .tuner_addr = ADDR_UNSET,
3888 .radio_addr = ADDR_UNSET,
3889 .tuner_config = 0,
3890 .mpeg = SAA7134_MPEG_DVB,
3891 .inputs = {{
3892 .name = name_tv, /* FIXME: analog tv untested */
3893 .vmux = 1,
3894 .amux = TV,
3895 .tv = 1,
3896 }},
3897 },
Mauro Carvalho Chehab36f6bb92008-06-26 17:03:00 -03003898 [SAA7134_BOARD_AVERMEDIA_M135A] = {
3899 .name = "Avermedia PCI pure analog (M135A)",
3900 .audio_clock = 0x00187de7,
3901 .tuner_type = TUNER_PHILIPS_TDA8290,
3902 .radio_type = UNSET,
3903 .tuner_addr = ADDR_UNSET,
3904 .radio_addr = ADDR_UNSET,
3905 .tuner_config = 2,
3906 .gpiomask = 0x020200000,
3907 .inputs = {{
3908 .name = name_tv,
3909 .vmux = 1,
3910 .amux = TV,
3911 .tv = 1,
3912 }, {
3913 .name = name_comp1,
3914 .vmux = 3,
3915 .amux = LINE1,
3916 }, {
3917 .name = name_svideo,
3918 .vmux = 8,
3919 .amux = LINE1,
3920 } },
3921 .radio = {
3922 .name = name_radio,
3923 .amux = TV,
3924 .gpio = 0x00200000,
3925 },
3926 .mute = {
3927 .name = name_mute,
3928 .amux = TV,
3929 .gpio = 0x01,
3930 },
3931 },
Herton Ronaldo Krzesinski9e1d9e72010-05-08 02:23:37 -03003932 [SAA7134_BOARD_AVERMEDIA_M733A] = {
3933 .name = "Avermedia PCI M733A",
3934 .audio_clock = 0x00187de7,
3935 .tuner_type = TUNER_PHILIPS_TDA8290,
3936 .radio_type = UNSET,
3937 .tuner_addr = ADDR_UNSET,
3938 .radio_addr = ADDR_UNSET,
3939 .tuner_config = 0,
3940 .gpiomask = 0x020200000,
3941 .inputs = {{
3942 .name = name_tv,
3943 .vmux = 1,
3944 .amux = TV,
3945 .tv = 1,
3946 }, {
3947 .name = name_comp1,
3948 .vmux = 3,
3949 .amux = LINE1,
3950 }, {
3951 .name = name_svideo,
3952 .vmux = 8,
3953 .amux = LINE1,
3954 } },
3955 .radio = {
3956 .name = name_radio,
3957 .amux = TV,
3958 .gpio = 0x00200000,
3959 },
3960 .mute = {
3961 .name = name_mute,
3962 .amux = TV,
3963 .gpio = 0x01,
3964 },
3965 },
Andrey J. Melnikoff (TEMHOTA)e8018c92008-01-07 05:17:39 -03003966 [SAA7134_BOARD_BEHOLD_401] = {
Dmitry Belimovb34dddb2008-04-23 14:09:08 -03003967 /* Beholder Intl. Ltd. 2008 */
3968 /*Dmitry Belimov <d.belimov@gmail.com> */
Andrey J. Melnikoff (TEMHOTA)e8018c92008-01-07 05:17:39 -03003969 .name = "Beholder BeholdTV 401",
3970 .audio_clock = 0x00187de7,
3971 .tuner_type = TUNER_PHILIPS_FQ1216ME,
3972 .radio_type = UNSET,
3973 .tuner_addr = ADDR_UNSET,
3974 .radio_addr = ADDR_UNSET,
Dmitry Belimovb34dddb2008-04-23 14:09:08 -03003975 .gpiomask = 0x00008000,
Andrey J. Melnikoff (TEMHOTA)e8018c92008-01-07 05:17:39 -03003976 .inputs = {{
3977 .name = name_svideo,
3978 .vmux = 8,
3979 .amux = LINE1,
3980 },{
3981 .name = name_comp1,
3982 .vmux = 1,
3983 .amux = LINE1,
3984 },{
3985 .name = name_tv,
3986 .vmux = 3,
3987 .amux = LINE2,
3988 .tv = 1,
3989 }},
3990 .mute = {
3991 .name = name_mute,
3992 .amux = LINE1,
3993 },
3994 },
3995 [SAA7134_BOARD_BEHOLD_403] = {
Dmitry Belimovb34dddb2008-04-23 14:09:08 -03003996 /* Beholder Intl. Ltd. 2008 */
3997 /*Dmitry Belimov <d.belimov@gmail.com> */
Andrey J. Melnikoff (TEMHOTA)e8018c92008-01-07 05:17:39 -03003998 .name = "Beholder BeholdTV 403",
3999 .audio_clock = 0x00187de7,
4000 .tuner_type = TUNER_PHILIPS_FQ1216ME,
4001 .radio_type = UNSET,
4002 .tuner_addr = ADDR_UNSET,
4003 .radio_addr = ADDR_UNSET,
Dmitry Belimovb34dddb2008-04-23 14:09:08 -03004004 .gpiomask = 0x00008000,
Andrey J. Melnikoff (TEMHOTA)e8018c92008-01-07 05:17:39 -03004005 .inputs = {{
4006 .name = name_svideo,
4007 .vmux = 8,
4008 .amux = LINE1,
4009 },{
4010 .name = name_comp1,
4011 .vmux = 1,
4012 .amux = LINE1,
4013 },{
4014 .name = name_tv,
4015 .vmux = 3,
4016 .amux = LINE2,
4017 .tv = 1,
4018 }},
4019 },
4020 [SAA7134_BOARD_BEHOLD_403FM] = {
Dmitry Belimovb34dddb2008-04-23 14:09:08 -03004021 /* Beholder Intl. Ltd. 2008 */
4022 /*Dmitry Belimov <d.belimov@gmail.com> */
Andrey J. Melnikoff (TEMHOTA)e8018c92008-01-07 05:17:39 -03004023 .name = "Beholder BeholdTV 403 FM",
4024 .audio_clock = 0x00187de7,
4025 .tuner_type = TUNER_PHILIPS_FQ1216ME,
4026 .radio_type = UNSET,
4027 .tuner_addr = ADDR_UNSET,
4028 .radio_addr = ADDR_UNSET,
Dmitry Belimovb34dddb2008-04-23 14:09:08 -03004029 .gpiomask = 0x00008000,
Andrey J. Melnikoff (TEMHOTA)e8018c92008-01-07 05:17:39 -03004030 .inputs = {{
4031 .name = name_svideo,
4032 .vmux = 8,
4033 .amux = LINE1,
4034 },{
4035 .name = name_comp1,
4036 .vmux = 1,
4037 .amux = LINE1,
4038 },{
4039 .name = name_tv,
4040 .vmux = 3,
4041 .amux = LINE2,
4042 .tv = 1,
4043 }},
4044 .radio = {
4045 .name = name_radio,
4046 .amux = LINE2,
4047 },
4048 },
4049 [SAA7134_BOARD_BEHOLD_405] = {
Dmitry Belimovb34dddb2008-04-23 14:09:08 -03004050 /* Beholder Intl. Ltd. 2008 */
4051 /*Dmitry Belimov <d.belimov@gmail.com> */
Andrey J. Melnikoff (TEMHOTA)e8018c92008-01-07 05:17:39 -03004052 .name = "Beholder BeholdTV 405",
4053 .audio_clock = 0x00187de7,
4054 .tuner_type = TUNER_PHILIPS_FM1216ME_MK3,
4055 .radio_type = UNSET,
4056 .tuner_addr = ADDR_UNSET,
4057 .radio_addr = ADDR_UNSET,
4058 .tda9887_conf = TDA9887_PRESENT,
Dmitry Belimovb34dddb2008-04-23 14:09:08 -03004059 .gpiomask = 0x00008000,
Andrey J. Melnikoff (TEMHOTA)e8018c92008-01-07 05:17:39 -03004060 .inputs = {{
4061 .name = name_svideo,
4062 .vmux = 8,
4063 .amux = LINE1,
4064 },{
4065 .name = name_comp1,
4066 .vmux = 3,
4067 .amux = LINE1,
4068 },{
4069 .name = name_tv,
4070 .vmux = 3,
4071 .amux = LINE2,
4072 .tv = 1,
4073 }},
4074 },
4075 [SAA7134_BOARD_BEHOLD_405FM] = {
4076 /* Sergey <skiv@orel.ru> */
Dmitry Belimovb34dddb2008-04-23 14:09:08 -03004077 /* Beholder Intl. Ltd. 2008 */
4078 /*Dmitry Belimov <d.belimov@gmail.com> */
Andrey J. Melnikoff (TEMHOTA)e8018c92008-01-07 05:17:39 -03004079 .name = "Beholder BeholdTV 405 FM",
4080 .audio_clock = 0x00187de7,
4081 .tuner_type = TUNER_PHILIPS_FM1216ME_MK3,
4082 .radio_type = UNSET,
4083 .tuner_addr = ADDR_UNSET,
4084 .radio_addr = ADDR_UNSET,
4085 .tda9887_conf = TDA9887_PRESENT,
Dmitry Belimovb34dddb2008-04-23 14:09:08 -03004086 .gpiomask = 0x00008000,
Andrey J. Melnikoff (TEMHOTA)e8018c92008-01-07 05:17:39 -03004087 .inputs = {{
4088 .name = name_svideo,
4089 .vmux = 8,
4090 .amux = LINE1,
4091 },{
4092 .name = name_comp1,
4093 .vmux = 3,
4094 .amux = LINE1,
4095 },{
4096 .name = name_tv,
4097 .vmux = 3,
4098 .amux = LINE2,
4099 .tv = 1,
4100 }},
4101 .radio = {
4102 .name = name_radio,
4103 .amux = LINE2,
4104 },
4105 },
Mauro Carvalho Chehab1434bc02008-01-07 05:20:04 -03004106 [SAA7134_BOARD_BEHOLD_407] = {
Dmitry Belimovb34dddb2008-04-23 14:09:08 -03004107 /* Beholder Intl. Ltd. 2008 */
4108 /*Dmitry Belimov <d.belimov@gmail.com> */
Mauro Carvalho Chehab1434bc02008-01-07 05:20:04 -03004109 .name = "Beholder BeholdTV 407",
4110 .audio_clock = 0x00187de7,
4111 .tuner_type = TUNER_PHILIPS_FM1216ME_MK3,
4112 .radio_type = UNSET,
4113 .tuner_addr = ADDR_UNSET,
4114 .radio_addr = ADDR_UNSET,
4115 .tda9887_conf = TDA9887_PRESENT,
Dmitry Belimovb34dddb2008-04-23 14:09:08 -03004116 .gpiomask = 0x00008000,
Mauro Carvalho Chehab1434bc02008-01-07 05:20:04 -03004117 .inputs = {{
4118 .name = name_svideo,
4119 .vmux = 8,
4120 .amux = LINE1,
4121 .gpio = 0xc0c000,
4122 },{
4123 .name = name_comp1,
4124 .vmux = 1,
4125 .amux = LINE1,
4126 .gpio = 0xc0c000,
4127 },{
4128 .name = name_tv,
4129 .vmux = 3,
4130 .amux = TV,
4131 .tv = 1,
4132 .gpio = 0xc0c000,
4133 }},
4134 },
Andrey J. Melnikoff (TEMHOTA)e8018c92008-01-07 05:17:39 -03004135 [SAA7134_BOARD_BEHOLD_407FM] = {
Dmitry Belimovb34dddb2008-04-23 14:09:08 -03004136 /* Beholder Intl. Ltd. 2008 */
4137 /*Dmitry Belimov <d.belimov@gmail.com> */
Andrey J. Melnikoff (TEMHOTA)e8018c92008-01-07 05:17:39 -03004138 .name = "Beholder BeholdTV 407 FM",
4139 .audio_clock = 0x00187de7,
4140 .tuner_type = TUNER_PHILIPS_FM1216ME_MK3,
4141 .radio_type = UNSET,
4142 .tuner_addr = ADDR_UNSET,
4143 .radio_addr = ADDR_UNSET,
4144 .tda9887_conf = TDA9887_PRESENT,
Dmitry Belimovb34dddb2008-04-23 14:09:08 -03004145 .gpiomask = 0x00008000,
Andrey J. Melnikoff (TEMHOTA)e8018c92008-01-07 05:17:39 -03004146 .inputs = {{
4147 .name = name_svideo,
4148 .vmux = 8,
4149 .amux = LINE1,
4150 .gpio = 0xc0c000,
4151 },{
4152 .name = name_comp1,
4153 .vmux = 1,
4154 .amux = LINE1,
4155 .gpio = 0xc0c000,
4156 },{
4157 .name = name_tv,
4158 .vmux = 3,
4159 .amux = TV,
4160 .tv = 1,
4161 .gpio = 0xc0c000,
4162 }},
4163 .radio = {
4164 .name = name_radio,
4165 .amux = LINE2,
4166 .gpio = 0xc0c000,
4167 },
4168 },
4169 [SAA7134_BOARD_BEHOLD_409] = {
Dmitry Belimovb34dddb2008-04-23 14:09:08 -03004170 /* Beholder Intl. Ltd. 2008 */
4171 /*Dmitry Belimov <d.belimov@gmail.com> */
Andrey J. Melnikoff (TEMHOTA)e8018c92008-01-07 05:17:39 -03004172 .name = "Beholder BeholdTV 409",
4173 .audio_clock = 0x00187de7,
4174 .tuner_type = TUNER_PHILIPS_FM1216ME_MK3,
4175 .radio_type = UNSET,
4176 .tuner_addr = ADDR_UNSET,
4177 .radio_addr = ADDR_UNSET,
4178 .tda9887_conf = TDA9887_PRESENT,
Dmitry Belimovb34dddb2008-04-23 14:09:08 -03004179 .gpiomask = 0x00008000,
Andrey J. Melnikoff (TEMHOTA)e8018c92008-01-07 05:17:39 -03004180 .inputs = {{
4181 .name = name_tv,
4182 .vmux = 3,
4183 .amux = TV,
4184 .tv = 1,
4185 },{
4186 .name = name_comp1,
4187 .vmux = 1,
4188 .amux = LINE1,
4189 },{
4190 .name = name_svideo,
4191 .vmux = 8,
4192 .amux = LINE1,
4193 }},
4194 },
4195 [SAA7134_BOARD_BEHOLD_505FM] = {
Dmitry Belimovb34dddb2008-04-23 14:09:08 -03004196 /* Beholder Intl. Ltd. 2008 */
4197 /*Dmitry Belimov <d.belimov@gmail.com> */
Dmitri Belimov84d728c2009-04-23 02:32:49 -03004198 .name = "Beholder BeholdTV 505 FM",
Andrey J. Melnikoff (TEMHOTA)e8018c92008-01-07 05:17:39 -03004199 .audio_clock = 0x00200000,
4200 .tuner_type = TUNER_PHILIPS_FM1216ME_MK3,
4201 .radio_type = UNSET,
4202 .tuner_addr = ADDR_UNSET,
4203 .radio_addr = ADDR_UNSET,
4204 .tda9887_conf = TDA9887_PRESENT,
Dmitry Belimovb34dddb2008-04-23 14:09:08 -03004205 .gpiomask = 0x00008000,
Andrey J. Melnikoff (TEMHOTA)e8018c92008-01-07 05:17:39 -03004206 .inputs = {{
4207 .name = name_tv,
4208 .vmux = 3,
4209 .amux = LINE2,
4210 .tv = 1,
Dmitri Belimov84d728c2009-04-23 02:32:49 -03004211 }, {
4212 .name = name_comp1,
4213 .vmux = 1,
4214 .amux = LINE1,
4215 }, {
4216 .name = name_svideo,
4217 .vmux = 8,
4218 .amux = LINE1,
4219 } },
4220 .mute = {
4221 .name = name_mute,
4222 .amux = LINE1,
4223 },
4224 .radio = {
4225 .name = name_radio,
4226 .amux = LINE2,
4227 },
4228 },
Dmitri Belimov9c6f97a2009-12-21 02:00:38 -03004229 [SAA7134_BOARD_BEHOLD_505RDS_MK5] = {
Dmitri Belimov84d728c2009-04-23 02:32:49 -03004230 /* Beholder Intl. Ltd. 2008 */
4231 /*Dmitry Belimov <d.belimov@gmail.com> */
4232 .name = "Beholder BeholdTV 505 RDS",
4233 .audio_clock = 0x00200000,
Dmitry Belimovc6e56cd2009-09-17 23:39:37 -03004234 .tuner_type = TUNER_PHILIPS_FM1216MK5,
Dmitri Belimov84d728c2009-04-23 02:32:49 -03004235 .radio_type = UNSET,
4236 .tuner_addr = ADDR_UNSET,
4237 .radio_addr = ADDR_UNSET,
Dmitri Belimov35c30572009-08-10 21:47:29 -03004238 .rds_addr = 0x10,
Dmitri Belimov84d728c2009-04-23 02:32:49 -03004239 .tda9887_conf = TDA9887_PRESENT,
4240 .gpiomask = 0x00008000,
4241 .inputs = {{
4242 .name = name_tv,
4243 .vmux = 3,
4244 .amux = LINE2,
4245 .tv = 1,
Andrey J. Melnikoff (TEMHOTA)e8018c92008-01-07 05:17:39 -03004246 },{
4247 .name = name_comp1,
4248 .vmux = 1,
4249 .amux = LINE1,
4250 },{
4251 .name = name_svideo,
4252 .vmux = 8,
4253 .amux = LINE1,
4254 }},
4255 .mute = {
4256 .name = name_mute,
4257 .amux = LINE1,
4258 },
4259 .radio = {
4260 .name = name_radio,
4261 .amux = LINE2,
4262 },
4263 },
4264 [SAA7134_BOARD_BEHOLD_507_9FM] = {
Dmitry Belimovb34dddb2008-04-23 14:09:08 -03004265 /* Beholder Intl. Ltd. 2008 */
4266 /*Dmitry Belimov <d.belimov@gmail.com> */
Dmitri Belimov84d728c2009-04-23 02:32:49 -03004267 .name = "Beholder BeholdTV 507 FM / BeholdTV 509 FM",
Andrey J. Melnikoff (TEMHOTA)e8018c92008-01-07 05:17:39 -03004268 .audio_clock = 0x00187de7,
4269 .tuner_type = TUNER_PHILIPS_FM1216ME_MK3,
4270 .radio_type = UNSET,
4271 .tuner_addr = ADDR_UNSET,
4272 .radio_addr = ADDR_UNSET,
4273 .tda9887_conf = TDA9887_PRESENT,
Dmitry Belimovb34dddb2008-04-23 14:09:08 -03004274 .gpiomask = 0x00008000,
Andrey J. Melnikoff (TEMHOTA)e8018c92008-01-07 05:17:39 -03004275 .inputs = {{
4276 .name = name_tv,
4277 .vmux = 3,
4278 .amux = TV,
4279 .tv = 1,
4280 },{
4281 .name = name_comp1,
4282 .vmux = 1,
4283 .amux = LINE1,
4284 },{
4285 .name = name_svideo,
4286 .vmux = 8,
4287 .amux = LINE1,
4288 }},
4289 .radio = {
4290 .name = name_radio,
4291 .amux = LINE2,
4292 },
4293 },
Dmitri Belimov84d728c2009-04-23 02:32:49 -03004294 [SAA7134_BOARD_BEHOLD_507RDS_MK5] = {
4295 /* Beholder Intl. Ltd. 2008 */
4296 /*Dmitry Belimov <d.belimov@gmail.com> */
4297 .name = "Beholder BeholdTV 507 RDS",
4298 .audio_clock = 0x00187de7,
Dmitry Belimovc6e56cd2009-09-17 23:39:37 -03004299 .tuner_type = TUNER_PHILIPS_FM1216MK5,
Dmitri Belimov84d728c2009-04-23 02:32:49 -03004300 .radio_type = UNSET,
4301 .tuner_addr = ADDR_UNSET,
4302 .radio_addr = ADDR_UNSET,
Dmitri Belimov35c30572009-08-10 21:47:29 -03004303 .rds_addr = 0x10,
Dmitri Belimov84d728c2009-04-23 02:32:49 -03004304 .tda9887_conf = TDA9887_PRESENT,
4305 .gpiomask = 0x00008000,
4306 .inputs = {{
4307 .name = name_tv,
4308 .vmux = 3,
4309 .amux = TV,
4310 .tv = 1,
4311 }, {
4312 .name = name_comp1,
4313 .vmux = 1,
4314 .amux = LINE1,
4315 }, {
4316 .name = name_svideo,
4317 .vmux = 8,
4318 .amux = LINE1,
4319 } },
4320 .radio = {
4321 .name = name_radio,
4322 .amux = LINE2,
4323 },
4324 },
4325 [SAA7134_BOARD_BEHOLD_507RDS_MK3] = {
4326 /* Beholder Intl. Ltd. 2008 */
4327 /*Dmitry Belimov <d.belimov@gmail.com> */
4328 .name = "Beholder BeholdTV 507 RDS",
4329 .audio_clock = 0x00187de7,
4330 .tuner_type = TUNER_PHILIPS_FM1216ME_MK3,
4331 .radio_type = UNSET,
4332 .tuner_addr = ADDR_UNSET,
4333 .radio_addr = ADDR_UNSET,
Dmitri Belimov35c30572009-08-10 21:47:29 -03004334 .rds_addr = 0x10,
Dmitri Belimov84d728c2009-04-23 02:32:49 -03004335 .tda9887_conf = TDA9887_PRESENT,
4336 .gpiomask = 0x00008000,
4337 .inputs = {{
4338 .name = name_tv,
4339 .vmux = 3,
4340 .amux = TV,
4341 .tv = 1,
4342 }, {
4343 .name = name_comp1,
4344 .vmux = 1,
4345 .amux = LINE1,
4346 }, {
4347 .name = name_svideo,
4348 .vmux = 8,
4349 .amux = LINE1,
4350 } },
4351 .radio = {
4352 .name = name_radio,
4353 .amux = LINE2,
4354 },
4355 },
Andrey J. Melnikoff (TEMHOTA)e8018c92008-01-07 05:17:39 -03004356 [SAA7134_BOARD_BEHOLD_COLUMBUS_TVFM] = {
Dmitry Belimovb34dddb2008-04-23 14:09:08 -03004357 /* Beholder Intl. Ltd. 2008 */
Dmitri Belimov29d83492010-08-23 10:30:14 -03004358 /* Dmitry Belimov <d.belimov@gmail.com> */
4359 .name = "Beholder BeholdTV Columbus TV/FM",
Andrey J. Melnikoff (TEMHOTA)e8018c92008-01-07 05:17:39 -03004360 .audio_clock = 0x00187de7,
4361 .tuner_type = TUNER_ALPS_TSBE5_PAL,
Dmitri Belimov29d83492010-08-23 10:30:14 -03004362 .radio_type = TUNER_TEA5767,
4363 .tuner_addr = 0xc2 >> 1,
4364 .radio_addr = 0xc0 >> 1,
Andrey J. Melnikoff (TEMHOTA)e8018c92008-01-07 05:17:39 -03004365 .tda9887_conf = TDA9887_PRESENT,
Dmitry Belimovb34dddb2008-04-23 14:09:08 -03004366 .gpiomask = 0x000A8004,
Andrey J. Melnikoff (TEMHOTA)e8018c92008-01-07 05:17:39 -03004367 .inputs = {{
4368 .name = name_tv,
4369 .vmux = 3,
4370 .amux = TV,
4371 .tv = 1,
Dmitry Belimovb34dddb2008-04-23 14:09:08 -03004372 .gpio = 0x000A8004,
4373 }, {
Andrey J. Melnikoff (TEMHOTA)e8018c92008-01-07 05:17:39 -03004374 .name = name_comp1,
4375 .vmux = 1,
4376 .amux = LINE1,
Dmitry Belimovb34dddb2008-04-23 14:09:08 -03004377 .gpio = 0x000A8000,
4378 }, {
Andrey J. Melnikoff (TEMHOTA)e8018c92008-01-07 05:17:39 -03004379 .name = name_svideo,
4380 .vmux = 8,
4381 .amux = LINE1,
Dmitry Belimovb34dddb2008-04-23 14:09:08 -03004382 .gpio = 0x000A8000,
4383 } },
Andrey J. Melnikoff (TEMHOTA)e8018c92008-01-07 05:17:39 -03004384 .radio = {
4385 .name = name_radio,
4386 .amux = LINE2,
Dmitry Belimovb34dddb2008-04-23 14:09:08 -03004387 .gpio = 0x000A8000,
Andrey J. Melnikoff (TEMHOTA)e8018c92008-01-07 05:17:39 -03004388 },
4389 },
Dmitri Belimov84d728c2009-04-23 02:32:49 -03004390 [SAA7134_BOARD_BEHOLD_607FM_MK3] = {
Andrey J. Melnikoff (TEMHOTA)e8018c92008-01-07 05:17:39 -03004391 /* Andrey Melnikoff <temnota@kmv.ru> */
Dmitri Belimov84d728c2009-04-23 02:32:49 -03004392 .name = "Beholder BeholdTV 607 FM",
Andrey J. Melnikoff (TEMHOTA)e8018c92008-01-07 05:17:39 -03004393 .audio_clock = 0x00187de7,
4394 .tuner_type = TUNER_PHILIPS_FM1216ME_MK3,
4395 .radio_type = UNSET,
4396 .tuner_addr = ADDR_UNSET,
4397 .radio_addr = ADDR_UNSET,
4398 .tda9887_conf = TDA9887_PRESENT,
4399 .inputs = {{
4400 .name = name_tv,
4401 .vmux = 3,
4402 .amux = TV,
4403 .tv = 1,
Dmitri Belimov84d728c2009-04-23 02:32:49 -03004404 }, {
4405 .name = name_comp1,
4406 .vmux = 1,
4407 .amux = LINE1,
4408 }, {
4409 .name = name_svideo,
4410 .vmux = 8,
4411 .amux = LINE1,
4412 } },
4413 .radio = {
4414 .name = name_radio,
4415 .amux = LINE2,
4416 },
4417 },
4418 [SAA7134_BOARD_BEHOLD_609FM_MK3] = {
4419 /* Andrey Melnikoff <temnota@kmv.ru> */
4420 .name = "Beholder BeholdTV 609 FM",
4421 .audio_clock = 0x00187de7,
4422 .tuner_type = TUNER_PHILIPS_FM1216ME_MK3,
4423 .radio_type = UNSET,
4424 .tuner_addr = ADDR_UNSET,
4425 .radio_addr = ADDR_UNSET,
4426 .tda9887_conf = TDA9887_PRESENT,
4427 .inputs = {{
4428 .name = name_tv,
4429 .vmux = 3,
4430 .amux = TV,
4431 .tv = 1,
4432 }, {
4433 .name = name_comp1,
4434 .vmux = 1,
4435 .amux = LINE1,
4436 }, {
4437 .name = name_svideo,
4438 .vmux = 8,
4439 .amux = LINE1,
4440 } },
4441 .radio = {
4442 .name = name_radio,
4443 .amux = LINE2,
4444 },
4445 },
4446 [SAA7134_BOARD_BEHOLD_607FM_MK5] = {
4447 /* Andrey Melnikoff <temnota@kmv.ru> */
4448 .name = "Beholder BeholdTV 607 FM",
4449 .audio_clock = 0x00187de7,
Dmitry Belimovc6e56cd2009-09-17 23:39:37 -03004450 .tuner_type = TUNER_PHILIPS_FM1216MK5,
Dmitri Belimov84d728c2009-04-23 02:32:49 -03004451 .radio_type = UNSET,
4452 .tuner_addr = ADDR_UNSET,
4453 .radio_addr = ADDR_UNSET,
4454 .tda9887_conf = TDA9887_PRESENT,
4455 .inputs = {{
4456 .name = name_tv,
4457 .vmux = 3,
4458 .amux = TV,
4459 .tv = 1,
4460 }, {
4461 .name = name_comp1,
4462 .vmux = 1,
4463 .amux = LINE1,
4464 }, {
4465 .name = name_svideo,
4466 .vmux = 8,
4467 .amux = LINE1,
4468 } },
4469 .radio = {
4470 .name = name_radio,
4471 .amux = LINE2,
4472 },
4473 },
4474 [SAA7134_BOARD_BEHOLD_609FM_MK5] = {
4475 /* Andrey Melnikoff <temnota@kmv.ru> */
4476 .name = "Beholder BeholdTV 609 FM",
4477 .audio_clock = 0x00187de7,
Dmitry Belimovc6e56cd2009-09-17 23:39:37 -03004478 .tuner_type = TUNER_PHILIPS_FM1216MK5,
Dmitri Belimov84d728c2009-04-23 02:32:49 -03004479 .radio_type = UNSET,
4480 .tuner_addr = ADDR_UNSET,
4481 .radio_addr = ADDR_UNSET,
4482 .tda9887_conf = TDA9887_PRESENT,
4483 .inputs = {{
4484 .name = name_tv,
4485 .vmux = 3,
4486 .amux = TV,
4487 .tv = 1,
4488 }, {
4489 .name = name_comp1,
4490 .vmux = 1,
4491 .amux = LINE1,
4492 }, {
4493 .name = name_svideo,
4494 .vmux = 8,
4495 .amux = LINE1,
4496 } },
4497 .radio = {
4498 .name = name_radio,
4499 .amux = LINE2,
4500 },
4501 },
4502 [SAA7134_BOARD_BEHOLD_607RDS_MK3] = {
4503 /* Andrey Melnikoff <temnota@kmv.ru> */
4504 .name = "Beholder BeholdTV 607 RDS",
4505 .audio_clock = 0x00187de7,
4506 .tuner_type = TUNER_PHILIPS_FM1216ME_MK3,
4507 .radio_type = UNSET,
4508 .tuner_addr = ADDR_UNSET,
4509 .radio_addr = ADDR_UNSET,
Dmitri Belimov35c30572009-08-10 21:47:29 -03004510 .rds_addr = 0x10,
Dmitri Belimov84d728c2009-04-23 02:32:49 -03004511 .tda9887_conf = TDA9887_PRESENT,
4512 .inputs = {{
4513 .name = name_tv,
4514 .vmux = 3,
4515 .amux = TV,
4516 .tv = 1,
4517 }, {
4518 .name = name_comp1,
4519 .vmux = 1,
4520 .amux = LINE1,
4521 }, {
4522 .name = name_svideo,
4523 .vmux = 8,
4524 .amux = LINE1,
4525 } },
4526 .radio = {
4527 .name = name_radio,
4528 .amux = LINE2,
4529 },
4530 },
4531 [SAA7134_BOARD_BEHOLD_609RDS_MK3] = {
4532 /* Andrey Melnikoff <temnota@kmv.ru> */
4533 .name = "Beholder BeholdTV 609 RDS",
4534 .audio_clock = 0x00187de7,
4535 .tuner_type = TUNER_PHILIPS_FM1216ME_MK3,
4536 .radio_type = UNSET,
4537 .tuner_addr = ADDR_UNSET,
4538 .radio_addr = ADDR_UNSET,
Dmitri Belimov35c30572009-08-10 21:47:29 -03004539 .rds_addr = 0x10,
Dmitri Belimov84d728c2009-04-23 02:32:49 -03004540 .tda9887_conf = TDA9887_PRESENT,
4541 .inputs = {{
4542 .name = name_tv,
4543 .vmux = 3,
4544 .amux = TV,
4545 .tv = 1,
4546 }, {
4547 .name = name_comp1,
4548 .vmux = 1,
4549 .amux = LINE1,
4550 }, {
4551 .name = name_svideo,
4552 .vmux = 8,
4553 .amux = LINE1,
4554 } },
4555 .radio = {
4556 .name = name_radio,
4557 .amux = LINE2,
4558 },
4559 },
4560 [SAA7134_BOARD_BEHOLD_607RDS_MK5] = {
4561 /* Andrey Melnikoff <temnota@kmv.ru> */
4562 .name = "Beholder BeholdTV 607 RDS",
4563 .audio_clock = 0x00187de7,
Dmitry Belimovc6e56cd2009-09-17 23:39:37 -03004564 .tuner_type = TUNER_PHILIPS_FM1216MK5,
Dmitri Belimov84d728c2009-04-23 02:32:49 -03004565 .radio_type = UNSET,
4566 .tuner_addr = ADDR_UNSET,
4567 .radio_addr = ADDR_UNSET,
Dmitri Belimov35c30572009-08-10 21:47:29 -03004568 .rds_addr = 0x10,
Dmitri Belimov84d728c2009-04-23 02:32:49 -03004569 .tda9887_conf = TDA9887_PRESENT,
4570 .inputs = {{
4571 .name = name_tv,
4572 .vmux = 3,
4573 .amux = TV,
4574 .tv = 1,
4575 }, {
4576 .name = name_comp1,
4577 .vmux = 1,
4578 .amux = LINE1,
4579 }, {
4580 .name = name_svideo,
4581 .vmux = 8,
4582 .amux = LINE1,
4583 } },
4584 .radio = {
4585 .name = name_radio,
4586 .amux = LINE2,
4587 },
4588 },
4589 [SAA7134_BOARD_BEHOLD_609RDS_MK5] = {
4590 /* Andrey Melnikoff <temnota@kmv.ru> */
4591 .name = "Beholder BeholdTV 609 RDS",
4592 .audio_clock = 0x00187de7,
Dmitry Belimovc6e56cd2009-09-17 23:39:37 -03004593 .tuner_type = TUNER_PHILIPS_FM1216MK5,
Dmitri Belimov84d728c2009-04-23 02:32:49 -03004594 .radio_type = UNSET,
4595 .tuner_addr = ADDR_UNSET,
4596 .radio_addr = ADDR_UNSET,
Dmitri Belimov35c30572009-08-10 21:47:29 -03004597 .rds_addr = 0x10,
Dmitri Belimov84d728c2009-04-23 02:32:49 -03004598 .tda9887_conf = TDA9887_PRESENT,
4599 .inputs = {{
4600 .name = name_tv,
4601 .vmux = 3,
4602 .amux = TV,
4603 .tv = 1,
Andrey J. Melnikoff (TEMHOTA)e8018c92008-01-07 05:17:39 -03004604 },{
4605 .name = name_comp1,
4606 .vmux = 1,
4607 .amux = LINE1,
4608 },{
4609 .name = name_svideo,
4610 .vmux = 8,
4611 .amux = LINE1,
4612 }},
4613 .radio = {
4614 .name = name_radio,
4615 .amux = LINE2,
4616 },
4617 },
4618 [SAA7134_BOARD_BEHOLD_M6] = {
4619 /* Igor Kuznetsov <igk@igk.ru> */
4620 /* Andrey Melnikoff <temnota@kmv.ru> */
Dmitry Belimov878cf2a2008-06-10 14:22:00 -03004621 /* Beholder Intl. Ltd. Dmitry Belimov <d.belimov@gmail.com> */
Dmitri Belimov6b6b7542009-05-28 01:58:57 -03004622 /* Alexey Osipov <lion-simba@pridelands.ru> */
Dmitry Belimov878cf2a2008-06-10 14:22:00 -03004623 .name = "Beholder BeholdTV M6",
Andrey J. Melnikoff (TEMHOTA)e8018c92008-01-07 05:17:39 -03004624 .audio_clock = 0x00187de7,
4625 .tuner_type = TUNER_PHILIPS_FM1216ME_MK3,
4626 .radio_type = UNSET,
4627 .tuner_addr = ADDR_UNSET,
4628 .radio_addr = ADDR_UNSET,
Hans Verkuil195784b2009-03-28 09:27:02 -03004629 .empress_addr = 0x20,
Andrey J. Melnikoff (TEMHOTA)e8018c92008-01-07 05:17:39 -03004630 .tda9887_conf = TDA9887_PRESENT,
Dmitry Belimov878cf2a2008-06-10 14:22:00 -03004631 .inputs = { {
Andrey J. Melnikoff (TEMHOTA)e8018c92008-01-07 05:17:39 -03004632 .name = name_tv,
4633 .vmux = 3,
4634 .amux = TV,
4635 .tv = 1,
Dmitry Belimov878cf2a2008-06-10 14:22:00 -03004636 }, {
Andrey J. Melnikoff (TEMHOTA)e8018c92008-01-07 05:17:39 -03004637 .name = name_comp1,
4638 .vmux = 1,
4639 .amux = LINE1,
Dmitry Belimov878cf2a2008-06-10 14:22:00 -03004640 }, {
Andrey J. Melnikoff (TEMHOTA)e8018c92008-01-07 05:17:39 -03004641 .name = name_svideo,
4642 .vmux = 8,
4643 .amux = LINE1,
Dmitry Belimov878cf2a2008-06-10 14:22:00 -03004644 } },
Andrey J. Melnikoff (TEMHOTA)e8018c92008-01-07 05:17:39 -03004645 .radio = {
4646 .name = name_radio,
4647 .amux = LINE2,
4648 },
4649 .mpeg = SAA7134_MPEG_EMPRESS,
Dmitry Belimov878cf2a2008-06-10 14:22:00 -03004650 .video_out = CCIR656,
4651 .vid_port_opts = (SET_T_CODE_POLARITY_NON_INVERTED |
4652 SET_CLOCK_NOT_DELAYED |
4653 SET_CLOCK_INVERTED |
4654 SET_VSYNC_OFF),
4655 },
4656 [SAA7134_BOARD_BEHOLD_M63] = {
4657 /* Igor Kuznetsov <igk@igk.ru> */
4658 /* Andrey Melnikoff <temnota@kmv.ru> */
4659 /* Beholder Intl. Ltd. Dmitry Belimov <d.belimov@gmail.com> */
4660 .name = "Beholder BeholdTV M63",
4661 .audio_clock = 0x00187de7,
4662 .tuner_type = TUNER_PHILIPS_FM1216ME_MK3,
4663 .radio_type = UNSET,
4664 .tuner_addr = ADDR_UNSET,
4665 .radio_addr = ADDR_UNSET,
Hans Verkuil195784b2009-03-28 09:27:02 -03004666 .empress_addr = 0x20,
Dmitry Belimov878cf2a2008-06-10 14:22:00 -03004667 .tda9887_conf = TDA9887_PRESENT,
4668 .inputs = { {
4669 .name = name_tv,
4670 .vmux = 3,
4671 .amux = TV,
4672 .tv = 1,
4673 }, {
4674 .name = name_comp1,
4675 .vmux = 1,
4676 .amux = LINE1,
4677 }, {
4678 .name = name_svideo,
4679 .vmux = 8,
4680 .amux = LINE1,
4681 } },
4682 .radio = {
4683 .name = name_radio,
4684 .amux = LINE2,
4685 },
4686 .mpeg = SAA7134_MPEG_EMPRESS,
4687 .video_out = CCIR656,
4688 .vid_port_opts = (SET_T_CODE_POLARITY_NON_INVERTED |
4689 SET_CLOCK_NOT_DELAYED |
4690 SET_CLOCK_INVERTED |
4691 SET_VSYNC_OFF),
4692 },
4693 [SAA7134_BOARD_BEHOLD_M6_EXTRA] = {
4694 /* Igor Kuznetsov <igk@igk.ru> */
4695 /* Andrey Melnikoff <temnota@kmv.ru> */
4696 /* Beholder Intl. Ltd. Dmitry Belimov <d.belimov@gmail.com> */
Dmitri Belimov6b6b7542009-05-28 01:58:57 -03004697 /* Alexey Osipov <lion-simba@pridelands.ru> */
Dmitry Belimov878cf2a2008-06-10 14:22:00 -03004698 .name = "Beholder BeholdTV M6 Extra",
4699 .audio_clock = 0x00187de7,
Dmitry Belimovc6e56cd2009-09-17 23:39:37 -03004700 .tuner_type = TUNER_PHILIPS_FM1216MK5,
Dmitry Belimov878cf2a2008-06-10 14:22:00 -03004701 .radio_type = UNSET,
4702 .tuner_addr = ADDR_UNSET,
4703 .radio_addr = ADDR_UNSET,
Dmitri Belimov35c30572009-08-10 21:47:29 -03004704 .rds_addr = 0x10,
Hans Verkuil195784b2009-03-28 09:27:02 -03004705 .empress_addr = 0x20,
Dmitry Belimov878cf2a2008-06-10 14:22:00 -03004706 .tda9887_conf = TDA9887_PRESENT,
4707 .inputs = { {
4708 .name = name_tv,
4709 .vmux = 3,
4710 .amux = TV,
4711 .tv = 1,
4712 }, {
4713 .name = name_comp1,
4714 .vmux = 1,
4715 .amux = LINE1,
4716 }, {
4717 .name = name_svideo,
4718 .vmux = 8,
4719 .amux = LINE1,
4720 } },
4721 .radio = {
4722 .name = name_radio,
4723 .amux = LINE2,
4724 },
4725 .mpeg = SAA7134_MPEG_EMPRESS,
4726 .video_out = CCIR656,
4727 .vid_port_opts = (SET_T_CODE_POLARITY_NON_INVERTED |
4728 SET_CLOCK_NOT_DELAYED |
4729 SET_CLOCK_INVERTED |
4730 SET_VSYNC_OFF),
Andrey J. Melnikoff (TEMHOTA)e8018c92008-01-07 05:17:39 -03004731 },
Hermann Pitton4ba24372008-01-20 19:27:51 -03004732 [SAA7134_BOARD_TWINHAN_DTV_DVB_3056] = {
4733 .name = "Twinhan Hybrid DTV-DVB 3056 PCI",
4734 .audio_clock = 0x00187de7,
4735 .tuner_type = TUNER_PHILIPS_TDA8290,
4736 .radio_type = UNSET,
4737 .tuner_addr = ADDR_UNSET,
4738 .radio_addr = ADDR_UNSET,
4739 .tuner_config = 2,
4740 .mpeg = SAA7134_MPEG_DVB,
4741 .gpiomask = 0x0200000,
4742 .inputs = {{
4743 .name = name_tv,
4744 .vmux = 1,
4745 .amux = TV,
4746 .tv = 1,
4747 }, {
4748 .name = name_comp1,
4749 .vmux = 3,
4750 .amux = LINE1,
4751 }, {
4752 .name = name_svideo,
4753 .vmux = 8, /* untested */
4754 .amux = LINE1,
4755 } },
4756 .radio = {
4757 .name = name_radio,
4758 .amux = TV,
4759 .gpio = 0x0200000,
4760 },
4761 },
Adrian Pardinif0ba3562008-02-11 12:40:53 -03004762 [SAA7134_BOARD_GENIUS_TVGO_A11MCE] = {
4763 /* Adrian Pardini <pardo.bsso@gmail.com> */
4764 .name = "Genius TVGO AM11MCE",
4765 .audio_clock = 0x00200000,
4766 .tuner_type = TUNER_TNF_5335MF,
4767 .radio_type = UNSET,
4768 .tuner_addr = ADDR_UNSET,
4769 .radio_addr = ADDR_UNSET,
4770 .gpiomask = 0xf000,
4771 .inputs = {{
4772 .name = name_tv_mono,
4773 .vmux = 1,
4774 .amux = LINE2,
4775 .gpio = 0x0000,
4776 .tv = 1,
4777 }, {
4778 .name = name_comp1,
4779 .vmux = 3,
4780 .amux = LINE1,
4781 .gpio = 0x2000,
4782 .tv = 1
4783 }, {
4784 .name = name_svideo,
4785 .vmux = 8,
4786 .amux = LINE1,
4787 .gpio = 0x2000,
4788 } },
4789 .radio = {
4790 .name = name_radio,
4791 .amux = LINE2,
4792 .gpio = 0x1000,
4793 },
4794 .mute = {
4795 .name = name_mute,
4796 .amux = LINE2,
4797 .gpio = 0x6000,
4798 },
4799 },
Hartmut Hackmann6ab465a2008-04-22 14:42:11 -03004800 [SAA7134_BOARD_PHILIPS_SNAKE] = {
4801 .name = "NXP Snake DVB-S reference design",
4802 .audio_clock = 0x00200000,
4803 .tuner_type = TUNER_ABSENT,
4804 .radio_type = UNSET,
4805 .tuner_addr = ADDR_UNSET,
4806 .radio_addr = ADDR_UNSET,
4807 .mpeg = SAA7134_MPEG_DVB,
4808 .inputs = {{
4809 .name = name_comp1,
4810 .vmux = 3,
4811 .amux = LINE1,
4812 }, {
4813 .name = name_svideo,
4814 .vmux = 8,
4815 .amux = LINE1,
4816 } },
4817 },
Hermann Pitton7b5b3f12008-04-22 14:42:12 -03004818 [SAA7134_BOARD_CREATIX_CTX953] = {
4819 .name = "Medion/Creatix CTX953 Hybrid",
4820 .audio_clock = 0x00187de7,
4821 .tuner_type = TUNER_PHILIPS_TDA8290,
4822 .radio_type = UNSET,
4823 .tuner_addr = ADDR_UNSET,
4824 .radio_addr = ADDR_UNSET,
4825 .tuner_config = 0,
4826 .mpeg = SAA7134_MPEG_DVB,
4827 .inputs = {{
4828 .name = name_tv,
4829 .vmux = 1,
4830 .amux = TV,
4831 .tv = 1,
4832 }, {
4833 .name = name_comp1,
4834 .vmux = 0,
4835 .amux = LINE1,
4836 }, {
4837 .name = name_svideo,
4838 .vmux = 8,
4839 .amux = LINE1,
4840 } },
4841 },
Russell Kliese6a6179b62008-04-22 14:42:12 -03004842 [SAA7134_BOARD_MSI_TVANYWHERE_AD11] = {
4843 .name = "MSI TV@nywhere A/D v1.1",
4844 .audio_clock = 0x00187de7,
4845 .tuner_type = TUNER_PHILIPS_TDA8290,
4846 .radio_type = UNSET,
4847 .tuner_addr = ADDR_UNSET,
4848 .radio_addr = ADDR_UNSET,
4849 .tuner_config = 2,
4850 .mpeg = SAA7134_MPEG_DVB,
4851 .gpiomask = 0x0200000,
4852 .inputs = { {
4853 .name = name_tv,
4854 .vmux = 1,
4855 .amux = TV,
4856 .tv = 1,
4857 }, {
4858 .name = name_comp1,
4859 .vmux = 3,
4860 .amux = LINE1,
4861 }, {
4862 .name = name_svideo,
4863 .vmux = 8,
4864 .amux = LINE1,
4865 } },
4866 .radio = {
4867 .name = name_radio,
4868 .amux = TV,
4869 .gpio = 0x0200000,
4870 },
4871 },
Mauro Carvalho Chehabbc36a682008-04-22 14:45:27 -03004872 [SAA7134_BOARD_AVERMEDIA_CARDBUS_506] = {
Mauro Carvalho Chehabd9ae6dd2008-04-22 14:46:06 -03004873 .name = "AVerMedia Cardbus TV/Radio (E506R)",
4874 .audio_clock = 0x187de7,
4875 .tuner_type = TUNER_XC2028,
Mauro Carvalho Chehab6e741712008-04-22 14:46:07 -03004876 .radio_type = UNSET,
Mauro Carvalho Chehabd9ae6dd2008-04-22 14:46:06 -03004877 .tuner_addr = ADDR_UNSET,
4878 .radio_addr = ADDR_UNSET,
Mauro Carvalho Chehabbc36a682008-04-22 14:45:27 -03004879 .mpeg = SAA7134_MPEG_DVB,
Mauro Carvalho Chehabbc36a682008-04-22 14:45:27 -03004880 .inputs = {{
4881 .name = name_tv,
4882 .vmux = 1,
4883 .amux = TV,
4884 .tv = 1,
4885 }, {
Tim Farrington31489362009-01-15 09:58:55 -03004886 .name = name_comp1,
4887 .vmux = 3,
Tim Farringtone5e4cd82008-06-29 11:54:08 -03004888 .amux = LINE1,
Mauro Carvalho Chehabbc36a682008-04-22 14:45:27 -03004889 }, {
4890 .name = name_svideo,
4891 .vmux = 8,
Tim Farrington31489362009-01-15 09:58:55 -03004892 .amux = LINE2,
Mauro Carvalho Chehabbc36a682008-04-22 14:45:27 -03004893 } },
4894 .radio = {
4895 .name = name_radio,
4896 .amux = TV,
4897 },
4898 },
4899 [SAA7134_BOARD_AVERMEDIA_A16D] = {
4900 .name = "AVerMedia Hybrid TV/Radio (A16D)",
4901 .audio_clock = 0x187de7,
4902 .tuner_type = TUNER_XC2028,
Mauro Carvalho Chehab6e741712008-04-22 14:46:07 -03004903 .radio_type = UNSET,
Mauro Carvalho Chehabd9ae6dd2008-04-22 14:46:06 -03004904 .tuner_addr = ADDR_UNSET,
4905 .radio_addr = ADDR_UNSET,
Hans Verkuilf87086e2008-07-18 00:50:58 -03004906 .mpeg = SAA7134_MPEG_DVB,
Mauro Carvalho Chehabbc36a682008-04-22 14:45:27 -03004907 .inputs = {{
4908 .name = name_tv,
4909 .vmux = 1,
4910 .amux = TV,
4911 .tv = 1,
4912 }, {
4913 .name = name_svideo,
4914 .vmux = 8,
4915 .amux = LINE1,
Dan Taylor9c7ecaf2008-06-27 13:29:41 -03004916 }, {
4917 .name = name_comp,
4918 .vmux = 0,
4919 .amux = LINE1,
Mauro Carvalho Chehabbc36a682008-04-22 14:45:27 -03004920 } },
4921 .radio = {
4922 .name = name_radio,
Tim Farrington6e501a32008-06-15 13:33:42 -03004923 .amux = TV,
Mauro Carvalho Chehabbc36a682008-04-22 14:45:27 -03004924 },
4925 },
4926 [SAA7134_BOARD_AVERMEDIA_M115] = {
4927 .name = "Avermedia M115",
4928 .audio_clock = 0x187de7,
4929 .tuner_type = TUNER_XC2028,
Mauro Carvalho Chehab6e741712008-04-22 14:46:07 -03004930 .radio_type = UNSET,
Mauro Carvalho Chehabd9ae6dd2008-04-22 14:46:06 -03004931 .tuner_addr = ADDR_UNSET,
4932 .radio_addr = ADDR_UNSET,
Mauro Carvalho Chehabbc36a682008-04-22 14:45:27 -03004933 .inputs = {{
4934 .name = name_tv,
4935 .vmux = 1,
4936 .amux = TV,
4937 .tv = 1,
4938 }, {
4939 .name = name_comp1,
4940 .vmux = 3,
4941 .amux = LINE1,
4942 }, {
4943 .name = name_svideo,
4944 .vmux = 8,
4945 .amux = LINE2,
4946 } },
4947 },
4948 [SAA7134_BOARD_VIDEOMATE_T750] = {
4949 /* John Newbigin <jn@it.swin.edu.au> */
4950 .name = "Compro VideoMate T750",
4951 .audio_clock = 0x00187de7,
4952 .tuner_type = TUNER_XC2028,
Mauro Carvalho Chehab6e741712008-04-22 14:46:07 -03004953 .radio_type = UNSET,
Mauro Carvalho Chehabd9ae6dd2008-04-22 14:46:06 -03004954 .tuner_addr = ADDR_UNSET,
4955 .radio_addr = ADDR_UNSET,
Mauro Carvalho Chehabbc36a682008-04-22 14:45:27 -03004956 .inputs = {{
4957 .name = name_tv,
4958 .vmux = 3,
4959 .amux = TV,
4960 .tv = 1,
4961 }, {
4962 .name = name_comp1,
4963 .vmux = 1,
4964 .amux = LINE2,
4965 }, {
4966 .name = name_svideo,
4967 .vmux = 8,
4968 .amux = LINE2,
4969 } },
4970 .radio = {
4971 .name = name_radio,
4972 .amux = TV,
4973 }
Matthias Schwarzottfc9d8ed2008-04-08 21:45:08 -03004974 },
4975 [SAA7134_BOARD_AVERMEDIA_A700_PRO] = {
4976 /* Matthias Schwarzott <zzam@gentoo.org> */
4977 .name = "Avermedia DVB-S Pro A700",
4978 .audio_clock = 0x00187de7,
4979 .tuner_type = TUNER_ABSENT,
4980 .radio_type = UNSET,
4981 .tuner_addr = ADDR_UNSET,
4982 .radio_addr = ADDR_UNSET,
Matthias Schwarzott04574182009-02-24 12:35:16 -03004983 .mpeg = SAA7134_MPEG_DVB,
Matthias Schwarzottfc9d8ed2008-04-08 21:45:08 -03004984 .inputs = { {
4985 .name = name_comp,
4986 .vmux = 1,
4987 .amux = LINE1,
4988 }, {
4989 .name = name_svideo,
4990 .vmux = 6,
4991 .amux = LINE1,
4992 } },
4993 },
4994 [SAA7134_BOARD_AVERMEDIA_A700_HYBRID] = {
4995 /* Matthias Schwarzott <zzam@gentoo.org> */
4996 .name = "Avermedia DVB-S Hybrid+FM A700",
4997 .audio_clock = 0x00187de7,
Matthias Schwarzott2659e462009-03-29 16:36:02 -03004998 .tuner_type = TUNER_XC2028,
Matthias Schwarzottfc9d8ed2008-04-08 21:45:08 -03004999 .radio_type = UNSET,
5000 .tuner_addr = ADDR_UNSET,
5001 .radio_addr = ADDR_UNSET,
Matthias Schwarzott04574182009-02-24 12:35:16 -03005002 .mpeg = SAA7134_MPEG_DVB,
Matthias Schwarzottfc9d8ed2008-04-08 21:45:08 -03005003 .inputs = { {
Matthias Schwarzott2659e462009-03-29 16:36:02 -03005004 .name = name_tv,
5005 .vmux = 4,
5006 .amux = TV,
5007 .tv = 1,
5008 }, {
Matthias Schwarzottfc9d8ed2008-04-08 21:45:08 -03005009 .name = name_comp,
5010 .vmux = 1,
5011 .amux = LINE1,
5012 }, {
5013 .name = name_svideo,
5014 .vmux = 6,
5015 .amux = LINE1,
5016 } },
Matthias Schwarzott2659e462009-03-29 16:36:02 -03005017 .radio = {
5018 .name = name_radio,
5019 .amux = TV,
5020 },
Matthias Schwarzottfc9d8ed2008-04-08 21:45:08 -03005021 },
Igor Kuznetsov02505272008-04-26 14:53:48 -03005022 [SAA7134_BOARD_BEHOLD_H6] = {
5023 /* Igor Kuznetsov <igk@igk.ru> */
5024 .name = "Beholder BeholdTV H6",
5025 .audio_clock = 0x00187de7,
Beholder Intl. Ltd. Dmitry Belimov4786dd62009-08-04 20:07:42 -03005026 .tuner_type = TUNER_PHILIPS_FMD1216MEX_MK3,
Igor Kuznetsov02505272008-04-26 14:53:48 -03005027 .radio_type = UNSET,
5028 .tuner_addr = ADDR_UNSET,
5029 .radio_addr = ADDR_UNSET,
5030 .tda9887_conf = TDA9887_PRESENT,
Dmitri Belimovf204ae42008-12-23 03:51:38 -03005031 .mpeg = SAA7134_MPEG_DVB,
Igor Kuznetsov02505272008-04-26 14:53:48 -03005032 .inputs = {{
5033 .name = name_tv,
5034 .vmux = 3,
5035 .amux = TV,
5036 .tv = 1,
5037 }, {
5038 .name = name_comp1,
5039 .vmux = 1,
5040 .amux = LINE1,
5041 }, {
5042 .name = name_svideo,
5043 .vmux = 8,
5044 .amux = LINE1,
5045 } },
5046 .radio = {
5047 .name = name_radio,
5048 .amux = LINE2,
5049 },
Igor Kuznetsov02505272008-04-26 14:53:48 -03005050 },
hermann pitton301e9d62008-09-14 17:49:14 -03005051 [SAA7134_BOARD_ASUSTeK_TIGER_3IN1] = {
5052 .name = "Asus Tiger 3in1",
5053 .audio_clock = 0x00187de7,
5054 .tuner_type = TUNER_PHILIPS_TDA8290,
5055 .radio_type = UNSET,
5056 .tuner_addr = ADDR_UNSET,
5057 .radio_addr = ADDR_UNSET,
5058 .tuner_config = 2,
5059 .gpiomask = 1 << 21,
5060 .mpeg = SAA7134_MPEG_DVB,
5061 .inputs = {{
5062 .name = name_tv,
5063 .vmux = 1,
5064 .amux = TV,
5065 .tv = 1,
5066 }, {
5067 .name = name_comp,
5068 .vmux = 0,
5069 .amux = LINE2,
5070 }, {
5071 .name = name_svideo,
5072 .vmux = 8,
5073 .amux = LINE2,
5074 } },
5075 .radio = {
5076 .name = name_radio,
5077 .amux = TV,
5078 .gpio = 0x0200000,
5079 },
5080 },
Mauro Carvalho Chehab9b000192008-06-26 17:03:00 -03005081 [SAA7134_BOARD_REAL_ANGEL_220] = {
5082 .name = "Zogis Real Angel 220",
5083 .audio_clock = 0x00187de7,
5084 .tuner_type = TUNER_TNF_5335MF,
5085 .radio_type = UNSET,
5086 .tuner_addr = ADDR_UNSET,
5087 .radio_addr = ADDR_UNSET,
5088 .gpiomask = 0x801a8087,
5089 .inputs = { {
5090 .name = name_tv,
5091 .vmux = 3,
5092 .amux = LINE2,
5093 .tv = 1,
5094 .gpio = 0x624000,
Hermann Pitton028165a2008-10-04 21:37:36 -03005095 }, {
Mauro Carvalho Chehab9b000192008-06-26 17:03:00 -03005096 .name = name_comp1,
5097 .vmux = 1,
5098 .amux = LINE1,
5099 .gpio = 0x624000,
5100 }, {
5101 .name = name_svideo,
5102 .vmux = 1,
5103 .amux = LINE1,
5104 .gpio = 0x624000,
5105 } },
5106 .radio = {
5107 .name = name_radio,
5108 .amux = LINE2,
5109 .gpio = 0x624001,
5110 },
5111 .mute = {
5112 .name = name_mute,
5113 .amux = TV,
5114 },
5115 },
Adam Gloverf689d902008-05-06 03:20:27 -03005116 [SAA7134_BOARD_ADS_INSTANT_HDTV_PCI] = {
5117 .name = "ADS Tech Instant HDTV",
5118 .audio_clock = 0x00187de7,
5119 .tuner_type = TUNER_PHILIPS_TUV1236D,
5120 .radio_type = UNSET,
5121 .tuner_addr = ADDR_UNSET,
5122 .radio_addr = ADDR_UNSET,
5123 .tda9887_conf = TDA9887_PRESENT,
5124 .mpeg = SAA7134_MPEG_DVB,
5125 .inputs = { {
5126 .name = name_tv,
5127 .vmux = 1,
5128 .amux = TV,
5129 .tv = 1,
5130 }, {
5131 .name = name_comp,
Hermann Pitton028165a2008-10-04 21:37:36 -03005132 .vmux = 4,
5133 .amux = LINE1,
Adam Gloverf689d902008-05-06 03:20:27 -03005134 }, {
5135 .name = name_svideo,
5136 .vmux = 8,
5137 .amux = LINE1,
5138 } },
5139 },
Hermann Pitton028165a2008-10-04 21:37:36 -03005140 [SAA7134_BOARD_ASUSTeK_TIGER] = {
5141 .name = "Asus Tiger Rev:1.00",
5142 .audio_clock = 0x00187de7,
5143 .tuner_type = TUNER_PHILIPS_TDA8290,
5144 .radio_type = UNSET,
5145 .tuner_addr = ADDR_UNSET,
5146 .radio_addr = ADDR_UNSET,
5147 .tuner_config = 0,
5148 .mpeg = SAA7134_MPEG_DVB,
5149 .gpiomask = 0x0200000,
5150 .inputs = { {
5151 .name = name_tv,
5152 .vmux = 1,
5153 .amux = TV,
5154 .tv = 1,
5155 }, {
5156 .name = name_comp1,
5157 .vmux = 3,
5158 .amux = LINE2,
5159 }, {
5160 .name = name_comp2,
5161 .vmux = 0,
5162 .amux = LINE2,
5163 }, {
5164 .name = name_svideo,
5165 .vmux = 8,
5166 .amux = LINE2,
5167 } },
5168 .radio = {
5169 .name = name_radio,
5170 .amux = TV,
5171 .gpio = 0x0200000,
5172 },
5173 },
Mauro Carvalho Chehab26d5f3a2008-12-07 13:19:29 -03005174 [SAA7134_BOARD_KWORLD_PLUS_TV_ANALOG] = {
5175 .name = "Kworld Plus TV Analog Lite PCI",
5176 .audio_clock = 0x00187de7,
5177 .tuner_type = TUNER_YMEC_TVF_5533MF,
5178 .radio_type = TUNER_TEA5767,
5179 .tuner_addr = ADDR_UNSET,
Hans Verkuilfac69862009-01-17 12:17:14 -03005180 .radio_addr = 0x60,
Mauro Carvalho Chehab26d5f3a2008-12-07 13:19:29 -03005181 .gpiomask = 0x80000700,
5182 .inputs = { {
5183 .name = name_tv,
5184 .vmux = 1,
5185 .amux = LINE2,
5186 .tv = 1,
5187 .gpio = 0x100,
5188 }, {
5189 .name = name_comp1,
5190 .vmux = 3,
5191 .amux = LINE1,
5192 .gpio = 0x200,
5193 }, {
5194 .name = name_svideo,
5195 .vmux = 8,
5196 .amux = LINE1,
5197 .gpio = 0x200,
5198 } },
5199 .radio = {
5200 .name = name_radio,
5201 .vmux = 1,
5202 .amux = LINE1,
5203 .gpio = 0x100,
5204 },
5205 .mute = {
5206 .name = name_mute,
5207 .vmux = 8,
5208 .amux = 2,
5209 },
5210 },
Mauro Carvalho Chehab68541cd2010-10-03 05:27:59 -03005211 [SAA7134_BOARD_KWORLD_PCI_SBTVD_FULLSEG] = {
5212 .name = "Kworld PCI SBTVD/ISDB-T Full-Seg Hybrid",
5213 .audio_clock = 0x00187de7,
Mauro Carvalho Chehab61830402011-01-13 14:24:44 -03005214 .tuner_type = TUNER_PHILIPS_TDA8290,
Mauro Carvalho Chehabf0551ef2010-10-03 07:01:26 -03005215 .tuner_addr = ADDR_UNSET,
Mauro Carvalho Chehabf0551ef2010-10-03 07:01:26 -03005216 .radio_type = UNSET,
Mauro Carvalho Chehab68541cd2010-10-03 05:27:59 -03005217 .radio_addr = ADDR_UNSET,
5218 .gpiomask = 0x8e054000,
5219 .mpeg = SAA7134_MPEG_DVB,
Mauro Carvalho Chehabf0551ef2010-10-03 07:01:26 -03005220 .ts_type = SAA7134_MPEG_TS_PARALLEL,
Mauro Carvalho Chehab68541cd2010-10-03 05:27:59 -03005221 .inputs = { {
5222 .name = name_tv,
5223 .vmux = 1,
5224 .amux = TV,
5225 .tv = 1,
5226#if 0 /* FIXME */
5227 }, {
5228 .name = name_comp1,
5229 .vmux = 3,
5230 .amux = LINE1,
5231 .gpio = 0x200,
5232 }, {
5233 .name = name_svideo,
5234 .vmux = 8,
5235 .amux = LINE1,
5236 .gpio = 0x200,
5237#endif
5238 } },
5239#if 0
5240 .radio = {
5241 .name = name_radio,
5242 .vmux = 1,
5243 .amux = LINE1,
5244 .gpio = 0x100,
5245 },
5246#endif
5247 .mute = {
5248 .name = name_mute,
5249 .vmux = 0,
5250 .amux = TV,
5251 },
5252 },
Pham Thanh Nam6a2d8022008-12-30 23:26:09 -03005253 [SAA7134_BOARD_AVERMEDIA_GO_007_FM_PLUS] = {
5254 .name = "Avermedia AVerTV GO 007 FM Plus",
5255 .audio_clock = 0x00187de7,
5256 .tuner_type = TUNER_PHILIPS_TDA8290,
5257 .radio_type = UNSET,
5258 .tuner_addr = ADDR_UNSET,
5259 .radio_addr = ADDR_UNSET,
5260 .gpiomask = 0x00300003,
5261 /* .gpiomask = 0x8c240003, */
5262 .inputs = { {
5263 .name = name_tv,
5264 .vmux = 1,
5265 .amux = TV,
5266 .tv = 1,
5267 .gpio = 0x01,
5268 }, {
5269 .name = name_svideo,
5270 .vmux = 6,
5271 .amux = LINE1,
5272 .gpio = 0x02,
5273 } },
5274 .radio = {
5275 .name = name_radio,
5276 .amux = TV,
5277 .gpio = 0x00300001,
5278 },
5279 .mute = {
5280 .name = name_mute,
5281 .amux = TV,
5282 .gpio = 0x01,
5283 },
5284 },
Andy Shevchenkodf0dbbe2009-04-08 14:01:19 -03005285 [SAA7134_BOARD_AVERMEDIA_STUDIO_507UA] = {
5286 /* Andy Shevchenko <andy@smile.org.ua> */
5287 .name = "Avermedia AVerTV Studio 507UA",
5288 .audio_clock = 0x00187de7,
5289 .tuner_type = TUNER_PHILIPS_FM1216ME_MK3, /* Should be MK5 */
5290 .radio_type = UNSET,
5291 .tuner_addr = ADDR_UNSET,
5292 .radio_addr = ADDR_UNSET,
5293 .tda9887_conf = TDA9887_PRESENT,
5294 .gpiomask = 0x03,
5295 .inputs = { {
5296 .name = name_tv,
5297 .vmux = 1,
5298 .amux = TV,
5299 .tv = 1,
5300 .gpio = 0x00,
5301 }, {
5302 .name = name_comp1,
5303 .vmux = 3,
5304 .amux = LINE1,
5305 .gpio = 0x00,
5306 }, {
5307 .name = name_svideo,
5308 .vmux = 8,
5309 .amux = LINE1,
5310 .gpio = 0x00,
5311 } },
5312 .radio = {
5313 .name = name_radio,
5314 .amux = LINE2,
5315 .gpio = 0x01,
5316 },
5317 .mute = {
5318 .name = name_mute,
5319 .amux = LINE1,
5320 .gpio = 0x00,
5321 },
5322 },
Igor M. Liplianinecfcfec2009-08-13 21:42:21 -03005323 [SAA7134_BOARD_VIDEOMATE_S350] = {
5324 /* Jan D. Louw <jd.louw@mweb.co.za */
5325 .name = "Compro VideoMate S350/S300",
5326 .audio_clock = 0x00187de7,
5327 .tuner_type = TUNER_ABSENT,
5328 .radio_type = UNSET,
5329 .tuner_addr = ADDR_UNSET,
5330 .radio_addr = ADDR_UNSET,
5331 .mpeg = SAA7134_MPEG_DVB,
5332 .inputs = { {
5333 .name = name_comp1,
5334 .vmux = 0,
5335 .amux = LINE1,
5336 }, {
5337 .name = name_svideo,
5338 .vmux = 8, /* Not tested */
5339 .amux = LINE1
5340 } },
5341 },
Dmitri Belimov2012c872009-08-26 01:01:12 -03005342 [SAA7134_BOARD_BEHOLD_X7] = {
5343 /* Beholder Intl. Ltd. Dmitry Belimov <d.belimov@gmail.com> */
5344 .name = "Beholder BeholdTV X7",
5345 .audio_clock = 0x00187de7,
5346 .tuner_type = TUNER_XC5000,
5347 .radio_type = UNSET,
5348 .tuner_addr = ADDR_UNSET,
5349 .radio_addr = ADDR_UNSET,
Beholder Intl. Ltd. Dmitry Belimov29309922009-09-30 23:02:21 -03005350 .mpeg = SAA7134_MPEG_DVB,
Dmitri Belimov2012c872009-08-26 01:01:12 -03005351 .inputs = { {
5352 .name = name_tv,
5353 .vmux = 2,
5354 .amux = TV,
5355 .tv = 1,
5356 }, {
5357 .name = name_comp1,
5358 .vmux = 0,
5359 .amux = LINE1,
5360 }, {
5361 .name = name_svideo,
5362 .vmux = 9,
5363 .amux = LINE1,
5364 } },
5365 .radio = {
5366 .name = name_radio,
5367 .amux = TV,
5368 },
5369 },
Henk Vergonet6c119ff2009-09-18 20:44:37 -03005370 [SAA7134_BOARD_ZOLID_HYBRID_PCI] = {
5371 .name = "Zolid Hybrid TV Tuner PCI",
5372 .audio_clock = 0x00187de7,
5373 .tuner_type = TUNER_PHILIPS_TDA8290,
5374 .radio_type = UNSET,
5375 .tuner_addr = ADDR_UNSET,
5376 .radio_addr = ADDR_UNSET,
5377 .tuner_config = 0,
5378 .mpeg = SAA7134_MPEG_DVB,
5379 .ts_type = SAA7134_MPEG_TS_PARALLEL,
5380 .inputs = {{
5381 .name = name_tv,
5382 .vmux = 1,
5383 .amux = TV,
5384 .tv = 1,
5385 } },
5386 .radio = { /* untested */
5387 .name = name_radio,
5388 .amux = TV,
5389 },
5390 },
Danny Woode3c6e1a2009-09-20 12:14:21 -03005391 [SAA7134_BOARD_ASUS_EUROPA_HYBRID] = {
5392 .name = "Asus Europa Hybrid OEM",
5393 .audio_clock = 0x00187de7,
5394 .tuner_type = TUNER_PHILIPS_TD1316,
5395 .radio_type = UNSET,
5396 .tuner_addr = 0x61,
5397 .radio_addr = ADDR_UNSET,
5398 .tda9887_conf = TDA9887_PRESENT | TDA9887_PORT1_ACTIVE,
5399 .mpeg = SAA7134_MPEG_DVB,
5400 .inputs = { {
5401 .name = name_tv,
5402 .vmux = 3,
5403 .amux = TV,
5404 .tv = 1,
5405 }, {
5406 .name = name_comp1,
5407 .vmux = 4,
5408 .amux = LINE2,
5409 }, {
5410 .name = name_svideo,
5411 .vmux = 8,
5412 .amux = LINE2,
5413 } },
5414 },
Michael Krufky53c8ec52009-10-31 13:46:08 -03005415 [SAA7134_BOARD_LEADTEK_WINFAST_DTV1000S] = {
5416 .name = "Leadtek Winfast DTV1000S",
5417 .audio_clock = 0x00187de7,
5418 .tuner_type = TUNER_PHILIPS_TDA8290,
5419 .radio_type = UNSET,
5420 .tuner_addr = ADDR_UNSET,
5421 .radio_addr = ADDR_UNSET,
5422 .mpeg = SAA7134_MPEG_DVB,
5423 .inputs = { {
5424 .name = name_comp1,
5425 .vmux = 3,
5426 }, {
5427 .name = name_svideo,
5428 .vmux = 8,
5429 } },
5430 },
Dmitri Belimov9c6f97a2009-12-21 02:00:38 -03005431 [SAA7134_BOARD_BEHOLD_505RDS_MK3] = {
5432 /* Beholder Intl. Ltd. 2008 */
5433 /*Dmitry Belimov <d.belimov@gmail.com> */
5434 .name = "Beholder BeholdTV 505 RDS",
5435 .audio_clock = 0x00200000,
5436 .tuner_type = TUNER_PHILIPS_FM1216ME_MK3,
5437 .radio_type = UNSET,
5438 .tuner_addr = ADDR_UNSET,
5439 .radio_addr = ADDR_UNSET,
5440 .rds_addr = 0x10,
5441 .tda9887_conf = TDA9887_PRESENT,
5442 .gpiomask = 0x00008000,
5443 .inputs = {{
5444 .name = name_tv,
5445 .vmux = 3,
5446 .amux = LINE2,
5447 .tv = 1,
5448 }, {
5449 .name = name_comp1,
5450 .vmux = 1,
5451 .amux = LINE1,
5452 }, {
5453 .name = name_svideo,
5454 .vmux = 8,
5455 .amux = LINE1,
5456 } },
5457 .mute = {
5458 .name = name_mute,
5459 .amux = LINE1,
5460 },
5461 .radio = {
5462 .name = name_radio,
5463 .amux = LINE2,
5464 },
5465 },
Vladimir Ermakov8f27fd92010-03-10 12:44:57 -03005466 [SAA7134_BOARD_HAWELL_HW_404M7] = {
5467 /* Hawell HW-404M7 & Hawell HW-808M7 */
5468 /* Bogoslovskiy Viktor <bogovic@bk.ru> */
5469 .name = "Hawell HW-404M7",
5470 .audio_clock = 0x00200000,
5471 .tuner_type = UNSET,
5472 .radio_type = UNSET,
5473 .tuner_addr = ADDR_UNSET,
5474 .radio_addr = ADDR_UNSET,
Vladimir Ermakove8383262010-04-07 02:23:31 -03005475 .gpiomask = 0x389c00,
Vladimir Ermakov8f27fd92010-03-10 12:44:57 -03005476 .inputs = {{
5477 .name = name_comp1,
5478 .vmux = 3,
5479 .amux = LINE1,
Vladimir Ermakove8383262010-04-07 02:23:31 -03005480 .gpio = 0x01fc00,
Vladimir Ermakov8f27fd92010-03-10 12:44:57 -03005481 } },
5482 },
Dmitri Belimov0faa2ed2010-04-06 01:00:05 -03005483 [SAA7134_BOARD_BEHOLD_H7] = {
5484 /* Beholder Intl. Ltd. Dmitry Belimov <d.belimov@gmail.com> */
5485 .name = "Beholder BeholdTV H7",
5486 .audio_clock = 0x00187de7,
5487 .tuner_type = TUNER_XC5000,
5488 .radio_type = UNSET,
5489 .tuner_addr = ADDR_UNSET,
5490 .radio_addr = ADDR_UNSET,
5491 .mpeg = SAA7134_MPEG_DVB,
5492 .ts_type = SAA7134_MPEG_TS_PARALLEL,
5493 .inputs = { {
5494 .name = name_tv,
5495 .vmux = 2,
5496 .amux = TV,
5497 .tv = 1,
5498 }, {
5499 .name = name_comp1,
5500 .vmux = 0,
5501 .amux = LINE1,
5502 }, {
5503 .name = name_svideo,
5504 .vmux = 9,
5505 .amux = LINE1,
5506 } },
5507 .radio = {
5508 .name = name_radio,
5509 .amux = TV,
5510 },
5511 },
5512 [SAA7134_BOARD_BEHOLD_A7] = {
5513 /* Beholder Intl. Ltd. Dmitry Belimov <d.belimov@gmail.com> */
5514 .name = "Beholder BeholdTV A7",
5515 .audio_clock = 0x00187de7,
5516 .tuner_type = TUNER_XC5000,
5517 .radio_type = UNSET,
5518 .tuner_addr = ADDR_UNSET,
5519 .radio_addr = ADDR_UNSET,
5520 .inputs = { {
5521 .name = name_tv,
5522 .vmux = 2,
5523 .amux = TV,
5524 .tv = 1,
5525 }, {
5526 .name = name_comp1,
5527 .vmux = 0,
5528 .amux = LINE1,
5529 }, {
5530 .name = name_svideo,
5531 .vmux = 9,
5532 .amux = LINE1,
5533 } },
5534 .radio = {
5535 .name = name_radio,
5536 .amux = TV,
5537 },
5538 },
Vadim Catana128fe952010-05-29 12:49:16 -03005539 [SAA7134_BOARD_TECHNOTREND_BUDGET_T3000] = {
5540 .name = "TechoTrend TT-budget T-3000",
5541 .tuner_type = TUNER_PHILIPS_TD1316,
5542 .audio_clock = 0x00187de7,
5543 .radio_type = UNSET,
5544 .tuner_addr = 0x63,
5545 .radio_addr = ADDR_UNSET,
5546 .tda9887_conf = TDA9887_PRESENT | TDA9887_PORT1_ACTIVE,
5547 .mpeg = SAA7134_MPEG_DVB,
5548 .inputs = {{
5549 .name = name_tv,
5550 .vmux = 3,
5551 .amux = TV,
5552 .tv = 1,
5553 }, {
5554 .name = name_comp1,
5555 .vmux = 0,
5556 .amux = LINE2,
5557 }, {
5558 .name = name_svideo,
5559 .vmux = 8,
5560 .amux = LINE2,
5561 } },
5562 },
Ramiro Moralesb7a0f2e2010-12-26 18:13:30 -03005563 [SAA7134_BOARD_VIDEOMATE_M1F] = {
5564 /* Pavel Osnova <pvosnova@gmail.com> */
5565 .name = "Compro VideoMate Vista M1F",
5566 .audio_clock = 0x00187de7,
5567 .tuner_type = TUNER_LG_PAL_NEW_TAPC,
5568 .radio_type = TUNER_TEA5767,
5569 .tuner_addr = ADDR_UNSET,
5570 .radio_addr = 0x60,
5571 .inputs = { {
5572 .name = name_tv,
5573 .vmux = 1,
5574 .amux = TV,
5575 .tv = 1,
5576 }, {
5577 .name = name_comp1,
5578 .vmux = 3,
5579 .amux = LINE2,
5580 }, {
5581 .name = name_svideo,
5582 .vmux = 8,
5583 .amux = LINE2,
5584 } },
5585 .radio = {
5586 .name = name_radio,
5587 .amux = LINE1,
5588 },
5589 .mute = {
5590 .name = name_mute,
5591 .amux = TV,
5592 },
5593 },
Dmitri Belimov2012c872009-08-26 01:01:12 -03005594
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07005595};
5596
Linus Torvalds1da177e2005-04-16 15:20:36 -07005597const unsigned int saa7134_bcount = ARRAY_SIZE(saa7134_boards);
5598
5599/* ------------------------------------------------------------------ */
5600/* PCI ids + subsystem IDs */
5601
5602struct pci_device_id saa7134_pci_tbl[] = {
5603 {
5604 .vendor = PCI_VENDOR_ID_PHILIPS,
5605 .device = PCI_DEVICE_ID_PHILIPS_SAA7134,
5606 .subvendor = PCI_VENDOR_ID_PHILIPS,
5607 .subdevice = 0x2001,
5608 .driver_data = SAA7134_BOARD_PROTEUS_PRO,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07005609 },{
Linus Torvalds1da177e2005-04-16 15:20:36 -07005610 .vendor = PCI_VENDOR_ID_PHILIPS,
5611 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
5612 .subvendor = PCI_VENDOR_ID_PHILIPS,
5613 .subdevice = 0x2001,
5614 .driver_data = SAA7134_BOARD_PROTEUS_PRO,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07005615 },{
Linus Torvalds1da177e2005-04-16 15:20:36 -07005616 .vendor = PCI_VENDOR_ID_PHILIPS,
5617 .device = PCI_DEVICE_ID_PHILIPS_SAA7134,
5618 .subvendor = PCI_VENDOR_ID_PHILIPS,
5619 .subdevice = 0x6752,
5620 .driver_data = SAA7134_BOARD_EMPRESS,
5621 },{
5622 .vendor = PCI_VENDOR_ID_PHILIPS,
5623 .device = PCI_DEVICE_ID_PHILIPS_SAA7134,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07005624 .subvendor = 0x1131,
5625 .subdevice = 0x4e85,
Linus Torvalds1da177e2005-04-16 15:20:36 -07005626 .driver_data = SAA7134_BOARD_MONSTERTV,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07005627 },{
5628 .vendor = PCI_VENDOR_ID_PHILIPS,
5629 .device = PCI_DEVICE_ID_PHILIPS_SAA7134,
Michael Krufky7df64e82005-11-08 21:36:16 -08005630 .subvendor = 0x153b,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07005631 .subdevice = 0x1142,
5632 .driver_data = SAA7134_BOARD_CINERGY400,
5633 },{
5634 .vendor = PCI_VENDOR_ID_PHILIPS,
5635 .device = PCI_DEVICE_ID_PHILIPS_SAA7134,
Michael Krufky7df64e82005-11-08 21:36:16 -08005636 .subvendor = 0x153b,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07005637 .subdevice = 0x1143,
5638 .driver_data = SAA7134_BOARD_CINERGY600,
5639 },{
5640 .vendor = PCI_VENDOR_ID_PHILIPS,
5641 .device = PCI_DEVICE_ID_PHILIPS_SAA7134,
Michael Krufky7df64e82005-11-08 21:36:16 -08005642 .subvendor = 0x153b,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07005643 .subdevice = 0x1158,
5644 .driver_data = SAA7134_BOARD_CINERGY600_MK3,
5645 },{
Linus Torvalds1da177e2005-04-16 15:20:36 -07005646 .vendor = PCI_VENDOR_ID_PHILIPS,
5647 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
5648 .subvendor = 0x153b,
5649 .subdevice = 0x1162,
5650 .driver_data = SAA7134_BOARD_CINERGY400_CARDBUS,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07005651 },{
Linus Torvalds1da177e2005-04-16 15:20:36 -07005652 .vendor = PCI_VENDOR_ID_PHILIPS,
5653 .device = PCI_DEVICE_ID_PHILIPS_SAA7134,
Zac Bowlingf49ba8d2006-06-19 19:49:20 -03005654 .subvendor = 0x5169,
5655 .subdevice = 0x0138,
5656 .driver_data = SAA7134_BOARD_FLYVIDEO3000_NTSC,
5657 },{
5658 .vendor = PCI_VENDOR_ID_PHILIPS,
5659 .device = PCI_DEVICE_ID_PHILIPS_SAA7134,
Linus Torvalds1da177e2005-04-16 15:20:36 -07005660 .subvendor = 0x5168,
5661 .subdevice = 0x0138,
5662 .driver_data = SAA7134_BOARD_FLYVIDEO3000,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07005663 },{
Linus Torvalds1da177e2005-04-16 15:20:36 -07005664 .vendor = PCI_VENDOR_ID_PHILIPS,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07005665 .device = PCI_DEVICE_ID_PHILIPS_SAA7134,
5666 .subvendor = 0x4e42, /* "Typhoon PCI Capture TV Card" Art.No. 50673 */
5667 .subdevice = 0x0138,
5668 .driver_data = SAA7134_BOARD_FLYVIDEO3000,
5669 },{
Linus Torvalds1da177e2005-04-16 15:20:36 -07005670 .vendor = PCI_VENDOR_ID_PHILIPS,
5671 .device = PCI_DEVICE_ID_PHILIPS_SAA7130,
5672 .subvendor = 0x5168,
5673 .subdevice = 0x0138,
5674 .driver_data = SAA7134_BOARD_FLYVIDEO2000,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07005675 },{
Linus Torvalds1da177e2005-04-16 15:20:36 -07005676 .vendor = PCI_VENDOR_ID_PHILIPS,
Peter Missel10b7a902006-01-23 17:11:06 -02005677 .device = PCI_DEVICE_ID_PHILIPS_SAA7130,
5678 .subvendor = 0x4e42, /* Typhoon */
5679 .subdevice = 0x0138, /* LifeView FlyTV Prime30 OEM */
5680 .driver_data = SAA7134_BOARD_FLYVIDEO2000,
5681 },{
5682 .vendor = PCI_VENDOR_ID_PHILIPS,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07005683 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
Linus Torvalds1da177e2005-04-16 15:20:36 -07005684 .subvendor = 0x5168,
5685 .subdevice = 0x0212, /* minipci, LR212 */
5686 .driver_data = SAA7134_BOARD_FLYTVPLATINUM_MINI,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07005687 },{
Linus Torvalds1da177e2005-04-16 15:20:36 -07005688 .vendor = PCI_VENDOR_ID_PHILIPS,
5689 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
Mauro Carvalho Chehab058afaf2005-11-08 21:36:49 -08005690 .subvendor = 0x14c0,
5691 .subdevice = 0x1212, /* minipci, LR1212 */
5692 .driver_data = SAA7134_BOARD_FLYTVPLATINUM_MINI2,
5693 },{
5694 .vendor = PCI_VENDOR_ID_PHILIPS,
5695 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
Glen Gray2d14f782005-11-08 21:36:12 -08005696 .subvendor = 0x4e42,
5697 .subdevice = 0x0212, /* OEM minipci, LR212 */
5698 .driver_data = SAA7134_BOARD_FLYTVPLATINUM_MINI,
5699 },{
5700 .vendor = PCI_VENDOR_ID_PHILIPS,
5701 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
Peter Missel10e92062005-05-01 08:59:21 -07005702 .subvendor = 0x5168, /* Animation Technologies (LifeView) */
Simon Farnsworthb39423a2007-05-01 10:01:20 -03005703 .subdevice = 0x0214, /* Standard PCI, LR214 Rev E and earlier (SAA7135) */
5704 .driver_data = SAA7134_BOARD_FLYTVPLATINUM_FM,
5705 },{
5706 .vendor = PCI_VENDOR_ID_PHILIPS,
5707 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
5708 .subvendor = 0x5168, /* Animation Technologies (LifeView) */
5709 .subdevice = 0x5214, /* Standard PCI, LR214 Rev F onwards (SAA7131) */
Linus Torvalds1da177e2005-04-16 15:20:36 -07005710 .driver_data = SAA7134_BOARD_FLYTVPLATINUM_FM,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07005711 },{
Linus Torvalds1da177e2005-04-16 15:20:36 -07005712 .vendor = PCI_VENDOR_ID_PHILIPS,
Peter Missel10e92062005-05-01 08:59:21 -07005713 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
5714 .subvendor = 0x1489, /* KYE */
5715 .subdevice = 0x0214, /* Genius VideoWonder ProTV */
5716 .driver_data = SAA7134_BOARD_FLYTVPLATINUM_FM, /* is an LR214WF actually */
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07005717 },{
Peter Missel10e92062005-05-01 08:59:21 -07005718 .vendor = PCI_VENDOR_ID_PHILIPS,
Linus Torvalds1da177e2005-04-16 15:20:36 -07005719 .device = PCI_DEVICE_ID_PHILIPS_SAA7134,
5720 .subvendor = 0x16be,
5721 .subdevice = 0x0003,
5722 .driver_data = SAA7134_BOARD_MD7134,
5723 },{
5724 .vendor = PCI_VENDOR_ID_PHILIPS,
Hermann Pittona5525682008-12-05 19:49:34 -03005725 .device = PCI_DEVICE_ID_PHILIPS_SAA7134,
5726 .subvendor = 0x16be, /* CTX946 analog TV, HW mpeg, DVB-T */
5727 .subdevice = 0x5000, /* only analog TV and DVB-T for now */
5728 .driver_data = SAA7134_BOARD_MD7134,
5729 }, {
5730 .vendor = PCI_VENDOR_ID_PHILIPS,
Linus Torvalds1da177e2005-04-16 15:20:36 -07005731 .device = PCI_DEVICE_ID_PHILIPS_SAA7130,
5732 .subvendor = 0x1048,
5733 .subdevice = 0x226b,
5734 .driver_data = SAA7134_BOARD_ELSA,
5735 },{
5736 .vendor = PCI_VENDOR_ID_PHILIPS,
5737 .device = PCI_DEVICE_ID_PHILIPS_SAA7130,
5738 .subvendor = 0x1048,
Michael Krufky9a7871b2006-02-27 15:22:49 -03005739 .subdevice = 0x226a,
Linus Torvalds1da177e2005-04-16 15:20:36 -07005740 .driver_data = SAA7134_BOARD_ELSA_500TV,
5741 },{
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07005742 .vendor = PCI_VENDOR_ID_PHILIPS,
Tamuki Shoichid0456d12006-02-27 00:08:04 -03005743 .device = PCI_DEVICE_ID_PHILIPS_SAA7130,
Michael Krufkyba524292006-02-27 14:38:17 -03005744 .subvendor = 0x1048,
5745 .subdevice = 0x226c,
Tamuki Shoichid0456d12006-02-27 00:08:04 -03005746 .driver_data = SAA7134_BOARD_ELSA_700TV,
5747 },{
5748 .vendor = PCI_VENDOR_ID_PHILIPS,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07005749 .device = PCI_DEVICE_ID_PHILIPS_SAA7134,
5750 .subvendor = PCI_VENDOR_ID_ASUSTEK,
5751 .subdevice = 0x4842,
5752 .driver_data = SAA7134_BOARD_ASUSTeK_TVFM7134,
Linus Torvalds1da177e2005-04-16 15:20:36 -07005753 },{
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07005754 .vendor = PCI_VENDOR_ID_PHILIPS,
5755 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
5756 .subvendor = PCI_VENDOR_ID_ASUSTEK,
5757 .subdevice = 0x4845,
5758 .driver_data = SAA7134_BOARD_ASUSTeK_TVFM7135,
Linus Torvalds1da177e2005-04-16 15:20:36 -07005759 },{
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07005760 .vendor = PCI_VENDOR_ID_PHILIPS,
5761 .device = PCI_DEVICE_ID_PHILIPS_SAA7134,
5762 .subvendor = PCI_VENDOR_ID_ASUSTEK,
5763 .subdevice = 0x4830,
5764 .driver_data = SAA7134_BOARD_ASUSTeK_TVFM7134,
Linus Torvalds1da177e2005-04-16 15:20:36 -07005765 },{
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07005766 .vendor = PCI_VENDOR_ID_PHILIPS,
5767 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
5768 .subvendor = PCI_VENDOR_ID_ASUSTEK,
5769 .subdevice = 0x4843,
5770 .driver_data = SAA7134_BOARD_ASUSTEK_TVFM7133,
5771 },{
5772 .vendor = PCI_VENDOR_ID_PHILIPS,
5773 .device = PCI_DEVICE_ID_PHILIPS_SAA7134,
5774 .subvendor = PCI_VENDOR_ID_ASUSTEK,
5775 .subdevice = 0x4840,
5776 .driver_data = SAA7134_BOARD_ASUSTeK_TVFM7134,
5777 },{
Linus Torvalds1da177e2005-04-16 15:20:36 -07005778 .vendor = PCI_VENDOR_ID_PHILIPS,
5779 .device = PCI_DEVICE_ID_PHILIPS_SAA7134,
5780 .subvendor = PCI_VENDOR_ID_PHILIPS,
5781 .subdevice = 0xfe01,
5782 .driver_data = SAA7134_BOARD_TVSTATION_RDS,
5783 },{
5784 .vendor = PCI_VENDOR_ID_PHILIPS,
5785 .device = PCI_DEVICE_ID_PHILIPS_SAA7134,
5786 .subvendor = 0x1894,
5787 .subdevice = 0xfe01,
5788 .driver_data = SAA7134_BOARD_TVSTATION_RDS,
5789 },{
5790 .vendor = PCI_VENDOR_ID_PHILIPS,
5791 .device = PCI_DEVICE_ID_PHILIPS_SAA7134,
5792 .subvendor = 0x1894,
5793 .subdevice = 0xa006,
5794 .driver_data = SAA7134_BOARD_TVSTATION_DVR,
5795 },{
5796 .vendor = PCI_VENDOR_ID_PHILIPS,
5797 .device = PCI_DEVICE_ID_PHILIPS_SAA7134,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07005798 .subvendor = 0x1131,
5799 .subdevice = 0x7133,
Linus Torvalds1da177e2005-04-16 15:20:36 -07005800 .driver_data = SAA7134_BOARD_VA1000POWER,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07005801 },{
Linus Torvalds1da177e2005-04-16 15:20:36 -07005802 .vendor = PCI_VENDOR_ID_PHILIPS,
5803 .device = PCI_DEVICE_ID_PHILIPS_SAA7130,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07005804 .subvendor = PCI_VENDOR_ID_PHILIPS,
5805 .subdevice = 0x2001,
Linus Torvalds1da177e2005-04-16 15:20:36 -07005806 .driver_data = SAA7134_BOARD_10MOONSTVMASTER,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07005807 },{
Linus Torvalds1da177e2005-04-16 15:20:36 -07005808 .vendor = PCI_VENDOR_ID_PHILIPS,
5809 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07005810 .subvendor = 0x185b,
5811 .subdevice = 0xc100,
Linus Torvalds1da177e2005-04-16 15:20:36 -07005812 .driver_data = SAA7134_BOARD_VIDEOMATE_TV,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07005813 },{
Linus Torvalds1da177e2005-04-16 15:20:36 -07005814 .vendor = PCI_VENDOR_ID_PHILIPS,
5815 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07005816 .subvendor = 0x185b,
5817 .subdevice = 0xc100,
Linus Torvalds1da177e2005-04-16 15:20:36 -07005818 .driver_data = SAA7134_BOARD_VIDEOMATE_TV_GOLD_PLUS,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07005819 },{
Linus Torvalds1da177e2005-04-16 15:20:36 -07005820 .vendor = PCI_VENDOR_ID_PHILIPS,
5821 .device = PCI_DEVICE_ID_PHILIPS_SAA7130,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07005822 .subvendor = PCI_VENDOR_ID_MATROX,
5823 .subdevice = 0x48d0,
Linus Torvalds1da177e2005-04-16 15:20:36 -07005824 .driver_data = SAA7134_BOARD_CRONOS_PLUS,
5825 },{
5826 .vendor = PCI_VENDOR_ID_PHILIPS,
5827 .device = PCI_DEVICE_ID_PHILIPS_SAA7134,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07005828 .subvendor = 0x1461, /* Avermedia Technologies Inc */
5829 .subdevice = 0xa70b,
Linus Torvalds1da177e2005-04-16 15:20:36 -07005830 .driver_data = SAA7134_BOARD_MD2819,
5831 },{
5832 .vendor = PCI_VENDOR_ID_PHILIPS,
Matthias Schwarzottfc9d8ed2008-04-08 21:45:08 -03005833 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
5834 .subvendor = 0x1461, /* Avermedia Technologies Inc */
5835 .subdevice = 0xa7a1,
5836 .driver_data = SAA7134_BOARD_AVERMEDIA_A700_PRO,
5837 }, {
5838 .vendor = PCI_VENDOR_ID_PHILIPS,
5839 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
5840 .subvendor = 0x1461, /* Avermedia Technologies Inc */
5841 .subdevice = 0xa7a2,
5842 .driver_data = SAA7134_BOARD_AVERMEDIA_A700_HYBRID,
5843 }, {
5844 .vendor = PCI_VENDOR_ID_PHILIPS,
Linus Torvalds1da177e2005-04-16 15:20:36 -07005845 .device = PCI_DEVICE_ID_PHILIPS_SAA7130,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07005846 .subvendor = 0x1461, /* Avermedia Technologies Inc */
5847 .subdevice = 0x2115,
Linus Torvalds1da177e2005-04-16 15:20:36 -07005848 .driver_data = SAA7134_BOARD_AVERMEDIA_STUDIO_305,
5849 },{
5850 .vendor = PCI_VENDOR_ID_PHILIPS,
5851 .device = PCI_DEVICE_ID_PHILIPS_SAA7130,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07005852 .subvendor = 0x1461, /* Avermedia Technologies Inc */
Vasiliy Temnikov5a5e1da2009-08-26 22:10:55 -03005853 .subdevice = 0xa115,
5854 .driver_data = SAA7134_BOARD_AVERMEDIA_STUDIO_505,
5855 }, {
5856 .vendor = PCI_VENDOR_ID_PHILIPS,
5857 .device = PCI_DEVICE_ID_PHILIPS_SAA7130,
5858 .subvendor = 0x1461, /* Avermedia Technologies Inc */
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07005859 .subdevice = 0x2108,
Linus Torvalds1da177e2005-04-16 15:20:36 -07005860 .driver_data = SAA7134_BOARD_AVERMEDIA_305,
5861 },{
5862 .vendor = PCI_VENDOR_ID_PHILIPS,
5863 .device = PCI_DEVICE_ID_PHILIPS_SAA7130,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07005864 .subvendor = 0x1461, /* Avermedia Technologies Inc */
5865 .subdevice = 0x10ff,
Linus Torvalds1da177e2005-04-16 15:20:36 -07005866 .driver_data = SAA7134_BOARD_AVERMEDIA_DVD_EZMAKER,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07005867 },{
Linus Torvalds1da177e2005-04-16 15:20:36 -07005868 /* AVerMedia CardBus */
5869 .vendor = PCI_VENDOR_ID_PHILIPS,
5870 .device = PCI_DEVICE_ID_PHILIPS_SAA7134,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07005871 .subvendor = 0x1461, /* Avermedia Technologies Inc */
5872 .subdevice = 0xd6ee,
Linus Torvalds1da177e2005-04-16 15:20:36 -07005873 .driver_data = SAA7134_BOARD_AVERMEDIA_CARDBUS,
5874 },{
Oldřich Jedličkad46de9d2009-04-14 15:47:17 -03005875 /* AVerMedia CardBus */
5876 .vendor = PCI_VENDOR_ID_PHILIPS,
5877 .device = PCI_DEVICE_ID_PHILIPS_SAA7134,
5878 .subvendor = 0x1461, /* Avermedia Technologies Inc */
5879 .subdevice = 0xb7e9,
5880 .driver_data = SAA7134_BOARD_AVERMEDIA_CARDBUS_501,
5881 }, {
Linus Torvalds1da177e2005-04-16 15:20:36 -07005882 /* TransGear 3000TV */
5883 .vendor = PCI_VENDOR_ID_PHILIPS,
5884 .device = PCI_DEVICE_ID_PHILIPS_SAA7130,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07005885 .subvendor = 0x1461, /* Avermedia Technologies Inc */
5886 .subdevice = 0x050c,
Linus Torvalds1da177e2005-04-16 15:20:36 -07005887 .driver_data = SAA7134_BOARD_TG3000TV,
5888 },{
Linus Torvalds1da177e2005-04-16 15:20:36 -07005889 .vendor = PCI_VENDOR_ID_PHILIPS,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07005890 .device = PCI_DEVICE_ID_PHILIPS_SAA7134,
5891 .subvendor = 0x11bd,
5892 .subdevice = 0x002b,
5893 .driver_data = SAA7134_BOARD_PINNACLE_PCTV_STEREO,
5894 },{
5895 .vendor = PCI_VENDOR_ID_PHILIPS,
5896 .device = PCI_DEVICE_ID_PHILIPS_SAA7134,
5897 .subvendor = 0x11bd,
5898 .subdevice = 0x002d,
5899 .driver_data = SAA7134_BOARD_PINNACLE_300I_DVBT_PAL,
5900 },{
5901 .vendor = PCI_VENDOR_ID_PHILIPS,
5902 .device = PCI_DEVICE_ID_PHILIPS_SAA7134,
5903 .subvendor = 0x1019,
5904 .subdevice = 0x4cb4,
5905 .driver_data = SAA7134_BOARD_ECS_TVP3XP,
5906 },{
5907 .vendor = PCI_VENDOR_ID_PHILIPS,
5908 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
5909 .subvendor = 0x1019,
5910 .subdevice = 0x4cb5,
5911 .driver_data = SAA7134_BOARD_ECS_TVP3XP_4CB5,
5912 },{
5913 .vendor = PCI_VENDOR_ID_PHILIPS,
Simon Farnsworthb39423a2007-05-01 10:01:20 -03005914 .device = PCI_DEVICE_ID_PHILIPS_SAA7134,
5915 .subvendor = 0x1019,
5916 .subdevice = 0x4cb6,
5917 .driver_data = SAA7134_BOARD_ECS_TVP3XP_4CB6,
5918 },{
5919 .vendor = PCI_VENDOR_ID_PHILIPS,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07005920 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
5921 .subvendor = 0x12ab,
5922 .subdevice = 0x0800,
5923 .driver_data = SAA7134_BOARD_UPMOST_PURPLE_TV,
Linus Torvalds1da177e2005-04-16 15:20:36 -07005924 },{
5925 .vendor = PCI_VENDOR_ID_PHILIPS,
5926 .device = PCI_DEVICE_ID_PHILIPS_SAA7130,
Michael Krufky7df64e82005-11-08 21:36:16 -08005927 .subvendor = 0x153b,
Linus Torvalds1da177e2005-04-16 15:20:36 -07005928 .subdevice = 0x1152,
5929 .driver_data = SAA7134_BOARD_CINERGY200,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07005930 },{
Linus Torvalds1da177e2005-04-16 15:20:36 -07005931 .vendor = PCI_VENDOR_ID_PHILIPS,
5932 .device = PCI_DEVICE_ID_PHILIPS_SAA7130,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07005933 .subvendor = 0x185b,
5934 .subdevice = 0xc100,
Linus Torvalds1da177e2005-04-16 15:20:36 -07005935 .driver_data = SAA7134_BOARD_VIDEOMATE_TV_PVR,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07005936 },{
Linus Torvalds1da177e2005-04-16 15:20:36 -07005937 .vendor = PCI_VENDOR_ID_PHILIPS,
Linus Torvalds1da177e2005-04-16 15:20:36 -07005938 .device = PCI_DEVICE_ID_PHILIPS_SAA7134,
5939 .subvendor = 0x1461, /* Avermedia Technologies Inc */
5940 .subdevice = 0x9715,
Mauro Carvalho Chehabac19ecc2005-06-23 22:05:09 -07005941 .driver_data = SAA7134_BOARD_AVERMEDIA_STUDIO_307,
5942 },{
5943 .vendor = PCI_VENDOR_ID_PHILIPS,
5944 .device = PCI_DEVICE_ID_PHILIPS_SAA7134,
5945 .subvendor = 0x1461, /* Avermedia Technologies Inc */
5946 .subdevice = 0xa70a,
Linus Torvalds1da177e2005-04-16 15:20:36 -07005947 .driver_data = SAA7134_BOARD_AVERMEDIA_307,
5948 },{
5949 .vendor = PCI_VENDOR_ID_PHILIPS,
5950 .device = PCI_DEVICE_ID_PHILIPS_SAA7134,
5951 .subvendor = 0x185b,
5952 .subdevice = 0xc200,
5953 .driver_data = SAA7134_BOARD_VIDEOMATE_GOLD_PLUS,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07005954 },{
Linus Torvalds1da177e2005-04-16 15:20:36 -07005955 .vendor = PCI_VENDOR_ID_PHILIPS,
5956 .device = PCI_DEVICE_ID_PHILIPS_SAA7134,
5957 .subvendor = 0x1540,
5958 .subdevice = 0x9524,
5959 .driver_data = SAA7134_BOARD_PROVIDEO_PV952,
5960
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07005961 },{
Linus Torvalds1da177e2005-04-16 15:20:36 -07005962 .vendor = PCI_VENDOR_ID_PHILIPS,
5963 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
5964 .subvendor = 0x5168,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07005965 .subdevice = 0x0502, /* Cardbus version */
Peter Missel10b7a902006-01-23 17:11:06 -02005966 .driver_data = SAA7134_BOARD_FLYDVBT_DUO_CARDBUS,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07005967 },{
5968 .vendor = PCI_VENDOR_ID_PHILIPS,
5969 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
5970 .subvendor = 0x5168,
5971 .subdevice = 0x0306, /* PCI version */
Linus Torvalds1da177e2005-04-16 15:20:36 -07005972 .driver_data = SAA7134_BOARD_FLYDVBTDUO,
Mauro Carvalho Chehabac19ecc2005-06-23 22:05:09 -07005973 },{
5974 .vendor = PCI_VENDOR_ID_PHILIPS,
5975 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
5976 .subvendor = 0x1461, /* Avermedia Technologies Inc */
5977 .subdevice = 0xf31f,
5978 .driver_data = SAA7134_BOARD_AVERMEDIA_GO_007_FM,
5979
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07005980 },{
Mauro Carvalho Chehabac19ecc2005-06-23 22:05:09 -07005981 .vendor = PCI_VENDOR_ID_PHILIPS,
Mauro Carvalho Chehab36f6bb92008-06-26 17:03:00 -03005982 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
5983 .subvendor = 0x1461, /* Avermedia Technologies Inc */
5984 .subdevice = 0xf11d,
5985 .driver_data = SAA7134_BOARD_AVERMEDIA_M135A,
5986 }, {
5987 .vendor = PCI_VENDOR_ID_PHILIPS,
Herton Ronaldo Krzesinski9e1d9e72010-05-08 02:23:37 -03005988 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
5989 .subvendor = 0x1461, /* Avermedia Technologies Inc */
5990 .subdevice = 0x4155,
5991 .driver_data = SAA7134_BOARD_AVERMEDIA_M733A,
5992 }, {
5993 .vendor = PCI_VENDOR_ID_PHILIPS,
5994 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
5995 .subvendor = 0x1461, /* Avermedia Technologies Inc */
5996 .subdevice = 0x4255,
5997 .driver_data = SAA7134_BOARD_AVERMEDIA_M733A,
5998 }, {
5999 .vendor = PCI_VENDOR_ID_PHILIPS,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07006000 .device = PCI_DEVICE_ID_PHILIPS_SAA7130,
6001 .subvendor = PCI_VENDOR_ID_PHILIPS,
6002 .subdevice = 0x2004,
6003 .driver_data = SAA7134_BOARD_PHILIPS_TOUGH,
6004 },{
6005 .vendor = PCI_VENDOR_ID_PHILIPS,
6006 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
Mauro Carvalho Chehabac19ecc2005-06-23 22:05:09 -07006007 .subvendor = 0x1421,
6008 .subdevice = 0x0350, /* PCI version */
6009 .driver_data = SAA7134_BOARD_ADS_INSTANT_TV,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07006010 },{
Mauro Carvalho Chehabac19ecc2005-06-23 22:05:09 -07006011 .vendor = PCI_VENDOR_ID_PHILIPS,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07006012 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
Mauro Carvalho Chehabac19ecc2005-06-23 22:05:09 -07006013 .subvendor = 0x1421,
Ricardo Cerqueira41d70c22006-01-09 15:25:34 -02006014 .subdevice = 0x0351, /* PCI version, new revision */
6015 .driver_data = SAA7134_BOARD_ADS_INSTANT_TV,
6016 },{
6017 .vendor = PCI_VENDOR_ID_PHILIPS,
6018 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
6019 .subvendor = 0x1421,
Mauro Carvalho Chehabac19ecc2005-06-23 22:05:09 -07006020 .subdevice = 0x0370, /* cardbus version */
6021 .driver_data = SAA7134_BOARD_ADS_INSTANT_TV,
Hartmut Hackmannd4b0aba2005-11-08 21:38:44 -08006022 },{
6023 .vendor = PCI_VENDOR_ID_PHILIPS,
6024 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
6025 .subvendor = 0x1421,
6026 .subdevice = 0x1370, /* cardbus version */
6027 .driver_data = SAA7134_BOARD_ADS_INSTANT_TV,
Linus Torvalds1da177e2005-04-16 15:20:36 -07006028
Peter Missel10b7a902006-01-23 17:11:06 -02006029 },{
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07006030 .vendor = PCI_VENDOR_ID_PHILIPS,
6031 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
Peter Missel10b7a902006-01-23 17:11:06 -02006032 .subvendor = 0x4e42, /* Typhoon */
6033 .subdevice = 0x0502, /* LifeView LR502 OEM */
6034 .driver_data = SAA7134_BOARD_FLYDVBT_DUO_CARDBUS,
Mauro Carvalho Chehab2f180712005-09-09 13:03:46 -07006035 },{
6036 .vendor = PCI_VENDOR_ID_PHILIPS,
6037 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
6038 .subvendor = 0x1043,
6039 .subdevice = 0x0210, /* mini pci NTSC version */
6040 .driver_data = SAA7134_BOARD_FLYTV_DIGIMATRIX,
6041 },{
6042 .vendor = PCI_VENDOR_ID_PHILIPS,
6043 .device = PCI_DEVICE_ID_PHILIPS_SAA7134,
6044 .subvendor = 0x1043,
6045 .subdevice = 0x0210, /* mini pci PAL/SECAM version */
Michael Krufky5d5c9902005-11-08 21:38:08 -08006046 .driver_data = SAA7134_BOARD_ASUSTEK_DIGIMATRIX_TV,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07006047
6048 },{
Nickolay V. Shmyreva8ff4172005-11-08 21:36:16 -08006049 .vendor = PCI_VENDOR_ID_PHILIPS,
6050 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
6051 .subvendor = 0x0000, /* It shouldn't break anything, since subdevice id seems unique */
6052 .subdevice = 0x4091,
6053 .driver_data = SAA7134_BOARD_BEHOLD_409FM,
Mauro Carvalho Chehab4ac97912005-11-08 21:37:43 -08006054 },{
6055 .vendor = PCI_VENDOR_ID_PHILIPS,
6056 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
6057 .subvendor = 0x5456, /* GoTView */
6058 .subdevice = 0x7135,
6059 .driver_data = SAA7134_BOARD_GOTVIEW_7135,
6060 },{
Hartmut Hackmann2cf36ac2005-11-08 21:36:32 -08006061 .vendor = PCI_VENDOR_ID_PHILIPS,
6062 .device = PCI_DEVICE_ID_PHILIPS_SAA7134,
6063 .subvendor = PCI_VENDOR_ID_PHILIPS,
6064 .subdevice = 0x2004,
6065 .driver_data = SAA7134_BOARD_PHILIPS_EUROPA,
Mauro Carvalho Chehab4ac97912005-11-08 21:37:43 -08006066 },{
Hartmut Hackmann2cf36ac2005-11-08 21:36:32 -08006067 .vendor = PCI_VENDOR_ID_PHILIPS,
6068 .device = PCI_DEVICE_ID_PHILIPS_SAA7134,
6069 .subvendor = 0x185b,
6070 .subdevice = 0xc900,
6071 .driver_data = SAA7134_BOARD_VIDEOMATE_DVBT_300,
Mauro Carvalho Chehab4ac97912005-11-08 21:37:43 -08006072 },{
Hartmut Hackmann2cf36ac2005-11-08 21:36:32 -08006073 .vendor = PCI_VENDOR_ID_PHILIPS,
6074 .device = PCI_DEVICE_ID_PHILIPS_SAA7130,
6075 .subvendor = 0x185b,
6076 .subdevice = 0xc901,
6077 .driver_data = SAA7134_BOARD_VIDEOMATE_DVBT_200,
6078 },{
Mauro Carvalho Chehab4ac97912005-11-08 21:37:43 -08006079 .vendor = PCI_VENDOR_ID_PHILIPS,
6080 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
6081 .subvendor = 0x1435,
6082 .subdevice = 0x7350,
6083 .driver_data = SAA7134_BOARD_RTD_VFG7350,
Nickolay V. Shmyrevbb881f12005-11-08 21:36:35 -08006084 },{
Mauro Carvalho Chehab4ac97912005-11-08 21:37:43 -08006085 .vendor = PCI_VENDOR_ID_PHILIPS,
6086 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
6087 .subvendor = 0x1435,
6088 .subdevice = 0x7330,
6089 .driver_data = SAA7134_BOARD_RTD_VFG7330,
Pieter Palmerscf1c5d12005-11-08 21:37:40 -08006090 },{
Mauro Carvalho Chehab4ac97912005-11-08 21:37:43 -08006091 .vendor = PCI_VENDOR_ID_PHILIPS,
6092 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
6093 .subvendor = 0x1461,
6094 .subdevice = 0x1044,
6095 .driver_data = SAA7134_BOARD_AVERMEDIA_AVERTVHD_A180,
6096 },{
Pieter Palmerscf1c5d12005-11-08 21:37:40 -08006097 .vendor = PCI_VENDOR_ID_PHILIPS,
6098 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
6099 .subvendor = 0x1131,
6100 .subdevice = 0x4ee9,
6101 .driver_data = SAA7134_BOARD_MONSTERTV_MOBILE,
Mauro Carvalho Chehab4ac97912005-11-08 21:37:43 -08006102 },{
Ricardo Cerqueirac2f6f9d2005-11-08 21:37:51 -08006103 .vendor = PCI_VENDOR_ID_PHILIPS,
6104 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
6105 .subvendor = 0x11bd,
6106 .subdevice = 0x002e,
6107 .driver_data = SAA7134_BOARD_PINNACLE_PCTV_110i,
6108 },{
Hermann Pitton28f02242005-11-08 21:38:03 -08006109 .vendor = PCI_VENDOR_ID_PHILIPS,
6110 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
6111 .subvendor = 0x1043,
6112 .subdevice = 0x4862,
6113 .driver_data = SAA7134_BOARD_ASUSTeK_P7131_DUAL,
Pavel Mihaylovc3d93192005-11-08 21:38:43 -08006114 },{
Hartmut Hackmann90e9df72005-11-08 21:38:42 -08006115 .vendor = PCI_VENDOR_ID_PHILIPS,
6116 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
6117 .subvendor = PCI_VENDOR_ID_PHILIPS,
6118 .subdevice = 0x2018,
6119 .driver_data = SAA7134_BOARD_PHILIPS_TIGER,
Hermann Pitton28f02242005-11-08 21:38:03 -08006120 },{
Ricardo Cerqueira80d2ad92005-11-13 16:08:01 -08006121 .vendor = PCI_VENDOR_ID_PHILIPS,
6122 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
6123 .subvendor = 0x1462,
Hermann Pittonb6667e52008-01-12 14:43:48 -03006124 .subdevice = 0x6231, /* tda8275a, ks003 IR */
6125 .driver_data = SAA7134_BOARD_MSI_TVATANYWHERE_PLUS,
6126 },{
6127 .vendor = PCI_VENDOR_ID_PHILIPS,
6128 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
6129 .subvendor = 0x1462,
6130 .subdevice = 0x8624, /* tda8275, ks003 IR */
Ricardo Cerqueira80d2ad92005-11-13 16:08:01 -08006131 .driver_data = SAA7134_BOARD_MSI_TVATANYWHERE_PLUS,
6132 },{
Jörg Schummerf639c9b2006-01-09 15:25:01 -02006133 .vendor = PCI_VENDOR_ID_PHILIPS,
6134 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
6135 .subvendor = 0x153b,
6136 .subdevice = 0x1160,
6137 .driver_data = SAA7134_BOARD_CINERGY250PCI,
6138 },{
Peter Missel4aa6ba52006-01-09 15:32:45 -02006139 .vendor = PCI_VENDOR_ID_PHILIPS,
6140 .device = PCI_DEVICE_ID_PHILIPS_SAA7133, /* SAA 7131E */
6141 .subvendor = 0x5168,
6142 .subdevice = 0x0319,
6143 .driver_data = SAA7134_BOARD_FLYDVB_TRIO,
6144 },{
Jose Alberto Regueroa78d0bf2006-02-07 06:25:14 -02006145 .vendor = PCI_VENDOR_ID_PHILIPS,
Hartmut Hackmann1e9bfb92006-08-07 14:03:32 -03006146 .device = PCI_DEVICE_ID_PHILIPS_SAA7134,
Jose Alberto Regueroa78d0bf2006-02-07 06:25:14 -02006147 .subvendor = 0x1461,
6148 .subdevice = 0x2c05,
6149 .driver_data = SAA7134_BOARD_AVERMEDIA_777,
6150 },{
Giampiero Giancipoli3d8466e2006-02-07 06:49:09 -02006151 .vendor = PCI_VENDOR_ID_PHILIPS,
6152 .device = PCI_DEVICE_ID_PHILIPS_SAA7134,
6153 .subvendor = 0x5168,
6154 .subdevice = 0x0301,
6155 .driver_data = SAA7134_BOARD_FLYDVBT_LR301,
6156 },{
Hartmut Hackmanndf42eaf2006-02-07 06:49:10 -02006157 .vendor = PCI_VENDOR_ID_PHILIPS,
6158 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
6159 .subvendor = 0x0331,
6160 .subdevice = 0x1421,
6161 .driver_data = SAA7134_BOARD_ADS_DUO_CARDBUS_PTV331,
6162 },{
Peter Hartshorn3dfb7292006-02-07 06:49:13 -02006163 .vendor = PCI_VENDOR_ID_PHILIPS,
6164 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
6165 .subvendor = 0x17de,
6166 .subdevice = 0x7201,
6167 .driver_data = SAA7134_BOARD_TEVION_DVBT_220RF,
6168 },{
Andrew Burri3e1410a2006-02-27 00:08:23 -03006169 .vendor = PCI_VENDOR_ID_PHILIPS,
Simon Farnsworthb39423a2007-05-01 10:01:20 -03006170 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
6171 .subvendor = 0x17de,
6172 .subdevice = 0x7250,
6173 .driver_data = SAA7134_BOARD_KWORLD_DVBT_210,
6174 },{
6175 .vendor = PCI_VENDOR_ID_PHILIPS,
Andrew Burri3e1410a2006-02-27 00:08:23 -03006176 .device = PCI_DEVICE_ID_PHILIPS_SAA7133, /* SAA7135HL */
6177 .subvendor = 0x17de,
6178 .subdevice = 0x7350,
6179 .driver_data = SAA7134_BOARD_KWORLD_ATSC110,
6180 },{
Rickard Osser68593af2006-03-11 17:14:12 -03006181 .vendor = PCI_VENDOR_ID_PHILIPS,
Eric Sandeen0ac3a5b2007-10-08 16:13:02 -03006182 .device = PCI_DEVICE_ID_PHILIPS_SAA7133, /* SAA7135HL */
6183 .subvendor = 0x17de,
6184 .subdevice = 0x7352,
6185 .driver_data = SAA7134_BOARD_KWORLD_ATSC110, /* ATSC 115 */
6186 },{
6187 .vendor = PCI_VENDOR_ID_PHILIPS,
Rickard Osser68593af2006-03-11 17:14:12 -03006188 .device = PCI_DEVICE_ID_PHILIPS_SAA7134,
6189 .subvendor = 0x1461,
6190 .subdevice = 0x7360,
6191 .driver_data = SAA7134_BOARD_AVERMEDIA_A169_B,
6192 },{
6193 .vendor = PCI_VENDOR_ID_PHILIPS,
6194 .device = PCI_DEVICE_ID_PHILIPS_SAA7134,
6195 .subvendor = 0x1461,
6196 .subdevice = 0x6360,
6197 .driver_data = SAA7134_BOARD_AVERMEDIA_A169_B1,
6198 },{
Michael Krufkyba3a5a82006-03-14 19:02:12 -03006199 .vendor = PCI_VENDOR_ID_PHILIPS,
6200 .device = PCI_DEVICE_ID_PHILIPS_SAA7134,
6201 .subvendor = 0x16be,
6202 .subdevice = 0x0005,
6203 .driver_data = SAA7134_BOARD_MD7134_BRIDGE_2,
6204 },{
Igor M. Liplianine2ac28f2006-08-08 09:10:10 -03006205 .vendor = PCI_VENDOR_ID_PHILIPS,
6206 .device = PCI_DEVICE_ID_PHILIPS_SAA7134,
6207 .subvendor = 0x5168,
6208 .subdevice = 0x0300,
6209 .driver_data = SAA7134_BOARD_FLYDVBS_LR300,
6210 },{
6211 .vendor = PCI_VENDOR_ID_PHILIPS,
6212 .device = PCI_DEVICE_ID_PHILIPS_SAA7134,
6213 .subvendor = 0x4e42,
6214 .subdevice = 0x0300,/* LR300 */
6215 .driver_data = SAA7134_BOARD_FLYDVBS_LR300,
6216 },{
Hartmut Hackmann42e6b3b2006-03-27 19:04:48 -03006217 .vendor = PCI_VENDOR_ID_PHILIPS,
6218 .device = PCI_DEVICE_ID_PHILIPS_SAA7134,
6219 .subvendor = 0x1489,
6220 .subdevice = 0x0301,
6221 .driver_data = SAA7134_BOARD_FLYDVBT_LR301,
6222 },{
6223 .vendor = PCI_VENDOR_ID_PHILIPS,
6224 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
6225 .subvendor = 0x5168, /* Animation Technologies (LifeView) */
6226 .subdevice = 0x0304,
6227 .driver_data = SAA7134_BOARD_FLYTVPLATINUM_FM,
6228 },{
Hartmut Hackmannd95b8942006-03-27 19:39:30 -03006229 .vendor = PCI_VENDOR_ID_PHILIPS,
6230 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
6231 .subvendor = 0x5168,
6232 .subdevice = 0x3306,
6233 .driver_data = SAA7134_BOARD_FLYDVBT_HYBRID_CARDBUS,
6234 },{
6235 .vendor = PCI_VENDOR_ID_PHILIPS,
6236 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
6237 .subvendor = 0x5168,
6238 .subdevice = 0x3502, /* whats the difference to 0x3306 ?*/
6239 .driver_data = SAA7134_BOARD_FLYDVBT_HYBRID_CARDBUS,
6240 },{
Hartmut Hackmann5eda2272006-08-07 14:03:32 -03006241 .vendor = PCI_VENDOR_ID_PHILIPS,
6242 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
Hermann Pitton29e4e052008-01-20 19:49:51 -03006243 .subvendor = 0x5168,
6244 .subdevice = 0x3307, /* FlyDVB-T Hybrid Mini PCI */
6245 .driver_data = SAA7134_BOARD_FLYDVBT_HYBRID_CARDBUS,
6246 }, {
6247 .vendor = PCI_VENDOR_ID_PHILIPS,
6248 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
Hartmut Hackmann5eda2272006-08-07 14:03:32 -03006249 .subvendor = 0x16be,
6250 .subdevice = 0x0007,
6251 .driver_data = SAA7134_BOARD_MEDION_MD8800_QUADRO,
6252 },{
6253 .vendor = PCI_VENDOR_ID_PHILIPS,
6254 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
6255 .subvendor = 0x16be,
6256 .subdevice = 0x0008,
6257 .driver_data = SAA7134_BOARD_MEDION_MD8800_QUADRO,
6258 },{
Hartmut Hackmann1e9bfb92006-08-07 14:03:32 -03006259 .vendor = PCI_VENDOR_ID_PHILIPS,
6260 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
Hermann Pitton728b92a2008-01-20 19:42:01 -03006261 .subvendor = 0x16be,
6262 .subdevice = 0x000d, /* triple CTX948_V1.1.1 */
6263 .driver_data = SAA7134_BOARD_MEDION_MD8800_QUADRO,
6264 }, {
6265 .vendor = PCI_VENDOR_ID_PHILIPS,
6266 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
Hartmut Hackmann1e9bfb92006-08-07 14:03:32 -03006267 .subvendor = 0x1461,
6268 .subdevice = 0x2c05,
6269 .driver_data = SAA7134_BOARD_AVERMEDIA_777,
6270 },{
Hartmut Hackmann2c591942006-08-07 14:03:32 -03006271 .vendor = PCI_VENDOR_ID_PHILIPS,
6272 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
6273 .subvendor = 0x1489,
6274 .subdevice = 0x0502, /* Cardbus version */
6275 .driver_data = SAA7134_BOARD_FLYDVBT_DUO_CARDBUS,
6276 },{
Michal Majchrowiczb04c1ba2006-09-13 16:42:42 -03006277 .vendor = PCI_VENDOR_ID_PHILIPS,
6278 .device = PCI_DEVICE_ID_PHILIPS_SAA7130,
6279 .subvendor = 0x0919, /* Philips Proteus PRO 2309 */
6280 .subdevice = 0x2003,
6281 .driver_data = SAA7134_BOARD_PROTEUS_2309,
6282 },{
Petr Baudis515c2082006-09-26 16:53:53 -03006283 .vendor = PCI_VENDOR_ID_PHILIPS,
6284 .device = PCI_DEVICE_ID_PHILIPS_SAA7134,
6285 .subvendor = 0x1461,
6286 .subdevice = 0x2c00,
6287 .driver_data = SAA7134_BOARD_AVERMEDIA_A16AR,
6288 },{
Hartmut Hackmanncf146ca2006-10-02 20:49:24 -03006289 .vendor = PCI_VENDOR_ID_PHILIPS,
6290 .device = PCI_DEVICE_ID_PHILIPS_SAA7134,
6291 .subvendor = 0x1043,
6292 .subdevice = 0x4860,
6293 .driver_data = SAA7134_BOARD_ASUS_EUROPA2_HYBRID,
6294 },{
Hartmut Hackmann587d2fd2006-10-06 19:13:50 -03006295 .vendor = PCI_VENDOR_ID_PHILIPS,
6296 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
6297 .subvendor = 0x11bd,
6298 .subdevice = 0x002f,
6299 .driver_data = SAA7134_BOARD_PINNACLE_PCTV_310i,
6300 },{
Mikhail Fedotov3ac706d2006-10-06 20:23:47 -03006301 .vendor = PCI_VENDOR_ID_PHILIPS,
6302 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
6303 .subvendor = 0x1461, /* Avermedia Technologies Inc */
6304 .subdevice = 0x9715,
6305 .driver_data = SAA7134_BOARD_AVERMEDIA_STUDIO_507,
6306 },{
Hartmut Hackmann83646812006-10-12 20:38:51 -03006307 .vendor = PCI_VENDOR_ID_PHILIPS,
Andy Shevchenkodf0dbbe2009-04-08 14:01:19 -03006308 .device = PCI_DEVICE_ID_PHILIPS_SAA7134,
6309 .subvendor = 0x1461, /* Avermedia Technologies Inc */
6310 .subdevice = 0xa11b,
6311 .driver_data = SAA7134_BOARD_AVERMEDIA_STUDIO_507UA,
6312 }, {
6313 .vendor = PCI_VENDOR_ID_PHILIPS,
Hartmut Hackmann83646812006-10-12 20:38:51 -03006314 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
6315 .subvendor = 0x1043,
6316 .subdevice = 0x4876,
Hartmut Hackmannf3eec0c02007-03-14 20:33:55 -03006317 .driver_data = SAA7134_BOARD_ASUSTeK_P7131_HYBRID_LNA,
Hartmut Hackmann83646812006-10-12 20:38:51 -03006318 },{
Thomas Gentyc6e53da2006-11-05 14:17:30 -03006319 .vendor = PCI_VENDOR_ID_PHILIPS,
6320 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
6321 .subvendor = 0x0070,
Michael Krufkyddf12222007-11-15 10:01:11 -03006322 .subdevice = 0x6700,
6323 .driver_data = SAA7134_BOARD_HAUPPAUGE_HVR1110,
6324 },{
6325 .vendor = PCI_VENDOR_ID_PHILIPS,
6326 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
6327 .subvendor = 0x0070,
Thomas Gentyc6e53da2006-11-05 14:17:30 -03006328 .subdevice = 0x6701,
6329 .driver_data = SAA7134_BOARD_HAUPPAUGE_HVR1110,
6330 },{
Hartmut Hackmann550a9a52006-11-15 21:31:54 -03006331 .vendor = PCI_VENDOR_ID_PHILIPS,
6332 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
Michael Krufkyddf12222007-11-15 10:01:11 -03006333 .subvendor = 0x0070,
6334 .subdevice = 0x6702,
6335 .driver_data = SAA7134_BOARD_HAUPPAUGE_HVR1110,
6336 },{
6337 .vendor = PCI_VENDOR_ID_PHILIPS,
6338 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
6339 .subvendor = 0x0070,
6340 .subdevice = 0x6703,
6341 .driver_data = SAA7134_BOARD_HAUPPAUGE_HVR1110,
6342 },{
6343 .vendor = PCI_VENDOR_ID_PHILIPS,
6344 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
6345 .subvendor = 0x0070,
6346 .subdevice = 0x6704,
6347 .driver_data = SAA7134_BOARD_HAUPPAUGE_HVR1110,
6348 },{
6349 .vendor = PCI_VENDOR_ID_PHILIPS,
6350 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
6351 .subvendor = 0x0070,
6352 .subdevice = 0x6705,
6353 .driver_data = SAA7134_BOARD_HAUPPAUGE_HVR1110,
6354 },{
6355 .vendor = PCI_VENDOR_ID_PHILIPS,
6356 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
Michael Krufkyf9996c92009-02-28 17:45:17 -03006357 .subvendor = 0x0070,
6358 .subdevice = 0x6706,
Michael Krufkyb5f05062009-08-03 16:51:33 -03006359 .driver_data = SAA7134_BOARD_HAUPPAUGE_HVR1150,
Michael Krufkyf9996c92009-02-28 17:45:17 -03006360 },{
6361 .vendor = PCI_VENDOR_ID_PHILIPS,
6362 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
6363 .subvendor = 0x0070,
6364 .subdevice = 0x6707,
Michael Krufky0e316ec2009-08-03 16:51:33 -03006365 .driver_data = SAA7134_BOARD_HAUPPAUGE_HVR1120,
Michael Krufkyf9996c92009-02-28 17:45:17 -03006366 },{
6367 .vendor = PCI_VENDOR_ID_PHILIPS,
6368 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
6369 .subvendor = 0x0070,
6370 .subdevice = 0x6708,
Michael Krufkyb5f05062009-08-03 16:51:33 -03006371 .driver_data = SAA7134_BOARD_HAUPPAUGE_HVR1150,
Michael Krufkyf9996c92009-02-28 17:45:17 -03006372 },{
6373 .vendor = PCI_VENDOR_ID_PHILIPS,
6374 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
6375 .subvendor = 0x0070,
6376 .subdevice = 0x6709,
Michael Krufky0e316ec2009-08-03 16:51:33 -03006377 .driver_data = SAA7134_BOARD_HAUPPAUGE_HVR1120,
Michael Krufkyf9996c92009-02-28 17:45:17 -03006378 },{
6379 .vendor = PCI_VENDOR_ID_PHILIPS,
6380 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
6381 .subvendor = 0x0070,
6382 .subdevice = 0x670a,
Michael Krufky0e316ec2009-08-03 16:51:33 -03006383 .driver_data = SAA7134_BOARD_HAUPPAUGE_HVR1120,
Michael Krufkyf9996c92009-02-28 17:45:17 -03006384 },{
6385 .vendor = PCI_VENDOR_ID_PHILIPS,
6386 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
Hartmut Hackmann550a9a52006-11-15 21:31:54 -03006387 .subvendor = 0x153b,
6388 .subdevice = 0x1172,
6389 .driver_data = SAA7134_BOARD_CINERGY_HT_PCMCIA,
6390 },{
Steven Walterd1158f42006-12-20 09:29:09 -03006391 .vendor = PCI_VENDOR_ID_PHILIPS,
6392 .device = PCI_DEVICE_ID_PHILIPS_SAA7130,
6393 .subvendor = PCI_VENDOR_ID_PHILIPS,
6394 .subdevice = 0x2342,
6395 .driver_data = SAA7134_BOARD_ENCORE_ENLTV,
6396 },{
Juan Pablo Sormanic36c4592006-12-27 12:46:36 -03006397 .vendor = PCI_VENDOR_ID_PHILIPS,
6398 .device = PCI_DEVICE_ID_PHILIPS_SAA7130,
6399 .subvendor = 0x1131,
6400 .subdevice = 0x2341,
6401 .driver_data = SAA7134_BOARD_ENCORE_ENLTV,
6402 },{
6403 .vendor = PCI_VENDOR_ID_PHILIPS,
6404 .device = PCI_DEVICE_ID_PHILIPS_SAA7130,
6405 .subvendor = 0x3016,
6406 .subdevice = 0x2344,
6407 .driver_data = SAA7134_BOARD_ENCORE_ENLTV,
6408 },{
6409 .vendor = PCI_VENDOR_ID_PHILIPS,
6410 .device = PCI_DEVICE_ID_PHILIPS_SAA7130,
6411 .subvendor = 0x1131,
6412 .subdevice = 0x230f,
6413 .driver_data = SAA7134_BOARD_ENCORE_ENLTV_FM,
6414 },{
Michael Krufky9de271e2007-01-16 18:36:40 -03006415 .vendor = PCI_VENDOR_ID_PHILIPS,
Mauro Carvalho Chehabbf1ece62008-06-26 17:03:00 -03006416 .device = PCI_DEVICE_ID_PHILIPS_SAA7130,
6417 .subvendor = 0x1a7f,
6418 .subdevice = 0x2008,
6419 .driver_data = SAA7134_BOARD_ENCORE_ENLTV_FM53,
6420 }, {
6421 .vendor = PCI_VENDOR_ID_PHILIPS,
Mauro Carvalho Chehabd642f2f2011-01-19 16:25:17 -02006422 .device = PCI_DEVICE_ID_PHILIPS_SAA7134,
6423 .subvendor = 0x1a7f,
6424 .subdevice = 0x2108,
6425 .driver_data = SAA7134_BOARD_ENCORE_ENLTV_FM3,
6426 }, {
6427 .vendor = PCI_VENDOR_ID_PHILIPS,
Michael Krufky9de271e2007-01-16 18:36:40 -03006428 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
6429 .subvendor = 0x153b,
6430 .subdevice = 0x1175,
6431 .driver_data = SAA7134_BOARD_CINERGY_HT_PCI,
6432 },{
Markus Rechbergere95d3172007-04-27 12:31:19 -03006433 .vendor = PCI_VENDOR_ID_PHILIPS,
6434 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
6435 .subvendor = 0x1461, /* Avermedia Technologies Inc */
6436 .subdevice = 0xf31e,
6437 .driver_data = SAA7134_BOARD_AVERMEDIA_M102,
6438 },{
Peter Misseldb483672007-04-27 12:31:20 -03006439 .vendor = PCI_VENDOR_ID_PHILIPS,
6440 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
6441 .subvendor = 0x4E42, /* MSI */
6442 .subdevice = 0x0306, /* TV@nywhere DUO */
6443 .driver_data = SAA7134_BOARD_FLYDVBTDUO,
6444 },{
Hartmut Hackmanne06cea42007-03-13 20:58:29 -03006445 .vendor = PCI_VENDOR_ID_PHILIPS,
6446 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
6447 .subvendor = 0x1043,
6448 .subdevice = 0x4871,
6449 .driver_data = SAA7134_BOARD_ASUS_P7131_4871,
6450 },{
6451 .vendor = PCI_VENDOR_ID_PHILIPS,
6452 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
6453 .subvendor = 0x1043,
Hermann Pitton028165a2008-10-04 21:37:36 -03006454 .subdevice = 0x4857, /* REV:1.00 */
6455 .driver_data = SAA7134_BOARD_ASUSTeK_TIGER,
Hartmut Hackmanne06cea42007-03-13 20:58:29 -03006456 },{
James T Klaas53958b32007-05-01 10:48:09 -03006457 .vendor = PCI_VENDOR_ID_PHILIPS,
6458 .device = PCI_DEVICE_ID_PHILIPS_SAA7134,
6459 .subvendor = 0x0919, /* SinoVideo PCI 2309 Proteus (7134) */
6460 .subdevice = 0x2003, /* OEM cardbus */
6461 .driver_data = SAA7134_BOARD_SABRENT_TV_PCB05,
6462 },{
Tony Wanaaccb822007-05-10 12:16:47 -03006463 .vendor = PCI_VENDOR_ID_PHILIPS,
6464 .device = PCI_DEVICE_ID_PHILIPS_SAA7130,
6465 .subvendor = PCI_VENDOR_ID_PHILIPS,
6466 .subdevice = 0x2304,
6467 .driver_data = SAA7134_BOARD_10MOONSTVMASTER3,
6468 },{
Edgar Simod90d9f52007-08-20 14:14:50 -03006469 .vendor = PCI_VENDOR_ID_PHILIPS,
6470 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
6471 .subvendor = 0x1461, /* Avermedia Technologies Inc */
6472 .subdevice = 0xf01d, /* AVerTV DVB-T Super 007 */
6473 .driver_data = SAA7134_BOARD_AVERMEDIA_SUPER_007,
6474 },{
Mauro Carvalho Chehab593f18c2007-10-07 02:17:09 -03006475 .vendor = PCI_VENDOR_ID_PHILIPS,
Andrey J. Melnikoff (TEMHOTA)e8018c92008-01-07 05:17:39 -03006476 .device = PCI_DEVICE_ID_PHILIPS_SAA7130,
Andrey J. Melnikoff (TEMHOTA)e8018c92008-01-07 05:17:39 -03006477 .subvendor = 0x0000,
6478 .subdevice = 0x4016,
6479 .driver_data = SAA7134_BOARD_BEHOLD_401,
6480 },{
6481 .vendor = PCI_VENDOR_ID_PHILIPS,
6482 .device = PCI_DEVICE_ID_PHILIPS_SAA7134,
Andrey J. Melnikoff (TEMHOTA)e8018c92008-01-07 05:17:39 -03006483 .subvendor = 0x0000,
6484 .subdevice = 0x4036,
6485 .driver_data = SAA7134_BOARD_BEHOLD_403,
6486 },{
6487 .vendor = PCI_VENDOR_ID_PHILIPS,
6488 .device = PCI_DEVICE_ID_PHILIPS_SAA7134,
6489 .subvendor = 0x0000,
6490 .subdevice = 0x4037,
6491 .driver_data = SAA7134_BOARD_BEHOLD_403FM,
6492 },{
6493 .vendor = PCI_VENDOR_ID_PHILIPS,
6494 .device = PCI_DEVICE_ID_PHILIPS_SAA7130,
6495 .subvendor = 0x0000,
6496 .subdevice = 0x4050,
6497 .driver_data = SAA7134_BOARD_BEHOLD_405,
6498 },{
6499 .vendor = PCI_VENDOR_ID_PHILIPS,
6500 .device = PCI_DEVICE_ID_PHILIPS_SAA7130,
6501 .subvendor = 0x0000,
6502 .subdevice = 0x4051,
6503 .driver_data = SAA7134_BOARD_BEHOLD_405FM,
6504 },{
6505 .vendor = PCI_VENDOR_ID_PHILIPS,
6506 .device = PCI_DEVICE_ID_PHILIPS_SAA7134,
6507 .subvendor = 0x0000,
6508 .subdevice = 0x4070,
6509 .driver_data = SAA7134_BOARD_BEHOLD_407,
6510 },{
6511 .vendor = PCI_VENDOR_ID_PHILIPS,
6512 .device = PCI_DEVICE_ID_PHILIPS_SAA7134,
6513 .subvendor = 0x0000,
6514 .subdevice = 0x4071,
6515 .driver_data = SAA7134_BOARD_BEHOLD_407FM,
6516 },{
6517 .vendor = PCI_VENDOR_ID_PHILIPS,
6518 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
6519 .subvendor = 0x0000,
6520 .subdevice = 0x4090,
6521 .driver_data = SAA7134_BOARD_BEHOLD_409,
6522 },{
6523 .vendor = PCI_VENDOR_ID_PHILIPS,
6524 .device = PCI_DEVICE_ID_PHILIPS_SAA7130,
6525 .subvendor = 0x0000,
Andrey J. Melnikoff (TEMHOTA)e8018c92008-01-07 05:17:39 -03006526 .subdevice = 0x505B,
Dmitri Belimov9c6f97a2009-12-21 02:00:38 -03006527 .driver_data = SAA7134_BOARD_BEHOLD_505RDS_MK5,
6528 }, {
6529 .vendor = PCI_VENDOR_ID_PHILIPS,
6530 .device = PCI_DEVICE_ID_PHILIPS_SAA7130,
6531 .subvendor = 0x0000,
6532 .subdevice = 0x5051,
6533 .driver_data = SAA7134_BOARD_BEHOLD_505RDS_MK3,
Andrey J. Melnikoff (TEMHOTA)e8018c92008-01-07 05:17:39 -03006534 },{
6535 .vendor = PCI_VENDOR_ID_PHILIPS,
6536 .device = PCI_DEVICE_ID_PHILIPS_SAA7130,
6537 .subvendor = 0x5ace,
6538 .subdevice = 0x5050,
6539 .driver_data = SAA7134_BOARD_BEHOLD_505FM,
6540 },{
6541 .vendor = PCI_VENDOR_ID_PHILIPS,
6542 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
6543 .subvendor = 0x0000,
6544 .subdevice = 0x5071,
Dmitri Belimov84d728c2009-04-23 02:32:49 -03006545 .driver_data = SAA7134_BOARD_BEHOLD_507RDS_MK3,
Andrey J. Melnikoff (TEMHOTA)e8018c92008-01-07 05:17:39 -03006546 },{
6547 .vendor = PCI_VENDOR_ID_PHILIPS,
6548 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
6549 .subvendor = 0x0000,
6550 .subdevice = 0x507B,
Dmitri Belimov84d728c2009-04-23 02:32:49 -03006551 .driver_data = SAA7134_BOARD_BEHOLD_507RDS_MK5,
Andrey J. Melnikoff (TEMHOTA)e8018c92008-01-07 05:17:39 -03006552 },{
6553 .vendor = PCI_VENDOR_ID_PHILIPS,
6554 .device = PCI_DEVICE_ID_PHILIPS_SAA7134,
6555 .subvendor = 0x5ace,
6556 .subdevice = 0x5070,
6557 .driver_data = SAA7134_BOARD_BEHOLD_507_9FM,
6558 },{
6559 .vendor = PCI_VENDOR_ID_PHILIPS,
6560 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
6561 .subvendor = 0x5ace,
6562 .subdevice = 0x5090,
6563 .driver_data = SAA7134_BOARD_BEHOLD_507_9FM,
6564 },{
6565 .vendor = PCI_VENDOR_ID_PHILIPS,
6566 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
6567 .subvendor = 0x0000,
6568 .subdevice = 0x5201,
6569 .driver_data = SAA7134_BOARD_BEHOLD_COLUMBUS_TVFM,
6570 },{
6571 .vendor = PCI_VENDOR_ID_PHILIPS,
6572 .device = PCI_DEVICE_ID_PHILIPS_SAA7134,
6573 .subvendor = 0x5ace,
6574 .subdevice = 0x6070,
Dmitri Belimov84d728c2009-04-23 02:32:49 -03006575 .driver_data = SAA7134_BOARD_BEHOLD_607FM_MK3,
Andrey J. Melnikoff (TEMHOTA)e8018c92008-01-07 05:17:39 -03006576 },{
6577 .vendor = PCI_VENDOR_ID_PHILIPS,
6578 .device = PCI_DEVICE_ID_PHILIPS_SAA7134,
6579 .subvendor = 0x5ace,
6580 .subdevice = 0x6071,
Dmitri Belimov84d728c2009-04-23 02:32:49 -03006581 .driver_data = SAA7134_BOARD_BEHOLD_607FM_MK5,
Andrey J. Melnikoff (TEMHOTA)e8018c92008-01-07 05:17:39 -03006582 },{
6583 .vendor = PCI_VENDOR_ID_PHILIPS,
6584 .device = PCI_DEVICE_ID_PHILIPS_SAA7134,
6585 .subvendor = 0x5ace,
6586 .subdevice = 0x6072,
Dmitri Belimov84d728c2009-04-23 02:32:49 -03006587 .driver_data = SAA7134_BOARD_BEHOLD_607RDS_MK3,
Andrey J. Melnikoff (TEMHOTA)e8018c92008-01-07 05:17:39 -03006588 },{
6589 .vendor = PCI_VENDOR_ID_PHILIPS,
6590 .device = PCI_DEVICE_ID_PHILIPS_SAA7134,
6591 .subvendor = 0x5ace,
6592 .subdevice = 0x6073,
Dmitri Belimov84d728c2009-04-23 02:32:49 -03006593 .driver_data = SAA7134_BOARD_BEHOLD_607RDS_MK5,
Andrey J. Melnikoff (TEMHOTA)e8018c92008-01-07 05:17:39 -03006594 },{
6595 .vendor = PCI_VENDOR_ID_PHILIPS,
6596 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
6597 .subvendor = 0x5ace,
6598 .subdevice = 0x6090,
Dmitri Belimov84d728c2009-04-23 02:32:49 -03006599 .driver_data = SAA7134_BOARD_BEHOLD_609FM_MK3,
Andrey J. Melnikoff (TEMHOTA)e8018c92008-01-07 05:17:39 -03006600 },{
6601 .vendor = PCI_VENDOR_ID_PHILIPS,
6602 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
6603 .subvendor = 0x5ace,
6604 .subdevice = 0x6091,
Dmitri Belimov84d728c2009-04-23 02:32:49 -03006605 .driver_data = SAA7134_BOARD_BEHOLD_609FM_MK5,
Andrey J. Melnikoff (TEMHOTA)e8018c92008-01-07 05:17:39 -03006606 },{
6607 .vendor = PCI_VENDOR_ID_PHILIPS,
6608 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
6609 .subvendor = 0x5ace,
6610 .subdevice = 0x6092,
Dmitri Belimov84d728c2009-04-23 02:32:49 -03006611 .driver_data = SAA7134_BOARD_BEHOLD_609RDS_MK3,
Andrey J. Melnikoff (TEMHOTA)e8018c92008-01-07 05:17:39 -03006612 },{
6613 .vendor = PCI_VENDOR_ID_PHILIPS,
6614 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
6615 .subvendor = 0x5ace,
6616 .subdevice = 0x6093,
Dmitri Belimov84d728c2009-04-23 02:32:49 -03006617 .driver_data = SAA7134_BOARD_BEHOLD_609RDS_MK5,
Andrey J. Melnikoff (TEMHOTA)e8018c92008-01-07 05:17:39 -03006618 },{
6619 .vendor = PCI_VENDOR_ID_PHILIPS,
6620 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
6621 .subvendor = 0x5ace,
6622 .subdevice = 0x6190,
6623 .driver_data = SAA7134_BOARD_BEHOLD_M6,
6624 },{
6625 .vendor = PCI_VENDOR_ID_PHILIPS,
6626 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
6627 .subvendor = 0x5ace,
6628 .subdevice = 0x6193,
Dmitry Belimov878cf2a2008-06-10 14:22:00 -03006629 .driver_data = SAA7134_BOARD_BEHOLD_M6_EXTRA,
Igor Kuznetsov5fe95e02008-04-26 14:59:08 -03006630 }, {
6631 .vendor = PCI_VENDOR_ID_PHILIPS,
6632 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
6633 .subvendor = 0x5ace,
6634 .subdevice = 0x6191,
Dmitry Belimov878cf2a2008-06-10 14:22:00 -03006635 .driver_data = SAA7134_BOARD_BEHOLD_M63,
Andrey J. Melnikoff (TEMHOTA)e8018c92008-01-07 05:17:39 -03006636 },{
6637 .vendor = PCI_VENDOR_ID_PHILIPS,
Mauro Carvalho Chehab593f18c2007-10-07 02:17:09 -03006638 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
6639 .subvendor = 0x4e42,
6640 .subdevice = 0x3502,
Hermann Pitton4ba24372008-01-20 19:27:51 -03006641 .driver_data = SAA7134_BOARD_FLYDVBT_HYBRID_CARDBUS,
6642 }, {
6643 .vendor = PCI_VENDOR_ID_PHILIPS,
6644 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
6645 .subvendor = 0x1822, /*Twinhan Technology Co. Ltd*/
6646 .subdevice = 0x0022,
6647 .driver_data = SAA7134_BOARD_TWINHAN_DTV_DVB_3056,
Hermann Pitton7b5b3f12008-04-22 14:42:12 -03006648 }, {
6649 .vendor = PCI_VENDOR_ID_PHILIPS,
6650 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
6651 .subvendor = 0x16be,
6652 .subdevice = 0x0010, /* Medion version CTX953_V.1.4.3 */
6653 .driver_data = SAA7134_BOARD_CREATIX_CTX953,
Russell Kliese6a6179b62008-04-22 14:42:12 -03006654 }, {
6655 .vendor = PCI_VENDOR_ID_PHILIPS,
6656 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
6657 .subvendor = 0x1462, /* MSI */
6658 .subdevice = 0x8625, /* TV@nywhere A/D v1.1 */
6659 .driver_data = SAA7134_BOARD_MSI_TVANYWHERE_AD11,
Mauro Carvalho Chehab593f18c2007-10-07 02:17:09 -03006660 },{
Mauro Carvalho Chehabbc36a682008-04-22 14:45:27 -03006661 .vendor = PCI_VENDOR_ID_PHILIPS,
6662 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
6663 .subvendor = 0x1461, /* Avermedia Technologies Inc */
6664 .subdevice = 0xf436,
6665 .driver_data = SAA7134_BOARD_AVERMEDIA_CARDBUS_506,
6666 }, {
6667 .vendor = PCI_VENDOR_ID_PHILIPS,
6668 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
6669 .subvendor = 0x1461, /* Avermedia Technologies Inc */
6670 .subdevice = 0xf936,
6671 .driver_data = SAA7134_BOARD_AVERMEDIA_A16D,
6672 }, {
6673 .vendor = PCI_VENDOR_ID_PHILIPS,
6674 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
6675 .subvendor = 0x1461, /* Avermedia Technologies Inc */
6676 .subdevice = 0xa836,
6677 .driver_data = SAA7134_BOARD_AVERMEDIA_M115,
6678 }, {
6679 .vendor = PCI_VENDOR_ID_PHILIPS,
6680 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
6681 .subvendor = 0x185b,
6682 .subdevice = 0xc900,
6683 .driver_data = SAA7134_BOARD_VIDEOMATE_T750,
6684 }, {
Igor Kuznetsov02505272008-04-26 14:53:48 -03006685 .vendor = PCI_VENDOR_ID_PHILIPS,
Adam Gloverf689d902008-05-06 03:20:27 -03006686 .device = PCI_DEVICE_ID_PHILIPS_SAA7133, /* SAA7135HL */
6687 .subvendor = 0x1421,
6688 .subdevice = 0x0380,
6689 .driver_data = SAA7134_BOARD_ADS_INSTANT_HDTV_PCI,
6690 }, {
6691 .vendor = PCI_VENDOR_ID_PHILIPS,
Igor Kuznetsov02505272008-04-26 14:53:48 -03006692 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
Daniel Gimpelevichbfda3a02008-06-28 01:45:26 -03006693 .subvendor = 0x5169,
6694 .subdevice = 0x1502,
6695 .driver_data = SAA7134_BOARD_FLYTVPLATINUM_MINI,
6696 }, {
6697 .vendor = PCI_VENDOR_ID_PHILIPS,
6698 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
Igor Kuznetsov02505272008-04-26 14:53:48 -03006699 .subvendor = 0x5ace,
6700 .subdevice = 0x6290,
6701 .driver_data = SAA7134_BOARD_BEHOLD_H6,
6702 }, {
Massimo Piccionie2fc00c2008-07-11 13:48:02 -03006703 .vendor = PCI_VENDOR_ID_PHILIPS,
6704 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
6705 .subvendor = 0x1461, /* Avermedia Technologies Inc */
6706 .subdevice = 0xf636,
6707 .driver_data = SAA7134_BOARD_AVERMEDIA_M103,
6708 }, {
hermann pitton301e9d62008-09-14 17:49:14 -03006709 .vendor = PCI_VENDOR_ID_PHILIPS,
6710 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
Barry Kitson27049dc2009-06-07 10:41:03 -03006711 .subvendor = 0x1461, /* Avermedia Technologies Inc */
6712 .subdevice = 0xf736,
6713 .driver_data = SAA7134_BOARD_AVERMEDIA_M103,
6714 }, {
6715 .vendor = PCI_VENDOR_ID_PHILIPS,
6716 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
hermann pitton301e9d62008-09-14 17:49:14 -03006717 .subvendor = 0x1043,
6718 .subdevice = 0x4878, /* REV:1.02G */
6719 .driver_data = SAA7134_BOARD_ASUSTeK_TIGER_3IN1,
6720 }, {
Mauro Carvalho Chehab26d5f3a2008-12-07 13:19:29 -03006721 .vendor = PCI_VENDOR_ID_PHILIPS,
6722 .device = PCI_DEVICE_ID_PHILIPS_SAA7134,
6723 .subvendor = 0x17de,
6724 .subdevice = 0x7128,
6725 .driver_data = SAA7134_BOARD_KWORLD_PLUS_TV_ANALOG,
6726 }, {
Pham Thanh Nam4a87d7c2008-12-31 06:57:19 -03006727 .vendor = PCI_VENDOR_ID_PHILIPS,
6728 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
Mauro Carvalho Chehab68541cd2010-10-03 05:27:59 -03006729 .subvendor = 0x17de,
6730 .subdevice = 0xb136,
6731 .driver_data = SAA7134_BOARD_KWORLD_PCI_SBTVD_FULLSEG,
6732 }, {
6733 .vendor = PCI_VENDOR_ID_PHILIPS,
6734 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
Pham Thanh Nam4a87d7c2008-12-31 06:57:19 -03006735 .subvendor = 0x1461, /* Avermedia Technologies Inc */
6736 .subdevice = 0xf31d,
6737 .driver_data = SAA7134_BOARD_AVERMEDIA_GO_007_FM_PLUS,
Igor M. Liplianinecfcfec2009-08-13 21:42:21 -03006738 }, {
6739 .vendor = PCI_VENDOR_ID_PHILIPS,
6740 .device = PCI_DEVICE_ID_PHILIPS_SAA7130,
6741 .subvendor = 0x185b,
6742 .subdevice = 0xc900,
6743 .driver_data = SAA7134_BOARD_VIDEOMATE_S350,
Pham Thanh Nam4a87d7c2008-12-31 06:57:19 -03006744 }, {
Dmitri Belimov2012c872009-08-26 01:01:12 -03006745 .vendor = PCI_VENDOR_ID_PHILIPS,
6746 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
6747 .subvendor = 0x5ace, /* Beholder Intl. Ltd. */
6748 .subdevice = 0x7595,
6749 .driver_data = SAA7134_BOARD_BEHOLD_X7,
6750 }, {
Eugene Yudin23389b82009-08-29 09:32:11 -03006751 .vendor = PCI_VENDOR_ID_PHILIPS,
6752 .device = PCI_DEVICE_ID_PHILIPS_SAA7134,
6753 .subvendor = 0x19d1, /* RoverMedia */
6754 .subdevice = 0x0138, /* LifeView FlyTV Prime30 OEM */
6755 .driver_data = SAA7134_BOARD_ROVERMEDIA_LINK_PRO_FM,
6756 }, {
Henk Vergonet6c119ff2009-09-18 20:44:37 -03006757 .vendor = PCI_VENDOR_ID_PHILIPS,
6758 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
6759 .subvendor = PCI_VENDOR_ID_PHILIPS,
6760 .subdevice = 0x2004,
6761 .driver_data = SAA7134_BOARD_ZOLID_HYBRID_PCI,
6762 }, {
Danny Woode3c6e1a2009-09-20 12:14:21 -03006763 .vendor = PCI_VENDOR_ID_PHILIPS,
6764 .device = PCI_DEVICE_ID_PHILIPS_SAA7134,
6765 .subvendor = 0x1043,
6766 .subdevice = 0x4847,
6767 .driver_data = SAA7134_BOARD_ASUS_EUROPA_HYBRID,
6768 }, {
Michael Krufky184e7692009-06-05 04:28:28 -03006769 .vendor = PCI_VENDOR_ID_PHILIPS,
6770 .device = PCI_DEVICE_ID_PHILIPS_SAA7130,
6771 .subvendor = 0x107d,
6772 .subdevice = 0x6655,
6773 .driver_data = SAA7134_BOARD_LEADTEK_WINFAST_DTV1000S,
6774 }, {
Vadim Catana128fe952010-05-29 12:49:16 -03006775 .vendor = PCI_VENDOR_ID_PHILIPS,
6776 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
6777 .subvendor = 0x13c2,
6778 .subdevice = 0x2804,
6779 .driver_data = SAA7134_BOARD_TECHNOTREND_BUDGET_T3000,
6780 }, {
Dmitri Belimov35bbe582010-10-26 00:31:40 -03006781 .vendor = PCI_VENDOR_ID_PHILIPS,
6782 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
6783 .subvendor = 0x5ace, /* Beholder Intl. Ltd. */
6784 .subdevice = 0x7190,
6785 .driver_data = SAA7134_BOARD_BEHOLD_H7,
6786 }, {
6787 .vendor = PCI_VENDOR_ID_PHILIPS,
6788 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
6789 .subvendor = 0x5ace, /* Beholder Intl. Ltd. */
6790 .subdevice = 0x7090,
6791 .driver_data = SAA7134_BOARD_BEHOLD_A7,
6792 }, {
Ramiro Moralesb7a0f2e2010-12-26 18:13:30 -03006793 .vendor = PCI_VENDOR_ID_PHILIPS,
6794 .device = PCI_DEVICE_ID_PHILIPS_SAA7135,
6795 .subvendor = 0x185b,
6796 .subdevice = 0xc900,
6797 .driver_data = SAA7134_BOARD_VIDEOMATE_M1F,
6798 }, {
Linus Torvalds1da177e2005-04-16 15:20:36 -07006799 /* --- boards without eeprom + subsystem ID --- */
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07006800 .vendor = PCI_VENDOR_ID_PHILIPS,
6801 .device = PCI_DEVICE_ID_PHILIPS_SAA7134,
6802 .subvendor = PCI_VENDOR_ID_PHILIPS,
Linus Torvalds1da177e2005-04-16 15:20:36 -07006803 .subdevice = 0,
6804 .driver_data = SAA7134_BOARD_NOAUTO,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07006805 },{
6806 .vendor = PCI_VENDOR_ID_PHILIPS,
6807 .device = PCI_DEVICE_ID_PHILIPS_SAA7130,
6808 .subvendor = PCI_VENDOR_ID_PHILIPS,
Linus Torvalds1da177e2005-04-16 15:20:36 -07006809 .subdevice = 0,
6810 .driver_data = SAA7134_BOARD_NOAUTO,
6811 },{
Linus Torvalds1da177e2005-04-16 15:20:36 -07006812 /* --- default catch --- */
6813 .vendor = PCI_VENDOR_ID_PHILIPS,
6814 .device = PCI_DEVICE_ID_PHILIPS_SAA7130,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07006815 .subvendor = PCI_ANY_ID,
6816 .subdevice = PCI_ANY_ID,
Linus Torvalds1da177e2005-04-16 15:20:36 -07006817 .driver_data = SAA7134_BOARD_UNKNOWN,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07006818 },{
Linus Torvalds1da177e2005-04-16 15:20:36 -07006819 .vendor = PCI_VENDOR_ID_PHILIPS,
6820 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07006821 .subvendor = PCI_ANY_ID,
6822 .subdevice = PCI_ANY_ID,
Linus Torvalds1da177e2005-04-16 15:20:36 -07006823 .driver_data = SAA7134_BOARD_UNKNOWN,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07006824 },{
Linus Torvalds1da177e2005-04-16 15:20:36 -07006825 .vendor = PCI_VENDOR_ID_PHILIPS,
6826 .device = PCI_DEVICE_ID_PHILIPS_SAA7134,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07006827 .subvendor = PCI_ANY_ID,
6828 .subdevice = PCI_ANY_ID,
Linus Torvalds1da177e2005-04-16 15:20:36 -07006829 .driver_data = SAA7134_BOARD_UNKNOWN,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07006830 },{
Linus Torvalds1da177e2005-04-16 15:20:36 -07006831 .vendor = PCI_VENDOR_ID_PHILIPS,
6832 .device = PCI_DEVICE_ID_PHILIPS_SAA7135,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07006833 .subvendor = PCI_ANY_ID,
6834 .subdevice = PCI_ANY_ID,
Linus Torvalds1da177e2005-04-16 15:20:36 -07006835 .driver_data = SAA7134_BOARD_UNKNOWN,
6836 },{
6837 /* --- end of list --- */
6838 }
6839};
6840MODULE_DEVICE_TABLE(pci, saa7134_pci_tbl);
6841
6842/* ----------------------------------------------------------- */
6843/* flyvideo tweaks */
6844
Linus Torvalds1da177e2005-04-16 15:20:36 -07006845
6846static void board_flyvideo(struct saa7134_dev *dev)
6847{
Linus Torvalds1da177e2005-04-16 15:20:36 -07006848 printk("%s: there are different flyvideo cards with different tuners\n"
6849 "%s: out there, you might have to use the tuner=<nr> insmod\n"
6850 "%s: option to override the default value.\n",
6851 dev->name, dev->name, dev->name);
6852}
6853
Mauro Carvalho Chehabbc36a682008-04-22 14:45:27 -03006854static int saa7134_xc2028_callback(struct saa7134_dev *dev,
6855 int command, int arg)
6856{
6857 switch (command) {
6858 case XC2028_TUNER_RESET:
Tim Farrington6e501a32008-06-15 13:33:42 -03006859 saa_andorl(SAA7134_GPIO_GPSTATUS0 >> 2, 0x00008000, 0x00000000);
6860 saa_andorl(SAA7134_GPIO_GPSTATUS0 >> 2, 0x00008000, 0x00008000);
6861 switch (dev->board) {
6862 case SAA7134_BOARD_AVERMEDIA_CARDBUS_506:
Massimo Piccionie2fc00c2008-07-11 13:48:02 -03006863 case SAA7134_BOARD_AVERMEDIA_M103:
Tim Farrington6e501a32008-06-15 13:33:42 -03006864 saa7134_set_gpio(dev, 23, 0);
6865 msleep(10);
6866 saa7134_set_gpio(dev, 23, 1);
6867 break;
6868 case SAA7134_BOARD_AVERMEDIA_A16D:
6869 saa7134_set_gpio(dev, 21, 0);
6870 msleep(10);
6871 saa7134_set_gpio(dev, 21, 1);
6872 break;
Matthias Schwarzott2659e462009-03-29 16:36:02 -03006873 case SAA7134_BOARD_AVERMEDIA_A700_HYBRID:
6874 saa7134_set_gpio(dev, 18, 0);
6875 msleep(10);
6876 saa7134_set_gpio(dev, 18, 1);
6877 break;
Tim Farrington6e501a32008-06-15 13:33:42 -03006878 }
6879 return 0;
Mauro Carvalho Chehabbc36a682008-04-22 14:45:27 -03006880 }
6881 return -EINVAL;
6882}
6883
Dmitri Belimov2012c872009-08-26 01:01:12 -03006884static int saa7134_xc5000_callback(struct saa7134_dev *dev,
6885 int command, int arg)
6886{
6887 switch (dev->board) {
6888 case SAA7134_BOARD_BEHOLD_X7:
Dmitri Belimov0faa2ed2010-04-06 01:00:05 -03006889 case SAA7134_BOARD_BEHOLD_H7:
6890 case SAA7134_BOARD_BEHOLD_A7:
Dmitri Belimov2012c872009-08-26 01:01:12 -03006891 if (command == XC5000_TUNER_RESET) {
6892 /* Down and UP pheripherial RESET pin for reset all chips */
6893 saa_writeb(SAA7134_SPECIAL_MODE, 0x00);
6894 msleep(10);
6895 saa_writeb(SAA7134_SPECIAL_MODE, 0x01);
6896 msleep(10);
6897 }
6898 break;
6899 default:
6900 saa_andorl(SAA7134_GPIO_GPMODE0 >> 2, 0x06e20000, 0x06e20000);
6901 saa_andorl(SAA7134_GPIO_GPSTATUS0 >> 2, 0x06a20000, 0x06a20000);
6902 saa_andorl(SAA7133_ANALOG_IO_SELECT >> 2, 0x02, 0x02);
6903 saa_andorl(SAA7134_ANALOG_IN_CTRL1 >> 2, 0x81, 0x81);
6904 saa_andorl(SAA7134_AUDIO_CLOCK0 >> 2, 0x03187de7, 0x03187de7);
6905 saa_andorl(SAA7134_AUDIO_PLL_CTRL >> 2, 0x03, 0x03);
6906 saa_andorl(SAA7134_AUDIO_CLOCKS_PER_FIELD0 >> 2,
6907 0x0001e000, 0x0001e000);
6908 break;
6909 }
6910 return 0;
6911}
Mauro Carvalho Chehabbc36a682008-04-22 14:45:27 -03006912
Michael Krufkyf9996c92009-02-28 17:45:17 -03006913static int saa7134_tda8290_827x_callback(struct saa7134_dev *dev,
6914 int command, int arg)
Mauro Carvalho Chehabbc36a682008-04-22 14:45:27 -03006915{
6916 u8 sync_control;
6917
6918 switch (command) {
6919 case 0: /* switch LNA gain through GPIO 22*/
6920 saa7134_set_gpio(dev, 22, arg) ;
6921 break;
6922 case 1: /* vsync output at GPIO22. 50 / 60Hz */
6923 saa_andorb(SAA7134_VIDEO_PORT_CTRL3, 0x80, 0x80);
6924 saa_andorb(SAA7134_VIDEO_PORT_CTRL6, 0x0f, 0x03);
6925 if (arg == 1)
6926 sync_control = 11;
6927 else
6928 sync_control = 17;
6929 saa_writeb(SAA7134_VGATE_START, sync_control);
6930 saa_writeb(SAA7134_VGATE_STOP, sync_control + 1);
6931 saa_andorb(SAA7134_MISC_VGATE_MSB, 0x03, 0x00);
6932 break;
6933 default:
6934 return -EINVAL;
6935 }
6936
6937 return 0;
6938}
6939
Michael Krufkyf9996c92009-02-28 17:45:17 -03006940static inline int saa7134_tda18271_hvr11x0_toggle_agc(struct saa7134_dev *dev,
6941 enum tda18271_mode mode)
6942{
6943 /* toggle AGC switch through GPIO 26 */
6944 switch (mode) {
6945 case TDA18271_ANALOG:
6946 saa7134_set_gpio(dev, 26, 0);
6947 break;
6948 case TDA18271_DIGITAL:
6949 saa7134_set_gpio(dev, 26, 1);
6950 break;
6951 default:
6952 return -EINVAL;
6953 }
6954 return 0;
6955}
6956
Mauro Carvalho Chehab68541cd2010-10-03 05:27:59 -03006957static inline int saa7134_kworld_sbtvd_toggle_agc(struct saa7134_dev *dev,
6958 enum tda18271_mode mode)
6959{
6960 /* toggle AGC switch through GPIO 27 */
6961 switch (mode) {
6962 case TDA18271_ANALOG:
Mauro Carvalho Chehabecb71d22011-01-14 12:03:03 -03006963 saa_writel(SAA7134_GPIO_GPMODE0 >> 2, 0x4000);
6964 saa_writel(SAA7134_GPIO_GPSTATUS0 >> 2, 0x4000);
6965 msleep(20);
Mauro Carvalho Chehab68541cd2010-10-03 05:27:59 -03006966 break;
6967 case TDA18271_DIGITAL:
Mauro Carvalho Chehabecb71d22011-01-14 12:03:03 -03006968 saa_writel(SAA7134_GPIO_GPMODE0 >> 2, 0x14000);
6969 saa_writel(SAA7134_GPIO_GPSTATUS0 >> 2, 0x14000);
6970 msleep(20);
6971 saa_writel(SAA7134_GPIO_GPMODE0 >> 2, 0x54000);
6972 saa_writel(SAA7134_GPIO_GPSTATUS0 >> 2, 0x54000);
6973 msleep(30);
Mauro Carvalho Chehab68541cd2010-10-03 05:27:59 -03006974 break;
6975 default:
6976 return -EINVAL;
6977 }
6978 return 0;
6979}
6980
Michael Krufkyf9996c92009-02-28 17:45:17 -03006981static int saa7134_tda8290_18271_callback(struct saa7134_dev *dev,
6982 int command, int arg)
6983{
6984 int ret = 0;
6985
6986 switch (command) {
6987 case TDA18271_CALLBACK_CMD_AGC_ENABLE: /* 0 */
6988 switch (dev->board) {
Michael Krufkyb5f05062009-08-03 16:51:33 -03006989 case SAA7134_BOARD_HAUPPAUGE_HVR1150:
Michael Krufky0e316ec2009-08-03 16:51:33 -03006990 case SAA7134_BOARD_HAUPPAUGE_HVR1120:
Michael Krufkyf9996c92009-02-28 17:45:17 -03006991 ret = saa7134_tda18271_hvr11x0_toggle_agc(dev, arg);
6992 break;
Mauro Carvalho Chehab68541cd2010-10-03 05:27:59 -03006993 case SAA7134_BOARD_KWORLD_PCI_SBTVD_FULLSEG:
6994 ret = saa7134_kworld_sbtvd_toggle_agc(dev, arg);
6995 break;
Michael Krufkyf9996c92009-02-28 17:45:17 -03006996 default:
6997 break;
6998 }
6999 break;
7000 default:
7001 ret = -EINVAL;
7002 break;
7003 }
7004 return ret;
7005}
7006
7007static int saa7134_tda8290_callback(struct saa7134_dev *dev,
7008 int command, int arg)
7009{
7010 int ret;
7011
7012 switch (dev->board) {
Michael Krufkyb5f05062009-08-03 16:51:33 -03007013 case SAA7134_BOARD_HAUPPAUGE_HVR1150:
Michael Krufky0e316ec2009-08-03 16:51:33 -03007014 case SAA7134_BOARD_HAUPPAUGE_HVR1120:
Herton Ronaldo Krzesinski9e1d9e72010-05-08 02:23:37 -03007015 case SAA7134_BOARD_AVERMEDIA_M733A:
Mauro Carvalho Chehab68541cd2010-10-03 05:27:59 -03007016 case SAA7134_BOARD_KWORLD_PCI_SBTVD_FULLSEG:
Michael Krufkyf9996c92009-02-28 17:45:17 -03007017 /* tda8290 + tda18271 */
7018 ret = saa7134_tda8290_18271_callback(dev, command, arg);
7019 break;
7020 default:
7021 /* tda8290 + tda827x */
7022 ret = saa7134_tda8290_827x_callback(dev, command, arg);
7023 break;
7024 }
7025 return ret;
7026}
7027
Michael Krufkyd7cba042008-09-12 13:31:45 -03007028int saa7134_tuner_callback(void *priv, int component, int command, int arg)
Mauro Carvalho Chehabbc36a682008-04-22 14:45:27 -03007029{
Hartmut Hackmann0fea03f2008-04-22 14:46:10 -03007030 struct saa7134_dev *dev = priv;
Mauro Carvalho Chehabecb71d22011-01-14 12:03:03 -03007031
Hartmut Hackmann7bff4b42008-04-22 14:46:08 -03007032 if (dev != NULL) {
7033 switch (dev->tuner_type) {
7034 case TUNER_PHILIPS_TDA8290:
7035 return saa7134_tda8290_callback(dev, command, arg);
7036 case TUNER_XC2028:
7037 return saa7134_xc2028_callback(dev, command, arg);
Dmitri Belimov2012c872009-08-26 01:01:12 -03007038 case TUNER_XC5000:
7039 return saa7134_xc5000_callback(dev, command, arg);
Hartmut Hackmann7bff4b42008-04-22 14:46:08 -03007040 }
Mauro Carvalho Chehab0be51b42008-04-22 14:46:10 -03007041 } else {
7042 printk(KERN_ERR "saa7134: Error - device struct undefined.\n");
7043 return -EINVAL;
Mauro Carvalho Chehabbc36a682008-04-22 14:45:27 -03007044 }
7045 return -EINVAL;
7046}
7047EXPORT_SYMBOL(saa7134_tuner_callback);
7048
Linus Torvalds1da177e2005-04-16 15:20:36 -07007049/* ----------------------------------------------------------- */
7050
Michael Krufky993efa72007-11-15 10:34:33 -03007051static void hauppauge_eeprom(struct saa7134_dev *dev, u8 *eeprom_data)
7052{
7053 struct tveeprom tv;
7054
7055 tveeprom_hauppauge_analog(&dev->i2c_client, &tv, eeprom_data);
7056
7057 /* Make sure we support the board model */
7058 switch (tv.model) {
7059 case 67019: /* WinTV-HVR1110 (Retail, IR Blaster, hybrid, FM, SVid/Comp, 3.5mm audio in) */
7060 case 67109: /* WinTV-HVR1000 (Retail, IR Receive, analog, no FM, SVid/Comp, 3.5mm audio in) */
Michael Krufkyb5f05062009-08-03 16:51:33 -03007061 case 67201: /* WinTV-HVR1150 (Retail, IR Receive, hybrid, FM, SVid/Comp, 3.5mm audio in) */
Michael Krufkyf9996c92009-02-28 17:45:17 -03007062 case 67301: /* WinTV-HVR1000 (Retail, IR Receive, analog, no FM, SVid/Comp, 3.5mm audio in) */
7063 case 67209: /* WinTV-HVR1110 (Retail, IR Receive, hybrid, FM, SVid/Comp, 3.5mm audio in) */
Michael Krufky993efa72007-11-15 10:34:33 -03007064 case 67559: /* WinTV-HVR1110 (OEM, no IR, hybrid, FM, SVid/Comp, RCA aud) */
7065 case 67569: /* WinTV-HVR1110 (OEM, no IR, hybrid, FM) */
7066 case 67579: /* WinTV-HVR1110 (OEM, no IR, hybrid, no FM) */
7067 case 67589: /* WinTV-HVR1110 (OEM, no IR, hybrid, no FM, SVid/Comp, RCA aud) */
7068 case 67599: /* WinTV-HVR1110 (OEM, no IR, hybrid, no FM, SVid/Comp, RCA aud) */
Michael Krufkyb5f05062009-08-03 16:51:33 -03007069 case 67651: /* WinTV-HVR1150 (OEM, no IR, hybrid, FM, SVid/Comp, RCA aud) */
Michael Krufkyf9996c92009-02-28 17:45:17 -03007070 case 67659: /* WinTV-HVR1110 (OEM, no IR, hybrid, FM, SVid/Comp, RCA aud) */
Michael Krufky993efa72007-11-15 10:34:33 -03007071 break;
7072 default:
7073 printk(KERN_WARNING "%s: warning: "
7074 "unknown hauppauge model #%d\n", dev->name, tv.model);
7075 break;
7076 }
7077
7078 printk(KERN_INFO "%s: hauppauge eeprom: model=%d\n",
7079 dev->name, tv.model);
7080}
7081
7082/* ----------------------------------------------------------- */
7083
Linus Torvalds1da177e2005-04-16 15:20:36 -07007084int saa7134_board_init1(struct saa7134_dev *dev)
7085{
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07007086 /* Always print gpio, often manufacturers encode tuner type and other info. */
Linus Torvalds1da177e2005-04-16 15:20:36 -07007087 saa_writel(SAA7134_GPIO_GPMODE0 >> 2, 0);
7088 dev->gpio_value = saa_readl(SAA7134_GPIO_GPSTATUS0 >> 2);
7089 printk(KERN_INFO "%s: board init: gpio is %x\n", dev->name, dev->gpio_value);
7090
7091 switch (dev->board) {
7092 case SAA7134_BOARD_FLYVIDEO2000:
7093 case SAA7134_BOARD_FLYVIDEO3000:
Zac Bowlingf49ba8d2006-06-19 19:49:20 -03007094 case SAA7134_BOARD_FLYVIDEO3000_NTSC:
Ricardo Cerqueiracb2444d2005-11-08 21:38:47 -08007095 dev->has_remote = SAA7134_REMOTE_GPIO;
Linus Torvalds1da177e2005-04-16 15:20:36 -07007096 board_flyvideo(dev);
7097 break;
Arnaud Patard6af90ab2005-11-08 21:36:55 -08007098 case SAA7134_BOARD_FLYTVPLATINUM_MINI2:
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07007099 case SAA7134_BOARD_FLYTVPLATINUM_FM:
Linus Torvalds1da177e2005-04-16 15:20:36 -07007100 case SAA7134_BOARD_CINERGY400:
7101 case SAA7134_BOARD_CINERGY600:
7102 case SAA7134_BOARD_CINERGY600_MK3:
7103 case SAA7134_BOARD_ECS_TVP3XP:
7104 case SAA7134_BOARD_ECS_TVP3XP_4CB5:
Simon Farnsworthb39423a2007-05-01 10:01:20 -03007105 case SAA7134_BOARD_ECS_TVP3XP_4CB6:
Linus Torvalds1da177e2005-04-16 15:20:36 -07007106 case SAA7134_BOARD_MD2819:
Mauro Carvalho Chehabac19ecc2005-06-23 22:05:09 -07007107 case SAA7134_BOARD_KWORLD_VSTREAM_XPERT:
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07007108 case SAA7134_BOARD_KWORLD_XPERT:
Linus Torvalds1da177e2005-04-16 15:20:36 -07007109 case SAA7134_BOARD_AVERMEDIA_STUDIO_305:
Vasiliy Temnikov5a5e1da2009-08-26 22:10:55 -03007110 case SAA7134_BOARD_AVERMEDIA_STUDIO_505:
Linus Torvalds1da177e2005-04-16 15:20:36 -07007111 case SAA7134_BOARD_AVERMEDIA_305:
Mauro Carvalho Chehabac19ecc2005-06-23 22:05:09 -07007112 case SAA7134_BOARD_AVERMEDIA_STUDIO_307:
Linus Torvalds1da177e2005-04-16 15:20:36 -07007113 case SAA7134_BOARD_AVERMEDIA_307:
Mikhail Fedotov3ac706d2006-10-06 20:23:47 -03007114 case SAA7134_BOARD_AVERMEDIA_STUDIO_507:
Mauro Carvalho Chehabac19ecc2005-06-23 22:05:09 -07007115 case SAA7134_BOARD_AVERMEDIA_GO_007_FM:
pasky@ucw.cz450efcf2006-11-12 14:22:32 -03007116 case SAA7134_BOARD_AVERMEDIA_777:
Mauro Carvalho Chehab36f6bb92008-06-26 17:03:00 -03007117 case SAA7134_BOARD_AVERMEDIA_M135A:
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07007118/* case SAA7134_BOARD_SABRENT_SBTTVFM: */ /* not finished yet */
Linus Torvalds1da177e2005-04-16 15:20:36 -07007119 case SAA7134_BOARD_VIDEOMATE_TV_PVR:
Nickolay V. Shmyrev2a9a9a82006-01-09 15:25:33 -02007120 case SAA7134_BOARD_VIDEOMATE_GOLD_PLUS:
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07007121 case SAA7134_BOARD_VIDEOMATE_TV_GOLD_PLUSII:
Ramiro Moralesb7a0f2e2010-12-26 18:13:30 -03007122 case SAA7134_BOARD_VIDEOMATE_M1F:
Nickolay V. Shmyrevfea095f2005-11-08 21:36:47 -08007123 case SAA7134_BOARD_VIDEOMATE_DVBT_300:
Michael Krufkyafce8922005-11-08 21:36:57 -08007124 case SAA7134_BOARD_VIDEOMATE_DVBT_200:
Hartmut Hackmanncbb94522006-10-30 20:00:16 -03007125 case SAA7134_BOARD_VIDEOMATE_DVBT_200A:
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07007126 case SAA7134_BOARD_MANLI_MTV001:
7127 case SAA7134_BOARD_MANLI_MTV002:
Nickolay V. Shmyreva8ff4172005-11-08 21:36:16 -08007128 case SAA7134_BOARD_BEHOLD_409FM:
Linus Torvalds1da177e2005-04-16 15:20:36 -07007129 case SAA7134_BOARD_AVACSSMARTTV:
Nickolay V. Shmyrev6b961442005-11-08 21:36:22 -08007130 case SAA7134_BOARD_GOTVIEW_7135:
James R. Webbdc2286c2005-11-08 21:37:00 -08007131 case SAA7134_BOARD_KWORLD_TERMINATOR:
Ricardo Cerqueira17ce1ff2005-11-08 21:38:47 -08007132 case SAA7134_BOARD_SEDNA_PC_TV_CARDBUS:
Giampiero Giancipoli3d8466e2006-02-07 06:49:09 -02007133 case SAA7134_BOARD_FLYDVBT_LR301:
Hermann Pitton91607232006-12-07 21:45:28 -03007134 case SAA7134_BOARD_ASUSTeK_P7131_DUAL:
Hartmut Hackmannf3eec0c02007-03-14 20:33:55 -03007135 case SAA7134_BOARD_ASUSTeK_P7131_HYBRID_LNA:
Mauro Carvalho Chehabdfb4ba12009-08-20 10:13:40 -03007136 case SAA7134_BOARD_ASUSTeK_P7131_ANALOG:
Rudo Thomasa8029172006-02-27 00:08:46 -03007137 case SAA7134_BOARD_FLYDVBTDUO:
Michal Majchrowiczb04c1ba2006-09-13 16:42:42 -03007138 case SAA7134_BOARD_PROTEUS_2309:
pasky@ucw.cz29e0f1a2006-11-12 14:23:32 -03007139 case SAA7134_BOARD_AVERMEDIA_A16AR:
Juan Pablo Sormanic36c4592006-12-27 12:46:36 -03007140 case SAA7134_BOARD_ENCORE_ENLTV:
7141 case SAA7134_BOARD_ENCORE_ENLTV_FM:
Mauro Carvalho Chehabbf1ece62008-06-26 17:03:00 -03007142 case SAA7134_BOARD_ENCORE_ENLTV_FM53:
Mauro Carvalho Chehabd642f2f2011-01-19 16:25:17 -02007143 case SAA7134_BOARD_ENCORE_ENLTV_FM3:
Tony Wan480f75a2007-05-11 11:33:50 -03007144 case SAA7134_BOARD_10MOONSTVMASTER3:
Andrey J. Melnikoff (TEMHOTA)e8018c92008-01-07 05:17:39 -03007145 case SAA7134_BOARD_BEHOLD_401:
7146 case SAA7134_BOARD_BEHOLD_403:
7147 case SAA7134_BOARD_BEHOLD_403FM:
7148 case SAA7134_BOARD_BEHOLD_405:
7149 case SAA7134_BOARD_BEHOLD_405FM:
7150 case SAA7134_BOARD_BEHOLD_407:
7151 case SAA7134_BOARD_BEHOLD_407FM:
7152 case SAA7134_BOARD_BEHOLD_409:
7153 case SAA7134_BOARD_BEHOLD_505FM:
Dmitri Belimov9c6f97a2009-12-21 02:00:38 -03007154 case SAA7134_BOARD_BEHOLD_505RDS_MK5:
7155 case SAA7134_BOARD_BEHOLD_505RDS_MK3:
Andrey J. Melnikoff (TEMHOTA)e8018c92008-01-07 05:17:39 -03007156 case SAA7134_BOARD_BEHOLD_507_9FM:
Dmitri Belimov84d728c2009-04-23 02:32:49 -03007157 case SAA7134_BOARD_BEHOLD_507RDS_MK3:
7158 case SAA7134_BOARD_BEHOLD_507RDS_MK5:
Adrian Pardinif0ba3562008-02-11 12:40:53 -03007159 case SAA7134_BOARD_GENIUS_TVGO_A11MCE:
Mauro Carvalho Chehab9b000192008-06-26 17:03:00 -03007160 case SAA7134_BOARD_REAL_ANGEL_220:
Mauro Carvalho Chehab26d5f3a2008-12-07 13:19:29 -03007161 case SAA7134_BOARD_KWORLD_PLUS_TV_ANALOG:
Pham Thanh Nam6a2d8022008-12-30 23:26:09 -03007162 case SAA7134_BOARD_AVERMEDIA_GO_007_FM_PLUS:
Eugene Yudin23389b82009-08-29 09:32:11 -03007163 case SAA7134_BOARD_ROVERMEDIA_LINK_PRO_FM:
Michael Obst0700ade2009-10-31 14:05:42 -03007164 case SAA7134_BOARD_LEADTEK_WINFAST_DTV1000S:
Ricardo Cerqueiracb2444d2005-11-08 21:38:47 -08007165 dev->has_remote = SAA7134_REMOTE_GPIO;
Linus Torvalds1da177e2005-04-16 15:20:36 -07007166 break;
Igor M. Liplianine2ac28f2006-08-08 09:10:10 -03007167 case SAA7134_BOARD_FLYDVBS_LR300:
7168 saa_writeb(SAA7134_GPIO_GPMODE3, 0x80);
7169 saa_writeb(SAA7134_GPIO_GPSTATUS2, 0x40);
7170 dev->has_remote = SAA7134_REMOTE_GPIO;
7171 break;
Linus Torvalds1da177e2005-04-16 15:20:36 -07007172 case SAA7134_BOARD_MD5044:
7173 printk("%s: seems there are two different versions of the MD5044\n"
Michael Krufkyfd2f2672006-03-11 16:21:36 -03007174 "%s: (with the same ID) out there. If sound doesn't work for\n"
7175 "%s: you try the audio_clock_override=0x200000 insmod option.\n",
7176 dev->name,dev->name,dev->name);
Linus Torvalds1da177e2005-04-16 15:20:36 -07007177 break;
7178 case SAA7134_BOARD_CINERGY400_CARDBUS:
7179 /* power-up tuner chip */
7180 saa_andorl(SAA7134_GPIO_GPMODE0 >> 2, 0x00040000, 0x00040000);
7181 saa_andorl(SAA7134_GPIO_GPSTATUS0 >> 2, 0x00040000, 0x00000000);
Mikhail Gusarov7bbbc0a2006-04-20 13:18:50 -03007182 break;
Hartmut Hackmanndf8cf702006-03-03 12:09:26 -03007183 case SAA7134_BOARD_PINNACLE_300I_DVBT_PAL:
7184 /* this turns the remote control chip off to work around a bug in it */
7185 saa_writeb(SAA7134_GPIO_GPMODE1, 0x80);
7186 saa_writeb(SAA7134_GPIO_GPSTATUS1, 0x80);
7187 break;
Pieter Palmerscf1c5d12005-11-08 21:37:40 -08007188 case SAA7134_BOARD_MONSTERTV_MOBILE:
7189 /* power-up tuner chip */
7190 saa_andorl(SAA7134_GPIO_GPMODE0 >> 2, 0x00040000, 0x00040000);
7191 saa_andorl(SAA7134_GPIO_GPSTATUS0 >> 2, 0x00040000, 0x00000004);
Linus Torvalds1da177e2005-04-16 15:20:36 -07007192 break;
Peter Missel10b7a902006-01-23 17:11:06 -02007193 case SAA7134_BOARD_FLYDVBT_DUO_CARDBUS:
Nickolay V. Shmyrev6b961442005-11-08 21:36:22 -08007194 /* turn the fan on */
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07007195 saa_writeb(SAA7134_GPIO_GPMODE3, 0x08);
7196 saa_writeb(SAA7134_GPIO_GPSTATUS3, 0x06);
7197 break;
Hartmut Hackmanndf42eaf2006-02-07 06:49:10 -02007198 case SAA7134_BOARD_ADS_DUO_CARDBUS_PTV331:
Hartmut Hackmannd95b8942006-03-27 19:39:30 -03007199 case SAA7134_BOARD_FLYDVBT_HYBRID_CARDBUS:
Hartmut Hackmann58ef4f92007-04-27 12:31:12 -03007200 saa_andorl(SAA7134_GPIO_GPMODE0 >> 2, 0x08000000, 0x08000000);
7201 saa_andorl(SAA7134_GPIO_GPSTATUS0 >> 2, 0x08000000, 0x00000000);
Hartmut Hackmanndf42eaf2006-02-07 06:49:10 -02007202 break;
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07007203 case SAA7134_BOARD_AVERMEDIA_CARDBUS:
Mauro Carvalho Chehabbc36a682008-04-22 14:45:27 -03007204 case SAA7134_BOARD_AVERMEDIA_M115:
Mauro Carvalho Chehab95a2fdb2008-03-28 17:52:44 -03007205 /* power-down tuner chip */
7206 saa_andorl(SAA7134_GPIO_GPMODE0 >> 2, 0xffffffff, 0);
7207 saa_andorl(SAA7134_GPIO_GPSTATUS0 >> 2, 0xffffffff, 0);
7208 msleep(10);
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07007209 /* power-up tuner chip */
7210 saa_andorl(SAA7134_GPIO_GPMODE0 >> 2, 0xffffffff, 0xffffffff);
7211 saa_andorl(SAA7134_GPIO_GPSTATUS0 >> 2, 0xffffffff, 0xffffffff);
Mauro Carvalho Chehab95a2fdb2008-03-28 17:52:44 -03007212 msleep(10);
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07007213 break;
Oldřich Jedličkad46de9d2009-04-14 15:47:17 -03007214 case SAA7134_BOARD_AVERMEDIA_CARDBUS_501:
7215 /* power-down tuner chip */
7216 saa_andorl(SAA7134_GPIO_GPMODE0 >> 2, 0x08400000, 0x08400000);
7217 saa_andorl(SAA7134_GPIO_GPSTATUS0 >> 2, 0x08400000, 0);
7218 msleep(10);
7219 saa_andorl(SAA7134_GPIO_GPMODE0 >> 2, 0x08400000, 0x08400000);
7220 saa_andorl(SAA7134_GPIO_GPSTATUS0 >> 2, 0x08400000, 0x08400000);
7221 msleep(10);
7222 dev->has_remote = SAA7134_REMOTE_I2C;
7223 break;
Tim Farrington6e501a32008-06-15 13:33:42 -03007224 case SAA7134_BOARD_AVERMEDIA_CARDBUS_506:
Oldřich Jedličkacb3bf502009-02-12 03:43:11 -03007225 saa7134_set_gpio(dev, 23, 0);
7226 msleep(10);
7227 saa7134_set_gpio(dev, 23, 1);
7228 dev->has_remote = SAA7134_REMOTE_I2C;
7229 break;
Massimo Piccionie2fc00c2008-07-11 13:48:02 -03007230 case SAA7134_BOARD_AVERMEDIA_M103:
Tim Farrington6e501a32008-06-15 13:33:42 -03007231 saa7134_set_gpio(dev, 23, 0);
7232 msleep(10);
7233 saa7134_set_gpio(dev, 23, 1);
7234 break;
7235 case SAA7134_BOARD_AVERMEDIA_A16D:
7236 saa7134_set_gpio(dev, 21, 0);
7237 msleep(10);
7238 saa7134_set_gpio(dev, 21, 1);
7239 msleep(1);
7240 dev->has_remote = SAA7134_REMOTE_GPIO;
7241 break;
Dmitry Belimovb34dddb2008-04-23 14:09:08 -03007242 case SAA7134_BOARD_BEHOLD_COLUMBUS_TVFM:
7243 /* power-down tuner chip */
7244 saa_andorl(SAA7134_GPIO_GPMODE0 >> 2, 0x000A8004, 0x000A8004);
7245 saa_andorl(SAA7134_GPIO_GPSTATUS0 >> 2, 0x000A8004, 0);
7246 msleep(10);
7247 /* power-up tuner chip */
7248 saa_andorl(SAA7134_GPIO_GPMODE0 >> 2, 0x000A8004, 0x000A8004);
7249 saa_andorl(SAA7134_GPIO_GPSTATUS0 >> 2, 0x000A8004, 0x000A8004);
7250 msleep(10);
7251 /* remote via GPIO */
7252 dev->has_remote = SAA7134_REMOTE_GPIO;
7253 break;
Nickolay V. Shmyrevbb881f12005-11-08 21:36:35 -08007254 case SAA7134_BOARD_RTD_VFG7350:
7255
7256 /*
7257 * Make sure Production Test Register at offset 0x1D1 is cleared
7258 * to take chip out of test mode. Clearing bit 4 (TST_EN_AOUT)
7259 * prevents pin 105 from remaining low; keeping pin 105 low
7260 * continually resets the SAA6752 chip.
7261 */
7262
7263 saa_writeb (SAA7134_PRODUCTION_TEST_MODE, 0x00);
7264 break;
Michael Krufkyb5f05062009-08-03 16:51:33 -03007265 case SAA7134_BOARD_HAUPPAUGE_HVR1150:
Michael Krufky0e316ec2009-08-03 16:51:33 -03007266 case SAA7134_BOARD_HAUPPAUGE_HVR1120:
Michael Krufkyf9996c92009-02-28 17:45:17 -03007267 /* GPIO 26 high for digital, low for analog */
7268 saa7134_set_gpio(dev, 26, 0);
7269 msleep(1);
7270
7271 saa7134_set_gpio(dev, 22, 0);
7272 msleep(10);
7273 saa7134_set_gpio(dev, 22, 1);
7274 break;
Ricardo Cerqueiracb2444d2005-11-08 21:38:47 -08007275 /* i2c remotes */
7276 case SAA7134_BOARD_PINNACLE_PCTV_110i:
Hartmut Hackmann587d2fd2006-10-06 19:13:50 -03007277 case SAA7134_BOARD_PINNACLE_PCTV_310i:
Ricardo Cerqueiracb2444d2005-11-08 21:38:47 -08007278 case SAA7134_BOARD_UPMOST_PURPLE_TV:
Brian Rogersba340b42008-10-13 08:37:06 -03007279 case SAA7134_BOARD_MSI_TVATANYWHERE_PLUS:
Thomas Genty177aaaf2006-11-29 21:57:24 -03007280 case SAA7134_BOARD_HAUPPAUGE_HVR1110:
Dmitri Belimov84d728c2009-04-23 02:32:49 -03007281 case SAA7134_BOARD_BEHOLD_607FM_MK3:
7282 case SAA7134_BOARD_BEHOLD_607FM_MK5:
7283 case SAA7134_BOARD_BEHOLD_609FM_MK3:
7284 case SAA7134_BOARD_BEHOLD_609FM_MK5:
7285 case SAA7134_BOARD_BEHOLD_607RDS_MK3:
7286 case SAA7134_BOARD_BEHOLD_607RDS_MK5:
7287 case SAA7134_BOARD_BEHOLD_609RDS_MK3:
7288 case SAA7134_BOARD_BEHOLD_609RDS_MK5:
Andrey J. Melnikoff (TEMHOTA)e8018c92008-01-07 05:17:39 -03007289 case SAA7134_BOARD_BEHOLD_M6:
Dmitry Belimov878cf2a2008-06-10 14:22:00 -03007290 case SAA7134_BOARD_BEHOLD_M63:
7291 case SAA7134_BOARD_BEHOLD_M6_EXTRA:
Dmitri Belimovf204ae42008-12-23 03:51:38 -03007292 case SAA7134_BOARD_BEHOLD_H6:
Dmitri Belimov2012c872009-08-26 01:01:12 -03007293 case SAA7134_BOARD_BEHOLD_X7:
Dmitri Belimov0faa2ed2010-04-06 01:00:05 -03007294 case SAA7134_BOARD_BEHOLD_H7:
7295 case SAA7134_BOARD_BEHOLD_A7:
Ricardo Cerqueiracb2444d2005-11-08 21:38:47 -08007296 dev->has_remote = SAA7134_REMOTE_I2C;
7297 break;
Rickard Osser68593af2006-03-11 17:14:12 -03007298 case SAA7134_BOARD_AVERMEDIA_A169_B:
Michael Krufky12a219d2006-03-14 16:07:42 -03007299 printk("%s: %s: dual saa713x broadcast decoders\n"
Rickard Osser68593af2006-03-11 17:14:12 -03007300 "%s: Sorry, none of the inputs to this chip are supported yet.\n"
7301 "%s: Dual decoder functionality is disabled for now, use the other chip.\n",
Michael Krufky12a219d2006-03-14 16:07:42 -03007302 dev->name,card(dev).name,dev->name,dev->name);
Rickard Osser68593af2006-03-11 17:14:12 -03007303 break;
Markus Rechbergere95d3172007-04-27 12:31:19 -03007304 case SAA7134_BOARD_AVERMEDIA_M102:
7305 /* enable tuner */
Albert Grahamd2761f22007-12-09 09:44:38 -03007306 dev->has_remote = SAA7134_REMOTE_GPIO;
Markus Rechbergere95d3172007-04-27 12:31:19 -03007307 saa_andorl(SAA7134_GPIO_GPMODE0 >> 2, 0x8c040007, 0x8c040007);
7308 saa_andorl(SAA7134_GPIO_GPSTATUS0 >> 2, 0x0c0007cd, 0x0c0007cd);
7309 break;
Matthias Schwarzottfc9d8ed2008-04-08 21:45:08 -03007310 case SAA7134_BOARD_AVERMEDIA_A700_HYBRID:
Matthias Schwarzott04574182009-02-24 12:35:16 -03007311 case SAA7134_BOARD_AVERMEDIA_A700_PRO:
Matthias Schwarzottfc9d8ed2008-04-08 21:45:08 -03007312 /* write windows gpio values */
7313 saa_andorl(SAA7134_GPIO_GPMODE0 >> 2, 0x80040100, 0x80040100);
7314 saa_andorl(SAA7134_GPIO_GPSTATUS0 >> 2, 0x80040100, 0x00040100);
Matthias Schwarzottfc9d8ed2008-04-08 21:45:08 -03007315 break;
Igor M. Liplianinecfcfec2009-08-13 21:42:21 -03007316 case SAA7134_BOARD_VIDEOMATE_S350:
7317 dev->has_remote = SAA7134_REMOTE_GPIO;
JD Louw8f50a3e2010-01-17 09:57:46 -03007318 saa_andorl(SAA7134_GPIO_GPMODE0 >> 2, 0x0000C000, 0x0000C000);
7319 saa_andorl(SAA7134_GPIO_GPSTATUS0 >> 2, 0x0000C000, 0x0000C000);
Igor M. Liplianinecfcfec2009-08-13 21:42:21 -03007320 break;
Herton Ronaldo Krzesinski9e1d9e72010-05-08 02:23:37 -03007321 case SAA7134_BOARD_AVERMEDIA_M733A:
7322 saa7134_set_gpio(dev, 1, 1);
7323 msleep(10);
7324 saa7134_set_gpio(dev, 1, 0);
7325 msleep(10);
7326 saa7134_set_gpio(dev, 1, 1);
7327 dev->has_remote = SAA7134_REMOTE_GPIO;
7328 break;
Linus Torvalds1da177e2005-04-16 15:20:36 -07007329 }
Linus Torvalds1da177e2005-04-16 15:20:36 -07007330 return 0;
7331}
7332
Mauro Carvalho Chehabc117d052008-04-26 14:05:58 -03007333static void saa7134_tuner_setup(struct saa7134_dev *dev)
7334{
7335 struct tuner_setup tun_setup;
7336 unsigned int mode_mask = T_RADIO |
7337 T_ANALOG_TV |
7338 T_DIGITAL_TV;
7339
7340 memset(&tun_setup, 0, sizeof(tun_setup));
7341 tun_setup.tuner_callback = saa7134_tuner_callback;
7342
7343 if (saa7134_boards[dev->board].radio_type != UNSET) {
7344 tun_setup.type = saa7134_boards[dev->board].radio_type;
7345 tun_setup.addr = saa7134_boards[dev->board].radio_addr;
7346
7347 tun_setup.mode_mask = T_RADIO;
7348
Hans Verkuilfac69862009-01-17 12:17:14 -03007349 saa_call_all(dev, tuner, s_type_addr, &tun_setup);
Mauro Carvalho Chehabc117d052008-04-26 14:05:58 -03007350 mode_mask &= ~T_RADIO;
7351 }
7352
7353 if ((dev->tuner_type != TUNER_ABSENT) && (dev->tuner_type != UNSET)) {
7354 tun_setup.type = dev->tuner_type;
7355 tun_setup.addr = dev->tuner_addr;
7356 tun_setup.config = saa7134_boards[dev->board].tuner_config;
7357 tun_setup.tuner_callback = saa7134_tuner_callback;
7358
7359 tun_setup.mode_mask = mode_mask;
7360
Hans Verkuilfac69862009-01-17 12:17:14 -03007361 saa_call_all(dev, tuner, s_type_addr, &tun_setup);
Mauro Carvalho Chehabc117d052008-04-26 14:05:58 -03007362 }
7363
7364 if (dev->tda9887_conf) {
7365 struct v4l2_priv_tun_config tda9887_cfg;
7366
7367 tda9887_cfg.tuner = TUNER_TDA9887;
7368 tda9887_cfg.priv = &dev->tda9887_conf;
7369
Hans Verkuilfac69862009-01-17 12:17:14 -03007370 saa_call_all(dev, tuner, s_config, &tda9887_cfg);
Mauro Carvalho Chehabc117d052008-04-26 14:05:58 -03007371 }
7372
7373 if (dev->tuner_type == TUNER_XC2028) {
7374 struct v4l2_priv_tun_config xc2028_cfg;
7375 struct xc2028_ctrl ctl;
7376
Oldrich Jedlickabdf398e2008-11-13 22:03:00 -03007377 memset(&xc2028_cfg, 0, sizeof(xc2028_cfg));
Mauro Carvalho Chehabc117d052008-04-26 14:05:58 -03007378 memset(&ctl, 0, sizeof(ctl));
7379
7380 ctl.fname = XC2028_DEFAULT_FIRMWARE;
7381 ctl.max_len = 64;
7382
7383 switch (dev->board) {
7384 case SAA7134_BOARD_AVERMEDIA_A16D:
Tim Farrington6e501a32008-06-15 13:33:42 -03007385 case SAA7134_BOARD_AVERMEDIA_CARDBUS_506:
Massimo Piccionie2fc00c2008-07-11 13:48:02 -03007386 case SAA7134_BOARD_AVERMEDIA_M103:
Matthias Schwarzott2659e462009-03-29 16:36:02 -03007387 case SAA7134_BOARD_AVERMEDIA_A700_HYBRID:
Mauro Carvalho Chehabc117d052008-04-26 14:05:58 -03007388 ctl.demod = XC3028_FE_ZARLINK456;
7389 break;
7390 default:
7391 ctl.demod = XC3028_FE_OREN538;
7392 ctl.mts = 1;
7393 }
7394
7395 xc2028_cfg.tuner = TUNER_XC2028;
7396 xc2028_cfg.priv = &ctl;
7397
Hans Verkuilfac69862009-01-17 12:17:14 -03007398 saa_call_all(dev, tuner, s_config, &xc2028_cfg);
Mauro Carvalho Chehabc117d052008-04-26 14:05:58 -03007399 }
7400}
7401
Linus Torvalds1da177e2005-04-16 15:20:36 -07007402/* stuff which needs working i2c */
7403int saa7134_board_init2(struct saa7134_dev *dev)
7404{
7405 unsigned char buf;
7406 int board;
Mauro Carvalho Chehabc117d052008-04-26 14:05:58 -03007407
Mauro Carvalho Chehabb9348352009-02-08 09:33:15 -03007408 /* Put here the code that enables the chips that are needed
7409 for analog mode and doesn't depend on the tuner attachment.
7410 It is also a good idea to get tuner type from eeprom, etc before
7411 initializing tuner, since we can avoid loading tuner driver
7412 on devices that has TUNER_ABSENT
7413 */
Linus Torvalds1da177e2005-04-16 15:20:36 -07007414 switch (dev->board) {
7415 case SAA7134_BOARD_BMK_MPEX_NOTUNER:
7416 case SAA7134_BOARD_BMK_MPEX_TUNER:
Mauro Carvalho Chehabb9348352009-02-08 09:33:15 -03007417 /* Checks if the device has a tuner at 0x60 addr
7418 If the device doesn't have a tuner, TUNER_ABSENT
7419 will be used at tuner_type, avoiding loading tuner
7420 without needing it
7421 */
Linus Torvalds1da177e2005-04-16 15:20:36 -07007422 dev->i2c_client.addr = 0x60;
Mauro Carvalho Chehabc117d052008-04-26 14:05:58 -03007423 board = (i2c_master_recv(&dev->i2c_client, &buf, 0) < 0)
Linus Torvalds1da177e2005-04-16 15:20:36 -07007424 ? SAA7134_BOARD_BMK_MPEX_NOTUNER
7425 : SAA7134_BOARD_BMK_MPEX_TUNER;
7426 if (board == dev->board)
7427 break;
7428 dev->board = board;
7429 printk("%s: board type fixup: %s\n", dev->name,
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07007430 saa7134_boards[dev->board].name);
Linus Torvalds1da177e2005-04-16 15:20:36 -07007431 dev->tuner_type = saa7134_boards[dev->board].tuner_type;
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07007432
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07007433 break;
Hartmut Hackmann2cf36ac2005-11-08 21:36:32 -08007434 case SAA7134_BOARD_MD7134:
Mauro Carvalho Chehabc117d052008-04-26 14:05:58 -03007435 {
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07007436 u8 subaddr;
7437 u8 data[3];
7438 int ret, tuner_t;
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07007439 struct i2c_msg msg[] = {{.addr=0x50, .flags=0, .buf=&subaddr, .len = 1},
7440 {.addr=0x50, .flags=I2C_M_RD, .buf=data, .len = 3}};
Mauro Carvalho Chehabb9348352009-02-08 09:33:15 -03007441
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07007442 subaddr= 0x14;
7443 tuner_t = 0;
Mauro Carvalho Chehabb9348352009-02-08 09:33:15 -03007444
7445 /* Retrieve device data from eeprom, checking for the
7446 proper tuner_type.
7447 */
Mauro Carvalho Chehab330a1152005-07-12 13:59:01 -07007448 ret = i2c_transfer(&dev->i2c_adap, msg, 2);
7449 if (ret != 2) {
7450 printk(KERN_ERR "EEPROM read failure\n");
7451 } else if ((data[0] != 0) && (data[0] != 0xff)) {
7452 /* old config structure */
7453 subaddr = data[0] + 2;
7454 msg[1].len = 2;
7455 i2c_transfer(&dev->i2c_adap, msg, 2);
7456 tuner_t = (data[0] << 8) + data[1];
7457 switch (tuner_t){
7458 case 0x0103:
7459 dev->tuner_type = TUNER_PHILIPS_PAL;
7460 break;
7461 case 0x010C:
7462 dev->tuner_type = TUNER_PHILIPS_FM1216ME_MK3;
7463 break;
7464 default:
7465 printk(KERN_ERR "%s Cant determine tuner type %x from EEPROM\n", dev->name, tuner_t);
7466 }
7467 } else if ((data[1] != 0) && (data[1] != 0xff)) {
7468 /* new config structure */
7469 subaddr = data[1] + 1;
7470 msg[1].len = 1;
7471 i2c_transfer(&dev->i2c_adap, msg, 2);
7472 subaddr = data[0] + 1;
7473 msg[1].len = 2;
7474 i2c_transfer(&dev->i2c_adap, msg, 2);
7475 tuner_t = (data[1] << 8) + data[0];
7476 switch (tuner_t) {
7477 case 0x0005:
7478 dev->tuner_type = TUNER_PHILIPS_FM1216ME_MK3;
7479 break;
7480 case 0x001d:
7481 dev->tuner_type = TUNER_PHILIPS_FMD1216ME_MK3;
7482 printk(KERN_INFO "%s Board has DVB-T\n", dev->name);
7483 break;
7484 default:
7485 printk(KERN_ERR "%s Cant determine tuner type %x from EEPROM\n", dev->name, tuner_t);
7486 }
7487 } else {
7488 printk(KERN_ERR "%s unexpected config structure\n", dev->name);
7489 }
7490
7491 printk(KERN_INFO "%s Tuner type is %d\n", dev->name, dev->tuner_type);
Linus Torvalds1da177e2005-04-16 15:20:36 -07007492 break;
Mauro Carvalho Chehabc117d052008-04-26 14:05:58 -03007493 }
Hartmut Hackmann2cf36ac2005-11-08 21:36:32 -08007494 case SAA7134_BOARD_PHILIPS_EUROPA:
Hartmut Hackmann6ab465a2008-04-22 14:42:11 -03007495 if (dev->autodetected && (dev->eedata[0x41] == 0x1c)) {
7496 /* Reconfigure board as Snake reference design */
7497 dev->board = SAA7134_BOARD_PHILIPS_SNAKE;
7498 dev->tuner_type = saa7134_boards[dev->board].tuner_type;
7499 printk(KERN_INFO "%s: Reconfigured board as %s\n",
7500 dev->name, saa7134_boards[dev->board].name);
7501 break;
7502 }
Mauro Carvalho Chehabb9348352009-02-08 09:33:15 -03007503 /* break intentionally omitted */
Hartmut Hackmann2cf36ac2005-11-08 21:36:32 -08007504 case SAA7134_BOARD_VIDEOMATE_DVBT_300:
Hartmut Hackmanncf146ca2006-10-02 20:49:24 -03007505 case SAA7134_BOARD_ASUS_EUROPA2_HYBRID:
Danny Woode3c6e1a2009-09-20 12:14:21 -03007506 case SAA7134_BOARD_ASUS_EUROPA_HYBRID:
Vadim Catana128fe952010-05-29 12:49:16 -03007507 case SAA7134_BOARD_TECHNOTREND_BUDGET_T3000:
Mauro Carvalho Chehabc117d052008-04-26 14:05:58 -03007508 {
7509
Mauro Carvalho Chehabb9348352009-02-08 09:33:15 -03007510 /* The Philips EUROPA based hybrid boards have the tuner
7511 connected through the channel decoder. We have to make it
7512 transparent to find it
Mauro Carvalho Chehab4ac97912005-11-08 21:37:43 -08007513 */
Hartmut Hackmann2cf36ac2005-11-08 21:36:32 -08007514 u8 data[] = { 0x07, 0x02};
7515 struct i2c_msg msg = {.addr=0x08, .flags=0, .buf=data, .len = sizeof(data)};
7516 i2c_transfer(&dev->i2c_adap, &msg, 1);
7517
Hartmut Hackmann2cf36ac2005-11-08 21:36:32 -08007518 break;
Mauro Carvalho Chehabc117d052008-04-26 14:05:58 -03007519 }
Hartmut Hackmann90e9df72005-11-08 21:38:42 -08007520 case SAA7134_BOARD_PHILIPS_TIGER:
Hartmut Hackmann58ef4f92007-04-27 12:31:12 -03007521 case SAA7134_BOARD_PHILIPS_TIGER_S:
Mauro Carvalho Chehabc117d052008-04-26 14:05:58 -03007522 {
Hartmut Hackmann58ef4f92007-04-27 12:31:12 -03007523 u8 data[] = { 0x3c, 0x33, 0x60};
Hartmut Hackmann58ef4f92007-04-27 12:31:12 -03007524 struct i2c_msg msg = {.addr=0x08, .flags=0, .buf=data, .len = sizeof(data)};
Mauro Carvalho Chehabc117d052008-04-26 14:05:58 -03007525 if (dev->autodetected && (dev->eedata[0x49] == 0x50)) {
Hartmut Hackmann58ef4f92007-04-27 12:31:12 -03007526 dev->board = SAA7134_BOARD_PHILIPS_TIGER_S;
7527 printk(KERN_INFO "%s: Reconfigured board as %s\n",
7528 dev->name, saa7134_boards[dev->board].name);
7529 }
Mauro Carvalho Chehabc117d052008-04-26 14:05:58 -03007530 if (dev->board == SAA7134_BOARD_PHILIPS_TIGER_S) {
7531 dev->tuner_type = TUNER_PHILIPS_TDA8290;
Hartmut Hackmann58ef4f92007-04-27 12:31:12 -03007532
Hartmut Hackmann58ef4f92007-04-27 12:31:12 -03007533 data[2] = 0x68;
Mauro Carvalho Chehabc117d052008-04-26 14:05:58 -03007534 i2c_transfer(&dev->i2c_adap, &msg, 1);
Mauro Carvalho Chehabb9348352009-02-08 09:33:15 -03007535 break;
Hartmut Hackmann58ef4f92007-04-27 12:31:12 -03007536 }
7537 i2c_transfer(&dev->i2c_adap, &msg, 1);
Hartmut Hackmann58ef4f92007-04-27 12:31:12 -03007538 break;
Mauro Carvalho Chehabc117d052008-04-26 14:05:58 -03007539 }
Mauro Carvalho Chehabb9348352009-02-08 09:33:15 -03007540 case SAA7134_BOARD_ASUSTeK_TVFM7135:
7541 /* The card below is detected as card=53, but is different */
Hermann Pitton0b17d0e2008-07-12 12:27:59 -03007542 if (dev->autodetected && (dev->eedata[0x27] == 0x03)) {
7543 dev->board = SAA7134_BOARD_ASUSTeK_P7131_ANALOG;
7544 printk(KERN_INFO "%s: P7131 analog only, using "
7545 "entry of %s\n",
7546 dev->name, saa7134_boards[dev->board].name);
Jean Delvarec6ebc6c2010-03-14 22:57:56 -03007547
7548 /* IR init has already happened for other cards, so
7549 * we have to catch up. */
7550 dev->has_remote = SAA7134_REMOTE_GPIO;
7551 saa7134_input_init1(dev);
Hermann Pitton0b17d0e2008-07-12 12:27:59 -03007552 }
7553 break;
Michael Krufkyb5f05062009-08-03 16:51:33 -03007554 case SAA7134_BOARD_HAUPPAUGE_HVR1150:
Michael Krufky0e316ec2009-08-03 16:51:33 -03007555 case SAA7134_BOARD_HAUPPAUGE_HVR1120:
Michael Krufkyf9996c92009-02-28 17:45:17 -03007556 hauppauge_eeprom(dev, dev->eedata+0x80);
7557 break;
Michael Krufky993efa72007-11-15 10:34:33 -03007558 case SAA7134_BOARD_HAUPPAUGE_HVR1110:
7559 hauppauge_eeprom(dev, dev->eedata+0x80);
7560 /* break intentionally omitted */
Hartmut Hackmann587d2fd2006-10-06 19:13:50 -03007561 case SAA7134_BOARD_PINNACLE_PCTV_310i:
Simon Farnsworthb39423a2007-05-01 10:01:20 -03007562 case SAA7134_BOARD_KWORLD_DVBT_210:
Peter Hartshorn3dfb7292006-02-07 06:49:13 -02007563 case SAA7134_BOARD_TEVION_DVBT_220RF:
Hermann Pitton028165a2008-10-04 21:37:36 -03007564 case SAA7134_BOARD_ASUSTeK_TIGER:
Hartmut Hackmannd4b0aba2005-11-08 21:38:44 -08007565 case SAA7134_BOARD_ASUSTeK_P7131_DUAL:
Hartmut Hackmannf3eec0c02007-03-14 20:33:55 -03007566 case SAA7134_BOARD_ASUSTeK_P7131_HYBRID_LNA:
Hartmut Hackmann5eda2272006-08-07 14:03:32 -03007567 case SAA7134_BOARD_MEDION_MD8800_QUADRO:
Hermann Pitton4ba24372008-01-20 19:27:51 -03007568 case SAA7134_BOARD_AVERMEDIA_SUPER_007:
7569 case SAA7134_BOARD_TWINHAN_DTV_DVB_3056:
Hermann Pitton7b5b3f12008-04-22 14:42:12 -03007570 case SAA7134_BOARD_CREATIX_CTX953:
Mauro Carvalho Chehabc117d052008-04-26 14:05:58 -03007571 {
Peter Hartshorn3dfb7292006-02-07 06:49:13 -02007572 /* this is a hybrid board, initialize to analog mode
7573 * and configure firmware eeprom address
7574 */
Hartmut Hackmann58ef4f92007-04-27 12:31:12 -03007575 u8 data[] = { 0x3c, 0x33, 0x60};
Hartmut Hackmann90e9df72005-11-08 21:38:42 -08007576 struct i2c_msg msg = {.addr=0x08, .flags=0, .buf=data, .len = sizeof(data)};
7577 i2c_transfer(&dev->i2c_adap, &msg, 1);
Hartmut Hackmann90e9df72005-11-08 21:38:42 -08007578 break;
Mauro Carvalho Chehabc117d052008-04-26 14:05:58 -03007579 }
hermann pitton301e9d62008-09-14 17:49:14 -03007580 case SAA7134_BOARD_ASUSTeK_TIGER_3IN1:
7581 {
7582 u8 data[] = { 0x3c, 0x33, 0x60};
7583 struct i2c_msg msg = {.addr = 0x0b, .flags = 0, .buf = data,
7584 .len = sizeof(data)};
7585 i2c_transfer(&dev->i2c_adap, &msg, 1);
7586 break;
7587 }
Nico Sabbi420f32f2006-03-03 12:11:28 -03007588 case SAA7134_BOARD_FLYDVB_TRIO:
Mauro Carvalho Chehabc117d052008-04-26 14:05:58 -03007589 {
Lukas Karasd995a182009-11-24 12:06:52 -03007590 u8 temp = 0;
7591 int rc;
Hartmut Hackmann293cdab2006-02-27 21:08:07 -03007592 u8 data[] = { 0x3c, 0x33, 0x62};
7593 struct i2c_msg msg = {.addr=0x09, .flags=0, .buf=data, .len = sizeof(data)};
7594 i2c_transfer(&dev->i2c_adap, &msg, 1);
Lukas Karasd995a182009-11-24 12:06:52 -03007595
7596 /*
7597 * send weak up message to pic16C505 chip
7598 * @ LifeView FlyDVB Trio
7599 */
7600 msg.buf = &temp;
7601 msg.addr = 0x0b;
7602 msg.len = 1;
7603 if (1 != i2c_transfer(&dev->i2c_adap, &msg, 1)) {
7604 printk(KERN_WARNING "%s: send wake up byte to pic16C505"
7605 "(IR chip) failed\n", dev->name);
7606 } else {
7607 msg.flags = I2C_M_RD;
7608 rc = i2c_transfer(&dev->i2c_adap, &msg, 1);
7609 printk(KERN_INFO "%s: probe IR chip @ i2c 0x%02x: %s\n",
7610 dev->name, msg.addr,
7611 (1 == rc) ? "yes" : "no");
7612 if (rc == 1)
7613 dev->has_remote = SAA7134_REMOTE_I2C;
7614 }
Hartmut Hackmann293cdab2006-02-27 21:08:07 -03007615 break;
Mauro Carvalho Chehabc117d052008-04-26 14:05:58 -03007616 }
Hartmut Hackmanndf42eaf2006-02-07 06:49:10 -02007617 case SAA7134_BOARD_ADS_DUO_CARDBUS_PTV331:
Hartmut Hackmannd95b8942006-03-27 19:39:30 -03007618 case SAA7134_BOARD_FLYDVBT_HYBRID_CARDBUS:
Mauro Carvalho Chehabc117d052008-04-26 14:05:58 -03007619 {
Hartmut Hackmann58ef4f92007-04-27 12:31:12 -03007620 /* initialize analog mode */
Hartmut Hackmann58ef4f92007-04-27 12:31:12 -03007621 u8 data[] = { 0x3c, 0x33, 0x6a};
Hartmut Hackmanndf42eaf2006-02-07 06:49:10 -02007622 struct i2c_msg msg = {.addr=0x08, .flags=0, .buf=data, .len = sizeof(data)};
7623 i2c_transfer(&dev->i2c_adap, &msg, 1);
Hartmut Hackmanndf42eaf2006-02-07 06:49:10 -02007624 break;
Mauro Carvalho Chehabc117d052008-04-26 14:05:58 -03007625 }
Hartmut Hackmann550a9a52006-11-15 21:31:54 -03007626 case SAA7134_BOARD_CINERGY_HT_PCMCIA:
Michael Krufky9de271e2007-01-16 18:36:40 -03007627 case SAA7134_BOARD_CINERGY_HT_PCI:
Mauro Carvalho Chehabc117d052008-04-26 14:05:58 -03007628 {
Hartmut Hackmann58ef4f92007-04-27 12:31:12 -03007629 /* initialize analog mode */
Hartmut Hackmann58ef4f92007-04-27 12:31:12 -03007630 u8 data[] = { 0x3c, 0x33, 0x68};
Hartmut Hackmann550a9a52006-11-15 21:31:54 -03007631 struct i2c_msg msg = {.addr=0x08, .flags=0, .buf=data, .len = sizeof(data)};
7632 i2c_transfer(&dev->i2c_adap, &msg, 1);
Hartmut Hackmann550a9a52006-11-15 21:31:54 -03007633 break;
Mauro Carvalho Chehabc117d052008-04-26 14:05:58 -03007634 }
Hartmut Hackmanncbb94522006-10-30 20:00:16 -03007635 case SAA7134_BOARD_VIDEOMATE_DVBT_200:
7636 case SAA7134_BOARD_VIDEOMATE_DVBT_200A:
7637 /* The T200 and the T200A share the same pci id. Consequently,
7638 * we are going to query eeprom to try to find out which one we
7639 * are actually looking at. */
7640
7641 /* Don't do this if the board was specifically selected with an
7642 * insmod option or if we have the default configuration T200*/
Mauro Carvalho Chehabb9348352009-02-08 09:33:15 -03007643 if (!dev->autodetected || (dev->eedata[0x41] == 0xd0))
Hartmut Hackmanncbb94522006-10-30 20:00:16 -03007644 break;
Mauro Carvalho Chehabb9348352009-02-08 09:33:15 -03007645 if (dev->eedata[0x41] == 0x02) {
Hartmut Hackmanncbb94522006-10-30 20:00:16 -03007646 /* Reconfigure board as T200A */
7647 dev->board = SAA7134_BOARD_VIDEOMATE_DVBT_200A;
7648 dev->tuner_type = saa7134_boards[dev->board].tuner_type;
7649 dev->tda9887_conf = saa7134_boards[dev->board].tda9887_conf;
7650 printk(KERN_INFO "%s: Reconfigured board as %s\n",
7651 dev->name, saa7134_boards[dev->board].name);
7652 } else {
7653 printk(KERN_WARNING "%s: Unexpected tuner type info: %x in eeprom\n",
7654 dev->name, dev->eedata[0x41]);
7655 break;
7656 }
7657 break;
Mauro Carvalho Chehabb9348352009-02-08 09:33:15 -03007658 case SAA7134_BOARD_ADS_INSTANT_HDTV_PCI:
7659 case SAA7134_BOARD_KWORLD_ATSC110:
7660 {
7661 struct i2c_msg msg = { .addr = 0x0a, .flags = 0 };
7662 int i;
7663 static u8 buffer[][2] = {
7664 { 0x10, 0x12 },
7665 { 0x13, 0x04 },
7666 { 0x16, 0x00 },
7667 { 0x14, 0x04 },
7668 { 0x17, 0x00 },
7669 };
7670
7671 for (i = 0; i < ARRAY_SIZE(buffer); i++) {
7672 msg.buf = &buffer[i][0];
7673 msg.len = ARRAY_SIZE(buffer[0]);
7674 if (i2c_transfer(&dev->i2c_adap, &msg, 1) != 1)
7675 printk(KERN_WARNING
7676 "%s: Unable to enable tuner(%i).\n",
7677 dev->name, i);
7678 }
7679 break;
7680 }
Dmitri Belimovb400f092010-03-30 03:02:17 -03007681 case SAA7134_BOARD_BEHOLD_H6:
7682 {
7683 u8 data[] = { 0x09, 0x9f, 0x86, 0x11};
7684 struct i2c_msg msg = {.addr = 0x61, .flags = 0, .buf = data,
7685 .len = sizeof(data)};
7686
7687 /* The tuner TUNER_PHILIPS_FMD1216MEX_MK3 after hardware */
7688 /* start has disabled IF and enabled DVB-T. When saa7134 */
7689 /* scan I2C devices it not detect IF tda9887 and can`t */
7690 /* watch TV without software reboot. For solve this problem */
7691 /* switch the tuner to analog TV mode manually. */
7692 if (i2c_transfer(&dev->i2c_adap, &msg, 1) != 1)
7693 printk(KERN_WARNING
7694 "%s: Unable to enable IF of the tuner.\n",
7695 dev->name);
7696 break;
7697 }
Mauro Carvalho Chehab68541cd2010-10-03 05:27:59 -03007698 case SAA7134_BOARD_KWORLD_PCI_SBTVD_FULLSEG:
Mauro Carvalho Chehab68541cd2010-10-03 05:27:59 -03007699 saa_writel(SAA7134_GPIO_GPMODE0 >> 2, 0x4000);
7700 saa_writel(SAA7134_GPIO_GPSTATUS0 >> 2, 0x4000);
7701
Mauro Carvalho Chehab61830402011-01-13 14:24:44 -03007702 saa7134_set_gpio(dev, 27, 0);
Mauro Carvalho Chehab68541cd2010-10-03 05:27:59 -03007703 break;
Mauro Carvalho Chehabb9348352009-02-08 09:33:15 -03007704 } /* switch() */
7705
7706 /* initialize tuner */
7707 if (TUNER_ABSENT != dev->tuner_type) {
7708 int has_demod = (dev->tda9887_conf & TDA9887_PRESENT);
7709
7710 /* Note: radio tuner address is always filled in,
7711 so we do not need to probe for a radio tuner device. */
7712 if (dev->radio_type != UNSET)
Hans Verkuile6574f22009-04-01 03:57:53 -03007713 v4l2_i2c_new_subdev(&dev->v4l2_dev,
Laurent Pinchart9a1f8b32010-09-24 10:16:44 -03007714 &dev->i2c_adap, "tuner",
Hans Verkuil53dacb12009-08-10 02:49:08 -03007715 dev->radio_addr, NULL);
Mauro Carvalho Chehabb9348352009-02-08 09:33:15 -03007716 if (has_demod)
Hans Verkuil53dacb12009-08-10 02:49:08 -03007717 v4l2_i2c_new_subdev(&dev->v4l2_dev,
Laurent Pinchart9a1f8b32010-09-24 10:16:44 -03007718 &dev->i2c_adap, "tuner",
Hans Verkuil53dacb12009-08-10 02:49:08 -03007719 0, v4l2_i2c_tuner_addrs(ADDRS_DEMOD));
Mauro Carvalho Chehabb9348352009-02-08 09:33:15 -03007720 if (dev->tuner_addr == ADDR_UNSET) {
7721 enum v4l2_i2c_tuner_type type =
7722 has_demod ? ADDRS_TV_WITH_DEMOD : ADDRS_TV;
7723
Hans Verkuil53dacb12009-08-10 02:49:08 -03007724 v4l2_i2c_new_subdev(&dev->v4l2_dev,
Laurent Pinchart9a1f8b32010-09-24 10:16:44 -03007725 &dev->i2c_adap, "tuner",
Hans Verkuil53dacb12009-08-10 02:49:08 -03007726 0, v4l2_i2c_tuner_addrs(type));
Mauro Carvalho Chehabb9348352009-02-08 09:33:15 -03007727 } else {
Hans Verkuile6574f22009-04-01 03:57:53 -03007728 v4l2_i2c_new_subdev(&dev->v4l2_dev,
Laurent Pinchart9a1f8b32010-09-24 10:16:44 -03007729 &dev->i2c_adap, "tuner",
Hans Verkuil53dacb12009-08-10 02:49:08 -03007730 dev->tuner_addr, NULL);
Mauro Carvalho Chehabb9348352009-02-08 09:33:15 -03007731 }
7732 }
7733
7734 saa7134_tuner_setup(dev);
7735
7736 switch (dev->board) {
Dmitry Belimovb34dddb2008-04-23 14:09:08 -03007737 case SAA7134_BOARD_BEHOLD_COLUMBUS_TVFM:
Oldřich Jedličkad46de9d2009-04-14 15:47:17 -03007738 case SAA7134_BOARD_AVERMEDIA_CARDBUS_501:
Mauro Carvalho Chehabc117d052008-04-26 14:05:58 -03007739 {
Dmitry Belimovb34dddb2008-04-23 14:09:08 -03007740 struct v4l2_priv_tun_config tea5767_cfg;
7741 struct tea5767_ctrl ctl;
7742
7743 dev->i2c_client.addr = 0xC0;
7744 /* set TEA5767(analog FM) defines */
7745 memset(&ctl, 0, sizeof(ctl));
7746 ctl.xtal_freq = TEA5767_HIGH_LO_13MHz;
7747 tea5767_cfg.tuner = TUNER_TEA5767;
7748 tea5767_cfg.priv = &ctl;
Hans Verkuilfac69862009-01-17 12:17:14 -03007749 saa_call_all(dev, tuner, s_config, &tea5767_cfg);
Dmitry Belimovb34dddb2008-04-23 14:09:08 -03007750 break;
Linus Torvalds1da177e2005-04-16 15:20:36 -07007751 }
Mauro Carvalho Chehabc117d052008-04-26 14:05:58 -03007752 } /* switch() */
Mauro Carvalho Chehabbc36a682008-04-22 14:45:27 -03007753
Linus Torvalds1da177e2005-04-16 15:20:36 -07007754 return 0;
7755}