Commit 7bff4b4d authored by Hartmut Hackmann's avatar Hartmut Hackmann Committed by Mauro Carvalho Chehab

V4L/DVB (7393): tda827x: fixed support of tuners with LNA

Tuner refactoring broke support of tuners with LNA configurations 1 and 2
for both, analog TV and DVB-T.
Additionally, this patch initializes the saa713x gpios defined by the gpiomask
at driver init to avoid undefined stated at dvb.
Signed-off-by: default avatarHartmut Hackmann <hartmut.hackmann@t-online.de>
Signed-off-by: default avatarMauro Carvalho Chehab <mchehab@infradead.org>
parent 5823b3a6
...@@ -94,7 +94,6 @@ struct tda1004x_config ...@@ -94,7 +94,6 @@ struct tda1004x_config
/* slave address and configuration of the tuner */ /* slave address and configuration of the tuner */
u8 tuner_address; u8 tuner_address;
u8 tuner_config;
u8 antenna_switch; u8 antenna_switch;
/* if the board uses another I2c Bridge (tda8290), its address */ /* if the board uses another I2c Bridge (tda8290), its address */
......
...@@ -142,7 +142,7 @@ static int tda827xo_set_params(struct dvb_frontend *fe, ...@@ -142,7 +142,7 @@ static int tda827xo_set_params(struct dvb_frontend *fe,
int i, tuner_freq, if_freq; int i, tuner_freq, if_freq;
u32 N; u32 N;
dprintk("%s:\n", __FUNCTION__); dprintk("%s:\n", __func__);
switch (params->u.ofdm.bandwidth) { switch (params->u.ofdm.bandwidth) {
case BANDWIDTH_6_MHZ: case BANDWIDTH_6_MHZ:
if_freq = 4000000; if_freq = 4000000;
...@@ -186,7 +186,7 @@ static int tda827xo_set_params(struct dvb_frontend *fe, ...@@ -186,7 +186,7 @@ static int tda827xo_set_params(struct dvb_frontend *fe,
fe->ops.i2c_gate_ctrl(fe, 1); fe->ops.i2c_gate_ctrl(fe, 1);
if (i2c_transfer(priv->i2c_adap, &msg, 1) != 1) { if (i2c_transfer(priv->i2c_adap, &msg, 1) != 1) {
printk("%s: could not write to tuner at addr: 0x%02x\n", printk("%s: could not write to tuner at addr: 0x%02x\n",
__FUNCTION__, priv->i2c_addr << 1); __func__, priv->i2c_addr << 1);
return -EIO; return -EIO;
} }
msleep(500); msleep(500);
...@@ -212,7 +212,7 @@ static int tda827xo_sleep(struct dvb_frontend *fe) ...@@ -212,7 +212,7 @@ static int tda827xo_sleep(struct dvb_frontend *fe)
struct i2c_msg msg = { .addr = priv->i2c_addr, .flags = 0, struct i2c_msg msg = { .addr = priv->i2c_addr, .flags = 0,
.buf = buf, .len = sizeof(buf) }; .buf = buf, .len = sizeof(buf) };
dprintk("%s:\n", __FUNCTION__); dprintk("%s:\n", __func__);
if (fe->ops.i2c_gate_ctrl) if (fe->ops.i2c_gate_ctrl)
fe->ops.i2c_gate_ctrl(fe, 1); fe->ops.i2c_gate_ctrl(fe, 1);
i2c_transfer(priv->i2c_adap, &msg, 1); i2c_transfer(priv->i2c_adap, &msg, 1);
...@@ -389,6 +389,79 @@ static struct tda827xa_data tda827xa_analog[] = { ...@@ -389,6 +389,79 @@ static struct tda827xa_data tda827xa_analog[] = {
{ .lomax = 0, .svco = 0, .spd = 0, .scr = 0, .sbs = 0, .gc3 = 0} { .lomax = 0, .svco = 0, .spd = 0, .scr = 0, .sbs = 0, .gc3 = 0}
}; };
static int tda827xa_sleep(struct dvb_frontend *fe)
{
struct tda827x_priv *priv = fe->tuner_priv;
static u8 buf[] = { 0x30, 0x90 };
struct i2c_msg msg = { .addr = priv->i2c_addr, .flags = 0,
.buf = buf, .len = sizeof(buf) };
dprintk("%s:\n", __func__);
if (fe->ops.i2c_gate_ctrl)
fe->ops.i2c_gate_ctrl(fe, 1);
i2c_transfer(priv->i2c_adap, &msg, 1);
if (fe->ops.i2c_gate_ctrl)
fe->ops.i2c_gate_ctrl(fe, 0);
if (priv->cfg && priv->cfg->sleep)
priv->cfg->sleep(fe);
return 0;
}
static void tda827xa_lna_gain(struct dvb_frontend *fe, int high,
struct analog_parameters *params)
{
struct tda827x_priv *priv = fe->tuner_priv;
unsigned char buf[] = {0x22, 0x01};
int arg;
int gp_func;
struct i2c_msg msg = { .addr = priv->cfg->switch_addr, .flags = 0,
.buf = buf, .len = sizeof(buf) };
if (NULL == priv->cfg) {
dprintk("tda827x_config not defined, cannot set LNA gain!\n");
return;
}
if (priv->cfg->config) {
if (high)
dprintk("setting LNA to high gain\n");
else
dprintk("setting LNA to low gain\n");
}
switch (priv->cfg->config) {
case 0: /* no LNA */
break;
case 1: /* switch is GPIO 0 of tda8290 */
case 2:
if (params == NULL) {
gp_func = 0;
arg = 0;
} else {
/* turn Vsync on */
gp_func = 1;
if (params->std & V4L2_STD_MN)
arg = 1;
else
arg = 0;
}
if (priv->cfg->tuner_callback)
priv->cfg->tuner_callback(priv->i2c_adap->algo_data,
gp_func, arg);
buf[1] = high ? 0 : 1;
if (priv->cfg->config == 2)
buf[1] = high ? 1 : 0;
i2c_transfer(priv->i2c_adap, &msg, 1);
break;
case 3: /* switch with GPIO of saa713x */
if (priv->cfg->tuner_callback)
priv->cfg->tuner_callback(priv->i2c_adap->algo_data, 0, high);
break;
}
}
static int tda827xa_set_params(struct dvb_frontend *fe, static int tda827xa_set_params(struct dvb_frontend *fe,
struct dvb_frontend_parameters *params) struct dvb_frontend_parameters *params)
{ {
...@@ -401,9 +474,9 @@ static int tda827xa_set_params(struct dvb_frontend *fe, ...@@ -401,9 +474,9 @@ static int tda827xa_set_params(struct dvb_frontend *fe,
int i, tuner_freq, if_freq; int i, tuner_freq, if_freq;
u32 N; u32 N;
dprintk("%s:\n", __FUNCTION__); dprintk("%s:\n", __func__);
if (priv->cfg && priv->cfg->lna_gain)
priv->cfg->lna_gain(fe, 1); tda827xa_lna_gain(fe, 1, NULL);
msleep(20); msleep(20);
switch (params->u.ofdm.bandwidth) { switch (params->u.ofdm.bandwidth) {
...@@ -444,7 +517,7 @@ static int tda827xa_set_params(struct dvb_frontend *fe, ...@@ -444,7 +517,7 @@ static int tda827xa_set_params(struct dvb_frontend *fe,
fe->ops.i2c_gate_ctrl(fe, 1); fe->ops.i2c_gate_ctrl(fe, 1);
if (i2c_transfer(priv->i2c_adap, &msg, 1) != 1) { if (i2c_transfer(priv->i2c_adap, &msg, 1) != 1) {
printk("%s: could not write to tuner at addr: 0x%02x\n", printk("%s: could not write to tuner at addr: 0x%02x\n",
__FUNCTION__, priv->i2c_addr << 1); __func__, priv->i2c_addr << 1);
return -EIO; return -EIO;
} }
buf[0] = 0x90; buf[0] = 0x90;
...@@ -474,8 +547,7 @@ static int tda827xa_set_params(struct dvb_frontend *fe, ...@@ -474,8 +547,7 @@ static int tda827xa_set_params(struct dvb_frontend *fe,
buf[1] >>= 4; buf[1] >>= 4;
dprintk("tda8275a AGC2 gain is: %d\n", buf[1]); dprintk("tda8275a AGC2 gain is: %d\n", buf[1]);
if ((buf[1]) < 2) { if ((buf[1]) < 2) {
if (priv->cfg && priv->cfg->lna_gain) tda827xa_lna_gain(fe, 0, NULL);
priv->cfg->lna_gain(fe, 0);
buf[0] = 0x60; buf[0] = 0x60;
buf[1] = 0x0c; buf[1] = 0x0c;
if (fe->ops.i2c_gate_ctrl) if (fe->ops.i2c_gate_ctrl)
...@@ -523,73 +595,6 @@ static int tda827xa_set_params(struct dvb_frontend *fe, ...@@ -523,73 +595,6 @@ static int tda827xa_set_params(struct dvb_frontend *fe,
return 0; return 0;
} }
static int tda827xa_sleep(struct dvb_frontend *fe)
{
struct tda827x_priv *priv = fe->tuner_priv;
static u8 buf[] = { 0x30, 0x90 };
struct i2c_msg msg = { .addr = priv->i2c_addr, .flags = 0,
.buf = buf, .len = sizeof(buf) };
dprintk("%s:\n", __FUNCTION__);
if (fe->ops.i2c_gate_ctrl)
fe->ops.i2c_gate_ctrl(fe, 1);
i2c_transfer(priv->i2c_adap, &msg, 1);
if (fe->ops.i2c_gate_ctrl)
fe->ops.i2c_gate_ctrl(fe, 0);
if (priv->cfg && priv->cfg->sleep)
priv->cfg->sleep(fe);
return 0;
}
/* ------------------------------------------------------------------ */
static void tda827xa_lna_gain(struct dvb_frontend *fe, int high,
struct analog_parameters *params)
{
struct tda827x_priv *priv = fe->tuner_priv;
unsigned char buf[] = {0x22, 0x01};
int arg;
struct i2c_msg msg = { .addr = priv->i2c_addr, .flags = 0,
.buf = buf, .len = sizeof(buf) };
if (NULL == priv->cfg) {
dprintk("tda827x_config not defined, cannot set LNA gain!\n");
return;
}
if (priv->cfg->config) {
if (high)
dprintk("setting LNA to high gain\n");
else
dprintk("setting LNA to low gain\n");
}
switch (*priv->cfg->config) {
case 0: /* no LNA */
break;
case 1: /* switch is GPIO 0 of tda8290 */
case 2:
/* turn Vsync on */
if (params->std & V4L2_STD_MN)
arg = 1;
else
arg = 0;
if (priv->cfg->tuner_callback)
priv->cfg->tuner_callback(priv, 1, arg);
buf[1] = high ? 0 : 1;
if (*priv->cfg->config == 2)
buf[1] = high ? 1 : 0;
i2c_transfer(priv->i2c_adap, &msg, 1);
break;
case 3: /* switch with GPIO of saa713x */
if (priv->cfg->tuner_callback)
priv->cfg->tuner_callback(priv, 0, high);
break;
}
}
static int tda827xa_set_analog_params(struct dvb_frontend *fe, static int tda827xa_set_analog_params(struct dvb_frontend *fe,
struct analog_parameters *params) struct analog_parameters *params)
...@@ -724,7 +729,7 @@ static int tda827x_get_bandwidth(struct dvb_frontend *fe, u32 *bandwidth) ...@@ -724,7 +729,7 @@ static int tda827x_get_bandwidth(struct dvb_frontend *fe, u32 *bandwidth)
static int tda827x_init(struct dvb_frontend *fe) static int tda827x_init(struct dvb_frontend *fe)
{ {
struct tda827x_priv *priv = fe->tuner_priv; struct tda827x_priv *priv = fe->tuner_priv;
dprintk("%s:\n", __FUNCTION__); dprintk("%s:\n", __func__);
if (priv->cfg && priv->cfg->init) if (priv->cfg && priv->cfg->init)
priv->cfg->init(fe); priv->cfg->init(fe);
...@@ -792,7 +797,7 @@ static int tda827x_probe_version(struct dvb_frontend *fe) ...@@ -792,7 +797,7 @@ static int tda827x_probe_version(struct dvb_frontend *fe)
fe->ops.i2c_gate_ctrl(fe, 1); fe->ops.i2c_gate_ctrl(fe, 1);
if (i2c_transfer(priv->i2c_adap, &msg, 1) != 1) { if (i2c_transfer(priv->i2c_adap, &msg, 1) != 1) {
printk("%s: could not read from tuner at addr: 0x%02x\n", printk("%s: could not read from tuner at addr: 0x%02x\n",
__FUNCTION__, msg.addr << 1); __func__, msg.addr << 1);
return -EIO; return -EIO;
} }
if ((data & 0x3c) == 0) { if ((data & 0x3c) == 0) {
...@@ -816,7 +821,7 @@ struct dvb_frontend *tda827x_attach(struct dvb_frontend *fe, int addr, ...@@ -816,7 +821,7 @@ struct dvb_frontend *tda827x_attach(struct dvb_frontend *fe, int addr,
{ {
struct tda827x_priv *priv = NULL; struct tda827x_priv *priv = NULL;
dprintk("%s:\n", __FUNCTION__); dprintk("%s:\n", __func__);
priv = kzalloc(sizeof(struct tda827x_priv), GFP_KERNEL); priv = kzalloc(sizeof(struct tda827x_priv), GFP_KERNEL);
if (priv == NULL) if (priv == NULL)
return NULL; return NULL;
......
...@@ -30,12 +30,12 @@ ...@@ -30,12 +30,12 @@
struct tda827x_config struct tda827x_config
{ {
/* saa7134 - provided callbacks */ /* saa7134 - provided callbacks */
void (*lna_gain) (struct dvb_frontend *fe, int high);
int (*init) (struct dvb_frontend *fe); int (*init) (struct dvb_frontend *fe);
int (*sleep) (struct dvb_frontend *fe); int (*sleep) (struct dvb_frontend *fe);
/* interface to tda829x driver */ /* interface to tda829x driver */
unsigned int *config; unsigned int config;
int switch_addr;
int (*tuner_callback) (void *dev, int command, int arg); int (*tuner_callback) (void *dev, int command, int arg);
void (*agcf)(struct dvb_frontend *fe); void (*agcf)(struct dvb_frontend *fe);
......
...@@ -5260,13 +5260,14 @@ int saa7134_tuner_callback(void *priv, int command, int arg) ...@@ -5260,13 +5260,14 @@ int saa7134_tuner_callback(void *priv, int command, int arg)
{ {
struct i2c_algo_bit_data *i2c_algo = priv; struct i2c_algo_bit_data *i2c_algo = priv;
struct saa7134_dev *dev = i2c_algo->data; struct saa7134_dev *dev = i2c_algo->data;
if (dev != NULL) {
switch (dev->tuner_type) { switch (dev->tuner_type) {
case TUNER_PHILIPS_TDA8290: case TUNER_PHILIPS_TDA8290:
return saa7134_tda8290_callback(dev, command, arg); return saa7134_tda8290_callback(dev, command, arg);
case TUNER_XC2028: case TUNER_XC2028:
return saa7134_xc2028_callback(dev, command, arg); return saa7134_xc2028_callback(dev, command, arg);
} }
}
return -EINVAL; return -EINVAL;
} }
EXPORT_SYMBOL(saa7134_tuner_callback); EXPORT_SYMBOL(saa7134_tuner_callback);
......
...@@ -864,6 +864,7 @@ static int __devinit saa7134_initdev(struct pci_dev *pci_dev, ...@@ -864,6 +864,7 @@ static int __devinit saa7134_initdev(struct pci_dev *pci_dev,
struct saa7134_dev *dev; struct saa7134_dev *dev;
struct saa7134_mpeg_ops *mops; struct saa7134_mpeg_ops *mops;
int err; int err;
int mask;
dev = kzalloc(sizeof(*dev),GFP_KERNEL); dev = kzalloc(sizeof(*dev),GFP_KERNEL);
if (NULL == dev) if (NULL == dev)
...@@ -1061,6 +1062,11 @@ static int __devinit saa7134_initdev(struct pci_dev *pci_dev, ...@@ -1061,6 +1062,11 @@ static int __devinit saa7134_initdev(struct pci_dev *pci_dev,
if (TUNER_ABSENT != dev->tuner_type) if (TUNER_ABSENT != dev->tuner_type)
saa7134_i2c_call_clients(dev, TUNER_SET_STANDBY, NULL); saa7134_i2c_call_clients(dev, TUNER_SET_STANDBY, NULL);
if (card(dev).gpiomask != 0) {
mask = card(dev).gpiomask;
saa_andorl(SAA7134_GPIO_GPMODE0 >> 2, mask, mask);
saa_andorl(SAA7134_GPIO_GPSTATUS0 >> 2, mask, 0);
}
return 0; return 0;
fail4: fail4:
......
This diff is collapsed.
...@@ -626,13 +626,8 @@ void saa7134_set_tvnorm_hw(struct saa7134_dev *dev) ...@@ -626,13 +626,8 @@ void saa7134_set_tvnorm_hw(struct saa7134_dev *dev)
{ {
saa7134_set_decoder(dev); saa7134_set_decoder(dev);
if (card_in(dev, dev->ctl_input).tv) { if (card_in(dev, dev->ctl_input).tv)
if ((card(dev).tuner_type == TUNER_PHILIPS_TDA8290)
&& ((card(dev).tuner_config == 1)
|| (card(dev).tuner_config == 2)))
saa7134_set_gpio(dev, 22, 5);
saa7134_i2c_call_clients(dev, VIDIOC_S_STD, &dev->tvnorm->id); saa7134_i2c_call_clients(dev, VIDIOC_S_STD, &dev->tvnorm->id);
}
} }
static void set_h_prescale(struct saa7134_dev *dev, int task, int prescale) static void set_h_prescale(struct saa7134_dev *dev, int task, int prescale)
......
...@@ -172,7 +172,7 @@ static void tda8290_set_params(struct dvb_frontend *fe, ...@@ -172,7 +172,7 @@ static void tda8290_set_params(struct dvb_frontend *fe,
set_audio(fe, params); set_audio(fe, params);
if (priv->cfg.config) if (priv->cfg.config)
tuner_dbg("tda827xa config is 0x%02x\n", *priv->cfg.config); tuner_dbg("tda827xa config is 0x%02x\n", priv->cfg.config);
tuner_i2c_xfer_send(&priv->i2c_props, easy_mode, 2); tuner_i2c_xfer_send(&priv->i2c_props, easy_mode, 2);
tuner_i2c_xfer_send(&priv->i2c_props, agc_out_on, 2); tuner_i2c_xfer_send(&priv->i2c_props, agc_out_on, 2);
tuner_i2c_xfer_send(&priv->i2c_props, soft_reset, 2); tuner_i2c_xfer_send(&priv->i2c_props, soft_reset, 2);
...@@ -442,8 +442,7 @@ static void tda8290_init_if(struct dvb_frontend *fe) ...@@ -442,8 +442,7 @@ static void tda8290_init_if(struct dvb_frontend *fe)
unsigned char set_GP00_CF[] = { 0x20, 0x01 }; unsigned char set_GP00_CF[] = { 0x20, 0x01 };
unsigned char set_GP01_CF[] = { 0x20, 0x0B }; unsigned char set_GP01_CF[] = { 0x20, 0x0B };
if ((priv->cfg.config) && if ((priv->cfg.config == 1) || (priv->cfg.config == 2))
((*priv->cfg.config == 1) || (*priv->cfg.config == 2)))
tuner_i2c_xfer_send(&priv->i2c_props, set_GP00_CF, 2); tuner_i2c_xfer_send(&priv->i2c_props, set_GP00_CF, 2);
else else
tuner_i2c_xfer_send(&priv->i2c_props, set_GP01_CF, 2); tuner_i2c_xfer_send(&priv->i2c_props, set_GP01_CF, 2);
...@@ -588,8 +587,8 @@ static int tda829x_find_tuner(struct dvb_frontend *fe) ...@@ -588,8 +587,8 @@ static int tda829x_find_tuner(struct dvb_frontend *fe)
else else
priv->ver |= TDA8275A; priv->ver |= TDA8275A;
tda827x_attach(fe, priv->tda827x_addr, tda827x_attach(fe, priv->tda827x_addr, priv->i2c_props.adap, &priv->cfg);
priv->i2c_props.adap, &priv->cfg); priv->cfg.switch_addr = priv->i2c_props.addr;
} }
if (fe->ops.tuner_ops.init) if (fe->ops.tuner_ops.init)
fe->ops.tuner_ops.init(fe); fe->ops.tuner_ops.init(fe);
......
...@@ -21,7 +21,7 @@ ...@@ -21,7 +21,7 @@
#include "dvb_frontend.h" #include "dvb_frontend.h"
struct tda829x_config { struct tda829x_config {
unsigned int *lna_cfg; unsigned int lna_cfg;
int (*tuner_callback) (void *dev, int command, int arg); int (*tuner_callback) (void *dev, int command, int arg);
unsigned int probe_tuner:1; unsigned int probe_tuner:1;
......
...@@ -320,7 +320,7 @@ static void tuner_i2c_address_check(struct tuner *t) ...@@ -320,7 +320,7 @@ static void tuner_i2c_address_check(struct tuner *t)
static void attach_tda829x(struct tuner *t) static void attach_tda829x(struct tuner *t)
{ {
struct tda829x_config cfg = { struct tda829x_config cfg = {
.lna_cfg = &t->config, .lna_cfg = t->config,
.tuner_callback = t->tuner_callback, .tuner_callback = t->tuner_callback,
}; };
tda829x_attach(&t->fe, t->i2c->adapter, t->i2c->addr, &cfg); tda829x_attach(&t->fe, t->i2c->adapter, t->i2c->addr, &cfg);
......
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