Important changes to repositories hosted on mbed.com
Mbed hosted mercurial repositories are deprecated and are due to be permanently deleted in July 2026.
To keep a copy of this software download the repository Zip archive or clone locally using Mercurial.
It is also possible to export all your personal repositories from the account settings page.
Dependents: GPS_6Axis_DataLogger_SD_UDP
Fork of C027_Support by
Diff: MDM.cpp
- Revision:
- 54:7ba8e4c218e2
- Parent:
- 52:8071747a7cb3
- Child:
- 55:e6cfbedfae8c
--- a/MDM.cpp Mon May 12 07:39:29 2014 +0000 +++ b/MDM.cpp Mon May 12 13:00:27 2014 +0000 @@ -4,7 +4,7 @@ #include "MDM.h" #define TRACE (1/*1=off,0=trace*/)?:printf -//#define DEBUG // enable this for AT command debugging +#define DEBUG // enable this for AT command debugging #define PROFILE "0" // this is the psd profile used #define MAX_SIZE 256 // max expected messages // some helper @@ -43,6 +43,8 @@ inst = this; memset(&_dev, 0, sizeof(_dev)); memset(&_net, 0, sizeof(_net)); + _net.lac = 0xFFFF; + _net.ci = 0xFFFFFFFF; _ip = NOIP; memset(_sockets, 0, sizeof(_sockets)); } @@ -82,7 +84,7 @@ int type = TYPE(ret); const char* s = (type == TYPE_UNKNOWN)? YEL("UNK") : (type == TYPE_TEXT) ? MAG("TXT") : - (type == TYPE_RESP_OK ) ? GRE("RESP_OK ") : + (type == TYPE_OK ) ? GRE("OK ") : (type == TYPE_ERROR) ? RED("ERR") : (type == TYPE_PLUS) ? CYA(" + ") : (type == TYPE_PROMPT) ? BLU(" > ") : @@ -101,7 +103,7 @@ // handle unsolicited commands here if (type == TYPE_PLUS) { const char* cmd = buf+3; - int a, b; + int a, b, c, d, r; char s[32]; // SMS Command --------------------------------- @@ -128,12 +130,14 @@ if (_dev.dev == DEV_LISA_C200) { // CDMA Specific ------------------------------------------- // +CREG: <n><SID>,<NID>,<stat> - if (sscanf(cmd, "CREG: %*d,%*d,%*d,%d",&a) == 1) { - if (a == 0) _net.reg = REG_NONE; // not registered, home network - else if (a == 1) _net.reg = REG_HOME; // registered, home network - else if (a == 2) _net.reg = REG_NONE; // not registered, but MT is currently searching a new operator to register to - else if (a == 3) _net.reg = REG_DENIED; // registration denied - else if (a == 5) _net.reg = REG_ROAMING; // registered, roaming + if (sscanf(cmd, "CREG: %*d,%d,%d,%d",&a,&b,&c) == 3) { + // _net.sid = a; + // _net.nid = b; + if (c == 0) _net.reg = REG_NONE; // not registered, home network + else if (c == 1) _net.reg = REG_HOME; // registered, home network + else if (c == 2) _net.reg = REG_NONE; // not registered, but MT is currently searching a new operator to register to + else if (c == 3) _net.reg = REG_DENIED; // registration denied + else if (c == 5) _net.reg = REG_ROAMING; // registered, roaming _net.act = ACT_CDMA; // +CSS: <mode>[,<format>,<oper>[,<AcT>]] } else if (sscanf(cmd, "CSS %*c,%2s,%*d",s) == 1) { @@ -143,7 +147,8 @@ // GSM/UMTS Specific ------------------------------------------- // +CREG: <n>, <stat>[,<lac>,<ci>[,AcT]] b = 255; - if (sscanf(cmd, "CREG: %*d,%d,%*d,%d",&a,&b) >= 1) { + r = sscanf(cmd, "CREG: %*d,%d,\"%X\",\"%X\",%d",&a,&b,&c,&d); + if (r >= 1) { // network status if (a == 0) _net.reg = REG_NONE; // 0: not registered, home network else if (a == 1) _net.reg = REG_HOME; // 1: registered, home network @@ -151,14 +156,19 @@ else if (a == 3) _net.reg = REG_DENIED; // 3: registration denied else if (a == 4) _net.reg = REG_UNKNOWN; // 4: unknown else if (a == 5) _net.reg = REG_ROAMING; // 5: registered, roaming + if ((r >= 2) && (b != 0xFFFF)) _net.lac = b; // location area code + if ((r >= 3) && (c != 0xFFFFFFFF)) _net.ci = c; // cell ID // access technology - if (b == 0) _net.act = ACT_GSM; // 0: GSM - else if (b == 1) _net.act = ACT_GSM; // 1: GSM COMPACT - else if (b == 2) _net.act = ACT_UTRAN; // 2: UTRAN - else if (b == 3) _net.act = ACT_EDGE; // 3: GSM with EDGE availability - else if (b == 4) _net.act = ACT_UTRAN; // 4: UTRAN with HSDPA availability - else if (b == 5) _net.act = ACT_UTRAN; // 5: UTRAN with HSUPA availability - else if (b == 6) _net.act = ACT_UTRAN; // 6: UTRAN with HSDPA and HSUPA availability + if (r >= 4) { + if (d == 0) _net.act = ACT_GSM; // 0: GSM + else if (d == 1) _net.act = ACT_GSM; // 1: GSM COMPACT + else if (d == 2) _net.act = ACT_UTRAN; // 2: UTRAN + else if (d == 3) _net.act = ACT_EDGE; // 3: GSM with EDGE availability + else if (d == 4) _net.act = ACT_UTRAN; // 4: UTRAN with HSDPA availability + else if (d == 5) _net.act = ACT_UTRAN; // 5: UTRAN with HSUPA availability + else if (d == 6) _net.act = ACT_UTRAN; // 6: UTRAN with HSDPA and HSUPA availability + } + // +UUPSDD: <profile_id> } else if (sscanf(cmd, "UUPSDD: %d",&a) == 1) { if (*PROFILE == a) _ip = NOIP; @@ -383,6 +393,10 @@ bool MDMParser::checkNetStatus(NetStatus* status /*= NULL*/) { + // enable the network registration unsolicited result code + sendFormated("AT+CREG=%d\r\n", (_dev.dev == DEV_LISA_C200) ? 1 : 2); + if (RESP_OK != waitFinalResp()) + return false; // check registration sendFormated("AT+CREG?\r\n"); if (RESP_OK != waitFinalResp()) @@ -425,7 +439,7 @@ } // Returns the signal strength indication sendFormated("AT+CSQ\r\n"); - if (RESP_OK != waitFinalResp(_cbCSQ, &_net.rssi)) + if (RESP_OK != waitFinalResp(_cbCSQ, &_net)) return false; if (status) { memcpy(status, &_net, sizeof(NetStatus)); @@ -466,14 +480,15 @@ return WAIT; } -int MDMParser::_cbCSQ(int type, const char* buf, int len, int* rssi) +int MDMParser::_cbCSQ(int type, const char* buf, int len, NetStatus* status) { - if ((type == TYPE_PLUS) && rssi){ - int a; + if ((type == TYPE_PLUS) && status){ + int a,b; + char _ber[] = { 49, 43, 37, 25, 19, 13, 7, 0 }; // see 3GPP TS 45.008 [20] subclause 8.2.4 // +CSQ: <rssi>,<qual> - if (sscanf(buf, "\r\n+CSQ: %d,%*d",&a) == 1) { - if (a != 99) *rssi = -113 + 2*a; // 0: -113 1: -111 ... 30: -53 dBm with 2 dBm steps - //if (b != 99) int qual = b; // + if (sscanf(buf, "\r\n+CSQ: %d,%d",&a,&b) == 2) { + if (a != 99) status->rssi = -113 + 2*a; // 0: -113 1: -111 ... 30: -53 dBm with 2 dBm steps + if ((b != 99) && (b < sizeof(_ber))) status->ber = _ber[b]; // } } return WAIT; @@ -932,7 +947,65 @@ } return true; } - + +// ---------------------------------------------------------------- + +void MDMParser::dumpDevStatus(MDMParser::DevStatus* status) +{ + printf("Device Status:\r\n"); + const char* txtDev[] = { "Unknown", "SARA-G350", "LISA-U200", "LISA-C200" }; + if (status->dev < sizeof(txtDev)/sizeof(*txtDev) && (status->dev != MDMParser::DEV_UNKNOWN)) + printf(" Device: %s\r\n", txtDev[status->dev]); + const char* txtLpm[] = { "Disabled", "Enabled", "Active" }; + if (status->lpm < sizeof(txtLpm)/sizeof(*txtLpm)) + printf(" Power Save: %s\r\n", txtLpm[status->lpm]); + const char* txtSim[] = { "Unknown", "Pin", "Ready" }; + if (status->sim < sizeof(txtSim)/sizeof(*txtSim) && (status->sim != MDMParser::SIM_UNKNOWN)) + printf(" SIM: %s\r\n", txtSim[status->sim]); + if (*status->ccid) + printf(" CCID: %s\r\n", status->ccid); + if (*status->imei) + printf(" IMEI: %s\r\n", status->imei); + if (*status->imsi) + printf(" IMSI: %s\r\n", status->imsi); + if (*status->meid) + printf(" MEID: %s\r\n", status->meid); // LISA-C + if (*status->manu) + printf(" Manufacturer: %s\r\n", status->manu); + if (*status->model) + printf(" Model: %s\r\n", status->model); + if (*status->ver) + printf(" Version: %s\r\n", status->ver); +} + +void MDMParser::dumpNetStatus(MDMParser::NetStatus *status) +{ + printf("Network Status:\r\n"); + const char* txtReg[] = { "Unknown", "Denied", "None", "Home", "Roaming" }; + if (status->reg < sizeof(txtReg)/sizeof(*txtReg) && (status->reg != MDMParser::REG_UNKNOWN)) + printf(" Registration: %s\r\n", txtReg[status->reg]); + const char* txtAct[] = { "Unknown", "GSM", "Edge", "3G", "CDMA" }; + if (status->act < sizeof(txtAct)/sizeof(*txtAct) && (status->act != MDMParser::ACT_UNKNOWN)) + printf(" Access Technology: %s\r\n", txtAct[status->act]); + if (status->rssi) + printf(" Signal Strength: %d dBm\r\n", status->rssi); + if (status->ber) + printf(" Bit Error Rate: %d\r\n", status->ber); + if (*status->opr) + printf(" Operator: %s\r\n", status->opr); + if (status->lac != 0xFFFF) + printf(" Location Area Code: %04X\r\n", status->lac); + if (status->ci != 0xFFFFFFFF) + printf(" Cell ID: %08X\r\n", status->ci); + if (*status->num) + printf(" Phone Number: %s\r\n", status->num); +} + +void MDMParser::dumpIp(MDMParser::IP ip) +{ + printf("IP Address: " IPSTR "\r\n", IPNUM(ip)); +} + // ---------------------------------------------------------------- int MDMParser::_cbCUSD(int type, const char* buf, int len, char* resp)