[media] dib7000p: enhancement
authorOlivier Grenie <olivier.grenie@parrot.com>
Mon, 31 Dec 2012 12:23:26 +0000 (09:23 -0300)
committerMauro Carvalho Chehab <mchehab@redhat.com>
Mon, 22 Apr 2013 20:13:43 +0000 (17:13 -0300)
The intend of this patch is to improve the support of the dib7000p. It is
now possible to set the minimum value for the AGC1. Also, the driver takes
into account the frequency offset introduced in the tuned frequency.

Signed-off-by: Olivier Grenie <olivier.grenie@parrot.com>
Signed-off-by: Patrick Boettcher <patrick.boettcher@parrot.com>
Signed-off-by: Mauro Carvalho Chehab <mchehab@redhat.com>
drivers/media/dvb-frontends/dib7000p.c
drivers/media/dvb-frontends/dib7000p.h

index 3e1eefada0e8adb577065225bb7ef9bdd3274102..effb87f773b0256c9b5eab954b0811f17ea0e3b3 100644 (file)
@@ -429,6 +429,13 @@ int dib7000p_get_agc_values(struct dvb_frontend *fe,
 }
 EXPORT_SYMBOL(dib7000p_get_agc_values);
 
+int dib7000p_set_agc1_min(struct dvb_frontend *fe, u16 v)
+{
+       struct dib7000p_state *state = fe->demodulator_priv;
+       return dib7000p_write_word(state, 108,  v);
+}
+EXPORT_SYMBOL(dib7000p_set_agc1_min);
+
 static void dib7000p_reset_pll(struct dib7000p_state *state)
 {
        struct dibx000_bandwidth_config *bw = &state->cfg.bw[0];
@@ -821,6 +828,7 @@ static int dib7000p_agc_startup(struct dvb_frontend *demod)
        u8 agc_split;
        u16 reg;
        u32 upd_demod_gain_period = 0x1000;
+       s32 frequency_offset = 0;
 
        switch (state->agc_state) {
        case 0:
@@ -841,7 +849,14 @@ static int dib7000p_agc_startup(struct dvb_frontend *demod)
                if (dib7000p_set_agc_config(state, BAND_OF_FREQUENCY(ch->frequency / 1000)) != 0)
                        return -1;
 
-               dib7000p_set_dds(state, 0);
+               if (demod->ops.tuner_ops.get_frequency) {
+                       u32 frequency_tuner;
+
+                       demod->ops.tuner_ops.get_frequency(demod, &frequency_tuner);
+                       frequency_offset = (s32)frequency_tuner / 1000 - ch->frequency / 1000;
+               }
+
+               dib7000p_set_dds(state, frequency_offset);
                ret = 7;
                (*agc_state)++;
                break;
index cf5e77956a1f35a9095f3532a3ab02f3fe5e4400..d08cdff59bdf72a0fad669fce946e1a90630ba6f 100644 (file)
@@ -63,6 +63,7 @@ extern struct i2c_adapter *dib7090_get_i2c_tuner(struct dvb_frontend *fe);
 extern int dib7090_slave_reset(struct dvb_frontend *fe);
 extern int dib7000p_get_agc_values(struct dvb_frontend *fe,
                u16 *agc_global, u16 *agc1, u16 *agc2, u16 *wbd);
+extern int dib7000p_set_agc1_min(struct dvb_frontend *fe, u16 v);
 #else
 static inline struct dvb_frontend *dib7000p_attach(struct i2c_adapter *i2c_adap, u8 i2c_addr, struct dib7000p_config *cfg)
 {
@@ -154,6 +155,12 @@ static inline int dib7000p_get_agc_values(struct dvb_frontend *fe,
        printk(KERN_WARNING "%s: driver disabled by Kconfig\n", __func__);
        return -ENODEV;
 }
+
+static inline int dib7000p_set_agc1_min(struct dvb_frontend *fe, u16 v)
+{
+       printk(KERN_WARNING "%s: driver disabled by Kconfig\n", __func__);
+       return -ENODEV;
+}
 #endif
 
 #endif