aboutsummaryrefslogtreecommitdiff
path: root/lib/dvb
diff options
context:
space:
mode:
authorFelix Domke <tmbinc@elitedvb.net>2008-03-11 22:45:54 +0000
committerFelix Domke <tmbinc@elitedvb.net>2008-03-11 22:45:54 +0000
commit0980594e3037839b361eae71646ccf960aaa2659 (patch)
treebe556b66116fc270362c79f38a8afb08020be4dc /lib/dvb
parenta4c3836577b7fab796563c6657257cf7e4a9ee73 (diff)
downloadenigma2-0980594e3037839b361eae71646ccf960aaa2659.tar.gz
enigma2-0980594e3037839b361eae71646ccf960aaa2659.zip
signal quality is SNR, signal power is AGC
Diffstat (limited to 'lib/dvb')
-rw-r--r--lib/dvb/frontend.cpp21
-rw-r--r--lib/dvb/frontend.h2
-rw-r--r--lib/dvb/idvb.h2
3 files changed, 14 insertions, 11 deletions
diff --git a/lib/dvb/frontend.cpp b/lib/dvb/frontend.cpp
index af821cdb..c8d6d15f 100644
--- a/lib/dvb/frontend.cpp
+++ b/lib/dvb/frontend.cpp
@@ -617,14 +617,14 @@ int eDVBFrontend::readFrontendData(int type)
eDebug("FE_READ_BER failed (%m)");
return ber;
}
- case signalPower:
+ case signalQuality:
{
uint16_t snr=0;
if (ioctl(m_fd, FE_READ_SNR, &snr) < 0 && errno != ERANGE)
eDebug("FE_READ_SNR failed (%m)");
return snr;
}
- case signalPowerdB: /* this will move into the driver */
+ case signalQualitydB: /* this will move into the driver */
{
uint16_t snr=0;
if (ioctl(m_fd, FE_READ_SNR, &snr) < 0 && errno != ERANGE)
@@ -669,11 +669,14 @@ int eDVBFrontend::readFrontendData(int type)
{
float snr_in_db=(snr-39075)/1764.7;
return (int)(snr_in_db * 100.0);
+ } else if (!strcmp(m_description, "Alps BSBE2"))
+ {
+ return (int)((snr >> 7) * 10.0);
} /* else
eDebug("no SNR dB calculation for frontendtype %s yet", m_description); */
return 0x12345678;
}
- case signalQuality:
+ case signalPower:
{
uint16_t strength=0;
if (ioctl(m_fd, FE_READ_SIGNAL_STRENGTH, &strength) < 0 && errno != ERANGE)
@@ -1060,17 +1063,17 @@ void eDVBFrontend::getFrontendStatus(ePyObject dest)
PutToDict(dest, "tuner_locked", readFrontendData(locked));
PutToDict(dest, "tuner_synced", readFrontendData(synced));
PutToDict(dest, "tuner_bit_error_rate", readFrontendData(bitErrorRate));
- PutToDict(dest, "tuner_signal_power", readFrontendData(signalPower));
- int sigPowerdB = readFrontendData(signalPowerdB);
- if (sigPowerdB == 0x12345678) // not support yet
+ PutToDict(dest, "tuner_signal_quality", readFrontendData(signalQuality));
+ int sigQualitydB = readFrontendData(signalQualitydB);
+ if (sigQualitydB == 0x12345678) // not support yet
{
ePyObject obj=Py_None;
Py_INCREF(obj);
- PutToDict(dest, "tuner_signal_power_db", obj);
+ PutToDict(dest, "tuner_signal_quality_db", obj);
}
else
- PutToDict(dest, "tuner_signal_power_db", sigPowerdB);
- PutToDict(dest, "tuner_signal_quality", readFrontendData(signalQuality));
+ PutToDict(dest, "tuner_signal_quality_db", sigQualitydB);
+ PutToDict(dest, "tuner_signal_power", readFrontendData(signalPower));
}
}
diff --git a/lib/dvb/frontend.h b/lib/dvb/frontend.h
index 5821e54d..41de874b 100644
--- a/lib/dvb/frontend.h
+++ b/lib/dvb/frontend.h
@@ -118,7 +118,7 @@ public:
RESULT getData(int num, int &data);
RESULT setData(int num, int val);
- int readFrontendData(int type); // bitErrorRate, signalPower, signalPowerdB, signalQuality, locked, synced
+ int readFrontendData(int type); // bitErrorRate, signalPower, signalQualitydB, signalQuality, locked, synced
void getFrontendStatus(ePyObject dest);
void getTransponderData(ePyObject dest, bool original);
void getFrontendData(ePyObject dest);
diff --git a/lib/dvb/idvb.h b/lib/dvb/idvb.h
index c18d2421..d16c9b48 100644
--- a/lib/dvb/idvb.h
+++ b/lib/dvb/idvb.h
@@ -444,7 +444,7 @@ public:
enum { stateIdle, stateTuning, stateFailed, stateLock, stateLostLock };
enum { toneOff, toneOn };
enum { voltageOff, voltage13, voltage18, voltage13_5, voltage18_5 };
- enum { bitErrorRate, signalPower, signalQuality, locked, synced, frontendNumber, signalPowerdB };
+ enum { bitErrorRate, signalPower, signalQuality, locked, synced, frontendNumber, signalQualitydB };
};
SWIG_IGNORE(iDVBFrontend);