diff options
| author | Serhii Kostiuk <serhii.o.kostiuk@globallogic.com> | 2019-06-11 16:30:23 +0300 | 
|---|---|---|
| committer | Serhii Kostiuk <serhii.o.kostiuk@globallogic.com> | 2019-06-11 16:30:23 +0300 | 
| commit | bce73d000b64fc8ecaf7a25041e97a1ef57a848e (patch) | |
| tree | 9d6993aadb04a45d68bf483a119a2a1189ccd959 | |
| parent | ea4e0213f94a1014a0b4f0e0e43c3222eddc177a (diff) | |
| download | libmts-io-bce73d000b64fc8ecaf7a25041e97a1ef57a848e.tar.gz libmts-io-bce73d000b64fc8ecaf7a25041e97a1ef57a848e.tar.bz2 libmts-io-bce73d000b64fc8ecaf7a25041e97a1ef57a848e.zip | |
[MTS-MTQ] QuectelRadio implementation
Moved Telit-specific conversion between RSSI and dBm into the TelitRadio class.
Quectel has MOSTLY the same conversion logic but in the case of TD-SCDMA
the RSSI values may be uncompatible.
| -rw-r--r-- | include/mts/MTS_IO_CellularRadio.h | 2 | ||||
| -rw-r--r-- | include/mts/MTS_IO_TelitRadio.h | 4 | ||||
| -rw-r--r-- | src/MTS_IO_CellularRadio.cpp | 41 | ||||
| -rw-r--r-- | src/MTS_IO_TelitRadio.cpp | 41 | 
4 files changed, 45 insertions, 43 deletions
| diff --git a/include/mts/MTS_IO_CellularRadio.h b/include/mts/MTS_IO_CellularRadio.h index 1572ac8..8e9201f 100644 --- a/include/mts/MTS_IO_CellularRadio.h +++ b/include/mts/MTS_IO_CellularRadio.h @@ -72,8 +72,6 @@ namespace MTS {                  CODE getSignalStrength(int32_t& iRssi) override;                  CODE getModemLocation(std::string& sLocation) override; -                CODE convertSignalStrengthTodBm(const int32_t& iRssi, int32_t& dBm) override; -                CODE convertdBmToSignalStrength(const int32_t& dBm, int32_t& iRssi) override;                  CODE getRegistration(REGISTRATION& eRegistration) override;                  CODE convertRegistrationToString(REGISTRATION eRegistration, std::string& sRegistration) override; diff --git a/include/mts/MTS_IO_TelitRadio.h b/include/mts/MTS_IO_TelitRadio.h index 7a44529..7162dfb 100644 --- a/include/mts/MTS_IO_TelitRadio.h +++ b/include/mts/MTS_IO_TelitRadio.h @@ -34,6 +34,10 @@ namespace MTS {                  CODE getService(std::string& sService) override;                  CODE getNetwork(std::string& sNetwork) override;                  CODE getNetworkStatus(Json::Value& jData) override; + +                CODE convertSignalStrengthTodBm(const int32_t& iRssi, int32_t& dBm) override; +                CODE convertdBmToSignalStrength(const int32_t& dBm, int32_t& iRssi) override; +                  CODE setMdn(const Json::Value& jArgs) override;              protected: diff --git a/src/MTS_IO_CellularRadio.cpp b/src/MTS_IO_CellularRadio.cpp index ee4e9ec..c6ff5af 100644 --- a/src/MTS_IO_CellularRadio.cpp +++ b/src/MTS_IO_CellularRadio.cpp @@ -516,47 +516,6 @@ CellularRadio::CODE CellularRadio::getModemLocation(std::string&) {      return FAILURE;  } -CellularRadio::CODE CellularRadio::convertSignalStrengthTodBm(const int32_t& iRssi, int32_t& iDbm) { - -    //Telit Conversion -    if(iRssi < 0 || iRssi == 99) { -        return FAILURE; -    } - -    if(iRssi == 0) { -        iDbm = -113; -    } else if(iRssi == 1) { -        iDbm = -111; -    } else if(iRssi <= 30) { -        //28 steps between 2 and 30 -        //54 dbm between 53 and 109 -        float stepSize = 54.0 / 28.0; -        iDbm = -109 + (int)(stepSize * (iRssi-2)); -    } else { -        iDbm = -51; -    } - -    return SUCCESS; -} - -CellularRadio::CODE CellularRadio::convertdBmToSignalStrength(const int32_t& iDBm, int32_t& iRssi) { -    //Telit Conversion -    if(iDBm <= -113) { -        iRssi = 0; -    } else if(iDBm <= -111) { -        iRssi = 1; -    } else if(iDBm <= -53) { -        //54 dbm between -109 and -53 -        //28 steps between 2 and 30 -        float stepSize = 28.0/54.0; -        iRssi = ((iDBm + 109)*stepSize) + 2; -    } else { -        iRssi = 31; -    } - -    return SUCCESS; -} -  CellularRadio::CODE CellularRadio::getEcho(bool& bEnabled) {      printTrace("%s| Echo Test", m_sName.c_str());      std::string sResult = sendCommand("AT"); diff --git a/src/MTS_IO_TelitRadio.cpp b/src/MTS_IO_TelitRadio.cpp index 7f9de63..bfcb42e 100644 --- a/src/MTS_IO_TelitRadio.cpp +++ b/src/MTS_IO_TelitRadio.cpp @@ -449,6 +449,47 @@ std::string TelitRadio::queryCGREGstring() {      return cmdResult;  } +CellularRadio::CODE TelitRadio::convertSignalStrengthTodBm(const int32_t& iRssi, int32_t& iDbm) { + +    //Telit Conversion +    if(iRssi < 0 || iRssi == 99) { +        return FAILURE; +    } + +    if(iRssi == 0) { +        iDbm = -113; +    } else if(iRssi == 1) { +        iDbm = -111; +    } else if(iRssi <= 30) { +        //28 steps between 2 and 30 +        //54 dbm between 53 and 109 +        float stepSize = 54.0 / 28.0; +        iDbm = -109 + (int)(stepSize * (iRssi-2)); +    } else { +        iDbm = -51; +    } + +    return SUCCESS; +} + +CellularRadio::CODE TelitRadio::convertdBmToSignalStrength(const int32_t& iDBm, int32_t& iRssi) { +    //Telit Conversion +    if(iDBm <= -113) { +        iRssi = 0; +    } else if(iDBm <= -111) { +        iRssi = 1; +    } else if(iDBm <= -53) { +        //54 dbm between -109 and -53 +        //28 steps between 2 and 30 +        float stepSize = 28.0/54.0; +        iRssi = ((iDBm + 109)*stepSize) + 2; +    } else { +        iRssi = 31; +    } + +    return SUCCESS; +} +  CellularRadio::CODE TelitRadio::setMdn(const Json::Value& jArgs) {      printTrace("%s| Set MDN", getName().c_str()); | 
