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

Dependencies:   SocketModem jsonlite mbed

Fork of MTS_M2x_Example by Multi-Hackers

Committer:
sam_grove
Date:
Sat Jan 04 06:37:50 2014 +0000
Revision:
2:76e0d5968991
Parent:
1:b12a128aae0e
Child:
3:d24e8bec5610
Child:
5:d4a4e2577be3
Initial commit

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