Commit d14361e4 authored by Mauro Carvalho Chehab's avatar Mauro Carvalho Chehab

V4L/DVB (12825): tm6000: I2C reading operations is not reliable on tm6000

tm6000 sometimes can't read from i2c, but this is currently required for
tuner-xc2028 to work.

This patch adds an option to tuner-xc2028 to not rely on i2c reading.
Signed-off-by: default avatarMauro Carvalho Chehab <mchehab@redhat.com>
Signed-off-by: default avatarMauro Carvalho Chehab <mchehab@redhat.com>
parent e839e4e5
...@@ -812,8 +812,14 @@ check_device: ...@@ -812,8 +812,14 @@ check_device:
/* Check firmware version against what we downloaded. */ /* Check firmware version against what we downloaded. */
if (priv->firm_version != ((version & 0xf0) << 4 | (version & 0x0f))) { if (priv->firm_version != ((version & 0xf0) << 4 | (version & 0x0f))) {
if (!priv->ctrl.read_not_reliable) {
tuner_err("Incorrect readback of firmware version.\n"); tuner_err("Incorrect readback of firmware version.\n");
goto fail; goto fail;
} else {
tuner_err("Returned an incorrect version. However, "
"read is not reliable enough. Ignoring it.\n");
hwmodel = 3028;
}
} }
/* Check that the tuner hardware model remains consistent over time. */ /* Check that the tuner hardware model remains consistent over time. */
......
...@@ -40,6 +40,7 @@ struct xc2028_ctrl { ...@@ -40,6 +40,7 @@ struct xc2028_ctrl {
unsigned int vhfbw7:1; unsigned int vhfbw7:1;
unsigned int uhfbw8:1; unsigned int uhfbw8:1;
unsigned int disable_power_mgmt:1; unsigned int disable_power_mgmt:1;
unsigned int read_not_reliable:1;
unsigned int demod; unsigned int demod;
enum firmware_type type:2; enum firmware_type type:2;
}; };
......
...@@ -189,6 +189,7 @@ static void tm6000_config_tuner (struct tm6000_core *dev) ...@@ -189,6 +189,7 @@ static void tm6000_config_tuner (struct tm6000_core *dev)
ctl.fname = "tm6000-xc3028.fw"; ctl.fname = "tm6000-xc3028.fw";
ctl.mts = 1; ctl.mts = 1;
ctl.read_not_reliable = 1;
xc2028_cfg.tuner = TUNER_XC2028; xc2028_cfg.tuner = TUNER_XC2028;
xc2028_cfg.priv = &ctl; xc2028_cfg.priv = &ctl;
......
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