bttv-cards.c
上传用户:lgb322
上传日期:2013-02-24
资源大小:30529k
文件大小:52k
源码类别:

嵌入式Linux

开发平台:

Unix_Linux

  1. /*
  2.     bttv-cards.c
  3.     this file has configuration informations - card-specific stuff
  4.     like the big tvcards array for the most part
  5.     Copyright (C) 1996,97,98 Ralph  Metzler (rjkm@thp.uni-koeln.de)
  6.                            & Marcus Metzler (mocm@thp.uni-koeln.de)
  7.     (c) 1999-2001 Gerd Knorr <kraxel@goldbach.in-berlin.de>
  8.     This program is free software; you can redistribute it and/or modify
  9.     it under the terms of the GNU General Public License as published by
  10.     the Free Software Foundation; either version 2 of the License, or
  11.     (at your option) any later version.
  12.     This program is distributed in the hope that it will be useful,
  13.     but WITHOUT ANY WARRANTY; without even the implied warranty of
  14.     MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
  15.     GNU General Public License for more details.
  16.     You should have received a copy of the GNU General Public License
  17.     along with this program; if not, write to the Free Software
  18.     Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
  19.     
  20. */
  21. #define __NO_VERSION__ 1
  22. #include <linux/version.h>
  23. #include <linux/delay.h>
  24. #include <linux/module.h>
  25. #include <linux/kmod.h>
  26. #include <linux/init.h>
  27. #include <linux/pci.h>
  28. #include <asm/io.h>
  29. #include "bttvp.h"
  30. #include "tuner.h"
  31. /* fwd decl */
  32. static void hauppauge_eeprom(struct bttv *btv);
  33. static void avermedia_eeprom(struct bttv *btv);
  34. static void init_PXC200(struct bttv *btv);
  35. #if 0
  36. static void init_tea5757(struct bttv *btv);
  37. #endif
  38. static void winview_audio(struct bttv *btv, struct video_audio *v, int set);
  39. static void lt9415_audio(struct bttv *btv, struct video_audio *v, int set);
  40. static void avermedia_tvphone_audio(struct bttv *btv, struct video_audio *v,
  41.     int set);
  42. static void terratv_audio(struct bttv *btv, struct video_audio *v, int set);
  43. static void gvbctv3pci_audio(struct bttv *btv, struct video_audio *v, int set);
  44. static void winfast2000_audio(struct bttv *btv, struct video_audio *v, int set);
  45. static void pvbt878p9b_audio(struct bttv *btv, struct video_audio *v, int set);
  46. /* config variables */
  47. static int triton1=0;
  48. static int vsfx=0;
  49. int no_overlay=-1;
  50. static unsigned int card[4]  = { -1, -1, -1, -1 };
  51. static unsigned int pll[4]   = { -1, -1, -1, -1 };
  52. static unsigned int tuner[4] = { -1, -1, -1, -1 };
  53. #ifdef MODULE
  54. static unsigned int autoload = 1;
  55. #else
  56. static unsigned int autoload = 0;
  57. #endif
  58. static unsigned int gpiomask = -1;
  59. static unsigned int audioall = -1;
  60. static unsigned int audiomux[5] = { -1, -1, -1, -1, -1 };
  61. /* insmod options */
  62. MODULE_PARM(triton1,"i");
  63. MODULE_PARM_DESC(triton1,"set ETBF pci config bit "
  64.  "[enable bug compatibility for triton1 + others]");
  65. MODULE_PARM(vsfx,"i");
  66. MODULE_PARM_DESC(vsfx,"set VSFX pci config bit [yet another chipset flaw workaround]");
  67. MODULE_PARM(no_overlay,"i");
  68. MODULE_PARM(card,"1-4i");
  69. MODULE_PARM_DESC(card,"specify TV/grabber card model, see CARDLIST file for a list");
  70. MODULE_PARM(pll,"1-4i");
  71. MODULE_PARM_DESC(pll,"specify installed crystal (0=none, 28=28 MHz, 35=35 MHz)");
  72. MODULE_PARM(tuner,"1-4i");
  73. MODULE_PARM_DESC(tuner,"specify installed tuner type");
  74. MODULE_PARM(autoload,"i");
  75. MODULE_PARM_DESC(autoload,"automatically load i2c modules like tuner.o, default is 1 (yes)");
  76. MODULE_PARM(gpiomask,"i");
  77. MODULE_PARM(audioall,"i");
  78. MODULE_PARM(audiomux,"1-5i");
  79. /* kernel args */
  80. #ifndef MODULE
  81. static int __init p_card(char *str)  { return bttv_parse(str,BTTV_MAX,card);  }
  82. static int __init p_pll(char *str)   { return bttv_parse(str,BTTV_MAX,pll);   }
  83. static int __init p_tuner(char *str) { return bttv_parse(str,BTTV_MAX,tuner); }
  84. __setup("bttv.card=",  p_card);
  85. __setup("bttv.pll=",   p_pll);
  86. __setup("bttv.tuner=", p_tuner);
  87. int __init bttv_parse(char *str, int max, int *vals)
  88. {
  89. int i,number,res = 2;
  90. for (i = 0; res == 2 && i < max; i++) {
  91. res = get_option(&str,&number);
  92. if (res)
  93. vals[i] = number;
  94. }
  95. return 1;
  96. }
  97. #endif
  98. /* ----------------------------------------------------------------------- */
  99. /* list of card IDs for bt878+ cards                                       */
  100. static struct CARD {
  101. unsigned id;
  102. int cardnr;
  103. char *name;
  104. } cards[] __devinitdata = {
  105. { 0x13eb0070, BTTV_HAUPPAUGE878,  "Hauppauge WinTV" },
  106. { 0x39000070, BTTV_HAUPPAUGE878,  "Hauppauge WinTV-D" },
  107. { 0x45000070, BTTV_HAUPPAUGE878,  "Hauppauge WinTV/PVR" },
  108. { 0xff000070, BTTV_HAUPPAUGE878,  "Osprey-100" },
  109. { 0xff010070, BTTV_HAUPPAUGE878,  "Osprey-200" },
  110. { 0x00011002, BTTV_ATI_TVWONDER,  "ATI TV Wonder" },
  111. { 0x00031002, BTTV_ATI_TVWONDERVE,"ATI TV Wonder/VE" },
  112. { 0x6606107d, BTTV_WINFAST2000,   "Leadtek WinFast TV 2000" },
  113. { 0x263610b4, BTTV_STB2,          "STB TV PCI FM, P/N 6000704" },
  114.   { 0x402010fc, BTTV_GVBCTV3PCI,    "I-O Data Co. GV-BCV3/PCI" },
  115. { 0x405010fc, BTTV_GVBCTV4PCI,    "I-O Data Co. GV-BCV4/PCI" },
  116. { 0x1200bd11, BTTV_PINNACLE,      "Pinnacle PCTV" },
  117. { 0x001211bd, BTTV_PINNACLE,      "Pinnacle PCTV" },
  118. { 0x001c11bd, BTTV_PINNACLE,      "Pinnacle PCTV Sat" },
  119. { 0x3000121a, BTTV_VOODOOTV_FM,   "3Dfx VoodooTV FM/ VoodooTV 200" },
  120. { 0x3000144f, BTTV_MAGICTVIEW063, "(Askey Magic/others) TView99 CPH06x" },
  121. { 0x3002144f, BTTV_MAGICTVIEW061, "(Askey Magic/others) TView99 CPH05x" },
  122. { 0x3005144f, BTTV_MAGICTVIEW061, "(Askey Magic/others) TView99 CPH061/06L (T1/LC)" },
  123. { 0x00011461, BTTV_AVPHONE98,     "AVerMedia TVPhone98" },
  124. { 0x00021461, BTTV_AVERMEDIA98,   "AVermedia TVCapture 98" },
  125. { 0x00031461, BTTV_AVPHONE98,     "AVerMedia TVPhone98" },
  126. { 0x00041461, BTTV_AVERMEDIA98,   "AVerMedia TVCapture 98" },
  127. { 0x300014ff, BTTV_MAGICTVIEW061, "TView 99 (CPH061)" },
  128. { 0x300214ff, BTTV_PHOEBE_TVMAS,  "Phoebe TV Master" },
  129. { 0x1117153b, BTTV_TERRATVALUE,   "Terratec TValue" },
  130. { 0x1118153b, BTTV_TERRATVALUE,   "Terratec TValue" },
  131. { 0x1119153b, BTTV_TERRATVALUE,   "Terratec TValue" },
  132. { 0x111a153b, BTTV_TERRATVALUE,   "Terratec TValue" },
  133. { 0x1123153b, BTTV_TERRATVRADIO,  "Terratec TV Radio+" },
  134. { 0x1127153b, BTTV_TERRATV,       "Terratec TV+"    },
  135. { 0x1134153b, BTTV_TERRATVALUE,   "Terratec TValue" },
  136. { 0x1135153b, BTTV_TERRATVALUER,  "Terratec TValue Radio" },
  137. { 0x400a15b0, BTTV_ZOLTRIX_GENIE, "Zoltrix Genie TV" },
  138. { 0x400d15b0, BTTV_ZOLTRIX_GENIE, "Zoltrix Genie TV / Radio" },
  139. { 0x401015b0, BTTV_ZOLTRIX_GENIE, "Zoltrix Genie TV / Radio" },
  140. { 0x401615b0, BTTV_ZOLTRIX_GENIE, "Zoltrix Genie TV / Radio" },
  141.      { 0x010115cb, BTTV_GMV1,          "AG GMV1" },
  142. { 0x010114c7, BTTV_MODTEC_205,    "Modular Technology PCTV" },
  143. { 0x18501851, BTTV_CHRONOS_VS2,   "Flyvideo 98 (LR50)/ Chronos Video Shuttle II" },
  144. { 0x18511851, BTTV_FLYVIDEO98EZ,  "Flyvideo 98EZ (LR51)/ CyberMail AV" },
  145. { 0x18521852, BTTV_TYPHOON_TVIEW, "Flyvideo 98FM (LR50)/ Typhoon TView TV/FM Tuner" },
  146. { 0x10b42636, BTTV_HAUPPAUGE878,  "STB ???" },
  147. { 0x217d6606, BTTV_WINFAST2000,   "Leadtek WinFast TV 2000" },
  148. { 0, -1, NULL }
  149. };
  150. /* ----------------------------------------------------------------------- */
  151. /* array with description for bt848 / bt878 tv/grabber cards               */
  152. struct tvcard bttv_tvcards[] = {
  153. {
  154. /* ---- card 0x00 ---------------------------------- */
  155. name: " *** UNKNOWN/GENERIC *** ",
  156. video_inputs: 4,
  157. audio_inputs: 1,
  158. tuner: 0,
  159. svhs: 2,
  160. muxsel: { 2, 3, 1, 0},
  161. tuner_type: -1,
  162. },{
  163. name: "MIRO PCTV",
  164. video_inputs: 4,
  165. audio_inputs: 1,
  166. tuner: 0,
  167. svhs: 2,
  168. gpiomask: 15,
  169. muxsel: { 2, 3, 1, 1},
  170. audiomux: { 2, 0, 0, 0, 10},
  171. needs_tvaudio: 1,
  172. tuner_type: -1,
  173. },{
  174. name: "Hauppauge (bt848)",
  175. video_inputs: 4,
  176. audio_inputs: 1,
  177. tuner: 0,
  178. svhs: 2,
  179. gpiomask: 7,
  180. muxsel: { 2, 3, 1, 1},
  181. audiomux: { 0, 1, 2, 3, 4},
  182. needs_tvaudio: 1,
  183. tuner_type: -1,
  184. },{
  185. name: "STB",
  186. video_inputs: 3,
  187. audio_inputs: 1,
  188. tuner: 0,
  189. svhs: 2,
  190. gpiomask: 7,
  191. muxsel: { 2, 3, 1, 1},
  192. audiomux: { 4, 0, 2, 3, 1},
  193. no_msp34xx: 1,
  194. needs_tvaudio: 1,
  195. tuner_type: -1,
  196. },{
  197. /* ---- card 0x04 ---------------------------------- */
  198. name: "Intel",
  199. video_inputs: 3,
  200. audio_inputs: 1,
  201. tuner: 0,
  202. svhs: -1,
  203. gpiomask: 7,
  204. muxsel: { 2, 3, 1, 1},
  205. audiomux: { 0, 1, 2, 3, 4},
  206. needs_tvaudio: 1,
  207. tuner_type: -1,
  208. },{
  209. name: "Diamond DTV2000",
  210. video_inputs: 4,
  211. audio_inputs: 1,
  212. tuner: 0,
  213. svhs: 2,
  214. gpiomask: 3,
  215. muxsel: { 2, 3, 1, 0},
  216. audiomux: { 0, 1, 0, 1, 3},
  217. needs_tvaudio: 1,
  218. tuner_type: -1,
  219. },{
  220. name: "AVerMedia TVPhone",
  221. video_inputs: 3,
  222. audio_inputs: 1,
  223. tuner: 0,
  224. svhs: 3,
  225. muxsel: { 2, 3, 1, 1},
  226. gpiomask: 0x0f,
  227. audiomux: { 0x0c, 0x04, 0x08, 0x04, 0},
  228. /*                0x04 for some cards ?? */
  229. needs_tvaudio: 1,
  230. tuner_type: -1,
  231. audio_hook: avermedia_tvphone_audio,
  232. },{
  233. name: "MATRIX-Vision MV-Delta",
  234. video_inputs: 5,
  235. audio_inputs: 1,
  236. tuner: -1,
  237. svhs: 3,
  238. gpiomask: 0,
  239. muxsel: { 2, 3, 1, 0, 0},
  240. audiomux: {0 },
  241. needs_tvaudio: 1,
  242. tuner_type: -1,
  243. },{
  244. /* ---- card 0x08 ---------------------------------- */
  245. name: "Fly Video II (Bt848)",
  246. video_inputs: 3,
  247. audio_inputs: 1,
  248. tuner: 0,
  249. svhs: 2,
  250. gpiomask: 0xc00,
  251. muxsel: { 2, 3, 1, 1},
  252. audiomux: { 0, 0xc00, 0x800, 0x400, 0xc00, 0},
  253. needs_tvaudio: 1,
  254. tuner_type: -1,
  255. },{
  256. name: "TurboTV",
  257. video_inputs: 3,
  258. audio_inputs: 1,
  259. tuner: 0,
  260. svhs: 2,
  261. gpiomask: 3,
  262. muxsel: { 2, 3, 1, 1},
  263. audiomux: { 1, 1, 2, 3, 0},
  264. needs_tvaudio: 1,
  265. tuner_type: -1,
  266. },{
  267. name: "Hauppauge (bt878)",
  268. video_inputs: 4,
  269. audio_inputs: 1,
  270. tuner: 0,
  271. svhs: 2,
  272. gpiomask: 0x0f, /* old: 7 */
  273. muxsel: { 2, 0, 1, 1},
  274. audiomux: { 0, 1, 2, 3, 4},
  275. needs_tvaudio: 1,
  276. pll: PLL_28,
  277. tuner_type: -1,
  278. },{
  279. name: "MIRO PCTV pro",
  280. video_inputs: 3,
  281. audio_inputs: 1,
  282. tuner: 0,
  283. svhs: 2,
  284. gpiomask: 0x3014f,
  285. muxsel: { 2, 3, 1, 1},
  286. audiomux: { 0x20001,0x10001, 0, 0,10},
  287. needs_tvaudio: 1,
  288. tuner_type: -1,
  289. },{
  290. /* ---- card 0x0c ---------------------------------- */
  291. name: "ADS Technologies Channel Surfer TV",
  292. video_inputs: 3,
  293. audio_inputs: 1,
  294. tuner: 0,
  295. svhs: 2,
  296. gpiomask: 15,
  297. muxsel: { 2, 3, 1, 1},
  298. audiomux: { 13, 14, 11, 7, 0, 0},
  299. needs_tvaudio: 1,
  300. tuner_type: -1,
  301. },{
  302. name: "AVerMedia TVCapture 98",
  303. video_inputs: 3,
  304. audio_inputs: 4,
  305. tuner: 0,
  306. svhs: 2,
  307. gpiomask: 15,
  308. muxsel: { 2, 3, 1, 1},
  309. audiomux: { 13, 14, 11, 7, 0, 0},
  310. needs_tvaudio: 1,
  311. pll: PLL_28,
  312. tuner_type: -1,
  313. },{
  314. name: "Aimslab VHX",
  315. video_inputs: 3,
  316. audio_inputs: 1,
  317. tuner: 0,
  318. svhs: 2,
  319. gpiomask: 7,
  320. muxsel: { 2, 3, 1, 1},
  321. audiomux: { 0, 1, 2, 3, 4},
  322. needs_tvaudio: 1,
  323. tuner_type: -1,
  324. },{
  325. name: "Zoltrix TV-Max",
  326. video_inputs: 3,
  327. audio_inputs: 1,
  328. tuner: 0,
  329. svhs: 2,
  330. gpiomask: 15,
  331. muxsel: { 2, 3, 1, 1},
  332. audiomux: {0 , 0, 1 , 0, 10},
  333. needs_tvaudio: 1,
  334. tuner_type: -1,
  335. },{
  336. /* ---- card 0x10 ---------------------------------- */
  337. name: "Pixelview PlayTV (bt878)",
  338. video_inputs: 3,
  339. audio_inputs: 1,
  340. tuner: 0,
  341. svhs: 2,
  342. gpiomask: 0x01fe00,
  343. muxsel: { 2, 3, 1, 1},
  344. audiomux: { 0x01c000, 0, 0x018000, 0x014000, 0x002000, 0 },
  345. needs_tvaudio: 1,
  346. pll: PLL_28,
  347. tuner_type: -1,
  348. },{
  349. name: "Leadtek WinView 601",
  350. video_inputs: 3,
  351. audio_inputs: 1,
  352. tuner: 0,
  353. svhs: 2,
  354. gpiomask: 0x8300f8,
  355. muxsel: { 2, 3, 1, 1,0},
  356. audiomux: { 0x4fa007,0xcfa007,0xcfa007,0xcfa007,0xcfa007,0xcfa007},
  357. needs_tvaudio: 1,
  358. tuner_type: -1,
  359. audio_hook: winview_audio,
  360. },{
  361. name: "AVEC Intercapture",
  362. video_inputs: 3,
  363. audio_inputs: 2,
  364. tuner: 0,
  365. svhs: 2,
  366. gpiomask: 0,
  367. muxsel: {2, 3, 1, 1},
  368. audiomux: {1, 0, 0, 0, 0},
  369. needs_tvaudio: 1,
  370. tuner_type: -1,
  371. },{
  372. name: "LifeView FlyKit w/o Tuner",
  373. video_inputs: 3,
  374. audio_inputs: 1,
  375. tuner: -1,
  376. svhs: -1,
  377. gpiomask: 0x8dff00,
  378. muxsel: { 2, 3, 1, 1},
  379. audiomux: { 0 },
  380. no_msp34xx: 1,
  381. tuner_type: -1,
  382. },{
  383. /* ---- card 0x14 ---------------------------------- */
  384. name: "CEI Raffles Card",
  385. video_inputs: 3,
  386. audio_inputs: 3,
  387. tuner: 0,
  388. svhs: 2,
  389. muxsel: {2, 3, 1, 1},
  390. tuner_type: -1,
  391. },{
  392. name: "Lucky Star Image World ConferenceTV",
  393. video_inputs: 3,
  394. audio_inputs: 1,
  395. tuner: 0,
  396. svhs: 2,
  397. gpiomask: 0x00fffe07,
  398. muxsel: { 2, 3, 1, 1},
  399. audiomux: { 131072, 1, 1638400, 3, 4},
  400. needs_tvaudio: 1,
  401. pll: PLL_28,
  402. tuner_type: TUNER_PHILIPS_PAL_I,
  403. },{
  404. name: "Phoebe Tv Master + FM",
  405. video_inputs: 3,
  406. audio_inputs: 1,
  407. tuner: 0,
  408. svhs: 2,
  409. gpiomask: 0xc00,
  410. muxsel: { 2, 3, 1, 1},
  411. audiomux: {0, 1, 0x800, 0x400, 0xc00, 0},
  412. needs_tvaudio: 1,
  413. tuner_type: -1,
  414. },{
  415. name: "Modular Technology MM205 PCTV, bt878",
  416. video_inputs: 2,
  417. audio_inputs: 1,
  418. tuner: 0,
  419. svhs: -1,
  420. gpiomask: 7,
  421. muxsel: { 2, 3 },
  422. audiomux: { 0, 0, 0, 0, 0 },
  423. no_msp34xx: 1,
  424. pll:            PLL_28,
  425. tuner_type:     TUNER_ALPS_TSBB5_PAL_I,
  426. },{
  427. /* ---- card 0x18 ---------------------------------- */
  428. name: "[many vendors] CPH05X/06X (bt878)",
  429. video_inputs: 3,
  430. audio_inputs: 1,
  431. tuner: 0,
  432. svhs: 2,
  433. gpiomask: 0xe00,
  434. muxsel: { 2, 3, 1, 1},
  435. audiomux: {0x400, 0x400, 0x400, 0x400, 0xc00},
  436. needs_tvaudio: 1,
  437. pll: PLL_28,
  438. tuner_type: -1,
  439. },{
  440. name: "Terratec/Vobis TV-Boostar",
  441. video_inputs: 3,
  442. audio_inputs: 1,
  443. tuner: 0,
  444. svhs: 2,
  445. gpiomask: 16777215,
  446. muxsel: { 2, 3, 1, 1},
  447. audiomux: { 131072, 1, 1638400, 3,4},
  448. needs_tvaudio: 1,
  449. tuner_type: -1,
  450. },{
  451. name: "Newer Hauppauge WinCam (bt878)",
  452. video_inputs: 4,
  453. audio_inputs: 1,
  454. tuner: 0,
  455. svhs: 3,
  456. gpiomask: 7,
  457. muxsel: { 2, 0, 1, 1},
  458. audiomux: { 0, 1, 2, 3, 4},
  459. needs_tvaudio: 1,
  460. tuner_type: -1,
  461. },{
  462. name: "MAXI TV Video PCI2",
  463. video_inputs: 3,
  464. audio_inputs: 1,
  465. tuner: 0,
  466. svhs: 2,
  467. gpiomask: 0xffff,
  468. muxsel: { 2, 3, 1, 1},
  469. audiomux: { 0, 1, 2, 3, 0xc00},
  470. needs_tvaudio: 1,
  471. tuner_type: TUNER_PHILIPS_SECAM,
  472. },{
  473. /* ---- card 0x1c ---------------------------------- */
  474. name: "Terratec TerraTV+",
  475. video_inputs: 3,
  476. audio_inputs: 1,
  477. tuner: 0,
  478. svhs: 2,
  479. gpiomask: 0x70000,
  480. muxsel: { 2, 3, 1, 1},
  481. audiomux: { 0x20000, 0x30000, 0x10000, 0x00000, 0x40000},
  482. needs_tvaudio: 1,
  483. tuner_type: TUNER_PHILIPS_PAL,
  484. audio_hook: terratv_audio,
  485. },{
  486. /* Jannik Fritsch <jannik@techfak.uni-bielefeld.de> */
  487. name: "Imagenation PXC200",
  488. video_inputs: 5,
  489. audio_inputs: 1,
  490. tuner: -1,
  491. svhs: 1, /* was: 4 */
  492. gpiomask: 0,
  493. muxsel: { 2, 3, 1, 0, 0},
  494. audiomux: { 0 },
  495. needs_tvaudio: 1,
  496. tuner_type: -1,
  497. },{
  498. name: "FlyVideo 98",
  499. video_inputs: 3,
  500. audio_inputs: 1,
  501. tuner: 0,
  502. svhs: 2,
  503. gpiomask: 0x1800,  //0x8dfe00
  504. muxsel: {2, 3, 1, 1},
  505. audiomux: { 0, 0x0800, 0x1000, 0x1000, 0x1800, 0 },
  506. needs_tvaudio: 1,
  507. tuner_type: -1,
  508. },{
  509. name: "iProTV",
  510. video_inputs: 3,
  511. audio_inputs: 1,
  512. tuner: 0,
  513. svhs: 2,
  514. gpiomask: 1,
  515. muxsel: { 2, 3, 1, 1},
  516. audiomux: { 1, 0, 0, 0, 0 },
  517. tuner_type: -1,
  518. },{
  519. /* ---- card 0x20 ---------------------------------- */
  520. name: "Intel Create and Share PCI",
  521. video_inputs: 4,
  522. audio_inputs: 1,
  523. tuner: 0,
  524. svhs: 2,
  525. gpiomask: 7,
  526. muxsel: { 2, 3, 1, 1},
  527. audiomux: { 4, 4, 4, 4, 4},
  528. needs_tvaudio: 1,
  529. tuner_type: -1,
  530. },{
  531. name: "Terratec TerraTValue",
  532. video_inputs: 3,
  533. audio_inputs: 1,
  534. tuner: 0,
  535. svhs: 2,
  536. gpiomask: 0xffff00,
  537. muxsel: { 2, 3, 1, 1},
  538. audiomux: { 0x500, 0, 0x300, 0x900, 0x900},
  539. needs_tvaudio: 1,
  540. pll: PLL_28,
  541. tuner_type: TUNER_PHILIPS_PAL,
  542. },{
  543. name: "Leadtek WinFast 2000",
  544. video_inputs: 3,
  545. audio_inputs: 1,
  546. tuner: 0,
  547. svhs: 2,
  548. gpiomask: 0xc33000,
  549. muxsel: { 2, 3, 1, 1,0},
  550. audiomux: { 0x422000,0x001000,0x621100,0x620000,0x800000,0x620000},
  551. needs_tvaudio: 0,
  552. pll: PLL_28,
  553. tuner_type: -1,
  554. audio_hook: winfast2000_audio,
  555. },{
  556. name: "Flyvideo 98 (LR50Q) / Chronos Video Shuttle II",
  557. video_inputs: 3,
  558. audio_inputs: 3,
  559. tuner: 0,
  560. svhs: 2,
  561. gpiomask: 0x1800,
  562. muxsel: { 2, 3, 1, 1},
  563. audiomux: { 0, 0x800, 0x1000, 0x1000, 0x1800},
  564. needs_tvaudio: 1,
  565. pll: PLL_28,
  566. tuner_type: -1,
  567. },{
  568. /* ---- card 0x24 ---------------------------------- */
  569. name: "Flyvideo 98FM (LR50Q) / Typhoon TView TV/FM Tuner",
  570. video_inputs: 3,
  571. audio_inputs: 3,
  572. tuner: 0,
  573. svhs: 2,
  574. gpiomask: 0x1800,
  575. muxsel: { 2, 3, 1, 1},
  576. audiomux: { 0, 0x800, 0x1000, 0x1000, 0x1800, 0 },
  577. needs_tvaudio: 1,
  578. pll: PLL_28,
  579. tuner_type: -1,
  580. has_radio: 1,
  581. },{
  582. name: "PixelView PlayTV pro",
  583. video_inputs: 3,
  584. audio_inputs: 1,
  585. tuner: 0,
  586. svhs: 2,
  587. gpiomask: 0xff,
  588. muxsel: { 2, 3, 1, 1 },
  589. audiomux: { 0x21, 0x20, 0x24, 0x2c, 0x29, 0x29 },
  590. no_msp34xx: 1,
  591. pll: PLL_28,
  592. tuner_type: -1,
  593. },{
  594. name: "TView99 CPH06X",
  595. video_inputs: 4,
  596. audio_inputs: 1,
  597. tuner: 0,
  598. svhs: 2,
  599. gpiomask: 0x551e00,
  600. muxsel: { 2, 3, 1, 0},
  601. audiomux: { 0x551400, 0x551200, 0, 0, 0x551c00, 0x551200 },
  602. needs_tvaudio: 1,
  603. pll: PLL_28,
  604. tuner_type: -1,
  605. },{
  606. name: "Pinnacle PCTV Studio/Rave",
  607. video_inputs: 3,
  608. audio_inputs: 1,
  609. tuner: 0,
  610. svhs: 2,
  611. gpiomask: 0x03000F,
  612. muxsel: { 2, 3, 1, 1},
  613. audiomux: { 2, 0, 0, 0, 1},
  614. needs_tvaudio: 1,
  615. pll: PLL_28,
  616. tuner_type: -1,
  617. },{
  618. /* ---- card 0x28 ---------------------------------- */
  619. name: "STB2",
  620. video_inputs: 3,
  621. audio_inputs: 1,
  622. tuner: 0,
  623. svhs: 2,
  624. gpiomask: 7,
  625. muxsel: { 2, 3, 1, 1},
  626. audiomux: { 4, 0, 2, 3, 1},
  627. no_msp34xx: 1,
  628. needs_tvaudio: 1,
  629. tuner_type: -1,
  630. },{
  631. name: "AVerMedia TVPhone 98",
  632. video_inputs: 3,
  633. audio_inputs: 4,
  634. tuner: 0,
  635. svhs: 2,
  636. gpiomask: 12,
  637. muxsel: { 2, 3, 1, 1},
  638. audiomux: { 13, 4, 11, 7, 0, 0},
  639. needs_tvaudio: 1,
  640. pll: PLL_28,
  641. tuner_type: -1,
  642. has_radio: 1,
  643. },{
  644. name: "ProVideo PV951", /* pic16c54 */
  645. video_inputs: 3,
  646. audio_inputs: 1,
  647. tuner: 0,
  648. svhs: 2,
  649. gpiomask: 0,
  650. muxsel: { 2, 3, 1, 1},
  651. audiomux: { 0, 0, 0, 0, 0},
  652. no_msp34xx: 1,
  653. pll: PLL_28,
  654. tuner_type: 1,
  655. },{
  656. name: "Little OnAir TV",
  657. video_inputs: 3,
  658. audio_inputs: 1,
  659. tuner: 0,
  660. svhs: 2,
  661. gpiomask: 0xe00b,
  662. muxsel: {2, 3, 1, 1},
  663. audiomux: {0xff9ff6, 0xff9ff6, 0xff1ff7, 0, 0xff3ffc},
  664. no_msp34xx: 1,
  665. tuner_type: -1,
  666. },{
  667. /* ---- card 0x2c ---------------------------------- */
  668. name: "Sigma TVII-FM",
  669. video_inputs: 2,
  670. audio_inputs: 1,
  671. tuner: 0,
  672. svhs: -1,
  673. gpiomask: 3,
  674. muxsel: {2, 3, 1, 1},
  675. audiomux: {1, 1, 0, 2, 3},
  676. no_msp34xx: 1,
  677. pll: PLL_NONE,
  678. tuner_type: -1,
  679. },{
  680. name: "MATRIX-Vision MV-Delta 2",
  681. video_inputs: 5,
  682. audio_inputs: 1,
  683. tuner: -1,
  684. svhs: 3,
  685. gpiomask: 0,
  686. muxsel: { 2, 3, 1, 0, 0},
  687. audiomux: {0 },
  688. no_msp34xx: 1,
  689. pll: PLL_28,
  690. tuner_type: -1,
  691. },{
  692. name: "Zoltrix Genie TV/FM",
  693. video_inputs: 3,
  694. audio_inputs: 1,
  695. tuner: 0,
  696. svhs: 2,
  697. gpiomask: 0xbcf03f,
  698. muxsel: { 2, 3, 1, 1},
  699. audiomux: { 0xbc803f, 0xbc903f, 0xbcb03f, 0, 0xbcb03f},
  700. no_msp34xx: 1,
  701. pll: PLL_28,
  702. tuner_type: 21,
  703. },{
  704. name: "Terratec TV/Radio+",
  705. video_inputs: 3,
  706. audio_inputs: 1,
  707. tuner: 0,
  708. svhs: 2,
  709. gpiomask: 0x1f0000,
  710. muxsel: { 2, 3, 1, 1},
  711. audiomux: { 0xe2ffff, 0xebffff, 0, 0, 0xe0ffff, 0xe2ffff },
  712. no_msp34xx: 1,
  713. pll: PLL_35,
  714. tuner_type: 1,
  715. has_radio: 1,
  716. },{
  717. /* ---- card 0x30 ---------------------------------- */
  718. name: "Dynalink Magic TView ",
  719. video_inputs: 3,
  720. audio_inputs: 1,
  721. tuner: 0,
  722. svhs: 2,
  723. gpiomask: 15,
  724. muxsel: { 2, 3, 1, 1},
  725. audiomux: {2,0,0,0,1},
  726. needs_tvaudio: 1,
  727. pll: PLL_28,
  728. tuner_type: -1,
  729. },{
  730. name: "GV-BCTV3",
  731. video_inputs: 3,
  732. audio_inputs: 1,
  733. tuner: 0,
  734. svhs: 2,
  735. gpiomask: 0x010f00,
  736. muxsel: {2, 3, 0, 0},
  737. audiomux: {0x10000, 0, 0x10000, 0, 0, 0},
  738. no_msp34xx: 1,
  739. pll: PLL_28,
  740. tuner_type: TUNER_ALPS_TSHC6_NTSC,
  741. audio_hook: gvbctv3pci_audio,
  742. },{
  743. name: "Prolink PV-BT878P+4E / PixelView PlayTV PAK / Lenco MXTV-9578 CP",
  744. video_inputs: 4,
  745. audio_inputs: 1,
  746. tuner: 0,
  747. svhs: 2,
  748. gpiomask: 0xAA0000,
  749. muxsel: { 2,3,1,1 },
  750. audiomux: { 0x20000, 0, 0x80000, 0x80000, 0xa8000, 0x46000  },
  751. no_msp34xx: 1,
  752. pll: PLL_28,
  753. tuner_type: TUNER_PHILIPS_PAL_I,
  754. },{
  755. name:           "Eagle Wireless Capricorn2 (bt878A)",
  756. video_inputs:   4,
  757. audio_inputs:   1,
  758. tuner:          0,
  759. svhs:           2,
  760. gpiomask:       7,
  761. muxsel:         { 2, 0, 1, 1},
  762. audiomux:       { 0, 1, 2, 3, 4},
  763. pll:            PLL_28,
  764. tuner_type:     -1 /* TUNER_ALPS_TMDH2_NTSC */,
  765. },{
  766. /* ---- card 0x34 ---------------------------------- */
  767. /* David H鋜deman <david@2gen.com> */
  768. name:           "Pinnacle PCTV Studio Pro",
  769. video_inputs:   3,
  770. audio_inputs:   1,
  771. tuner:          0,
  772. svhs:           2,
  773. gpiomask:       0x03000F,
  774. muxsel: { 2, 3, 1, 1},
  775. audiomux: { 1, 0x10001, 0, 0, 10},
  776. needs_tvaudio:  1,
  777. pll:            PLL_28,
  778. tuner_type:     -1,
  779. },{
  780. /* Claas Langbehn <claas@bigfoot.com>,
  781.    Sven Grothklags <sven@upb.de> */
  782. name: "Typhoon TView RDS + FM Stereo / KNC1 TV Station RDS",
  783. video_inputs: 3,
  784. audio_inputs: 3,
  785. tuner: 0,
  786. svhs: 2,
  787. gpiomask: 0x1c,
  788. muxsel: { 2, 3, 1, 1},
  789. audiomux: { 0, 0, 0x10, 8, 4 },
  790. needs_tvaudio: 1,
  791. pll: PLL_28,
  792. tuner_type: TUNER_PHILIPS_PAL_I,
  793. has_radio: 1,
  794. },{
  795. /* Tim R鰏termundt <rosterm@uni-muenster.de>
  796.    in de.comp.os.unix.linux.hardware:
  797. options bttv card=0 pll=1 radio=1 gpiomask=0x18e0
  798. audiomux=0x44c71f,0x44d71f,0,0x44d71f,0x44dfff
  799. options tuner type=5 */
  800. name: "Lifetec LT 9415 TV (LR90 Rev.F)",
  801. video_inputs: 4,
  802. audio_inputs: 1,
  803. tuner: 0,
  804. svhs: 2,
  805. gpiomask: 0x18e0,
  806. muxsel: { 2, 3, 1, 1},
  807. audiomux: { 0x0000,0x0800,0x1000,0x1000,0x18e0 },
  808.        /* 0x0000: Tuner normal stereo
  809.   0x0080: Tuner A2 SAP (second audio program = Zweikanalton)
  810.   0x0880: Tuner A2 stereo */
  811. pll: PLL_28,
  812. tuner_type: TUNER_PHILIPS_PAL,
  813. audio_hook: lt9415_audio,
  814. has_radio: 1,
  815. },{
  816. /* Miguel Angel Alvarez <maacruz@navegalia.com>
  817.    old Easy TV BT848 version (model CPH031) */
  818. name:           "BESTBUY Easy TV",
  819. video_inputs: 4,
  820. audio_inputs:   1,
  821. tuner:          0,
  822. svhs:           2,
  823. gpiomask:       0xF,
  824. muxsel:         { 2, 3, 1, 0},
  825. audiomux:       { 2, 0, 0, 0, 10},
  826. needs_tvaudio:  0,
  827. pll: PLL_28,
  828. tuner_type: TUNER_TEMIC_PAL,
  829. },{
  830. /* ---- card 0x38 ---------------------------------- */
  831. /* Gordon Heydon <gjheydon@bigfoot.com ('98) */
  832. name:           "FlyVideo '98/FM",
  833. video_inputs:   3,
  834. audio_inputs:   3,
  835. tuner:          0,
  836. svhs:           2,
  837. gpiomask:       0x1800,
  838. muxsel:         { 2, 3, 0, 1},
  839. audiomux:       { 0, 0x800, 0x1000, 0x1000, 0x1800, 0 },
  840. needs_tvaudio:  1,
  841. pll:            PLL_28,
  842. tuner_type:     5,
  843. },{
  844. /* This is the ultimate cheapo capture card 
  845.  * just a BT848A on a small PCB!
  846.  * Steve Hosgood <steve@equiinet.com> */
  847. name:           "GrandTec 'Grand Video Capture'",
  848. video_inputs:   2,
  849. audio_inputs:   0,
  850. tuner:          -1,
  851. svhs:           1,
  852. gpiomask:       0,
  853. muxsel:         { 3, 1 },
  854. audiomux:       { 0 },
  855. needs_tvaudio:  0,
  856. no_msp34xx:     1,
  857. pll:            PLL_35,
  858. tuner_type:     -1,
  859. },{
  860.         /* Daniel Herrington <daniel.herrington@home.com> */
  861.         name:           "Phoebe TV Master Only (No FM)",
  862.         video_inputs:   3,
  863.         audio_inputs:   1,
  864.         tuner:          0,
  865.         svhs:           2,
  866.         gpiomask:       0xe00,
  867.         muxsel:         { 2, 3, 1, 1},
  868.         audiomux:       { 0x400, 0x400, 0x400, 0x400, 0x800, 0x400 },
  869.         needs_tvaudio:  1,
  870.         pll:            PLL_NONE,
  871.         tuner_type:     TUNER_TEMIC_4036FY5_NTSC,
  872. },{
  873. /* Matti Mottus <mottus@physic.ut.ee> */
  874. name: "TV Capturer",
  875. video_inputs: 4,
  876. audio_inputs: 1,
  877. tuner: 0,
  878. svhs: 2,
  879.         gpiomask:       0x03000F,
  880. muxsel: { 2, 3, 1, 0},
  881.         audiomux:       { 2,0,0,0,1 },
  882. pll:            PLL_28,
  883. tuner_type: 0,
  884. },{
  885. /* ---- card 0x3c ---------------------------------- */
  886. /* Philip Blundell <philb@gnu.org> */
  887. name:           "MM100PCTV",
  888. video_inputs:   2,
  889. audio_inputs:   2,
  890. gpiomask:       11,
  891. muxsel:         { 2, 3, 1, 1},
  892. audiomux:       { 2, 0, 0, 1, 8},
  893. pll:            PLL_NONE,
  894. tuner_type:     TUNER_TEMIC_PAL,
  895. },{
  896. /* Adrian Cox <adrian@humboldt.co.uk */
  897. name:         "AG Electronics GMV1",
  898. video_inputs:   2,
  899. audio_inputs:   0,
  900. tuner:         -1,
  901. svhs:         1,
  902. gpiomask:       0xF,
  903. muxsel:         { 2, 2},
  904. audiomux:       { },
  905. no_msp34xx:     1,
  906. needs_tvaudio:  0,
  907. pll:         PLL_28,
  908. tuner_type:     -1,
  909. },{
  910. /* Miguel Angel Alvarez <maacruz@navegalia.com>
  911.    new Easy TV BT878 version (model CPH061) 
  912.    special thanks to Informatica Mieres for providing the card */
  913. name:           "BESTBUY Easy TV (bt878)",
  914. video_inputs: 3,
  915. audio_inputs:   2,
  916. tuner:          0,
  917. svhs:           2,
  918. gpiomask:       0xFF,
  919. muxsel:         { 2, 3, 1, 0},
  920. audiomux:       { 1, 0, 4, 4, 9},
  921. needs_tvaudio:  0,
  922. pll: PLL_28,
  923. tuner_type: TUNER_PHILIPS_PAL,
  924. },{
  925. /* Lukas Gebauer <geby@volny.cz> */
  926. name: "ATI TV-Wonder",
  927. video_inputs: 3,
  928. audio_inputs: 1,
  929. tuner: 0,
  930. svhs: 2,
  931. gpiomask: 0xf03f,
  932. muxsel: { 2, 3, 0, 1},
  933. audiomux: { 0xbffe, 0, 0xbfff, 0, 0xbffe},
  934. pll: PLL_28,
  935. tuner_type: TUNER_TEMIC_4006FN5_MULTI_PAL,
  936. },{
  937. /* ---- card 0x40 ---------------------------------- */
  938. /* Lukas Gebauer <geby@volny.cz> */
  939. name: "ATI TV-Wonder VE",
  940. video_inputs: 2,
  941. audio_inputs: 1,
  942. tuner: 0,
  943. svhs: -1,
  944. gpiomask: 1,
  945. muxsel: { 2, 3, 0, 1},
  946. audiomux: { 0, 0, 1, 0, 0},
  947. no_msp34xx: 1,
  948. pll: PLL_28,
  949. tuner_type: TUNER_TEMIC_4006FN5_MULTI_PAL,
  950. },{
  951. /* DeeJay <deejay@westel900.net (2000S) */
  952. name:           "FlyVideo 2000S",
  953. video_inputs:   3,
  954. audio_inputs:   3,
  955. tuner:          0,
  956. svhs:           2,
  957. gpiomask: 0x18e0,
  958. muxsel: { 2, 3, 0, 1},
  959. audiomux: { 0,0x18e0,0x1000,0x1000,0x1080, 0x1080 },
  960. needs_tvaudio:  1,
  961. pll:            PLL_28,
  962. tuner_type:     5,
  963. },{
  964. name: "Terratec TValueRadio",
  965. video_inputs: 3,
  966. audio_inputs: 1,
  967. tuner: 0,
  968. svhs: 2,
  969. gpiomask: 0xffff00,
  970. muxsel: { 2, 3, 1, 1},
  971. audiomux: { 0x500, 0x500, 0x300, 0x900, 0x900},
  972. needs_tvaudio: 1,
  973. pll: PLL_28,
  974. tuner_type: TUNER_PHILIPS_PAL,
  975. has_radio: 1,
  976. },{
  977. /* TANAKA Kei <peg00625@nifty.com> */
  978. name:           "GV-BCTV4/PCI",
  979. video_inputs:   3,
  980. audio_inputs:   1,
  981. tuner:          0,
  982. svhs:           2,
  983. gpiomask:       0x010f00,
  984. muxsel:         {2, 3, 0, 0},
  985. audiomux:       {0x10000, 0, 0x10000, 0, 0, 0},
  986. no_msp34xx:     1,
  987. pll:            PLL_28,
  988. tuner_type:     TUNER_SHARP_2U5JF5540_NTSC,
  989. audio_hook:     gvbctv3pci_audio,
  990. },{
  991. /* ---- card 0x44 ---------------------------------- */
  992.         name:           "3Dfx VoodooTV FM (Euro), VoodooTV 200 (USA)",
  993. // try "insmod msp3400 simple=0" if you have
  994. // sound problems with this card.
  995.         video_inputs:   4,
  996.         audio_inputs:   1,
  997.         tuner:          0,
  998.         svhs:           -1,
  999.         gpiomask:       0x4f8a00,
  1000.                 // 0x100000: 1=MSP enabled (0=disable again)
  1001. // 0x010000: somehow influences tuner picture quality (?)
  1002.         audiomux:       {0x947fff, 0x987fff,0x947fff,0x947fff},
  1003.                         //tvtuner, radio,   external,internal,mute,stereo
  1004.         muxsel:         { 2, 3 ,0 ,1}, /* tuner, Composit, SVid, Composit-on-Svid-adapter*/
  1005.         tuner_type:     TUNER_MT2032,
  1006. pll: PLL_28,
  1007. has_radio: 1,
  1008. },{
  1009. /* Philip Blundell <pb@nexus.co.uk> */
  1010. name:           "Active Imaging AIMMS",
  1011. video_inputs:   1,
  1012. audio_inputs:   0,
  1013. tuner:          -1,
  1014. tuner_type:     -1,
  1015. pll:            PLL_28,
  1016. muxsel:         { 2 },
  1017. gpiomask:       0
  1018. },{
  1019.         /* Tomasz Pyra <hellfire@sedez.iq.pl> */
  1020.         name:           "PV-BT878P+",
  1021.         video_inputs:   3,
  1022.         audio_inputs:   4,
  1023.         tuner:          0,
  1024.         svhs:           2,
  1025.         gpiomask:       15,
  1026.         muxsel:         { 2, 3, 1, 1},
  1027.         audiomux:       { 0, 0, 11, 7, 13, 0},
  1028.         needs_tvaudio:  1,
  1029.         pll:            PLL_28,
  1030.         tuner_type:     25,
  1031. },{
  1032. name: "Flyvideo 98EZ (capture only)",
  1033. video_inputs: 4,
  1034. audio_inputs:   0,
  1035. tuner: -1,
  1036. svhs: 2,
  1037. muxsel: { 2, 3, 1, 1}, // AV1, AV2, SVHS, CVid adapter on SVHS
  1038. pll: PLL_28,
  1039. no_msp34xx: 1,
  1040. },{
  1041. /* ---- card 0x48 ---------------------------------- */
  1042. /* Dariusz Kowalewski <darekk@automex.pl> */
  1043. name: "Prolink PV-BT878P+9B (PlayTV Pro rev.9B FM+NICAM)",
  1044. video_inputs: 3,
  1045. audio_inputs: 1,
  1046. tuner: 0,
  1047. svhs: 2,
  1048. gpiomask: 0x3f,
  1049. muxsel: { 2, 3, 0, 1 },
  1050. audiomux: { 0x01, 0x00, 0x03, 0x03, 0x09, 0x02 },
  1051. needs_tvaudio:  1,
  1052. no_msp34xx: 1,
  1053. no_tda9875: 1,
  1054. pll: PLL_28,
  1055. tuner_type: -1,
  1056. audio_hook: pvbt878p9b_audio,
  1057. has_radio: 1,
  1058. }
  1059. };
  1060. const int bttv_num_tvcards = (sizeof(bttv_tvcards)/sizeof(struct tvcard));
  1061. /* ----------------------------------------------------------------------- */
  1062. static unsigned char eeprom_data[256];
  1063. /*
  1064.  * identify card
  1065.  */
  1066. void __devinit bttv_idcard(struct bttv *btv)
  1067. {
  1068. unsigned int gpiobits;
  1069. int i,type;
  1070. unsigned short tmp;
  1071. /* read PCI subsystem ID */
  1072. pci_read_config_word(btv->dev, PCI_SUBSYSTEM_ID, &tmp);
  1073. btv->cardid = tmp << 16;
  1074. pci_read_config_word(btv->dev, PCI_SUBSYSTEM_VENDOR_ID, &tmp);
  1075. btv->cardid |= tmp;
  1076. if (0 != btv->cardid && 0xffffffff != btv->cardid) {
  1077. /* look for the card */
  1078. for (type = -1, i = 0; cards[i].id != 0; i++)
  1079. if (cards[i].id  == btv->cardid)
  1080. type = i;
  1081. if (type != -1) {
  1082. /* found it */
  1083. printk(KERN_INFO "bttv%d: detected: %s [card=%d], "
  1084.        "PCI subsystem ID is %04x:%04xn",
  1085.        btv->nr,cards[type].name,cards[type].cardnr,
  1086.        btv->cardid & 0xffff, btv->cardid >> 16);
  1087. btv->type = cards[type].cardnr;
  1088. } else {
  1089. /* 404 */
  1090. printk(KERN_INFO "bttv%d: subsystem: %04x:%04x (UNKNOWN)n",
  1091.        btv->nr, btv->cardid&0xffff, btv->cardid>>16);
  1092. printk(KERN_DEBUG "please mail id, board name and "
  1093.        "the correct card= insmod option to kraxel@bytesex.orgn");
  1094. }
  1095. }
  1096. /* let the user override the autodetected type */
  1097. if (card[btv->nr] >= 0 && card[btv->nr] < bttv_num_tvcards)
  1098. btv->type=card[btv->nr];
  1099. /* print which card config we are using */
  1100. sprintf(btv->video_dev.name,"BT%d%s(%.23s)",
  1101. btv->id,
  1102. (btv->id==848 && btv->revision==0x12) ? "A" : "",
  1103. bttv_tvcards[btv->type].name);
  1104. printk(KERN_INFO "bttv%d: using: %s [card=%d,%s]n",btv->nr,
  1105.        btv->video_dev.name,btv->type,
  1106.        (card[btv->nr] >= 0 && card[btv->nr] < bttv_num_tvcards) ?
  1107.        "insmod option" : "autodetected");
  1108. /* overwrite gpio stuff ?? */
  1109. if (-1 == audioall && -1 == audiomux[0])
  1110. return;
  1111. if (-1 != audiomux[0]) {
  1112. gpiobits = 0;
  1113. for (i = 0; i < 5; i++) {
  1114. bttv_tvcards[btv->type].audiomux[i] = audiomux[i];
  1115. gpiobits |= audiomux[i];
  1116. }
  1117. } else {
  1118. gpiobits = audioall;
  1119. for (i = 0; i < 5; i++) {
  1120. bttv_tvcards[btv->type].audiomux[i] = audioall;
  1121. }
  1122. }
  1123. bttv_tvcards[btv->type].gpiomask = (-1 != gpiomask) ? gpiomask : gpiobits;
  1124. printk(KERN_INFO "bttv%d: gpio config override: mask=0x%x, mux=",
  1125.        btv->nr,bttv_tvcards[btv->type].gpiomask);
  1126. for (i = 0; i < 5; i++) {
  1127. printk("%s0x%x", i ? "," : "", bttv_tvcards[btv->type].audiomux[i]);
  1128. }
  1129. printk("n");
  1130. }
  1131. /*
  1132.  * (most) board specific initialisations goes here
  1133.  */
  1134. int miro_tunermap[] = { 0,6,2,3,   4,5,6,0,  3,0,4,5,  5,2,16,1,
  1135. 14,2,17,1, 4,1,4,3,  1,2,16,1, 4,4,4,4 };
  1136. int miro_fmtuner[]  = { 0,0,0,0,   0,0,0,0,  0,0,0,0,  0,0,0,1,
  1137. 1,1,1,1,   1,1,1,0,  0,0,0,0,  0,0,0,0 };
  1138. void __devinit bttv_init_card(struct bttv *btv)
  1139. {
  1140. /* miro/pinnacle */
  1141.         if (btv->type == BTTV_MIRO      ||
  1142.     btv->type == BTTV_MIROPRO   ||
  1143.     btv->type == BTTV_PINNACLE  ||
  1144.     btv->type == BTTV_PINNACLEPRO) {
  1145. int id,msp;
  1146. id  = ((btread(BT848_GPIO_DATA)>>10) & 31) -1;
  1147. msp = bttv_I2CRead(btv, I2C_MSP3400, "MSP34xx");
  1148. btv->tuner_type = miro_tunermap[id];
  1149. if (0 == (btread(BT848_GPIO_DATA) & 0x20)) {
  1150. btv->has_radio = 1;
  1151. if (!miro_fmtuner[id]) {
  1152. btv->has_matchbox = 1;
  1153. btv->mbox_we    = (1<<6);
  1154. btv->mbox_most  = (1<<7);
  1155. btv->mbox_clk   = (1<<8);
  1156. btv->mbox_data  = (1<<9);
  1157. btv->mbox_mask  = (1<<6)|(1<<7)|(1<<8)|(1<<9);
  1158. }
  1159. } else {
  1160. btv->has_radio = 0;
  1161. }
  1162. if (-1 != msp) {
  1163. if (btv->type == BTTV_MIRO)
  1164. btv->type = BTTV_MIROPRO;
  1165. if (btv->type == BTTV_PINNACLE)
  1166. btv->type = BTTV_PINNACLEPRO;
  1167. }
  1168. if (bttv_verbose)
  1169. printk(KERN_INFO "bttv%d: miro: id=%d tuner=%d "
  1170.        "radio=%s stereo=%sn",
  1171.        btv->nr, id+1, btv->tuner_type,
  1172.        !btv->has_radio ? "no" :
  1173.    (btv->has_matchbox ? "matchbox" : "fmtuner"),
  1174.        (-1 == msp) ? "no" : "yes");
  1175. #if 0
  1176. if (btv->has_matchbox) {
  1177. if (bttv_verbose)
  1178. printk(KERN_INFO "Initializing TEA5757...n");
  1179. init_tea5757(btv);
  1180. }
  1181. #endif
  1182. }
  1183.         if (btv->type == BTTV_HAUPPAUGE || btv->type == BTTV_HAUPPAUGE878) {
  1184. /* pick up some config infos from the eeprom */
  1185. bttv_readee(btv,eeprom_data,0xa0);
  1186.                 hauppauge_eeprom(btv);
  1187.         }
  1188. if (btv->type == BTTV_AVERMEDIA98 || btv->type == BTTV_AVPHONE98) {
  1189. bttv_readee(btv,eeprom_data,0xa0);
  1190. avermedia_eeprom(btv);
  1191. }
  1192.   if (btv->type == BTTV_PXC200)
  1193. init_PXC200(btv);
  1194. if (btv->type == BTTV_VHX) {
  1195. btv->has_radio    = 1;
  1196. btv->has_matchbox = 1;
  1197. btv->mbox_we      = 0x20;
  1198. btv->mbox_most    = 0;
  1199. btv->mbox_clk     = 0x08;
  1200. btv->mbox_data    = 0x10;
  1201. btv->mbox_mask    = 0x38;
  1202. }
  1203. if (btv->type == BTTV_LIFETEC_9415) {
  1204. if (btread(BT848_GPIO_DATA) & 0x4000)
  1205. printk("bttv%d: lifetec: tv mono/fm stereo cardn", btv->nr);
  1206. else
  1207. printk("bttv%d: lifetec: stereo(TDA9821) cardn",btv->nr);
  1208. }
  1209. if (btv->type == BTTV_MAGICTVIEW061) {
  1210. if(btv->cardid == 0x4002144f) {
  1211. btv->has_radio=1;
  1212. printk("bttv%d: radio detected by subsystem id (CPH05x)n",btv->nr);
  1213. }
  1214. }
  1215. /* pll configuration */
  1216.         if (!(btv->id==848 && btv->revision==0x11)) {
  1217. /* defaults from card list */
  1218. if (PLL_28 == bttv_tvcards[btv->type].pll) {
  1219. btv->pll.pll_ifreq=28636363;
  1220. btv->pll.pll_crystal=BT848_IFORM_XT0;
  1221. }
  1222. if (PLL_35 == bttv_tvcards[btv->type].pll) {
  1223. btv->pll.pll_ifreq=35468950;
  1224. btv->pll.pll_crystal=BT848_IFORM_XT1;
  1225. }
  1226. /* insmod options can override */
  1227.                 switch (pll[btv->nr]) {
  1228.                 case 0: /* none */
  1229. btv->pll.pll_crystal = 0;
  1230. btv->pll.pll_ifreq   = 0;
  1231. btv->pll.pll_ofreq   = 0;
  1232.                         break;
  1233.                 case 1: /* 28 MHz */
  1234. case 28:
  1235.                         btv->pll.pll_ifreq   = 28636363;
  1236. btv->pll.pll_ofreq   = 0;
  1237.                         btv->pll.pll_crystal = BT848_IFORM_XT0;
  1238.                         break;
  1239.                 case 2: /* 35 MHz */
  1240. case 35:
  1241.                         btv->pll.pll_ifreq   = 35468950;
  1242. btv->pll.pll_ofreq   = 0;
  1243.                         btv->pll.pll_crystal = BT848_IFORM_XT1;
  1244.                         break;
  1245.                 }
  1246.         }
  1247. /* tuner configuration (from card list / insmod option) */
  1248.   if (-1 != bttv_tvcards[btv->type].tuner_type)
  1249.                 btv->tuner_type = bttv_tvcards[btv->type].tuner_type;
  1250. if (-1 != tuner[btv->nr])
  1251. btv->tuner_type = tuner[btv->nr];
  1252. if (btv->tuner_type != -1)
  1253. bttv_call_i2c_clients(btv,TUNER_SET_TYPE,&btv->tuner_type);
  1254. if (bttv_tvcards[btv->type].has_radio)
  1255. btv->has_radio=1;
  1256. /* try to detect audio/fader chips */
  1257. if (!bttv_tvcards[btv->type].no_msp34xx &&
  1258.     bttv_I2CRead(btv, I2C_MSP3400, "MSP34xx") >=0) {
  1259. if (autoload)
  1260. request_module("msp3400");
  1261. }
  1262. if (!bttv_tvcards[btv->type].no_tda9875 &&
  1263.     bttv_I2CRead(btv, I2C_TDA9875, "TDA9875") >=0) {
  1264. if (autoload)
  1265. request_module("tda9875");
  1266. }
  1267. if (bttv_I2CRead(btv, I2C_TDA7432, "TDA7432") >=0) {
  1268. if (autoload)
  1269. request_module("tda7432");
  1270. }
  1271. if (bttv_tvcards[btv->type].needs_tvaudio) {
  1272. if (autoload)
  1273. request_module("tvaudio");
  1274. }
  1275. if (bttv_tvcards[btv->type].tuner != -1) {
  1276. if (autoload)
  1277. request_module("tuner");
  1278. }
  1279. }
  1280. /* ----------------------------------------------------------------------- */
  1281. /* some hauppauge specific stuff                                           */
  1282. static struct HAUPPAUGE_TUNER 
  1283. {
  1284.         int  id;
  1285.         char *name;
  1286. hauppauge_tuner[] __devinitdata = 
  1287. {
  1288.         { TUNER_ABSENT,        "" },
  1289.         { TUNER_ABSENT,        "External" },
  1290.         { TUNER_ABSENT,        "Unspecified" },
  1291.         { TUNER_PHILIPS_PAL,   "Philips FI1216" },
  1292.         { TUNER_PHILIPS_SECAM, "Philips FI1216MF" },
  1293.         { TUNER_PHILIPS_NTSC,  "Philips FI1236" },
  1294.         { TUNER_PHILIPS_PAL_I, "Philips FI1246" },
  1295.         { TUNER_PHILIPS_PAL_DK,"Philips FI1256" },
  1296.         { TUNER_PHILIPS_PAL,   "Philips FI1216 MK2" },
  1297.         { TUNER_PHILIPS_SECAM, "Philips FI1216MF MK2" },
  1298.         { TUNER_PHILIPS_NTSC,  "Philips FI1236 MK2" },
  1299.         { TUNER_PHILIPS_PAL_I, "Philips FI1246 MK2" },
  1300.         { TUNER_PHILIPS_PAL_DK,"Philips FI1256 MK2" },
  1301.         { TUNER_TEMIC_NTSC,    "Temic 4032FY5" },
  1302.         { TUNER_TEMIC_PAL,     "Temic 4002FH5" },
  1303.         { TUNER_TEMIC_PAL_I,   "Temic 4062FY5" },
  1304.         { TUNER_PHILIPS_PAL,   "Philips FR1216 MK2" },
  1305.         { TUNER_PHILIPS_SECAM, "Philips FR1216MF MK2" },
  1306.         { TUNER_PHILIPS_NTSC,  "Philips FR1236 MK2" },
  1307.         { TUNER_PHILIPS_PAL_I, "Philips FR1246 MK2" },
  1308.         { TUNER_PHILIPS_PAL_DK,"Philips FR1256 MK2" },
  1309.         { TUNER_PHILIPS_PAL,   "Philips FM1216" },
  1310.         { TUNER_PHILIPS_SECAM, "Philips FM1216MF" },
  1311.         { TUNER_PHILIPS_NTSC,  "Philips FM1236" },
  1312.         { TUNER_PHILIPS_PAL_I, "Philips FM1246" },
  1313.         { TUNER_PHILIPS_PAL_DK,"Philips FM1256" },
  1314.         { TUNER_TEMIC_4036FY5_NTSC, "Temic 4036FY5" },
  1315.         { TUNER_ABSENT,        "Samsung TCPN9082D" },
  1316.         { TUNER_ABSENT,        "Samsung TCPM9092P" },
  1317.         { TUNER_TEMIC_4006FH5_PAL, "Temic 4006FH5" },
  1318.         { TUNER_ABSENT,        "Samsung TCPN9085D" },
  1319.         { TUNER_ABSENT,        "Samsung TCPB9085P" },
  1320.         { TUNER_ABSENT,        "Samsung TCPL9091P" },
  1321.         { TUNER_TEMIC_4039FR5_NTSC, "Temic 4039FR5" },
  1322.         { TUNER_PHILIPS_FQ1216ME,   "Philips FQ1216 ME" },
  1323.         { TUNER_TEMIC_4066FY5_PAL_I, "Temic 4066FY5" },
  1324.         { TUNER_ABSENT,        "Philips TD1536" },
  1325.         { TUNER_ABSENT,        "Philips TD1536D" },
  1326. { TUNER_PHILIPS_NTSC,  "Philips FMR1236" }, /* mono radio */
  1327.         { TUNER_ABSENT,        "Philips FI1256MP" },
  1328.         { TUNER_ABSENT,        "Samsung TCPQ9091P" },
  1329.         { TUNER_TEMIC_4006FN5_MULTI_PAL, "Temic 4006FN5" },
  1330.         { TUNER_TEMIC_4009FR5_PAL, "Temic 4009FR5" },
  1331.         { TUNER_TEMIC_4046FM5,     "Temic 4046FM5" },
  1332. { TUNER_TEMIC_4009FN5_MULTI_PAL_FM, "Temic 4009FN5" },
  1333. { TUNER_ABSENT,        "Philips TD1536D_FH_44"},
  1334. { TUNER_LG_NTSC_FM,    "LG TP18NSR01F"},
  1335. { TUNER_LG_PAL_FM,     "LG TP18PSB01D"},
  1336. { TUNER_LG_PAL,        "LG TP18PSB11D"},
  1337. { TUNER_LG_PAL_I_FM,   "LG TAPC-I001D"},
  1338. { TUNER_LG_PAL_I,      "LG TAPC-I701D"}
  1339. };
  1340. static void __devinit hauppauge_eeprom(struct bttv *btv)
  1341. {
  1342. int blk2,tuner,radio,model;
  1343. if (eeprom_data[0] != 0x84 || eeprom_data[2] != 0)
  1344. printk(KERN_WARNING "bttv%d: Hauppauge eeprom: invalidn",
  1345.        btv->nr);
  1346. /* Block 2 starts after len+3 bytes header */
  1347. blk2 = eeprom_data[1] + 3;
  1348. /* decode + use some config infos */
  1349. model = eeprom_data[12] << 8 | eeprom_data[11];
  1350. tuner = eeprom_data[9];
  1351. radio = eeprom_data[blk2-1] & 0x01;
  1352.         if (tuner < sizeof(hauppauge_tuner)/sizeof(struct HAUPPAUGE_TUNER))
  1353.                 btv->tuner_type = hauppauge_tuner[tuner].id;
  1354. if (radio)
  1355. btv->has_radio = 1;
  1356. if (bttv_verbose)
  1357. printk(KERN_INFO "bttv%d: Hauppauge eeprom: model=%d, "
  1358.        "tuner=%s (%d), radio=%sn",
  1359.        btv->nr, model, hauppauge_tuner[tuner].name,
  1360.        btv->tuner_type, radio ? "yes" : "no");
  1361. }
  1362. // AVermedia specific stuff...
  1363. // from  bktr_card.c
  1364. int tuner_0_table[] = {
  1365.         TUNER_PHILIPS_NTSC,  TUNER_PHILIPS_PAL,
  1366.         TUNER_PHILIPS_PAL,   TUNER_PHILIPS_PAL,
  1367.         TUNER_PHILIPS_PAL,   TUNER_PHILIPS_PAL,
  1368.         TUNER_PHILIPS_SECAM, TUNER_PHILIPS_SECAM,
  1369.         TUNER_PHILIPS_SECAM, TUNER_PHILIPS_PAL};
  1370. /*
  1371. int tuner_0_fm_table[] = {
  1372.         PHILIPS_FR1236_NTSC,  PHILIPS_FR1216_PAL,
  1373.         PHILIPS_FR1216_PAL,   PHILIPS_FR1216_PAL,
  1374.         PHILIPS_FR1216_PAL,   PHILIPS_FR1216_PAL,
  1375.         PHILIPS_FR1236_SECAM, PHILIPS_FR1236_SECAM,
  1376.         PHILIPS_FR1236_SECAM, PHILIPS_FR1216_PAL};
  1377. */
  1378. int tuner_1_table[] = {
  1379.         TUNER_TEMIC_NTSC,  TUNER_TEMIC_PAL,
  1380. TUNER_TEMIC_PAL,   TUNER_TEMIC_PAL,
  1381. TUNER_TEMIC_PAL,   TUNER_TEMIC_PAL,
  1382.         TUNER_TEMIC_4012FY5, TUNER_TEMIC_4012FY5, //TUNER_TEMIC_SECAM
  1383.         TUNER_TEMIC_4012FY5, TUNER_TEMIC_PAL};
  1384. static void __devinit avermedia_eeprom(struct bttv *btv)
  1385. {
  1386.         int tuner_make,tuner_tv_fm,tuner_format,tuner=0;
  1387. tuner_make   = (eeprom_data[0x41] & 0x7);
  1388.         tuner_tv_fm  = (eeprom_data[0x41] & 0x18) >> 3;
  1389.         tuner_format = (eeprom_data[0x42] & 0xf0) >> 4;
  1390. if (tuner_make == 0 || tuner_make == 2)
  1391. if(tuner_format <=9)
  1392. tuner = tuner_0_table[tuner_format];
  1393. if (tuner_make == 1)
  1394. if(tuner_format <=9)
  1395. tuner = tuner_1_table[tuner_format];
  1396. printk(KERN_INFO "bttv%d: Avermedia eeprom[0x%02x%02x]: tuner=",
  1397. btv->nr,eeprom_data[0x41],eeprom_data[0x42]);
  1398. if(tuner) {
  1399. btv->tuner_type=tuner;
  1400. printk("%dn",tuner);
  1401. } else
  1402. printk("Unknown typen");
  1403. }
  1404. /*
  1405.  * reset/enable the MSP on some Hauppauge cards
  1406.  * Thanks to Ky鰏ti M鋖kki (kmalkki@cc.hut.fi)!
  1407.  *
  1408.  * Hauppauge:  pin  5
  1409.  * Voodoo:     pin 20
  1410.  */
  1411. void __devinit bttv_boot_msp34xx(struct bttv *btv, int pin)
  1412. {
  1413. int mask = (1 << pin);
  1414.         btaor(mask, ~mask, BT848_GPIO_OUT_EN);
  1415.         btaor(0, ~mask, BT848_GPIO_DATA);
  1416.         udelay(2500);
  1417.         btaor(mask, ~mask, BT848_GPIO_DATA);
  1418. if (bttv_gpio)
  1419. bttv_gpio_tracking(btv,"msp34xx");
  1420. if (bttv_verbose)
  1421. printk(KERN_INFO "bttv%d: Hauppauge/Voodoo msp34xx: reset line "
  1422.        "init [%d]n", btv->nr, pin);
  1423. }
  1424. /* ----------------------------------------------------------------------- */
  1425. /*  Imagenation L-Model PXC200 Framegrabber */
  1426. /*  This is basically the same procedure as 
  1427.  *  used by Alessandro Rubini in his pxc200 
  1428.  *  driver, but using BTTV functions */
  1429. static void __devinit init_PXC200(struct bttv *btv)
  1430. {
  1431. static int vals[] __devinitdata = { 0x08, 0x09, 0x0a, 0x0b, 0x0d, 0x0d,
  1432.     0x01, 0x02, 0x03, 0x04, 0x05, 0x06,
  1433.     0x00 };
  1434. int i,tmp;
  1435. /* Initialise GPIO-connevted stuff */
  1436. btwrite(1<<13,BT848_GPIO_OUT_EN); /* Reset pin only */
  1437. btwrite(0,BT848_GPIO_DATA);
  1438. udelay(3);
  1439. btwrite(1<<13,BT848_GPIO_DATA);
  1440. /* GPIO inputs are pulled up, so no need to drive 
  1441.  * reset pin any longer */
  1442. btwrite(0,BT848_GPIO_OUT_EN);
  1443. if (bttv_gpio)
  1444. bttv_gpio_tracking(btv,"pxc200");
  1445. /*  we could/should try and reset/control the AD pots? but
  1446.     right now  we simply  turned off the crushing.  Without
  1447.     this the AGC drifts drifts
  1448.     remember the EN is reverse logic -->
  1449.     setting BT848_ADC_AGC_EN disable the AGC
  1450.     tboult@eecs.lehigh.edu
  1451. */
  1452. btwrite(BT848_ADC_RESERVED|BT848_ADC_AGC_EN, BT848_ADC);
  1453. /* Initialise MAX517 DAC */
  1454. printk(KERN_INFO "Setting DAC reference voltage level ...n");
  1455. bttv_I2CWrite(btv,0x5E,0,0x80,1);
  1456. /* Initialise 12C508 PIC */
  1457. /* The I2CWrite and I2CRead commmands are actually to the 
  1458.  * same chips - but the R/W bit is included in the address
  1459.  * argument so the numbers are different */
  1460. printk(KERN_INFO "Initialising 12C508 PIC chip ...n");
  1461. for (i = 0; i < sizeof(vals)/sizeof(int); i++) {
  1462. tmp=bttv_I2CWrite(btv,0x1E,vals[i],0,1);
  1463. printk(KERN_INFO "I2C Write(0x08) = %inI2C Read () = %xnn",
  1464.        tmp,bttv_I2CRead(btv,0x1F,NULL));
  1465. }
  1466. printk(KERN_INFO "PXC200 Initialised.n");
  1467. }
  1468. /* ----------------------------------------------------------------------- */
  1469. /* Miro Pro radio stuff -- the tea5757 is connected to some GPIO ports     */
  1470. /*
  1471.  * Copyright (c) 1999 Csaba Halasz <qgehali@uni-miskolc.hu>
  1472.  * This code is placed under the terms of the GNU General Public License
  1473.  *
  1474.  * Brutally hacked by Dan Sheridan <dan.sheridan@contact.org.uk> djs52 8/3/00
  1475.  */
  1476. #if 0
  1477. /* bus bits on the GPIO port */
  1478. #define TEA_WE 6
  1479. #define TEA_DATA 9
  1480. #define TEA_CLK 8
  1481. #define TEA_MOST 7
  1482. #endif
  1483. #define BUS_LOW(bit)  btand(~(bit), BT848_GPIO_DATA)
  1484. #define BUS_HIGH(bit) btor((bit), BT848_GPIO_DATA)
  1485. #define BUS_IN(bit) (btread(BT848_GPIO_DATA) & (bit))
  1486. /* TEA5757 register bits */
  1487. #define TEA_FREQ 0:14
  1488. #define TEA_BUFFER 15:15
  1489. #define TEA_SIGNAL_STRENGTH 16:17
  1490. #define TEA_PORT1 18:18
  1491. #define TEA_PORT0 19:19
  1492. #define TEA_BAND 20:21
  1493. #define TEA_BAND_FM 0
  1494. #define TEA_BAND_MW 1
  1495. #define TEA_BAND_LW 2
  1496. #define TEA_BAND_SW 3
  1497. #define TEA_MONO 22:22
  1498. #define TEA_ALLOW_STEREO 0
  1499. #define TEA_FORCE_MONO 1
  1500. #define TEA_SEARCH_DIRECTION 23:23
  1501. #define TEA_SEARCH_DOWN 0
  1502. #define TEA_SEARCH_UP 1
  1503. #define TEA_STATUS 24:24
  1504. #define TEA_STATUS_TUNED 0
  1505. #define TEA_STATUS_SEARCHING 1
  1506. /* Low-level stuff */
  1507. static int tea5757_read(struct bttv *btv)
  1508. {
  1509. int value = 0;
  1510. long timeout;
  1511. int i;
  1512. /* better safe than sorry */
  1513. btaor((btv->mbox_clk | btv->mbox_we),
  1514.       ~btv->mbox_mask, BT848_GPIO_OUT_EN);
  1515. if (bttv_gpio)
  1516. bttv_gpio_tracking(btv,"tea5757 read");
  1517. BUS_LOW(btv->mbox_we);
  1518. BUS_LOW(btv->mbox_clk);
  1519. udelay(10);
  1520. for(timeout = jiffies + 10 * HZ;
  1521.     BUS_IN(btv->mbox_data) && time_before(jiffies, timeout);
  1522.     schedule()); /* 10 s */
  1523. if (BUS_IN(btv->mbox_data)) {
  1524. printk(KERN_WARNING "bttv%d: tea5757: read timeoutn",btv->nr);
  1525. return -1;
  1526. }
  1527. for(timeout = jiffies + HZ/5;
  1528.     BUS_IN(btv->mbox_data) == 1 && time_before(jiffies, timeout);
  1529.     schedule()); /* 0.2 s */
  1530. dprintk("bttv%d: tea5757:",btv->nr);
  1531. for(i = 0; i < 24; i++)
  1532. {
  1533. udelay(5);
  1534. BUS_HIGH(btv->mbox_clk);
  1535. udelay(5);
  1536. dprintk("%c",(BUS_IN(btv->mbox_most) == 0)?'T':'-');
  1537. BUS_LOW(btv->mbox_clk);
  1538. value <<= 1;
  1539. value |= (BUS_IN(btv->mbox_data) == 0)?0:1;  /* MSB first */
  1540. dprintk("%c", (BUS_IN(btv->mbox_most) == 0)?'S':'M');
  1541. }
  1542. dprintk("nbttv%d: tea5757: read 0x%Xn", btv->nr, value);
  1543. return value;
  1544. }
  1545. static int tea5757_write(struct bttv *btv, int value)
  1546. {
  1547. int i;
  1548. int reg = value;
  1549. btaor(btv->mbox_clk | btv->mbox_we | btv->mbox_data,
  1550.       ~btv->mbox_mask, BT848_GPIO_OUT_EN);
  1551. if (bttv_gpio)
  1552. bttv_gpio_tracking(btv,"tea5757 write");
  1553. dprintk("bttv%d: tea5757: write 0x%Xn", btv->nr, value);
  1554. BUS_LOW(btv->mbox_clk);
  1555. BUS_HIGH(btv->mbox_we);
  1556. for(i = 0; i < 25; i++)
  1557. {
  1558. if (reg & 0x1000000)
  1559. BUS_HIGH(btv->mbox_data);
  1560. else
  1561. BUS_LOW(btv->mbox_data);
  1562. reg <<= 1;
  1563. BUS_HIGH(btv->mbox_clk);
  1564. udelay(10);
  1565. BUS_LOW(btv->mbox_clk);
  1566. udelay(10);
  1567. }
  1568. BUS_LOW(btv->mbox_we);  /* unmute !!! */
  1569. return 0;
  1570. }
  1571. void tea5757_set_freq(struct bttv *btv, unsigned short freq)
  1572. {
  1573. tea5757_write(btv, 5 * freq + 0x358); /* add 10.7MHz (see docs) */
  1574. if (bttv_debug)
  1575. tea5757_read(btv);
  1576. }
  1577. /* ----------------------------------------------------------------------- */
  1578. /* winview                                                                 */
  1579. void winview_audio(struct bttv *btv, struct video_audio *v, int set)
  1580. {
  1581. /* PT2254A programming Jon Tombs, jon@gte.esi.us.es */
  1582. int bits_out, loops, vol, data;
  1583. if (!set) {
  1584. /* Fixed by Leandro Lucarella <luca@linuxmendoza.org.ar (07/31/01) */
  1585. v->flags |= VIDEO_AUDIO_VOLUME;
  1586. return;
  1587. }
  1588. /* 32 levels logarithmic */
  1589. vol = 32 - ((v->volume>>11));
  1590. /* units */
  1591. bits_out = (PT2254_DBS_IN_2>>(vol%5));
  1592. /* tens */
  1593. bits_out |= (PT2254_DBS_IN_10>>(vol/5));
  1594. bits_out |= PT2254_L_CHANNEL | PT2254_R_CHANNEL;
  1595. data = btread(BT848_GPIO_DATA);
  1596. data &= ~(WINVIEW_PT2254_CLK| WINVIEW_PT2254_DATA|
  1597.   WINVIEW_PT2254_STROBE);
  1598. for (loops = 17; loops >= 0 ; loops--) {
  1599. if (bits_out & (1<<loops))
  1600. data |=  WINVIEW_PT2254_DATA;
  1601. else
  1602. data &= ~WINVIEW_PT2254_DATA;
  1603. btwrite(data, BT848_GPIO_DATA);
  1604. udelay(5);
  1605. data |= WINVIEW_PT2254_CLK;
  1606. btwrite(data, BT848_GPIO_DATA);
  1607. udelay(5);
  1608. data &= ~WINVIEW_PT2254_CLK;
  1609. btwrite(data, BT848_GPIO_DATA);
  1610. }
  1611. data |=  WINVIEW_PT2254_STROBE;
  1612. data &= ~WINVIEW_PT2254_DATA;
  1613. btwrite(data, BT848_GPIO_DATA);
  1614. udelay(10);                     
  1615. data &= ~WINVIEW_PT2254_STROBE;
  1616. btwrite(data, BT848_GPIO_DATA);
  1617. }
  1618. /* ----------------------------------------------------------------------- */
  1619. /* mono/stereo control for various cards (which don't use i2c chips but    */
  1620. /* connect something to the GPIO pins                                      */
  1621. static void
  1622. gvbctv3pci_audio(struct bttv *btv, struct video_audio *v, int set)
  1623. {
  1624. unsigned int con = 0;
  1625. if (set) {
  1626. btor(0x300, BT848_GPIO_OUT_EN);
  1627. if (v->mode & VIDEO_SOUND_LANG1)
  1628. con = 0x000;
  1629. if (v->mode & VIDEO_SOUND_LANG2)
  1630. con = 0x300;
  1631. if (v->mode & VIDEO_SOUND_STEREO)
  1632. con = 0x200;
  1633. // if (v->mode & VIDEO_SOUND_MONO)
  1634. // con = 0x100;
  1635. btaor(con, ~0x300, BT848_GPIO_DATA);
  1636. } else {
  1637. v->mode = VIDEO_SOUND_STEREO |
  1638.   VIDEO_SOUND_LANG1  | VIDEO_SOUND_LANG2;
  1639. }
  1640. }
  1641. /*
  1642.  * Mario Medina Nussbaum <medisoft@alohabbs.org.mx>
  1643.  *  I discover that on BT848_GPIO_DATA address a byte 0xcce enable stereo,
  1644.  *  0xdde enables mono and 0xccd enables sap
  1645.  *
  1646.  * Petr Vandrovec <VANDROVE@vc.cvut.cz>
  1647.  *  P.S.: At least mask in line above is wrong - GPIO pins 3,2 select
  1648.  *  input/output sound connection, so both must be set for output mode.
  1649.  *
  1650.  * Looks like it's needed only for the "tvphone", the "tvphone 98"
  1651.  * handles this with a tda9840
  1652.  *
  1653.  */
  1654. static void
  1655. avermedia_tvphone_audio(struct bttv *btv, struct video_audio *v, int set)
  1656. {
  1657. int val = 0;
  1658. if (set) {
  1659. if (v->mode & VIDEO_SOUND_LANG1)   /* SAP */
  1660. val = 0x02;
  1661. if (v->mode & VIDEO_SOUND_STEREO)
  1662. val = 0x01;
  1663. if (val) {
  1664. btaor(val, ~0x03, BT848_GPIO_DATA);
  1665. if (bttv_gpio)
  1666. bttv_gpio_tracking(btv,"avermedia");
  1667. }
  1668. } else {
  1669. v->mode = VIDEO_SOUND_MONO | VIDEO_SOUND_STEREO |
  1670. VIDEO_SOUND_LANG1;
  1671. return;
  1672. }
  1673. }
  1674. /* Lifetec 9415 handling */
  1675. static void
  1676. lt9415_audio(struct bttv *btv, struct video_audio *v, int set)
  1677. {
  1678.         int val = 0;
  1679.         if (btread(BT848_GPIO_DATA) & 0x4000) {
  1680. v->mode = VIDEO_SOUND_MONO;
  1681. return;
  1682. }
  1683.         if (set) {
  1684.                 if (v->mode & VIDEO_SOUND_LANG2)  /* A2 SAP */
  1685.                         val = 0x0080;
  1686. if (v->mode & VIDEO_SOUND_STEREO) /* A2 stereo */
  1687.                         val = 0x0880;
  1688.                 if ((v->mode & VIDEO_SOUND_LANG1) ||
  1689.     (v->mode & VIDEO_SOUND_MONO))
  1690. val = 0;
  1691.                 btaor(val, ~0x0880, BT848_GPIO_DATA);
  1692.                 if (bttv_gpio)
  1693.                         bttv_gpio_tracking(btv,"lt9415");
  1694.         } else {
  1695. /* autodetect doesn't work with this card :-( */
  1696.                 v->mode = VIDEO_SOUND_MONO | VIDEO_SOUND_STEREO |
  1697. VIDEO_SOUND_LANG1 | VIDEO_SOUND_LANG2;
  1698.                 return;
  1699.         }
  1700. }
  1701. static void
  1702. terratv_audio(struct bttv *btv, struct video_audio *v, int set)
  1703. {
  1704. unsigned int con = 0;
  1705. if (set) {
  1706. btor(0x180000, BT848_GPIO_OUT_EN);
  1707. if (v->mode & VIDEO_SOUND_LANG2)
  1708. con = 0x080000;
  1709. if (v->mode & VIDEO_SOUND_STEREO)
  1710. con = 0x180000;
  1711. btaor(con, ~0x180000, BT848_GPIO_DATA);
  1712. if (bttv_gpio)
  1713. bttv_gpio_tracking(btv,"terratv");
  1714. } else {
  1715. v->mode = VIDEO_SOUND_MONO | VIDEO_SOUND_STEREO |
  1716. VIDEO_SOUND_LANG1 | VIDEO_SOUND_LANG2;
  1717. }
  1718. }
  1719. static void
  1720. winfast2000_audio(struct bttv *btv, struct video_audio *v, int set)
  1721. {
  1722. unsigned long val = 0;
  1723. if (set) {
  1724. /*btor (0xc32000, BT848_GPIO_OUT_EN);*/
  1725. if (v->mode & VIDEO_SOUND_MONO) /* Mono */
  1726. val = 0x420000;
  1727. if (v->mode & VIDEO_SOUND_LANG1) /* Mono */
  1728. val = 0x420000;
  1729. if (v->mode & VIDEO_SOUND_LANG2) /* SAP */
  1730. val = 0x410000;
  1731. if (v->mode & VIDEO_SOUND_STEREO) /* Stereo */
  1732. val = 0x020000;
  1733. if (val) {
  1734. btaor(val, ~0x430000, BT848_GPIO_DATA);
  1735. if (bttv_gpio)
  1736. bttv_gpio_tracking(btv,"winfast2000");
  1737. }
  1738. } else {
  1739. v->mode = VIDEO_SOUND_MONO | VIDEO_SOUND_STEREO |
  1740.   VIDEO_SOUND_LANG1 | VIDEO_SOUND_LANG2;
  1741. }
  1742. }
  1743. /*
  1744.  * Dariusz Kowalewski <darekk@automex.pl>
  1745.  * sound control for Prolink PV-BT878P+9B (PixelView PlayTV Pro FM+NICAM
  1746.  * revision 9B has on-board TDA9874A sound decoder).
  1747.  */
  1748. static void
  1749. pvbt878p9b_audio(struct bttv *btv, struct video_audio *v, int set)
  1750. {
  1751. unsigned int val = 0;
  1752. #if BTTV_VERSION_CODE > KERNEL_VERSION(0,8,0)
  1753. if (btv->radio_user)
  1754. return;
  1755. #else
  1756. if (btv->radio)
  1757. return;
  1758. #endif
  1759. if (set) {
  1760. if (v->mode & VIDEO_SOUND_MONO) {
  1761. val = 0x01;
  1762. }
  1763. if ((v->mode & (VIDEO_SOUND_LANG1 | VIDEO_SOUND_LANG2))
  1764.     || (v->mode & VIDEO_SOUND_STEREO)) {
  1765. val = 0x02;
  1766. }
  1767. if (val) {
  1768. btaor(val, ~0x03, BT848_GPIO_DATA);
  1769. if (bttv_gpio)
  1770. bttv_gpio_tracking(btv,"pvbt878p9b");
  1771. }
  1772. } else {
  1773. v->mode = VIDEO_SOUND_MONO | VIDEO_SOUND_STEREO |
  1774.   VIDEO_SOUND_LANG1 | VIDEO_SOUND_LANG2;
  1775. }
  1776. }
  1777. /* ----------------------------------------------------------------------- */
  1778. /* motherboard chipset specific stuff                                      */
  1779. void __devinit bttv_check_chipset(void)
  1780. {
  1781. int pcipci_fail = 0;
  1782. struct pci_dev *dev = NULL;
  1783. /* for 2.4.x we'll use the pci quirks (drivers/pci/quirks.c) */
  1784. if (pci_pci_problems & PCIPCI_FAIL)
  1785. pcipci_fail = 1;
  1786. if (pci_pci_problems & (PCIPCI_TRITON|PCIPCI_NATOMA|PCIPCI_VIAETBF))
  1787. triton1 = 1;
  1788. if (pci_pci_problems & PCIPCI_VSFX)
  1789. vsfx = 1;
  1790. /* print which chipset we have */
  1791. while ((dev = pci_find_class(PCI_CLASS_BRIDGE_HOST << 8,dev)))
  1792. printk(KERN_INFO "bttv: Host bridge is %sn",dev->name);
  1793. /* print warnings about any quirks found */
  1794. if (triton1)
  1795. printk(KERN_INFO "bttv: Host bridge needs ETBF enabled.n");
  1796. if (vsfx)
  1797. printk(KERN_INFO "bttv: Host bridge needs VSFX enabled.n");
  1798. if (pcipci_fail) {
  1799. printk(KERN_WARNING "bttv: BT848 and your chipset may not work together.n");
  1800. if (-1 == no_overlay) {
  1801. printk(KERN_WARNING "bttv: going to disable overlay.n");
  1802. no_overlay = 1;
  1803. }
  1804. }
  1805. while ((dev = pci_find_device(PCI_VENDOR_ID_INTEL,
  1806.       PCI_DEVICE_ID_INTEL_82441, dev))) {
  1807.                 unsigned char b;
  1808.                 pci_read_config_byte(dev, 0x53, &b);
  1809. if (bttv_debug)
  1810. printk(KERN_INFO "bttv: Host bridge: 82441FX Natoma, "
  1811.        "bufcon=0x%02xn",b);
  1812. }
  1813. }
  1814. int __devinit bttv_handle_chipset(struct bttv *btv)
  1815. {
  1816.   unsigned char command;
  1817. if (!triton1 && !vsfx)
  1818. return 0;
  1819. if (bttv_verbose) {
  1820. if (triton1)
  1821. printk("bttv%d: enabling ETBF (430FX/VP3 compatibilty)n",btv->nr);
  1822. if (vsfx && btv->id >= 878)
  1823. printk("bttv%d: enabling VSFXn",btv->nr);
  1824. }
  1825. if (btv->id < 878) {
  1826. /* bt848 (mis)uses a bit in the irq mask for etbf */
  1827. if (triton1)
  1828. btv->triton1 = BT848_INT_ETBF;
  1829. } else {
  1830. /* bt878 has a bit in the pci config space for it */
  1831.                 pci_read_config_byte(btv->dev, BT878_DEVCTRL, &command);
  1832. if (triton1)
  1833. command |= BT878_EN_TBFX;
  1834. if (vsfx)
  1835. command |= BT878_EN_VSFX;
  1836.                 pci_write_config_byte(btv->dev, BT878_DEVCTRL, command);
  1837.         }
  1838. return 0;
  1839. }
  1840. /*
  1841.  * Local variables:
  1842.  * c-basic-offset: 8
  1843.  * End:
  1844.  */