bttv-cards.c
上传用户:lgb322
上传日期:2013-02-24
资源大小:30529k
文件大小:52k
- /*
- bttv-cards.c
- this file has configuration informations - card-specific stuff
- like the big tvcards array for the most part
- Copyright (C) 1996,97,98 Ralph Metzler (rjkm@thp.uni-koeln.de)
- & Marcus Metzler (mocm@thp.uni-koeln.de)
- (c) 1999-2001 Gerd Knorr <kraxel@goldbach.in-berlin.de>
- This program is free software; you can redistribute it and/or modify
- it under the terms of the GNU General Public License as published by
- the Free Software Foundation; either version 2 of the License, or
- (at your option) any later version.
- This program is distributed in the hope that it will be useful,
- but WITHOUT ANY WARRANTY; without even the implied warranty of
- MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
- GNU General Public License for more details.
- You should have received a copy of the GNU General Public License
- along with this program; if not, write to the Free Software
- Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
-
- */
- #define __NO_VERSION__ 1
- #include <linux/version.h>
- #include <linux/delay.h>
- #include <linux/module.h>
- #include <linux/kmod.h>
- #include <linux/init.h>
- #include <linux/pci.h>
- #include <asm/io.h>
- #include "bttvp.h"
- #include "tuner.h"
- /* fwd decl */
- static void hauppauge_eeprom(struct bttv *btv);
- static void avermedia_eeprom(struct bttv *btv);
- static void init_PXC200(struct bttv *btv);
- #if 0
- static void init_tea5757(struct bttv *btv);
- #endif
- static void winview_audio(struct bttv *btv, struct video_audio *v, int set);
- static void lt9415_audio(struct bttv *btv, struct video_audio *v, int set);
- static void avermedia_tvphone_audio(struct bttv *btv, struct video_audio *v,
- int set);
- static void terratv_audio(struct bttv *btv, struct video_audio *v, int set);
- static void gvbctv3pci_audio(struct bttv *btv, struct video_audio *v, int set);
- static void winfast2000_audio(struct bttv *btv, struct video_audio *v, int set);
- static void pvbt878p9b_audio(struct bttv *btv, struct video_audio *v, int set);
- /* config variables */
- static int triton1=0;
- static int vsfx=0;
- int no_overlay=-1;
- static unsigned int card[4] = { -1, -1, -1, -1 };
- static unsigned int pll[4] = { -1, -1, -1, -1 };
- static unsigned int tuner[4] = { -1, -1, -1, -1 };
- #ifdef MODULE
- static unsigned int autoload = 1;
- #else
- static unsigned int autoload = 0;
- #endif
- static unsigned int gpiomask = -1;
- static unsigned int audioall = -1;
- static unsigned int audiomux[5] = { -1, -1, -1, -1, -1 };
- /* insmod options */
- MODULE_PARM(triton1,"i");
- MODULE_PARM_DESC(triton1,"set ETBF pci config bit "
- "[enable bug compatibility for triton1 + others]");
- MODULE_PARM(vsfx,"i");
- MODULE_PARM_DESC(vsfx,"set VSFX pci config bit [yet another chipset flaw workaround]");
- MODULE_PARM(no_overlay,"i");
- MODULE_PARM(card,"1-4i");
- MODULE_PARM_DESC(card,"specify TV/grabber card model, see CARDLIST file for a list");
- MODULE_PARM(pll,"1-4i");
- MODULE_PARM_DESC(pll,"specify installed crystal (0=none, 28=28 MHz, 35=35 MHz)");
- MODULE_PARM(tuner,"1-4i");
- MODULE_PARM_DESC(tuner,"specify installed tuner type");
- MODULE_PARM(autoload,"i");
- MODULE_PARM_DESC(autoload,"automatically load i2c modules like tuner.o, default is 1 (yes)");
- MODULE_PARM(gpiomask,"i");
- MODULE_PARM(audioall,"i");
- MODULE_PARM(audiomux,"1-5i");
- /* kernel args */
- #ifndef MODULE
- static int __init p_card(char *str) { return bttv_parse(str,BTTV_MAX,card); }
- static int __init p_pll(char *str) { return bttv_parse(str,BTTV_MAX,pll); }
- static int __init p_tuner(char *str) { return bttv_parse(str,BTTV_MAX,tuner); }
- __setup("bttv.card=", p_card);
- __setup("bttv.pll=", p_pll);
- __setup("bttv.tuner=", p_tuner);
- int __init bttv_parse(char *str, int max, int *vals)
- {
- int i,number,res = 2;
-
- for (i = 0; res == 2 && i < max; i++) {
- res = get_option(&str,&number);
- if (res)
- vals[i] = number;
- }
- return 1;
- }
- #endif
- /* ----------------------------------------------------------------------- */
- /* list of card IDs for bt878+ cards */
- static struct CARD {
- unsigned id;
- int cardnr;
- char *name;
- } cards[] __devinitdata = {
- { 0x13eb0070, BTTV_HAUPPAUGE878, "Hauppauge WinTV" },
- { 0x39000070, BTTV_HAUPPAUGE878, "Hauppauge WinTV-D" },
- { 0x45000070, BTTV_HAUPPAUGE878, "Hauppauge WinTV/PVR" },
- { 0xff000070, BTTV_HAUPPAUGE878, "Osprey-100" },
- { 0xff010070, BTTV_HAUPPAUGE878, "Osprey-200" },
- { 0x00011002, BTTV_ATI_TVWONDER, "ATI TV Wonder" },
- { 0x00031002, BTTV_ATI_TVWONDERVE,"ATI TV Wonder/VE" },
- { 0x6606107d, BTTV_WINFAST2000, "Leadtek WinFast TV 2000" },
- { 0x263610b4, BTTV_STB2, "STB TV PCI FM, P/N 6000704" },
- { 0x402010fc, BTTV_GVBCTV3PCI, "I-O Data Co. GV-BCV3/PCI" },
- { 0x405010fc, BTTV_GVBCTV4PCI, "I-O Data Co. GV-BCV4/PCI" },
- { 0x1200bd11, BTTV_PINNACLE, "Pinnacle PCTV" },
- { 0x001211bd, BTTV_PINNACLE, "Pinnacle PCTV" },
- { 0x001c11bd, BTTV_PINNACLE, "Pinnacle PCTV Sat" },
- { 0x3000121a, BTTV_VOODOOTV_FM, "3Dfx VoodooTV FM/ VoodooTV 200" },
-
- { 0x3000144f, BTTV_MAGICTVIEW063, "(Askey Magic/others) TView99 CPH06x" },
- { 0x3002144f, BTTV_MAGICTVIEW061, "(Askey Magic/others) TView99 CPH05x" },
- { 0x3005144f, BTTV_MAGICTVIEW061, "(Askey Magic/others) TView99 CPH061/06L (T1/LC)" },
-
- { 0x00011461, BTTV_AVPHONE98, "AVerMedia TVPhone98" },
- { 0x00021461, BTTV_AVERMEDIA98, "AVermedia TVCapture 98" },
- { 0x00031461, BTTV_AVPHONE98, "AVerMedia TVPhone98" },
- { 0x00041461, BTTV_AVERMEDIA98, "AVerMedia TVCapture 98" },
- { 0x300014ff, BTTV_MAGICTVIEW061, "TView 99 (CPH061)" },
- { 0x300214ff, BTTV_PHOEBE_TVMAS, "Phoebe TV Master" },
- { 0x1117153b, BTTV_TERRATVALUE, "Terratec TValue" },
- { 0x1118153b, BTTV_TERRATVALUE, "Terratec TValue" },
- { 0x1119153b, BTTV_TERRATVALUE, "Terratec TValue" },
- { 0x111a153b, BTTV_TERRATVALUE, "Terratec TValue" },
- { 0x1123153b, BTTV_TERRATVRADIO, "Terratec TV Radio+" },
- { 0x1127153b, BTTV_TERRATV, "Terratec TV+" },
- { 0x1134153b, BTTV_TERRATVALUE, "Terratec TValue" },
- { 0x1135153b, BTTV_TERRATVALUER, "Terratec TValue Radio" },
- { 0x400a15b0, BTTV_ZOLTRIX_GENIE, "Zoltrix Genie TV" },
- { 0x400d15b0, BTTV_ZOLTRIX_GENIE, "Zoltrix Genie TV / Radio" },
- { 0x401015b0, BTTV_ZOLTRIX_GENIE, "Zoltrix Genie TV / Radio" },
- { 0x401615b0, BTTV_ZOLTRIX_GENIE, "Zoltrix Genie TV / Radio" },
- { 0x010115cb, BTTV_GMV1, "AG GMV1" },
- { 0x010114c7, BTTV_MODTEC_205, "Modular Technology PCTV" },
- { 0x18501851, BTTV_CHRONOS_VS2, "Flyvideo 98 (LR50)/ Chronos Video Shuttle II" },
- { 0x18511851, BTTV_FLYVIDEO98EZ, "Flyvideo 98EZ (LR51)/ CyberMail AV" },
- { 0x18521852, BTTV_TYPHOON_TVIEW, "Flyvideo 98FM (LR50)/ Typhoon TView TV/FM Tuner" },
- { 0x10b42636, BTTV_HAUPPAUGE878, "STB ???" },
- { 0x217d6606, BTTV_WINFAST2000, "Leadtek WinFast TV 2000" },
- { 0, -1, NULL }
- };
- /* ----------------------------------------------------------------------- */
- /* array with description for bt848 / bt878 tv/grabber cards */
- struct tvcard bttv_tvcards[] = {
- {
- /* ---- card 0x00 ---------------------------------- */
- name: " *** UNKNOWN/GENERIC *** ",
- video_inputs: 4,
- audio_inputs: 1,
- tuner: 0,
- svhs: 2,
- muxsel: { 2, 3, 1, 0},
- tuner_type: -1,
- },{
- name: "MIRO PCTV",
- video_inputs: 4,
- audio_inputs: 1,
- tuner: 0,
- svhs: 2,
- gpiomask: 15,
- muxsel: { 2, 3, 1, 1},
- audiomux: { 2, 0, 0, 0, 10},
- needs_tvaudio: 1,
- tuner_type: -1,
- },{
- name: "Hauppauge (bt848)",
- video_inputs: 4,
- audio_inputs: 1,
- tuner: 0,
- svhs: 2,
- gpiomask: 7,
- muxsel: { 2, 3, 1, 1},
- audiomux: { 0, 1, 2, 3, 4},
- needs_tvaudio: 1,
- tuner_type: -1,
- },{
- name: "STB",
- video_inputs: 3,
- audio_inputs: 1,
- tuner: 0,
- svhs: 2,
- gpiomask: 7,
- muxsel: { 2, 3, 1, 1},
- audiomux: { 4, 0, 2, 3, 1},
- no_msp34xx: 1,
- needs_tvaudio: 1,
- tuner_type: -1,
- },{
- /* ---- card 0x04 ---------------------------------- */
- name: "Intel",
- video_inputs: 3,
- audio_inputs: 1,
- tuner: 0,
- svhs: -1,
- gpiomask: 7,
- muxsel: { 2, 3, 1, 1},
- audiomux: { 0, 1, 2, 3, 4},
- needs_tvaudio: 1,
- tuner_type: -1,
- },{
- name: "Diamond DTV2000",
- video_inputs: 4,
- audio_inputs: 1,
- tuner: 0,
- svhs: 2,
- gpiomask: 3,
- muxsel: { 2, 3, 1, 0},
- audiomux: { 0, 1, 0, 1, 3},
- needs_tvaudio: 1,
- tuner_type: -1,
- },{
- name: "AVerMedia TVPhone",
- video_inputs: 3,
- audio_inputs: 1,
- tuner: 0,
- svhs: 3,
- muxsel: { 2, 3, 1, 1},
- gpiomask: 0x0f,
- audiomux: { 0x0c, 0x04, 0x08, 0x04, 0},
- /* 0x04 for some cards ?? */
- needs_tvaudio: 1,
- tuner_type: -1,
- audio_hook: avermedia_tvphone_audio,
- },{
- name: "MATRIX-Vision MV-Delta",
- video_inputs: 5,
- audio_inputs: 1,
- tuner: -1,
- svhs: 3,
- gpiomask: 0,
- muxsel: { 2, 3, 1, 0, 0},
- audiomux: {0 },
- needs_tvaudio: 1,
- tuner_type: -1,
- },{
- /* ---- card 0x08 ---------------------------------- */
- name: "Fly Video II (Bt848)",
- video_inputs: 3,
- audio_inputs: 1,
- tuner: 0,
- svhs: 2,
- gpiomask: 0xc00,
- muxsel: { 2, 3, 1, 1},
- audiomux: { 0, 0xc00, 0x800, 0x400, 0xc00, 0},
- needs_tvaudio: 1,
- tuner_type: -1,
- },{
- name: "TurboTV",
- video_inputs: 3,
- audio_inputs: 1,
- tuner: 0,
- svhs: 2,
- gpiomask: 3,
- muxsel: { 2, 3, 1, 1},
- audiomux: { 1, 1, 2, 3, 0},
- needs_tvaudio: 1,
- tuner_type: -1,
- },{
- name: "Hauppauge (bt878)",
- video_inputs: 4,
- audio_inputs: 1,
- tuner: 0,
- svhs: 2,
- gpiomask: 0x0f, /* old: 7 */
- muxsel: { 2, 0, 1, 1},
- audiomux: { 0, 1, 2, 3, 4},
- needs_tvaudio: 1,
- pll: PLL_28,
- tuner_type: -1,
- },{
- name: "MIRO PCTV pro",
- video_inputs: 3,
- audio_inputs: 1,
- tuner: 0,
- svhs: 2,
- gpiomask: 0x3014f,
- muxsel: { 2, 3, 1, 1},
- audiomux: { 0x20001,0x10001, 0, 0,10},
- needs_tvaudio: 1,
- tuner_type: -1,
- },{
- /* ---- card 0x0c ---------------------------------- */
- name: "ADS Technologies Channel Surfer TV",
- video_inputs: 3,
- audio_inputs: 1,
- tuner: 0,
- svhs: 2,
- gpiomask: 15,
- muxsel: { 2, 3, 1, 1},
- audiomux: { 13, 14, 11, 7, 0, 0},
- needs_tvaudio: 1,
- tuner_type: -1,
- },{
- name: "AVerMedia TVCapture 98",
- video_inputs: 3,
- audio_inputs: 4,
- tuner: 0,
- svhs: 2,
- gpiomask: 15,
- muxsel: { 2, 3, 1, 1},
- audiomux: { 13, 14, 11, 7, 0, 0},
- needs_tvaudio: 1,
- pll: PLL_28,
- tuner_type: -1,
- },{
- name: "Aimslab VHX",
- video_inputs: 3,
- audio_inputs: 1,
- tuner: 0,
- svhs: 2,
- gpiomask: 7,
- muxsel: { 2, 3, 1, 1},
- audiomux: { 0, 1, 2, 3, 4},
- needs_tvaudio: 1,
- tuner_type: -1,
- },{
- name: "Zoltrix TV-Max",
- video_inputs: 3,
- audio_inputs: 1,
- tuner: 0,
- svhs: 2,
- gpiomask: 15,
- muxsel: { 2, 3, 1, 1},
- audiomux: {0 , 0, 1 , 0, 10},
- needs_tvaudio: 1,
- tuner_type: -1,
- },{
- /* ---- card 0x10 ---------------------------------- */
- name: "Pixelview PlayTV (bt878)",
- video_inputs: 3,
- audio_inputs: 1,
- tuner: 0,
- svhs: 2,
- gpiomask: 0x01fe00,
- muxsel: { 2, 3, 1, 1},
- audiomux: { 0x01c000, 0, 0x018000, 0x014000, 0x002000, 0 },
- needs_tvaudio: 1,
- pll: PLL_28,
- tuner_type: -1,
- },{
- name: "Leadtek WinView 601",
- video_inputs: 3,
- audio_inputs: 1,
- tuner: 0,
- svhs: 2,
- gpiomask: 0x8300f8,
- muxsel: { 2, 3, 1, 1,0},
- audiomux: { 0x4fa007,0xcfa007,0xcfa007,0xcfa007,0xcfa007,0xcfa007},
- needs_tvaudio: 1,
- tuner_type: -1,
- audio_hook: winview_audio,
- },{
- name: "AVEC Intercapture",
- video_inputs: 3,
- audio_inputs: 2,
- tuner: 0,
- svhs: 2,
- gpiomask: 0,
- muxsel: {2, 3, 1, 1},
- audiomux: {1, 0, 0, 0, 0},
- needs_tvaudio: 1,
- tuner_type: -1,
- },{
- name: "LifeView FlyKit w/o Tuner",
- video_inputs: 3,
- audio_inputs: 1,
- tuner: -1,
- svhs: -1,
- gpiomask: 0x8dff00,
- muxsel: { 2, 3, 1, 1},
- audiomux: { 0 },
- no_msp34xx: 1,
- tuner_type: -1,
- },{
- /* ---- card 0x14 ---------------------------------- */
- name: "CEI Raffles Card",
- video_inputs: 3,
- audio_inputs: 3,
- tuner: 0,
- svhs: 2,
- muxsel: {2, 3, 1, 1},
- tuner_type: -1,
- },{
- name: "Lucky Star Image World ConferenceTV",
- video_inputs: 3,
- audio_inputs: 1,
- tuner: 0,
- svhs: 2,
- gpiomask: 0x00fffe07,
- muxsel: { 2, 3, 1, 1},
- audiomux: { 131072, 1, 1638400, 3, 4},
- needs_tvaudio: 1,
- pll: PLL_28,
- tuner_type: TUNER_PHILIPS_PAL_I,
- },{
- name: "Phoebe Tv Master + FM",
- video_inputs: 3,
- audio_inputs: 1,
- tuner: 0,
- svhs: 2,
- gpiomask: 0xc00,
- muxsel: { 2, 3, 1, 1},
- audiomux: {0, 1, 0x800, 0x400, 0xc00, 0},
- needs_tvaudio: 1,
- tuner_type: -1,
- },{
- name: "Modular Technology MM205 PCTV, bt878",
- video_inputs: 2,
- audio_inputs: 1,
- tuner: 0,
- svhs: -1,
- gpiomask: 7,
- muxsel: { 2, 3 },
- audiomux: { 0, 0, 0, 0, 0 },
- no_msp34xx: 1,
- pll: PLL_28,
- tuner_type: TUNER_ALPS_TSBB5_PAL_I,
- },{
- /* ---- card 0x18 ---------------------------------- */
- name: "[many vendors] CPH05X/06X (bt878)",
- video_inputs: 3,
- audio_inputs: 1,
- tuner: 0,
- svhs: 2,
- gpiomask: 0xe00,
- muxsel: { 2, 3, 1, 1},
- audiomux: {0x400, 0x400, 0x400, 0x400, 0xc00},
- needs_tvaudio: 1,
- pll: PLL_28,
- tuner_type: -1,
- },{
- name: "Terratec/Vobis TV-Boostar",
- video_inputs: 3,
- audio_inputs: 1,
- tuner: 0,
- svhs: 2,
- gpiomask: 16777215,
- muxsel: { 2, 3, 1, 1},
- audiomux: { 131072, 1, 1638400, 3,4},
- needs_tvaudio: 1,
- tuner_type: -1,
- },{
- name: "Newer Hauppauge WinCam (bt878)",
- video_inputs: 4,
- audio_inputs: 1,
- tuner: 0,
- svhs: 3,
- gpiomask: 7,
- muxsel: { 2, 0, 1, 1},
- audiomux: { 0, 1, 2, 3, 4},
- needs_tvaudio: 1,
- tuner_type: -1,
- },{
- name: "MAXI TV Video PCI2",
- video_inputs: 3,
- audio_inputs: 1,
- tuner: 0,
- svhs: 2,
- gpiomask: 0xffff,
- muxsel: { 2, 3, 1, 1},
- audiomux: { 0, 1, 2, 3, 0xc00},
- needs_tvaudio: 1,
- tuner_type: TUNER_PHILIPS_SECAM,
- },{
- /* ---- card 0x1c ---------------------------------- */
- name: "Terratec TerraTV+",
- video_inputs: 3,
- audio_inputs: 1,
- tuner: 0,
- svhs: 2,
- gpiomask: 0x70000,
- muxsel: { 2, 3, 1, 1},
- audiomux: { 0x20000, 0x30000, 0x10000, 0x00000, 0x40000},
- needs_tvaudio: 1,
- tuner_type: TUNER_PHILIPS_PAL,
- audio_hook: terratv_audio,
- },{
- /* Jannik Fritsch <jannik@techfak.uni-bielefeld.de> */
- name: "Imagenation PXC200",
- video_inputs: 5,
- audio_inputs: 1,
- tuner: -1,
- svhs: 1, /* was: 4 */
- gpiomask: 0,
- muxsel: { 2, 3, 1, 0, 0},
- audiomux: { 0 },
- needs_tvaudio: 1,
- tuner_type: -1,
- },{
- name: "FlyVideo 98",
- video_inputs: 3,
- audio_inputs: 1,
- tuner: 0,
- svhs: 2,
- gpiomask: 0x1800, //0x8dfe00
- muxsel: {2, 3, 1, 1},
- audiomux: { 0, 0x0800, 0x1000, 0x1000, 0x1800, 0 },
- needs_tvaudio: 1,
- tuner_type: -1,
- },{
- name: "iProTV",
- video_inputs: 3,
- audio_inputs: 1,
- tuner: 0,
- svhs: 2,
- gpiomask: 1,
- muxsel: { 2, 3, 1, 1},
- audiomux: { 1, 0, 0, 0, 0 },
- tuner_type: -1,
- },{
- /* ---- card 0x20 ---------------------------------- */
- name: "Intel Create and Share PCI",
- video_inputs: 4,
- audio_inputs: 1,
- tuner: 0,
- svhs: 2,
- gpiomask: 7,
- muxsel: { 2, 3, 1, 1},
- audiomux: { 4, 4, 4, 4, 4},
- needs_tvaudio: 1,
- tuner_type: -1,
- },{
- name: "Terratec TerraTValue",
- video_inputs: 3,
- audio_inputs: 1,
- tuner: 0,
- svhs: 2,
- gpiomask: 0xffff00,
- muxsel: { 2, 3, 1, 1},
- audiomux: { 0x500, 0, 0x300, 0x900, 0x900},
- needs_tvaudio: 1,
- pll: PLL_28,
- tuner_type: TUNER_PHILIPS_PAL,
- },{
- name: "Leadtek WinFast 2000",
- video_inputs: 3,
- audio_inputs: 1,
- tuner: 0,
- svhs: 2,
- gpiomask: 0xc33000,
- muxsel: { 2, 3, 1, 1,0},
- audiomux: { 0x422000,0x001000,0x621100,0x620000,0x800000,0x620000},
- needs_tvaudio: 0,
- pll: PLL_28,
- tuner_type: -1,
- audio_hook: winfast2000_audio,
- },{
- name: "Flyvideo 98 (LR50Q) / Chronos Video Shuttle II",
- video_inputs: 3,
- audio_inputs: 3,
- tuner: 0,
- svhs: 2,
- gpiomask: 0x1800,
- muxsel: { 2, 3, 1, 1},
- audiomux: { 0, 0x800, 0x1000, 0x1000, 0x1800},
- needs_tvaudio: 1,
- pll: PLL_28,
- tuner_type: -1,
- },{
- /* ---- card 0x24 ---------------------------------- */
- name: "Flyvideo 98FM (LR50Q) / Typhoon TView TV/FM Tuner",
- video_inputs: 3,
- audio_inputs: 3,
- tuner: 0,
- svhs: 2,
- gpiomask: 0x1800,
- muxsel: { 2, 3, 1, 1},
- audiomux: { 0, 0x800, 0x1000, 0x1000, 0x1800, 0 },
- needs_tvaudio: 1,
- pll: PLL_28,
- tuner_type: -1,
- has_radio: 1,
- },{
- name: "PixelView PlayTV pro",
- video_inputs: 3,
- audio_inputs: 1,
- tuner: 0,
- svhs: 2,
- gpiomask: 0xff,
- muxsel: { 2, 3, 1, 1 },
- audiomux: { 0x21, 0x20, 0x24, 0x2c, 0x29, 0x29 },
- no_msp34xx: 1,
- pll: PLL_28,
- tuner_type: -1,
- },{
- name: "TView99 CPH06X",
- video_inputs: 4,
- audio_inputs: 1,
- tuner: 0,
- svhs: 2,
- gpiomask: 0x551e00,
- muxsel: { 2, 3, 1, 0},
- audiomux: { 0x551400, 0x551200, 0, 0, 0x551c00, 0x551200 },
- needs_tvaudio: 1,
- pll: PLL_28,
- tuner_type: -1,
- },{
- name: "Pinnacle PCTV Studio/Rave",
- video_inputs: 3,
- audio_inputs: 1,
- tuner: 0,
- svhs: 2,
- gpiomask: 0x03000F,
- muxsel: { 2, 3, 1, 1},
- audiomux: { 2, 0, 0, 0, 1},
- needs_tvaudio: 1,
- pll: PLL_28,
- tuner_type: -1,
- },{
- /* ---- card 0x28 ---------------------------------- */
- name: "STB2",
- video_inputs: 3,
- audio_inputs: 1,
- tuner: 0,
- svhs: 2,
- gpiomask: 7,
- muxsel: { 2, 3, 1, 1},
- audiomux: { 4, 0, 2, 3, 1},
- no_msp34xx: 1,
- needs_tvaudio: 1,
- tuner_type: -1,
- },{
- name: "AVerMedia TVPhone 98",
- video_inputs: 3,
- audio_inputs: 4,
- tuner: 0,
- svhs: 2,
- gpiomask: 12,
- muxsel: { 2, 3, 1, 1},
- audiomux: { 13, 4, 11, 7, 0, 0},
- needs_tvaudio: 1,
- pll: PLL_28,
- tuner_type: -1,
- has_radio: 1,
- },{
- name: "ProVideo PV951", /* pic16c54 */
- video_inputs: 3,
- audio_inputs: 1,
- tuner: 0,
- svhs: 2,
- gpiomask: 0,
- muxsel: { 2, 3, 1, 1},
- audiomux: { 0, 0, 0, 0, 0},
- no_msp34xx: 1,
- pll: PLL_28,
- tuner_type: 1,
- },{
- name: "Little OnAir TV",
- video_inputs: 3,
- audio_inputs: 1,
- tuner: 0,
- svhs: 2,
- gpiomask: 0xe00b,
- muxsel: {2, 3, 1, 1},
- audiomux: {0xff9ff6, 0xff9ff6, 0xff1ff7, 0, 0xff3ffc},
- no_msp34xx: 1,
- tuner_type: -1,
- },{
- /* ---- card 0x2c ---------------------------------- */
- name: "Sigma TVII-FM",
- video_inputs: 2,
- audio_inputs: 1,
- tuner: 0,
- svhs: -1,
- gpiomask: 3,
- muxsel: {2, 3, 1, 1},
- audiomux: {1, 1, 0, 2, 3},
- no_msp34xx: 1,
- pll: PLL_NONE,
- tuner_type: -1,
- },{
- name: "MATRIX-Vision MV-Delta 2",
- video_inputs: 5,
- audio_inputs: 1,
- tuner: -1,
- svhs: 3,
- gpiomask: 0,
- muxsel: { 2, 3, 1, 0, 0},
- audiomux: {0 },
- no_msp34xx: 1,
- pll: PLL_28,
- tuner_type: -1,
- },{
- name: "Zoltrix Genie TV/FM",
- video_inputs: 3,
- audio_inputs: 1,
- tuner: 0,
- svhs: 2,
- gpiomask: 0xbcf03f,
- muxsel: { 2, 3, 1, 1},
- audiomux: { 0xbc803f, 0xbc903f, 0xbcb03f, 0, 0xbcb03f},
- no_msp34xx: 1,
- pll: PLL_28,
- tuner_type: 21,
- },{
- name: "Terratec TV/Radio+",
- video_inputs: 3,
- audio_inputs: 1,
- tuner: 0,
- svhs: 2,
- gpiomask: 0x1f0000,
- muxsel: { 2, 3, 1, 1},
- audiomux: { 0xe2ffff, 0xebffff, 0, 0, 0xe0ffff, 0xe2ffff },
- no_msp34xx: 1,
- pll: PLL_35,
- tuner_type: 1,
- has_radio: 1,
- },{
- /* ---- card 0x30 ---------------------------------- */
- name: "Dynalink Magic TView ",
- video_inputs: 3,
- audio_inputs: 1,
- tuner: 0,
- svhs: 2,
- gpiomask: 15,
- muxsel: { 2, 3, 1, 1},
- audiomux: {2,0,0,0,1},
- needs_tvaudio: 1,
- pll: PLL_28,
- tuner_type: -1,
- },{
- name: "GV-BCTV3",
- video_inputs: 3,
- audio_inputs: 1,
- tuner: 0,
- svhs: 2,
- gpiomask: 0x010f00,
- muxsel: {2, 3, 0, 0},
- audiomux: {0x10000, 0, 0x10000, 0, 0, 0},
- no_msp34xx: 1,
- pll: PLL_28,
- tuner_type: TUNER_ALPS_TSHC6_NTSC,
- audio_hook: gvbctv3pci_audio,
- },{
- name: "Prolink PV-BT878P+4E / PixelView PlayTV PAK / Lenco MXTV-9578 CP",
- video_inputs: 4,
- audio_inputs: 1,
- tuner: 0,
- svhs: 2,
- gpiomask: 0xAA0000,
- muxsel: { 2,3,1,1 },
- audiomux: { 0x20000, 0, 0x80000, 0x80000, 0xa8000, 0x46000 },
- no_msp34xx: 1,
- pll: PLL_28,
- tuner_type: TUNER_PHILIPS_PAL_I,
- },{
- name: "Eagle Wireless Capricorn2 (bt878A)",
- video_inputs: 4,
- audio_inputs: 1,
- tuner: 0,
- svhs: 2,
- gpiomask: 7,
- muxsel: { 2, 0, 1, 1},
- audiomux: { 0, 1, 2, 3, 4},
- pll: PLL_28,
- tuner_type: -1 /* TUNER_ALPS_TMDH2_NTSC */,
- },{
- /* ---- card 0x34 ---------------------------------- */
- /* David H鋜deman <david@2gen.com> */
- name: "Pinnacle PCTV Studio Pro",
- video_inputs: 3,
- audio_inputs: 1,
- tuner: 0,
- svhs: 2,
- gpiomask: 0x03000F,
- muxsel: { 2, 3, 1, 1},
- audiomux: { 1, 0x10001, 0, 0, 10},
- needs_tvaudio: 1,
- pll: PLL_28,
- tuner_type: -1,
- },{
- /* Claas Langbehn <claas@bigfoot.com>,
- Sven Grothklags <sven@upb.de> */
- name: "Typhoon TView RDS + FM Stereo / KNC1 TV Station RDS",
- video_inputs: 3,
- audio_inputs: 3,
- tuner: 0,
- svhs: 2,
- gpiomask: 0x1c,
- muxsel: { 2, 3, 1, 1},
- audiomux: { 0, 0, 0x10, 8, 4 },
- needs_tvaudio: 1,
- pll: PLL_28,
- tuner_type: TUNER_PHILIPS_PAL_I,
- has_radio: 1,
- },{
- /* Tim R鰏termundt <rosterm@uni-muenster.de>
- in de.comp.os.unix.linux.hardware:
- options bttv card=0 pll=1 radio=1 gpiomask=0x18e0
- audiomux=0x44c71f,0x44d71f,0,0x44d71f,0x44dfff
- options tuner type=5 */
- name: "Lifetec LT 9415 TV (LR90 Rev.F)",
- video_inputs: 4,
- audio_inputs: 1,
- tuner: 0,
- svhs: 2,
- gpiomask: 0x18e0,
- muxsel: { 2, 3, 1, 1},
- audiomux: { 0x0000,0x0800,0x1000,0x1000,0x18e0 },
- /* 0x0000: Tuner normal stereo
- 0x0080: Tuner A2 SAP (second audio program = Zweikanalton)
- 0x0880: Tuner A2 stereo */
- pll: PLL_28,
- tuner_type: TUNER_PHILIPS_PAL,
- audio_hook: lt9415_audio,
- has_radio: 1,
- },{
- /* Miguel Angel Alvarez <maacruz@navegalia.com>
- old Easy TV BT848 version (model CPH031) */
- name: "BESTBUY Easy TV",
- video_inputs: 4,
- audio_inputs: 1,
- tuner: 0,
- svhs: 2,
- gpiomask: 0xF,
- muxsel: { 2, 3, 1, 0},
- audiomux: { 2, 0, 0, 0, 10},
- needs_tvaudio: 0,
- pll: PLL_28,
- tuner_type: TUNER_TEMIC_PAL,
- },{
- /* ---- card 0x38 ---------------------------------- */
- /* Gordon Heydon <gjheydon@bigfoot.com ('98) */
- name: "FlyVideo '98/FM",
- video_inputs: 3,
- audio_inputs: 3,
- tuner: 0,
- svhs: 2,
- gpiomask: 0x1800,
- muxsel: { 2, 3, 0, 1},
- audiomux: { 0, 0x800, 0x1000, 0x1000, 0x1800, 0 },
- needs_tvaudio: 1,
- pll: PLL_28,
- tuner_type: 5,
- },{
- /* This is the ultimate cheapo capture card
- * just a BT848A on a small PCB!
- * Steve Hosgood <steve@equiinet.com> */
- name: "GrandTec 'Grand Video Capture'",
- video_inputs: 2,
- audio_inputs: 0,
- tuner: -1,
- svhs: 1,
- gpiomask: 0,
- muxsel: { 3, 1 },
- audiomux: { 0 },
- needs_tvaudio: 0,
- no_msp34xx: 1,
- pll: PLL_35,
- tuner_type: -1,
- },{
- /* Daniel Herrington <daniel.herrington@home.com> */
- name: "Phoebe TV Master Only (No FM)",
- video_inputs: 3,
- audio_inputs: 1,
- tuner: 0,
- svhs: 2,
- gpiomask: 0xe00,
- muxsel: { 2, 3, 1, 1},
- audiomux: { 0x400, 0x400, 0x400, 0x400, 0x800, 0x400 },
- needs_tvaudio: 1,
- pll: PLL_NONE,
- tuner_type: TUNER_TEMIC_4036FY5_NTSC,
- },{
- /* Matti Mottus <mottus@physic.ut.ee> */
- name: "TV Capturer",
- video_inputs: 4,
- audio_inputs: 1,
- tuner: 0,
- svhs: 2,
- gpiomask: 0x03000F,
- muxsel: { 2, 3, 1, 0},
- audiomux: { 2,0,0,0,1 },
- pll: PLL_28,
- tuner_type: 0,
- },{
- /* ---- card 0x3c ---------------------------------- */
- /* Philip Blundell <philb@gnu.org> */
- name: "MM100PCTV",
- video_inputs: 2,
- audio_inputs: 2,
- gpiomask: 11,
- muxsel: { 2, 3, 1, 1},
- audiomux: { 2, 0, 0, 1, 8},
- pll: PLL_NONE,
- tuner_type: TUNER_TEMIC_PAL,
- },{
- /* Adrian Cox <adrian@humboldt.co.uk */
- name: "AG Electronics GMV1",
- video_inputs: 2,
- audio_inputs: 0,
- tuner: -1,
- svhs: 1,
- gpiomask: 0xF,
- muxsel: { 2, 2},
- audiomux: { },
- no_msp34xx: 1,
- needs_tvaudio: 0,
- pll: PLL_28,
- tuner_type: -1,
- },{
- /* Miguel Angel Alvarez <maacruz@navegalia.com>
- new Easy TV BT878 version (model CPH061)
- special thanks to Informatica Mieres for providing the card */
- name: "BESTBUY Easy TV (bt878)",
- video_inputs: 3,
- audio_inputs: 2,
- tuner: 0,
- svhs: 2,
- gpiomask: 0xFF,
- muxsel: { 2, 3, 1, 0},
- audiomux: { 1, 0, 4, 4, 9},
- needs_tvaudio: 0,
- pll: PLL_28,
- tuner_type: TUNER_PHILIPS_PAL,
- },{
- /* Lukas Gebauer <geby@volny.cz> */
- name: "ATI TV-Wonder",
- video_inputs: 3,
- audio_inputs: 1,
- tuner: 0,
- svhs: 2,
- gpiomask: 0xf03f,
- muxsel: { 2, 3, 0, 1},
- audiomux: { 0xbffe, 0, 0xbfff, 0, 0xbffe},
- pll: PLL_28,
- tuner_type: TUNER_TEMIC_4006FN5_MULTI_PAL,
- },{
- /* ---- card 0x40 ---------------------------------- */
- /* Lukas Gebauer <geby@volny.cz> */
- name: "ATI TV-Wonder VE",
- video_inputs: 2,
- audio_inputs: 1,
- tuner: 0,
- svhs: -1,
- gpiomask: 1,
- muxsel: { 2, 3, 0, 1},
- audiomux: { 0, 0, 1, 0, 0},
- no_msp34xx: 1,
- pll: PLL_28,
- tuner_type: TUNER_TEMIC_4006FN5_MULTI_PAL,
- },{
- /* DeeJay <deejay@westel900.net (2000S) */
- name: "FlyVideo 2000S",
- video_inputs: 3,
- audio_inputs: 3,
- tuner: 0,
- svhs: 2,
- gpiomask: 0x18e0,
- muxsel: { 2, 3, 0, 1},
- audiomux: { 0,0x18e0,0x1000,0x1000,0x1080, 0x1080 },
- needs_tvaudio: 1,
- pll: PLL_28,
- tuner_type: 5,
- },{
- name: "Terratec TValueRadio",
- video_inputs: 3,
- audio_inputs: 1,
- tuner: 0,
- svhs: 2,
- gpiomask: 0xffff00,
- muxsel: { 2, 3, 1, 1},
- audiomux: { 0x500, 0x500, 0x300, 0x900, 0x900},
- needs_tvaudio: 1,
- pll: PLL_28,
- tuner_type: TUNER_PHILIPS_PAL,
- has_radio: 1,
- },{
- /* TANAKA Kei <peg00625@nifty.com> */
- name: "GV-BCTV4/PCI",
- video_inputs: 3,
- audio_inputs: 1,
- tuner: 0,
- svhs: 2,
- gpiomask: 0x010f00,
- muxsel: {2, 3, 0, 0},
- audiomux: {0x10000, 0, 0x10000, 0, 0, 0},
- no_msp34xx: 1,
- pll: PLL_28,
- tuner_type: TUNER_SHARP_2U5JF5540_NTSC,
- audio_hook: gvbctv3pci_audio,
- },{
- /* ---- card 0x44 ---------------------------------- */
- name: "3Dfx VoodooTV FM (Euro), VoodooTV 200 (USA)",
- // try "insmod msp3400 simple=0" if you have
- // sound problems with this card.
- video_inputs: 4,
- audio_inputs: 1,
- tuner: 0,
- svhs: -1,
- gpiomask: 0x4f8a00,
- // 0x100000: 1=MSP enabled (0=disable again)
- // 0x010000: somehow influences tuner picture quality (?)
- audiomux: {0x947fff, 0x987fff,0x947fff,0x947fff},
- //tvtuner, radio, external,internal,mute,stereo
- muxsel: { 2, 3 ,0 ,1}, /* tuner, Composit, SVid, Composit-on-Svid-adapter*/
- tuner_type: TUNER_MT2032,
- pll: PLL_28,
- has_radio: 1,
- },{
- /* Philip Blundell <pb@nexus.co.uk> */
- name: "Active Imaging AIMMS",
- video_inputs: 1,
- audio_inputs: 0,
- tuner: -1,
- tuner_type: -1,
- pll: PLL_28,
- muxsel: { 2 },
- gpiomask: 0
- },{
- /* Tomasz Pyra <hellfire@sedez.iq.pl> */
- name: "PV-BT878P+",
- video_inputs: 3,
- audio_inputs: 4,
- tuner: 0,
- svhs: 2,
- gpiomask: 15,
- muxsel: { 2, 3, 1, 1},
- audiomux: { 0, 0, 11, 7, 13, 0},
- needs_tvaudio: 1,
- pll: PLL_28,
- tuner_type: 25,
- },{
- name: "Flyvideo 98EZ (capture only)",
- video_inputs: 4,
- audio_inputs: 0,
- tuner: -1,
- svhs: 2,
- muxsel: { 2, 3, 1, 1}, // AV1, AV2, SVHS, CVid adapter on SVHS
- pll: PLL_28,
- no_msp34xx: 1,
- },{
- /* ---- card 0x48 ---------------------------------- */
- /* Dariusz Kowalewski <darekk@automex.pl> */
- name: "Prolink PV-BT878P+9B (PlayTV Pro rev.9B FM+NICAM)",
- video_inputs: 3,
- audio_inputs: 1,
- tuner: 0,
- svhs: 2,
- gpiomask: 0x3f,
- muxsel: { 2, 3, 0, 1 },
- audiomux: { 0x01, 0x00, 0x03, 0x03, 0x09, 0x02 },
- needs_tvaudio: 1,
- no_msp34xx: 1,
- no_tda9875: 1,
- pll: PLL_28,
- tuner_type: -1,
- audio_hook: pvbt878p9b_audio,
- has_radio: 1,
- }
- };
- const int bttv_num_tvcards = (sizeof(bttv_tvcards)/sizeof(struct tvcard));
- /* ----------------------------------------------------------------------- */
- static unsigned char eeprom_data[256];
- /*
- * identify card
- */
- void __devinit bttv_idcard(struct bttv *btv)
- {
- unsigned int gpiobits;
- int i,type;
- unsigned short tmp;
- /* read PCI subsystem ID */
- pci_read_config_word(btv->dev, PCI_SUBSYSTEM_ID, &tmp);
- btv->cardid = tmp << 16;
- pci_read_config_word(btv->dev, PCI_SUBSYSTEM_VENDOR_ID, &tmp);
- btv->cardid |= tmp;
- if (0 != btv->cardid && 0xffffffff != btv->cardid) {
- /* look for the card */
- for (type = -1, i = 0; cards[i].id != 0; i++)
- if (cards[i].id == btv->cardid)
- type = i;
-
- if (type != -1) {
- /* found it */
- printk(KERN_INFO "bttv%d: detected: %s [card=%d], "
- "PCI subsystem ID is %04x:%04xn",
- btv->nr,cards[type].name,cards[type].cardnr,
- btv->cardid & 0xffff, btv->cardid >> 16);
- btv->type = cards[type].cardnr;
- } else {
- /* 404 */
- printk(KERN_INFO "bttv%d: subsystem: %04x:%04x (UNKNOWN)n",
- btv->nr, btv->cardid&0xffff, btv->cardid>>16);
- printk(KERN_DEBUG "please mail id, board name and "
- "the correct card= insmod option to kraxel@bytesex.orgn");
- }
- }
- /* let the user override the autodetected type */
- if (card[btv->nr] >= 0 && card[btv->nr] < bttv_num_tvcards)
- btv->type=card[btv->nr];
-
- /* print which card config we are using */
- sprintf(btv->video_dev.name,"BT%d%s(%.23s)",
- btv->id,
- (btv->id==848 && btv->revision==0x12) ? "A" : "",
- bttv_tvcards[btv->type].name);
- printk(KERN_INFO "bttv%d: using: %s [card=%d,%s]n",btv->nr,
- btv->video_dev.name,btv->type,
- (card[btv->nr] >= 0 && card[btv->nr] < bttv_num_tvcards) ?
- "insmod option" : "autodetected");
- /* overwrite gpio stuff ?? */
- if (-1 == audioall && -1 == audiomux[0])
- return;
- if (-1 != audiomux[0]) {
- gpiobits = 0;
- for (i = 0; i < 5; i++) {
- bttv_tvcards[btv->type].audiomux[i] = audiomux[i];
- gpiobits |= audiomux[i];
- }
- } else {
- gpiobits = audioall;
- for (i = 0; i < 5; i++) {
- bttv_tvcards[btv->type].audiomux[i] = audioall;
- }
- }
- bttv_tvcards[btv->type].gpiomask = (-1 != gpiomask) ? gpiomask : gpiobits;
- printk(KERN_INFO "bttv%d: gpio config override: mask=0x%x, mux=",
- btv->nr,bttv_tvcards[btv->type].gpiomask);
- for (i = 0; i < 5; i++) {
- printk("%s0x%x", i ? "," : "", bttv_tvcards[btv->type].audiomux[i]);
- }
- printk("n");
- }
- /*
- * (most) board specific initialisations goes here
- */
- int miro_tunermap[] = { 0,6,2,3, 4,5,6,0, 3,0,4,5, 5,2,16,1,
- 14,2,17,1, 4,1,4,3, 1,2,16,1, 4,4,4,4 };
- int miro_fmtuner[] = { 0,0,0,0, 0,0,0,0, 0,0,0,0, 0,0,0,1,
- 1,1,1,1, 1,1,1,0, 0,0,0,0, 0,0,0,0 };
- void __devinit bttv_init_card(struct bttv *btv)
- {
- /* miro/pinnacle */
- if (btv->type == BTTV_MIRO ||
- btv->type == BTTV_MIROPRO ||
- btv->type == BTTV_PINNACLE ||
- btv->type == BTTV_PINNACLEPRO) {
- int id,msp;
- id = ((btread(BT848_GPIO_DATA)>>10) & 31) -1;
- msp = bttv_I2CRead(btv, I2C_MSP3400, "MSP34xx");
- btv->tuner_type = miro_tunermap[id];
- if (0 == (btread(BT848_GPIO_DATA) & 0x20)) {
- btv->has_radio = 1;
- if (!miro_fmtuner[id]) {
- btv->has_matchbox = 1;
- btv->mbox_we = (1<<6);
- btv->mbox_most = (1<<7);
- btv->mbox_clk = (1<<8);
- btv->mbox_data = (1<<9);
- btv->mbox_mask = (1<<6)|(1<<7)|(1<<8)|(1<<9);
- }
- } else {
- btv->has_radio = 0;
- }
- if (-1 != msp) {
- if (btv->type == BTTV_MIRO)
- btv->type = BTTV_MIROPRO;
- if (btv->type == BTTV_PINNACLE)
- btv->type = BTTV_PINNACLEPRO;
- }
- if (bttv_verbose)
- printk(KERN_INFO "bttv%d: miro: id=%d tuner=%d "
- "radio=%s stereo=%sn",
- btv->nr, id+1, btv->tuner_type,
- !btv->has_radio ? "no" :
- (btv->has_matchbox ? "matchbox" : "fmtuner"),
- (-1 == msp) ? "no" : "yes");
- #if 0
- if (btv->has_matchbox) {
- if (bttv_verbose)
- printk(KERN_INFO "Initializing TEA5757...n");
- init_tea5757(btv);
- }
- #endif
- }
- if (btv->type == BTTV_HAUPPAUGE || btv->type == BTTV_HAUPPAUGE878) {
- /* pick up some config infos from the eeprom */
- bttv_readee(btv,eeprom_data,0xa0);
- hauppauge_eeprom(btv);
- }
- if (btv->type == BTTV_AVERMEDIA98 || btv->type == BTTV_AVPHONE98) {
- bttv_readee(btv,eeprom_data,0xa0);
- avermedia_eeprom(btv);
- }
- if (btv->type == BTTV_PXC200)
- init_PXC200(btv);
- if (btv->type == BTTV_VHX) {
- btv->has_radio = 1;
- btv->has_matchbox = 1;
- btv->mbox_we = 0x20;
- btv->mbox_most = 0;
- btv->mbox_clk = 0x08;
- btv->mbox_data = 0x10;
- btv->mbox_mask = 0x38;
- }
- if (btv->type == BTTV_LIFETEC_9415) {
- if (btread(BT848_GPIO_DATA) & 0x4000)
- printk("bttv%d: lifetec: tv mono/fm stereo cardn", btv->nr);
- else
- printk("bttv%d: lifetec: stereo(TDA9821) cardn",btv->nr);
- }
- if (btv->type == BTTV_MAGICTVIEW061) {
- if(btv->cardid == 0x4002144f) {
- btv->has_radio=1;
- printk("bttv%d: radio detected by subsystem id (CPH05x)n",btv->nr);
- }
- }
- /* pll configuration */
- if (!(btv->id==848 && btv->revision==0x11)) {
- /* defaults from card list */
- if (PLL_28 == bttv_tvcards[btv->type].pll) {
- btv->pll.pll_ifreq=28636363;
- btv->pll.pll_crystal=BT848_IFORM_XT0;
- }
- if (PLL_35 == bttv_tvcards[btv->type].pll) {
- btv->pll.pll_ifreq=35468950;
- btv->pll.pll_crystal=BT848_IFORM_XT1;
- }
- /* insmod options can override */
- switch (pll[btv->nr]) {
- case 0: /* none */
- btv->pll.pll_crystal = 0;
- btv->pll.pll_ifreq = 0;
- btv->pll.pll_ofreq = 0;
- break;
- case 1: /* 28 MHz */
- case 28:
- btv->pll.pll_ifreq = 28636363;
- btv->pll.pll_ofreq = 0;
- btv->pll.pll_crystal = BT848_IFORM_XT0;
- break;
- case 2: /* 35 MHz */
- case 35:
- btv->pll.pll_ifreq = 35468950;
- btv->pll.pll_ofreq = 0;
- btv->pll.pll_crystal = BT848_IFORM_XT1;
- break;
- }
- }
- /* tuner configuration (from card list / insmod option) */
- if (-1 != bttv_tvcards[btv->type].tuner_type)
- btv->tuner_type = bttv_tvcards[btv->type].tuner_type;
- if (-1 != tuner[btv->nr])
- btv->tuner_type = tuner[btv->nr];
- if (btv->tuner_type != -1)
- bttv_call_i2c_clients(btv,TUNER_SET_TYPE,&btv->tuner_type);
- if (bttv_tvcards[btv->type].has_radio)
- btv->has_radio=1;
- /* try to detect audio/fader chips */
- if (!bttv_tvcards[btv->type].no_msp34xx &&
- bttv_I2CRead(btv, I2C_MSP3400, "MSP34xx") >=0) {
- if (autoload)
- request_module("msp3400");
- }
- if (!bttv_tvcards[btv->type].no_tda9875 &&
- bttv_I2CRead(btv, I2C_TDA9875, "TDA9875") >=0) {
- if (autoload)
- request_module("tda9875");
- }
- if (bttv_I2CRead(btv, I2C_TDA7432, "TDA7432") >=0) {
- if (autoload)
- request_module("tda7432");
- }
- if (bttv_tvcards[btv->type].needs_tvaudio) {
- if (autoload)
- request_module("tvaudio");
- }
- if (bttv_tvcards[btv->type].tuner != -1) {
- if (autoload)
- request_module("tuner");
- }
- }
- /* ----------------------------------------------------------------------- */
- /* some hauppauge specific stuff */
- static struct HAUPPAUGE_TUNER
- {
- int id;
- char *name;
- }
- hauppauge_tuner[] __devinitdata =
- {
- { TUNER_ABSENT, "" },
- { TUNER_ABSENT, "External" },
- { TUNER_ABSENT, "Unspecified" },
- { TUNER_PHILIPS_PAL, "Philips FI1216" },
- { TUNER_PHILIPS_SECAM, "Philips FI1216MF" },
- { TUNER_PHILIPS_NTSC, "Philips FI1236" },
- { TUNER_PHILIPS_PAL_I, "Philips FI1246" },
- { TUNER_PHILIPS_PAL_DK,"Philips FI1256" },
- { TUNER_PHILIPS_PAL, "Philips FI1216 MK2" },
- { TUNER_PHILIPS_SECAM, "Philips FI1216MF MK2" },
- { TUNER_PHILIPS_NTSC, "Philips FI1236 MK2" },
- { TUNER_PHILIPS_PAL_I, "Philips FI1246 MK2" },
- { TUNER_PHILIPS_PAL_DK,"Philips FI1256 MK2" },
- { TUNER_TEMIC_NTSC, "Temic 4032FY5" },
- { TUNER_TEMIC_PAL, "Temic 4002FH5" },
- { TUNER_TEMIC_PAL_I, "Temic 4062FY5" },
- { TUNER_PHILIPS_PAL, "Philips FR1216 MK2" },
- { TUNER_PHILIPS_SECAM, "Philips FR1216MF MK2" },
- { TUNER_PHILIPS_NTSC, "Philips FR1236 MK2" },
- { TUNER_PHILIPS_PAL_I, "Philips FR1246 MK2" },
- { TUNER_PHILIPS_PAL_DK,"Philips FR1256 MK2" },
- { TUNER_PHILIPS_PAL, "Philips FM1216" },
- { TUNER_PHILIPS_SECAM, "Philips FM1216MF" },
- { TUNER_PHILIPS_NTSC, "Philips FM1236" },
- { TUNER_PHILIPS_PAL_I, "Philips FM1246" },
- { TUNER_PHILIPS_PAL_DK,"Philips FM1256" },
- { TUNER_TEMIC_4036FY5_NTSC, "Temic 4036FY5" },
- { TUNER_ABSENT, "Samsung TCPN9082D" },
- { TUNER_ABSENT, "Samsung TCPM9092P" },
- { TUNER_TEMIC_4006FH5_PAL, "Temic 4006FH5" },
- { TUNER_ABSENT, "Samsung TCPN9085D" },
- { TUNER_ABSENT, "Samsung TCPB9085P" },
- { TUNER_ABSENT, "Samsung TCPL9091P" },
- { TUNER_TEMIC_4039FR5_NTSC, "Temic 4039FR5" },
- { TUNER_PHILIPS_FQ1216ME, "Philips FQ1216 ME" },
- { TUNER_TEMIC_4066FY5_PAL_I, "Temic 4066FY5" },
- { TUNER_ABSENT, "Philips TD1536" },
- { TUNER_ABSENT, "Philips TD1536D" },
- { TUNER_PHILIPS_NTSC, "Philips FMR1236" }, /* mono radio */
- { TUNER_ABSENT, "Philips FI1256MP" },
- { TUNER_ABSENT, "Samsung TCPQ9091P" },
- { TUNER_TEMIC_4006FN5_MULTI_PAL, "Temic 4006FN5" },
- { TUNER_TEMIC_4009FR5_PAL, "Temic 4009FR5" },
- { TUNER_TEMIC_4046FM5, "Temic 4046FM5" },
- { TUNER_TEMIC_4009FN5_MULTI_PAL_FM, "Temic 4009FN5" },
- { TUNER_ABSENT, "Philips TD1536D_FH_44"},
- { TUNER_LG_NTSC_FM, "LG TP18NSR01F"},
- { TUNER_LG_PAL_FM, "LG TP18PSB01D"},
- { TUNER_LG_PAL, "LG TP18PSB11D"},
- { TUNER_LG_PAL_I_FM, "LG TAPC-I001D"},
- { TUNER_LG_PAL_I, "LG TAPC-I701D"}
- };
- static void __devinit hauppauge_eeprom(struct bttv *btv)
- {
- int blk2,tuner,radio,model;
- if (eeprom_data[0] != 0x84 || eeprom_data[2] != 0)
- printk(KERN_WARNING "bttv%d: Hauppauge eeprom: invalidn",
- btv->nr);
- /* Block 2 starts after len+3 bytes header */
- blk2 = eeprom_data[1] + 3;
- /* decode + use some config infos */
- model = eeprom_data[12] << 8 | eeprom_data[11];
- tuner = eeprom_data[9];
- radio = eeprom_data[blk2-1] & 0x01;
-
- if (tuner < sizeof(hauppauge_tuner)/sizeof(struct HAUPPAUGE_TUNER))
- btv->tuner_type = hauppauge_tuner[tuner].id;
- if (radio)
- btv->has_radio = 1;
-
- if (bttv_verbose)
- printk(KERN_INFO "bttv%d: Hauppauge eeprom: model=%d, "
- "tuner=%s (%d), radio=%sn",
- btv->nr, model, hauppauge_tuner[tuner].name,
- btv->tuner_type, radio ? "yes" : "no");
- }
- // AVermedia specific stuff...
- // from bktr_card.c
- int tuner_0_table[] = {
- TUNER_PHILIPS_NTSC, TUNER_PHILIPS_PAL,
- TUNER_PHILIPS_PAL, TUNER_PHILIPS_PAL,
- TUNER_PHILIPS_PAL, TUNER_PHILIPS_PAL,
- TUNER_PHILIPS_SECAM, TUNER_PHILIPS_SECAM,
- TUNER_PHILIPS_SECAM, TUNER_PHILIPS_PAL};
- /*
- int tuner_0_fm_table[] = {
- PHILIPS_FR1236_NTSC, PHILIPS_FR1216_PAL,
- PHILIPS_FR1216_PAL, PHILIPS_FR1216_PAL,
- PHILIPS_FR1216_PAL, PHILIPS_FR1216_PAL,
- PHILIPS_FR1236_SECAM, PHILIPS_FR1236_SECAM,
- PHILIPS_FR1236_SECAM, PHILIPS_FR1216_PAL};
- */
- int tuner_1_table[] = {
- TUNER_TEMIC_NTSC, TUNER_TEMIC_PAL,
- TUNER_TEMIC_PAL, TUNER_TEMIC_PAL,
- TUNER_TEMIC_PAL, TUNER_TEMIC_PAL,
- TUNER_TEMIC_4012FY5, TUNER_TEMIC_4012FY5, //TUNER_TEMIC_SECAM
- TUNER_TEMIC_4012FY5, TUNER_TEMIC_PAL};
- static void __devinit avermedia_eeprom(struct bttv *btv)
- {
- int tuner_make,tuner_tv_fm,tuner_format,tuner=0;
- tuner_make = (eeprom_data[0x41] & 0x7);
- tuner_tv_fm = (eeprom_data[0x41] & 0x18) >> 3;
- tuner_format = (eeprom_data[0x42] & 0xf0) >> 4;
- if (tuner_make == 0 || tuner_make == 2)
- if(tuner_format <=9)
- tuner = tuner_0_table[tuner_format];
- if (tuner_make == 1)
- if(tuner_format <=9)
- tuner = tuner_1_table[tuner_format];
-
- printk(KERN_INFO "bttv%d: Avermedia eeprom[0x%02x%02x]: tuner=",
- btv->nr,eeprom_data[0x41],eeprom_data[0x42]);
- if(tuner) {
- btv->tuner_type=tuner;
- printk("%dn",tuner);
- } else
- printk("Unknown typen");
- }
- /*
- * reset/enable the MSP on some Hauppauge cards
- * Thanks to Ky鰏ti M鋖kki (kmalkki@cc.hut.fi)!
- *
- * Hauppauge: pin 5
- * Voodoo: pin 20
- */
- void __devinit bttv_boot_msp34xx(struct bttv *btv, int pin)
- {
- int mask = (1 << pin);
- btaor(mask, ~mask, BT848_GPIO_OUT_EN);
- btaor(0, ~mask, BT848_GPIO_DATA);
- udelay(2500);
- btaor(mask, ~mask, BT848_GPIO_DATA);
- if (bttv_gpio)
- bttv_gpio_tracking(btv,"msp34xx");
- if (bttv_verbose)
- printk(KERN_INFO "bttv%d: Hauppauge/Voodoo msp34xx: reset line "
- "init [%d]n", btv->nr, pin);
- }
- /* ----------------------------------------------------------------------- */
- /* Imagenation L-Model PXC200 Framegrabber */
- /* This is basically the same procedure as
- * used by Alessandro Rubini in his pxc200
- * driver, but using BTTV functions */
- static void __devinit init_PXC200(struct bttv *btv)
- {
- static int vals[] __devinitdata = { 0x08, 0x09, 0x0a, 0x0b, 0x0d, 0x0d,
- 0x01, 0x02, 0x03, 0x04, 0x05, 0x06,
- 0x00 };
- int i,tmp;
- /* Initialise GPIO-connevted stuff */
- btwrite(1<<13,BT848_GPIO_OUT_EN); /* Reset pin only */
- btwrite(0,BT848_GPIO_DATA);
- udelay(3);
- btwrite(1<<13,BT848_GPIO_DATA);
- /* GPIO inputs are pulled up, so no need to drive
- * reset pin any longer */
- btwrite(0,BT848_GPIO_OUT_EN);
- if (bttv_gpio)
- bttv_gpio_tracking(btv,"pxc200");
- /* we could/should try and reset/control the AD pots? but
- right now we simply turned off the crushing. Without
- this the AGC drifts drifts
- remember the EN is reverse logic -->
- setting BT848_ADC_AGC_EN disable the AGC
- tboult@eecs.lehigh.edu
- */
- btwrite(BT848_ADC_RESERVED|BT848_ADC_AGC_EN, BT848_ADC);
-
- /* Initialise MAX517 DAC */
- printk(KERN_INFO "Setting DAC reference voltage level ...n");
- bttv_I2CWrite(btv,0x5E,0,0x80,1);
-
- /* Initialise 12C508 PIC */
- /* The I2CWrite and I2CRead commmands are actually to the
- * same chips - but the R/W bit is included in the address
- * argument so the numbers are different */
-
- printk(KERN_INFO "Initialising 12C508 PIC chip ...n");
- for (i = 0; i < sizeof(vals)/sizeof(int); i++) {
- tmp=bttv_I2CWrite(btv,0x1E,vals[i],0,1);
- printk(KERN_INFO "I2C Write(0x08) = %inI2C Read () = %xnn",
- tmp,bttv_I2CRead(btv,0x1F,NULL));
- }
- printk(KERN_INFO "PXC200 Initialised.n");
- }
- /* ----------------------------------------------------------------------- */
- /* Miro Pro radio stuff -- the tea5757 is connected to some GPIO ports */
- /*
- * Copyright (c) 1999 Csaba Halasz <qgehali@uni-miskolc.hu>
- * This code is placed under the terms of the GNU General Public License
- *
- * Brutally hacked by Dan Sheridan <dan.sheridan@contact.org.uk> djs52 8/3/00
- */
- #if 0
- /* bus bits on the GPIO port */
- #define TEA_WE 6
- #define TEA_DATA 9
- #define TEA_CLK 8
- #define TEA_MOST 7
- #endif
- #define BUS_LOW(bit) btand(~(bit), BT848_GPIO_DATA)
- #define BUS_HIGH(bit) btor((bit), BT848_GPIO_DATA)
- #define BUS_IN(bit) (btread(BT848_GPIO_DATA) & (bit))
- /* TEA5757 register bits */
- #define TEA_FREQ 0:14
- #define TEA_BUFFER 15:15
- #define TEA_SIGNAL_STRENGTH 16:17
- #define TEA_PORT1 18:18
- #define TEA_PORT0 19:19
- #define TEA_BAND 20:21
- #define TEA_BAND_FM 0
- #define TEA_BAND_MW 1
- #define TEA_BAND_LW 2
- #define TEA_BAND_SW 3
- #define TEA_MONO 22:22
- #define TEA_ALLOW_STEREO 0
- #define TEA_FORCE_MONO 1
- #define TEA_SEARCH_DIRECTION 23:23
- #define TEA_SEARCH_DOWN 0
- #define TEA_SEARCH_UP 1
- #define TEA_STATUS 24:24
- #define TEA_STATUS_TUNED 0
- #define TEA_STATUS_SEARCHING 1
- /* Low-level stuff */
- static int tea5757_read(struct bttv *btv)
- {
- int value = 0;
- long timeout;
- int i;
-
- /* better safe than sorry */
- btaor((btv->mbox_clk | btv->mbox_we),
- ~btv->mbox_mask, BT848_GPIO_OUT_EN);
- if (bttv_gpio)
- bttv_gpio_tracking(btv,"tea5757 read");
-
- BUS_LOW(btv->mbox_we);
- BUS_LOW(btv->mbox_clk);
-
- udelay(10);
- for(timeout = jiffies + 10 * HZ;
- BUS_IN(btv->mbox_data) && time_before(jiffies, timeout);
- schedule()); /* 10 s */
- if (BUS_IN(btv->mbox_data)) {
- printk(KERN_WARNING "bttv%d: tea5757: read timeoutn",btv->nr);
- return -1;
- }
- for(timeout = jiffies + HZ/5;
- BUS_IN(btv->mbox_data) == 1 && time_before(jiffies, timeout);
- schedule()); /* 0.2 s */
- dprintk("bttv%d: tea5757:",btv->nr);
- for(i = 0; i < 24; i++)
- {
- udelay(5);
- BUS_HIGH(btv->mbox_clk);
- udelay(5);
- dprintk("%c",(BUS_IN(btv->mbox_most) == 0)?'T':'-');
- BUS_LOW(btv->mbox_clk);
- value <<= 1;
- value |= (BUS_IN(btv->mbox_data) == 0)?0:1; /* MSB first */
- dprintk("%c", (BUS_IN(btv->mbox_most) == 0)?'S':'M');
- }
- dprintk("nbttv%d: tea5757: read 0x%Xn", btv->nr, value);
- return value;
- }
- static int tea5757_write(struct bttv *btv, int value)
- {
- int i;
- int reg = value;
-
- btaor(btv->mbox_clk | btv->mbox_we | btv->mbox_data,
- ~btv->mbox_mask, BT848_GPIO_OUT_EN);
- if (bttv_gpio)
- bttv_gpio_tracking(btv,"tea5757 write");
- dprintk("bttv%d: tea5757: write 0x%Xn", btv->nr, value);
- BUS_LOW(btv->mbox_clk);
- BUS_HIGH(btv->mbox_we);
- for(i = 0; i < 25; i++)
- {
- if (reg & 0x1000000)
- BUS_HIGH(btv->mbox_data);
- else
- BUS_LOW(btv->mbox_data);
- reg <<= 1;
- BUS_HIGH(btv->mbox_clk);
- udelay(10);
- BUS_LOW(btv->mbox_clk);
- udelay(10);
- }
- BUS_LOW(btv->mbox_we); /* unmute !!! */
- return 0;
- }
- void tea5757_set_freq(struct bttv *btv, unsigned short freq)
- {
- tea5757_write(btv, 5 * freq + 0x358); /* add 10.7MHz (see docs) */
- if (bttv_debug)
- tea5757_read(btv);
- }
- /* ----------------------------------------------------------------------- */
- /* winview */
- void winview_audio(struct bttv *btv, struct video_audio *v, int set)
- {
- /* PT2254A programming Jon Tombs, jon@gte.esi.us.es */
- int bits_out, loops, vol, data;
- if (!set) {
- /* Fixed by Leandro Lucarella <luca@linuxmendoza.org.ar (07/31/01) */
- v->flags |= VIDEO_AUDIO_VOLUME;
- return;
- }
-
- /* 32 levels logarithmic */
- vol = 32 - ((v->volume>>11));
- /* units */
- bits_out = (PT2254_DBS_IN_2>>(vol%5));
- /* tens */
- bits_out |= (PT2254_DBS_IN_10>>(vol/5));
- bits_out |= PT2254_L_CHANNEL | PT2254_R_CHANNEL;
- data = btread(BT848_GPIO_DATA);
- data &= ~(WINVIEW_PT2254_CLK| WINVIEW_PT2254_DATA|
- WINVIEW_PT2254_STROBE);
- for (loops = 17; loops >= 0 ; loops--) {
- if (bits_out & (1<<loops))
- data |= WINVIEW_PT2254_DATA;
- else
- data &= ~WINVIEW_PT2254_DATA;
- btwrite(data, BT848_GPIO_DATA);
- udelay(5);
- data |= WINVIEW_PT2254_CLK;
- btwrite(data, BT848_GPIO_DATA);
- udelay(5);
- data &= ~WINVIEW_PT2254_CLK;
- btwrite(data, BT848_GPIO_DATA);
- }
- data |= WINVIEW_PT2254_STROBE;
- data &= ~WINVIEW_PT2254_DATA;
- btwrite(data, BT848_GPIO_DATA);
- udelay(10);
- data &= ~WINVIEW_PT2254_STROBE;
- btwrite(data, BT848_GPIO_DATA);
- }
- /* ----------------------------------------------------------------------- */
- /* mono/stereo control for various cards (which don't use i2c chips but */
- /* connect something to the GPIO pins */
- static void
- gvbctv3pci_audio(struct bttv *btv, struct video_audio *v, int set)
- {
- unsigned int con = 0;
- if (set) {
- btor(0x300, BT848_GPIO_OUT_EN);
- if (v->mode & VIDEO_SOUND_LANG1)
- con = 0x000;
- if (v->mode & VIDEO_SOUND_LANG2)
- con = 0x300;
- if (v->mode & VIDEO_SOUND_STEREO)
- con = 0x200;
- // if (v->mode & VIDEO_SOUND_MONO)
- // con = 0x100;
- btaor(con, ~0x300, BT848_GPIO_DATA);
- } else {
- v->mode = VIDEO_SOUND_STEREO |
- VIDEO_SOUND_LANG1 | VIDEO_SOUND_LANG2;
- }
- }
- /*
- * Mario Medina Nussbaum <medisoft@alohabbs.org.mx>
- * I discover that on BT848_GPIO_DATA address a byte 0xcce enable stereo,
- * 0xdde enables mono and 0xccd enables sap
- *
- * Petr Vandrovec <VANDROVE@vc.cvut.cz>
- * P.S.: At least mask in line above is wrong - GPIO pins 3,2 select
- * input/output sound connection, so both must be set for output mode.
- *
- * Looks like it's needed only for the "tvphone", the "tvphone 98"
- * handles this with a tda9840
- *
- */
- static void
- avermedia_tvphone_audio(struct bttv *btv, struct video_audio *v, int set)
- {
- int val = 0;
- if (set) {
- if (v->mode & VIDEO_SOUND_LANG1) /* SAP */
- val = 0x02;
- if (v->mode & VIDEO_SOUND_STEREO)
- val = 0x01;
- if (val) {
- btaor(val, ~0x03, BT848_GPIO_DATA);
- if (bttv_gpio)
- bttv_gpio_tracking(btv,"avermedia");
- }
- } else {
- v->mode = VIDEO_SOUND_MONO | VIDEO_SOUND_STEREO |
- VIDEO_SOUND_LANG1;
- return;
- }
- }
- /* Lifetec 9415 handling */
- static void
- lt9415_audio(struct bttv *btv, struct video_audio *v, int set)
- {
- int val = 0;
- if (btread(BT848_GPIO_DATA) & 0x4000) {
- v->mode = VIDEO_SOUND_MONO;
- return;
- }
- if (set) {
- if (v->mode & VIDEO_SOUND_LANG2) /* A2 SAP */
- val = 0x0080;
- if (v->mode & VIDEO_SOUND_STEREO) /* A2 stereo */
- val = 0x0880;
- if ((v->mode & VIDEO_SOUND_LANG1) ||
- (v->mode & VIDEO_SOUND_MONO))
- val = 0;
- btaor(val, ~0x0880, BT848_GPIO_DATA);
- if (bttv_gpio)
- bttv_gpio_tracking(btv,"lt9415");
- } else {
- /* autodetect doesn't work with this card :-( */
- v->mode = VIDEO_SOUND_MONO | VIDEO_SOUND_STEREO |
- VIDEO_SOUND_LANG1 | VIDEO_SOUND_LANG2;
- return;
- }
- }
- static void
- terratv_audio(struct bttv *btv, struct video_audio *v, int set)
- {
- unsigned int con = 0;
- if (set) {
- btor(0x180000, BT848_GPIO_OUT_EN);
- if (v->mode & VIDEO_SOUND_LANG2)
- con = 0x080000;
- if (v->mode & VIDEO_SOUND_STEREO)
- con = 0x180000;
- btaor(con, ~0x180000, BT848_GPIO_DATA);
- if (bttv_gpio)
- bttv_gpio_tracking(btv,"terratv");
- } else {
- v->mode = VIDEO_SOUND_MONO | VIDEO_SOUND_STEREO |
- VIDEO_SOUND_LANG1 | VIDEO_SOUND_LANG2;
- }
- }
- static void
- winfast2000_audio(struct bttv *btv, struct video_audio *v, int set)
- {
- unsigned long val = 0;
- if (set) {
- /*btor (0xc32000, BT848_GPIO_OUT_EN);*/
- if (v->mode & VIDEO_SOUND_MONO) /* Mono */
- val = 0x420000;
- if (v->mode & VIDEO_SOUND_LANG1) /* Mono */
- val = 0x420000;
- if (v->mode & VIDEO_SOUND_LANG2) /* SAP */
- val = 0x410000;
- if (v->mode & VIDEO_SOUND_STEREO) /* Stereo */
- val = 0x020000;
- if (val) {
- btaor(val, ~0x430000, BT848_GPIO_DATA);
- if (bttv_gpio)
- bttv_gpio_tracking(btv,"winfast2000");
- }
- } else {
- v->mode = VIDEO_SOUND_MONO | VIDEO_SOUND_STEREO |
- VIDEO_SOUND_LANG1 | VIDEO_SOUND_LANG2;
- }
- }
- /*
- * Dariusz Kowalewski <darekk@automex.pl>
- * sound control for Prolink PV-BT878P+9B (PixelView PlayTV Pro FM+NICAM
- * revision 9B has on-board TDA9874A sound decoder).
- */
- static void
- pvbt878p9b_audio(struct bttv *btv, struct video_audio *v, int set)
- {
- unsigned int val = 0;
- #if BTTV_VERSION_CODE > KERNEL_VERSION(0,8,0)
- if (btv->radio_user)
- return;
- #else
- if (btv->radio)
- return;
- #endif
- if (set) {
- if (v->mode & VIDEO_SOUND_MONO) {
- val = 0x01;
- }
- if ((v->mode & (VIDEO_SOUND_LANG1 | VIDEO_SOUND_LANG2))
- || (v->mode & VIDEO_SOUND_STEREO)) {
- val = 0x02;
- }
- if (val) {
- btaor(val, ~0x03, BT848_GPIO_DATA);
- if (bttv_gpio)
- bttv_gpio_tracking(btv,"pvbt878p9b");
- }
- } else {
- v->mode = VIDEO_SOUND_MONO | VIDEO_SOUND_STEREO |
- VIDEO_SOUND_LANG1 | VIDEO_SOUND_LANG2;
- }
- }
- /* ----------------------------------------------------------------------- */
- /* motherboard chipset specific stuff */
- void __devinit bttv_check_chipset(void)
- {
- int pcipci_fail = 0;
- struct pci_dev *dev = NULL;
- /* for 2.4.x we'll use the pci quirks (drivers/pci/quirks.c) */
- if (pci_pci_problems & PCIPCI_FAIL)
- pcipci_fail = 1;
- if (pci_pci_problems & (PCIPCI_TRITON|PCIPCI_NATOMA|PCIPCI_VIAETBF))
- triton1 = 1;
- if (pci_pci_problems & PCIPCI_VSFX)
- vsfx = 1;
- /* print which chipset we have */
- while ((dev = pci_find_class(PCI_CLASS_BRIDGE_HOST << 8,dev)))
- printk(KERN_INFO "bttv: Host bridge is %sn",dev->name);
- /* print warnings about any quirks found */
- if (triton1)
- printk(KERN_INFO "bttv: Host bridge needs ETBF enabled.n");
- if (vsfx)
- printk(KERN_INFO "bttv: Host bridge needs VSFX enabled.n");
- if (pcipci_fail) {
- printk(KERN_WARNING "bttv: BT848 and your chipset may not work together.n");
- if (-1 == no_overlay) {
- printk(KERN_WARNING "bttv: going to disable overlay.n");
- no_overlay = 1;
- }
- }
- while ((dev = pci_find_device(PCI_VENDOR_ID_INTEL,
- PCI_DEVICE_ID_INTEL_82441, dev))) {
- unsigned char b;
- pci_read_config_byte(dev, 0x53, &b);
- if (bttv_debug)
- printk(KERN_INFO "bttv: Host bridge: 82441FX Natoma, "
- "bufcon=0x%02xn",b);
- }
- }
- int __devinit bttv_handle_chipset(struct bttv *btv)
- {
- unsigned char command;
- if (!triton1 && !vsfx)
- return 0;
- if (bttv_verbose) {
- if (triton1)
- printk("bttv%d: enabling ETBF (430FX/VP3 compatibilty)n",btv->nr);
- if (vsfx && btv->id >= 878)
- printk("bttv%d: enabling VSFXn",btv->nr);
- }
- if (btv->id < 878) {
- /* bt848 (mis)uses a bit in the irq mask for etbf */
- if (triton1)
- btv->triton1 = BT848_INT_ETBF;
- } else {
- /* bt878 has a bit in the pci config space for it */
- pci_read_config_byte(btv->dev, BT878_DEVCTRL, &command);
- if (triton1)
- command |= BT878_EN_TBFX;
- if (vsfx)
- command |= BT878_EN_VSFX;
- pci_write_config_byte(btv->dev, BT878_DEVCTRL, command);
- }
- return 0;
- }
- /*
- * Local variables:
- * c-basic-offset: 8
- * End:
- */