--- /common/Programms/ver2/src/s2-liplianin/linux/drivers/media/dvb/frontends/stb0899_drv.c 2009-12-31 17:15:38.115203347 +0300 +++ ./linux/drivers/media/dvb/frontends/stb0899_drv.c 2010-01-14 22:17:22.671634551 +0300 @@ -980,6 +980,16 @@ *strength = stb0899_table_lookup(stb0899_dvbsrf_tab, ARRAY_SIZE(stb0899_dvbsrf_tab) - 1, val); *strength += 750; + + const int MIN_STRENGTH_DVBS = 0; + const int MAX_STRENGTH_DVBS = 680; + if (*strength < MIN_STRENGTH_DVBS) + *strength = 0; + else if(*strength > MAX_STRENGTH_DVBS) + *strength = 0xFFFF; + else + *strength = (*strength - MIN_STRENGTH_DVBS) * 0xFFFF / (MAX_STRENGTH_DVBS - MIN_STRENGTH_DVBS); + dprintk(state->verbose, FE_DEBUG, 1, "AGCIQVALUE = 0x%02x, C = %d * 0.1 dBm", val & 0xff, *strength); } @@ -992,6 +1002,7 @@ *strength = stb0899_table_lookup(stb0899_dvbs2rf_tab, ARRAY_SIZE(stb0899_dvbs2rf_tab) - 1, val); *strength += 750; + *strength = *strength << 4; dprintk(state->verbose, FE_DEBUG, 1, "IF_AGC_GAIN = 0x%04x, C = %d * 0.1 dBm", val & 0x3fff, *strength); } @@ -1024,6 +1035,16 @@ val = MAKEWORD16(buf[0], buf[1]); *snr = stb0899_table_lookup(stb0899_cn_tab, ARRAY_SIZE(stb0899_cn_tab) - 1, val); + + const int MIN_SNR_DVBS = 0; + const int MAX_SNR_DVBS = 200; + if (*snr < MIN_SNR_DVBS) + *snr = 0; + else if(*snr > MAX_SNR_DVBS) + *snr = 0xFFFF; + else + *snr = (*snr - MIN_SNR_DVBS) * 0xFFFF / (MAX_SNR_DVBS - MIN_SNR_DVBS); + dprintk(state->verbose, FE_DEBUG, 1, "NIR = 0x%02x%02x = %u, C/N = %d * 0.1 dBm\n", buf[0], buf[1], val, *snr); } @@ -1048,6 +1069,16 @@ val = (quantn - estn) / 10; } *snr = val; + + const int MIN_SNR_DVBS2 = 10; + const int MAX_SNR_DVBS2 = 70; + if (*snr < MIN_SNR_DVBS2) + *snr = 0; + else if(*snr > MAX_SNR_DVBS2) + *snr = 0xFFFF; + else + *snr = (*snr - MIN_SNR_DVBS2) * 0xFFFF / (MAX_SNR_DVBS2 - MIN_SNR_DVBS2); + dprintk(state->verbose, FE_DEBUG, 1, "Es/N0 quant = %d (%d) estimate = %u (%d), C/N = %d * 0.1 dBm", quant, quantn, est, estn, val); }