Skip to content

Commit

Permalink
---
Browse files Browse the repository at this point in the history
yaml
---
r: 29898
b: refs/heads/master
c: 605ee41
h: refs/heads/master
v: v3
  • Loading branch information
Andrew de Quincey authored and Mauro Carvalho Chehab committed Jun 25, 2006
1 parent 955ec15 commit c89268a
Show file tree
Hide file tree
Showing 3 changed files with 17 additions and 14 deletions.
2 changes: 1 addition & 1 deletion [refs]
Original file line number Diff line number Diff line change
@@ -1,2 +1,2 @@
---
refs/heads/master: 638a3fba39748b63bdfa391bd65144e487a02e3c
refs/heads/master: 605ee41c432e550a4e6a4f6fd82013b2989e36a3
25 changes: 16 additions & 9 deletions trunk/drivers/media/dvb/frontends/nxt6000.c
Original file line number Diff line number Diff line change
Expand Up @@ -207,12 +207,6 @@ static void nxt6000_setup(struct dvb_frontend* fe)
nxt6000_writereg(state, SUB_DIAG_MODE_SEL, 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)
Expand Down Expand Up @@ -469,9 +463,10 @@ static int nxt6000_set_frontend(struct dvb_frontend* fe, struct dvb_frontend_par
struct nxt6000_state* state = fe->demodulator_priv;
int result;

nxt6000_writereg(state, ENABLE_TUNER_IIC, 0x01); /* open i2c bus switch */
state->config->pll_set(fe, param);
nxt6000_writereg(state, ENABLE_TUNER_IIC, 0x00); /* close i2c bus switch */
if (fe->ops->tuner_ops.set_params) {
fe->ops->tuner_ops.set_params(fe, param);
if (fe->ops->i2c_gate_ctrl) fe->ops->i2c_gate_ctrl(fe, 0);
}

if ((result = nxt6000_set_bandwidth(state, param->u.ofdm.bandwidth)) < 0)
return result;
Expand Down Expand Up @@ -532,6 +527,17 @@ static int nxt6000_fe_get_tune_settings(struct dvb_frontend* fe, struct dvb_fron
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;

struct dvb_frontend* nxt6000_attach(const struct nxt6000_config* config,
Expand Down Expand Up @@ -584,6 +590,7 @@ static struct dvb_frontend_ops nxt6000_ops = {
.release = nxt6000_release,

.init = nxt6000_init,
.i2c_gate_ctrl = nxt6000_i2c_gate_ctrl,

.get_tune_settings = nxt6000_fe_get_tune_settings,

Expand Down
4 changes: 0 additions & 4 deletions trunk/drivers/media/dvb/frontends/nxt6000.h
Original file line number Diff line number Diff line change
Expand Up @@ -31,10 +31,6 @@ struct nxt6000_config

/* should clock inversion be used? */
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,
Expand Down

0 comments on commit c89268a

Please sign in to comment.