Here it is ...
Dependencies: libxDot-mbed5 TSL2561
Fork of Dot-Examples by
Diff: examples/src/ota_example.cpp
- Revision:
- 39:0d4362063352
- Parent:
- 38:401bd606d2dd
- Child:
- 40:314e6b1c289f
--- a/examples/src/ota_example.cpp Wed Jul 25 18:30:01 2018 +0000 +++ b/examples/src/ota_example.cpp Thu Jul 26 12:03:47 2018 -0400 @@ -1,6 +1,7 @@ #include "dot_util.h" #include "RadioEvent.h" #include "TSL2561.h" + #if ACTIVE_EXAMPLE == OTA_EXAMPLE @@ -23,8 +24,16 @@ // * either the network name and passphrase can be used or // // the network ID (8 bytes) and KEY (16 bytes) // ///////////////////////////////////////////////////////////// -static std::string network_name = "MTCDT-19400691"; -static std::string network_passphrase = "MTCDT-19400691"; + +// wifi gateway +//static std::string network_name = "MTCDT-19400691"; +//static std::string network_passphrase = "MTCDT-19400691"; + +// cellular gateway +static std::string network_name = "iuiot-gw1"; +static std::string network_passphrase = "pivotiot"; + + static uint8_t network_id[] = { 0x6C, 0x4E, 0xEF, 0x66, 0xF4, 0x79, 0x86, 0xA6 }; static uint8_t network_key[] = { 0x1F, 0x33, 0xA1, 0x70, 0xA5, 0xF1, 0xFD, 0xA0, 0xAB, 0x69, 0x7A, 0xAE, 0x2B, 0x95, 0x91, 0x6B }; static uint8_t frequency_sub_band = 1; @@ -37,13 +46,16 @@ // in sleep mode, IO state is maintained, RAM is retained, and application will resume after waking up // in deepsleep mode, IOs float, RAM is lost, and application will start from beginning after waking up // if deep_sleep == true, device will enter deepsleep mode -static bool deep_sleep = true; +static bool deep_sleep = false; +static const uint16_t HOURLY_SLEEP_INTERVAL = 3600; // 1 hour +static const uint16_t DAILY_SLEEP_INTERVAL = 43200; // 12 hours mDot* dot = NULL; lora::ChannelPlan* plan = NULL; - +DigitalOut led1(LED1); Serial pc(PA_9, PA_10); +TSL2561 lightSensor(PB_9, PB_8); int main() { pc.baud(115200); @@ -51,7 +63,18 @@ // Custom event handler for automatically displaying RX data RadioEvent events; - + + ///////////////////////////// + // visual display + led1 = 0; + for(int i = 0; i < 5; i++) { + led1 = 1; + wait(1); + led1 = 0; + wait(1); + } + + mts::MTSLog::setLogLevel(mts::MTSLog::TRACE_LEVEL); @@ -153,7 +176,7 @@ // hourly loop while( counter < 12) { - uint8_t light_data = get_light_data(); + uint8_t light_data = get_light_data(&lightSensor, &pc); //pc.printf("pseudo-light data: %d\r\n", light_data); pc.printf("\r\nhour: %d\r\n", ++counter); @@ -177,7 +200,7 @@ } // ONLY ONE of the three functions below should be uncommented depending on the desired wakeup method - sleep_wake_rtc_only(deep_sleep, 30, &pc); + sleep_wake_rtc_only(deep_sleep, HOURLY_SLEEP_INTERVAL, &pc); //sleep_wake_interrupt_only(deep_sleep); //sleep_wake_rtc_or_interrupt(deep_sleep); } @@ -191,8 +214,6 @@ pc.printf("\r\n"); pc.printf("capacity tx_data: %d\r\n", tx_data.capacity()); - //tx_data.reserve(tx_data.size()); - //pc.printf("cap resized: %d\r\n", tx_data.capacity()); pc.printf("sized tx_data: %d\r\n", tx_data.size()); //actually send the data pc.printf("sending data\r\n"); @@ -208,6 +229,9 @@ tx_data.erase(tx_data.begin(), tx_data.end()); counter = 0; pc.printf("deleted tx_data and reset counter\r\ncap: %d size: %d\r\n", tx_data.capacity(), tx_data.size()); + + // sleep for the day + sleep_wake_rtc_only(deep_sleep, DAILY_SLEEP_INTERVAL, &pc); }