summaryrefslogtreecommitdiff
path: root/linux/drivers/media
diff options
context:
space:
mode:
authorAndrew de Quincey <adq_dvb@lidskialf.net>2006-04-18 21:47:12 +0100
committerAndrew de Quincey <adq_dvb@lidskialf.net>2006-04-18 21:47:12 +0100
commitb567a613dbe04986b2731674f5a0a71bdabd8065 (patch)
tree41040df42cf45145078c3707da2fba057e5b6c7a /linux/drivers/media
parente2e414107e1ee3aa4df0be1e15f0b157cb96243e (diff)
downloadmediapointer-dvb-s2-b567a613dbe04986b2731674f5a0a71bdabd8065.tar.gz
mediapointer-dvb-s2-b567a613dbe04986b2731674f5a0a71bdabd8065.tar.bz2
Sort out support for non-attached tuners on mt352
From: Andrew de Quincey <adq_dvb@lidskialf.net> Make it use set_params/pllbuf as appropriate so it works with dvb_pll_attach()ed tuners. Signed-off-by: Andrew de Quincey <adq_dvb@lidskialf.net>
Diffstat (limited to 'linux/drivers/media')
-rw-r--r--linux/drivers/media/dvb/frontends/mt352.c24
1 files changed, 19 insertions, 5 deletions
diff --git a/linux/drivers/media/dvb/frontends/mt352.c b/linux/drivers/media/dvb/frontends/mt352.c
index a7a347a3c..3c86018e7 100644
--- a/linux/drivers/media/dvb/frontends/mt352.c
+++ b/linux/drivers/media/dvb/frontends/mt352.c
@@ -287,18 +287,32 @@ static int mt352_set_parameters(struct dvb_frontend* fe,
mt352_calc_nominal_rate(state, op->bandwidth, buf+4);
mt352_calc_input_freq(state, buf+6);
+ // if there is no secondary tuner, call set_params to set up a potential
+ // tuner attached elsewhere
+ if (state->config.no_tuner) {
+ 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);
+ }
+
+ /* start decoding only */
+ mt352_write(fe, fsm_go, 2);
+ }
+
+ // retrieve the pllbuf - we do this even if there is no
+ // secondary tuner simply so we have a record of what was sent for
+ // debugging.
if (fe->ops->tuner_ops.pllbuf) {
fe->ops->tuner_ops.pllbuf(fe, param, buf+8, 5);
buf[8] <<= 1;
mt352_write(fe, buf, sizeof(buf));
}
- if (state->config.no_tuner) {
- /* start decoding */
- mt352_write(fe, fsm_go, 2);
- } else {
- /* start tuning */
+
+ // send PLL and start tuning and then decoding
+ if (!state->config.no_tuner) {
mt352_write(fe, tuner_go, 2);
}
+
return 0;
}