Slow tuning, EG:
> szap-s2 -r -c 39.FTATV "1=Pgm1;Net1"
reading channels from file '39.FTATV'
zapping to 3 '1=Pgm1;Net1':
delivery DVB-S, modulation QPSK
sat 0, frequency 11140 MHz V, symbolrate 
1425000, coderate 5/6, rolloff 0.35
vpid 0x0200, apid 0x0300, sid 0x0001
using '/dev/dvb/adapter0/frontend0' and '/dev/dvb/adapter0/demux0'
status 00 | signal c2c0 | snr 0000 | ber 
00012d4a | unc 
00000000 |
status 03 | signal ff80 | snr 0000 | ber 
00000000 | unc 
00000000 |
status 01 | signal ff80 | snr 0000 | ber 
00000000 | unc 
00000000 |
status 01 | signal ff80 | snr 0000 | ber 
00000000 | unc 
00000000 |
status 03 | signal c040 | snr 0000 | ber 
00000000 | unc 
00000000 |
status 03 | signal ff80 | snr 0000 | ber 
00000000 | unc 
00000000 |
status 01 | signal ff80 | snr 0000 | ber 
00000000 | unc 
00000000 |
status 03 | signal c040 | snr 0000 | ber 
00000000 | unc 
00000000 |
status 01 | signal ff80 | snr 0000 | ber 
00000000 | unc 
00000000 |
status 01 | signal ff80 | snr 0000 | ber 
00000000 | unc 
00000000 |
status 01 | signal c040 | snr 0000 | ber 
00000000 | unc 
00000000 |
status 01 | signal ff80 | snr 0000 | ber 
00000000 | unc 
00000000 |
status 01 | signal ff80 | snr 0000 | ber 
00000000 | unc 
00000000 |
status 01 | signal c040 | snr 0000 | ber 
00000000 | unc 
00000000 |
status 03 | signal c040 | snr 0000 | ber 
00000000 | unc 
00000000 |
status 1f | signal c040 | snr bb33 | ber 
00000000 | unc 
00000000 | FE_HAS_LOCK
Appears to be resolved by dropping zig-zag tuning and relying on
hardware only:
> szap-s2 -r -c 39.FTATV "1=Pgm1;Net1"
reading channels from file '39.FTATV'
zapping to 3 '1=Pgm1;Net1':
delivery DVB-S, modulation QPSK
sat 0, frequency 11140 MHz V, symbolrate 
1425000, coderate 5/6, rolloff 0.35
vpid 0x0200, apid 0x0300, sid 0x0001
using '/dev/dvb/adapter0/frontend0' and '/dev/dvb/adapter0/demux0'
status 01 | signal ff80 | snr 0000 | ber 
00000000 | unc 
00000000 |
status 1f | signal ff80 | snr c199 | ber 
00000000 | unc 
00000000 | FE_HAS_LOCK
status 1f | signal c040 | snr c199 | ber 
00000000 | unc 
00000000 | FE_HAS_LOCK
status 1f | signal ff80 | snr c199 | ber 
00000000 | unc 
00000000 | FE_HAS_LOCK
Tuning to a weaker channel shows that the hardware recovers sync:
status 1f | signal fe40 | snr 5199 | ber 
00000000 | unc 
00000000 | FE_HAS_LOCK
status 03 | signal fd40 | snr 5000 | ber 
00000000 | unc 
00000000 |
status 1f | signal fe40 | snr 5000 | ber 
00000000 | unc 
00000000 | FE_HAS_LOCK
status 03 | signal fd80 | snr 5000 | ber 
00000000 | unc 
00000000 |
status 01 | signal fd80 | snr 4e66 | ber 
00000000 | unc 
00000000 |
status 1f | signal fe40 | snr 5000 | ber 
00000000 | unc 
00000000 | FE_HAS_LOCK
status 03 | signal fe40 | snr 5000 | ber 
00000000 | unc 
00000000 |
status 01 | signal fd80 | snr 0000 | ber 
00000000 | unc 
00000000 |
status 1f | signal fe40 | snr 5199 | ber 
00000000 | unc 
00000000 | FE_HAS_LOCK
Also, tuning, moving the dish and then restoring the dish also retunes.
Signed-off-by: Darron Broad <darron@kewl.org>
Cc: Steven Toth <stoth@hauppauge.com>
Signed-off-by: Mauro Carvalho Chehab <mchehab@redhat.com>
 #define CX24116_HAS_SYNCLOCK (0x08)
 #define CX24116_HAS_UNKNOWN1 (0x10)
 #define CX24116_HAS_UNKNOWN2 (0x20)
-#define CX24116_STATUS_MASK  (0x3f)
+#define CX24116_STATUS_MASK  (0x0f)
 #define CX24116_SIGNAL_MASK  (0xc0)
 
 #define CX24116_DISEQC_TONEOFF   (0)    /* toneburst never sent */
 {
        struct cx24116_state *state = fe->demodulator_priv;
 
-       int lock = cx24116_readreg(state, CX24116_REG_SSTATUS);
+       int lock = cx24116_readreg(state, CX24116_REG_SSTATUS) &
+               CX24116_STATUS_MASK;
 
        dprintk("%s: status = 0x%02x\n", __func__, lock);
 
        return ret;
 }
 
+static int cx24116_tune(struct dvb_frontend *fe, struct dvb_frontend_parameters *params,
+       unsigned int mode_flags, unsigned int *delay, fe_status_t *status)
+{
+       *delay = HZ / 5;
+       if (params) {
+               int ret = cx24116_set_frontend(fe, params);
+               if (ret)
+                       return ret;
+       }
+       return cx24116_read_status(fe, status);
+}
+
+static int cx24116_get_algo(struct dvb_frontend *fe)
+{
+       return DVBFE_ALGO_HW;
+}
+
 static struct dvb_frontend_ops cx24116_ops = {
 
        .info = {
        .set_voltage = cx24116_set_voltage,
        .diseqc_send_master_cmd = cx24116_send_diseqc_msg,
        .diseqc_send_burst = cx24116_diseqc_send_burst,
+       .get_frontend_algo = cx24116_get_algo,
+       .tune = cx24116_tune,
 
        .set_property = cx24116_set_property,
        .get_property = cx24116_get_property,