[media] xc5000: get rid of positive error codes
Errors should also be negative and should follow the Kernel standards. Signed-off-by: Mauro Carvalho Chehab <m.chehab@samsung.com>
This commit is contained in:
parent
f6fef86341
commit
859ae7f012
|
@ -75,13 +75,6 @@ struct xc5000_priv {
|
||||||
#define XC_RF_MODE_AIR 0
|
#define XC_RF_MODE_AIR 0
|
||||||
#define XC_RF_MODE_CABLE 1
|
#define XC_RF_MODE_CABLE 1
|
||||||
|
|
||||||
/* Result codes */
|
|
||||||
#define XC_RESULT_SUCCESS 0
|
|
||||||
#define XC_RESULT_RESET_FAILURE 1
|
|
||||||
#define XC_RESULT_I2C_WRITE_FAILURE 2
|
|
||||||
#define XC_RESULT_I2C_READ_FAILURE 3
|
|
||||||
#define XC_RESULT_OUT_OF_RANGE 5
|
|
||||||
|
|
||||||
/* Product id */
|
/* Product id */
|
||||||
#define XC_PRODUCT_ID_FW_NOT_LOADED 0x2000
|
#define XC_PRODUCT_ID_FW_NOT_LOADED 0x2000
|
||||||
#define XC_PRODUCT_ID_FW_LOADED 0x1388
|
#define XC_PRODUCT_ID_FW_LOADED 0x1388
|
||||||
|
@ -258,9 +251,9 @@ static int xc_send_i2c_data(struct xc5000_priv *priv, u8 *buf, int len)
|
||||||
|
|
||||||
if (i2c_transfer(priv->i2c_props.adap, &msg, 1) != 1) {
|
if (i2c_transfer(priv->i2c_props.adap, &msg, 1) != 1) {
|
||||||
printk(KERN_ERR "xc5000: I2C write failed (len=%i)\n", len);
|
printk(KERN_ERR "xc5000: I2C write failed (len=%i)\n", len);
|
||||||
return XC_RESULT_I2C_WRITE_FAILURE;
|
return -EREMOTEIO;
|
||||||
}
|
}
|
||||||
return XC_RESULT_SUCCESS;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
#if 0
|
#if 0
|
||||||
|
@ -297,7 +290,7 @@ static int xc5000_readreg(struct xc5000_priv *priv, u16 reg, u16 *val)
|
||||||
}
|
}
|
||||||
|
|
||||||
*val = (bval[0] << 8) | bval[1];
|
*val = (bval[0] << 8) | bval[1];
|
||||||
return XC_RESULT_SUCCESS;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
static void xc_wait(int wait_ms)
|
static void xc_wait(int wait_ms)
|
||||||
|
@ -320,13 +313,13 @@ static int xc5000_TunerReset(struct dvb_frontend *fe)
|
||||||
XC5000_TUNER_RESET, 0);
|
XC5000_TUNER_RESET, 0);
|
||||||
if (ret) {
|
if (ret) {
|
||||||
printk(KERN_ERR "xc5000: reset failed\n");
|
printk(KERN_ERR "xc5000: reset failed\n");
|
||||||
return XC_RESULT_RESET_FAILURE;
|
return ret;
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
printk(KERN_ERR "xc5000: no tuner reset callback function, fatal\n");
|
printk(KERN_ERR "xc5000: no tuner reset callback function, fatal\n");
|
||||||
return XC_RESULT_RESET_FAILURE;
|
return -EINVAL;
|
||||||
}
|
}
|
||||||
return XC_RESULT_SUCCESS;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
static int xc_write_reg(struct xc5000_priv *priv, u16 regAddr, u16 i2cData)
|
static int xc_write_reg(struct xc5000_priv *priv, u16 regAddr, u16 i2cData)
|
||||||
|
@ -340,11 +333,11 @@ static int xc_write_reg(struct xc5000_priv *priv, u16 regAddr, u16 i2cData)
|
||||||
buf[2] = (i2cData >> 8) & 0xFF;
|
buf[2] = (i2cData >> 8) & 0xFF;
|
||||||
buf[3] = i2cData & 0xFF;
|
buf[3] = i2cData & 0xFF;
|
||||||
result = xc_send_i2c_data(priv, buf, 4);
|
result = xc_send_i2c_data(priv, buf, 4);
|
||||||
if (result == XC_RESULT_SUCCESS) {
|
if (result == 0) {
|
||||||
/* wait for busy flag to clear */
|
/* wait for busy flag to clear */
|
||||||
while ((WatchDogTimer > 0) && (result == XC_RESULT_SUCCESS)) {
|
while ((WatchDogTimer > 0) && (result == 0)) {
|
||||||
result = xc5000_readreg(priv, XREG_BUSY, (u16 *)buf);
|
result = xc5000_readreg(priv, XREG_BUSY, (u16 *)buf);
|
||||||
if (result == XC_RESULT_SUCCESS) {
|
if (result == 0) {
|
||||||
if ((buf[0] == 0) && (buf[1] == 0)) {
|
if ((buf[0] == 0) && (buf[1] == 0)) {
|
||||||
/* busy flag cleared */
|
/* busy flag cleared */
|
||||||
break;
|
break;
|
||||||
|
@ -356,7 +349,7 @@ static int xc_write_reg(struct xc5000_priv *priv, u16 regAddr, u16 i2cData)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
if (WatchDogTimer <= 0)
|
if (WatchDogTimer <= 0)
|
||||||
result = XC_RESULT_I2C_WRITE_FAILURE;
|
result = -EREMOTEIO;
|
||||||
|
|
||||||
return result;
|
return result;
|
||||||
}
|
}
|
||||||
|
@ -377,7 +370,7 @@ static int xc_load_i2c_sequence(struct dvb_frontend *fe, const u8 *i2c_sequence)
|
||||||
/* RESET command */
|
/* RESET command */
|
||||||
result = xc5000_TunerReset(fe);
|
result = xc5000_TunerReset(fe);
|
||||||
index += 2;
|
index += 2;
|
||||||
if (result != XC_RESULT_SUCCESS)
|
if (result != 0)
|
||||||
return result;
|
return result;
|
||||||
} else if (len & 0x8000) {
|
} else if (len & 0x8000) {
|
||||||
/* WAIT command */
|
/* WAIT command */
|
||||||
|
@ -404,7 +397,7 @@ static int xc_load_i2c_sequence(struct dvb_frontend *fe, const u8 *i2c_sequence)
|
||||||
result = xc_send_i2c_data(priv, buf,
|
result = xc_send_i2c_data(priv, buf,
|
||||||
nbytes_to_send);
|
nbytes_to_send);
|
||||||
|
|
||||||
if (result != XC_RESULT_SUCCESS)
|
if (result != 0)
|
||||||
return result;
|
return result;
|
||||||
|
|
||||||
pos += nbytes_to_send - 2;
|
pos += nbytes_to_send - 2;
|
||||||
|
@ -412,7 +405,7 @@ static int xc_load_i2c_sequence(struct dvb_frontend *fe, const u8 *i2c_sequence)
|
||||||
index += len;
|
index += len;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
return XC_RESULT_SUCCESS;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
static int xc_initialize(struct xc5000_priv *priv)
|
static int xc_initialize(struct xc5000_priv *priv)
|
||||||
|
@ -437,7 +430,7 @@ static int xc_SetTVStandard(struct xc5000_priv *priv,
|
||||||
}
|
}
|
||||||
|
|
||||||
ret = xc_write_reg(priv, XREG_VIDEO_MODE, VideoMode);
|
ret = xc_write_reg(priv, XREG_VIDEO_MODE, VideoMode);
|
||||||
if (ret == XC_RESULT_SUCCESS)
|
if (ret == 0)
|
||||||
ret = xc_write_reg(priv, XREG_AUDIO_MODE, AudioMode);
|
ret = xc_write_reg(priv, XREG_AUDIO_MODE, AudioMode);
|
||||||
|
|
||||||
return ret;
|
return ret;
|
||||||
|
@ -467,7 +460,7 @@ static int xc_set_RF_frequency(struct xc5000_priv *priv, u32 freq_hz)
|
||||||
|
|
||||||
if ((freq_hz > xc5000_tuner_ops.info.frequency_max) ||
|
if ((freq_hz > xc5000_tuner_ops.info.frequency_max) ||
|
||||||
(freq_hz < xc5000_tuner_ops.info.frequency_min))
|
(freq_hz < xc5000_tuner_ops.info.frequency_min))
|
||||||
return XC_RESULT_OUT_OF_RANGE;
|
return -EINVAL;
|
||||||
|
|
||||||
freq_code = (u16)(freq_hz / 15625);
|
freq_code = (u16)(freq_hz / 15625);
|
||||||
|
|
||||||
|
@ -500,7 +493,7 @@ static int xc_get_frequency_error(struct xc5000_priv *priv, u32 *freq_error_hz)
|
||||||
u32 tmp;
|
u32 tmp;
|
||||||
|
|
||||||
result = xc5000_readreg(priv, XREG_FREQ_ERROR, ®Data);
|
result = xc5000_readreg(priv, XREG_FREQ_ERROR, ®Data);
|
||||||
if (result != XC_RESULT_SUCCESS)
|
if (result != 0)
|
||||||
return result;
|
return result;
|
||||||
|
|
||||||
tmp = (u32)regData;
|
tmp = (u32)regData;
|
||||||
|
@ -521,7 +514,7 @@ static int xc_get_version(struct xc5000_priv *priv,
|
||||||
int result;
|
int result;
|
||||||
|
|
||||||
result = xc5000_readreg(priv, XREG_VERSION, &data);
|
result = xc5000_readreg(priv, XREG_VERSION, &data);
|
||||||
if (result != XC_RESULT_SUCCESS)
|
if (result != 0)
|
||||||
return result;
|
return result;
|
||||||
|
|
||||||
(*hw_majorversion) = (data >> 12) & 0x0F;
|
(*hw_majorversion) = (data >> 12) & 0x0F;
|
||||||
|
@ -543,7 +536,7 @@ static int xc_get_hsync_freq(struct xc5000_priv *priv, u32 *hsync_freq_hz)
|
||||||
int result;
|
int result;
|
||||||
|
|
||||||
result = xc5000_readreg(priv, XREG_HSYNC_FREQ, ®Data);
|
result = xc5000_readreg(priv, XREG_HSYNC_FREQ, ®Data);
|
||||||
if (result != XC_RESULT_SUCCESS)
|
if (result != 0)
|
||||||
return result;
|
return result;
|
||||||
|
|
||||||
(*hsync_freq_hz) = ((regData & 0x0fff) * 763)/100;
|
(*hsync_freq_hz) = ((regData & 0x0fff) * 763)/100;
|
||||||
|
@ -593,7 +586,7 @@ static int xc_tune_channel(struct xc5000_priv *priv, u32 freq_hz, int mode)
|
||||||
|
|
||||||
dprintk(1, "%s(%u)\n", __func__, freq_hz);
|
dprintk(1, "%s(%u)\n", __func__, freq_hz);
|
||||||
|
|
||||||
if (xc_set_RF_frequency(priv, freq_hz) != XC_RESULT_SUCCESS)
|
if (xc_set_RF_frequency(priv, freq_hz) != 0)
|
||||||
return 0;
|
return 0;
|
||||||
|
|
||||||
if (mode == XC_TUNE_ANALOG) {
|
if (mode == XC_TUNE_ANALOG) {
|
||||||
|
@ -607,7 +600,7 @@ static int xc_tune_channel(struct xc5000_priv *priv, u32 freq_hz, int mode)
|
||||||
static int xc_set_xtal(struct dvb_frontend *fe)
|
static int xc_set_xtal(struct dvb_frontend *fe)
|
||||||
{
|
{
|
||||||
struct xc5000_priv *priv = fe->tuner_priv;
|
struct xc5000_priv *priv = fe->tuner_priv;
|
||||||
int ret = XC_RESULT_SUCCESS;
|
int ret = 0;
|
||||||
|
|
||||||
switch (priv->chip_id) {
|
switch (priv->chip_id) {
|
||||||
default:
|
default:
|
||||||
|
@ -649,23 +642,22 @@ static int xc5000_fwupload(struct dvb_frontend *fe)
|
||||||
priv->i2c_props.adap->dev.parent);
|
priv->i2c_props.adap->dev.parent);
|
||||||
if (ret) {
|
if (ret) {
|
||||||
printk(KERN_ERR "xc5000: Upload failed. (file not found?)\n");
|
printk(KERN_ERR "xc5000: Upload failed. (file not found?)\n");
|
||||||
ret = XC_RESULT_RESET_FAILURE;
|
|
||||||
goto out;
|
goto out;
|
||||||
} else {
|
} else {
|
||||||
printk(KERN_DEBUG "xc5000: firmware read %Zu bytes.\n",
|
printk(KERN_DEBUG "xc5000: firmware read %Zu bytes.\n",
|
||||||
fw->size);
|
fw->size);
|
||||||
ret = XC_RESULT_SUCCESS;
|
ret = 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (fw->size != desired_fw->size) {
|
if (fw->size != desired_fw->size) {
|
||||||
printk(KERN_ERR "xc5000: firmware incorrect size\n");
|
printk(KERN_ERR "xc5000: firmware incorrect size\n");
|
||||||
ret = XC_RESULT_RESET_FAILURE;
|
ret = -EINVAL;
|
||||||
} else {
|
} else {
|
||||||
printk(KERN_INFO "xc5000: firmware uploading...\n");
|
printk(KERN_INFO "xc5000: firmware uploading...\n");
|
||||||
ret = xc_load_i2c_sequence(fe, fw->data);
|
ret = xc_load_i2c_sequence(fe, fw->data);
|
||||||
if (XC_RESULT_SUCCESS == ret)
|
if (0 == ret)
|
||||||
ret = xc_set_xtal(fe);
|
ret = xc_set_xtal(fe);
|
||||||
if (XC_RESULT_SUCCESS == ret)
|
if (0 == ret)
|
||||||
printk(KERN_INFO "xc5000: firmware upload complete...\n");
|
printk(KERN_INFO "xc5000: firmware upload complete...\n");
|
||||||
else
|
else
|
||||||
printk(KERN_ERR "xc5000: firmware upload failed...\n");
|
printk(KERN_ERR "xc5000: firmware upload failed...\n");
|
||||||
|
@ -744,7 +736,7 @@ static int xc5000_set_params(struct dvb_frontend *fe)
|
||||||
u32 freq = fe->dtv_property_cache.frequency;
|
u32 freq = fe->dtv_property_cache.frequency;
|
||||||
u32 delsys = fe->dtv_property_cache.delivery_system;
|
u32 delsys = fe->dtv_property_cache.delivery_system;
|
||||||
|
|
||||||
if (xc_load_fw_and_init_tuner(fe, 0) != XC_RESULT_SUCCESS) {
|
if (xc_load_fw_and_init_tuner(fe, 0) != 0) {
|
||||||
dprintk(1, "Unable to load firmware and init tuner\n");
|
dprintk(1, "Unable to load firmware and init tuner\n");
|
||||||
return -EINVAL;
|
return -EINVAL;
|
||||||
}
|
}
|
||||||
|
@ -821,7 +813,7 @@ static int xc5000_set_params(struct dvb_frontend *fe)
|
||||||
__func__, freq, priv->freq_hz);
|
__func__, freq, priv->freq_hz);
|
||||||
|
|
||||||
ret = xc_SetSignalSource(priv, priv->rf_mode);
|
ret = xc_SetSignalSource(priv, priv->rf_mode);
|
||||||
if (ret != XC_RESULT_SUCCESS) {
|
if (ret != 0) {
|
||||||
printk(KERN_ERR
|
printk(KERN_ERR
|
||||||
"xc5000: xc_SetSignalSource(%d) failed\n",
|
"xc5000: xc_SetSignalSource(%d) failed\n",
|
||||||
priv->rf_mode);
|
priv->rf_mode);
|
||||||
|
@ -831,13 +823,13 @@ static int xc5000_set_params(struct dvb_frontend *fe)
|
||||||
ret = xc_SetTVStandard(priv,
|
ret = xc_SetTVStandard(priv,
|
||||||
XC5000_Standard[priv->video_standard].VideoMode,
|
XC5000_Standard[priv->video_standard].VideoMode,
|
||||||
XC5000_Standard[priv->video_standard].AudioMode, 0);
|
XC5000_Standard[priv->video_standard].AudioMode, 0);
|
||||||
if (ret != XC_RESULT_SUCCESS) {
|
if (ret != 0) {
|
||||||
printk(KERN_ERR "xc5000: xc_SetTVStandard failed\n");
|
printk(KERN_ERR "xc5000: xc_SetTVStandard failed\n");
|
||||||
return -EREMOTEIO;
|
return -EREMOTEIO;
|
||||||
}
|
}
|
||||||
|
|
||||||
ret = xc_set_IF_frequency(priv, priv->if_khz);
|
ret = xc_set_IF_frequency(priv, priv->if_khz);
|
||||||
if (ret != XC_RESULT_SUCCESS) {
|
if (ret != 0) {
|
||||||
printk(KERN_ERR "xc5000: xc_Set_IF_frequency(%d) failed\n",
|
printk(KERN_ERR "xc5000: xc_Set_IF_frequency(%d) failed\n",
|
||||||
priv->if_khz);
|
priv->if_khz);
|
||||||
return -EIO;
|
return -EIO;
|
||||||
|
@ -862,15 +854,15 @@ static int xc5000_is_firmware_loaded(struct dvb_frontend *fe)
|
||||||
u16 id;
|
u16 id;
|
||||||
|
|
||||||
ret = xc5000_readreg(priv, XREG_PRODUCT_ID, &id);
|
ret = xc5000_readreg(priv, XREG_PRODUCT_ID, &id);
|
||||||
if (ret == XC_RESULT_SUCCESS) {
|
if (ret == 0) {
|
||||||
if (id == XC_PRODUCT_ID_FW_NOT_LOADED)
|
if (id == XC_PRODUCT_ID_FW_NOT_LOADED)
|
||||||
ret = XC_RESULT_RESET_FAILURE;
|
ret = -ENOENT;
|
||||||
else
|
else
|
||||||
ret = XC_RESULT_SUCCESS;
|
ret = 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
dprintk(1, "%s() returns %s id = 0x%x\n", __func__,
|
dprintk(1, "%s() returns %s id = 0x%x\n", __func__,
|
||||||
ret == XC_RESULT_SUCCESS ? "True" : "False", id);
|
ret == 0 ? "True" : "False", id);
|
||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -937,7 +929,7 @@ static int xc5000_set_tv_freq(struct dvb_frontend *fe,
|
||||||
|
|
||||||
tune_channel:
|
tune_channel:
|
||||||
ret = xc_SetSignalSource(priv, priv->rf_mode);
|
ret = xc_SetSignalSource(priv, priv->rf_mode);
|
||||||
if (ret != XC_RESULT_SUCCESS) {
|
if (ret != 0) {
|
||||||
printk(KERN_ERR
|
printk(KERN_ERR
|
||||||
"xc5000: xc_SetSignalSource(%d) failed\n",
|
"xc5000: xc_SetSignalSource(%d) failed\n",
|
||||||
priv->rf_mode);
|
priv->rf_mode);
|
||||||
|
@ -947,7 +939,7 @@ tune_channel:
|
||||||
ret = xc_SetTVStandard(priv,
|
ret = xc_SetTVStandard(priv,
|
||||||
XC5000_Standard[priv->video_standard].VideoMode,
|
XC5000_Standard[priv->video_standard].VideoMode,
|
||||||
XC5000_Standard[priv->video_standard].AudioMode, 0);
|
XC5000_Standard[priv->video_standard].AudioMode, 0);
|
||||||
if (ret != XC_RESULT_SUCCESS) {
|
if (ret != 0) {
|
||||||
printk(KERN_ERR "xc5000: xc_SetTVStandard failed\n");
|
printk(KERN_ERR "xc5000: xc_SetTVStandard failed\n");
|
||||||
return -EREMOTEIO;
|
return -EREMOTEIO;
|
||||||
}
|
}
|
||||||
|
@ -966,7 +958,7 @@ tune_channel:
|
||||||
/* PLL is unlocked, force reload of the firmware */
|
/* PLL is unlocked, force reload of the firmware */
|
||||||
dprintk(1, "xc5000: PLL not locked (0x%x). Reloading...\n",
|
dprintk(1, "xc5000: PLL not locked (0x%x). Reloading...\n",
|
||||||
pll_lock_status);
|
pll_lock_status);
|
||||||
if (xc_load_fw_and_init_tuner(fe, 1) != XC_RESULT_SUCCESS) {
|
if (xc_load_fw_and_init_tuner(fe, 1) != 0) {
|
||||||
printk(KERN_ERR "xc5000: Unable to reload fw\n");
|
printk(KERN_ERR "xc5000: Unable to reload fw\n");
|
||||||
return -EREMOTEIO;
|
return -EREMOTEIO;
|
||||||
}
|
}
|
||||||
|
@ -1011,13 +1003,13 @@ static int xc5000_set_radio_freq(struct dvb_frontend *fe,
|
||||||
ret = xc_SetTVStandard(priv, XC5000_Standard[radio_input].VideoMode,
|
ret = xc_SetTVStandard(priv, XC5000_Standard[radio_input].VideoMode,
|
||||||
XC5000_Standard[radio_input].AudioMode, radio_input);
|
XC5000_Standard[radio_input].AudioMode, radio_input);
|
||||||
|
|
||||||
if (ret != XC_RESULT_SUCCESS) {
|
if (ret != 0) {
|
||||||
printk(KERN_ERR "xc5000: xc_SetTVStandard failed\n");
|
printk(KERN_ERR "xc5000: xc_SetTVStandard failed\n");
|
||||||
return -EREMOTEIO;
|
return -EREMOTEIO;
|
||||||
}
|
}
|
||||||
|
|
||||||
ret = xc_SetSignalSource(priv, priv->rf_mode);
|
ret = xc_SetSignalSource(priv, priv->rf_mode);
|
||||||
if (ret != XC_RESULT_SUCCESS) {
|
if (ret != 0) {
|
||||||
printk(KERN_ERR
|
printk(KERN_ERR
|
||||||
"xc5000: xc_SetSignalSource(%d) failed\n",
|
"xc5000: xc_SetSignalSource(%d) failed\n",
|
||||||
priv->rf_mode);
|
priv->rf_mode);
|
||||||
|
@ -1044,7 +1036,7 @@ static int xc5000_set_analog_params(struct dvb_frontend *fe,
|
||||||
if (priv->i2c_props.adap == NULL)
|
if (priv->i2c_props.adap == NULL)
|
||||||
return -EINVAL;
|
return -EINVAL;
|
||||||
|
|
||||||
if (xc_load_fw_and_init_tuner(fe, 0) != XC_RESULT_SUCCESS) {
|
if (xc_load_fw_and_init_tuner(fe, 0) != 0) {
|
||||||
dprintk(1, "Unable to load firmware and init tuner\n");
|
dprintk(1, "Unable to load firmware and init tuner\n");
|
||||||
return -EINVAL;
|
return -EINVAL;
|
||||||
}
|
}
|
||||||
|
@ -1105,23 +1097,23 @@ static int xc5000_get_status(struct dvb_frontend *fe, u32 *status)
|
||||||
static int xc_load_fw_and_init_tuner(struct dvb_frontend *fe, int force)
|
static int xc_load_fw_and_init_tuner(struct dvb_frontend *fe, int force)
|
||||||
{
|
{
|
||||||
struct xc5000_priv *priv = fe->tuner_priv;
|
struct xc5000_priv *priv = fe->tuner_priv;
|
||||||
int ret = XC_RESULT_SUCCESS;
|
int ret = 0;
|
||||||
u16 pll_lock_status;
|
u16 pll_lock_status;
|
||||||
u16 fw_ck;
|
u16 fw_ck;
|
||||||
|
|
||||||
if (force || xc5000_is_firmware_loaded(fe) != XC_RESULT_SUCCESS) {
|
if (force || xc5000_is_firmware_loaded(fe) != 0) {
|
||||||
|
|
||||||
fw_retry:
|
fw_retry:
|
||||||
|
|
||||||
ret = xc5000_fwupload(fe);
|
ret = xc5000_fwupload(fe);
|
||||||
if (ret != XC_RESULT_SUCCESS)
|
if (ret != 0)
|
||||||
return ret;
|
return ret;
|
||||||
|
|
||||||
msleep(20);
|
msleep(20);
|
||||||
|
|
||||||
if (priv->fw_checksum_supported) {
|
if (priv->fw_checksum_supported) {
|
||||||
if (xc5000_readreg(priv, XREG_FW_CHECKSUM, &fw_ck)
|
if (xc5000_readreg(priv, XREG_FW_CHECKSUM, &fw_ck)
|
||||||
!= XC_RESULT_SUCCESS) {
|
!= 0) {
|
||||||
dprintk(1, "%s() FW checksum reading failed.\n",
|
dprintk(1, "%s() FW checksum reading failed.\n",
|
||||||
__func__);
|
__func__);
|
||||||
goto fw_retry;
|
goto fw_retry;
|
||||||
|
@ -1137,7 +1129,7 @@ fw_retry:
|
||||||
/* Start the tuner self-calibration process */
|
/* Start the tuner self-calibration process */
|
||||||
ret |= xc_initialize(priv);
|
ret |= xc_initialize(priv);
|
||||||
|
|
||||||
if (ret != XC_RESULT_SUCCESS)
|
if (ret != 0)
|
||||||
goto fw_retry;
|
goto fw_retry;
|
||||||
|
|
||||||
/* Wait for calibration to complete.
|
/* Wait for calibration to complete.
|
||||||
|
@ -1148,7 +1140,7 @@ fw_retry:
|
||||||
xc_wait(100);
|
xc_wait(100);
|
||||||
|
|
||||||
if (priv->init_status_supported) {
|
if (priv->init_status_supported) {
|
||||||
if (xc5000_readreg(priv, XREG_INIT_STATUS, &fw_ck) != XC_RESULT_SUCCESS) {
|
if (xc5000_readreg(priv, XREG_INIT_STATUS, &fw_ck) != 0) {
|
||||||
dprintk(1, "%s() FW failed reading init status.\n",
|
dprintk(1, "%s() FW failed reading init status.\n",
|
||||||
__func__);
|
__func__);
|
||||||
goto fw_retry;
|
goto fw_retry;
|
||||||
|
@ -1191,13 +1183,13 @@ static int xc5000_sleep(struct dvb_frontend *fe)
|
||||||
was removed in newer versions of the firmware. The "supported"
|
was removed in newer versions of the firmware. The "supported"
|
||||||
way to sleep the tuner is to pull the reset pin low for 10ms */
|
way to sleep the tuner is to pull the reset pin low for 10ms */
|
||||||
ret = xc5000_TunerReset(fe);
|
ret = xc5000_TunerReset(fe);
|
||||||
if (ret != XC_RESULT_SUCCESS) {
|
if (ret != 0) {
|
||||||
printk(KERN_ERR
|
printk(KERN_ERR
|
||||||
"xc5000: %s() unable to shutdown tuner\n",
|
"xc5000: %s() unable to shutdown tuner\n",
|
||||||
__func__);
|
__func__);
|
||||||
return -EREMOTEIO;
|
return -EREMOTEIO;
|
||||||
} else
|
} else
|
||||||
return XC_RESULT_SUCCESS;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
static int xc5000_init(struct dvb_frontend *fe)
|
static int xc5000_init(struct dvb_frontend *fe)
|
||||||
|
@ -1205,7 +1197,7 @@ static int xc5000_init(struct dvb_frontend *fe)
|
||||||
struct xc5000_priv *priv = fe->tuner_priv;
|
struct xc5000_priv *priv = fe->tuner_priv;
|
||||||
dprintk(1, "%s()\n", __func__);
|
dprintk(1, "%s()\n", __func__);
|
||||||
|
|
||||||
if (xc_load_fw_and_init_tuner(fe, 0) != XC_RESULT_SUCCESS) {
|
if (xc_load_fw_and_init_tuner(fe, 0) != 0) {
|
||||||
printk(KERN_ERR "xc5000: Unable to initialise tuner\n");
|
printk(KERN_ERR "xc5000: Unable to initialise tuner\n");
|
||||||
return -EREMOTEIO;
|
return -EREMOTEIO;
|
||||||
}
|
}
|
||||||
|
@ -1327,7 +1319,7 @@ struct dvb_frontend *xc5000_attach(struct dvb_frontend *fe,
|
||||||
/* Check if firmware has been loaded. It is possible that another
|
/* Check if firmware has been loaded. It is possible that another
|
||||||
instance of the driver has loaded the firmware.
|
instance of the driver has loaded the firmware.
|
||||||
*/
|
*/
|
||||||
if (xc5000_readreg(priv, XREG_PRODUCT_ID, &id) != XC_RESULT_SUCCESS)
|
if (xc5000_readreg(priv, XREG_PRODUCT_ID, &id) != 0)
|
||||||
goto fail;
|
goto fail;
|
||||||
|
|
||||||
switch (id) {
|
switch (id) {
|
||||||
|
|
Loading…
Reference in New Issue