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