Lines Matching +full:gpio0 +full:- +full:adc +full:- +full:pin

1 // SPDX-License-Identifier: GPL-2.0-or-later
4 * card-specific stuff.
19 static unsigned int tuner[] = {[0 ... (CX88_MAXBOARDS - 1)] = UNSET };
20 static unsigned int radio[] = {[0 ... (CX88_MAXBOARDS - 1)] = UNSET };
21 static unsigned int card[] = {[0 ... (CX88_MAXBOARDS - 1)] = UNSET };
45 /* ------------------------------------------------------------------ */
82 .gpio0 = 0xff00, // internal decoder
86 .gpio0 = 0xff01, // mono from tuner chip
90 .gpio0 = 0xff02,
94 .gpio0 = 0xff02,
98 .gpio0 = 0xff01,
124 .gpio0 = 0xff00, // internal decoder
134 .gpio0 = 0xff10,
147 .gpio0 = 0x03ff,
151 .gpio0 = 0x03fe,
155 .gpio0 = 0x03fe,
168 .gpio0 = 0x00F5e700,
175 .gpio0 = 0x00F5c700,
182 .gpio0 = 0x00F5c700,
189 .gpio0 = 0x00F5d700,
223 .name = "MSI TV-@nywhere Master",
232 .gpio0 = 0x000040bf,
238 .gpio0 = 0x000040bf,
244 .gpio0 = 0x000040bf,
251 .gpio0 = 0x000040bf,
266 .gpio0 = 0x0035e700,
273 .gpio0 = 0x0035c700,
280 .gpio0 = 0x0035c700,
287 .gpio0 = 0x0035d700,
304 .gpio0 = 0x0000bde2,
309 .gpio0 = 0x0000bde6,
314 .gpio0 = 0x0000bde6,
319 .gpio0 = 0x0000bd62,
325 .name = "IODATA GV-VCP3/PCI",
351 .gpio0 = 0xbff0,
355 .gpio0 = 0xbff3,
359 .gpio0 = 0xbff3,
363 .gpio0 = 0xbff0,
367 .name = "ASUS PVR-416",
376 .gpio0 = 0x0000fde6,
380 .gpio0 = 0x0000fde6, // 0x0000fda6 L,R RCA audio in?
385 .gpio0 = 0x0000fde2,
390 .name = "MSI TV-@nywhere",
399 .gpio0 = 0x00000fbf,
404 .gpio0 = 0x00000fbf,
409 .gpio0 = 0x00000fbf,
414 .name = "KWorld/VStream XPert DVB-T",
422 .gpio0 = 0x0700,
427 .gpio0 = 0x0700,
433 .name = "DViCO FusionHDTV DVB-T1",
441 .gpio0 = 0x000027df,
445 .gpio0 = 0x000027df,
458 .gpio0 = 0x07f8,
462 .gpio0 = 0x07f9, // mono from tuner chip
466 .gpio0 = 0x000007fa,
470 .gpio0 = 0x000007fa,
474 .gpio0 = 0x000007f8,
478 .name = "DViCO FusionHDTV 3 Gold-Q",
485 * 0 - reset asserted
486 * 1 - normal operation
488 * 0 - enable selected source
489 * 1 - mute
491 * 0 - analog audio input connector on tab
492 * 1 - analog DAC output from CX23881 chip
494 * 0 - RF connector labeled CABLE
495 * 1 - RF connector labeled ANT
497 * 0 - normal RF
498 * 1 - high RF
503 .gpio0 = 0x0f0d,
507 .gpio0 = 0x0f05,
511 .gpio0 = 0x0f00,
515 .gpio0 = 0x0f00,
520 .name = "Hauppauge Nova-T DVB-T",
532 .name = "Conexant DVB-T reference design",
557 .name = "DViCO FusionHDTV DVB-T Plus",
565 .gpio0 = 0x000027df,
569 .gpio0 = 0x000027df,
574 .name = "digitalnow DNTV Live! DVB-T",
582 .gpio0 = 0x00000700,
587 .gpio0 = 0x00000700,
603 * GPIO[7] = input to CX88's audio/chroma ADC
614 .gpio0 = 0x00008484,
618 .gpio0 = 0x00008400,
622 .gpio0 = 0x00008400,
626 .gpio0 = 0x00008404,
641 .gpio0 = 0xed1a,
646 .gpio0 = 0xff01,
650 .gpio0 = 0xff02,
654 .gpio0 = 0xed92,
659 .gpio0 = 0xed96,
665 .name = "Digital-Logic MICROSPACE Entertainment Center (MEC)",
674 .gpio0 = 0x00009d80,
679 .gpio0 = 0x00009d76,
684 .gpio0 = 0x00009d76,
689 .gpio0 = 0x00009d00,
730 .gpio0 = 0xbf61, /* internal decoder */
734 .gpio0 = 0xbf63,
738 .gpio0 = 0xbf63,
742 .gpio0 = 0xbf60,
746 .name = "DViCO FusionHDTV 3 Gold-T",
755 .gpio0 = 0x97ed,
759 .gpio0 = 0x97e9,
763 .gpio0 = 0x97e9,
768 .name = "ADS Tech Instant TV DVB-T PCI",
776 .gpio0 = 0x0700,
781 .gpio0 = 0x0700,
787 .name = "TerraTec Cinergy 1400 DVB-T",
803 .tuner_type = TUNER_LG_TDVS_H06XF, /* TDVS-H062F */
811 .gpio0 = 0x87fd,
815 .gpio0 = 0x87f9,
819 .gpio0 = 0x87f9,
833 .gpio0 = 0x0000cd73,
838 .gpio0 = 0x0000cd73,
843 .gpio0 = 0x0000cdb3,
849 .gpio0 = 0x0000cdf3,
856 .name = "Kworld V-Stream Xpert DVD",
861 .gpio0 = 0x03000000,
868 .gpio0 = 0x03000000,
883 .gpio0 = 0x00000ff7,
890 .gpio0 = 0x00000ffe,
897 .gpio0 = 0x00000ffe,
905 .name = "WinFast DTV1000-T",
932 .gpio0 = 0x00ff,
939 .gpio0 = 0x00ff,
946 .gpio0 = 0x00ff,
953 .name = "Hauppauge Nova-S-Plus DVB-S",
963 /* 2: Line-In */
968 /* 2: Line-In */
973 /* 2: Line-In */
979 .name = "Hauppauge Nova-SE2 DVB-S",
991 .name = "KWorld DVB-S 100",
1000 /* 2: Line-In */
1005 /* 2: Line-In */
1010 /* 2: Line-In */
1016 .name = "Hauppauge WinTV-HVR1100 DVB-T/Hybrid",
1036 .name = "Hauppauge WinTV-HVR1100 DVB-T/Hybrid (Low Profile)",
1053 .name = "digitalnow DNTV Live! DVB-T Pro",
1063 .gpio0 = 0xf80808,
1067 .gpio0 = 0xf80808,
1071 .gpio0 = 0xf80808,
1075 .gpio0 = 0xf80808,
1080 /* Kworld V-stream Xpert DVB-T with Thomson tuner */
1081 /* DTT 7579 Conexant CX22702-19 Conexant CX2388x */
1083 .name = "KWorld/VStream XPert DVB-T with cx22702",
1091 .gpio0 = 0x0700,
1096 .gpio0 = 0x0700,
1102 .name = "DViCO FusionHDTV DVB-T Dual Digital",
1110 .gpio0 = 0x000067df,
1114 .gpio0 = 0x000067df,
1127 .gpio0 = 0x3de2,
1132 .gpio0 = 0x3de6,
1137 .gpio0 = 0x3de6,
1142 .gpio0 = 0x3de6,
1148 .name = "DViCO FusionHDTV DVB-T Hybrid",
1156 .gpio0 = 0x0000a75f,
1160 .gpio0 = 0x0000a75b,
1164 .gpio0 = 0x0000a75b,
1170 .tuner_type = TUNER_LG_TDVS_H06XF, /* TDVS-H064F */
1178 .gpio0 = 0x87fd,
1182 .gpio0 = 0x87f9,
1186 .gpio0 = 0x87f9,
1204 .gpio0 = 0x0000BDE6
1220 .gpio0 = 0x5da6,
1233 .gpio0 = 0x0788,
1237 .gpio0 = 0x078b,
1241 .gpio0 = 0x078b,
1245 .gpio0 = 0x074a,
1258 .gpio0 = 0x00017304,
1265 .gpio0 = 0x0001d701,
1272 .gpio0 = 0x0001d503,
1279 .gpio0 = 0x0001d701,
1286 .gpio0 = 0x00015702,
1303 .gpio0 = 0x00017300,
1310 .gpio0 = 0x00018300,
1317 .gpio0 = 0x00018301,
1324 .gpio0 = 0x00018301,
1331 .gpio0 = 0x00015702,
1339 .name = "Geniatech DVB-S",
1354 .name = "Hauppauge WinTV-HVR3000 TriMode Analog/DVB-S/DVB-T",
1364 .gpio0 = 0x84bf,
1370 .gpio0 = 0x84bf,
1371 /* 2: Line-In */
1376 .gpio0 = 0x84bf,
1377 /* 2: Line-In */
1382 .gpio0 = 0x84bf,
1398 .gpio0 = 0x0709,
1402 .gpio0 = 0x070b,
1406 .gpio0 = 0x070b,
1410 .name = "Shenzhen Tungsten Ages Tech TE-DTV-250 / Swann OEM",
1418 .gpio0 = 0x003fffff,
1425 .gpio0 = 0x003fffff,
1432 .gpio0 = 0x003fffff,
1439 .name = "Hauppauge WinTV-HVR1300 DVB-T/Hybrid MPEG Encoder",
1447 * gpio0 as reported by Mike Crash <mike AT mikecrash.com>
1452 .gpio0 = 0xef88,
1458 .gpio0 = 0xef88,
1459 /* 2: Line-In */
1464 .gpio0 = 0xef88,
1465 /* 2: Line-In */
1471 .gpio0 = 0xef88,
1477 .name = "Samsung SMT 7020 DVB-S",
1497 .gpio0 = 0x04ff,
1501 .gpio0 = 0x07fa,
1505 .gpio0 = 0x07fa,
1517 .gpio0 = 0x04fb,
1522 .gpio0 = 0x04fb,
1528 .gpio0 = 0x04fb,
1544 .gpio0 = 0x000027df, /* Unconfirmed */
1548 .gpio0 = 0x000027df, /* Unconfirmed */
1553 .gpio0 = 0x000027df, /* Unconfirmed */
1567 .gpio0 = 0x004ff,
1573 .gpio0 = 0x004fb,
1579 .gpio0 = 0x004fb,
1585 .gpio0 = 0x004ff,
1594 /* Line-in Audio : set GPIO 2, 18, 19 value to 0, 1, 1 */
1605 .gpio0 = 0x0400, /* pin 2 = 0 */
1607 .gpio2 = 0x0C04, /* pin 18 = 1, pin 19 = 0 */
1612 .gpio0 = 0x0400, /* pin 2 = 0 */
1614 .gpio2 = 0x0C0C, /* pin 18 = 1, pin 19 = 1 */
1619 .gpio0 = 0x0400, /* pin 2 = 0 */
1621 .gpio2 = 0x0C0C, /* pin 18 = 1, pin 19 = 1 */
1626 .gpio0 = 0x0400, /* pin 2 = 0 */
1628 .gpio2 = 0x0C00, /* pin 18 = 0, pin 19 = 0 */
1641 .gpio0 = 0x0400, /* pin 2 = 0 */
1643 .gpio2 = 0x0C04, /* pin 18 = 1, pin 19 = 0 */
1648 .gpio0 = 0x0400, /* pin 2 = 0 */
1650 .gpio2 = 0x0C0C, /* pin 18 = 1, pin 19 = 1 */
1655 .gpio0 = 0x0400, /* pin 2 = 0 */
1657 .gpio2 = 0x0C0C, /* pin 18 = 1, pin 19 = 1 */
1662 .gpio0 = 0x0400, /* pin 2 = 0 */
1664 .gpio2 = 0x0C00, /* pin 18 = 0, pin 19 = 0 */
1677 .gpio0 = 0x0400, /* pin 2 = 0 */
1678 .gpio1 = 0x6040, /* pin 14 = 1, pin 13 = 0 */
1684 .gpio0 = 0x0400, /* pin 2 = 0 */
1685 .gpio1 = 0x6060, /* pin 14 = 1, pin 13 = 1 */
1691 .gpio0 = 0x0400, /* pin 2 = 0 */
1692 .gpio1 = 0x6060, /* pin 14 = 1, pin 13 = 1 */
1698 .gpio0 = 0x0400, /* pin 2 = 0 */
1699 .gpio1 = 0x6000, /* pin 14 = 1, pin 13 = 0 */
1712 * there is no way to deactivate audio pass-
1719 .gpio0 = 0x00ff,
1725 .gpio0 = 0x00ff,
1731 .gpio0 = 0x00ff,
1737 .gpio0 = 0x000ff,
1743 .gpio0 = 0x000ff,
1750 .name = "Geniatech X8000-MT DVBT",
1756 .gpio0 = 0x00000000,
1763 .gpio0 = 0x00000000,
1770 .gpio0 = 0x00000000,
1777 .gpio0 = 0x00000000,
1790 /* if gpio1:bit9 is enabled, DVB-T won't work */
1795 .gpio0 = 0x0000,
1801 .gpio0 = 0x0000,
1807 .gpio0 = 0x0000,
1813 .gpio0 = 0x0000,
1820 .name = "DViCO FusionHDTV DVB-T PRO",
1828 .gpio0 = 0x000067df,
1832 .gpio0 = 0x000067df,
1845 .gpio0 = 0x10df,
1849 .gpio0 = 0x16d9,
1853 .gpio0 = 0x16d9,
1864 .gpio0 = 0x0ff,
1887 .gpio0 = 0x04fb,
1893 .gpio0 = 0x04fb,
1899 .gpio0 = 0x04fb,
1905 .gpio0 = 0x04ff,
1913 * otherwise, tuner-xc3028 won't be detected.
1915 * tuner-xc3028 without doing an i2c probe.
1926 .gpio0 = 0x000000ff,
1932 .gpio0 = 0x000000ff,
1938 .gpio0 = 0x000000ff,
1944 .gpio0 = 0x000000ff,
1951 .name = "Hauppauge WinTV-HVR4000 DVB-S/S2/T/Hybrid",
1959 * GPIO0 (WINTV2000)
1961 * Analogue SAT DVB-T
1964 * S-Video 0xc4bf 0xc4bb
1966 * S-Video1 0xc4ff 0xc4fb
1971 * 2 1 O:MPEG PORT 0=DVB-T 1=DVB-S
1976 * 7 1 O:DVB-T DEMOD RESET LOW
1988 * WM8775 ADC
1991 * 2: Line-In
1992 * 3: Line-In Expansion
1998 .gpio0 = 0xc4bf,
2004 .gpio0 = 0xc4bf,
2005 /* 2: Line-In */
2010 .gpio0 = 0xc4bf,
2011 /* 2: Line-In */
2016 .gpio0 = 0xc4bf,
2024 .name = "Hauppauge WinTV-HVR4000(Lite) DVB-S/S2",
2036 .name = "TeVii S420 DVB-S",
2048 .name = "TeVii S460 DVB-S/S2",
2060 .name = "TeVii S464 DVB-S/S2",
2072 .name = "Omicom SS4 DVB-S/S2 PCI",
2084 .name = "TBS 8910 DVB-S",
2096 .name = "TBS 8920 DVB-S/S2",
2104 .gpio0 = 0x8080,
2109 .name = "Prof 6200 DVB-S",
2121 .name = "PROF 7300 DVB-S/S2",
2133 .name = "SATTRADE ST4200 DVB-S/S2",
2153 .gpio0 = 0x004ff,
2159 .gpio0 = 0x004fb,
2165 .gpio0 = 0x004fb,
2171 .gpio0 = 0x004ff,
2178 .name = "Hauppauge WinTV-IR Only",
2194 * 12: tuner reset pin
2201 .gpio0 = 0x0400, /* pin 2 = 0 */
2202 .gpio1 = 0x6040, /* pin 13 = 0, pin 14 = 1 */
2207 .gpio0 = 0x0400, /* pin 2 = 0 */
2208 .gpio1 = 0x6060, /* pin 13 = 1, pin 14 = 1 */
2213 .gpio0 = 0x0400, /* pin 2 = 0 */
2214 .gpio1 = 0x6060, /* pin 13 = 1, pin 14 = 1 */
2219 .gpio0 = 0x0400, /* pin 2 = 0 */
2220 .gpio1 = 0x6000, /* pin 13 = 0, pin 14 = 0 */
2235 * 12: tuner reset pin
2242 .gpio0 = 0x0400, /* pin 2 = 0 */
2243 .gpio1 = 0x6040, /* pin 13 = 0, pin 14 = 1 */
2248 .gpio0 = 0x0400, /* pin 2 = 0 */
2249 .gpio1 = 0x6060, /* pin 13 = 1, pin 14 = 1 */
2254 .gpio0 = 0x0400, /* pin 2 = 0 */
2255 .gpio1 = 0x6060, /* pin 13 = 1, pin 14 = 1 */
2260 .gpio0 = 0x0400, /* pin 2 = 0 */
2261 .gpio1 = 0x6000, /* pin 13 = 0, pin 14 = 0 */
2283 .gpio0 = 0x0403,
2290 .gpio0 = 0x0403,
2297 .gpio0 = 0x0403, /* was 0x0407 */
2304 .gpio0 = 0x0403, /* was 0x0407 */
2311 .gpio0 = 0x0403,
2319 .name = "Prof 7301 DVB-S/S2",
2331 .name = "Twinhan VP-1027 DVB-S",
2344 /* ------------------------------------------------------------------ */
2446 .subdevice = 0x3000, /* HD-3000 card */
2544 /* Re-branded DViCO: DigitalNow DVB-T Dual */
2549 /* Re-branded DViCO: UltraView DVB-T Plus */
2620 .subdevice = 0xc111, /* AverMedia M150-D */
2665 .subdevice = 0x0341, /* ADS Tech InstantTV DVB-S */
2869 core->board.tuner_type = TUNER_PHILIPS_FM1236_MK3; in leadtek_eeprom()
2872 core->board.tuner_type = TUNER_PHILIPS_FM1216ME_MK3; in leadtek_eeprom()
2877 core->board.tuner_type, eeprom_data[0]); in leadtek_eeprom()
2885 core->board.tuner_type = tv.tuner_type; in hauppauge_eeprom()
2886 core->tuner_formats = tv.tuner_formats; in hauppauge_eeprom()
2887 core->board.radio.type = tv.has_radio ? CX88_RADIO : 0; in hauppauge_eeprom()
2888 core->model = tv.model; in hauppauge_eeprom()
2892 case 14009: /* WinTV-HVR3000 (Retail, IR, b/panel video, 3.5mm audio in) */ in hauppauge_eeprom()
2893 case 14019: /* WinTV-HVR3000 (Retail, IR Blaster, b/panel video, 3.5mm audio in) */ in hauppauge_eeprom()
2894 case 14029: /* WinTV-HVR3000 (Retail, IR, b/panel video, 3.5mm audio in - 880 bridge) */ in hauppauge_eeprom()
2895 case 14109: /* WinTV-HVR3000 (Retail, IR, b/panel video, 3.5mm audio in - low profile) */ in hauppauge_eeprom()
2896 case 14129: /* WinTV-HVR3000 (Retail, IR, b/panel video, 3.5mm audio in - 880 bridge - LP) */ in hauppauge_eeprom()
2897 case 14559: /* WinTV-HVR3000 (OEM, no IR, b/panel video, 3.5mm audio in) */ in hauppauge_eeprom()
2898 case 14569: /* WinTV-HVR3000 (OEM, no IR, no back panel video) */ in hauppauge_eeprom()
2899 case 14659: /* WinTV-HVR3000 (OEM, no IR, b/panel video, RCA audio in - Low profile) */ in hauppauge_eeprom()
2900 case 14669: /* WinTV-HVR3000 (OEM, no IR, no b/panel video - Low profile) */ in hauppauge_eeprom()
2901 case 28552: /* WinTV-PVR 'Roslyn' (No IR) */ in hauppauge_eeprom()
2902 case 34519: /* WinTV-PCI-FM */ in hauppauge_eeprom()
2904 /* WinTV-HVR4000 (DVBS/S2/T, Video and IR, back panel inputs) */ in hauppauge_eeprom()
2905 case 69100: /* WinTV-HVR4000LITE (DVBS/S2, IR) */ in hauppauge_eeprom()
2906 case 69500: /* WinTV-HVR4000LITE (DVBS/S2, No IR) */ in hauppauge_eeprom()
2908 /* WinTV-HVR4000 (DVBS/S2/T, Video no IR, back panel inputs) */ in hauppauge_eeprom()
2909 case 69569: /* WinTV-HVR4000 (DVBS/S2/T, Video no IR) */ in hauppauge_eeprom()
2910 case 90002: /* Nova-T-PCI (9002) */ in hauppauge_eeprom()
2911 case 92001: /* Nova-S-Plus (Video and IR) */ in hauppauge_eeprom()
2912 case 92002: /* Nova-S-Plus (Video and IR) */ in hauppauge_eeprom()
2913 case 90003: /* Nova-T-PCI (9002 No RF out) */ in hauppauge_eeprom()
2914 case 90500: /* Nova-T-PCI (oem) */ in hauppauge_eeprom()
2915 case 90501: /* Nova-T-PCI (oem/IR) */ in hauppauge_eeprom()
2916 case 92000: /* Nova-SE2 (OEM, No Video or IR) */ in hauppauge_eeprom()
2917 case 92900: /* WinTV-IROnly (No analog or digital Video inputs) */ in hauppauge_eeprom()
2918 case 94009: /* WinTV-HVR1100 (Video and IR Retail) */ in hauppauge_eeprom()
2919 case 94501: /* WinTV-HVR1100 (Video and IR OEM) */ in hauppauge_eeprom()
2920 case 96009: /* WinTV-HVR1300 (PAL Video, MPEG Video and IR RX) */ in hauppauge_eeprom()
2921 case 96019: /* WinTV-HVR1300 (PAL Video, MPEG Video and IR RX/TX) */ in hauppauge_eeprom()
2922 case 96559: /* WinTV-HVR1300 (PAL Video, MPEG Video no IR) */ in hauppauge_eeprom()
2923 case 96569: /* WinTV-HVR1300 () */ in hauppauge_eeprom()
2924 case 96659: /* WinTV-HVR1300 () */ in hauppauge_eeprom()
2925 case 98559: /* WinTV-HVR1100LP (Video no IR, Retail - Low Profile) */ in hauppauge_eeprom()
2986 core->board.tuner_type = gdi_tuner[eeprom_data[0x0d]].id; in gdi_eeprom()
2987 core->board.radio.type = gdi_tuner[eeprom_data[0x0d]].fm ? in gdi_eeprom()
2999 switch (core->boardnr) { in cx88_dvico_xc2028_callback()
3001 /* GPIO-4 xc3028 tuner */ in cx88_dvico_xc2028_callback()
3016 return -EINVAL; in cx88_dvico_xc2028_callback()
3031 switch (INPUT(core->input).type) { in cx88_xc3028_geniatech_tuner_callback()
3050 return -EINVAL; in cx88_xc3028_geniatech_tuner_callback()
3067 return -EINVAL; in cx88_xc3028_winfast1800h_callback()
3084 return -EINVAL; in cx88_xc4000_winfast2000h_plus_callback()
3102 return -EINVAL; in cx88_pv_8000gt_callback()
3135 err = i2c_transfer(&core->i2c_adap, &msg, 1); in dvico_fusionhdtv_hybrid_init()
3147 /* Board-specific callbacks */ in cx88_xc2028_tuner_callback()
3148 switch (core->boardnr) { in cx88_xc2028_tuner_callback()
3168 switch (INPUT(core->input).type) { in cx88_xc2028_tuner_callback()
3189 return -EINVAL; in cx88_xc2028_tuner_callback()
3195 /* Board-specific callbacks */ in cx88_xc4000_tuner_callback()
3196 switch (core->boardnr) { in cx88_xc4000_tuner_callback()
3204 return -EINVAL; in cx88_xc4000_tuner_callback()
3210 * analog tuner attach (tuner-core.c) and dvb tuner attach (cx88-dvb.c)
3215 switch (core->boardnr) { in cx88_xc5000_tuner_callback()
3220 * djh - According to the engineer at PCTV Systems, in cx88_xc5000_tuner_callback()
3221 * the xc5000 reset pin is supposed to be on GPIO12. in cx88_xc5000_tuner_callback()
3240 return -EINVAL; in cx88_xc5000_tuner_callback()
3250 return -EINVAL; in cx88_xc5000_tuner_callback()
3261 pr_err("Error - i2c private data undefined.\n"); in cx88_tuner_callback()
3262 return -EINVAL; in cx88_tuner_callback()
3265 core = i2c_algo->data; in cx88_tuner_callback()
3268 pr_err("Error - device struct undefined.\n"); in cx88_tuner_callback()
3269 return -EINVAL; in cx88_tuner_callback()
3273 return -EINVAL; in cx88_tuner_callback()
3275 switch (core->board.tuner_type) { in cx88_tuner_callback()
3287 core->board.tuner_type); in cx88_tuner_callback()
3288 return -EINVAL; in cx88_tuner_callback()
3292 /* ----------------------------------------------------------------------- */
3298 if (!pci->subsystem_vendor && !pci->subsystem_device) { in cx88_card_list()
3311 pr_err(" card=%d -> %s\n", i, cx88_boards[i].name); in cx88_card_list()
3316 switch (core->boardnr) { in cx88_card_setup_pre_i2c()
3354 cx_write(MO_GP0_IO, core->board.input[0].gpio0); in cx88_card_setup_pre_i2c()
3386 * Sets board-dependent xc3028 configuration
3392 ctl->fname = XC2028_DEFAULT_FIRMWARE; in cx88_setup_xc3028()
3393 ctl->max_len = 64; in cx88_setup_xc3028()
3395 switch (core->boardnr) { in cx88_setup_xc3028()
3398 if (core->i2c_algo.udelay < 16) in cx88_setup_xc3028()
3399 core->i2c_algo.udelay = 16; in cx88_setup_xc3028()
3403 ctl->demod = XC3028_FE_ZARLINK456; in cx88_setup_xc3028()
3407 ctl->demod = XC3028_FE_OREN538; in cx88_setup_xc3028()
3417 ctl->disable_power_mgmt = 1; in cx88_setup_xc3028()
3420 ctl->demod = XC3028_FE_ZARLINK456; in cx88_setup_xc3028()
3421 ctl->fname = XC3028L_DEFAULT_FIRMWARE; in cx88_setup_xc3028()
3422 ctl->read_not_reliable = 1; in cx88_setup_xc3028()
3428 * Those boards uses non-MTS firmware in cx88_setup_xc3028()
3433 ctl->demod = XC3028_FE_ZARLINK456; in cx88_setup_xc3028()
3434 ctl->mts = 1; in cx88_setup_xc3028()
3437 ctl->demod = XC3028_FE_OREN538; in cx88_setup_xc3028()
3438 ctl->mts = 1; in cx88_setup_xc3028()
3451 if (!core->i2c_rc) { in cx88_card_setup()
3452 core->i2c_client.addr = 0xa0 >> 1; in cx88_card_setup()
3453 tveeprom_read(&core->i2c_client, eeprom, sizeof(eeprom)); in cx88_card_setup()
3456 switch (core->boardnr) { in cx88_card_setup()
3459 if (!core->i2c_rc) in cx88_card_setup()
3463 if (!core->i2c_rc) in cx88_card_setup()
3469 if (!core->i2c_rc) in cx88_card_setup()
3482 if (!core->i2c_rc) in cx88_card_setup()
3490 /* GPIO0:0 is hooked to demod reset */ in cx88_card_setup()
3491 /* GPIO0:4 is hooked to xc3028 reset */ in cx88_card_setup()
3497 /* GPIO0:6 is hooked to FX2 reset pin */ in cx88_card_setup()
3506 /* GPIO0:0 is hooked to mt352 reset pin */ in cx88_card_setup()
3511 if (!core->i2c_rc && in cx88_card_setup()
3512 core->boardnr == CX88_BOARD_DVICO_FUSIONHDTV_DVB_T_HYBRID) in cx88_card_setup()
3528 if (!core->i2c_rc) { in cx88_card_setup()
3538 core->i2c_client.addr = 0x0a; in cx88_card_setup()
3541 if (i2c_master_send(&core->i2c_client, in cx88_card_setup()
3587 if (core->board.radio_type != UNSET) { in cx88_card_setup()
3589 tun_setup.type = core->board.radio_type; in cx88_card_setup()
3590 tun_setup.addr = core->board.radio_addr; in cx88_card_setup()
3596 if (core->board.tuner_type != UNSET) { in cx88_card_setup()
3598 tun_setup.type = core->board.tuner_type; in cx88_card_setup()
3599 tun_setup.addr = core->board.tuner_addr; in cx88_card_setup()
3605 if (core->board.tda9887_conf) { in cx88_card_setup()
3609 tda9887_cfg.priv = &core->board.tda9887_conf; in cx88_card_setup()
3614 if (core->board.tuner_type == TUNER_XC2028) { in cx88_card_setup()
3618 /* Fills device-dependent initialization parameters */ in cx88_card_setup()
3632 /* ------------------------------------------------------------------ */
3642 pr_info("quirk: PCIPCI_TRITON -- set TBFX\n"); in cx88_pci_quirks()
3646 pr_info("quirk: PCIPCI_NATOMA -- set TBFX\n"); in cx88_pci_quirks()
3650 pr_info("quirk: PCIPCI_VIAETBF -- set TBFX\n"); in cx88_pci_quirks()
3654 pr_info("quirk: PCIPCI_VSFX -- set VSFX\n"); in cx88_pci_quirks()
3659 pr_info("quirk: PCIPCI_ALIMAGIK -- latency fixup\n"); in cx88_pci_quirks()
3685 core->name)) in cx88_get_resources()
3688 PCI_FUNC(pci->devfn), in cx88_get_resources()
3690 pci->subsystem_vendor, pci->subsystem_device); in cx88_get_resources()
3691 return -EBUSY; in cx88_get_resources()
3707 refcount_set(&core->refcount, 1); in cx88_core_create()
3708 core->pci_bus = pci->bus->number; in cx88_core_create()
3709 core->pci_slot = PCI_SLOT(pci->devfn); in cx88_core_create()
3710 core->pci_irqmask = PCI_INT_RISC_RD_BERRINT | PCI_INT_RISC_WR_BERRINT | in cx88_core_create()
3713 mutex_init(&core->lock); in cx88_core_create()
3715 core->nr = nr; in cx88_core_create()
3716 sprintf(core->name, "cx88[%d]", core->nr); in cx88_core_create()
3724 core->tvnorm = 0; in cx88_core_create()
3726 core->width = 320; in cx88_core_create()
3727 core->height = 240; in cx88_core_create()
3728 core->field = V4L2_FIELD_INTERLACED; in cx88_core_create()
3730 strscpy(core->v4l2_dev.name, core->name, sizeof(core->v4l2_dev.name)); in cx88_core_create()
3731 if (v4l2_device_register(NULL, &core->v4l2_dev)) { in cx88_core_create()
3736 if (v4l2_ctrl_handler_init(&core->video_hdl, 13)) { in cx88_core_create()
3737 v4l2_device_unregister(&core->v4l2_dev); in cx88_core_create()
3742 if (v4l2_ctrl_handler_init(&core->audio_hdl, 13)) { in cx88_core_create()
3743 v4l2_ctrl_handler_free(&core->video_hdl); in cx88_core_create()
3744 v4l2_device_unregister(&core->v4l2_dev); in cx88_core_create()
3750 v4l2_ctrl_handler_free(&core->video_hdl); in cx88_core_create()
3751 v4l2_ctrl_handler_free(&core->audio_hdl); in cx88_core_create()
3752 v4l2_device_unregister(&core->v4l2_dev); in cx88_core_create()
3758 cx88_pci_quirks(core->name, pci); in cx88_core_create()
3759 core->lmmio = ioremap(pci_resource_start(pci, 0), in cx88_core_create()
3761 core->bmmio = (u8 __iomem *)core->lmmio; in cx88_core_create()
3763 if (!core->lmmio) { in cx88_core_create()
3766 v4l2_ctrl_handler_free(&core->video_hdl); in cx88_core_create()
3767 v4l2_ctrl_handler_free(&core->audio_hdl); in cx88_core_create()
3768 v4l2_device_unregister(&core->v4l2_dev); in cx88_core_create()
3774 core->boardnr = UNSET; in cx88_core_create()
3775 if (card[core->nr] < ARRAY_SIZE(cx88_boards)) in cx88_core_create()
3776 core->boardnr = card[core->nr]; in cx88_core_create()
3777 for (i = 0; core->boardnr == UNSET && i < ARRAY_SIZE(cx88_subids); i++) in cx88_core_create()
3778 if (pci->subsystem_vendor == cx88_subids[i].subvendor && in cx88_core_create()
3779 pci->subsystem_device == cx88_subids[i].subdevice) in cx88_core_create()
3780 core->boardnr = cx88_subids[i].card; in cx88_core_create()
3781 if (core->boardnr == UNSET) { in cx88_core_create()
3782 core->boardnr = CX88_BOARD_UNKNOWN; in cx88_core_create()
3786 core->board = cx88_boards[core->boardnr]; in cx88_core_create()
3788 if (!core->board.num_frontends && (core->board.mpeg & CX88_MPEG_DVB)) in cx88_core_create()
3789 core->board.num_frontends = 1; in cx88_core_create()
3792 pci->subsystem_vendor, pci->subsystem_device, core->board.name, in cx88_core_create()
3793 core->boardnr, card[core->nr] == core->boardnr ? in cx88_core_create()
3795 core->board.num_frontends); in cx88_core_create()
3797 if (tuner[core->nr] != UNSET) in cx88_core_create()
3798 core->board.tuner_type = tuner[core->nr]; in cx88_core_create()
3799 if (radio[core->nr] != UNSET) in cx88_core_create()
3800 core->board.radio_type = radio[core->nr]; in cx88_core_create()
3803 core->board.tuner_type, core->board.radio_type); in cx88_core_create()
3811 if (core->board.tuner_type != UNSET) { in cx88_core_create()
3823 int has_demod = (core->board.tda9887_conf & TDA9887_PRESENT); in cx88_core_create()
3831 v4l2_i2c_new_subdev(&core->v4l2_dev, &core->i2c_adap, in cx88_core_create()
3835 v4l2_i2c_new_subdev(&core->v4l2_dev, in cx88_core_create()
3836 &core->i2c_adap, "tuner", in cx88_core_create()
3838 if (core->board.tuner_addr == ADDR_UNSET) { in cx88_core_create()
3839 v4l2_i2c_new_subdev(&core->v4l2_dev, in cx88_core_create()
3840 &core->i2c_adap, "tuner", in cx88_core_create()
3843 v4l2_i2c_new_subdev(&core->v4l2_dev, &core->i2c_adap, in cx88_core_create()
3844 "tuner", core->board.tuner_addr, in cx88_core_create()