Multitech + KL46Z NanoService example with the RTOS
Dependencies: mbed SocketModem nanoservice_client_1_12
Diff: main.cpp
- Revision:
- 1:5147d3fa7816
- Parent:
- 0:f739ace74102
- Child:
- 2:1592223f12e1
--- a/main.cpp Mon Feb 17 21:39:28 2014 +0000 +++ b/main.cpp Mon Feb 17 22:26:04 2014 +0000 @@ -2,10 +2,93 @@ #include "config.h" #include "debug.h" +// Multitech Cellular includes +#include "Cellular.h" +#include "Endpoint.h" +#include "IPStack.h" +#include "MTSSerialFlowControl.h" + +using namespace mts; + +Cellular* cellular; + +// **************************************************************************** +// Cellular initialization + +static void cellular_init() +{ + + //Setup serial interface to radio + MTSSerialFlowControl* serial = new MTSSerialFlowControl(PTD3, PTD2, PTA12, PTC8); + serial->baud(115200); + + //Setup Cellular class + cellular = Cellular::getInstance(); + cellular->init(serial, PTA4, PTC9); //DCD and DTR pins for KL46Z + + //Run status and configuration commands + DEBUG("\n\r////Start Status and Configuration Commands////"); + DEBUG("Command Test: %s", getCodeNames(cellular->test()).c_str()); //Make sure you can talk to the radio + DEBUG("Signal Strength: %d", cellular->getSignalStrength()); //Check the signal strength should be above 8 + + //Makes sure you are reistered with cell + DEBUG("Registration State: %s", Cellular::getRegistrationNames(cellular->getRegistration()).c_str()); + + //Shows example of how to send other commands, look at AT command guide for more info + DEBUG("Send Basic Command (AT): %s", getCodeNames(cellular->sendBasicCommand("AT", 1000)).c_str()); + DEBUG("Send Command (AT+CSQ): %s", cellular->sendCommand("AT+CSQ", 1000).c_str()); + + //Start Test + DEBUG("\n\r////Start Network Connectivity Test////"); + DEBUG("Set APN: %s", getCodeNames(cellular->setApn(CELLULAR_APN)).c_str()); //Use APN from service provider!!! + + //Setup a data connection + DEBUG("Attempting to Connect, this may take some time..."); + while (!cellular->connect()) { + DEBUG("Failed to connect... Trying again."); + wait(1); + } + DEBUG("Connected to the Network!"); + + //Try pinging default server "8.8.8.8" (Google's DNS) + DEBUG("Ping Valid: %s", cellular->ping() ? "true" : "false"); + wait(3); + +} + +// **************************************************************************** +// NSP initialization + +static void nsp_init() +{ + // Bind the port + cellular->bind(EP_PORT); + + // Open a TCP connection + while (!cellular->open(NSP_ADDRESS, NSP_PORT, mts::IPStack::TCP)) + { + DEBUG("TCP connection failed."); + wait(3); + } + DEBUG("TCP connection to NSP successful."); + cellular->write("test", 4, -1); + +// nsp.set_address(NSP_ADDRESS, NSP_PORT); + +// DEBUG("name: %s", endpoint_name); +// DEBUG("NSP=%s - port %d\n", NSP_ADDRESS, NSP_PORT); +} + int main() { + printf("\r\n*****************************************************************************\r\n"); DEBUG("NanoService Example for KL46Z + Multitech Cellular"); + // Inititalize the Cellular modem + cellular_init(); + + // Bind the socket and configure NSP settings + nsp_init(); }