diff options
-rw-r--r-- | drivers/media/common/tuners/xc4000.c | 272 | ||||
-rw-r--r-- | drivers/media/dvb/dvb-usb/dib0700_devices.c | 15 |
2 files changed, 126 insertions, 161 deletions
diff --git a/drivers/media/common/tuners/xc4000.c b/drivers/media/common/tuners/xc4000.c index 160ca26286cc..ebc84269b5e6 100644 --- a/drivers/media/common/tuners/xc4000.c +++ b/drivers/media/common/tuners/xc4000.c | |||
@@ -5,6 +5,7 @@ | |||
5 | * Copyright (c) 2007 Steven Toth <stoth@linuxtv.org> | 5 | * Copyright (c) 2007 Steven Toth <stoth@linuxtv.org> |
6 | * Copyright (c) 2009 Devin Heitmueller <dheitmueller@kernellabs.com> | 6 | * Copyright (c) 2009 Devin Heitmueller <dheitmueller@kernellabs.com> |
7 | * Copyright (c) 2009 Davide Ferri <d.ferri@zero11.it> | 7 | * Copyright (c) 2009 Davide Ferri <d.ferri@zero11.it> |
8 | * Copyright (c) 2010 Istvan Varga <istvan_v@mailbox.hu> | ||
8 | * | 9 | * |
9 | * This program is free software; you can redistribute it and/or modify | 10 | * This program is free software; you can redistribute it and/or modify |
10 | * it under the terms of the GNU General Public License as published by | 11 | * it under the terms of the GNU General Public License as published by |
@@ -14,7 +15,6 @@ | |||
14 | * This program is distributed in the hope that it will be useful, | 15 | * This program is distributed in the hope that it will be useful, |
15 | * but WITHOUT ANY WARRANTY; without even the implied warranty of | 16 | * but WITHOUT ANY WARRANTY; without even the implied warranty of |
16 | * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the | 17 | * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the |
17 | * | ||
18 | * GNU General Public License for more details. | 18 | * GNU General Public License for more details. |
19 | * | 19 | * |
20 | * You should have received a copy of the GNU General Public License | 20 | * You should have received a copy of the GNU General Public License |
@@ -39,44 +39,29 @@ | |||
39 | 39 | ||
40 | static int debug; | 40 | static int debug; |
41 | module_param(debug, int, 0644); | 41 | module_param(debug, int, 0644); |
42 | MODULE_PARM_DESC(debug, "\n\t\tDebugging level (0 to 2, default: 0 (off))."); | 42 | MODULE_PARM_DESC(debug, "Debugging level (0 to 2, default: 0 (off))."); |
43 | 43 | ||
44 | static int no_poweroff; | 44 | static int no_poweroff; |
45 | module_param(no_poweroff, int, 0644); | 45 | module_param(no_poweroff, int, 0644); |
46 | MODULE_PARM_DESC(no_poweroff, "\n\t\t1: keep device energized and with tuner " | 46 | MODULE_PARM_DESC(no_poweroff, "Power management (1: disabled, 2: enabled, " |
47 | "ready all the times.\n" | 47 | "0 (default): use device-specific default mode)."); |
48 | "\t\tFaster, but consumes more power and keeps the device hotter.\n" | ||
49 | "\t\t2: powers device off when not used.\n" | ||
50 | "\t\t0 (default): use device-specific default mode."); | ||
51 | |||
52 | #define XC4000_AUDIO_STD_B 1 | ||
53 | #define XC4000_AUDIO_STD_A2 2 | ||
54 | #define XC4000_AUDIO_STD_K3 4 | ||
55 | #define XC4000_AUDIO_STD_L 8 | ||
56 | #define XC4000_AUDIO_STD_INPUT1 16 | ||
57 | #define XC4000_AUDIO_STD_MONO 32 | ||
58 | 48 | ||
59 | static int audio_std; | 49 | static int audio_std; |
60 | module_param(audio_std, int, 0644); | 50 | module_param(audio_std, int, 0644); |
61 | MODULE_PARM_DESC(audio_std, "\n\t\tAudio standard. XC4000 audio decoder " | 51 | MODULE_PARM_DESC(audio_std, "Audio standard. XC4000 audio decoder explicitly " |
62 | "explicitly needs to know\n" | 52 | "needs to know what audio standard is needed for some video standards " |
63 | "\t\twhat audio standard is needed for some video standards with\n" | 53 | "with audio A2 or NICAM. The valid settings are a sum of:\n" |
64 | "\t\taudio A2 or NICAM.\n" | 54 | " 1: use NICAM/B or A2/B instead of NICAM/A or A2/A\n" |
65 | "\t\tThe valid settings are a sum of:\n" | 55 | " 2: use A2 instead of NICAM or BTSC\n" |
66 | "\t\t 1: use NICAM/B or A2/B instead of NICAM/A or A2/A\n" | 56 | " 4: use SECAM/K3 instead of K1\n" |
67 | "\t\t 2: use A2 instead of NICAM or BTSC\n" | 57 | " 8: use PAL-D/K audio for SECAM-D/K\n" |
68 | "\t\t 4: use SECAM/K3 instead of K1\n" | 58 | "16: use FM radio input 1 instead of input 2\n" |
69 | "\t\t 8: use PAL-D/K audio for SECAM-D/K\n" | 59 | "32: use mono audio (the lower three bits are ignored)"); |
70 | "\t\t16: use FM radio input 1 instead of input 2\n" | ||
71 | "\t\t32: use mono audio (the lower three bits are ignored)"); | ||
72 | |||
73 | #define XC4000_DEFAULT_FIRMWARE "xc4000.fw" | ||
74 | 60 | ||
75 | static char firmware_name[30]; | 61 | static char firmware_name[30]; |
76 | module_param_string(firmware_name, firmware_name, sizeof(firmware_name), 0); | 62 | module_param_string(firmware_name, firmware_name, sizeof(firmware_name), 0); |
77 | MODULE_PARM_DESC(firmware_name, "\n\t\tFirmware file name. Allows overriding " | 63 | MODULE_PARM_DESC(firmware_name, "Firmware file name. Allows overriding the " |
78 | "the default firmware\n" | 64 | "default firmware name."); |
79 | "\t\tname."); | ||
80 | 65 | ||
81 | static DEFINE_MUTEX(xc4000_list_mutex); | 66 | static DEFINE_MUTEX(xc4000_list_mutex); |
82 | static LIST_HEAD(hybrid_tuner_instance_list); | 67 | static LIST_HEAD(hybrid_tuner_instance_list); |
@@ -115,13 +100,21 @@ struct xc4000_priv { | |||
115 | u8 rf_mode; | 100 | u8 rf_mode; |
116 | u8 card_type; | 101 | u8 card_type; |
117 | u8 ignore_i2c_write_errors; | 102 | u8 ignore_i2c_write_errors; |
118 | /* struct xc2028_ctrl ctrl; */ | ||
119 | struct firmware_properties cur_fw; | 103 | struct firmware_properties cur_fw; |
120 | __u16 hwmodel; | 104 | __u16 hwmodel; |
121 | __u16 hwvers; | 105 | __u16 hwvers; |
122 | struct mutex lock; | 106 | struct mutex lock; |
123 | }; | 107 | }; |
124 | 108 | ||
109 | #define XC4000_AUDIO_STD_B 1 | ||
110 | #define XC4000_AUDIO_STD_A2 2 | ||
111 | #define XC4000_AUDIO_STD_K3 4 | ||
112 | #define XC4000_AUDIO_STD_L 8 | ||
113 | #define XC4000_AUDIO_STD_INPUT1 16 | ||
114 | #define XC4000_AUDIO_STD_MONO 32 | ||
115 | |||
116 | #define XC4000_DEFAULT_FIRMWARE "dvb-fe-xc4000-1.4.fw" | ||
117 | |||
125 | /* Misc Defines */ | 118 | /* Misc Defines */ |
126 | #define MAX_TV_STANDARD 24 | 119 | #define MAX_TV_STANDARD 24 |
127 | #define XC_MAX_I2C_WRITE_LENGTH 64 | 120 | #define XC_MAX_I2C_WRITE_LENGTH 64 |
@@ -131,13 +124,6 @@ struct xc4000_priv { | |||
131 | #define XC_RF_MODE_AIR 0 | 124 | #define XC_RF_MODE_AIR 0 |
132 | #define XC_RF_MODE_CABLE 1 | 125 | #define XC_RF_MODE_CABLE 1 |
133 | 126 | ||
134 | /* Result codes */ | ||
135 | #define XC_RESULT_SUCCESS 0 | ||
136 | #define XC_RESULT_RESET_FAILURE 1 | ||
137 | #define XC_RESULT_I2C_WRITE_FAILURE 2 | ||
138 | #define XC_RESULT_I2C_READ_FAILURE 3 | ||
139 | #define XC_RESULT_OUT_OF_RANGE 5 | ||
140 | |||
141 | /* Product id */ | 127 | /* Product id */ |
142 | #define XC_PRODUCT_ID_FW_NOT_LOADED 0x2000 | 128 | #define XC_PRODUCT_ID_FW_NOT_LOADED 0x2000 |
143 | #define XC_PRODUCT_ID_XC4000 0x0FA0 | 129 | #define XC_PRODUCT_ID_XC4000 0x0FA0 |
@@ -202,8 +188,8 @@ struct xc4000_priv { | |||
202 | 188 | ||
203 | struct XC_TV_STANDARD { | 189 | struct XC_TV_STANDARD { |
204 | const char *Name; | 190 | const char *Name; |
205 | u16 AudioMode; | 191 | u16 audio_mode; |
206 | u16 VideoMode; | 192 | u16 video_mode; |
207 | u16 int_freq; | 193 | u16 int_freq; |
208 | }; | 194 | }; |
209 | 195 | ||
@@ -233,7 +219,7 @@ struct XC_TV_STANDARD { | |||
233 | #define XC4000_FM_Radio_INPUT2 22 | 219 | #define XC4000_FM_Radio_INPUT2 22 |
234 | #define XC4000_FM_Radio_INPUT1 23 | 220 | #define XC4000_FM_Radio_INPUT1 23 |
235 | 221 | ||
236 | static struct XC_TV_STANDARD XC4000_Standard[MAX_TV_STANDARD] = { | 222 | static struct XC_TV_STANDARD xc4000_standard[MAX_TV_STANDARD] = { |
237 | {"M/N-NTSC/PAL-BTSC", 0x0000, 0x80A0, 4500}, | 223 | {"M/N-NTSC/PAL-BTSC", 0x0000, 0x80A0, 4500}, |
238 | {"M/N-NTSC/PAL-A2", 0x0000, 0x80A0, 4600}, | 224 | {"M/N-NTSC/PAL-A2", 0x0000, 0x80A0, 4600}, |
239 | {"M/N-NTSC/PAL-EIAJ", 0x0040, 0x80A0, 4500}, | 225 | {"M/N-NTSC/PAL-EIAJ", 0x0040, 0x80A0, 4500}, |
@@ -261,7 +247,7 @@ static struct XC_TV_STANDARD XC4000_Standard[MAX_TV_STANDARD] = { | |||
261 | }; | 247 | }; |
262 | 248 | ||
263 | static int xc4000_readreg(struct xc4000_priv *priv, u16 reg, u16 *val); | 249 | static int xc4000_readreg(struct xc4000_priv *priv, u16 reg, u16 *val); |
264 | static int xc4000_TunerReset(struct dvb_frontend *fe); | 250 | static int xc4000_tuner_reset(struct dvb_frontend *fe); |
265 | static void xc_debug_dump(struct xc4000_priv *priv); | 251 | static void xc_debug_dump(struct xc4000_priv *priv); |
266 | 252 | ||
267 | static int xc_send_i2c_data(struct xc4000_priv *priv, u8 *buf, int len) | 253 | static int xc_send_i2c_data(struct xc4000_priv *priv, u8 *buf, int len) |
@@ -276,18 +262,13 @@ static int xc_send_i2c_data(struct xc4000_priv *priv, u8 *buf, int len) | |||
276 | printk("bytes %02x %02x %02x %02x\n", buf[0], | 262 | printk("bytes %02x %02x %02x %02x\n", buf[0], |
277 | buf[1], buf[2], buf[3]); | 263 | buf[1], buf[2], buf[3]); |
278 | } | 264 | } |
279 | return XC_RESULT_I2C_WRITE_FAILURE; | 265 | return -EREMOTEIO; |
280 | } | 266 | } |
281 | } | 267 | } |
282 | return XC_RESULT_SUCCESS; | 268 | return 0; |
283 | } | ||
284 | |||
285 | static void xc_wait(int wait_ms) | ||
286 | { | ||
287 | msleep(wait_ms); | ||
288 | } | 269 | } |
289 | 270 | ||
290 | static int xc4000_TunerReset(struct dvb_frontend *fe) | 271 | static int xc4000_tuner_reset(struct dvb_frontend *fe) |
291 | { | 272 | { |
292 | struct xc4000_priv *priv = fe->tuner_priv; | 273 | struct xc4000_priv *priv = fe->tuner_priv; |
293 | int ret; | 274 | int ret; |
@@ -302,13 +283,14 @@ static int xc4000_TunerReset(struct dvb_frontend *fe) | |||
302 | XC4000_TUNER_RESET, 0); | 283 | XC4000_TUNER_RESET, 0); |
303 | if (ret) { | 284 | if (ret) { |
304 | printk(KERN_ERR "xc4000: reset failed\n"); | 285 | printk(KERN_ERR "xc4000: reset failed\n"); |
305 | return XC_RESULT_RESET_FAILURE; | 286 | return -EREMOTEIO; |
306 | } | 287 | } |
307 | } else { | 288 | } else { |
308 | printk(KERN_ERR "xc4000: no tuner reset callback function, fatal\n"); | 289 | printk(KERN_ERR "xc4000: no tuner reset callback function, " |
309 | return XC_RESULT_RESET_FAILURE; | 290 | "fatal\n"); |
291 | return -EINVAL; | ||
310 | } | 292 | } |
311 | return XC_RESULT_SUCCESS; | 293 | return 0; |
312 | } | 294 | } |
313 | 295 | ||
314 | static int xc_write_reg(struct xc4000_priv *priv, u16 regAddr, u16 i2cData) | 296 | static int xc_write_reg(struct xc4000_priv *priv, u16 regAddr, u16 i2cData) |
@@ -339,15 +321,12 @@ static int xc_load_i2c_sequence(struct dvb_frontend *fe, const u8 *i2c_sequence) | |||
339 | len = i2c_sequence[index] * 256 + i2c_sequence[index+1]; | 321 | len = i2c_sequence[index] * 256 + i2c_sequence[index+1]; |
340 | if (len == 0x0000) { | 322 | if (len == 0x0000) { |
341 | /* RESET command */ | 323 | /* RESET command */ |
324 | /* NOTE: this is ignored, as the reset callback was */ | ||
325 | /* already called by check_firmware() */ | ||
342 | index += 2; | 326 | index += 2; |
343 | #if 0 /* not needed, as already called by check_firmware() */ | ||
344 | result = xc4000_TunerReset(fe); | ||
345 | if (result != XC_RESULT_SUCCESS) | ||
346 | return result; | ||
347 | #endif | ||
348 | } else if (len & 0x8000) { | 327 | } else if (len & 0x8000) { |
349 | /* WAIT command */ | 328 | /* WAIT command */ |
350 | xc_wait(len & 0x7FFF); | 329 | msleep(len & 0x7FFF); |
351 | index += 2; | 330 | index += 2; |
352 | } else { | 331 | } else { |
353 | /* Send i2c data whilst ensuring individual transactions | 332 | /* Send i2c data whilst ensuring individual transactions |
@@ -370,7 +349,7 @@ static int xc_load_i2c_sequence(struct dvb_frontend *fe, const u8 *i2c_sequence) | |||
370 | result = xc_send_i2c_data(priv, buf, | 349 | result = xc_send_i2c_data(priv, buf, |
371 | nbytes_to_send); | 350 | nbytes_to_send); |
372 | 351 | ||
373 | if (result != XC_RESULT_SUCCESS) | 352 | if (result != 0) |
374 | return result; | 353 | return result; |
375 | 354 | ||
376 | pos += nbytes_to_send - 2; | 355 | pos += nbytes_to_send - 2; |
@@ -378,31 +357,31 @@ static int xc_load_i2c_sequence(struct dvb_frontend *fe, const u8 *i2c_sequence) | |||
378 | index += len; | 357 | index += len; |
379 | } | 358 | } |
380 | } | 359 | } |
381 | return XC_RESULT_SUCCESS; | 360 | return 0; |
382 | } | 361 | } |
383 | 362 | ||
384 | static int xc_SetTVStandard(struct xc4000_priv *priv, | 363 | static int xc_set_tv_standard(struct xc4000_priv *priv, |
385 | u16 VideoMode, u16 AudioMode) | 364 | u16 video_mode, u16 audio_mode) |
386 | { | 365 | { |
387 | int ret; | 366 | int ret; |
388 | dprintk(1, "%s(0x%04x,0x%04x)\n", __func__, VideoMode, AudioMode); | 367 | dprintk(1, "%s(0x%04x,0x%04x)\n", __func__, video_mode, audio_mode); |
389 | dprintk(1, "%s() Standard = %s\n", | 368 | dprintk(1, "%s() Standard = %s\n", |
390 | __func__, | 369 | __func__, |
391 | XC4000_Standard[priv->video_standard].Name); | 370 | xc4000_standard[priv->video_standard].Name); |
392 | 371 | ||
393 | /* Don't complain when the request fails because of i2c stretching */ | 372 | /* Don't complain when the request fails because of i2c stretching */ |
394 | priv->ignore_i2c_write_errors = 1; | 373 | priv->ignore_i2c_write_errors = 1; |
395 | 374 | ||
396 | ret = xc_write_reg(priv, XREG_VIDEO_MODE, VideoMode); | 375 | ret = xc_write_reg(priv, XREG_VIDEO_MODE, video_mode); |
397 | if (ret == XC_RESULT_SUCCESS) | 376 | if (ret == 0) |
398 | ret = xc_write_reg(priv, XREG_AUDIO_MODE, AudioMode); | 377 | ret = xc_write_reg(priv, XREG_AUDIO_MODE, audio_mode); |
399 | 378 | ||
400 | priv->ignore_i2c_write_errors = 0; | 379 | priv->ignore_i2c_write_errors = 0; |
401 | 380 | ||
402 | return ret; | 381 | return ret; |
403 | } | 382 | } |
404 | 383 | ||
405 | static int xc_SetSignalSource(struct xc4000_priv *priv, u16 rf_mode) | 384 | static int xc_set_signal_source(struct xc4000_priv *priv, u16 rf_mode) |
406 | { | 385 | { |
407 | dprintk(1, "%s(%d) Source = %s\n", __func__, rf_mode, | 386 | dprintk(1, "%s(%d) Source = %s\n", __func__, rf_mode, |
408 | rf_mode == XC_RF_MODE_AIR ? "ANTENNA" : "CABLE"); | 387 | rf_mode == XC_RF_MODE_AIR ? "ANTENNA" : "CABLE"); |
@@ -418,25 +397,26 @@ static int xc_SetSignalSource(struct xc4000_priv *priv, u16 rf_mode) | |||
418 | 397 | ||
419 | static const struct dvb_tuner_ops xc4000_tuner_ops; | 398 | static const struct dvb_tuner_ops xc4000_tuner_ops; |
420 | 399 | ||
421 | static int xc_set_RF_frequency(struct xc4000_priv *priv, u32 freq_hz) | 400 | static int xc_set_rf_frequency(struct xc4000_priv *priv, u32 freq_hz) |
422 | { | 401 | { |
423 | u16 freq_code; | 402 | u16 freq_code; |
424 | 403 | ||
425 | dprintk(1, "%s(%u)\n", __func__, freq_hz); | 404 | dprintk(1, "%s(%u)\n", __func__, freq_hz); |
426 | 405 | ||
427 | if ((freq_hz > xc4000_tuner_ops.info.frequency_max) || | 406 | if ((freq_hz > xc4000_tuner_ops.info.frequency_max) || |
428 | (freq_hz < xc4000_tuner_ops.info.frequency_min)) | 407 | (freq_hz < xc4000_tuner_ops.info.frequency_min)) |
429 | return XC_RESULT_OUT_OF_RANGE; | 408 | return -EINVAL; |
430 | 409 | ||
431 | freq_code = (u16)(freq_hz / 15625); | 410 | freq_code = (u16)(freq_hz / 15625); |
432 | 411 | ||
433 | /* WAS: Starting in firmware version 1.1.44, Xceive recommends using the | 412 | /* WAS: Starting in firmware version 1.1.44, Xceive recommends using the |
434 | FINERFREQ for all normal tuning (the doc indicates reg 0x03 should | 413 | FINERFREQ for all normal tuning (the doc indicates reg 0x03 should |
435 | only be used for fast scanning for channel lock) */ | 414 | only be used for fast scanning for channel lock) */ |
436 | return xc_write_reg(priv, XREG_RF_FREQ, freq_code); /* WAS: XREG_FINERFREQ */ | 415 | /* WAS: XREG_FINERFREQ */ |
416 | return xc_write_reg(priv, XREG_RF_FREQ, freq_code); | ||
437 | } | 417 | } |
438 | 418 | ||
439 | static int xc_get_ADC_Envelope(struct xc4000_priv *priv, u16 *adc_envelope) | 419 | static int xc_get_adc_envelope(struct xc4000_priv *priv, u16 *adc_envelope) |
440 | { | 420 | { |
441 | return xc4000_readreg(priv, XREG_ADC_ENV, adc_envelope); | 421 | return xc4000_readreg(priv, XREG_ADC_ENV, adc_envelope); |
442 | } | 422 | } |
@@ -448,7 +428,7 @@ static int xc_get_frequency_error(struct xc4000_priv *priv, u32 *freq_error_hz) | |||
448 | u32 tmp; | 428 | u32 tmp; |
449 | 429 | ||
450 | result = xc4000_readreg(priv, XREG_FREQ_ERROR, ®Data); | 430 | result = xc4000_readreg(priv, XREG_FREQ_ERROR, ®Data); |
451 | if (result != XC_RESULT_SUCCESS) | 431 | if (result != 0) |
452 | return result; | 432 | return result; |
453 | 433 | ||
454 | tmp = (u32)regData & 0xFFFFU; | 434 | tmp = (u32)regData & 0xFFFFU; |
@@ -470,7 +450,7 @@ static int xc_get_version(struct xc4000_priv *priv, | |||
470 | int result; | 450 | int result; |
471 | 451 | ||
472 | result = xc4000_readreg(priv, XREG_VERSION, &data); | 452 | result = xc4000_readreg(priv, XREG_VERSION, &data); |
473 | if (result != XC_RESULT_SUCCESS) | 453 | if (result != 0) |
474 | return result; | 454 | return result; |
475 | 455 | ||
476 | (*hw_majorversion) = (data >> 12) & 0x0F; | 456 | (*hw_majorversion) = (data >> 12) & 0x0F; |
@@ -487,7 +467,7 @@ static int xc_get_hsync_freq(struct xc4000_priv *priv, u32 *hsync_freq_hz) | |||
487 | int result; | 467 | int result; |
488 | 468 | ||
489 | result = xc4000_readreg(priv, XREG_HSYNC_FREQ, ®Data); | 469 | result = xc4000_readreg(priv, XREG_HSYNC_FREQ, ®Data); |
490 | if (result != XC_RESULT_SUCCESS) | 470 | if (result != 0) |
491 | return result; | 471 | return result; |
492 | 472 | ||
493 | (*hsync_freq_hz) = ((regData & 0x0fff) * 763)/100; | 473 | (*hsync_freq_hz) = ((regData & 0x0fff) * 763)/100; |
@@ -504,19 +484,19 @@ static int xc_get_quality(struct xc4000_priv *priv, u16 *quality) | |||
504 | return xc4000_readreg(priv, XREG_QUALITY, quality); | 484 | return xc4000_readreg(priv, XREG_QUALITY, quality); |
505 | } | 485 | } |
506 | 486 | ||
507 | static u16 WaitForLock(struct xc4000_priv *priv) | 487 | static u16 xc_wait_for_lock(struct xc4000_priv *priv) |
508 | { | 488 | { |
509 | u16 lockState = 0; | 489 | u16 lock_state = 0; |
510 | int watchDogCount = 40; | 490 | int watchdog_count = 40; |
511 | 491 | ||
512 | while ((lockState == 0) && (watchDogCount > 0)) { | 492 | while ((lock_state == 0) && (watchdog_count > 0)) { |
513 | xc_get_lock_status(priv, &lockState); | 493 | xc_get_lock_status(priv, &lock_state); |
514 | if (lockState != 1) { | 494 | if (lock_state != 1) { |
515 | xc_wait(5); | 495 | msleep(5); |
516 | watchDogCount--; | 496 | watchdog_count--; |
517 | } | 497 | } |
518 | } | 498 | } |
519 | return lockState; | 499 | return lock_state; |
520 | } | 500 | } |
521 | 501 | ||
522 | static int xc_tune_channel(struct xc4000_priv *priv, u32 freq_hz) | 502 | static int xc_tune_channel(struct xc4000_priv *priv, u32 freq_hz) |
@@ -528,15 +508,15 @@ static int xc_tune_channel(struct xc4000_priv *priv, u32 freq_hz) | |||
528 | 508 | ||
529 | /* Don't complain when the request fails because of i2c stretching */ | 509 | /* Don't complain when the request fails because of i2c stretching */ |
530 | priv->ignore_i2c_write_errors = 1; | 510 | priv->ignore_i2c_write_errors = 1; |
531 | result = xc_set_RF_frequency(priv, freq_hz); | 511 | result = xc_set_rf_frequency(priv, freq_hz); |
532 | priv->ignore_i2c_write_errors = 0; | 512 | priv->ignore_i2c_write_errors = 0; |
533 | 513 | ||
534 | if (result != XC_RESULT_SUCCESS) | 514 | if (result != 0) |
535 | return 0; | 515 | return 0; |
536 | 516 | ||
537 | /* wait for lock only in analog TV mode */ | 517 | /* wait for lock only in analog TV mode */ |
538 | if ((priv->cur_fw.type & (FM | DTV6 | DTV7 | DTV78 | DTV8)) == 0) { | 518 | if ((priv->cur_fw.type & (FM | DTV6 | DTV7 | DTV78 | DTV8)) == 0) { |
539 | if (WaitForLock(priv) != 1) | 519 | if (xc_wait_for_lock(priv) != 1) |
540 | found = 0; | 520 | found = 0; |
541 | } | 521 | } |
542 | 522 | ||
@@ -544,7 +524,7 @@ static int xc_tune_channel(struct xc4000_priv *priv, u32 freq_hz) | |||
544 | * Frame Lines needs two frame times after initial lock | 524 | * Frame Lines needs two frame times after initial lock |
545 | * before it is valid. | 525 | * before it is valid. |
546 | */ | 526 | */ |
547 | xc_wait(debug ? 100 : 10); | 527 | msleep(debug ? 100 : 10); |
548 | 528 | ||
549 | if (debug) | 529 | if (debug) |
550 | xc_debug_dump(priv); | 530 | xc_debug_dump(priv); |
@@ -569,7 +549,7 @@ static int xc4000_readreg(struct xc4000_priv *priv, u16 reg, u16 *val) | |||
569 | } | 549 | } |
570 | 550 | ||
571 | *val = (bval[0] << 8) | bval[1]; | 551 | *val = (bval[0] << 8) | bval[1]; |
572 | return XC_RESULT_SUCCESS; | 552 | return 0; |
573 | } | 553 | } |
574 | 554 | ||
575 | #define dump_firm_type(t) dump_firm_type_and_int_freq(t, 0) | 555 | #define dump_firm_type(t) dump_firm_type_and_int_freq(t, 0) |
@@ -647,7 +627,7 @@ static int seek_firmware(struct dvb_frontend *fe, unsigned int type, | |||
647 | unsigned int best_nr_diffs = 255U; | 627 | unsigned int best_nr_diffs = 255U; |
648 | 628 | ||
649 | if (!priv->firm) { | 629 | if (!priv->firm) { |
650 | printk("Error! firmware not loaded\n"); | 630 | printk(KERN_ERR "Error! firmware not loaded\n"); |
651 | return -EINVAL; | 631 | return -EINVAL; |
652 | } | 632 | } |
653 | 633 | ||
@@ -685,8 +665,8 @@ static int seek_firmware(struct dvb_frontend *fe, unsigned int type, | |||
685 | 665 | ||
686 | if (best_nr_diffs > 0U) { | 666 | if (best_nr_diffs > 0U) { |
687 | printk("Selecting best matching firmware (%u bits differ) for " | 667 | printk("Selecting best matching firmware (%u bits differ) for " |
688 | "type=", best_nr_diffs); | 668 | "type=(%x), id %016llx:\n", |
689 | printk("(%x), id %016llx:\n", type, (unsigned long long)*id); | 669 | best_nr_diffs, type, (unsigned long long)*id); |
690 | i = best_i; | 670 | i = best_i; |
691 | } | 671 | } |
692 | 672 | ||
@@ -695,8 +675,8 @@ found: | |||
695 | 675 | ||
696 | ret: | 676 | ret: |
697 | if (debug) { | 677 | if (debug) { |
698 | printk("%s firmware for type=", (i < 0) ? "Can't find" : | 678 | printk("%s firmware for type=", |
699 | "Found"); | 679 | (i < 0) ? "Can't find" : "Found"); |
700 | dump_firm_type(type); | 680 | dump_firm_type(type); |
701 | printk("(%x), id %016llx.\n", type, (unsigned long long)*id); | 681 | printk("(%x), id %016llx.\n", type, (unsigned long long)*id); |
702 | } | 682 | } |
@@ -745,11 +725,10 @@ static int xc4000_fwupload(struct dvb_frontend *fe) | |||
745 | rc = request_firmware(&fw, fname, priv->i2c_props.adap->dev.parent); | 725 | rc = request_firmware(&fw, fname, priv->i2c_props.adap->dev.parent); |
746 | if (rc < 0) { | 726 | if (rc < 0) { |
747 | if (rc == -ENOENT) | 727 | if (rc == -ENOENT) |
748 | printk("Error: firmware %s not found.\n", | 728 | printk("Error: firmware %s not found.\n", fname); |
749 | fname); | ||
750 | else | 729 | else |
751 | printk("Error %d while requesting firmware %s \n", | 730 | printk("Error %d while requesting firmware %s \n", |
752 | rc, fname); | 731 | rc, fname); |
753 | 732 | ||
754 | return rc; | 733 | return rc; |
755 | } | 734 | } |
@@ -757,13 +736,12 @@ static int xc4000_fwupload(struct dvb_frontend *fe) | |||
757 | endp = p + fw->size; | 736 | endp = p + fw->size; |
758 | 737 | ||
759 | if (fw->size < sizeof(name) - 1 + 2 + 2) { | 738 | if (fw->size < sizeof(name) - 1 + 2 + 2) { |
760 | printk("Error: firmware file %s has invalid size!\n", | 739 | printk("Error: firmware file %s has invalid size!\n", fname); |
761 | fname); | ||
762 | goto corrupt; | 740 | goto corrupt; |
763 | } | 741 | } |
764 | 742 | ||
765 | memcpy(name, p, sizeof(name) - 1); | 743 | memcpy(name, p, sizeof(name) - 1); |
766 | name[sizeof(name) - 1] = 0; | 744 | name[sizeof(name) - 1] = '\0'; |
767 | p += sizeof(name) - 1; | 745 | p += sizeof(name) - 1; |
768 | 746 | ||
769 | priv->firm_version = get_unaligned_le16(p); | 747 | priv->firm_version = get_unaligned_le16(p); |
@@ -920,7 +898,7 @@ static int load_scode(struct dvb_frontend *fe, unsigned int type, | |||
920 | } | 898 | } |
921 | 899 | ||
922 | rc = xc_send_i2c_data(priv, scode_buf, 13); | 900 | rc = xc_send_i2c_data(priv, scode_buf, 13); |
923 | if (rc != XC_RESULT_SUCCESS) { | 901 | if (rc != 0) { |
924 | /* Even if the send failed, make sure we set back to indirect | 902 | /* Even if the send failed, make sure we set back to indirect |
925 | mode */ | 903 | mode */ |
926 | printk("Failed to set scode %d\n", rc); | 904 | printk("Failed to set scode %d\n", rc); |
@@ -953,16 +931,11 @@ static int check_firmware(struct dvb_frontend *fe, unsigned int type, | |||
953 | return rc; | 931 | return rc; |
954 | } | 932 | } |
955 | 933 | ||
956 | #ifdef DJH_DEBUG | ||
957 | if (priv->ctrl.mts && !(type & FM)) | ||
958 | type |= MTS; | ||
959 | #endif | ||
960 | |||
961 | retry: | 934 | retry: |
962 | new_fw.type = type; | 935 | new_fw.type = type; |
963 | new_fw.id = std; | 936 | new_fw.id = std; |
964 | new_fw.std_req = std; | 937 | new_fw.std_req = std; |
965 | new_fw.scode_table = SCODE /* | priv->ctrl.scode_table */; | 938 | new_fw.scode_table = SCODE; |
966 | new_fw.scode_nr = 0; | 939 | new_fw.scode_nr = 0; |
967 | new_fw.int_freq = int_freq; | 940 | new_fw.int_freq = int_freq; |
968 | 941 | ||
@@ -971,15 +944,11 @@ retry: | |||
971 | dump_firm_type(new_fw.type); | 944 | dump_firm_type(new_fw.type); |
972 | printk("(%x), id %016llx, ", new_fw.type, | 945 | printk("(%x), id %016llx, ", new_fw.type, |
973 | (unsigned long long)new_fw.std_req); | 946 | (unsigned long long)new_fw.std_req); |
974 | if (!int_freq) { | 947 | if (!int_freq) |
975 | printk("scode_tbl "); | 948 | printk(KERN_CONT "scode_tbl "); |
976 | #ifdef DJH_DEBUG | 949 | else |
977 | dump_firm_type(priv->ctrl.scode_table); | 950 | printk(KERN_CONT "int_freq %d, ", new_fw.int_freq); |
978 | printk("(%x), ", priv->ctrl.scode_table); | 951 | printk(KERN_CONT "scode_nr %d\n", new_fw.scode_nr); |
979 | #endif | ||
980 | } else | ||
981 | printk("int_freq %d, ", new_fw.int_freq); | ||
982 | printk("scode_nr %d\n", new_fw.scode_nr); | ||
983 | } | 952 | } |
984 | 953 | ||
985 | /* No need to reload base firmware if it matches */ | 954 | /* No need to reload base firmware if it matches */ |
@@ -992,7 +961,7 @@ retry: | |||
992 | memset(&priv->cur_fw, 0, sizeof(priv->cur_fw)); | 961 | memset(&priv->cur_fw, 0, sizeof(priv->cur_fw)); |
993 | 962 | ||
994 | /* Reset is needed before loading firmware */ | 963 | /* Reset is needed before loading firmware */ |
995 | rc = xc4000_TunerReset(fe); | 964 | rc = xc4000_tuner_reset(fe); |
996 | if (rc < 0) | 965 | if (rc < 0) |
997 | goto fail; | 966 | goto fail; |
998 | 967 | ||
@@ -1046,14 +1015,14 @@ skip_std_specific: | |||
1046 | /* Load SCODE firmware, if exists */ | 1015 | /* Load SCODE firmware, if exists */ |
1047 | rc = load_scode(fe, new_fw.type | new_fw.scode_table, &new_fw.id, | 1016 | rc = load_scode(fe, new_fw.type | new_fw.scode_table, &new_fw.id, |
1048 | new_fw.int_freq, new_fw.scode_nr); | 1017 | new_fw.int_freq, new_fw.scode_nr); |
1049 | if (rc != XC_RESULT_SUCCESS) | 1018 | if (rc != 0) |
1050 | dprintk(1, "load scode failed %d\n", rc); | 1019 | dprintk(1, "load scode failed %d\n", rc); |
1051 | 1020 | ||
1052 | check_device: | 1021 | check_device: |
1053 | rc = xc4000_readreg(priv, XREG_PRODUCT_ID, &hwmodel); | 1022 | rc = xc4000_readreg(priv, XREG_PRODUCT_ID, &hwmodel); |
1054 | 1023 | ||
1055 | if (xc_get_version(priv, &hw_major, &hw_minor, &fw_major, | 1024 | if (xc_get_version(priv, &hw_major, &hw_minor, &fw_major, |
1056 | &fw_minor) != XC_RESULT_SUCCESS) { | 1025 | &fw_minor) != 0) { |
1057 | printk("Unable to read tuner registers.\n"); | 1026 | printk("Unable to read tuner registers.\n"); |
1058 | goto fail; | 1027 | goto fail; |
1059 | } | 1028 | } |
@@ -1121,7 +1090,7 @@ static void xc_debug_dump(struct xc4000_priv *priv) | |||
1121 | u8 hw_majorversion = 0, hw_minorversion = 0; | 1090 | u8 hw_majorversion = 0, hw_minorversion = 0; |
1122 | u8 fw_majorversion = 0, fw_minorversion = 0; | 1091 | u8 fw_majorversion = 0, fw_minorversion = 0; |
1123 | 1092 | ||
1124 | xc_get_ADC_Envelope(priv, &adc_envelope); | 1093 | xc_get_adc_envelope(priv, &adc_envelope); |
1125 | dprintk(1, "*** ADC envelope (0-1023) = %d\n", adc_envelope); | 1094 | dprintk(1, "*** ADC envelope (0-1023) = %d\n", adc_envelope); |
1126 | 1095 | ||
1127 | xc_get_frequency_error(priv, &freq_error_hz); | 1096 | xc_get_frequency_error(priv, &freq_error_hz); |
@@ -1235,24 +1204,23 @@ static int xc4000_set_params(struct dvb_frontend *fe, | |||
1235 | __func__, priv->freq_hz); | 1204 | __func__, priv->freq_hz); |
1236 | 1205 | ||
1237 | /* Make sure the correct firmware type is loaded */ | 1206 | /* Make sure the correct firmware type is loaded */ |
1238 | if (check_firmware(fe, type, 0, priv->if_khz) != XC_RESULT_SUCCESS) | 1207 | if (check_firmware(fe, type, 0, priv->if_khz) != 0) |
1239 | goto fail; | 1208 | goto fail; |
1240 | 1209 | ||
1241 | ret = xc_SetSignalSource(priv, priv->rf_mode); | 1210 | ret = xc_set_signal_source(priv, priv->rf_mode); |
1242 | if (ret != XC_RESULT_SUCCESS) { | 1211 | if (ret != 0) { |
1243 | printk(KERN_ERR | 1212 | printk(KERN_ERR "xc4000: xc_set_signal_source(%d) failed\n", |
1244 | "xc4000: xc_SetSignalSource(%d) failed\n", | ||
1245 | priv->rf_mode); | 1213 | priv->rf_mode); |
1246 | goto fail; | 1214 | goto fail; |
1247 | } else { | 1215 | } else { |
1248 | u16 video_mode, audio_mode; | 1216 | u16 video_mode, audio_mode; |
1249 | video_mode = XC4000_Standard[priv->video_standard].VideoMode; | 1217 | video_mode = xc4000_standard[priv->video_standard].video_mode; |
1250 | audio_mode = XC4000_Standard[priv->video_standard].AudioMode; | 1218 | audio_mode = xc4000_standard[priv->video_standard].audio_mode; |
1251 | if (type == DTV6 && priv->firm_version != 0x0102) | 1219 | if (type == DTV6 && priv->firm_version != 0x0102) |
1252 | video_mode |= 0x0001; | 1220 | video_mode |= 0x0001; |
1253 | ret = xc_SetTVStandard(priv, video_mode, audio_mode); | 1221 | ret = xc_set_tv_standard(priv, video_mode, audio_mode); |
1254 | if (ret != XC_RESULT_SUCCESS) { | 1222 | if (ret != 0) { |
1255 | printk(KERN_ERR "xc4000: xc_SetTVStandard failed\n"); | 1223 | printk(KERN_ERR "xc4000: xc_set_tv_standard failed\n"); |
1256 | /* DJH - do not return when it fails... */ | 1224 | /* DJH - do not return when it fails... */ |
1257 | /* goto fail; */ | 1225 | /* goto fail; */ |
1258 | } | 1226 | } |
@@ -1423,27 +1391,25 @@ static int xc4000_set_analog_params(struct dvb_frontend *fe, | |||
1423 | } | 1391 | } |
1424 | 1392 | ||
1425 | tune_channel: | 1393 | tune_channel: |
1426 | /* Fix me: it could be air. */ | 1394 | /* FIXME: it could be air. */ |
1427 | priv->rf_mode = XC_RF_MODE_CABLE; | 1395 | priv->rf_mode = XC_RF_MODE_CABLE; |
1428 | 1396 | ||
1429 | if (check_firmware(fe, type, params->std, | 1397 | if (check_firmware(fe, type, params->std, |
1430 | XC4000_Standard[priv->video_standard].int_freq) | 1398 | xc4000_standard[priv->video_standard].int_freq) != 0) |
1431 | != XC_RESULT_SUCCESS) { | ||
1432 | goto fail; | 1399 | goto fail; |
1433 | } | ||
1434 | 1400 | ||
1435 | ret = xc_SetSignalSource(priv, priv->rf_mode); | 1401 | ret = xc_set_signal_source(priv, priv->rf_mode); |
1436 | if (ret != XC_RESULT_SUCCESS) { | 1402 | if (ret != 0) { |
1437 | printk(KERN_ERR | 1403 | printk(KERN_ERR |
1438 | "xc4000: xc_SetSignalSource(%d) failed\n", | 1404 | "xc4000: xc_set_signal_source(%d) failed\n", |
1439 | priv->rf_mode); | 1405 | priv->rf_mode); |
1440 | goto fail; | 1406 | goto fail; |
1441 | } else { | 1407 | } else { |
1442 | u16 video_mode, audio_mode; | 1408 | u16 video_mode, audio_mode; |
1443 | video_mode = XC4000_Standard[priv->video_standard].VideoMode; | 1409 | video_mode = xc4000_standard[priv->video_standard].video_mode; |
1444 | audio_mode = XC4000_Standard[priv->video_standard].AudioMode; | 1410 | audio_mode = xc4000_standard[priv->video_standard].audio_mode; |
1445 | if (priv->video_standard < XC4000_BG_PAL_A2) { | 1411 | if (priv->video_standard < XC4000_BG_PAL_A2) { |
1446 | if (0 /*type & NOGD*/) | 1412 | if (type & NOGD) |
1447 | video_mode &= 0xFF7F; | 1413 | video_mode &= 0xFF7F; |
1448 | } else if (priv->video_standard < XC4000_I_PAL_NICAM) { | 1414 | } else if (priv->video_standard < XC4000_I_PAL_NICAM) { |
1449 | if (priv->card_type == XC4000_CARD_WINFAST_CX88 && | 1415 | if (priv->card_type == XC4000_CARD_WINFAST_CX88 && |
@@ -1452,9 +1418,9 @@ tune_channel: | |||
1452 | if (audio_std & XC4000_AUDIO_STD_B) | 1418 | if (audio_std & XC4000_AUDIO_STD_B) |
1453 | video_mode |= 0x0080; | 1419 | video_mode |= 0x0080; |
1454 | } | 1420 | } |
1455 | ret = xc_SetTVStandard(priv, video_mode, audio_mode); | 1421 | ret = xc_set_tv_standard(priv, video_mode, audio_mode); |
1456 | if (ret != XC_RESULT_SUCCESS) { | 1422 | if (ret != 0) { |
1457 | printk(KERN_ERR "xc4000: xc_SetTVStandard failed\n"); | 1423 | printk(KERN_ERR "xc4000: xc_set_tv_standard failed\n"); |
1458 | goto fail; | 1424 | goto fail; |
1459 | } | 1425 | } |
1460 | } | 1426 | } |
@@ -1542,7 +1508,7 @@ static int xc4000_get_status(struct dvb_frontend *fe, u32 *status) | |||
1542 | static int xc4000_sleep(struct dvb_frontend *fe) | 1508 | static int xc4000_sleep(struct dvb_frontend *fe) |
1543 | { | 1509 | { |
1544 | struct xc4000_priv *priv = fe->tuner_priv; | 1510 | struct xc4000_priv *priv = fe->tuner_priv; |
1545 | int ret = XC_RESULT_SUCCESS; | 1511 | int ret = 0; |
1546 | 1512 | ||
1547 | dprintk(1, "%s()\n", __func__); | 1513 | dprintk(1, "%s()\n", __func__); |
1548 | 1514 | ||
@@ -1556,14 +1522,13 @@ static int xc4000_sleep(struct dvb_frontend *fe) | |||
1556 | /* force reset and firmware reload */ | 1522 | /* force reset and firmware reload */ |
1557 | priv->cur_fw.type = XC_POWERED_DOWN; | 1523 | priv->cur_fw.type = XC_POWERED_DOWN; |
1558 | 1524 | ||
1559 | if (xc_write_reg(priv, XREG_POWER_DOWN, 0) | 1525 | if (xc_write_reg(priv, XREG_POWER_DOWN, 0) != 0) { |
1560 | != XC_RESULT_SUCCESS) { | ||
1561 | printk(KERN_ERR | 1526 | printk(KERN_ERR |
1562 | "xc4000: %s() unable to shutdown tuner\n", | 1527 | "xc4000: %s() unable to shutdown tuner\n", |
1563 | __func__); | 1528 | __func__); |
1564 | ret = -EREMOTEIO; | 1529 | ret = -EREMOTEIO; |
1565 | } | 1530 | } |
1566 | xc_wait(20); | 1531 | msleep(20); |
1567 | } | 1532 | } |
1568 | 1533 | ||
1569 | mutex_unlock(&priv->lock); | 1534 | mutex_unlock(&priv->lock); |
@@ -1672,8 +1637,7 @@ struct dvb_frontend *xc4000_attach(struct dvb_frontend *fe, | |||
1672 | */ | 1637 | */ |
1673 | 1638 | ||
1674 | if (instance == 1) { | 1639 | if (instance == 1) { |
1675 | if (xc4000_readreg(priv, XREG_PRODUCT_ID, &id) | 1640 | if (xc4000_readreg(priv, XREG_PRODUCT_ID, &id) != 0) |
1676 | != XC_RESULT_SUCCESS) | ||
1677 | goto fail; | 1641 | goto fail; |
1678 | } else { | 1642 | } else { |
1679 | id = ((priv->cur_fw.type & BASE) != 0 ? | 1643 | id = ((priv->cur_fw.type & BASE) != 0 ? |
@@ -1713,7 +1677,7 @@ struct dvb_frontend *xc4000_attach(struct dvb_frontend *fe, | |||
1713 | mutex_lock(&priv->lock); | 1677 | mutex_lock(&priv->lock); |
1714 | ret = xc4000_fwupload(fe); | 1678 | ret = xc4000_fwupload(fe); |
1715 | mutex_unlock(&priv->lock); | 1679 | mutex_unlock(&priv->lock); |
1716 | if (ret != XC_RESULT_SUCCESS) | 1680 | if (ret != 0) |
1717 | goto fail2; | 1681 | goto fail2; |
1718 | } | 1682 | } |
1719 | 1683 | ||
diff --git a/drivers/media/dvb/dvb-usb/dib0700_devices.c b/drivers/media/dvb/dvb-usb/dib0700_devices.c index a5212a5c2b48..d546270d3f5d 100644 --- a/drivers/media/dvb/dvb-usb/dib0700_devices.c +++ b/drivers/media/dvb/dvb-usb/dib0700_devices.c | |||
@@ -2706,13 +2706,14 @@ static struct dibx000_agc_config stk7700p_7000p_xc4000_agc_config = { | |||
2706 | }; | 2706 | }; |
2707 | 2707 | ||
2708 | static struct dibx000_bandwidth_config stk7700p_xc4000_pll_config = { | 2708 | static struct dibx000_bandwidth_config stk7700p_xc4000_pll_config = { |
2709 | 60000, 30000, // internal, sampling | 2709 | 60000, 30000, /* internal, sampling */ |
2710 | 1, 8, 3, 1, 0, // pll_cfg: prediv, ratio, range, reset, bypass | 2710 | 1, 8, 3, 1, 0, /* pll_cfg: prediv, ratio, range, reset, bypass */ |
2711 | 0, 0, 1, 1, 0, // misc: refdiv, bypclk_div, IO_CLK_en_core, ADClkSrc, modulo | 2711 | 0, 0, 1, 1, 0, /* misc: refdiv, bypclk_div, IO_CLK_en_core, */ |
2712 | (3 << 14) | (1 << 12) | (524 << 0), // sad_cfg: refsel, sel, freq_15k | 2712 | /* ADClkSrc, modulo */ |
2713 | 39370534, // ifreq | 2713 | (3 << 14) | (1 << 12) | 524, /* sad_cfg: refsel, sel, freq_15k */ |
2714 | 20452225, // timf | 2714 | 39370534, /* ifreq */ |
2715 | 30000000, // xtal | 2715 | 20452225, /* timf */ |
2716 | 30000000 /* xtal */ | ||
2716 | }; | 2717 | }; |
2717 | 2718 | ||
2718 | /* FIXME: none of these inputs are validated yet */ | 2719 | /* FIXME: none of these inputs are validated yet */ |