| Mike Isely | 989eb15 | 2007-11-26 01:53:12 -0300 | [diff] [blame] | 1 | /* | 
|  | 2 | * | 
| Mike Isely | 989eb15 | 2007-11-26 01:53:12 -0300 | [diff] [blame] | 3 | * | 
|  | 4 | *  Copyright (C) 2007 Mike Isely <isely@pobox.com> | 
|  | 5 | * | 
|  | 6 | *  This program is free software; you can redistribute it and/or modify | 
|  | 7 | *  it under the terms of the GNU General Public License as published by | 
|  | 8 | *  the Free Software Foundation; either version 2 of the License | 
|  | 9 | * | 
|  | 10 | *  This program is distributed in the hope that it will be useful, | 
|  | 11 | *  but WITHOUT ANY WARRANTY; without even the implied warranty of | 
|  | 12 | *  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the | 
|  | 13 | *  GNU General Public License for more details. | 
|  | 14 | * | 
|  | 15 | *  You should have received a copy of the GNU General Public License | 
|  | 16 | *  along with this program; if not, write to the Free Software | 
|  | 17 | *  Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA | 
|  | 18 | * | 
|  | 19 | */ | 
|  | 20 |  | 
|  | 21 | /* | 
|  | 22 |  | 
|  | 23 | This source file should encompass ALL per-device type information for the | 
|  | 24 | driver.  To define a new device, add elements to the pvr2_device_table and | 
|  | 25 | pvr2_device_desc structures. | 
|  | 26 |  | 
|  | 27 | */ | 
|  | 28 |  | 
|  | 29 | #include "pvrusb2-devattr.h" | 
|  | 30 | #include <linux/usb.h> | 
| Mike Isely | 6a54025 | 2007-12-02 23:51:34 -0300 | [diff] [blame] | 31 | /* This is needed in order to pull in tuner type ids... */ | 
| Mike Isely | 9e2e3ae | 2007-11-26 02:14:23 -0300 | [diff] [blame] | 32 | #include <linux/i2c.h> | 
| Mike Isely | 9e2e3ae | 2007-11-26 02:14:23 -0300 | [diff] [blame] | 33 | #include <media/tuner.h> | 
| Michael Krufky | 906a495 | 2008-03-28 05:47:47 -0300 | [diff] [blame] | 34 | #ifdef CONFIG_VIDEO_PVRUSB2_DVB | 
|  | 35 | #include "pvrusb2-hdw-internal.h" | 
|  | 36 | #include "lgdt330x.h" | 
| Michael Krufky | 087886e | 2008-03-28 05:49:36 -0300 | [diff] [blame] | 37 | #include "s5h1409.h" | 
| Michael Krufky | 4aef8fd | 2008-04-25 04:19:02 -0300 | [diff] [blame] | 38 | #include "s5h1411.h" | 
| Michael Krufky | 95814bc | 2008-04-19 15:36:51 -0300 | [diff] [blame] | 39 | #include "tda10048.h" | 
| Michael Krufky | 087886e | 2008-03-28 05:49:36 -0300 | [diff] [blame] | 40 | #include "tda18271.h" | 
|  | 41 | #include "tda8290.h" | 
| Michael Krufky | 906a495 | 2008-03-28 05:47:47 -0300 | [diff] [blame] | 42 | #include "tuner-simple.h" | 
|  | 43 | #endif | 
| Mike Isely | 989eb15 | 2007-11-26 01:53:12 -0300 | [diff] [blame] | 44 |  | 
| Mike Isely | 4542783 | 2007-12-08 17:11:13 -0300 | [diff] [blame] | 45 |  | 
| Mike Isely | d130fa8 | 2007-12-08 17:20:06 -0300 | [diff] [blame] | 46 | /*------------------------------------------------------------------------*/ | 
|  | 47 | /* Hauppauge PVR-USB2 Model 29xxx */ | 
| Mike Isely | 989eb15 | 2007-11-26 01:53:12 -0300 | [diff] [blame] | 48 |  | 
| Mike Isely | dd5f322 | 2009-03-07 02:07:12 -0300 | [diff] [blame] | 49 | static const struct pvr2_device_client_desc pvr2_cli_29xxx[] = { | 
|  | 50 | { .module_id = PVR2_CLIENT_ID_SAA7115 }, | 
|  | 51 | { .module_id = PVR2_CLIENT_ID_MSP3400 }, | 
|  | 52 | { .module_id = PVR2_CLIENT_ID_TUNER }, | 
| Mike Isely | bb65242 | 2009-03-14 14:09:04 -0300 | [diff] [blame] | 53 | { .module_id = PVR2_CLIENT_ID_DEMOD }, | 
| Mike Isely | 989eb15 | 2007-11-26 01:53:12 -0300 | [diff] [blame] | 54 | }; | 
|  | 55 |  | 
| Mike Isely | 989eb15 | 2007-11-26 01:53:12 -0300 | [diff] [blame] | 56 | static const char *pvr2_fw1_names_29xxx[] = { | 
|  | 57 | "v4l-pvrusb2-29xxx-01.fw", | 
|  | 58 | }; | 
|  | 59 |  | 
| Mike Isely | d130fa8 | 2007-12-08 17:20:06 -0300 | [diff] [blame] | 60 | static const struct pvr2_device_desc pvr2_device_29xxx = { | 
| Mike Isely | 1d70c7f | 2009-11-25 02:55:38 -0300 | [diff] [blame] | 61 | .description = "WinTV PVR USB2 Model 29xxx", | 
| Mike Isely | 989eb15 | 2007-11-26 01:53:12 -0300 | [diff] [blame] | 62 | .shortname = "29xxx", | 
| Mike Isely | dd5f322 | 2009-03-07 02:07:12 -0300 | [diff] [blame] | 63 | .client_table.lst = pvr2_cli_29xxx, | 
|  | 64 | .client_table.cnt = ARRAY_SIZE(pvr2_cli_29xxx), | 
| Mike Isely | 989eb15 | 2007-11-26 01:53:12 -0300 | [diff] [blame] | 65 | .fx2_firmware.lst = pvr2_fw1_names_29xxx, | 
|  | 66 | .fx2_firmware.cnt = ARRAY_SIZE(pvr2_fw1_names_29xxx), | 
| Mike Isely | aaf7884 | 2007-11-26 02:04:11 -0300 | [diff] [blame] | 67 | .flag_has_hauppauge_rom = !0, | 
| Mike Isely | 1aaac60 | 2008-04-22 14:45:36 -0300 | [diff] [blame] | 68 | .flag_has_analogtuner = !0, | 
| Mike Isely | d068c6e | 2008-04-22 14:45:36 -0300 | [diff] [blame] | 69 | .flag_has_fmradio = !0, | 
| Mike Isely | 1aaac60 | 2008-04-22 14:45:36 -0300 | [diff] [blame] | 70 | .flag_has_composite = !0, | 
|  | 71 | .flag_has_svideo = !0, | 
| Mike Isely | f5174af | 2007-11-26 02:07:26 -0300 | [diff] [blame] | 72 | .signal_routing_scheme = PVR2_ROUTING_SCHEME_HAUPPAUGE, | 
| Mike Isely | 40381cb | 2008-04-22 14:45:42 -0300 | [diff] [blame] | 73 | .led_scheme = PVR2_LED_SCHEME_HAUPPAUGE, | 
| Mike Isely | 27eab38 | 2009-04-06 01:51:38 -0300 | [diff] [blame] | 74 | .ir_scheme = PVR2_IR_SCHEME_29XXX, | 
| Mike Isely | d130fa8 | 2007-12-08 17:20:06 -0300 | [diff] [blame] | 75 | }; | 
|  | 76 |  | 
|  | 77 |  | 
|  | 78 |  | 
|  | 79 | /*------------------------------------------------------------------------*/ | 
|  | 80 | /* Hauppauge PVR-USB2 Model 24xxx */ | 
|  | 81 |  | 
| Mike Isely | dd5f322 | 2009-03-07 02:07:12 -0300 | [diff] [blame] | 82 | static const struct pvr2_device_client_desc pvr2_cli_24xxx[] = { | 
|  | 83 | { .module_id = PVR2_CLIENT_ID_CX25840 }, | 
|  | 84 | { .module_id = PVR2_CLIENT_ID_TUNER }, | 
|  | 85 | { .module_id = PVR2_CLIENT_ID_WM8775 }, | 
| Mike Isely | bb65242 | 2009-03-14 14:09:04 -0300 | [diff] [blame] | 86 | { .module_id = PVR2_CLIENT_ID_DEMOD }, | 
| Mike Isely | d130fa8 | 2007-12-08 17:20:06 -0300 | [diff] [blame] | 87 | }; | 
|  | 88 |  | 
|  | 89 | static const char *pvr2_fw1_names_24xxx[] = { | 
|  | 90 | "v4l-pvrusb2-24xxx-01.fw", | 
|  | 91 | }; | 
|  | 92 |  | 
|  | 93 | static const struct pvr2_device_desc pvr2_device_24xxx = { | 
| Mike Isely | 1d70c7f | 2009-11-25 02:55:38 -0300 | [diff] [blame] | 94 | .description = "WinTV PVR USB2 Model 24xxx", | 
| Mike Isely | 989eb15 | 2007-11-26 01:53:12 -0300 | [diff] [blame] | 95 | .shortname = "24xxx", | 
| Mike Isely | dd5f322 | 2009-03-07 02:07:12 -0300 | [diff] [blame] | 96 | .client_table.lst = pvr2_cli_24xxx, | 
|  | 97 | .client_table.cnt = ARRAY_SIZE(pvr2_cli_24xxx), | 
| Mike Isely | 989eb15 | 2007-11-26 01:53:12 -0300 | [diff] [blame] | 98 | .fx2_firmware.lst = pvr2_fw1_names_24xxx, | 
|  | 99 | .fx2_firmware.cnt = ARRAY_SIZE(pvr2_fw1_names_24xxx), | 
|  | 100 | .flag_has_cx25840 = !0, | 
|  | 101 | .flag_has_wm8775 = !0, | 
| Mike Isely | aaf7884 | 2007-11-26 02:04:11 -0300 | [diff] [blame] | 102 | .flag_has_hauppauge_rom = !0, | 
| Mike Isely | 1aaac60 | 2008-04-22 14:45:36 -0300 | [diff] [blame] | 103 | .flag_has_analogtuner = !0, | 
| Mike Isely | d068c6e | 2008-04-22 14:45:36 -0300 | [diff] [blame] | 104 | .flag_has_fmradio = !0, | 
| Mike Isely | 1aaac60 | 2008-04-22 14:45:36 -0300 | [diff] [blame] | 105 | .flag_has_composite = !0, | 
|  | 106 | .flag_has_svideo = !0, | 
| Mike Isely | f5174af | 2007-11-26 02:07:26 -0300 | [diff] [blame] | 107 | .signal_routing_scheme = PVR2_ROUTING_SCHEME_HAUPPAUGE, | 
| Mike Isely | 40381cb | 2008-04-22 14:45:42 -0300 | [diff] [blame] | 108 | .led_scheme = PVR2_LED_SCHEME_HAUPPAUGE, | 
| Mike Isely | 31335b1 | 2008-07-25 19:35:31 -0300 | [diff] [blame] | 109 | .ir_scheme = PVR2_IR_SCHEME_24XXX, | 
| Mike Isely | d130fa8 | 2007-12-08 17:20:06 -0300 | [diff] [blame] | 110 | }; | 
|  | 111 |  | 
|  | 112 |  | 
|  | 113 |  | 
|  | 114 | /*------------------------------------------------------------------------*/ | 
|  | 115 | /* GOTVIEW USB2.0 DVD2 */ | 
|  | 116 |  | 
| Mike Isely | dd5f322 | 2009-03-07 02:07:12 -0300 | [diff] [blame] | 117 | static const struct pvr2_device_client_desc pvr2_cli_gotview_2[] = { | 
|  | 118 | { .module_id = PVR2_CLIENT_ID_CX25840 }, | 
|  | 119 | { .module_id = PVR2_CLIENT_ID_TUNER }, | 
| Mike Isely | c641a18 | 2010-05-15 00:07:04 -0300 | [diff] [blame] | 120 | { .module_id = PVR2_CLIENT_ID_DEMOD }, | 
| Mike Isely | d130fa8 | 2007-12-08 17:20:06 -0300 | [diff] [blame] | 121 | }; | 
|  | 122 |  | 
|  | 123 | static const struct pvr2_device_desc pvr2_device_gotview_2 = { | 
| Mike Isely | 9e2e3ae | 2007-11-26 02:14:23 -0300 | [diff] [blame] | 124 | .description = "Gotview USB 2.0 DVD 2", | 
|  | 125 | .shortname = "gv2", | 
| Mike Isely | dd5f322 | 2009-03-07 02:07:12 -0300 | [diff] [blame] | 126 | .client_table.lst = pvr2_cli_gotview_2, | 
|  | 127 | .client_table.cnt = ARRAY_SIZE(pvr2_cli_gotview_2), | 
| Mike Isely | 787f5ab | 2007-12-08 17:08:32 -0300 | [diff] [blame] | 128 | .flag_has_cx25840 = !0, | 
| Mike Isely | 9e2e3ae | 2007-11-26 02:14:23 -0300 | [diff] [blame] | 129 | .default_tuner_type = TUNER_PHILIPS_FM1216ME_MK3, | 
| Mike Isely | 1aaac60 | 2008-04-22 14:45:36 -0300 | [diff] [blame] | 130 | .flag_has_analogtuner = !0, | 
| Mike Isely | 1df59f0 | 2008-04-21 03:50:39 -0300 | [diff] [blame] | 131 | .flag_has_fmradio = !0, | 
| Mike Isely | 1aaac60 | 2008-04-22 14:45:36 -0300 | [diff] [blame] | 132 | .flag_has_composite = !0, | 
|  | 133 | .flag_has_svideo = !0, | 
| Mike Isely | 9e2e3ae | 2007-11-26 02:14:23 -0300 | [diff] [blame] | 134 | .signal_routing_scheme = PVR2_ROUTING_SCHEME_GOTVIEW, | 
| Mike Isely | 989eb15 | 2007-11-26 01:53:12 -0300 | [diff] [blame] | 135 | }; | 
|  | 136 |  | 
| Mike Isely | d130fa8 | 2007-12-08 17:20:06 -0300 | [diff] [blame] | 137 |  | 
|  | 138 |  | 
| Mike Isely | fd1da78 | 2008-04-22 14:45:42 -0300 | [diff] [blame] | 139 | /*------------------------------------------------------------------------*/ | 
|  | 140 | /* GOTVIEW USB2.0 DVD Deluxe */ | 
|  | 141 |  | 
|  | 142 | /* (same module list as gotview_2) */ | 
|  | 143 |  | 
|  | 144 | static const struct pvr2_device_desc pvr2_device_gotview_2d = { | 
|  | 145 | .description = "Gotview USB 2.0 DVD Deluxe", | 
|  | 146 | .shortname = "gv2d", | 
| Mike Isely | dd5f322 | 2009-03-07 02:07:12 -0300 | [diff] [blame] | 147 | .client_table.lst = pvr2_cli_gotview_2, | 
|  | 148 | .client_table.cnt = ARRAY_SIZE(pvr2_cli_gotview_2), | 
| Mike Isely | fd1da78 | 2008-04-22 14:45:42 -0300 | [diff] [blame] | 149 | .flag_has_cx25840 = !0, | 
|  | 150 | .default_tuner_type = TUNER_PHILIPS_FM1216ME_MK3, | 
|  | 151 | .flag_has_analogtuner = !0, | 
|  | 152 | .flag_has_composite = !0, | 
|  | 153 | .flag_has_svideo = !0, | 
|  | 154 | .signal_routing_scheme = PVR2_ROUTING_SCHEME_GOTVIEW, | 
|  | 155 | }; | 
|  | 156 |  | 
|  | 157 |  | 
|  | 158 |  | 
| Mike Isely | d130fa8 | 2007-12-08 17:20:06 -0300 | [diff] [blame] | 159 | /*------------------------------------------------------------------------*/ | 
|  | 160 | /* OnAir Creator */ | 
|  | 161 |  | 
| Michael Krufky | 906a495 | 2008-03-28 05:47:47 -0300 | [diff] [blame] | 162 | #ifdef CONFIG_VIDEO_PVRUSB2_DVB | 
|  | 163 | static struct lgdt330x_config pvr2_lgdt3303_config = { | 
|  | 164 | .demod_address       = 0x0e, | 
|  | 165 | .demod_chip          = LGDT3303, | 
|  | 166 | .clock_polarity_flip = 1, | 
|  | 167 | }; | 
|  | 168 |  | 
|  | 169 | static int pvr2_lgdt3303_attach(struct pvr2_dvb_adapter *adap) | 
|  | 170 | { | 
|  | 171 | adap->fe = dvb_attach(lgdt330x_attach, &pvr2_lgdt3303_config, | 
|  | 172 | &adap->channel.hdw->i2c_adap); | 
|  | 173 | if (adap->fe) | 
|  | 174 | return 0; | 
|  | 175 |  | 
|  | 176 | return -EIO; | 
|  | 177 | } | 
|  | 178 |  | 
|  | 179 | static int pvr2_lgh06xf_attach(struct pvr2_dvb_adapter *adap) | 
|  | 180 | { | 
|  | 181 | dvb_attach(simple_tuner_attach, adap->fe, | 
|  | 182 | &adap->channel.hdw->i2c_adap, 0x61, | 
|  | 183 | TUNER_LG_TDVS_H06XF); | 
|  | 184 |  | 
|  | 185 | return 0; | 
|  | 186 | } | 
|  | 187 |  | 
| Mike Isely | 69ea3c1 | 2009-03-07 02:08:58 -0300 | [diff] [blame] | 188 | static const struct pvr2_dvb_props pvr2_onair_creator_fe_props = { | 
| Michael Krufky | 906a495 | 2008-03-28 05:47:47 -0300 | [diff] [blame] | 189 | .frontend_attach = pvr2_lgdt3303_attach, | 
|  | 190 | .tuner_attach    = pvr2_lgh06xf_attach, | 
|  | 191 | }; | 
|  | 192 | #endif | 
|  | 193 |  | 
| Mike Isely | dd5f322 | 2009-03-07 02:07:12 -0300 | [diff] [blame] | 194 | static const struct pvr2_device_client_desc pvr2_cli_onair_creator[] = { | 
|  | 195 | { .module_id = PVR2_CLIENT_ID_SAA7115 }, | 
|  | 196 | { .module_id = PVR2_CLIENT_ID_CS53L32A }, | 
|  | 197 | { .module_id = PVR2_CLIENT_ID_TUNER }, | 
| Mike Isely | d130fa8 | 2007-12-08 17:20:06 -0300 | [diff] [blame] | 198 | }; | 
|  | 199 |  | 
|  | 200 | static const struct pvr2_device_desc pvr2_device_onair_creator = { | 
|  | 201 | .description = "OnAir Creator Hybrid USB tuner", | 
|  | 202 | .shortname = "oac", | 
| Mike Isely | dd5f322 | 2009-03-07 02:07:12 -0300 | [diff] [blame] | 203 | .client_table.lst = pvr2_cli_onair_creator, | 
|  | 204 | .client_table.cnt = ARRAY_SIZE(pvr2_cli_onair_creator), | 
| Mike Isely | d130fa8 | 2007-12-08 17:20:06 -0300 | [diff] [blame] | 205 | .default_tuner_type = TUNER_LG_TDVS_H06XF, | 
| Mike Isely | 1aaac60 | 2008-04-22 14:45:36 -0300 | [diff] [blame] | 206 | .flag_has_analogtuner = !0, | 
|  | 207 | .flag_has_composite = !0, | 
|  | 208 | .flag_has_svideo = !0, | 
| Mike Isely | 72998b7 | 2008-04-03 04:51:19 -0300 | [diff] [blame] | 209 | .flag_digital_requires_cx23416 = !0, | 
| Mike Isely | 2a6b627 | 2009-03-15 17:53:29 -0300 | [diff] [blame] | 210 | .signal_routing_scheme = PVR2_ROUTING_SCHEME_ONAIR, | 
| Mike Isely | e8f5bac | 2008-04-22 14:45:40 -0300 | [diff] [blame] | 211 | .digital_control_scheme = PVR2_DIGITAL_SCHEME_ONAIR, | 
| Michael Krufky | f0910c7 | 2008-04-22 14:45:45 -0300 | [diff] [blame] | 212 | .default_std_mask = V4L2_STD_NTSC_M, | 
| Michael Krufky | 906a495 | 2008-03-28 05:47:47 -0300 | [diff] [blame] | 213 | #ifdef CONFIG_VIDEO_PVRUSB2_DVB | 
|  | 214 | .dvb_props = &pvr2_onair_creator_fe_props, | 
|  | 215 | #endif | 
| Mike Isely | d130fa8 | 2007-12-08 17:20:06 -0300 | [diff] [blame] | 216 | }; | 
| Mike Isely | d130fa8 | 2007-12-08 17:20:06 -0300 | [diff] [blame] | 217 |  | 
|  | 218 |  | 
|  | 219 |  | 
| Mike Isely | d130fa8 | 2007-12-08 17:20:06 -0300 | [diff] [blame] | 220 | /*------------------------------------------------------------------------*/ | 
|  | 221 | /* OnAir USB 2.0 */ | 
|  | 222 |  | 
| Michael Krufky | 906a495 | 2008-03-28 05:47:47 -0300 | [diff] [blame] | 223 | #ifdef CONFIG_VIDEO_PVRUSB2_DVB | 
|  | 224 | static struct lgdt330x_config pvr2_lgdt3302_config = { | 
|  | 225 | .demod_address       = 0x0e, | 
|  | 226 | .demod_chip          = LGDT3302, | 
|  | 227 | }; | 
|  | 228 |  | 
|  | 229 | static int pvr2_lgdt3302_attach(struct pvr2_dvb_adapter *adap) | 
|  | 230 | { | 
|  | 231 | adap->fe = dvb_attach(lgdt330x_attach, &pvr2_lgdt3302_config, | 
|  | 232 | &adap->channel.hdw->i2c_adap); | 
|  | 233 | if (adap->fe) | 
|  | 234 | return 0; | 
|  | 235 |  | 
|  | 236 | return -EIO; | 
|  | 237 | } | 
|  | 238 |  | 
|  | 239 | static int pvr2_fcv1236d_attach(struct pvr2_dvb_adapter *adap) | 
|  | 240 | { | 
|  | 241 | dvb_attach(simple_tuner_attach, adap->fe, | 
|  | 242 | &adap->channel.hdw->i2c_adap, 0x61, | 
|  | 243 | TUNER_PHILIPS_FCV1236D); | 
|  | 244 |  | 
|  | 245 | return 0; | 
|  | 246 | } | 
|  | 247 |  | 
| Mike Isely | 69ea3c1 | 2009-03-07 02:08:58 -0300 | [diff] [blame] | 248 | static const struct pvr2_dvb_props pvr2_onair_usb2_fe_props = { | 
| Michael Krufky | 906a495 | 2008-03-28 05:47:47 -0300 | [diff] [blame] | 249 | .frontend_attach = pvr2_lgdt3302_attach, | 
|  | 250 | .tuner_attach    = pvr2_fcv1236d_attach, | 
|  | 251 | }; | 
|  | 252 | #endif | 
|  | 253 |  | 
| Mike Isely | dd5f322 | 2009-03-07 02:07:12 -0300 | [diff] [blame] | 254 | static const struct pvr2_device_client_desc pvr2_cli_onair_usb2[] = { | 
|  | 255 | { .module_id = PVR2_CLIENT_ID_SAA7115 }, | 
|  | 256 | { .module_id = PVR2_CLIENT_ID_CS53L32A }, | 
|  | 257 | { .module_id = PVR2_CLIENT_ID_TUNER }, | 
| Mike Isely | d130fa8 | 2007-12-08 17:20:06 -0300 | [diff] [blame] | 258 | }; | 
|  | 259 |  | 
|  | 260 | static const struct pvr2_device_desc pvr2_device_onair_usb2 = { | 
|  | 261 | .description = "OnAir USB2 Hybrid USB tuner", | 
|  | 262 | .shortname = "oa2", | 
| Mike Isely | dd5f322 | 2009-03-07 02:07:12 -0300 | [diff] [blame] | 263 | .client_table.lst = pvr2_cli_onair_usb2, | 
|  | 264 | .client_table.cnt = ARRAY_SIZE(pvr2_cli_onair_usb2), | 
| Michael Krufky | ab8b870 | 2008-04-22 14:46:05 -0300 | [diff] [blame] | 265 | .default_tuner_type = TUNER_PHILIPS_FCV1236D, | 
| Mike Isely | 1aaac60 | 2008-04-22 14:45:36 -0300 | [diff] [blame] | 266 | .flag_has_analogtuner = !0, | 
|  | 267 | .flag_has_composite = !0, | 
|  | 268 | .flag_has_svideo = !0, | 
| Mike Isely | 72998b7 | 2008-04-03 04:51:19 -0300 | [diff] [blame] | 269 | .flag_digital_requires_cx23416 = !0, | 
| Mike Isely | 2a6b627 | 2009-03-15 17:53:29 -0300 | [diff] [blame] | 270 | .signal_routing_scheme = PVR2_ROUTING_SCHEME_ONAIR, | 
| Mike Isely | e8f5bac | 2008-04-22 14:45:40 -0300 | [diff] [blame] | 271 | .digital_control_scheme = PVR2_DIGITAL_SCHEME_ONAIR, | 
| Michael Krufky | f0910c7 | 2008-04-22 14:45:45 -0300 | [diff] [blame] | 272 | .default_std_mask = V4L2_STD_NTSC_M, | 
| Michael Krufky | 906a495 | 2008-03-28 05:47:47 -0300 | [diff] [blame] | 273 | #ifdef CONFIG_VIDEO_PVRUSB2_DVB | 
|  | 274 | .dvb_props = &pvr2_onair_usb2_fe_props, | 
|  | 275 | #endif | 
| Mike Isely | d130fa8 | 2007-12-08 17:20:06 -0300 | [diff] [blame] | 276 | }; | 
| Mike Isely | d130fa8 | 2007-12-08 17:20:06 -0300 | [diff] [blame] | 277 |  | 
|  | 278 |  | 
|  | 279 |  | 
|  | 280 | /*------------------------------------------------------------------------*/ | 
| Michael Krufky | 92c9d07 | 2008-03-15 23:59:29 -0300 | [diff] [blame] | 281 | /* Hauppauge PVR-USB2 Model 73xxx */ | 
|  | 282 |  | 
| Michael Krufky | 95814bc | 2008-04-19 15:36:51 -0300 | [diff] [blame] | 283 | #ifdef CONFIG_VIDEO_PVRUSB2_DVB | 
|  | 284 | static struct tda10048_config hauppauge_tda10048_config = { | 
|  | 285 | .demod_address  = 0x10 >> 1, | 
|  | 286 | .output_mode    = TDA10048_PARALLEL_OUTPUT, | 
|  | 287 | .fwbulkwritelen = TDA10048_BULKWRITE_50, | 
|  | 288 | .inversion      = TDA10048_INVERSION_ON, | 
| Steven Toth | 08b8358 | 2009-05-15 21:04:56 -0300 | [diff] [blame] | 289 | .dtv6_if_freq_khz = TDA10048_IF_3300, | 
|  | 290 | .dtv7_if_freq_khz = TDA10048_IF_3800, | 
|  | 291 | .dtv8_if_freq_khz = TDA10048_IF_4300, | 
| Steven Toth | c747020 | 2009-05-02 11:09:08 -0300 | [diff] [blame] | 292 | .clk_freq_khz   = TDA10048_CLK_16000, | 
| Steven Toth | 507a34f | 2009-05-05 19:31:42 -0300 | [diff] [blame] | 293 | .disable_gate_access = 1, | 
| Michael Krufky | 95814bc | 2008-04-19 15:36:51 -0300 | [diff] [blame] | 294 | }; | 
|  | 295 |  | 
|  | 296 | static struct tda829x_config tda829x_no_probe = { | 
|  | 297 | .probe_tuner = TDA829X_DONT_PROBE, | 
|  | 298 | }; | 
|  | 299 |  | 
|  | 300 | static struct tda18271_config hauppauge_tda18271_dvb_config = { | 
|  | 301 | .gate    = TDA18271_GATE_ANALOG, | 
| Michael Krufky | a18eaf0 | 2009-08-29 17:47:01 -0300 | [diff] [blame] | 302 | .output_opt = TDA18271_OUTPUT_LT_OFF, | 
| Michael Krufky | 95814bc | 2008-04-19 15:36:51 -0300 | [diff] [blame] | 303 | }; | 
|  | 304 |  | 
|  | 305 | static int pvr2_tda10048_attach(struct pvr2_dvb_adapter *adap) | 
|  | 306 | { | 
|  | 307 | adap->fe = dvb_attach(tda10048_attach, &hauppauge_tda10048_config, | 
|  | 308 | &adap->channel.hdw->i2c_adap); | 
|  | 309 | if (adap->fe) | 
|  | 310 | return 0; | 
|  | 311 |  | 
|  | 312 | return -EIO; | 
|  | 313 | } | 
|  | 314 |  | 
|  | 315 | static int pvr2_73xxx_tda18271_8295_attach(struct pvr2_dvb_adapter *adap) | 
|  | 316 | { | 
|  | 317 | dvb_attach(tda829x_attach, adap->fe, | 
|  | 318 | &adap->channel.hdw->i2c_adap, 0x42, | 
|  | 319 | &tda829x_no_probe); | 
|  | 320 | dvb_attach(tda18271_attach, adap->fe, 0x60, | 
|  | 321 | &adap->channel.hdw->i2c_adap, | 
|  | 322 | &hauppauge_tda18271_dvb_config); | 
|  | 323 |  | 
|  | 324 | return 0; | 
|  | 325 | } | 
|  | 326 |  | 
| Mike Isely | 69ea3c1 | 2009-03-07 02:08:58 -0300 | [diff] [blame] | 327 | static const struct pvr2_dvb_props pvr2_73xxx_dvb_props = { | 
| Michael Krufky | 95814bc | 2008-04-19 15:36:51 -0300 | [diff] [blame] | 328 | .frontend_attach = pvr2_tda10048_attach, | 
|  | 329 | .tuner_attach    = pvr2_73xxx_tda18271_8295_attach, | 
|  | 330 | }; | 
|  | 331 | #endif | 
|  | 332 |  | 
| Mike Isely | dd5f322 | 2009-03-07 02:07:12 -0300 | [diff] [blame] | 333 | static const struct pvr2_device_client_desc pvr2_cli_73xxx[] = { | 
|  | 334 | { .module_id = PVR2_CLIENT_ID_CX25840 }, | 
|  | 335 | { .module_id = PVR2_CLIENT_ID_TUNER, | 
|  | 336 | .i2c_address_list = "\x42"}, | 
| Michael Krufky | 92c9d07 | 2008-03-15 23:59:29 -0300 | [diff] [blame] | 337 | }; | 
|  | 338 |  | 
|  | 339 | static const char *pvr2_fw1_names_73xxx[] = { | 
|  | 340 | "v4l-pvrusb2-73xxx-01.fw", | 
|  | 341 | }; | 
|  | 342 |  | 
|  | 343 | static const struct pvr2_device_desc pvr2_device_73xxx = { | 
| Mike Isely | 1d70c7f | 2009-11-25 02:55:38 -0300 | [diff] [blame] | 344 | .description = "WinTV HVR-1900 Model 73xxx", | 
| Michael Krufky | 92c9d07 | 2008-03-15 23:59:29 -0300 | [diff] [blame] | 345 | .shortname = "73xxx", | 
| Mike Isely | dd5f322 | 2009-03-07 02:07:12 -0300 | [diff] [blame] | 346 | .client_table.lst = pvr2_cli_73xxx, | 
|  | 347 | .client_table.cnt = ARRAY_SIZE(pvr2_cli_73xxx), | 
| Michael Krufky | 92c9d07 | 2008-03-15 23:59:29 -0300 | [diff] [blame] | 348 | .fx2_firmware.lst = pvr2_fw1_names_73xxx, | 
|  | 349 | .fx2_firmware.cnt = ARRAY_SIZE(pvr2_fw1_names_73xxx), | 
|  | 350 | .flag_has_cx25840 = !0, | 
|  | 351 | .flag_has_hauppauge_rom = !0, | 
|  | 352 | .flag_has_analogtuner = !0, | 
|  | 353 | .flag_has_composite = !0, | 
|  | 354 | .flag_has_svideo = !0, | 
| Gary Francis | 7572746 | 2009-11-25 03:03:31 -0300 | [diff] [blame] | 355 | .flag_fx2_16kb = !0, | 
| Michael Krufky | 92c9d07 | 2008-03-15 23:59:29 -0300 | [diff] [blame] | 356 | .signal_routing_scheme = PVR2_ROUTING_SCHEME_HAUPPAUGE, | 
|  | 357 | .digital_control_scheme = PVR2_DIGITAL_SCHEME_HAUPPAUGE, | 
|  | 358 | .led_scheme = PVR2_LED_SCHEME_HAUPPAUGE, | 
| Mike Isely | 31335b1 | 2008-07-25 19:35:31 -0300 | [diff] [blame] | 359 | .ir_scheme = PVR2_IR_SCHEME_ZILOG, | 
| Michael Krufky | 95814bc | 2008-04-19 15:36:51 -0300 | [diff] [blame] | 360 | #ifdef CONFIG_VIDEO_PVRUSB2_DVB | 
|  | 361 | .dvb_props = &pvr2_73xxx_dvb_props, | 
|  | 362 | #endif | 
| Michael Krufky | 92c9d07 | 2008-03-15 23:59:29 -0300 | [diff] [blame] | 363 | }; | 
|  | 364 |  | 
|  | 365 |  | 
|  | 366 |  | 
|  | 367 | /*------------------------------------------------------------------------*/ | 
| Michael Krufky | 11fcd47 | 2007-10-25 02:01:10 -0300 | [diff] [blame] | 368 | /* Hauppauge PVR-USB2 Model 75xxx */ | 
|  | 369 |  | 
| Michael Krufky | 087886e | 2008-03-28 05:49:36 -0300 | [diff] [blame] | 370 | #ifdef CONFIG_VIDEO_PVRUSB2_DVB | 
|  | 371 | static struct s5h1409_config pvr2_s5h1409_config = { | 
|  | 372 | .demod_address = 0x32 >> 1, | 
|  | 373 | .output_mode   = S5H1409_PARALLEL_OUTPUT, | 
|  | 374 | .gpio          = S5H1409_GPIO_OFF, | 
|  | 375 | .qam_if        = 4000, | 
|  | 376 | .inversion     = S5H1409_INVERSION_ON, | 
|  | 377 | .status_mode   = S5H1409_DEMODLOCKING, | 
|  | 378 | }; | 
|  | 379 |  | 
| Michael Krufky | 4aef8fd | 2008-04-25 04:19:02 -0300 | [diff] [blame] | 380 | static struct s5h1411_config pvr2_s5h1411_config = { | 
|  | 381 | .output_mode   = S5H1411_PARALLEL_OUTPUT, | 
|  | 382 | .gpio          = S5H1411_GPIO_OFF, | 
|  | 383 | .vsb_if        = S5H1411_IF_44000, | 
|  | 384 | .qam_if        = S5H1411_IF_4000, | 
|  | 385 | .inversion     = S5H1411_INVERSION_ON, | 
|  | 386 | .status_mode   = S5H1411_DEMODLOCKING, | 
|  | 387 | }; | 
|  | 388 |  | 
| Michael Krufky | 087886e | 2008-03-28 05:49:36 -0300 | [diff] [blame] | 389 | static struct tda18271_std_map hauppauge_tda18271_std_map = { | 
|  | 390 | .atsc_6   = { .if_freq = 5380, .agc_mode = 3, .std = 3, | 
|  | 391 | .if_lvl = 6, .rfagc_top = 0x37, }, | 
|  | 392 | .qam_6    = { .if_freq = 4000, .agc_mode = 3, .std = 0, | 
|  | 393 | .if_lvl = 6, .rfagc_top = 0x37, }, | 
|  | 394 | }; | 
|  | 395 |  | 
|  | 396 | static struct tda18271_config hauppauge_tda18271_config = { | 
|  | 397 | .std_map = &hauppauge_tda18271_std_map, | 
|  | 398 | .gate    = TDA18271_GATE_ANALOG, | 
| Michael Krufky | a18eaf0 | 2009-08-29 17:47:01 -0300 | [diff] [blame] | 399 | .output_opt = TDA18271_OUTPUT_LT_OFF, | 
| Michael Krufky | 087886e | 2008-03-28 05:49:36 -0300 | [diff] [blame] | 400 | }; | 
|  | 401 |  | 
|  | 402 | static int pvr2_s5h1409_attach(struct pvr2_dvb_adapter *adap) | 
|  | 403 | { | 
|  | 404 | adap->fe = dvb_attach(s5h1409_attach, &pvr2_s5h1409_config, | 
|  | 405 | &adap->channel.hdw->i2c_adap); | 
|  | 406 | if (adap->fe) | 
|  | 407 | return 0; | 
|  | 408 |  | 
|  | 409 | return -EIO; | 
|  | 410 | } | 
|  | 411 |  | 
| Michael Krufky | 4aef8fd | 2008-04-25 04:19:02 -0300 | [diff] [blame] | 412 | static int pvr2_s5h1411_attach(struct pvr2_dvb_adapter *adap) | 
|  | 413 | { | 
|  | 414 | adap->fe = dvb_attach(s5h1411_attach, &pvr2_s5h1411_config, | 
|  | 415 | &adap->channel.hdw->i2c_adap); | 
|  | 416 | if (adap->fe) | 
|  | 417 | return 0; | 
|  | 418 |  | 
|  | 419 | return -EIO; | 
|  | 420 | } | 
|  | 421 |  | 
| Michael Krufky | 087886e | 2008-03-28 05:49:36 -0300 | [diff] [blame] | 422 | static int pvr2_tda18271_8295_attach(struct pvr2_dvb_adapter *adap) | 
|  | 423 | { | 
|  | 424 | dvb_attach(tda829x_attach, adap->fe, | 
|  | 425 | &adap->channel.hdw->i2c_adap, 0x42, | 
|  | 426 | &tda829x_no_probe); | 
|  | 427 | dvb_attach(tda18271_attach, adap->fe, 0x60, | 
|  | 428 | &adap->channel.hdw->i2c_adap, | 
|  | 429 | &hauppauge_tda18271_config); | 
|  | 430 |  | 
|  | 431 | return 0; | 
|  | 432 | } | 
|  | 433 |  | 
| Mike Isely | 69ea3c1 | 2009-03-07 02:08:58 -0300 | [diff] [blame] | 434 | static const struct pvr2_dvb_props pvr2_750xx_dvb_props = { | 
| Michael Krufky | 087886e | 2008-03-28 05:49:36 -0300 | [diff] [blame] | 435 | .frontend_attach = pvr2_s5h1409_attach, | 
|  | 436 | .tuner_attach    = pvr2_tda18271_8295_attach, | 
|  | 437 | }; | 
| Michael Krufky | 4aef8fd | 2008-04-25 04:19:02 -0300 | [diff] [blame] | 438 |  | 
| Mike Isely | 69ea3c1 | 2009-03-07 02:08:58 -0300 | [diff] [blame] | 439 | static const struct pvr2_dvb_props pvr2_751xx_dvb_props = { | 
| Michael Krufky | 4aef8fd | 2008-04-25 04:19:02 -0300 | [diff] [blame] | 440 | .frontend_attach = pvr2_s5h1411_attach, | 
|  | 441 | .tuner_attach    = pvr2_tda18271_8295_attach, | 
|  | 442 | }; | 
| Michael Krufky | 087886e | 2008-03-28 05:49:36 -0300 | [diff] [blame] | 443 | #endif | 
|  | 444 |  | 
| Michael Krufky | 11fcd47 | 2007-10-25 02:01:10 -0300 | [diff] [blame] | 445 | static const char *pvr2_fw1_names_75xxx[] = { | 
|  | 446 | "v4l-pvrusb2-73xxx-01.fw", | 
|  | 447 | }; | 
|  | 448 |  | 
| Michael Krufky | c881284 | 2008-03-28 05:48:44 -0300 | [diff] [blame] | 449 | static const struct pvr2_device_desc pvr2_device_750xx = { | 
| Mike Isely | 1d70c7f | 2009-11-25 02:55:38 -0300 | [diff] [blame] | 450 | .description = "WinTV HVR-1950 Model 750xx", | 
| Michael Krufky | c881284 | 2008-03-28 05:48:44 -0300 | [diff] [blame] | 451 | .shortname = "750xx", | 
| Mike Isely | dd5f322 | 2009-03-07 02:07:12 -0300 | [diff] [blame] | 452 | .client_table.lst = pvr2_cli_73xxx, | 
|  | 453 | .client_table.cnt = ARRAY_SIZE(pvr2_cli_73xxx), | 
| Michael Krufky | c881284 | 2008-03-28 05:48:44 -0300 | [diff] [blame] | 454 | .fx2_firmware.lst = pvr2_fw1_names_75xxx, | 
|  | 455 | .fx2_firmware.cnt = ARRAY_SIZE(pvr2_fw1_names_75xxx), | 
|  | 456 | .flag_has_cx25840 = !0, | 
|  | 457 | .flag_has_hauppauge_rom = !0, | 
|  | 458 | .flag_has_analogtuner = !0, | 
|  | 459 | .flag_has_composite = !0, | 
|  | 460 | .flag_has_svideo = !0, | 
| Mike Isely | c21c2db | 2009-11-25 02:49:21 -0300 | [diff] [blame] | 461 | .flag_fx2_16kb = !0, | 
| Michael Krufky | c881284 | 2008-03-28 05:48:44 -0300 | [diff] [blame] | 462 | .signal_routing_scheme = PVR2_ROUTING_SCHEME_HAUPPAUGE, | 
|  | 463 | .digital_control_scheme = PVR2_DIGITAL_SCHEME_HAUPPAUGE, | 
|  | 464 | .default_std_mask = V4L2_STD_NTSC_M, | 
|  | 465 | .led_scheme = PVR2_LED_SCHEME_HAUPPAUGE, | 
| Mike Isely | 31335b1 | 2008-07-25 19:35:31 -0300 | [diff] [blame] | 466 | .ir_scheme = PVR2_IR_SCHEME_ZILOG, | 
| Michael Krufky | 087886e | 2008-03-28 05:49:36 -0300 | [diff] [blame] | 467 | #ifdef CONFIG_VIDEO_PVRUSB2_DVB | 
|  | 468 | .dvb_props = &pvr2_750xx_dvb_props, | 
|  | 469 | #endif | 
| Michael Krufky | c881284 | 2008-03-28 05:48:44 -0300 | [diff] [blame] | 470 | }; | 
|  | 471 |  | 
|  | 472 | static const struct pvr2_device_desc pvr2_device_751xx = { | 
| Mike Isely | 1d70c7f | 2009-11-25 02:55:38 -0300 | [diff] [blame] | 473 | .description = "WinTV HVR-1950 Model 751xx", | 
| Michael Krufky | c881284 | 2008-03-28 05:48:44 -0300 | [diff] [blame] | 474 | .shortname = "751xx", | 
| Mike Isely | dd5f322 | 2009-03-07 02:07:12 -0300 | [diff] [blame] | 475 | .client_table.lst = pvr2_cli_73xxx, | 
|  | 476 | .client_table.cnt = ARRAY_SIZE(pvr2_cli_73xxx), | 
| Michael Krufky | 11fcd47 | 2007-10-25 02:01:10 -0300 | [diff] [blame] | 477 | .fx2_firmware.lst = pvr2_fw1_names_75xxx, | 
|  | 478 | .fx2_firmware.cnt = ARRAY_SIZE(pvr2_fw1_names_75xxx), | 
|  | 479 | .flag_has_cx25840 = !0, | 
|  | 480 | .flag_has_hauppauge_rom = !0, | 
| Mike Isely | 1aaac60 | 2008-04-22 14:45:36 -0300 | [diff] [blame] | 481 | .flag_has_analogtuner = !0, | 
|  | 482 | .flag_has_composite = !0, | 
|  | 483 | .flag_has_svideo = !0, | 
| Mike Isely | c21c2db | 2009-11-25 02:49:21 -0300 | [diff] [blame] | 484 | .flag_fx2_16kb = !0, | 
| Michael Krufky | 11fcd47 | 2007-10-25 02:01:10 -0300 | [diff] [blame] | 485 | .signal_routing_scheme = PVR2_ROUTING_SCHEME_HAUPPAUGE, | 
| Mike Isely | e8f5bac | 2008-04-22 14:45:40 -0300 | [diff] [blame] | 486 | .digital_control_scheme = PVR2_DIGITAL_SCHEME_HAUPPAUGE, | 
| Michael Krufky | 11fcd47 | 2007-10-25 02:01:10 -0300 | [diff] [blame] | 487 | .default_std_mask = V4L2_STD_NTSC_M, | 
| Mike Isely | 40381cb | 2008-04-22 14:45:42 -0300 | [diff] [blame] | 488 | .led_scheme = PVR2_LED_SCHEME_HAUPPAUGE, | 
| Mike Isely | 31335b1 | 2008-07-25 19:35:31 -0300 | [diff] [blame] | 489 | .ir_scheme = PVR2_IR_SCHEME_ZILOG, | 
| Michael Krufky | 4aef8fd | 2008-04-25 04:19:02 -0300 | [diff] [blame] | 490 | #ifdef CONFIG_VIDEO_PVRUSB2_DVB | 
|  | 491 | .dvb_props = &pvr2_751xx_dvb_props, | 
|  | 492 | #endif | 
| Michael Krufky | 11fcd47 | 2007-10-25 02:01:10 -0300 | [diff] [blame] | 493 | }; | 
|  | 494 |  | 
|  | 495 |  | 
|  | 496 |  | 
|  | 497 | /*------------------------------------------------------------------------*/ | 
| Mike Isely | d130fa8 | 2007-12-08 17:20:06 -0300 | [diff] [blame] | 498 |  | 
|  | 499 | struct usb_device_id pvr2_device_table[] = { | 
|  | 500 | { USB_DEVICE(0x2040, 0x2900), | 
|  | 501 | .driver_info = (kernel_ulong_t)&pvr2_device_29xxx}, | 
| Mike Isely | b675c05 | 2008-08-30 15:08:28 -0300 | [diff] [blame] | 502 | { USB_DEVICE(0x2040, 0x2950), /* Logically identical to 2900 */ | 
|  | 503 | .driver_info = (kernel_ulong_t)&pvr2_device_29xxx}, | 
| Mike Isely | d130fa8 | 2007-12-08 17:20:06 -0300 | [diff] [blame] | 504 | { USB_DEVICE(0x2040, 0x2400), | 
|  | 505 | .driver_info = (kernel_ulong_t)&pvr2_device_24xxx}, | 
|  | 506 | { USB_DEVICE(0x1164, 0x0622), | 
|  | 507 | .driver_info = (kernel_ulong_t)&pvr2_device_gotview_2}, | 
| Mike Isely | fd1da78 | 2008-04-22 14:45:42 -0300 | [diff] [blame] | 508 | { USB_DEVICE(0x1164, 0x0602), | 
|  | 509 | .driver_info = (kernel_ulong_t)&pvr2_device_gotview_2d}, | 
| Mike Isely | d130fa8 | 2007-12-08 17:20:06 -0300 | [diff] [blame] | 510 | { USB_DEVICE(0x11ba, 0x1003), | 
|  | 511 | .driver_info = (kernel_ulong_t)&pvr2_device_onair_creator}, | 
| Mike Isely | d130fa8 | 2007-12-08 17:20:06 -0300 | [diff] [blame] | 512 | { USB_DEVICE(0x11ba, 0x1001), | 
|  | 513 | .driver_info = (kernel_ulong_t)&pvr2_device_onair_usb2}, | 
| Michael Krufky | 92c9d07 | 2008-03-15 23:59:29 -0300 | [diff] [blame] | 514 | { USB_DEVICE(0x2040, 0x7300), | 
|  | 515 | .driver_info = (kernel_ulong_t)&pvr2_device_73xxx}, | 
| Michael Krufky | 11fcd47 | 2007-10-25 02:01:10 -0300 | [diff] [blame] | 516 | { USB_DEVICE(0x2040, 0x7500), | 
| Michael Krufky | c881284 | 2008-03-28 05:48:44 -0300 | [diff] [blame] | 517 | .driver_info = (kernel_ulong_t)&pvr2_device_750xx}, | 
| Michael Krufky | dd6e946 | 2008-03-08 06:07:38 -0300 | [diff] [blame] | 518 | { USB_DEVICE(0x2040, 0x7501), | 
| Michael Krufky | c881284 | 2008-03-28 05:48:44 -0300 | [diff] [blame] | 519 | .driver_info = (kernel_ulong_t)&pvr2_device_751xx}, | 
| Mike Isely | d130fa8 | 2007-12-08 17:20:06 -0300 | [diff] [blame] | 520 | { } | 
|  | 521 | }; | 
| Mike Isely | 989eb15 | 2007-11-26 01:53:12 -0300 | [diff] [blame] | 522 |  | 
|  | 523 | MODULE_DEVICE_TABLE(usb, pvr2_device_table); | 
|  | 524 |  | 
|  | 525 |  | 
|  | 526 | /* | 
|  | 527 | Stuff for Emacs to see, in order to encourage consistent editing style: | 
|  | 528 | *** Local Variables: *** | 
|  | 529 | *** mode: c *** | 
|  | 530 | *** fill-column: 75 *** | 
|  | 531 | *** tab-width: 8 *** | 
|  | 532 | *** c-basic-offset: 8 *** | 
|  | 533 | *** End: *** | 
|  | 534 | */ |