diff options
| author | Jeff Hatch <jhatch@multitech.com> | 2020-06-11 09:16:35 -0500 | 
|---|---|---|
| committer | Jeff Hatch <jhatch@multitech.com> | 2020-06-11 09:16:35 -0500 | 
| commit | adaca6b0fc6430f38ae3f0551f9a248563ad53b5 (patch) | |
| tree | 81cbf2ef9a2378e3b9e50dbfbf68e5e91dd5c919 /src/MTS_IO_QuectelRadio.cpp | |
| parent | 4b0d95808e5681c47a7dcbbff8109856e40bad60 (diff) | |
| parent | 04b90430c91f4257ebeff3bcccbe8c5d7413e7ae (diff) | |
| download | libmts-io-adaca6b0fc6430f38ae3f0551f9a248563ad53b5.tar.gz libmts-io-adaca6b0fc6430f38ae3f0551f9a248563ad53b5.tar.bz2 libmts-io-adaca6b0fc6430f38ae3f0551f9a248563ad53b5.zip | |
Merge branch 'ms/MTX-3444_L4G1_support_implementation' into 'master'
[MTX-3444] mPower Oct20: L4G1 libmts-io support
See merge request !23
Diffstat (limited to 'src/MTS_IO_QuectelRadio.cpp')
| -rw-r--r-- | src/MTS_IO_QuectelRadio.cpp | 34 | 
1 files changed, 34 insertions, 0 deletions
| diff --git a/src/MTS_IO_QuectelRadio.cpp b/src/MTS_IO_QuectelRadio.cpp index c4bdc56..5024f54 100644 --- a/src/MTS_IO_QuectelRadio.cpp +++ b/src/MTS_IO_QuectelRadio.cpp @@ -20,6 +20,8 @@  #include "mts/MTS_IO_QuectelRadio.h" +#include <climits> +  #include <mts/MTS_Logger.h>  #include <mts/MTS_Thread.h>  #include <mts/MTS_Text.h> @@ -568,3 +570,35 @@ ICellularRadio::CODE QuectelRadio::convertToActiveBand(const std::string& sQuect      return SUCCESS;  } + +ICellularRadio::CODE QuectelRadio::setCellularMode(CELLULAR_MODES networks) { +    std::string prefNet; +    unsigned int prefOnly = 0, prefCount = 0; +    for (int i = sizeof(networks)*CHAR_BIT-1; i>=0; --i){ +        switch (1<<i & networks) { +            case ICellularRadio::CELLULAR_MODE_2G: prefNet += "01"  ; prefOnly = 1; prefCount++; break; +            case ICellularRadio::CELLULAR_MODE_3G: prefNet += "0302"; prefOnly = 2; prefCount++; break; +            case ICellularRadio::CELLULAR_MODE_4G: prefNet += "04"  ; prefOnly = 3; prefCount++; break; +        } +    } + +    std::string sCmd; +    if (prefCount == 1) { // *g-only +        sCmd = "AT+QCFG=\"nwscanmode\"," + std::to_string(prefOnly); +    } else { // preferred +        sCmd = "AT+QCFG=\"nwscanmode\",0"; +    } +    std::string cmdResult = sendCommand(sCmd); +    if (cmdResult.find(ICellularRadio::RSP_OK) == std::string::npos) { +        printError("%s| AT+QCFG=\"nwscanmode\" returned unexpected response: [%s][%s]", getName().c_str(), sCmd.c_str(), cmdResult.c_str()); +        return FAILURE; +    } + +    sCmd = "AT+QCFG=\"nwscanseq\"," + prefNet; +    cmdResult = sendCommand(sCmd); +    if (cmdResult.find(ICellularRadio::RSP_OK) == std::string::npos) { +        printError("%s| AT+QCFG=\"nwscanseq\" returned unexpected response: [%s][%s]", getName().c_str(), sCmd.c_str(), cmdResult.c_str()); +        return FAILURE; +    } +    return SUCCESS; +} | 
