Error with receive value from M2X, sharing it for debug purpose

Dependencies:   SocketModem jsonlite mbed

Fork of MTS_M2x_Example by Multi-Hackers

Committer:
mfiore
Date:
Sun Jan 05 07:00:38 2014 +0000
Revision:
5:d4a4e2577be3
Parent:
2:76e0d5968991
Child:
6:0dbcf434679b
update SocketModem library; remove wait before Cellular::init() function

Who changed what in which revision?

UserRevisionLine numberNew contents of line
mfiore 0:032beb056844 1 #include "mbed.h"
mfiore 0:032beb056844 2 #include "M2XStreamClient.h"
mfiore 0:032beb056844 3 #include "include_me.h"
mfiore 0:032beb056844 4
mfiore 0:032beb056844 5 using namespace mts;
mfiore 0:032beb056844 6
mfiore 5:d4a4e2577be3 7 const char key[] = "";
mfiore 5:d4a4e2577be3 8 const char feed[] = "";
sam_grove 2:76e0d5968991 9 const char stream[] = "amb-temp";
mfiore 0:032beb056844 10
mfiore 1:b12a128aae0e 11 // set to 1 for cellular shield board
mfiore 1:b12a128aae0e 12 // set to 0 for wifi shield board
sam_grove 2:76e0d5968991 13 #define CELL_SHIELD 0
sam_grove 2:76e0d5968991 14
sam_grove 2:76e0d5968991 15 std::string ssid = "belkin54g";
mfiore 5:d4a4e2577be3 16 std::string phrase = "hackathon";
mfiore 5:d4a4e2577be3 17 Wifi::SecurityType security_type = Wifi::WPA;
mfiore 1:b12a128aae0e 18
mfiore 0:032beb056844 19 int main() {
mfiore 1:b12a128aae0e 20 #if CELL_SHIELD
mfiore 0:032beb056844 21 MTSSerialFlowControl* serial = new MTSSerialFlowControl(PTD3, PTD2, PTA12, PTC8);
mfiore 0:032beb056844 22 serial->baud(115200);
mfiore 1:b12a128aae0e 23 Transport::setTransport(Transport::CELLULAR);
mfiore 0:032beb056844 24 Cellular* cell = Cellular::getInstance();
sam_grove 2:76e0d5968991 25 cell->init(serial, PTA4, PTC9); //DCD and DTR pins for KL46Z
mfiore 0:032beb056844 26
mfiore 0:032beb056844 27 int max_tries = 5;
mfiore 0:032beb056844 28 int i;
mfiore 0:032beb056844 29 std::string apn = "wap.cingular";
mfiore 0:032beb056844 30
mfiore 0:032beb056844 31 i = 0;
mfiore 0:032beb056844 32 while (i++ < max_tries) {
mfiore 0:032beb056844 33 if (cell->getRegistration() == Cellular::REGISTERED) {
mfiore 0:032beb056844 34 printf("registered with tower\n\r");
mfiore 0:032beb056844 35 break;
mfiore 0:032beb056844 36 } else if (i >= max_tries) {
mfiore 0:032beb056844 37 printf("failed to register with tower\n\r");
mfiore 0:032beb056844 38 } else {
mfiore 0:032beb056844 39 wait(3);
mfiore 0:032beb056844 40 }
mfiore 0:032beb056844 41 }
mfiore 0:032beb056844 42
mfiore 1:b12a128aae0e 43 printf("signal strength: %d\n\r", cell->getSignalStrength());
mfiore 1:b12a128aae0e 44
mfiore 0:032beb056844 45 i = 0;
mfiore 1:b12a128aae0e 46 printf("setting APN to %s\n\r", apn.c_str());
mfiore 0:032beb056844 47 while (i++ < max_tries) {
mfiore 0:032beb056844 48 if (cell->setApn(apn) == SUCCESS) {
mfiore 0:032beb056844 49 printf("successfully set APN\n\r");
mfiore 0:032beb056844 50 break;
mfiore 0:032beb056844 51 } else if (i >= max_tries) {
mfiore 0:032beb056844 52 printf("failed to set APN\n\r");
mfiore 0:032beb056844 53 } else {
mfiore 0:032beb056844 54 wait(1);
mfiore 0:032beb056844 55 }
mfiore 0:032beb056844 56 }
mfiore 0:032beb056844 57
mfiore 0:032beb056844 58 i = 0;
mfiore 1:b12a128aae0e 59 printf("bringing up PPP link\n\r");
mfiore 0:032beb056844 60 while (i++ < max_tries) {
mfiore 0:032beb056844 61 if (cell->connect()) {
mfiore 0:032beb056844 62 printf("PPP link is up\n\r");
mfiore 0:032beb056844 63 break;
mfiore 0:032beb056844 64 } else if (i >= max_tries) {
mfiore 0:032beb056844 65 printf("failed to bring PPP link up\n\r");
mfiore 0:032beb056844 66 } else {
mfiore 0:032beb056844 67 wait(1);
mfiore 0:032beb056844 68 }
mfiore 0:032beb056844 69 }
mfiore 1:b12a128aae0e 70 #else
mfiore 1:b12a128aae0e 71 for (int i = 6; i >= 0; i = i - 2) {
mfiore 1:b12a128aae0e 72 wait(2);
mfiore 1:b12a128aae0e 73 printf("Waiting %d seconds...\n\r", i);
mfiore 0:032beb056844 74 }
mfiore 0:032beb056844 75 MTSSerial* serial = new MTSSerial(PTD3, PTD2, 256, 256);
mfiore 0:032beb056844 76 serial->baud(9600);
mfiore 0:032beb056844 77 Transport::setTransport(Transport::WIFI);
mfiore 0:032beb056844 78 Wifi* wifi = Wifi::getInstance();
mfiore 0:032beb056844 79 printf("Init: %s\n\r", wifi->init(serial) ? "SUCCESS" : "FAILURE");
mfiore 5:d4a4e2577be3 80 printf("Set Network: %s\n\r", getCodeNames(wifi->setNetwork(ssid, security_type, phrase)).c_str());
mfiore 0:032beb056844 81 printf("Set DHCP: %s\n\r", getCodeNames(wifi->setDeviceIP("DHCP")).c_str());
mfiore 0:032beb056844 82 printf("Signal Strnegth (dBm): %d\n\r", wifi->getSignalStrength());
mfiore 0:032beb056844 83 printf("Is Connected: %s\n\r", wifi->isConnected() ? "True" : "False");
mfiore 0:032beb056844 84 printf("Connect: %s\n\r", wifi->connect() ? "Success" : "Failure");
mfiore 0:032beb056844 85 printf("Is Connected: %s\n\r", wifi->isConnected() ? "True" : "False");
mfiore 1:b12a128aae0e 86 #endif
mfiore 0:032beb056844 87
mfiore 0:032beb056844 88 /* send some data */
mfiore 1:b12a128aae0e 89 Client client;
mfiore 1:b12a128aae0e 90 M2XStreamClient m2xClient(&client, key);
mfiore 0:032beb056844 91 int ret;
mfiore 0:032beb056844 92 int num;
mfiore 0:032beb056844 93 while (true) {
mfiore 0:032beb056844 94 num = rand();
mfiore 0:032beb056844 95 printf("sending %d\r\n", num);
mfiore 0:032beb056844 96 ret = m2xClient.send(feed, stream, num);
mfiore 0:032beb056844 97 printf("send() returned %d\r\n", ret);
mfiore 0:032beb056844 98 wait(5);
mfiore 0:032beb056844 99 }
mfiore 0:032beb056844 100 }