diff options
| author | Oliver Endriss <o.endriss@gmx.de> | 2007-05-28 18:06:27 -0300 | 
|---|---|---|
| committer | Mauro Carvalho Chehab <mchehab@infradead.org> | 2007-06-08 08:21:13 -0300 | 
| commit | c6604150ab04aaaf98baf1ddca2e9e4f7d3da4d3 (patch) | |
| tree | 61ff048d9c9b8b4f1c8d9a8b729ed847cc79f2ac | |
| parent | dc02d50a6d71cba2b2edb78377af5a5965879a49 (diff) | |
V4L/DVB (5716): Tda10086,tda826x: fix tuning, STR/SNR values
Several people reported unreliable reception with the current driver.
Furthermore, STR and SNR values seem to be inverted.
This fix is based on a patch posted by Hartmut Hackman.
Thanks to Helmut Auer for testing and helping to optimize the patch.
tda826x:
- set baseband cut-off to 19 MHz
tda10086:
- change the parameters of the carrier recovery loop
- toggle register 0x02 between 0x35 (tuning) and 0x00 (locked)
- invert STR and SNR values
Signed-off-by: Oliver Endriss <o.endriss@gmx.de>
Signed-off-by: Mauro Carvalho Chehab <mchehab@infradead.org>
| -rw-r--r-- | drivers/media/dvb/frontends/tda10086.c | 21 | ||||
| -rw-r--r-- | drivers/media/dvb/frontends/tda826x.c | 4 | 
2 files changed, 18 insertions, 7 deletions
| diff --git a/drivers/media/dvb/frontends/tda10086.c b/drivers/media/dvb/frontends/tda10086.c index ccc429cbbad0..0f2d4b415560 100644 --- a/drivers/media/dvb/frontends/tda10086.c +++ b/drivers/media/dvb/frontends/tda10086.c @@ -41,6 +41,7 @@ struct tda10086_state {  	/* private demod data */  	u32 frequency;  	u32 symbol_rate; +	bool has_lock;  };  static int debug = 0; @@ -116,7 +117,7 @@ static int tda10086_init(struct dvb_frontend* fe)  	// misc setup  	tda10086_write_byte(state, 0x01, 0x94);  	tda10086_write_byte(state, 0x02, 0x35); // NOTE: TT drivers appear to disable CSWP -	tda10086_write_byte(state, 0x03, 0x64); +	tda10086_write_byte(state, 0x03, 0xe4);  	tda10086_write_byte(state, 0x04, 0x43);  	tda10086_write_byte(state, 0x0c, 0x0c);  	tda10086_write_byte(state, 0x1b, 0xb0); // noise threshold @@ -146,7 +147,7 @@ static int tda10086_init(struct dvb_frontend* fe)  	// setup AGC  	tda10086_write_byte(state, 0x05, 0x0B);  	tda10086_write_byte(state, 0x37, 0x63); -	tda10086_write_byte(state, 0x3f, 0x03); // NOTE: flydvb uses 0x0a and varies it +	tda10086_write_byte(state, 0x3f, 0x0a); // NOTE: flydvb varies it  	tda10086_write_byte(state, 0x40, 0x64);  	tda10086_write_byte(state, 0x41, 0x4f);  	tda10086_write_byte(state, 0x42, 0x43); @@ -398,6 +399,10 @@ static int tda10086_set_frontend(struct dvb_frontend* fe,  	dprintk ("%s\n", __FUNCTION__); +	// modify parameters for tuning +	tda10086_write_byte(state, 0x02, 0x35); +	state->has_lock = false; +  	// set params  	if (fe->ops.tuner_ops.set_params) {  		fe->ops.tuner_ops.set_params(fe, fe_params); @@ -542,8 +547,14 @@ static int tda10086_read_status(struct dvb_frontend* fe, fe_status_t *fe_status)  		*fe_status |= FE_HAS_VITERBI;  	if (val & 0x08)  		*fe_status |= FE_HAS_SYNC; -	if (val & 0x10) +	if (val & 0x10) {  		*fe_status |= FE_HAS_LOCK; +		if (!state->has_lock) { +			state->has_lock = true; +			// modify parameters for stable reception +			tda10086_write_byte(state, 0x02, 0x00); +		} +	}  	return 0;  } @@ -555,7 +566,7 @@ static int tda10086_read_signal_strength(struct dvb_frontend* fe, u16 * signal)  	dprintk ("%s\n", __FUNCTION__); -	_str = tda10086_read_byte(state, 0x43); +	_str = 0xff - tda10086_read_byte(state, 0x43);  	*signal = (_str << 8) | _str;  	return 0; @@ -568,7 +579,7 @@ static int tda10086_read_snr(struct dvb_frontend* fe, u16 * snr)  	dprintk ("%s\n", __FUNCTION__); -	_snr = tda10086_read_byte(state, 0x1c); +	_snr = 0xff - tda10086_read_byte(state, 0x1c);  	*snr = (_snr << 8) | _snr;  	return 0; diff --git a/drivers/media/dvb/frontends/tda826x.c b/drivers/media/dvb/frontends/tda826x.c index 79f971dc52b6..bd3ebc284835 100644 --- a/drivers/media/dvb/frontends/tda826x.c +++ b/drivers/media/dvb/frontends/tda826x.c @@ -89,8 +89,8 @@ static int tda826x_set_params(struct dvb_frontend *fe, struct dvb_frontend_param  	buf[2] = (1<<5) | 0x0b; // 1Mhz + 0.45 VCO  	buf[3] = div >> 7;  	buf[4] = div << 1; -	buf[5] = 0xff; // basedband filter to max -	buf[6] = 0xfe; // gains at max + no RF attenuation +	buf[5] = 0x77; // baseband cut-off 19 MHz +	buf[6] = 0xfe; // baseband gain 9 db + no RF attenuation  	buf[7] = 0x83; // charge pumps at high, tests off  	buf[8] = 0x80; // recommended value 4 for AMPVCO + disable ports.  	buf[9] = 0x1a; // normal caltime + recommended values for SELTH + SELVTL | 
