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.
Fork of GPRS by
Diff: gprs.cpp
- Revision:
- 4:63a2619b423b
- Parent:
- 3:48ee24a4b0f3
- Child:
- 5:ac2342f162fa
--- a/gprs.cpp Fri Jan 10 05:59:36 2014 +0000
+++ b/gprs.cpp Tue Jan 21 06:44:58 2014 +0000
@@ -19,24 +19,8 @@
License along with this library; if not, write to the Free Software
Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
*/
-
-
#include "gprs.h"
-int GPRS::init(void)
-{
- wait(0.5);
- sendCmd("AT+CFUN=1\r\n");
- wait(1);
- if(0 != checkSIMStatus()) { //check SIM card status
- return -1;
- }
- if(checkSignalStrength()<1) { //check Signal Strength
- return -1;
- }
- return 0;
-}
-
int GPRS::readBuffer(char *buffer,int count)
{
int i = 0;
@@ -101,14 +85,26 @@
return 0;
}
-
-
int GPRS::sendCmdAndWaitForResp(char *cmd, char *resp, int timeout)
{
sendCmd(cmd);
return waitForResp(resp,timeout);
}
+int GPRS::init(void)
+{
+ if(0 != checkSIMStatus()) {
+ return -1;
+ }
+ if(checkSignalStrength()<1) {
+ return -1;
+ }
+ if(0 != settingSMS()) {
+ return -1;
+ }
+ return 0;
+}
+
int GPRS::checkSIMStatus(void)
{
char gprsBuffer[30];
@@ -150,67 +146,70 @@
return index;
}
+int GPRS::settingSMS(void)
+{
+ if(0 != sendCmdAndWaitForResp("AT+CNMI=2,2\r\n", "OK", DEFAULT_TIMEOUT)) {
+ return -1;
+ }
+ if(0 != sendCmdAndWaitForResp("AT+CMGF=1\r\n", "OK", DEFAULT_TIMEOUT)) {
+ return -1;
+ }
+ return 0;
+}
+
int GPRS::sendSMS(char *number, char *data)
{
char cmd[64];
- if(0 != sendCmdAndWaitForResp("AT+CMGF=1\r\n", "OK", DEFAULT_TIMEOUT)) { // Set message mode to ASCII
- return -1;
+ while(gprsSerial.readable()) {
+ char c = gprsSerial.getc();
}
- wait(0.5);
- // Set the phone number
- snprintf(cmd, sizeof(cmd),"AT+CMGS=\"%s\"\r\n", number);
+ snprintf(cmd, sizeof(cmd),"AT+CMGS=\"%s\"\r\n",number);
if(0 != sendCmdAndWaitForResp(cmd,">",DEFAULT_TIMEOUT)) {
return -1;
}
wait(1);
- gprsSerial.puts(data);// Send Message
- wait(0.5);
- gprsSerial.putc(0x1A);//end mark
+ gprsSerial.puts(data);
+ gprsSerial.putc((char)0x1a);
return 0;
}
-int GPRS::readSMS(char *buffer, char *message, bool check)
+int GPRS::readSMS(char *message, int index)
{
- int index,i = 0;
+ int i = 0;
char gprsBuffer[100];
char *p,*s;
-
- if(sscanf(buffer, "$$+CMTI: \"SM\",%d", &index)>0) {
- gprsSerial.printf("AT+CMGR=%d\r\n", index);
- } else {
- return -1;
- }
+ gprsSerial.printf("AT+CMGR=%d\r\n",index);
cleanBuffer(gprsBuffer,100);
readBuffer(gprsBuffer,100);
- if(NULL == ( s = strstr(gprsBuffer,"+CMGR: \"REC UNREAD\""))) {
+ if(NULL == ( s = strstr(gprsBuffer,"+CMGR"))) {
return -1;
}
-
- //check phone number
- if(check) {
- char number[20];
- snprintf(number,sizeof(number),"\"+86%s\"",phoneNumber); //for China
- p = s + 20;
- if(0 != (strncmp(number,p,14))) {
- return -1;
+ if(NULL != ( s = strstr(gprsBuffer,"+32"))) {
+ p = s + 6;
+ while((*p != '$')&&(i < SMS_MAX_LENGTH-1)) {
+ message[i++] = *(p++);
}
+ message[i] = '\0';
}
- p = s + 64;
- while(*p != '$') {
- message[i++] = *(p++);
- }
- message[i] = '\0';
return 0;
}
int GPRS::deleteSMS(int index)
{
- char cmd[64];
+ char cmd[32];
snprintf(cmd,sizeof(cmd),"AT+CMGD=%d\r\n",index);
sendCmd(cmd);
return 0;
}
+int GPRS::getSMS(char* message)
+{
+ if(NULL != messageBuffer) {
+ strncpy(message,messageBuffer,SMS_MAX_LENGTH);
+ }
+ return 0;
+}
+
int GPRS::callUp(char *number)
{
if(0 != sendCmdAndWaitForResp("AT+COLP=1\r\n","OK",5)) {
@@ -227,18 +226,23 @@
return 0;
}
-int GPRS::loop(bool check)
+int GPRS::loopHandle(void)
{
char gprsBuffer[100];
int i = 0;
+ char *s = NULL;
cleanBuffer(gprsBuffer,100);
+ while(gprsSerial.readable()) {
+ char c = gprsSerial.getc();
+ }
+ wait(1);
+START:
while(1) {
if(gprsSerial.readable()) {
break;
}
wait(1);
}
-
timeCnt.start(); // start timer
while(1) {
while (gprsSerial.readable()) {
@@ -257,21 +261,27 @@
break;
}
}
-
if(NULL != strstr(gprsBuffer,"RING")) {
- if(0 != answer()) {
+ return MESSAGE_RING;
+ } else if(NULL != (s = strstr(gprsBuffer,"+CMT"))) { //SMS: $$+CMTI: "SM",24$$
+ if(NULL != (s = strstr(gprsBuffer,"+32"))) {
+ s += 6;
+ int i = 0;
+ cleanBuffer(messageBuffer,SMS_MAX_LENGTH);
+ while((*s != '$')&&(i < SMS_MAX_LENGTH-1)) {
+ messageBuffer[i++] = *(s++);
+ }
+ messageBuffer[i] = '\0';
+ return MESSAGE_SMS;
+ } else {
+ goto START;
}
- } else if(NULL != strstr(gprsBuffer,"$$+CMTI: \"SM\"")) { //SMS: $$+CMTI: "SM",24$$
- char message[64];
- if(0 != readSMS(gprsBuffer, message, check)) {
- }
+ } else {
+ goto START;
}
- return 0;
}
-/****************************************GPRS TCP CONNECT************************************/
-
int GPRS::connectTCP(char *ip, char *port)
{
char cipstart[50];
@@ -309,29 +319,3 @@
sendCmd("AT+CIPSHUT\r\n");
return 0;
}
-
-/****************************************GPRS DEBUG******************************************/
-void GPRS::serialDebug(PinName tx, PinName rx)
-{
- char buffer[64];
- int count = 0;
- Serial pc(tx,rx);
- while(1) {
- if(gprsSerial.readable()) {
- while(gprsSerial.readable()) {
- char c = gprsSerial.getc();
- buffer[count++] = c;
- if(count == 64) break;
- }
- pc.puts(buffer);
- for(int i = 0; i < count; i++) {
- buffer[i] = NULL;
- }
- count = 0;
- }
-
- if(pc.readable()) {
- gprsSerial.putc(pc.getc());
- }
- }
-}
