V4L/DVB (3856): Convert sp887x 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: Andrew de Quincey <adq_dvb@lidskialf.net> Signed-off-by: Mauro Carvalho Chehab <mchehab@infradead.org>
This commit is contained in:
committed by
Mauro Carvalho Chehab
parent
53a8ee3e90
commit
085542dc86
@@ -208,15 +208,6 @@ static int sp887x_initial_setup (struct dvb_frontend* fe, const struct firmware
|
|||||||
/* bit 0x010: enable data valid signal */
|
/* bit 0x010: enable data valid signal */
|
||||||
sp887x_writereg(state, 0xd00, 0x010);
|
sp887x_writereg(state, 0xd00, 0x010);
|
||||||
sp887x_writereg(state, 0x0d1, 0x000);
|
sp887x_writereg(state, 0x0d1, 0x000);
|
||||||
|
|
||||||
/* setup the PLL */
|
|
||||||
if (state->config->pll_init) {
|
|
||||||
sp887x_writereg(state, 0x206, 0x001);
|
|
||||||
state->config->pll_init(fe);
|
|
||||||
sp887x_writereg(state, 0x206, 0x000);
|
|
||||||
}
|
|
||||||
|
|
||||||
printk ("done.\n");
|
|
||||||
return 0;
|
return 0;
|
||||||
};
|
};
|
||||||
|
|
||||||
@@ -362,9 +353,16 @@ static int sp887x_setup_frontend_parameters (struct dvb_frontend* fe,
|
|||||||
sp887x_microcontroller_stop(state);
|
sp887x_microcontroller_stop(state);
|
||||||
|
|
||||||
/* setup the PLL */
|
/* setup the PLL */
|
||||||
sp887x_writereg(state, 0x206, 0x001);
|
if (fe->ops->tuner_ops.set_params) {
|
||||||
actual_freq = state->config->pll_set(fe, p);
|
fe->ops->tuner_ops.set_params(fe, p);
|
||||||
sp887x_writereg(state, 0x206, 0x000);
|
if (fe->ops->i2c_gate_ctrl) fe->ops->i2c_gate_ctrl(fe, 0);
|
||||||
|
}
|
||||||
|
if (fe->ops->tuner_ops.get_frequency) {
|
||||||
|
fe->ops->tuner_ops.get_frequency(fe, &actual_freq);
|
||||||
|
if (fe->ops->i2c_gate_ctrl) fe->ops->i2c_gate_ctrl(fe, 0);
|
||||||
|
} else {
|
||||||
|
actual_freq = p->frequency;
|
||||||
|
}
|
||||||
|
|
||||||
/* read status reg in order to clear <pending irqs */
|
/* read status reg in order to clear <pending irqs */
|
||||||
sp887x_readreg(state, 0x200);
|
sp887x_readreg(state, 0x200);
|
||||||
@@ -486,6 +484,17 @@ static int sp887x_read_ucblocks(struct dvb_frontend* fe, u32* ucblocks)
|
|||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static int sp887x_i2c_gate_ctrl(struct dvb_frontend* fe, int enable)
|
||||||
|
{
|
||||||
|
struct sp887x_state* state = fe->demodulator_priv;
|
||||||
|
|
||||||
|
if (enable) {
|
||||||
|
return sp887x_writereg(state, 0x206, 0x001);
|
||||||
|
} else {
|
||||||
|
return sp887x_writereg(state, 0x206, 0x000);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
static int sp887x_sleep(struct dvb_frontend* fe)
|
static int sp887x_sleep(struct dvb_frontend* fe)
|
||||||
{
|
{
|
||||||
struct sp887x_state* state = fe->demodulator_priv;
|
struct sp887x_state* state = fe->demodulator_priv;
|
||||||
@@ -589,6 +598,7 @@ static struct dvb_frontend_ops sp887x_ops = {
|
|||||||
|
|
||||||
.init = sp887x_init,
|
.init = sp887x_init,
|
||||||
.sleep = sp887x_sleep,
|
.sleep = sp887x_sleep,
|
||||||
|
.i2c_gate_ctrl = sp887x_i2c_gate_ctrl,
|
||||||
|
|
||||||
.set_frontend = sp887x_setup_frontend_parameters,
|
.set_frontend = sp887x_setup_frontend_parameters,
|
||||||
.get_tune_settings = sp887x_get_tune_settings,
|
.get_tune_settings = sp887x_get_tune_settings,
|
||||||
|
@@ -13,12 +13,6 @@ struct sp887x_config
|
|||||||
/* the demodulator's i2c address */
|
/* the demodulator's i2c address */
|
||||||
u8 demod_address;
|
u8 demod_address;
|
||||||
|
|
||||||
/* PLL maintenance */
|
|
||||||
int (*pll_init)(struct dvb_frontend* fe);
|
|
||||||
|
|
||||||
/* this should return the actual frequency tuned to */
|
|
||||||
int (*pll_set)(struct dvb_frontend* fe, struct dvb_frontend_parameters* params);
|
|
||||||
|
|
||||||
/* request firmware for device */
|
/* request firmware for device */
|
||||||
int (*request_firmware)(struct dvb_frontend* fe, const struct firmware **fw, char* name);
|
int (*request_firmware)(struct dvb_frontend* fe, const struct firmware **fw, char* name);
|
||||||
};
|
};
|
||||||
|
Reference in New Issue
Block a user