Commit 605ee41c authored by Andrew de Quincey's avatar Andrew de Quincey Committed by Mauro Carvalho Chehab

V4L/DVB (3867): Convert nxt6000 to refactored tuner code

Convert to tuner_ops calls.
Remove pll function pointers from structure.
Remove unneeded tuner calls.
Add i2c gate control function.
Signed-off-by: default avatarAndrew de Quincey <adq_dvb@lidskialf.net>
Signed-off-by: default avatarMauro Carvalho Chehab <mchehab@infradead.org>
parent 638a3fba
...@@ -207,12 +207,6 @@ static void nxt6000_setup(struct dvb_frontend* fe) ...@@ -207,12 +207,6 @@ static void nxt6000_setup(struct dvb_frontend* fe)
nxt6000_writereg(state, SUB_DIAG_MODE_SEL, 0); nxt6000_writereg(state, SUB_DIAG_MODE_SEL, 0);
nxt6000_writereg(state, TS_FORMAT, 0); nxt6000_writereg(state, TS_FORMAT, 0);
if (state->config->pll_init) {
nxt6000_writereg(state, ENABLE_TUNER_IIC, 0x01); /* open i2c bus switch */
state->config->pll_init(fe);
nxt6000_writereg(state, ENABLE_TUNER_IIC, 0x00); /* close i2c bus switch */
}
} }
static void nxt6000_dump_status(struct nxt6000_state *state) static void nxt6000_dump_status(struct nxt6000_state *state)
...@@ -469,9 +463,10 @@ static int nxt6000_set_frontend(struct dvb_frontend* fe, struct dvb_frontend_par ...@@ -469,9 +463,10 @@ static int nxt6000_set_frontend(struct dvb_frontend* fe, struct dvb_frontend_par
struct nxt6000_state* state = fe->demodulator_priv; struct nxt6000_state* state = fe->demodulator_priv;
int result; int result;
nxt6000_writereg(state, ENABLE_TUNER_IIC, 0x01); /* open i2c bus switch */ if (fe->ops->tuner_ops.set_params) {
state->config->pll_set(fe, param); fe->ops->tuner_ops.set_params(fe, param);
nxt6000_writereg(state, ENABLE_TUNER_IIC, 0x00); /* close i2c bus switch */ if (fe->ops->i2c_gate_ctrl) fe->ops->i2c_gate_ctrl(fe, 0);
}
if ((result = nxt6000_set_bandwidth(state, param->u.ofdm.bandwidth)) < 0) if ((result = nxt6000_set_bandwidth(state, param->u.ofdm.bandwidth)) < 0)
return result; return result;
...@@ -532,6 +527,17 @@ static int nxt6000_fe_get_tune_settings(struct dvb_frontend* fe, struct dvb_fron ...@@ -532,6 +527,17 @@ static int nxt6000_fe_get_tune_settings(struct dvb_frontend* fe, struct dvb_fron
return 0; return 0;
} }
static int nxt6000_i2c_gate_ctrl(struct dvb_frontend* fe, int enable)
{
struct nxt6000_state* state = fe->demodulator_priv;
if (enable) {
return nxt6000_writereg(state, ENABLE_TUNER_IIC, 0x01);
} else {
return nxt6000_writereg(state, ENABLE_TUNER_IIC, 0x00);
}
}
static struct dvb_frontend_ops nxt6000_ops; static struct dvb_frontend_ops nxt6000_ops;
struct dvb_frontend* nxt6000_attach(const struct nxt6000_config* config, struct dvb_frontend* nxt6000_attach(const struct nxt6000_config* config,
...@@ -584,6 +590,7 @@ static struct dvb_frontend_ops nxt6000_ops = { ...@@ -584,6 +590,7 @@ static struct dvb_frontend_ops nxt6000_ops = {
.release = nxt6000_release, .release = nxt6000_release,
.init = nxt6000_init, .init = nxt6000_init,
.i2c_gate_ctrl = nxt6000_i2c_gate_ctrl,
.get_tune_settings = nxt6000_fe_get_tune_settings, .get_tune_settings = nxt6000_fe_get_tune_settings,
......
...@@ -31,10 +31,6 @@ struct nxt6000_config ...@@ -31,10 +31,6 @@ struct nxt6000_config
/* should clock inversion be used? */ /* should clock inversion be used? */
u8 clock_inversion:1; u8 clock_inversion:1;
/* PLL maintenance */
int (*pll_init)(struct dvb_frontend* fe);
int (*pll_set)(struct dvb_frontend* fe, struct dvb_frontend_parameters* params);
}; };
extern struct dvb_frontend* nxt6000_attach(const struct nxt6000_config* config, extern struct dvb_frontend* nxt6000_attach(const struct nxt6000_config* config,
......
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