diff options
Diffstat (limited to '')
| -rw-r--r-- | plugin_dvb.c | 34 | 
1 files changed, 26 insertions, 8 deletions
| diff --git a/plugin_dvb.c b/plugin_dvb.c index 95715ad..783519a 100644 --- a/plugin_dvb.c +++ b/plugin_dvb.c @@ -64,6 +64,8 @@ static HASH DVB;  static int get_dvb_stats(void)  { +    static int ioc_disable = 0; +      int age;      int fd;      unsigned short snr, sig; @@ -82,24 +84,40 @@ static int get_dvb_stats(void)  	return -1;      } -    if (ioctl(fd, FE_READ_SIGNAL_STRENGTH, &sig) != 0) { +    sig = 0; +    if ((ioc_disable & 0x01) == 0 && ioctl(fd, FE_READ_SIGNAL_STRENGTH, &sig) != 0) {  	error("ioctl(FE_READ_SIGNAL_STRENGTH) failed: %s", strerror(errno)); -	sig = 0; +	if (errno == ENOSYS) { +	  ioc_disable |= 0x01; +	  error("ioctl(FE_READ_SIGNAL_STRENGTH) disabled."); +	}      } -    if (ioctl(fd, FE_READ_SNR, &snr) != 0) { +    snr = 0; +    if ((ioc_disable & 0x02) == 0 && ioctl(fd, FE_READ_SNR, &snr) != 0) {  	error("ioctl(FE_READ_SNR) failed: %s", strerror(errno)); -	snr = 0; +	if (errno == ENOSYS) { +	  ioc_disable |= 0x02; +	  error("ioctl(FE_READ_SNR) disabled."); +	}      } -    if (ioctl(fd, FE_READ_BER, &ber) != 0) { +    ber = 0; +    if ((ioc_disable & 0x04) == 0 && ioctl(fd, FE_READ_BER, &ber) != 0) {  	error("ioctl(FE_READ_BER) failed: %s", strerror(errno)); -	ber = 0; +	if (errno == ENOSYS) { +	  ioc_disable |= 0x04; +	  error("ioctl(FE_READ_BER) disabled."); +	}      } -    if (ioctl(fd, FE_READ_UNCORRECTED_BLOCKS, &ucb) != 0) { +    ucb = 0; +    if ((ioc_disable & 0x08) == 0 && ioctl(fd, FE_READ_UNCORRECTED_BLOCKS, &ucb) != 0) {  	error("ioctl(FE_READ_UNCORRECTED_BLOCKS) failed: %s", strerror(errno)); -	ucb = 0; +	if (errno == ENOSYS) { +	  ioc_disable |= 0x08; +	  error("ioctl(FE_READ_UNCORRECTED_BLOCKS) disabled."); +	}      }      close(fd); | 
