Commit fbe4a29f authored by Istvan Varga's avatar Istvan Varga Committed by Mauro Carvalho Chehab

[media] xc4000: code cleanup

This is the first of a set of patches that update the original xc4000
sources to my modified version. It removes some unused code, and makes
a few minor formatting changes.

[mchehab@redhat.com: re-add XC_TUNE_ANALOG/XC_TUNE_DIGITAL constants, to avoid compilation breakage]
Signed-off-by: default avatarIstvan Varga <istvan_v@mailbox.hu>
Signed-off-by: default avatarMauro Carvalho Chehab <mchehab@redhat.com>
parent e3bb7c60
...@@ -55,8 +55,6 @@ static LIST_HEAD(hybrid_tuner_instance_list); ...@@ -55,8 +55,6 @@ static LIST_HEAD(hybrid_tuner_instance_list);
/* Note that the last version digit is my internal build number (so I can /* Note that the last version digit is my internal build number (so I can
rev the firmware even if the core Xceive firmware was unchanged) */ rev the firmware even if the core Xceive firmware was unchanged) */
#define XC4000_DEFAULT_FIRMWARE "dvb-fe-xc4000-1.4.1.fw" #define XC4000_DEFAULT_FIRMWARE "dvb-fe-xc4000-1.4.1.fw"
#define XC4000_DEFAULT_FIRMWARE_SIZE 18643
/* struct for storing firmware table */ /* struct for storing firmware table */
struct firmware_description { struct firmware_description {
...@@ -87,11 +85,11 @@ struct xc4000_priv { ...@@ -87,11 +85,11 @@ struct xc4000_priv {
u32 bandwidth; u32 bandwidth;
u8 video_standard; u8 video_standard;
u8 rf_mode; u8 rf_mode;
// struct xc2028_ctrl ctrl; u8 ignore_i2c_write_errors;
/* struct xc2028_ctrl ctrl; */
struct firmware_properties cur_fw; struct firmware_properties cur_fw;
__u16 hwmodel; __u16 hwmodel;
__u16 hwvers; __u16 hwvers;
u8 ignore_i2c_write_errors;
}; };
/* Misc Defines */ /* Misc Defines */
...@@ -167,10 +165,10 @@ struct xc4000_priv { ...@@ -167,10 +165,10 @@ struct xc4000_priv {
For the RESET and WAIT commands, the two following bytes will contain For the RESET and WAIT commands, the two following bytes will contain
immediately the length of the following transaction. immediately the length of the following transaction.
*/ */
struct XC_TV_STANDARD { struct XC_TV_STANDARD {
char *Name; const char *Name;
u16 AudioMode; u16 AudioMode;
u16 VideoMode; u16 VideoMode;
}; };
...@@ -200,33 +198,6 @@ struct XC_TV_STANDARD { ...@@ -200,33 +198,6 @@ struct XC_TV_STANDARD {
#define XC4000_FM_Radio_INPUT2 21 #define XC4000_FM_Radio_INPUT2 21
#define XC4000_FM_Radio_INPUT1 22 #define XC4000_FM_Radio_INPUT1 22
/* WAS :
static struct XC_TV_STANDARD XC4000_Standard[MAX_TV_STANDARD] = {
{"M/N-NTSC/PAL-BTSC", 0x0400, 0x8020},
{"M/N-NTSC/PAL-A2", 0x0600, 0x8020},
{"M/N-NTSC/PAL-EIAJ", 0x0440, 0x8020},
{"M/N-NTSC/PAL-Mono", 0x0478, 0x8020},
{"B/G-PAL-A2", 0x0A00, 0x8049},
{"B/G-PAL-NICAM", 0x0C04, 0x8049},
{"B/G-PAL-MONO", 0x0878, 0x8059},
{"I-PAL-NICAM", 0x1080, 0x8009},
{"I-PAL-NICAM-MONO", 0x0E78, 0x8009},
{"D/K-PAL-A2", 0x1600, 0x8009},
{"D/K-PAL-NICAM", 0x0E80, 0x8009},
{"D/K-PAL-MONO", 0x1478, 0x8009},
{"D/K-SECAM-A2 DK1", 0x1200, 0x8009},
{"D/K-SECAM-A2 L/DK3", 0x0E00, 0x8009},
{"D/K-SECAM-A2 MONO", 0x1478, 0x8009},
{"L-SECAM-NICAM", 0x8E82, 0x0009},
{"L'-SECAM-NICAM", 0x8E82, 0x4009},
{"DTV6", 0x00C0, 0x8002},
{"DTV8", 0x00C0, 0x800B},
{"DTV7/8", 0x00C0, 0x801B},
{"DTV7", 0x00C0, 0x8007},
{"FM Radio-INPUT2", 0x9802, 0x9002},
{"FM Radio-INPUT1", 0x0208, 0x9002}
};*/
static struct XC_TV_STANDARD XC4000_Standard[MAX_TV_STANDARD] = { static struct XC_TV_STANDARD XC4000_Standard[MAX_TV_STANDARD] = {
{"M/N-NTSC/PAL-BTSC", 0x0000, 0x8020}, {"M/N-NTSC/PAL-BTSC", 0x0000, 0x8020},
{"M/N-NTSC/PAL-A2", 0x0000, 0x8020}, {"M/N-NTSC/PAL-A2", 0x0000, 0x8020},
...@@ -253,7 +224,6 @@ static struct XC_TV_STANDARD XC4000_Standard[MAX_TV_STANDARD] = { ...@@ -253,7 +224,6 @@ static struct XC_TV_STANDARD XC4000_Standard[MAX_TV_STANDARD] = {
{"FM Radio-INPUT1", 0x0008, 0x9000} {"FM Radio-INPUT1", 0x0008, 0x9000}
}; };
static int xc4000_is_firmware_loaded(struct dvb_frontend *fe);
static int xc4000_readreg(struct xc4000_priv *priv, u16 reg, u16 *val); static int xc4000_readreg(struct xc4000_priv *priv, u16 reg, u16 *val);
static int xc4000_TunerReset(struct dvb_frontend *fe); static int xc4000_TunerReset(struct dvb_frontend *fe);
...@@ -275,10 +245,6 @@ static int xc_send_i2c_data(struct xc4000_priv *priv, u8 *buf, int len) ...@@ -275,10 +245,6 @@ static int xc_send_i2c_data(struct xc4000_priv *priv, u8 *buf, int len)
return XC_RESULT_SUCCESS; return XC_RESULT_SUCCESS;
} }
/* This routine is never used because the only time we read data from the
i2c bus is when we read registers, and we want that to be an atomic i2c
transaction in case we are on a multi-master bus */
static void xc_wait(int wait_ms) static void xc_wait(int wait_ms)
{ {
msleep(wait_ms); msleep(wait_ms);
...@@ -431,7 +397,6 @@ static int xc_set_RF_frequency(struct xc4000_priv *priv, u32 freq_hz) ...@@ -431,7 +397,6 @@ static int xc_set_RF_frequency(struct xc4000_priv *priv, u32 freq_hz)
return xc_write_reg(priv, XREG_RF_FREQ, freq_code); /* WAS: XREG_FINERFREQ */ return xc_write_reg(priv, XREG_RF_FREQ, freq_code); /* WAS: XREG_FINERFREQ */
} }
static int xc_get_ADC_Envelope(struct xc4000_priv *priv, u16 *adc_envelope) static int xc_get_ADC_Envelope(struct xc4000_priv *priv, u16 *adc_envelope)
{ {
return xc4000_readreg(priv, XREG_ADC_ENV, adc_envelope); return xc4000_readreg(priv, XREG_ADC_ENV, adc_envelope);
...@@ -476,12 +441,6 @@ static int xc_get_version(struct xc4000_priv *priv, ...@@ -476,12 +441,6 @@ static int xc_get_version(struct xc4000_priv *priv,
return 0; return 0;
} }
/* WAS THERE
static int xc_get_buildversion(struct xc4000_priv *priv, u16 *buildrev)
{
return xc4000_readreg(priv, XREG_BUILD, buildrev);
}*/
static int xc_get_hsync_freq(struct xc4000_priv *priv, u32 *hsync_freq_hz) static int xc_get_hsync_freq(struct xc4000_priv *priv, u32 *hsync_freq_hz)
{ {
u16 regData; u16 regData;
...@@ -694,7 +653,6 @@ static int seek_firmware(struct dvb_frontend *fe, unsigned int type, ...@@ -694,7 +653,6 @@ static int seek_firmware(struct dvb_frontend *fe, unsigned int type,
if (best_nr_matches > 0) { if (best_nr_matches > 0) {
printk("Selecting best matching firmware (%d bits) for " printk("Selecting best matching firmware (%d bits) for "
"type=", best_nr_matches); "type=", best_nr_matches);
// dump_firm_type(type);
printk("(%x), id %016llx:\n", type, (unsigned long long)*id); printk("(%x), id %016llx:\n", type, (unsigned long long)*id);
i = best_i; i = best_i;
goto found; goto found;
...@@ -749,7 +707,7 @@ static int xc4000_fwupload(struct dvb_frontend *fe) ...@@ -749,7 +707,7 @@ static int xc4000_fwupload(struct dvb_frontend *fe)
int rc = 0; int rc = 0;
int n, n_array; int n, n_array;
char name[33]; char name[33];
char *fname; const char *fname;
fname = XC4000_DEFAULT_FIRMWARE; fname = XC4000_DEFAULT_FIRMWARE;
...@@ -831,7 +789,6 @@ static int xc4000_fwupload(struct dvb_frontend *fe) ...@@ -831,7 +789,6 @@ static int xc4000_fwupload(struct dvb_frontend *fe)
if (!size || size > endp - p) { if (!size || size > endp - p) {
printk("Firmware type "); printk("Firmware type ");
// dump_firm_type(type);
printk("(%x), id %llx is corrupted " printk("(%x), id %llx is corrupted "
"(size=%d, expected %d)\n", "(size=%d, expected %d)\n",
type, (unsigned long long)id, type, (unsigned long long)id,
...@@ -877,7 +834,6 @@ static int xc4000_fwupload(struct dvb_frontend *fe) ...@@ -877,7 +834,6 @@ static int xc4000_fwupload(struct dvb_frontend *fe)
err: err:
printk("Releasing partially loaded firmware file.\n"); printk("Releasing partially loaded firmware file.\n");
// free_firmware(priv);
done: done:
release_firmware(fw); release_firmware(fw);
...@@ -986,8 +942,7 @@ static int check_firmware(struct dvb_frontend *fe, unsigned int type, ...@@ -986,8 +942,7 @@ static int check_firmware(struct dvb_frontend *fe, unsigned int type,
new_fw.type = type; new_fw.type = type;
new_fw.id = std; new_fw.id = std;
new_fw.std_req = std; new_fw.std_req = std;
// new_fw.scode_table = SCODE | priv->ctrl.scode_table; new_fw.scode_table = SCODE /* | priv->ctrl.scode_table */;
new_fw.scode_table = SCODE;
new_fw.scode_nr = 0; new_fw.scode_nr = 0;
new_fw.int_freq = int_freq; new_fw.int_freq = int_freq;
...@@ -1148,7 +1103,6 @@ static void xc_debug_dump(struct xc4000_priv *priv) ...@@ -1148,7 +1103,6 @@ static void xc_debug_dump(struct xc4000_priv *priv)
u16 quality; u16 quality;
u8 hw_majorversion = 0, hw_minorversion = 0; u8 hw_majorversion = 0, hw_minorversion = 0;
u8 fw_majorversion = 0, fw_minorversion = 0; u8 fw_majorversion = 0, fw_minorversion = 0;
// u16 fw_buildversion = 0;
/* Wait for stats to stabilize. /* Wait for stats to stabilize.
* Frame Lines needs two frame times after initial lock * Frame Lines needs two frame times after initial lock
...@@ -1168,12 +1122,7 @@ static void xc_debug_dump(struct xc4000_priv *priv) ...@@ -1168,12 +1122,7 @@ static void xc_debug_dump(struct xc4000_priv *priv)
xc_get_version(priv, &hw_majorversion, &hw_minorversion, xc_get_version(priv, &hw_majorversion, &hw_minorversion,
&fw_majorversion, &fw_minorversion); &fw_majorversion, &fw_minorversion);
// WAS:
// xc_get_buildversion(priv, &fw_buildversion);
// dprintk(1, "*** HW: V%02x.%02x, FW: V%02x.%02x.%04x\n",
// hw_majorversion, hw_minorversion,
// fw_majorversion, fw_minorversion, fw_buildversion);
// NOW:
dprintk(1, "*** HW: V%02x.%02x, FW: V%02x.%02x\n", dprintk(1, "*** HW: V%02x.%02x, FW: V%02x.%02x\n",
hw_majorversion, hw_minorversion, hw_majorversion, hw_minorversion,
fw_majorversion, fw_minorversion); fw_majorversion, fw_minorversion);
...@@ -1290,25 +1239,6 @@ static int xc4000_set_params(struct dvb_frontend *fe, ...@@ -1290,25 +1239,6 @@ static int xc4000_set_params(struct dvb_frontend *fe,
return 0; return 0;
} }
static int xc4000_is_firmware_loaded(struct dvb_frontend *fe)
{
struct xc4000_priv *priv = fe->tuner_priv;
int ret;
u16 id;
ret = xc4000_readreg(priv, XREG_PRODUCT_ID, &id);
if (ret == XC_RESULT_SUCCESS) {
if (id == XC_PRODUCT_ID_FW_NOT_LOADED)
ret = XC_RESULT_RESET_FAILURE;
else
ret = XC_RESULT_SUCCESS;
}
dprintk(1, "%s() returns %s id = 0x%x\n", __func__,
ret == XC_RESULT_SUCCESS ? "True" : "False", id);
return ret;
}
static int xc4000_set_analog_params(struct dvb_frontend *fe, static int xc4000_set_analog_params(struct dvb_frontend *fe,
struct analog_parameters *params) struct analog_parameters *params)
{ {
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment