Commit 8354b196 authored by Michael Krufky's avatar Michael Krufky Committed by Chris Wright

[PATCH] DVB: fix dvb_pll_attach for mt352/zl10353 in cx88-dvb, and nxt200x

DVB: fix dvb_pll_attach for mt352/zl10353 in cx88-dvb, and nxt200x

Typical wiring of MT352, ZL10353, NXT2002 and NXT2004 based tuners
differ from dvb-pll's expectation that the PLL is directly accessible.
On these boards, the PLL is actually hidden behind the demodulator, and
as such can only be accessed via the demodulator's interface.  It was
failing to communicate with the PLL during an attach test and
subsequently not connecting the tuner ops.

By passing a NULL I2C bus handle to dvb_pll_attach, this accessibility
check can be bypassed.  Do this for the affected boards.  Also fix a
possible NULL dereference at sleep time, which would otherwise be
exposed by this change.

This patch has been backported to the 2.6.18.y stable kernel series
from the original changesets from Chris Pascoe and Michael Krufky,
already present in the upstream 2.6.19 kernel tree.
Signed-off-by: default avatarChris Pascoe <c.pascoe@itee.uq.edu.au>
Signed-off-by: default avatarMichael Krufky <mkrufky@linuxtv.org>
Signed-off-by: default avatarGreg Kroah-Hartman <gregkh@suse.de>
Signed-off-by: default avatarChris Wright <chrisw@sous-sol.org>
parent 37f8d2f4
...@@ -527,7 +527,7 @@ int flexcop_frontend_init(struct flexcop_device *fc) ...@@ -527,7 +527,7 @@ int flexcop_frontend_init(struct flexcop_device *fc)
/* try the air atsc 2nd generation (nxt2002) */ /* try the air atsc 2nd generation (nxt2002) */
if ((fc->fe = nxt200x_attach(&samsung_tbmv_config, &fc->i2c_adap)) != NULL) { if ((fc->fe = nxt200x_attach(&samsung_tbmv_config, &fc->i2c_adap)) != NULL) {
fc->dev_type = FC_AIR_ATSC2; fc->dev_type = FC_AIR_ATSC2;
dvb_pll_attach(fc->fe, 0x61, &fc->i2c_adap, &dvb_pll_samsung_tbmv); dvb_pll_attach(fc->fe, 0x61, NULL, &dvb_pll_samsung_tbmv);
info("found the nxt2002 at i2c address: 0x%02x",samsung_tbmv_config.demod_address); info("found the nxt2002 at i2c address: 0x%02x",samsung_tbmv_config.demod_address);
} else } else
/* try the air atsc 3nd generation (lgdt3303) */ /* try the air atsc 3nd generation (lgdt3303) */
......
...@@ -493,6 +493,9 @@ static int dvb_pll_sleep(struct dvb_frontend *fe) ...@@ -493,6 +493,9 @@ static int dvb_pll_sleep(struct dvb_frontend *fe)
int i; int i;
int result; int result;
if (priv->i2c == NULL)
return -EINVAL;
for (i = 0; i < priv->pll_desc->count; i++) { for (i = 0; i < priv->pll_desc->count; i++) {
if (priv->pll_desc->entries[i].limit == 0) if (priv->pll_desc->entries[i].limit == 0)
break; break;
......
...@@ -576,7 +576,7 @@ static int dvb_register(struct cx8802_dev *dev) ...@@ -576,7 +576,7 @@ static int dvb_register(struct cx8802_dev *dev)
&dev->core->i2c_adap); &dev->core->i2c_adap);
if (dev->dvb.frontend != NULL) { if (dev->dvb.frontend != NULL) {
dvb_pll_attach(dev->dvb.frontend, 0x60, dvb_pll_attach(dev->dvb.frontend, 0x60,
&dev->core->i2c_adap, NULL,
&dvb_pll_thomson_dtt7579); &dvb_pll_thomson_dtt7579);
break; break;
} }
...@@ -587,7 +587,7 @@ static int dvb_register(struct cx8802_dev *dev) ...@@ -587,7 +587,7 @@ static int dvb_register(struct cx8802_dev *dev)
&dev->core->i2c_adap); &dev->core->i2c_adap);
if (dev->dvb.frontend != NULL) { if (dev->dvb.frontend != NULL) {
dvb_pll_attach(dev->dvb.frontend, 0x60, dvb_pll_attach(dev->dvb.frontend, 0x60,
&dev->core->i2c_adap, NULL,
&dvb_pll_thomson_dtt7579); &dvb_pll_thomson_dtt7579);
} }
#endif #endif
...@@ -600,7 +600,7 @@ static int dvb_register(struct cx8802_dev *dev) ...@@ -600,7 +600,7 @@ static int dvb_register(struct cx8802_dev *dev)
&dev->core->i2c_adap); &dev->core->i2c_adap);
if (dev->dvb.frontend != NULL) { if (dev->dvb.frontend != NULL) {
dvb_pll_attach(dev->dvb.frontend, 0x61, dvb_pll_attach(dev->dvb.frontend, 0x61,
&dev->core->i2c_adap, NULL,
&dvb_pll_thomson_dtt7579); &dvb_pll_thomson_dtt7579);
break; break;
} }
...@@ -611,7 +611,7 @@ static int dvb_register(struct cx8802_dev *dev) ...@@ -611,7 +611,7 @@ static int dvb_register(struct cx8802_dev *dev)
&dev->core->i2c_adap); &dev->core->i2c_adap);
if (dev->dvb.frontend != NULL) { if (dev->dvb.frontend != NULL) {
dvb_pll_attach(dev->dvb.frontend, 0x61, dvb_pll_attach(dev->dvb.frontend, 0x61,
&dev->core->i2c_adap, NULL,
&dvb_pll_thomson_dtt7579); &dvb_pll_thomson_dtt7579);
} }
#endif #endif
...@@ -623,7 +623,7 @@ static int dvb_register(struct cx8802_dev *dev) ...@@ -623,7 +623,7 @@ static int dvb_register(struct cx8802_dev *dev)
&dev->core->i2c_adap); &dev->core->i2c_adap);
if (dev->dvb.frontend != NULL) { if (dev->dvb.frontend != NULL) {
dvb_pll_attach(dev->dvb.frontend, 0x61, dvb_pll_attach(dev->dvb.frontend, 0x61,
&dev->core->i2c_adap, NULL,
&dvb_pll_lg_z201); &dvb_pll_lg_z201);
} }
break; break;
...@@ -634,7 +634,7 @@ static int dvb_register(struct cx8802_dev *dev) ...@@ -634,7 +634,7 @@ static int dvb_register(struct cx8802_dev *dev)
&dev->core->i2c_adap); &dev->core->i2c_adap);
if (dev->dvb.frontend != NULL) { if (dev->dvb.frontend != NULL) {
dvb_pll_attach(dev->dvb.frontend, 0x61, dvb_pll_attach(dev->dvb.frontend, 0x61,
&dev->core->i2c_adap, NULL,
&dvb_pll_unknown_1); &dvb_pll_unknown_1);
} }
break; break;
...@@ -757,7 +757,7 @@ static int dvb_register(struct cx8802_dev *dev) ...@@ -757,7 +757,7 @@ static int dvb_register(struct cx8802_dev *dev)
&dev->core->i2c_adap); &dev->core->i2c_adap);
if (dev->dvb.frontend != NULL) { if (dev->dvb.frontend != NULL) {
dvb_pll_attach(dev->dvb.frontend, 0x61, dvb_pll_attach(dev->dvb.frontend, 0x61,
&dev->core->i2c_adap, NULL,
&dvb_pll_tuv1236d); &dvb_pll_tuv1236d);
} }
break; break;
......
...@@ -1158,13 +1158,13 @@ static int dvb_init(struct saa7134_dev *dev) ...@@ -1158,13 +1158,13 @@ static int dvb_init(struct saa7134_dev *dev)
case SAA7134_BOARD_AVERMEDIA_AVERTVHD_A180: case SAA7134_BOARD_AVERMEDIA_AVERTVHD_A180:
dev->dvb.frontend = nxt200x_attach(&avertvhda180, &dev->i2c_adap); dev->dvb.frontend = nxt200x_attach(&avertvhda180, &dev->i2c_adap);
if (dev->dvb.frontend) { if (dev->dvb.frontend) {
dvb_pll_attach(dev->dvb.frontend, 0x61, &dev->i2c_adap, &dvb_pll_tdhu2); dvb_pll_attach(dev->dvb.frontend, 0x61, NULL, &dvb_pll_tdhu2);
} }
break; break;
case SAA7134_BOARD_KWORLD_ATSC110: case SAA7134_BOARD_KWORLD_ATSC110:
dev->dvb.frontend = nxt200x_attach(&kworldatsc110, &dev->i2c_adap); dev->dvb.frontend = nxt200x_attach(&kworldatsc110, &dev->i2c_adap);
if (dev->dvb.frontend) { if (dev->dvb.frontend) {
dvb_pll_attach(dev->dvb.frontend, 0x61, &dev->i2c_adap, &dvb_pll_tuv1236d); dvb_pll_attach(dev->dvb.frontend, 0x61, NULL, &dvb_pll_tuv1236d);
} }
break; break;
#endif #endif
......
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