3 * device driver for philips saa7134 based TV cards
6 * (c) 2001-04 Gerd Knorr <kraxel@bytesex.org> [SuSE Labs]
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.
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.
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.
23 #include <linux/init.h>
24 #include <linux/module.h>
26 #include "saa7134-reg.h"
28 #include <media/v4l2-common.h>
30 /* commly used strings */
31 static char name_mute[] = "mute";
32 static char name_radio[] = "Radio";
33 static char name_tv[] = "Television";
34 static char name_tv_mono[] = "TV (mono only)";
35 static char name_comp1[] = "Composite1";
36 static char name_comp2[] = "Composite2";
37 static char name_comp3[] = "Composite3";
38 static char name_comp4[] = "Composite4";
39 static char name_svideo[] = "S-Video";
41 /* ------------------------------------------------------------------ */
42 /* board config info */
44 struct saa7134_board saa7134_boards[] = {
45 [SAA7134_BOARD_UNKNOWN] = {
46 .name = "UNKNOWN/GENERIC",
47 .audio_clock = 0x00187de7,
48 .tuner_type = TUNER_ABSENT,
50 .tuner_addr = ADDR_UNSET,
51 .radio_addr = ADDR_UNSET,
59 [SAA7134_BOARD_PROTEUS_PRO] = {
61 .name = "Proteus Pro [philips reference design]",
62 .audio_clock = 0x00187de7,
63 .tuner_type = TUNER_PHILIPS_PAL,
65 .tuner_addr = ADDR_UNSET,
66 .radio_addr = ADDR_UNSET,
88 [SAA7134_BOARD_FLYVIDEO3000] = {
89 /* "Marco d'Itri" <md@Linux.IT> */
90 .name = "LifeView FlyVIDEO3000",
91 .audio_clock = 0x00200000,
92 .tuner_type = TUNER_PHILIPS_PAL,
94 .tuner_addr = ADDR_UNSET,
95 .radio_addr = ADDR_UNSET,
105 .name = name_tv_mono,
137 [SAA7134_BOARD_FLYVIDEO2000] = {
138 /* "TC Wan" <tcwan@cs.usm.my> */
139 .name = "LifeView/Typhoon FlyVIDEO2000",
140 .audio_clock = 0x00200000,
141 .tuner_type = TUNER_LG_PAL_NEW_TAPC,
143 .tuner_addr = ADDR_UNSET,
144 .radio_addr = ADDR_UNSET,
180 [SAA7134_BOARD_FLYTVPLATINUM_MINI] = {
181 /* "Arnaud Quette" <aquette@free.fr> */
182 .name = "LifeView FlyTV Platinum Mini",
183 .audio_clock = 0x00200000,
184 .tuner_type = TUNER_PHILIPS_TDA8290,
186 .tuner_addr = ADDR_UNSET,
187 .radio_addr = ADDR_UNSET,
195 .name = name_comp1, /* Composite signal on S-Video input */
199 .name = name_comp2, /* Composite input */
208 [SAA7134_BOARD_FLYTVPLATINUM_FM] = {
209 /* LifeView FlyTV Platinum FM (LR214WF) */
210 /* "Peter Missel <peter.missel@onlinehome.de> */
211 .name = "LifeView FlyTV Platinum FM",
212 .audio_clock = 0x00200000,
213 .tuner_type = TUNER_PHILIPS_TDA8290,
215 .tuner_addr = ADDR_UNSET,
216 .radio_addr = ADDR_UNSET,
218 .gpiomask = 0x1E000, /* Set GP16 and unused 15,14,13 to Output */
223 .gpio = 0x10000, /* GP16=1 selects TV input */
226 /* .name = name_tv_mono,
232 */ .name = name_comp1, /* Composite signal on S-Video input */
235 /* .gpio = 0x4000, */
237 .name = name_comp2, /* Composite input */
240 /* .gpio = 0x4000, */
242 .name = name_svideo, /* S-Video signal on S-Video input */
245 /* .gpio = 0x4000, */
250 .gpio = 0x00000, /* GP16=0 selects FM radio antenna */
258 [SAA7134_BOARD_EMPRESS] = {
259 /* "Gert Vervoort" <gert.vervoort@philips.com> */
261 .audio_clock = 0x00187de7,
262 .tuner_type = TUNER_PHILIPS_PAL,
264 .tuner_addr = ADDR_UNSET,
265 .radio_addr = ADDR_UNSET,
285 .mpeg = SAA7134_MPEG_EMPRESS,
286 .video_out = CCIR656,
288 [SAA7134_BOARD_MONSTERTV] = {
289 /* "K.Ohta" <alpha292@bremen.or.jp> */
290 .name = "SKNet Monster TV",
291 .audio_clock = 0x00187de7,
292 .tuner_type = TUNER_PHILIPS_NTSC_M,
294 .tuner_addr = ADDR_UNSET,
295 .radio_addr = ADDR_UNSET,
316 [SAA7134_BOARD_MD9717] = {
317 .name = "Tevion MD 9717",
318 .audio_clock = 0x00200000,
319 .tuner_type = TUNER_PHILIPS_PAL,
321 .tuner_addr = ADDR_UNSET,
322 .radio_addr = ADDR_UNSET,
329 /* workaround for problems with normal TV sound */
330 .name = name_tv_mono,
352 [SAA7134_BOARD_TVSTATION_RDS] = {
353 /* Typhoon TV Tuner RDS: Art.Nr. 50694 */
354 .name = "KNC One TV-Station RDS / Typhoon TV Tuner RDS",
355 .audio_clock = 0x00200000,
356 .tuner_type = TUNER_PHILIPS_FM1216ME_MK3,
358 .tuner_addr = ADDR_UNSET,
359 .radio_addr = ADDR_UNSET,
360 .tda9887_conf = TDA9887_PRESENT,
367 .name = name_tv_mono,
382 .name = "CVid over SVid",
391 [SAA7134_BOARD_TVSTATION_DVR] = {
392 .name = "KNC One TV-Station DVR",
393 .audio_clock = 0x00200000,
394 .tuner_type = TUNER_PHILIPS_FM1216ME_MK3,
396 .tuner_addr = ADDR_UNSET,
397 .radio_addr = ADDR_UNSET,
398 .tda9887_conf = TDA9887_PRESENT,
399 .gpiomask = 0x820000,
422 .mpeg = SAA7134_MPEG_EMPRESS,
423 .video_out = CCIR656,
425 [SAA7134_BOARD_CINERGY400] = {
426 .name = "Terratec Cinergy 400 TV",
427 .audio_clock = 0x00200000,
428 .tuner_type = TUNER_PHILIPS_PAL,
430 .tuner_addr = ADDR_UNSET,
431 .radio_addr = ADDR_UNSET,
446 .name = name_comp2, /* CVideo over SVideo Connector */
451 [SAA7134_BOARD_MD5044] = {
452 .name = "Medion 5044",
453 .audio_clock = 0x00187de7, /* was: 0x00200000, */
454 .tuner_type = TUNER_PHILIPS_FM1216ME_MK3,
456 .tuner_addr = ADDR_UNSET,
457 .radio_addr = ADDR_UNSET,
458 .tda9887_conf = TDA9887_PRESENT,
465 /* workaround for problems with normal TV sound */
466 .name = name_tv_mono,
488 [SAA7134_BOARD_KWORLD] = {
489 .name = "Kworld/KuroutoShikou SAA7130-TVPCI",
490 .audio_clock = 0x00187de7,
491 .tuner_type = TUNER_PHILIPS_NTSC_M,
493 .tuner_addr = ADDR_UNSET,
494 .radio_addr = ADDR_UNSET,
510 [SAA7134_BOARD_CINERGY600] = {
511 .name = "Terratec Cinergy 600 TV",
512 .audio_clock = 0x00200000,
513 .tuner_type = TUNER_PHILIPS_PAL,
515 .tuner_addr = ADDR_UNSET,
516 .radio_addr = ADDR_UNSET,
517 .tda9887_conf = TDA9887_PRESENT,
532 .name = name_comp2, /* CVideo over SVideo Connector */
541 [SAA7134_BOARD_MD7134] = {
542 .name = "Medion 7134",
543 .audio_clock = 0x00187de7,
544 .tuner_type = TUNER_PHILIPS_FMD1216ME_MK3,
546 .tuner_addr = ADDR_UNSET,
547 .radio_addr = ADDR_UNSET,
548 .tda9887_conf = TDA9887_PRESENT,
549 .mpeg = SAA7134_MPEG_DVB,
569 [SAA7134_BOARD_TYPHOON_90031] = {
570 /* aka Typhoon "TV+Radio", Art.Nr 90031 */
571 /* Tom Zoerner <tomzo at users sourceforge net> */
572 .name = "Typhoon TV+Radio 90031",
573 .audio_clock = 0x00200000,
574 .tuner_type = TUNER_PHILIPS_PAL,
576 .tuner_addr = ADDR_UNSET,
577 .radio_addr = ADDR_UNSET,
578 .tda9887_conf = TDA9887_PRESENT,
598 [SAA7134_BOARD_ELSA] = {
599 .name = "ELSA EX-VISION 300TV",
600 .audio_clock = 0x00187de7,
601 .tuner_type = TUNER_HITACHI_NTSC,
603 .tuner_addr = ADDR_UNSET,
604 .radio_addr = ADDR_UNSET,
620 [SAA7134_BOARD_ELSA_500TV] = {
621 .name = "ELSA EX-VISION 500TV",
622 .audio_clock = 0x00187de7,
623 .tuner_type = TUNER_HITACHI_NTSC,
625 .tuner_addr = ADDR_UNSET,
626 .radio_addr = ADDR_UNSET,
637 .name = name_tv_mono,
643 [SAA7134_BOARD_ASUSTeK_TVFM7134] = {
644 .name = "ASUS TV-FM 7134",
645 .audio_clock = 0x00187de7,
646 .tuner_type = TUNER_PHILIPS_FM1216ME_MK3,
648 .tuner_addr = ADDR_UNSET,
649 .radio_addr = ADDR_UNSET,
650 .tda9887_conf = TDA9887_PRESENT,
670 [SAA7134_BOARD_ASUSTeK_TVFM7135] = {
671 .name = "ASUS TV-FM 7135",
672 .audio_clock = 0x00187de7,
673 .tuner_type = TUNER_PHILIPS_TDA8290,
675 .tuner_addr = ADDR_UNSET,
676 .radio_addr = ADDR_UNSET,
677 .gpiomask = 0x200000,
706 [SAA7134_BOARD_VA1000POWER] = {
707 .name = "AOPEN VA1000 POWER",
708 .audio_clock = 0x00187de7,
709 .tuner_type = TUNER_PHILIPS_NTSC,
711 .tuner_addr = ADDR_UNSET,
712 .radio_addr = ADDR_UNSET,
728 [SAA7134_BOARD_10MOONSTVMASTER] = {
729 /* "lilicheng" <llc@linuxfans.org> */
730 .name = "10MOONS PCI TV CAPTURE CARD",
731 .audio_clock = 0x00200000,
732 .tuner_type = TUNER_LG_PAL_NEW_TAPC,
734 .tuner_addr = ADDR_UNSET,
735 .radio_addr = ADDR_UNSET,
770 [SAA7134_BOARD_BMK_MPEX_NOTUNER] = {
771 /* "Andrew de Quincey" <adq@lidskialf.net> */
772 .name = "BMK MPEX No Tuner",
773 .audio_clock = 0x200000,
774 .tuner_type = TUNER_ABSENT,
776 .tuner_addr = ADDR_UNSET,
777 .radio_addr = ADDR_UNSET,
799 .mpeg = SAA7134_MPEG_EMPRESS,
800 .video_out = CCIR656,
802 [SAA7134_BOARD_VIDEOMATE_TV] = {
803 .name = "Compro VideoMate TV",
804 .audio_clock = 0x00187de7,
805 .tuner_type = TUNER_PHILIPS_NTSC_M,
807 .tuner_addr = ADDR_UNSET,
808 .radio_addr = ADDR_UNSET,
824 [SAA7134_BOARD_VIDEOMATE_TV_GOLD_PLUS] = {
825 .name = "Compro VideoMate TV Gold+",
826 .audio_clock = 0x00187de7,
827 .tuner_type = TUNER_PHILIPS_NTSC_M,
828 .gpiomask = 0x800c0000,
830 .tuner_addr = ADDR_UNSET,
831 .radio_addr = ADDR_UNSET,
848 }}, /* radio and probably mute is missing */
850 [SAA7134_BOARD_CRONOS_PLUS] = {
859 .name = "Matrox CronosPlus",
860 .tuner_type = TUNER_ABSENT,
862 .tuner_addr = ADDR_UNSET,
863 .radio_addr = ADDR_UNSET,
887 [SAA7134_BOARD_MD2819] = {
888 .name = "AverMedia M156 / Medion 2819",
889 .audio_clock = 0x00187de7,
890 .tuner_type = TUNER_PHILIPS_FM1216ME_MK3,
892 .tuner_addr = ADDR_UNSET,
893 .radio_addr = ADDR_UNSET,
894 .tda9887_conf = TDA9887_PRESENT,
918 [SAA7134_BOARD_BMK_MPEX_TUNER] = {
919 /* "Greg Wickham <greg.wickham@grangenet.net> */
920 .name = "BMK MPEX Tuner",
921 .audio_clock = 0x200000,
922 .tuner_type = TUNER_PHILIPS_PAL,
924 .tuner_addr = ADDR_UNSET,
925 .radio_addr = ADDR_UNSET,
940 .mpeg = SAA7134_MPEG_EMPRESS,
941 .video_out = CCIR656,
943 [SAA7134_BOARD_ASUSTEK_TVFM7133] = {
944 .name = "ASUS TV-FM 7133",
945 .audio_clock = 0x00187de7,
946 /* probably wrong, the 7133 one is the NTSC version ...
947 * .tuner_type = TUNER_PHILIPS_FM1236_MK3 */
948 .tuner_type = TUNER_LG_NTSC_NEW_TAPC,
950 .tuner_addr = ADDR_UNSET,
951 .radio_addr = ADDR_UNSET,
952 .tda9887_conf = TDA9887_PRESENT,
973 [SAA7134_BOARD_PINNACLE_PCTV_STEREO] = {
974 .name = "Pinnacle PCTV Stereo (saa7134)",
975 .audio_clock = 0x00187de7,
976 .tuner_type = TUNER_MT2032,
978 .tuner_addr = ADDR_UNSET,
979 .radio_addr = ADDR_UNSET,
980 .tda9887_conf = TDA9887_PRESENT | TDA9887_INTERCARRIER | TDA9887_PORT2_ACTIVE,
1000 [SAA7134_BOARD_MANLI_MTV002] = {
1001 /* Ognjen Nastic <ognjen@logosoft.ba> */
1002 .name = "Manli MuchTV M-TV002/Behold TV 403 FM",
1003 .audio_clock = 0x00200000,
1004 .tuner_type = TUNER_PHILIPS_PAL,
1005 .radio_type = UNSET,
1006 .tuner_addr = ADDR_UNSET,
1007 .radio_addr = ADDR_UNSET,
1009 .name = name_svideo,
1027 [SAA7134_BOARD_MANLI_MTV001] = {
1028 /* Ognjen Nastic <ognjen@logosoft.ba> UNTESTED */
1029 .name = "Manli MuchTV M-TV001/Behold TV 401",
1030 .audio_clock = 0x00200000,
1031 .tuner_type = TUNER_PHILIPS_PAL,
1032 .radio_type = UNSET,
1033 .tuner_addr = ADDR_UNSET,
1034 .radio_addr = ADDR_UNSET,
1036 .name = name_svideo,
1054 [SAA7134_BOARD_TG3000TV] = {
1055 /* TransGear 3000TV */
1056 .name = "Nagase Sangyo TransGear 3000TV",
1057 .audio_clock = 0x00187de7,
1058 .tuner_type = TUNER_PHILIPS_NTSC_M,
1059 .radio_type = UNSET,
1060 .tuner_addr = ADDR_UNSET,
1061 .radio_addr = ADDR_UNSET,
1072 .name = name_svideo,
1077 [SAA7134_BOARD_ECS_TVP3XP] = {
1078 .name = "Elitegroup ECS TVP3XP FM1216 Tuner Card(PAL-BG,FM) ",
1079 .audio_clock = 0x187de7, /* xtal 32.1 MHz */
1080 .tuner_type = TUNER_PHILIPS_PAL,
1081 .radio_type = UNSET,
1082 .tuner_addr = ADDR_UNSET,
1083 .radio_addr = ADDR_UNSET,
1090 .name = name_tv_mono,
1099 .name = name_svideo,
1103 .name = "CVid over SVid",
1112 [SAA7134_BOARD_ECS_TVP3XP_4CB5] = {
1113 .name = "Elitegroup ECS TVP3XP FM1236 Tuner Card (NTSC,FM)",
1114 .audio_clock = 0x187de7,
1115 .tuner_type = TUNER_PHILIPS_NTSC,
1116 .radio_type = UNSET,
1117 .tuner_addr = ADDR_UNSET,
1118 .radio_addr = ADDR_UNSET,
1125 .name = name_tv_mono,
1134 .name = name_svideo,
1138 .name = "CVid over SVid",
1147 [SAA7134_BOARD_AVACSSMARTTV] = {
1148 /* Roman Pszonczenko <romka@kolos.math.uni.lodz.pl> */
1149 .name = "AVACS SmartTV",
1150 .audio_clock = 0x00187de7,
1151 .tuner_type = TUNER_PHILIPS_PAL,
1152 .radio_type = UNSET,
1153 .tuner_addr = ADDR_UNSET,
1154 .radio_addr = ADDR_UNSET,
1161 .name = name_tv_mono,
1174 .name = name_svideo,
1184 [SAA7134_BOARD_AVERMEDIA_DVD_EZMAKER] = {
1185 /* Michael Smith <msmith@cbnco.com> */
1186 .name = "AVerMedia DVD EZMaker",
1187 .audio_clock = 0x00187de7,
1188 .tuner_type = TUNER_ABSENT,
1189 .radio_type = UNSET,
1190 .tuner_addr = ADDR_UNSET,
1191 .radio_addr = ADDR_UNSET,
1196 .name = name_svideo,
1200 [SAA7134_BOARD_NOVAC_PRIMETV7133] = {
1201 /* toshii@netbsd.org */
1202 .name = "Noval Prime TV 7133",
1203 .audio_clock = 0x00200000,
1204 .tuner_type = TUNER_ALPS_TSBH1_NTSC,
1205 .radio_type = UNSET,
1206 .tuner_addr = ADDR_UNSET,
1207 .radio_addr = ADDR_UNSET,
1217 .name = name_svideo,
1221 [SAA7134_BOARD_AVERMEDIA_STUDIO_305] = {
1222 .name = "AverMedia AverTV Studio 305",
1223 .audio_clock = 0x00187de7,
1224 .tuner_type = TUNER_PHILIPS_FM1256_IH3,
1225 .radio_type = UNSET,
1226 .tuner_addr = ADDR_UNSET,
1227 .radio_addr = ADDR_UNSET,
1228 .tda9887_conf = TDA9887_PRESENT,
1243 .name = name_svideo,
1256 [SAA7134_BOARD_UPMOST_PURPLE_TV] = {
1257 .name = "UPMOST PURPLE TV",
1258 .audio_clock = 0x00187de7,
1259 .tuner_type = TUNER_PHILIPS_FM1236_MK3,
1260 .radio_type = UNSET,
1261 .tuner_addr = ADDR_UNSET,
1262 .radio_addr = ADDR_UNSET,
1263 .tda9887_conf = TDA9887_PRESENT,
1270 .name = name_svideo,
1275 [SAA7134_BOARD_ITEMS_MTV005] = {
1276 /* Norman Jonas <normanjonas@arcor.de> */
1277 .name = "Items MuchTV Plus / IT-005",
1278 .audio_clock = 0x00187de7,
1279 .tuner_type = TUNER_PHILIPS_PAL,
1280 .radio_type = UNSET,
1281 .tuner_addr = ADDR_UNSET,
1282 .radio_addr = ADDR_UNSET,
1293 .name = name_svideo,
1302 [SAA7134_BOARD_CINERGY200] = {
1303 .name = "Terratec Cinergy 200 TV",
1304 .audio_clock = 0x00200000,
1305 .tuner_type = TUNER_PHILIPS_PAL,
1306 .radio_type = UNSET,
1307 .tuner_addr = ADDR_UNSET,
1308 .radio_addr = ADDR_UNSET,
1319 .name = name_svideo,
1323 .name = name_comp2, /* CVideo over SVideo Connector */
1332 [SAA7134_BOARD_VIDEOMATE_TV_PVR] = {
1333 /* Alain St-Denis <alain@topaze.homeip.net> */
1334 .name = "Compro VideoMate TV PVR/FM",
1335 .audio_clock = 0x00187de7,
1336 .tuner_type = TUNER_PHILIPS_NTSC_M,
1337 .radio_type = UNSET,
1338 .tuner_addr = ADDR_UNSET,
1339 .radio_addr = ADDR_UNSET,
1340 .gpiomask = 0x808c0080,
1342 .name = name_svideo,
1369 [SAA7134_BOARD_SABRENT_SBTTVFM] = {
1370 /* Michael Rodriguez-Torrent <mrtorrent@asu.edu> */
1371 .name = "Sabrent SBT-TVFM (saa7130)",
1372 .audio_clock = 0x00187de7,
1373 .tuner_type = TUNER_PHILIPS_NTSC_M,
1374 .radio_type = UNSET,
1375 .tuner_addr = ADDR_UNSET,
1376 .radio_addr = ADDR_UNSET,
1387 .name = name_svideo,
1396 [SAA7134_BOARD_ZOLID_XPERT_TV7134] = {
1397 /* Helge Jensen <helge.jensen@slog.dk> */
1398 .name = ":Zolid Xpert TV7134",
1399 .audio_clock = 0x00187de7,
1400 .tuner_type = TUNER_PHILIPS_NTSC,
1401 .radio_type = UNSET,
1402 .tuner_addr = ADDR_UNSET,
1403 .radio_addr = ADDR_UNSET,
1405 .name = name_svideo,
1419 [SAA7134_BOARD_EMPIRE_PCI_TV_RADIO_LE] = {
1420 /* "Matteo Az" <matte.az@nospam.libero.it> ;-) */
1421 .name = "Empire PCI TV-Radio LE",
1422 .audio_clock = 0x00187de7,
1423 .tuner_type = TUNER_PHILIPS_PAL,
1424 .radio_type = UNSET,
1425 .tuner_addr = ADDR_UNSET,
1426 .radio_addr = ADDR_UNSET,
1429 .name = name_tv_mono,
1440 .name = name_svideo,
1456 [SAA7134_BOARD_AVERMEDIA_STUDIO_307] = {
1458 Nickolay V. Shmyrev <nshmyrev@yandex.ru>
1459 Lots of thanks to Andrey Zolotarev <zolotarev_andrey@mail.ru>
1461 .name = "Avermedia AVerTV Studio 307",
1462 .audio_clock = 0x00187de7,
1463 .tuner_type = TUNER_PHILIPS_FM1256_IH3,
1464 .radio_type = UNSET,
1465 .tuner_addr = ADDR_UNSET,
1466 .radio_addr = ADDR_UNSET,
1467 .tda9887_conf = TDA9887_PRESENT,
1486 .name = name_svideo,
1502 [SAA7134_BOARD_AVERMEDIA_GO_007_FM] = {
1503 .name = "Avermedia AVerTV GO 007 FM",
1504 .audio_clock = 0x00187de7,
1505 .tuner_type = TUNER_PHILIPS_TDA8290,
1506 .radio_type = UNSET,
1507 .tuner_addr = ADDR_UNSET,
1508 .radio_addr = ADDR_UNSET,
1509 .gpiomask = 0x00300003,
1510 /* .gpiomask = 0x8c240003, */
1523 .name = name_svideo,
1539 [SAA7134_BOARD_AVERMEDIA_CARDBUS] = {
1540 /* Kees.Blom@cwi.nl */
1541 .name = "AVerMedia Cardbus TV/Radio (E500)",
1542 .audio_clock = 0x187de7,
1543 .tuner_type = TUNER_PHILIPS_TDA8290,
1544 .radio_type = UNSET,
1545 .tuner_addr = ADDR_UNSET,
1546 .radio_addr = ADDR_UNSET,
1557 .name = name_svideo,
1566 [SAA7134_BOARD_CINERGY400_CARDBUS] = {
1567 .name = "Terratec Cinergy 400 mobile",
1568 .audio_clock = 0x187de7,
1569 .tuner_type = TUNER_ALPS_TSBE5_PAL,
1570 .radio_type = UNSET,
1571 .tuner_addr = ADDR_UNSET,
1572 .radio_addr = ADDR_UNSET,
1573 .tda9887_conf = TDA9887_PRESENT,
1580 .name = name_tv_mono,
1589 .name = name_svideo,
1594 [SAA7134_BOARD_CINERGY600_MK3] = {
1595 .name = "Terratec Cinergy 600 TV MK3",
1596 .audio_clock = 0x00200000,
1597 .tuner_type = TUNER_PHILIPS_FM1216ME_MK3,
1598 .radio_type = UNSET,
1599 .tuner_addr = ADDR_UNSET,
1600 .radio_addr = ADDR_UNSET,
1601 .tda9887_conf = TDA9887_PRESENT,
1612 .name = name_svideo,
1616 .name = name_comp2, /* CVideo over SVideo Connector */
1625 [SAA7134_BOARD_VIDEOMATE_GOLD_PLUS] = {
1626 /* Dylan Walkden <dylan_walkden@hotmail.com> */
1627 .name = "Compro VideoMate Gold+ Pal",
1628 .audio_clock = 0x00187de7,
1629 .tuner_type = TUNER_PHILIPS_PAL,
1630 .radio_type = UNSET,
1631 .tuner_addr = ADDR_UNSET,
1632 .radio_addr = ADDR_UNSET,
1633 .gpiomask = 0x1ce780,
1635 .name = name_svideo,
1636 .vmux = 0, /* CVideo over SVideo Connector - ok? */
1662 [SAA7134_BOARD_PINNACLE_300I_DVBT_PAL] = {
1663 .name = "Pinnacle PCTV 300i DVB-T + PAL",
1664 .audio_clock = 0x00187de7,
1665 .tuner_type = TUNER_MT2032,
1666 .radio_type = UNSET,
1667 .tuner_addr = ADDR_UNSET,
1668 .radio_addr = ADDR_UNSET,
1669 .tda9887_conf = TDA9887_PRESENT | TDA9887_INTERCARRIER | TDA9887_PORT2_ACTIVE,
1670 .mpeg = SAA7134_MPEG_DVB,
1685 .name = name_svideo,
1690 [SAA7134_BOARD_PROVIDEO_PV952] = {
1691 /* andreas.kretschmer@web.de */
1692 .name = "ProVideo PV952",
1693 .audio_clock = 0x00187de7,
1694 .tuner_type = TUNER_PHILIPS_FM1216ME_MK3,
1695 .radio_type = UNSET,
1696 .tuner_addr = ADDR_UNSET,
1697 .radio_addr = ADDR_UNSET,
1698 .tda9887_conf = TDA9887_PRESENT,
1709 .name = name_tv_mono,
1719 [SAA7134_BOARD_AVERMEDIA_305] = {
1720 /* much like the "studio" version but without radio
1721 * and another tuner (sirspiritus@yandex.ru) */
1722 .name = "AverMedia AverTV/305",
1723 .audio_clock = 0x00187de7,
1724 .tuner_type = TUNER_PHILIPS_FQ1216ME,
1725 .radio_type = UNSET,
1726 .tuner_addr = ADDR_UNSET,
1727 .radio_addr = ADDR_UNSET,
1728 .tda9887_conf = TDA9887_PRESENT,
1743 .name = name_svideo,
1752 [SAA7134_BOARD_FLYDVBTDUO] = {
1753 /* LifeView FlyDVB-T DUO */
1754 /* "Nico Sabbi <nsabbi@tiscali.it> Hartmut Hackmann hartmut.hackmann@t-online.de*/
1755 .name = "LifeView FlyDVB-T DUO",
1756 .audio_clock = 0x00200000,
1757 .tuner_type = TUNER_PHILIPS_TDA8290,
1758 .radio_type = UNSET,
1759 .tuner_addr = ADDR_UNSET,
1760 .radio_addr = ADDR_UNSET,
1761 .mpeg = SAA7134_MPEG_DVB,
1768 .name = name_comp1, /* Composite signal on S-Video input */
1772 .name = name_comp2, /* Composite input */
1776 .name = name_svideo, /* S-Video signal on S-Video input */
1781 [SAA7134_BOARD_PHILIPS_TOUGH] = {
1782 .name = "Philips TOUGH DVB-T reference design",
1783 .tuner_type = TUNER_ABSENT,
1784 .audio_clock = 0x00187de7,
1785 .radio_type = UNSET,
1786 .tuner_addr = ADDR_UNSET,
1787 .radio_addr = ADDR_UNSET,
1788 .mpeg = SAA7134_MPEG_DVB,
1794 .name = name_svideo,
1799 [SAA7134_BOARD_AVERMEDIA_307] = {
1801 Davydov Vladimir <vladimir@iqmedia.com>
1803 .name = "Avermedia AVerTV 307",
1804 .audio_clock = 0x00187de7,
1805 .tuner_type = TUNER_PHILIPS_FQ1216ME,
1806 .radio_type = UNSET,
1807 .tuner_addr = ADDR_UNSET,
1808 .radio_addr = ADDR_UNSET,
1809 .tda9887_conf = TDA9887_PRESENT,
1824 .name = name_svideo,
1829 [SAA7134_BOARD_ADS_INSTANT_TV] = {
1830 .name = "ADS Tech Instant TV (saa7135)",
1831 .audio_clock = 0x00187de7,
1832 .tuner_type = TUNER_PHILIPS_TDA8290,
1833 .radio_type = UNSET,
1834 .tuner_addr = ADDR_UNSET,
1835 .radio_addr = ADDR_UNSET,
1846 .name = name_svideo,
1851 [SAA7134_BOARD_KWORLD_VSTREAM_XPERT] = {
1852 .name = "Kworld/Tevion V-Stream Xpert TV PVR7134",
1853 .audio_clock = 0x00187de7,
1854 .tuner_type = TUNER_PHILIPS_PAL_I,
1855 .radio_type = UNSET,
1856 .tuner_addr = ADDR_UNSET,
1857 .radio_addr = ADDR_UNSET,
1869 .gpio = 0x200, /* gpio by DScaler */
1871 .name = name_svideo,
1887 [SAA7134_BOARD_FLYDVBT_DUO_CARDBUS] = {
1888 .name = "LifeView/Typhoon FlyDVB-T Duo Cardbus",
1889 .audio_clock = 0x00200000,
1890 .tuner_type = TUNER_PHILIPS_TDA8290,
1891 .radio_type = UNSET,
1892 .tuner_addr = ADDR_UNSET,
1893 .radio_addr = ADDR_UNSET,
1894 .mpeg = SAA7134_MPEG_DVB,
1895 .gpiomask = 0x00200000,
1900 .gpio = 0x200000, /* GPIO21=High for TV input */
1903 .name = name_svideo, /* S-Video signal on S-Video input */
1907 .name = name_comp1, /* Composite signal on S-Video input */
1911 .name = name_comp2, /* Composite input */
1918 .gpio = 0x000000, /* GPIO21=Low for FM radio antenna */
1921 [SAA7134_BOARD_VIDEOMATE_TV_GOLD_PLUSII] = {
1922 .name = "Compro VideoMate TV Gold+II",
1923 .audio_clock = 0x002187de7,
1924 .tuner_type = TUNER_LG_PAL_NEW_TAPC,
1925 .radio_type = TUNER_TEA5767,
1928 .gpiomask = 0x8c1880,
1930 .name = name_svideo,
1957 [SAA7134_BOARD_KWORLD_XPERT] = {
1960 - Remote control doesn't initialize properly.
1961 - Audio volume starts muted,
1962 then gradually increases after channel change.
1963 - Overlay scaling problems (application error?)
1964 - Composite S-Video untested.
1965 From: Konrad Rzepecki <hannibal@megapolis.pl>
1967 .name = "Kworld Xpert TV PVR7134",
1968 .audio_clock = 0x00187de7,
1969 .tuner_type = TUNER_TENA_9533_DI,
1970 .radio_type = TUNER_TEA5767,
1984 .gpio = 0x200, /* gpio by DScaler */
1986 .name = name_svideo,
2002 [SAA7134_BOARD_FLYTV_DIGIMATRIX] = {
2003 .name = "FlyTV mini Asus Digimatrix",
2004 .audio_clock = 0x00200000,
2005 .tuner_type = TUNER_LG_NTSC_TALN_MINI,
2006 .radio_type = UNSET,
2007 .tuner_addr = ADDR_UNSET,
2008 .radio_addr = ADDR_UNSET,
2015 .name = name_tv_mono,
2028 .name = name_svideo,
2033 .name = name_radio, /* radio unconfirmed */
2037 [SAA7134_BOARD_KWORLD_TERMINATOR] = {
2038 /* Kworld V-Stream Studio TV Terminator */
2039 /* "James Webb <jrwebb@qwest.net> */
2040 .name = "V-Stream Studio TV Terminator",
2041 .audio_clock = 0x00187de7,
2042 .tuner_type = TUNER_PHILIPS_TDA8290,
2043 .radio_type = UNSET,
2044 .tuner_addr = ADDR_UNSET,
2045 .radio_addr = ADDR_UNSET,
2046 .gpiomask = 1 << 21,
2054 .name = name_comp1, /* Composite input */
2059 .name = name_svideo, /* S-Video input */
2070 [SAA7134_BOARD_YUAN_TUN900] = {
2072 * S-Video and composite sources untested.
2073 * Radio not working.
2074 * Remote control not yet implemented.
2075 * From : codemaster@webgeeks.be */
2076 .name = "Yuan TUN-900 (saa7135)",
2077 .audio_clock = 0x00187de7,
2078 .tuner_type = TUNER_PHILIPS_TDA8290,
2079 .radio_type = UNSET,
2080 .tuner_addr= ADDR_UNSET,
2081 .radio_addr= ADDR_UNSET,
2082 .gpiomask = 0x00010003,
2095 .name = name_svideo,
2111 [SAA7134_BOARD_BEHOLD_409FM] = {
2112 /* <http://tuner.beholder.ru>, Sergey <skiv@orel.ru> */
2113 .name = "Beholder BeholdTV 409 FM",
2114 .audio_clock = 0x00187de7,
2115 .tuner_type = TUNER_PHILIPS_FM1216ME_MK3,
2116 .radio_type = UNSET,
2117 .tuner_addr = ADDR_UNSET,
2118 .radio_addr = ADDR_UNSET,
2119 .tda9887_conf = TDA9887_PRESENT,
2130 .name = name_svideo,
2139 [SAA7134_BOARD_GOTVIEW_7135] = {
2140 /* Mike Baikov <mike@baikov.com> */
2141 /* Andrey Cvetcov <ays14@yandex.ru> */
2142 .name = "GoTView 7135 PCI",
2143 .audio_clock = 0x00187de7,
2144 .tuner_type = TUNER_PHILIPS_FM1216ME_MK3,
2145 .radio_type = UNSET,
2146 .tuner_addr = ADDR_UNSET,
2147 .radio_addr = ADDR_UNSET,
2148 .tda9887_conf = TDA9887_PRESENT,
2149 .gpiomask = 0x00200003,
2157 .name = name_tv_mono,
2167 .name = name_svideo,
2183 [SAA7134_BOARD_PHILIPS_EUROPA] = {
2184 .name = "Philips EUROPA V3 reference design",
2185 .audio_clock = 0x00187de7,
2186 .tuner_type = TUNER_PHILIPS_TD1316,
2187 .radio_type = UNSET,
2189 .radio_addr = ADDR_UNSET,
2190 .tda9887_conf = TDA9887_PRESENT,
2191 .mpeg = SAA7134_MPEG_DVB,
2202 .name = name_svideo,
2207 [SAA7134_BOARD_VIDEOMATE_DVBT_300] = {
2208 .name = "Compro Videomate DVB-T300",
2209 .audio_clock = 0x00187de7,
2210 .tuner_type = TUNER_PHILIPS_TD1316,
2211 .radio_type = UNSET,
2213 .radio_addr = ADDR_UNSET,
2214 .tda9887_conf = TDA9887_PRESENT,
2215 .mpeg = SAA7134_MPEG_DVB,
2226 .name = name_svideo,
2231 [SAA7134_BOARD_VIDEOMATE_DVBT_200] = {
2232 .name = "Compro Videomate DVB-T200",
2233 .tuner_type = TUNER_ABSENT,
2234 .audio_clock = 0x00187de7,
2235 .radio_type = UNSET,
2236 .tuner_addr = ADDR_UNSET,
2237 .radio_addr = ADDR_UNSET,
2238 .mpeg = SAA7134_MPEG_DVB,
2244 .name = name_svideo,
2249 [SAA7134_BOARD_RTD_VFG7350] = {
2250 .name = "RTD Embedded Technologies VFG7350",
2251 .audio_clock = 0x00200000,
2252 .tuner_type = TUNER_ABSENT,
2253 .radio_type = UNSET,
2254 .tuner_addr = ADDR_UNSET,
2255 .radio_addr = ADDR_UNSET,
2257 .name = "Composite 0",
2261 .name = "Composite 1",
2265 .name = "Composite 2",
2269 .name = "Composite 3",
2273 .name = "S-Video 0",
2277 .name = "S-Video 1",
2281 .mpeg = SAA7134_MPEG_EMPRESS,
2282 .video_out = CCIR656,
2283 .vid_port_opts = ( SET_T_CODE_POLARITY_NON_INVERTED |
2284 SET_CLOCK_NOT_DELAYED |
2285 SET_CLOCK_INVERTED |
2288 [SAA7134_BOARD_RTD_VFG7330] = {
2289 .name = "RTD Embedded Technologies VFG7330",
2290 .audio_clock = 0x00200000,
2291 .tuner_type = TUNER_ABSENT,
2292 .radio_type = UNSET,
2293 .tuner_addr = ADDR_UNSET,
2294 .radio_addr = ADDR_UNSET,
2296 .name = "Composite 0",
2300 .name = "Composite 1",
2304 .name = "Composite 2",
2308 .name = "Composite 3",
2312 .name = "S-Video 0",
2316 .name = "S-Video 1",
2321 [SAA7134_BOARD_FLYTVPLATINUM_MINI2] = {
2322 .name = "LifeView FlyTV Platinum Mini2",
2323 .audio_clock = 0x00200000,
2324 .tuner_type = TUNER_PHILIPS_TDA8290,
2325 .radio_type = UNSET,
2326 .tuner_addr = ADDR_UNSET,
2327 .radio_addr = ADDR_UNSET,
2335 .name = name_comp1, /* Composite signal on S-Video input */
2339 .name = name_comp2, /* Composite input */
2343 .name = name_svideo,
2348 [SAA7134_BOARD_AVERMEDIA_AVERTVHD_A180] = {
2349 /* Michael Krufky <mkrufky@m1k.net>
2350 * Uses Alps Electric TDHU2, containing NXT2004 ATSC Decoder
2351 * AFAIK, there is no analog demod, thus,
2352 * no support for analog television.
2354 .name = "AVerMedia AVerTVHD MCE A180",
2355 .audio_clock = 0x00187de7,
2356 .tuner_type = TUNER_ABSENT,
2357 .radio_type = UNSET,
2358 .tuner_addr = ADDR_UNSET,
2359 .radio_addr = ADDR_UNSET,
2360 .mpeg = SAA7134_MPEG_DVB,
2366 .name = name_svideo,
2371 [SAA7134_BOARD_MONSTERTV_MOBILE] = {
2372 .name = "SKNet MonsterTV Mobile",
2373 .audio_clock = 0x00187de7,
2374 .tuner_type = TUNER_PHILIPS_TDA8290,
2375 .radio_type = UNSET,
2376 .tuner_addr = ADDR_UNSET,
2377 .radio_addr = ADDR_UNSET,
2389 .name = name_svideo,
2394 [SAA7134_BOARD_PINNACLE_PCTV_110i] = {
2395 .name = "Pinnacle PCTV 40i/50i/110i (saa7133)",
2396 .audio_clock = 0x00187de7,
2397 .tuner_type = TUNER_PHILIPS_TDA8290,
2398 .radio_type = UNSET,
2399 .tuner_addr = ADDR_UNSET,
2400 .radio_addr = ADDR_UNSET,
2401 .gpiomask = 0x080200000,
2416 .name = name_svideo,
2425 [SAA7134_BOARD_ASUSTeK_P7131_DUAL] = {
2426 .name = "ASUSTeK P7131 Dual",
2427 .audio_clock = 0x00187de7,
2428 .tuner_type = TUNER_PHILIPS_TDA8290,
2429 .radio_type = UNSET,
2430 .tuner_addr = ADDR_UNSET,
2431 .radio_addr = ADDR_UNSET,
2432 .gpiomask = 1 << 21,
2433 .mpeg = SAA7134_MPEG_DVB,
2444 .name = name_svideo,
2454 [SAA7134_BOARD_SEDNA_PC_TV_CARDBUS] = {
2455 /* Paul Tom Zalac <pzalac@gmail.com> */
2456 /* Pavel Mihaylov <bin@bash.info> */
2457 .name = "Sedna/MuchTV PC TV Cardbus TV/Radio (ITO25 Rev:2B)",
2458 /* Sedna/MuchTV (OEM) Cardbus TV Tuner */
2459 .audio_clock = 0x00187de7,
2460 .tuner_type = TUNER_PHILIPS_TDA8290,
2461 .radio_type = UNSET,
2462 .tuner_addr = ADDR_UNSET,
2463 .radio_addr = ADDR_UNSET,
2464 .gpiomask = 0xe880c0,
2475 .name = name_svideo,
2484 [SAA7134_BOARD_ASUSTEK_DIGIMATRIX_TV] = {
2485 /* "Cyril Lacoux (Yack)" <clacoux@ifeelgood.org> */
2486 .name = "ASUS Digimatrix TV",
2487 .audio_clock = 0x00200000,
2488 .tuner_type = TUNER_PHILIPS_FQ1216ME,
2489 .tda9887_conf = TDA9887_PRESENT,
2490 .radio_type = UNSET,
2491 .tuner_addr = ADDR_UNSET,
2492 .radio_addr = ADDR_UNSET,
2503 .name = name_svideo,
2508 [SAA7134_BOARD_PHILIPS_TIGER] = {
2509 .name = "Philips Tiger reference design",
2510 .audio_clock = 0x00187de7,
2511 .tuner_type = TUNER_PHILIPS_TDA8290,
2512 .radio_type = UNSET,
2513 .tuner_addr = ADDR_UNSET,
2514 .radio_addr = ADDR_UNSET,
2515 .mpeg = SAA7134_MPEG_DVB,
2516 .gpiomask = 1 << 21,
2527 .name = name_svideo,
2537 [SAA7134_BOARD_MSI_TVATANYWHERE_PLUS] = {
2538 .name = "MSI TV@Anywhere plus",
2539 .audio_clock = 0x00187de7,
2540 .tuner_type = TUNER_PHILIPS_TDA8290,
2541 .radio_type = UNSET,
2542 .tuner_addr = ADDR_UNSET,
2543 .radio_addr = ADDR_UNSET,
2554 .name = name_svideo,
2563 [SAA7134_BOARD_CINERGY250PCI] = {
2564 /* remote-control does not work. The signal about a
2565 key press comes in via gpio, but the key code
2566 doesn't. Neither does it have an i2c remote control
2568 .name = "Terratec Cinergy 250 PCI TV",
2569 .audio_clock = 0x00187de7,
2570 .tuner_type = TUNER_PHILIPS_TDA8290,
2571 .radio_type = UNSET,
2572 .tuner_addr = ADDR_UNSET,
2573 .radio_addr = ADDR_UNSET,
2574 .gpiomask = 0x80200000,
2581 .name = name_svideo, /* NOT tested */
2591 [SAA7134_BOARD_FLYDVB_TRIO] = {
2592 /* LifeView LR319 FlyDVB Trio */
2593 /* Peter Missel <peter.missel@onlinehome.de> */
2594 .name = "LifeView FlyDVB Trio",
2595 .audio_clock = 0x00200000,
2596 .tuner_type = TUNER_PHILIPS_TDA8290,
2597 .radio_type = UNSET,
2598 .tuner_addr = ADDR_UNSET,
2599 .radio_addr = ADDR_UNSET,
2600 .gpiomask = 0x00200000,
2602 .name = name_tv, /* Analog broadcast/cable TV */
2605 .gpio = 0x200000, /* GPIO21=High for TV input */
2608 .name = name_svideo, /* S-Video signal on S-Video input */
2612 .name = name_comp1, /* Composite signal on S-Video input */
2616 .name = name_comp2, /* Composite input */
2623 .gpio = 0x000000, /* GPIO21=Low for FM radio antenna */
2628 const unsigned int saa7134_bcount = ARRAY_SIZE(saa7134_boards);
2630 /* ------------------------------------------------------------------ */
2631 /* PCI ids + subsystem IDs */
2633 struct pci_device_id saa7134_pci_tbl[] = {
2635 .vendor = PCI_VENDOR_ID_PHILIPS,
2636 .device = PCI_DEVICE_ID_PHILIPS_SAA7134,
2637 .subvendor = PCI_VENDOR_ID_PHILIPS,
2638 .subdevice = 0x2001,
2639 .driver_data = SAA7134_BOARD_PROTEUS_PRO,
2641 .vendor = PCI_VENDOR_ID_PHILIPS,
2642 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
2643 .subvendor = PCI_VENDOR_ID_PHILIPS,
2644 .subdevice = 0x2001,
2645 .driver_data = SAA7134_BOARD_PROTEUS_PRO,
2647 .vendor = PCI_VENDOR_ID_PHILIPS,
2648 .device = PCI_DEVICE_ID_PHILIPS_SAA7134,
2649 .subvendor = PCI_VENDOR_ID_PHILIPS,
2650 .subdevice = 0x6752,
2651 .driver_data = SAA7134_BOARD_EMPRESS,
2653 .vendor = PCI_VENDOR_ID_PHILIPS,
2654 .device = PCI_DEVICE_ID_PHILIPS_SAA7134,
2655 .subvendor = 0x1131,
2656 .subdevice = 0x4e85,
2657 .driver_data = SAA7134_BOARD_MONSTERTV,
2659 .vendor = PCI_VENDOR_ID_PHILIPS,
2660 .device = PCI_DEVICE_ID_PHILIPS_SAA7134,
2661 .subvendor = 0x153b,
2662 .subdevice = 0x1142,
2663 .driver_data = SAA7134_BOARD_CINERGY400,
2665 .vendor = PCI_VENDOR_ID_PHILIPS,
2666 .device = PCI_DEVICE_ID_PHILIPS_SAA7134,
2667 .subvendor = 0x153b,
2668 .subdevice = 0x1143,
2669 .driver_data = SAA7134_BOARD_CINERGY600,
2671 .vendor = PCI_VENDOR_ID_PHILIPS,
2672 .device = PCI_DEVICE_ID_PHILIPS_SAA7134,
2673 .subvendor = 0x153b,
2674 .subdevice = 0x1158,
2675 .driver_data = SAA7134_BOARD_CINERGY600_MK3,
2677 .vendor = PCI_VENDOR_ID_PHILIPS,
2678 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
2679 .subvendor = 0x153b,
2680 .subdevice = 0x1162,
2681 .driver_data = SAA7134_BOARD_CINERGY400_CARDBUS,
2683 .vendor = PCI_VENDOR_ID_PHILIPS,
2684 .device = PCI_DEVICE_ID_PHILIPS_SAA7134,
2685 .subvendor = 0x5168,
2686 .subdevice = 0x0138,
2687 .driver_data = SAA7134_BOARD_FLYVIDEO3000,
2689 .vendor = PCI_VENDOR_ID_PHILIPS,
2690 .device = PCI_DEVICE_ID_PHILIPS_SAA7134,
2691 .subvendor = 0x4e42, /* "Typhoon PCI Capture TV Card" Art.No. 50673 */
2692 .subdevice = 0x0138,
2693 .driver_data = SAA7134_BOARD_FLYVIDEO3000,
2695 .vendor = PCI_VENDOR_ID_PHILIPS,
2696 .device = PCI_DEVICE_ID_PHILIPS_SAA7130,
2697 .subvendor = 0x5168,
2698 .subdevice = 0x0138,
2699 .driver_data = SAA7134_BOARD_FLYVIDEO2000,
2701 .vendor = PCI_VENDOR_ID_PHILIPS,
2702 .device = PCI_DEVICE_ID_PHILIPS_SAA7130,
2703 .subvendor = 0x4e42, /* Typhoon */
2704 .subdevice = 0x0138, /* LifeView FlyTV Prime30 OEM */
2705 .driver_data = SAA7134_BOARD_FLYVIDEO2000,
2707 .vendor = PCI_VENDOR_ID_PHILIPS,
2708 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
2709 .subvendor = 0x5168,
2710 .subdevice = 0x0212, /* minipci, LR212 */
2711 .driver_data = SAA7134_BOARD_FLYTVPLATINUM_MINI,
2713 .vendor = PCI_VENDOR_ID_PHILIPS,
2714 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
2715 .subvendor = 0x14c0,
2716 .subdevice = 0x1212, /* minipci, LR1212 */
2717 .driver_data = SAA7134_BOARD_FLYTVPLATINUM_MINI2,
2719 .vendor = PCI_VENDOR_ID_PHILIPS,
2720 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
2721 .subvendor = 0x4e42,
2722 .subdevice = 0x0212, /* OEM minipci, LR212 */
2723 .driver_data = SAA7134_BOARD_FLYTVPLATINUM_MINI,
2725 .vendor = PCI_VENDOR_ID_PHILIPS,
2726 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
2727 .subvendor = 0x5168, /* Animation Technologies (LifeView) */
2728 .subdevice = 0x0214, /* Standard PCI, LR214WF */
2729 .driver_data = SAA7134_BOARD_FLYTVPLATINUM_FM,
2731 .vendor = PCI_VENDOR_ID_PHILIPS,
2732 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
2733 .subvendor = 0x1489, /* KYE */
2734 .subdevice = 0x0214, /* Genius VideoWonder ProTV */
2735 .driver_data = SAA7134_BOARD_FLYTVPLATINUM_FM, /* is an LR214WF actually */
2737 .vendor = PCI_VENDOR_ID_PHILIPS,
2738 .device = PCI_DEVICE_ID_PHILIPS_SAA7134,
2739 .subvendor = 0x16be,
2740 .subdevice = 0x0003,
2741 .driver_data = SAA7134_BOARD_MD7134,
2743 .vendor = PCI_VENDOR_ID_PHILIPS,
2744 .device = PCI_DEVICE_ID_PHILIPS_SAA7130,
2745 .subvendor = 0x1048,
2746 .subdevice = 0x226b,
2747 .driver_data = SAA7134_BOARD_ELSA,
2749 .vendor = PCI_VENDOR_ID_PHILIPS,
2750 .device = PCI_DEVICE_ID_PHILIPS_SAA7130,
2751 .subvendor = 0x1048,
2752 .subdevice = 0x226b,
2753 .driver_data = SAA7134_BOARD_ELSA_500TV,
2755 .vendor = PCI_VENDOR_ID_PHILIPS,
2756 .device = PCI_DEVICE_ID_PHILIPS_SAA7134,
2757 .subvendor = PCI_VENDOR_ID_ASUSTEK,
2758 .subdevice = 0x4842,
2759 .driver_data = SAA7134_BOARD_ASUSTeK_TVFM7134,
2761 .vendor = PCI_VENDOR_ID_PHILIPS,
2762 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
2763 .subvendor = PCI_VENDOR_ID_ASUSTEK,
2764 .subdevice = 0x4845,
2765 .driver_data = SAA7134_BOARD_ASUSTeK_TVFM7135,
2767 .vendor = PCI_VENDOR_ID_PHILIPS,
2768 .device = PCI_DEVICE_ID_PHILIPS_SAA7134,
2769 .subvendor = PCI_VENDOR_ID_ASUSTEK,
2770 .subdevice = 0x4830,
2771 .driver_data = SAA7134_BOARD_ASUSTeK_TVFM7134,
2773 .vendor = PCI_VENDOR_ID_PHILIPS,
2774 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
2775 .subvendor = PCI_VENDOR_ID_ASUSTEK,
2776 .subdevice = 0x4843,
2777 .driver_data = SAA7134_BOARD_ASUSTEK_TVFM7133,
2779 .vendor = PCI_VENDOR_ID_PHILIPS,
2780 .device = PCI_DEVICE_ID_PHILIPS_SAA7134,
2781 .subvendor = PCI_VENDOR_ID_ASUSTEK,
2782 .subdevice = 0x4840,
2783 .driver_data = SAA7134_BOARD_ASUSTeK_TVFM7134,
2785 .vendor = PCI_VENDOR_ID_PHILIPS,
2786 .device = PCI_DEVICE_ID_PHILIPS_SAA7134,
2787 .subvendor = PCI_VENDOR_ID_PHILIPS,
2788 .subdevice = 0xfe01,
2789 .driver_data = SAA7134_BOARD_TVSTATION_RDS,
2791 .vendor = PCI_VENDOR_ID_PHILIPS,
2792 .device = PCI_DEVICE_ID_PHILIPS_SAA7134,
2793 .subvendor = 0x1894,
2794 .subdevice = 0xfe01,
2795 .driver_data = SAA7134_BOARD_TVSTATION_RDS,
2797 .vendor = PCI_VENDOR_ID_PHILIPS,
2798 .device = PCI_DEVICE_ID_PHILIPS_SAA7134,
2799 .subvendor = 0x1894,
2800 .subdevice = 0xa006,
2801 .driver_data = SAA7134_BOARD_TVSTATION_DVR,
2803 .vendor = PCI_VENDOR_ID_PHILIPS,
2804 .device = PCI_DEVICE_ID_PHILIPS_SAA7134,
2805 .subvendor = 0x1131,
2806 .subdevice = 0x7133,
2807 .driver_data = SAA7134_BOARD_VA1000POWER,
2809 .vendor = PCI_VENDOR_ID_PHILIPS,
2810 .device = PCI_DEVICE_ID_PHILIPS_SAA7130,
2811 .subvendor = PCI_VENDOR_ID_PHILIPS,
2812 .subdevice = 0x2001,
2813 .driver_data = SAA7134_BOARD_10MOONSTVMASTER,
2815 .vendor = PCI_VENDOR_ID_PHILIPS,
2816 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
2817 .subvendor = 0x185b,
2818 .subdevice = 0xc100,
2819 .driver_data = SAA7134_BOARD_VIDEOMATE_TV,
2821 .vendor = PCI_VENDOR_ID_PHILIPS,
2822 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
2823 .subvendor = 0x185b,
2824 .subdevice = 0xc100,
2825 .driver_data = SAA7134_BOARD_VIDEOMATE_TV_GOLD_PLUS,
2827 .vendor = PCI_VENDOR_ID_PHILIPS,
2828 .device = PCI_DEVICE_ID_PHILIPS_SAA7130,
2829 .subvendor = PCI_VENDOR_ID_MATROX,
2830 .subdevice = 0x48d0,
2831 .driver_data = SAA7134_BOARD_CRONOS_PLUS,
2833 .vendor = PCI_VENDOR_ID_PHILIPS,
2834 .device = PCI_DEVICE_ID_PHILIPS_SAA7134,
2835 .subvendor = 0x1461, /* Avermedia Technologies Inc */
2836 .subdevice = 0xa70b,
2837 .driver_data = SAA7134_BOARD_MD2819,
2839 .vendor = PCI_VENDOR_ID_PHILIPS,
2840 .device = PCI_DEVICE_ID_PHILIPS_SAA7130,
2841 .subvendor = 0x1461, /* Avermedia Technologies Inc */
2842 .subdevice = 0x2115,
2843 .driver_data = SAA7134_BOARD_AVERMEDIA_STUDIO_305,
2845 .vendor = PCI_VENDOR_ID_PHILIPS,
2846 .device = PCI_DEVICE_ID_PHILIPS_SAA7130,
2847 .subvendor = 0x1461, /* Avermedia Technologies Inc */
2848 .subdevice = 0x2108,
2849 .driver_data = SAA7134_BOARD_AVERMEDIA_305,
2851 .vendor = PCI_VENDOR_ID_PHILIPS,
2852 .device = PCI_DEVICE_ID_PHILIPS_SAA7130,
2853 .subvendor = 0x1461, /* Avermedia Technologies Inc */
2854 .subdevice = 0x10ff,
2855 .driver_data = SAA7134_BOARD_AVERMEDIA_DVD_EZMAKER,
2857 /* AVerMedia CardBus */
2858 .vendor = PCI_VENDOR_ID_PHILIPS,
2859 .device = PCI_DEVICE_ID_PHILIPS_SAA7134,
2860 .subvendor = 0x1461, /* Avermedia Technologies Inc */
2861 .subdevice = 0xd6ee,
2862 .driver_data = SAA7134_BOARD_AVERMEDIA_CARDBUS,
2864 /* TransGear 3000TV */
2865 .vendor = PCI_VENDOR_ID_PHILIPS,
2866 .device = PCI_DEVICE_ID_PHILIPS_SAA7130,
2867 .subvendor = 0x1461, /* Avermedia Technologies Inc */
2868 .subdevice = 0x050c,
2869 .driver_data = SAA7134_BOARD_TG3000TV,
2871 .vendor = PCI_VENDOR_ID_PHILIPS,
2872 .device = PCI_DEVICE_ID_PHILIPS_SAA7134,
2873 .subvendor = 0x11bd,
2874 .subdevice = 0x002b,
2875 .driver_data = SAA7134_BOARD_PINNACLE_PCTV_STEREO,
2877 .vendor = PCI_VENDOR_ID_PHILIPS,
2878 .device = PCI_DEVICE_ID_PHILIPS_SAA7134,
2879 .subvendor = 0x11bd,
2880 .subdevice = 0x002d,
2881 .driver_data = SAA7134_BOARD_PINNACLE_300I_DVBT_PAL,
2883 .vendor = PCI_VENDOR_ID_PHILIPS,
2884 .device = PCI_DEVICE_ID_PHILIPS_SAA7134,
2885 .subvendor = 0x1019,
2886 .subdevice = 0x4cb4,
2887 .driver_data = SAA7134_BOARD_ECS_TVP3XP,
2889 .vendor = PCI_VENDOR_ID_PHILIPS,
2890 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
2891 .subvendor = 0x1019,
2892 .subdevice = 0x4cb5,
2893 .driver_data = SAA7134_BOARD_ECS_TVP3XP_4CB5,
2895 .vendor = PCI_VENDOR_ID_PHILIPS,
2896 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
2897 .subvendor = 0x12ab,
2898 .subdevice = 0x0800,
2899 .driver_data = SAA7134_BOARD_UPMOST_PURPLE_TV,
2901 .vendor = PCI_VENDOR_ID_PHILIPS,
2902 .device = PCI_DEVICE_ID_PHILIPS_SAA7130,
2903 .subvendor = 0x153b,
2904 .subdevice = 0x1152,
2905 .driver_data = SAA7134_BOARD_CINERGY200,
2907 .vendor = PCI_VENDOR_ID_PHILIPS,
2908 .device = PCI_DEVICE_ID_PHILIPS_SAA7130,
2909 .subvendor = 0x185b,
2910 .subdevice = 0xc100,
2911 .driver_data = SAA7134_BOARD_VIDEOMATE_TV_PVR,
2913 .vendor = PCI_VENDOR_ID_PHILIPS,
2914 .device = PCI_DEVICE_ID_PHILIPS_SAA7134,
2915 .subvendor = 0x1461, /* Avermedia Technologies Inc */
2916 .subdevice = 0x9715,
2917 .driver_data = SAA7134_BOARD_AVERMEDIA_STUDIO_307,
2919 .vendor = PCI_VENDOR_ID_PHILIPS,
2920 .device = PCI_DEVICE_ID_PHILIPS_SAA7134,
2921 .subvendor = 0x1461, /* Avermedia Technologies Inc */
2922 .subdevice = 0xa70a,
2923 .driver_data = SAA7134_BOARD_AVERMEDIA_307,
2925 .vendor = PCI_VENDOR_ID_PHILIPS,
2926 .device = PCI_DEVICE_ID_PHILIPS_SAA7134,
2927 .subvendor = 0x185b,
2928 .subdevice = 0xc200,
2929 .driver_data = SAA7134_BOARD_VIDEOMATE_GOLD_PLUS,
2931 .vendor = PCI_VENDOR_ID_PHILIPS,
2932 .device = PCI_DEVICE_ID_PHILIPS_SAA7134,
2933 .subvendor = 0x1540,
2934 .subdevice = 0x9524,
2935 .driver_data = SAA7134_BOARD_PROVIDEO_PV952,
2938 .vendor = PCI_VENDOR_ID_PHILIPS,
2939 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
2940 .subvendor = 0x5168,
2941 .subdevice = 0x0502, /* Cardbus version */
2942 .driver_data = SAA7134_BOARD_FLYDVBT_DUO_CARDBUS,
2944 .vendor = PCI_VENDOR_ID_PHILIPS,
2945 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
2946 .subvendor = 0x5168,
2947 .subdevice = 0x0306, /* PCI version */
2948 .driver_data = SAA7134_BOARD_FLYDVBTDUO,
2950 .vendor = PCI_VENDOR_ID_PHILIPS,
2951 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
2952 .subvendor = 0x1461, /* Avermedia Technologies Inc */
2953 .subdevice = 0xf31f,
2954 .driver_data = SAA7134_BOARD_AVERMEDIA_GO_007_FM,
2957 .vendor = PCI_VENDOR_ID_PHILIPS,
2958 .device = PCI_DEVICE_ID_PHILIPS_SAA7130,
2959 .subvendor = PCI_VENDOR_ID_PHILIPS,
2960 .subdevice = 0x2004,
2961 .driver_data = SAA7134_BOARD_PHILIPS_TOUGH,
2963 .vendor = PCI_VENDOR_ID_PHILIPS,
2964 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
2965 .subvendor = 0x1421,
2966 .subdevice = 0x0350, /* PCI version */
2967 .driver_data = SAA7134_BOARD_ADS_INSTANT_TV,
2969 .vendor = PCI_VENDOR_ID_PHILIPS,
2970 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
2971 .subvendor = 0x1421,
2972 .subdevice = 0x0351, /* PCI version, new revision */
2973 .driver_data = SAA7134_BOARD_ADS_INSTANT_TV,
2975 .vendor = PCI_VENDOR_ID_PHILIPS,
2976 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
2977 .subvendor = 0x1421,
2978 .subdevice = 0x0370, /* cardbus version */
2979 .driver_data = SAA7134_BOARD_ADS_INSTANT_TV,
2981 .vendor = PCI_VENDOR_ID_PHILIPS,
2982 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
2983 .subvendor = 0x1421,
2984 .subdevice = 0x1370, /* cardbus version */
2985 .driver_data = SAA7134_BOARD_ADS_INSTANT_TV,
2988 .vendor = PCI_VENDOR_ID_PHILIPS,
2989 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
2990 .subvendor = 0x4e42, /* Typhoon */
2991 .subdevice = 0x0502, /* LifeView LR502 OEM */
2992 .driver_data = SAA7134_BOARD_FLYDVBT_DUO_CARDBUS,
2994 .vendor = PCI_VENDOR_ID_PHILIPS,
2995 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
2996 .subvendor = 0x1043,
2997 .subdevice = 0x0210, /* mini pci NTSC version */
2998 .driver_data = SAA7134_BOARD_FLYTV_DIGIMATRIX,
3000 .vendor = PCI_VENDOR_ID_PHILIPS,
3001 .device = PCI_DEVICE_ID_PHILIPS_SAA7134,
3002 .subvendor = 0x1043,
3003 .subdevice = 0x0210, /* mini pci PAL/SECAM version */
3004 .driver_data = SAA7134_BOARD_ASUSTEK_DIGIMATRIX_TV,
3007 .vendor = PCI_VENDOR_ID_PHILIPS,
3008 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
3009 .subvendor = 0x0000, /* It shouldn't break anything, since subdevice id seems unique */
3010 .subdevice = 0x4091,
3011 .driver_data = SAA7134_BOARD_BEHOLD_409FM,
3013 .vendor = PCI_VENDOR_ID_PHILIPS,
3014 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
3015 .subvendor = 0x5456, /* GoTView */
3016 .subdevice = 0x7135,
3017 .driver_data = SAA7134_BOARD_GOTVIEW_7135,
3019 .vendor = PCI_VENDOR_ID_PHILIPS,
3020 .device = PCI_DEVICE_ID_PHILIPS_SAA7134,
3021 .subvendor = PCI_VENDOR_ID_PHILIPS,
3022 .subdevice = 0x2004,
3023 .driver_data = SAA7134_BOARD_PHILIPS_EUROPA,
3025 .vendor = PCI_VENDOR_ID_PHILIPS,
3026 .device = PCI_DEVICE_ID_PHILIPS_SAA7134,
3027 .subvendor = 0x185b,
3028 .subdevice = 0xc900,
3029 .driver_data = SAA7134_BOARD_VIDEOMATE_DVBT_300,
3031 .vendor = PCI_VENDOR_ID_PHILIPS,
3032 .device = PCI_DEVICE_ID_PHILIPS_SAA7130,
3033 .subvendor = 0x185b,
3034 .subdevice = 0xc901,
3035 .driver_data = SAA7134_BOARD_VIDEOMATE_DVBT_200,
3037 .vendor = PCI_VENDOR_ID_PHILIPS,
3038 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
3039 .subvendor = 0x1435,
3040 .subdevice = 0x7350,
3041 .driver_data = SAA7134_BOARD_RTD_VFG7350,
3043 .vendor = PCI_VENDOR_ID_PHILIPS,
3044 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
3045 .subvendor = 0x1435,
3046 .subdevice = 0x7330,
3047 .driver_data = SAA7134_BOARD_RTD_VFG7330,
3049 .vendor = PCI_VENDOR_ID_PHILIPS,
3050 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
3051 .subvendor = 0x1461,
3052 .subdevice = 0x1044,
3053 .driver_data = SAA7134_BOARD_AVERMEDIA_AVERTVHD_A180,
3055 .vendor = PCI_VENDOR_ID_PHILIPS,
3056 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
3057 .subvendor = 0x1131,
3058 .subdevice = 0x4ee9,
3059 .driver_data = SAA7134_BOARD_MONSTERTV_MOBILE,
3061 .vendor = PCI_VENDOR_ID_PHILIPS,
3062 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
3063 .subvendor = 0x11bd,
3064 .subdevice = 0x002e,
3065 .driver_data = SAA7134_BOARD_PINNACLE_PCTV_110i,
3067 .vendor = PCI_VENDOR_ID_PHILIPS,
3068 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
3069 .subvendor = 0x1043,
3070 .subdevice = 0x4862,
3071 .driver_data = SAA7134_BOARD_ASUSTeK_P7131_DUAL,
3073 .vendor = PCI_VENDOR_ID_PHILIPS,
3074 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
3075 .subvendor = PCI_VENDOR_ID_PHILIPS,
3076 .subdevice = 0x2018,
3077 .driver_data = SAA7134_BOARD_PHILIPS_TIGER,
3079 .vendor = PCI_VENDOR_ID_PHILIPS,
3080 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
3081 .subvendor = 0x1462,
3082 .subdevice = 0x6231,
3083 .driver_data = SAA7134_BOARD_MSI_TVATANYWHERE_PLUS,
3085 .vendor = PCI_VENDOR_ID_PHILIPS,
3086 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
3087 .subvendor = 0x153b,
3088 .subdevice = 0x1160,
3089 .driver_data = SAA7134_BOARD_CINERGY250PCI,
3091 .vendor = PCI_VENDOR_ID_PHILIPS,
3092 .device = PCI_DEVICE_ID_PHILIPS_SAA7133, /* SAA 7131E */
3093 .subvendor = 0x5168,
3094 .subdevice = 0x0319,
3095 .driver_data = SAA7134_BOARD_FLYDVB_TRIO,
3097 /* --- boards without eeprom + subsystem ID --- */
3098 .vendor = PCI_VENDOR_ID_PHILIPS,
3099 .device = PCI_DEVICE_ID_PHILIPS_SAA7134,
3100 .subvendor = PCI_VENDOR_ID_PHILIPS,
3102 .driver_data = SAA7134_BOARD_NOAUTO,
3104 .vendor = PCI_VENDOR_ID_PHILIPS,
3105 .device = PCI_DEVICE_ID_PHILIPS_SAA7130,
3106 .subvendor = PCI_VENDOR_ID_PHILIPS,
3108 .driver_data = SAA7134_BOARD_NOAUTO,
3111 /* --- default catch --- */
3112 .vendor = PCI_VENDOR_ID_PHILIPS,
3113 .device = PCI_DEVICE_ID_PHILIPS_SAA7130,
3114 .subvendor = PCI_ANY_ID,
3115 .subdevice = PCI_ANY_ID,
3116 .driver_data = SAA7134_BOARD_UNKNOWN,
3118 .vendor = PCI_VENDOR_ID_PHILIPS,
3119 .device = PCI_DEVICE_ID_PHILIPS_SAA7133,
3120 .subvendor = PCI_ANY_ID,
3121 .subdevice = PCI_ANY_ID,
3122 .driver_data = SAA7134_BOARD_UNKNOWN,
3124 .vendor = PCI_VENDOR_ID_PHILIPS,
3125 .device = PCI_DEVICE_ID_PHILIPS_SAA7134,
3126 .subvendor = PCI_ANY_ID,
3127 .subdevice = PCI_ANY_ID,
3128 .driver_data = SAA7134_BOARD_UNKNOWN,
3130 .vendor = PCI_VENDOR_ID_PHILIPS,
3131 .device = PCI_DEVICE_ID_PHILIPS_SAA7135,
3132 .subvendor = PCI_ANY_ID,
3133 .subdevice = PCI_ANY_ID,
3134 .driver_data = SAA7134_BOARD_UNKNOWN,
3136 /* --- end of list --- */
3139 MODULE_DEVICE_TABLE(pci, saa7134_pci_tbl);
3141 /* ----------------------------------------------------------- */
3142 /* flyvideo tweaks */
3145 static void board_flyvideo(struct saa7134_dev *dev)
3147 printk("%s: there are different flyvideo cards with different tuners\n"
3148 "%s: out there, you might have to use the tuner=<nr> insmod\n"
3149 "%s: option to override the default value.\n",
3150 dev->name, dev->name, dev->name);
3153 /* ----------------------------------------------------------- */
3155 int saa7134_board_init1(struct saa7134_dev *dev)
3157 /* Always print gpio, often manufacturers encode tuner type and other info. */
3158 saa_writel(SAA7134_GPIO_GPMODE0 >> 2, 0);
3159 dev->gpio_value = saa_readl(SAA7134_GPIO_GPSTATUS0 >> 2);
3160 printk(KERN_INFO "%s: board init: gpio is %x\n", dev->name, dev->gpio_value);
3162 switch (dev->board) {
3163 case SAA7134_BOARD_FLYVIDEO2000:
3164 case SAA7134_BOARD_FLYVIDEO3000:
3165 dev->has_remote = SAA7134_REMOTE_GPIO;
3166 board_flyvideo(dev);
3168 case SAA7134_BOARD_FLYTVPLATINUM_MINI2:
3169 case SAA7134_BOARD_FLYTVPLATINUM_FM:
3170 case SAA7134_BOARD_CINERGY400:
3171 case SAA7134_BOARD_CINERGY600:
3172 case SAA7134_BOARD_CINERGY600_MK3:
3173 case SAA7134_BOARD_ECS_TVP3XP:
3174 case SAA7134_BOARD_ECS_TVP3XP_4CB5:
3175 case SAA7134_BOARD_MD2819:
3176 case SAA7134_BOARD_KWORLD_VSTREAM_XPERT:
3177 case SAA7134_BOARD_KWORLD_XPERT:
3178 case SAA7134_BOARD_AVERMEDIA_STUDIO_305:
3179 case SAA7134_BOARD_AVERMEDIA_305:
3180 case SAA7134_BOARD_AVERMEDIA_STUDIO_307:
3181 case SAA7134_BOARD_AVERMEDIA_307:
3182 case SAA7134_BOARD_AVERMEDIA_GO_007_FM:
3183 /* case SAA7134_BOARD_SABRENT_SBTTVFM: */ /* not finished yet */
3184 case SAA7134_BOARD_VIDEOMATE_TV_PVR:
3185 case SAA7134_BOARD_VIDEOMATE_GOLD_PLUS:
3186 case SAA7134_BOARD_VIDEOMATE_TV_GOLD_PLUSII:
3187 case SAA7134_BOARD_VIDEOMATE_DVBT_300:
3188 case SAA7134_BOARD_VIDEOMATE_DVBT_200:
3189 case SAA7134_BOARD_MANLI_MTV001:
3190 case SAA7134_BOARD_MANLI_MTV002:
3191 case SAA7134_BOARD_BEHOLD_409FM:
3192 case SAA7134_BOARD_AVACSSMARTTV:
3193 case SAA7134_BOARD_GOTVIEW_7135:
3194 case SAA7134_BOARD_KWORLD_TERMINATOR:
3195 case SAA7134_BOARD_SEDNA_PC_TV_CARDBUS:
3196 dev->has_remote = SAA7134_REMOTE_GPIO;
3198 case SAA7134_BOARD_MD5044:
3199 printk("%s: seems there are two different versions of the MD5044\n"
3200 "%s: (with the same ID) out there. If sound doesn't work for\n"
3201 "%s: you try the audio_clock_override=0x200000 insmod option.\n",
3202 dev->name,dev->name,dev->name);
3204 case SAA7134_BOARD_CINERGY400_CARDBUS:
3205 /* power-up tuner chip */
3206 saa_andorl(SAA7134_GPIO_GPMODE0 >> 2, 0x00040000, 0x00040000);
3207 saa_andorl(SAA7134_GPIO_GPSTATUS0 >> 2, 0x00040000, 0x00000000);
3208 case SAA7134_BOARD_MONSTERTV_MOBILE:
3209 /* power-up tuner chip */
3210 saa_andorl(SAA7134_GPIO_GPMODE0 >> 2, 0x00040000, 0x00040000);
3211 saa_andorl(SAA7134_GPIO_GPSTATUS0 >> 2, 0x00040000, 0x00000004);
3213 case SAA7134_BOARD_FLYDVBT_DUO_CARDBUS:
3214 /* turn the fan on */
3215 saa_writeb(SAA7134_GPIO_GPMODE3, 0x08);
3216 saa_writeb(SAA7134_GPIO_GPSTATUS3, 0x06);
3218 case SAA7134_BOARD_AVERMEDIA_CARDBUS:
3219 /* power-up tuner chip */
3220 saa_andorl(SAA7134_GPIO_GPMODE0 >> 2, 0xffffffff, 0xffffffff);
3221 saa_andorl(SAA7134_GPIO_GPSTATUS0 >> 2, 0xffffffff, 0xffffffff);
3224 case SAA7134_BOARD_RTD_VFG7350:
3227 * Make sure Production Test Register at offset 0x1D1 is cleared
3228 * to take chip out of test mode. Clearing bit 4 (TST_EN_AOUT)
3229 * prevents pin 105 from remaining low; keeping pin 105 low
3230 * continually resets the SAA6752 chip.
3233 saa_writeb (SAA7134_PRODUCTION_TEST_MODE, 0x00);
3236 case SAA7134_BOARD_PINNACLE_PCTV_110i:
3237 case SAA7134_BOARD_UPMOST_PURPLE_TV:
3238 dev->has_remote = SAA7134_REMOTE_I2C;
3244 /* stuff which needs working i2c */
3245 int saa7134_board_init2(struct saa7134_dev *dev)
3250 switch (dev->board) {
3251 case SAA7134_BOARD_BMK_MPEX_NOTUNER:
3252 case SAA7134_BOARD_BMK_MPEX_TUNER:
3253 dev->i2c_client.addr = 0x60;
3254 board = (i2c_master_recv(&dev->i2c_client,&buf,0) < 0)
3255 ? SAA7134_BOARD_BMK_MPEX_NOTUNER
3256 : SAA7134_BOARD_BMK_MPEX_TUNER;
3257 if (board == dev->board)
3260 printk("%s: board type fixup: %s\n", dev->name,
3261 saa7134_boards[dev->board].name);
3262 dev->tuner_type = saa7134_boards[dev->board].tuner_type;
3264 if (TUNER_ABSENT != dev->tuner_type) {
3265 struct tuner_setup tun_setup;
3267 tun_setup.mode_mask = T_RADIO | T_ANALOG_TV | T_DIGITAL_TV;
3268 tun_setup.type = dev->tuner_type;
3269 tun_setup.addr = ADDR_UNSET;
3271 saa7134_i2c_call_clients (dev, TUNER_SET_TYPE_ADDR, &tun_setup);
3274 case SAA7134_BOARD_MD7134:
3276 struct tuner_setup tun_setup;
3281 struct i2c_msg msg[] = {{.addr=0x50, .flags=0, .buf=&subaddr, .len = 1},
3282 {.addr=0x50, .flags=I2C_M_RD, .buf=data, .len = 3}};
3285 ret = i2c_transfer(&dev->i2c_adap, msg, 2);
3287 printk(KERN_ERR "EEPROM read failure\n");
3288 } else if ((data[0] != 0) && (data[0] != 0xff)) {
3289 /* old config structure */
3290 subaddr = data[0] + 2;
3292 i2c_transfer(&dev->i2c_adap, msg, 2);
3293 tuner_t = (data[0] << 8) + data[1];
3296 dev->tuner_type = TUNER_PHILIPS_PAL;
3299 dev->tuner_type = TUNER_PHILIPS_FM1216ME_MK3;
3302 printk(KERN_ERR "%s Cant determine tuner type %x from EEPROM\n", dev->name, tuner_t);
3304 } else if ((data[1] != 0) && (data[1] != 0xff)) {
3305 /* new config structure */
3306 subaddr = data[1] + 1;
3308 i2c_transfer(&dev->i2c_adap, msg, 2);
3309 subaddr = data[0] + 1;
3311 i2c_transfer(&dev->i2c_adap, msg, 2);
3312 tuner_t = (data[1] << 8) + data[0];
3315 dev->tuner_type = TUNER_PHILIPS_FM1216ME_MK3;
3318 dev->tuner_type = TUNER_PHILIPS_FMD1216ME_MK3;
3319 printk(KERN_INFO "%s Board has DVB-T\n", dev->name);
3322 printk(KERN_ERR "%s Cant determine tuner type %x from EEPROM\n", dev->name, tuner_t);
3325 printk(KERN_ERR "%s unexpected config structure\n", dev->name);
3328 printk(KERN_INFO "%s Tuner type is %d\n", dev->name, dev->tuner_type);
3329 if (dev->tuner_type == TUNER_PHILIPS_FMD1216ME_MK3) {
3330 dev->tda9887_conf = TDA9887_PRESENT | TDA9887_PORT1_ACTIVE | TDA9887_PORT2_ACTIVE;
3331 saa7134_i2c_call_clients(dev,TDA9887_SET_CONFIG, &dev->tda9887_conf);
3334 tun_setup.mode_mask = T_RADIO | T_ANALOG_TV | T_DIGITAL_TV;
3335 tun_setup.type = dev->tuner_type;
3336 tun_setup.addr = ADDR_UNSET;
3338 saa7134_i2c_call_clients (dev, TUNER_SET_TYPE_ADDR,&tun_setup);
3341 case SAA7134_BOARD_PHILIPS_EUROPA:
3342 case SAA7134_BOARD_VIDEOMATE_DVBT_300:
3343 /* The Philips EUROPA based hybrid boards have the tuner connected through
3344 * the channel decoder. We have to make it transparent to find it
3347 struct tuner_setup tun_setup;
3348 u8 data[] = { 0x07, 0x02};
3349 struct i2c_msg msg = {.addr=0x08, .flags=0, .buf=data, .len = sizeof(data)};
3350 i2c_transfer(&dev->i2c_adap, &msg, 1);
3352 tun_setup.mode_mask = T_ANALOG_TV | T_DIGITAL_TV;
3353 tun_setup.type = dev->tuner_type;
3354 tun_setup.addr = dev->tuner_addr;
3356 saa7134_i2c_call_clients (dev, TUNER_SET_TYPE_ADDR,&tun_setup);
3359 case SAA7134_BOARD_PHILIPS_TIGER:
3360 case SAA7134_BOARD_ASUSTeK_P7131_DUAL:
3361 /* this is a hybrid board, initialize to analog mode */
3363 u8 data[] = { 0x3c, 0x33, 0x68};
3364 struct i2c_msg msg = {.addr=0x08, .flags=0, .buf=data, .len = sizeof(data)};
3365 i2c_transfer(&dev->i2c_adap, &msg, 1);
3372 /* ----------------------------------------------------------- */