MTDOT-BOX-EVB-Factory-Firmware

Dependencies:   NCP5623B GpsParser ISL29011 libmDot-mbed5 MTS-Serial MMA845x DOGS102 MPL3115A2

Committer:
Mike Fiore
Date:
Thu Feb 04 12:36:36 2016 -0600
Revision:
1:71125aa00e33
Child:
5:10ea08959743
add rest of source - version 2.0.0

Who changed what in which revision?

UserRevisionLine numberNew contents of line
Mike Fiore 1:71125aa00e33 1 /* Copyright (c) <2016> <MultiTech Systems>, MIT License
Mike Fiore 1:71125aa00e33 2 *
Mike Fiore 1:71125aa00e33 3 * Permission is hereby granted, free of charge, to any person obtaining a copy of this software
Mike Fiore 1:71125aa00e33 4 * and associated documentation files (the "Software"), to deal in the Software without restriction,
Mike Fiore 1:71125aa00e33 5 * including without limitation the rights to use, copy, modify, merge, publish, distribute,
Mike Fiore 1:71125aa00e33 6 * sublicense, and/or sell copies of the Software, and to permit persons to whom the Software is
Mike Fiore 1:71125aa00e33 7 * furnished to do so, subject to the following conditions:
Mike Fiore 1:71125aa00e33 8 *
Mike Fiore 1:71125aa00e33 9 * The above copyright notice and this permission notice shall be included in all copies or
Mike Fiore 1:71125aa00e33 10 * substantial portions of the Software.
Mike Fiore 1:71125aa00e33 11 *
Mike Fiore 1:71125aa00e33 12 * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING
Mike Fiore 1:71125aa00e33 13 * BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
Mike Fiore 1:71125aa00e33 14 * NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM,
Mike Fiore 1:71125aa00e33 15 * DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
Mike Fiore 1:71125aa00e33 16 * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
Mike Fiore 1:71125aa00e33 17 */
Mike Fiore 1:71125aa00e33 18
Mike Fiore 1:71125aa00e33 19 #include "ModeJoin.h"
Mike Fiore 1:71125aa00e33 20 #include "MTSLog.h"
Mike Fiore 1:71125aa00e33 21 #include "MTSText.h"
Mike Fiore 1:71125aa00e33 22
Mike Fiore 1:71125aa00e33 23 ModeJoin::ModeJoin(DOGS102* lcd, ButtonHandler* buttons, mDot* dot, LoRaHandler* lora, GPSPARSER* gps, SensorHandler* sensors)
Mike Fiore 1:71125aa00e33 24 : Mode(lcd, buttons, dot, lora, gps, sensors),
Mike Fiore 1:71125aa00e33 25 _join(lcd, _band),
Mike Fiore 1:71125aa00e33 26 _joined(false)
Mike Fiore 1:71125aa00e33 27 {}
Mike Fiore 1:71125aa00e33 28
Mike Fiore 1:71125aa00e33 29 ModeJoin::~ModeJoin() {}
Mike Fiore 1:71125aa00e33 30
Mike Fiore 1:71125aa00e33 31 bool ModeJoin::start() {
Mike Fiore 1:71125aa00e33 32 bool joining = false;
Mike Fiore 1:71125aa00e33 33
Mike Fiore 1:71125aa00e33 34 // clear any stale signals
Mike Fiore 1:71125aa00e33 35 osSignalClear(_main_id, buttonSignal | loraSignal);
Mike Fiore 1:71125aa00e33 36
Mike Fiore 1:71125aa00e33 37 _initial_data_rate = _dot->getTxDataRate();
Mike Fiore 1:71125aa00e33 38 _initial_power = _dot->getTxPower();
Mike Fiore 1:71125aa00e33 39
Mike Fiore 1:71125aa00e33 40 _data_rate = (_band == mDot::FB_915) ? mDot::SF_10 : mDot::SF_12;
Mike Fiore 1:71125aa00e33 41 _power = 20;
Mike Fiore 1:71125aa00e33 42 _joined = false;
Mike Fiore 1:71125aa00e33 43
Mike Fiore 1:71125aa00e33 44 display();
Mike Fiore 1:71125aa00e33 45
Mike Fiore 1:71125aa00e33 46 _dot->setTxDataRate(_data_rate);
Mike Fiore 1:71125aa00e33 47 _dot->setTxPower(_power);
Mike Fiore 1:71125aa00e33 48 _lora->resetJoinAttempts();
Mike Fiore 1:71125aa00e33 49
Mike Fiore 1:71125aa00e33 50 while (! _joined) {
Mike Fiore 1:71125aa00e33 51 _next_tx = _dot->getNextTxMs();
Mike Fiore 1:71125aa00e33 52 if (! joining && _next_tx > 0) {
Mike Fiore 1:71125aa00e33 53 logInfo("next tx %lu ms", _next_tx);
Mike Fiore 1:71125aa00e33 54 _join.updateStatus("Waiting...");
Mike Fiore 1:71125aa00e33 55 _join.updateCountdown(_next_tx / 1000);
Mike Fiore 1:71125aa00e33 56 } else if (! joining) {
Mike Fiore 1:71125aa00e33 57 logInfo("attempting to join");
Mike Fiore 1:71125aa00e33 58 joining = true;
Mike Fiore 1:71125aa00e33 59 display();
Mike Fiore 1:71125aa00e33 60 _lora->join();
Mike Fiore 1:71125aa00e33 61 }
Mike Fiore 1:71125aa00e33 62
Mike Fiore 1:71125aa00e33 63 osEvent e = Thread::signal_wait(0, 250);
Mike Fiore 1:71125aa00e33 64 if (e.status == osEventSignal) {
Mike Fiore 1:71125aa00e33 65 if (e.value.signals & buttonSignal) {
Mike Fiore 1:71125aa00e33 66 _be = _buttons->getButtonEvent();
Mike Fiore 1:71125aa00e33 67 switch (_be) {
Mike Fiore 1:71125aa00e33 68 case ButtonHandler::sw1_press:
Mike Fiore 1:71125aa00e33 69 _dot->setTxDataRate(_initial_data_rate);
Mike Fiore 1:71125aa00e33 70 _dot->setTxPower(_initial_power);
Mike Fiore 1:71125aa00e33 71 return false;
Mike Fiore 1:71125aa00e33 72 case ButtonHandler::sw2_press:
Mike Fiore 1:71125aa00e33 73 break;
Mike Fiore 1:71125aa00e33 74 case ButtonHandler::sw1_hold:
Mike Fiore 1:71125aa00e33 75 _dot->setTxDataRate(_initial_data_rate);
Mike Fiore 1:71125aa00e33 76 _dot->setTxPower(_initial_power);
Mike Fiore 1:71125aa00e33 77 return false;
Mike Fiore 1:71125aa00e33 78 }
Mike Fiore 1:71125aa00e33 79 }
Mike Fiore 1:71125aa00e33 80 if (e.value.signals & loraSignal) {
Mike Fiore 1:71125aa00e33 81 _ls = _lora->getStatus();
Mike Fiore 1:71125aa00e33 82 switch (_ls) {
Mike Fiore 1:71125aa00e33 83 case LoRaHandler::join_success:
Mike Fiore 1:71125aa00e33 84 _join.updateStatus("Join Success!");
Mike Fiore 1:71125aa00e33 85 _join.displayCancel(false);
Mike Fiore 1:71125aa00e33 86 logInfo("joined");
Mike Fiore 1:71125aa00e33 87 _joined = true;
Mike Fiore 1:71125aa00e33 88 osDelay(2000);
Mike Fiore 1:71125aa00e33 89 _dot->setTxDataRate(_initial_data_rate);
Mike Fiore 1:71125aa00e33 90 _dot->setTxPower(_initial_power);
Mike Fiore 1:71125aa00e33 91 return true;
Mike Fiore 1:71125aa00e33 92
Mike Fiore 1:71125aa00e33 93 case LoRaHandler::join_failure:
Mike Fiore 1:71125aa00e33 94 logInfo("failed to join");
Mike Fiore 1:71125aa00e33 95 joining = false;
Mike Fiore 1:71125aa00e33 96 break;
Mike Fiore 1:71125aa00e33 97 }
Mike Fiore 1:71125aa00e33 98 }
Mike Fiore 1:71125aa00e33 99 }
Mike Fiore 1:71125aa00e33 100 }
Mike Fiore 1:71125aa00e33 101
Mike Fiore 1:71125aa00e33 102 _dot->setTxDataRate(_initial_data_rate);
Mike Fiore 1:71125aa00e33 103 _dot->setTxPower(_initial_power);
Mike Fiore 1:71125aa00e33 104 return false;
Mike Fiore 1:71125aa00e33 105 }
Mike Fiore 1:71125aa00e33 106
Mike Fiore 1:71125aa00e33 107 void ModeJoin::display() {
Mike Fiore 1:71125aa00e33 108 _join.display();
Mike Fiore 1:71125aa00e33 109 _join.updateStatus("Joining...");
Mike Fiore 1:71125aa00e33 110 if (_dot->getJoinMode() == mDot::MANUAL) {
Mike Fiore 1:71125aa00e33 111 _join.updateId(mts::Text::bin2hexString(_dot->getNetworkId()));
Mike Fiore 1:71125aa00e33 112 _join.updateKey(mts::Text::bin2hexString(_dot->getNetworkKey()));
Mike Fiore 1:71125aa00e33 113 } else {
Mike Fiore 1:71125aa00e33 114 _join.updateId(_dot->getNetworkName());
Mike Fiore 1:71125aa00e33 115 _join.updateKey(_dot->getNetworkPassphrase());
Mike Fiore 1:71125aa00e33 116 }
Mike Fiore 1:71125aa00e33 117 if (_band == mDot::FB_915) {
Mike Fiore 1:71125aa00e33 118 _sub_band = _dot->getFrequencySubBand();
Mike Fiore 1:71125aa00e33 119 _join.updateFsb(_sub_band);
Mike Fiore 1:71125aa00e33 120 }
Mike Fiore 1:71125aa00e33 121 // mDot::DataRateStr returns format SF_XX - we only want to display the XX part
Mike Fiore 1:71125aa00e33 122 _join.updateRate(_dot->DataRateStr(_data_rate).substr(3));
Mike Fiore 1:71125aa00e33 123 _join.updatePower(_power);
Mike Fiore 1:71125aa00e33 124 _join.updateAttempt(_lora->getJoinAttempts());
Mike Fiore 1:71125aa00e33 125 }
Mike Fiore 1:71125aa00e33 126