diff options
author | Andrew de Quincey <adq_dvb@lidskialf.net> | 2006-04-18 16:47:09 -0400 |
---|---|---|
committer | Mauro Carvalho Chehab <mchehab@infradead.org> | 2006-06-25 00:58:35 -0400 |
commit | a81870e00bf502db2c579dcb9721adab3775ba58 (patch) | |
tree | f235348748b929e42aadc6a2dd5314fa6308b689 /drivers/media/dvb/frontends/mt312.c | |
parent | 0244422220f149d2e930deab89515fd5ca9a6bdd (diff) |
V4L/DVB (3849): Convert mt312 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>
Diffstat (limited to 'drivers/media/dvb/frontends/mt312.c')
-rw-r--r-- | drivers/media/dvb/frontends/mt312.c | 25 |
1 files changed, 16 insertions, 9 deletions
diff --git a/drivers/media/dvb/frontends/mt312.c b/drivers/media/dvb/frontends/mt312.c index d3aea83cf218..46e12a8acf72 100644 --- a/drivers/media/dvb/frontends/mt312.c +++ b/drivers/media/dvb/frontends/mt312.c | |||
@@ -277,12 +277,6 @@ static int mt312_initfe(struct dvb_frontend* fe) | |||
277 | if ((ret = mt312_writereg(state, CS_SW_LIM, 0x69)) < 0) | 277 | if ((ret = mt312_writereg(state, CS_SW_LIM, 0x69)) < 0) |
278 | return ret; | 278 | return ret; |
279 | 279 | ||
280 | if (state->config->pll_init) { | ||
281 | mt312_writereg(state, GPP_CTRL, 0x40); | ||
282 | state->config->pll_init(fe); | ||
283 | mt312_writereg(state, GPP_CTRL, 0x00); | ||
284 | } | ||
285 | |||
286 | return 0; | 280 | return 0; |
287 | } | 281 | } |
288 | 282 | ||
@@ -529,9 +523,10 @@ static int mt312_set_frontend(struct dvb_frontend* fe, | |||
529 | return -EINVAL; | 523 | return -EINVAL; |
530 | } | 524 | } |
531 | 525 | ||
532 | mt312_writereg(state, GPP_CTRL, 0x40); | 526 | if (fe->ops->tuner_ops.set_params) { |
533 | state->config->pll_set(fe, p); | 527 | fe->ops->tuner_ops.set_params(fe, p); |
534 | mt312_writereg(state, GPP_CTRL, 0x00); | 528 | if (fe->ops->i2c_gate_ctrl) fe->ops->i2c_gate_ctrl(fe, 0); |
529 | } | ||
535 | 530 | ||
536 | /* sr = (u16)(sr * 256.0 / 1000000.0) */ | 531 | /* sr = (u16)(sr * 256.0 / 1000000.0) */ |
537 | sr = mt312_div(p->u.qpsk.symbol_rate * 4, 15625); | 532 | sr = mt312_div(p->u.qpsk.symbol_rate * 4, 15625); |
@@ -578,6 +573,17 @@ static int mt312_get_frontend(struct dvb_frontend* fe, | |||
578 | return 0; | 573 | return 0; |
579 | } | 574 | } |
580 | 575 | ||
576 | static int mt312_i2c_gate_ctrl(struct dvb_frontend* fe, int enable) | ||
577 | { | ||
578 | struct mt312_state* state = fe->demodulator_priv; | ||
579 | |||
580 | if (enable) { | ||
581 | return mt312_writereg(state, GPP_CTRL, 0x40); | ||
582 | } else { | ||
583 | return mt312_writereg(state, GPP_CTRL, 0x00); | ||
584 | } | ||
585 | } | ||
586 | |||
581 | static int mt312_sleep(struct dvb_frontend* fe) | 587 | static int mt312_sleep(struct dvb_frontend* fe) |
582 | { | 588 | { |
583 | struct mt312_state *state = fe->demodulator_priv; | 589 | struct mt312_state *state = fe->demodulator_priv; |
@@ -633,6 +639,7 @@ static struct dvb_frontend_ops vp310_mt312_ops = { | |||
633 | 639 | ||
634 | .init = mt312_initfe, | 640 | .init = mt312_initfe, |
635 | .sleep = mt312_sleep, | 641 | .sleep = mt312_sleep, |
642 | .i2c_gate_ctrl = mt312_i2c_gate_ctrl, | ||
636 | 643 | ||
637 | .set_frontend = mt312_set_frontend, | 644 | .set_frontend = mt312_set_frontend, |
638 | .get_frontend = mt312_get_frontend, | 645 | .get_frontend = mt312_get_frontend, |