Basic xdot code to check how many memory is available for user APP after initializing libxdot lorawan stack

Committer:
Jason Reiss
Date:
Mon May 18 13:12:47 2020 -0500
Revision:
41:67feacfab49c
Parent:
40:3cb0ed329c6e
Child:
42:20f6b29a9903
Add ServerTime event handler to RadioEvent

Who changed what in which revision?

UserRevisionLine numberNew contents of line
Mike Fiore 14:19fae4509473 1 #ifndef __RADIO_EVENT_H__
Mike Fiore 14:19fae4509473 2 #define __RADIO_EVENT_H__
Mike Fiore 14:19fae4509473 3
Mike Fiore 14:19fae4509473 4 #include "dot_util.h"
Mike Fiore 14:19fae4509473 5 #include "mDotEvent.h"
Jason Reiss 34:f6486829a451 6 #include "Fota.h"
Mike Fiore 14:19fae4509473 7
Mike Fiore 14:19fae4509473 8 class RadioEvent : public mDotEvent
Mike Fiore 14:19fae4509473 9 {
Jason Reiss 34:f6486829a451 10
Mike Fiore 14:19fae4509473 11 public:
Mike Fiore 14:19fae4509473 12 RadioEvent() {}
Jason Reiss 34:f6486829a451 13
Mike Fiore 14:19fae4509473 14 virtual ~RadioEvent() {}
Jason Reiss 34:f6486829a451 15
Jason Reiss 40:3cb0ed329c6e 16 virtual void PacketRx(uint8_t port, uint8_t *payload, uint16_t size, int16_t rssi, int16_t snr, lora::DownlinkControl ctrl, uint8_t slot, uint8_t retries, uint32_t address, bool dupRx) {
Jason Reiss 34:f6486829a451 17 mDotEvent::PacketRx(port, payload, size, rssi, snr, ctrl, slot, retries, address, dupRx);
Jason Reiss 34:f6486829a451 18
Jason Reiss 34:f6486829a451 19 #if ACTIVE_EXAMPLE == FOTA_EXAMPLE
Jason Reiss 34:f6486829a451 20 if(port == 200 || port == 201 || port == 202) {
Jason Reiss 34:f6486829a451 21 Fota::getInstance()->processCmd(payload, port, size);
Jason Reiss 34:f6486829a451 22 }
Jason Reiss 34:f6486829a451 23 #endif
Jason Reiss 34:f6486829a451 24 }
Jason Reiss 34:f6486829a451 25
Mike Fiore 14:19fae4509473 26 /*!
Mike Fiore 14:19fae4509473 27 * MAC layer event callback prototype.
Mike Fiore 14:19fae4509473 28 *
Mike Fiore 14:19fae4509473 29 * \param [IN] flags Bit field indicating the MAC events occurred
Mike Fiore 14:19fae4509473 30 * \param [IN] info Details about MAC events occurred
Mike Fiore 14:19fae4509473 31 */
Mike Fiore 14:19fae4509473 32 virtual void MacEvent(LoRaMacEventFlags* flags, LoRaMacEventInfo* info) {
Jason Reiss 34:f6486829a451 33
Mike Fiore 14:19fae4509473 34 if (mts::MTSLog::getLogLevel() == mts::MTSLog::TRACE_LEVEL) {
Mike Fiore 14:19fae4509473 35 std::string msg = "OK";
Mike Fiore 14:19fae4509473 36 switch (info->Status) {
Mike Fiore 14:19fae4509473 37 case LORAMAC_EVENT_INFO_STATUS_ERROR:
Mike Fiore 14:19fae4509473 38 msg = "ERROR";
Mike Fiore 14:19fae4509473 39 break;
Mike Fiore 14:19fae4509473 40 case LORAMAC_EVENT_INFO_STATUS_TX_TIMEOUT:
Mike Fiore 14:19fae4509473 41 msg = "TX_TIMEOUT";
Mike Fiore 14:19fae4509473 42 break;
Mike Fiore 14:19fae4509473 43 case LORAMAC_EVENT_INFO_STATUS_RX_TIMEOUT:
Mike Fiore 14:19fae4509473 44 msg = "RX_TIMEOUT";
Mike Fiore 14:19fae4509473 45 break;
Mike Fiore 14:19fae4509473 46 case LORAMAC_EVENT_INFO_STATUS_RX_ERROR:
Mike Fiore 14:19fae4509473 47 msg = "RX_ERROR";
Mike Fiore 14:19fae4509473 48 break;
Mike Fiore 14:19fae4509473 49 case LORAMAC_EVENT_INFO_STATUS_JOIN_FAIL:
Mike Fiore 14:19fae4509473 50 msg = "JOIN_FAIL";
Mike Fiore 14:19fae4509473 51 break;
Mike Fiore 14:19fae4509473 52 case LORAMAC_EVENT_INFO_STATUS_DOWNLINK_FAIL:
Mike Fiore 14:19fae4509473 53 msg = "DOWNLINK_FAIL";
Mike Fiore 14:19fae4509473 54 break;
Mike Fiore 14:19fae4509473 55 case LORAMAC_EVENT_INFO_STATUS_ADDRESS_FAIL:
Mike Fiore 14:19fae4509473 56 msg = "ADDRESS_FAIL";
Mike Fiore 14:19fae4509473 57 break;
Mike Fiore 14:19fae4509473 58 case LORAMAC_EVENT_INFO_STATUS_MIC_FAIL:
Mike Fiore 14:19fae4509473 59 msg = "MIC_FAIL";
Mike Fiore 14:19fae4509473 60 break;
Mike Fiore 14:19fae4509473 61 default:
Mike Fiore 14:19fae4509473 62 break;
Mike Fiore 14:19fae4509473 63 }
Mike Fiore 14:19fae4509473 64 logTrace("Event: %s", msg.c_str());
Jason Reiss 34:f6486829a451 65
Mike Fiore 14:19fae4509473 66 logTrace("Flags Tx: %d Rx: %d RxData: %d RxSlot: %d LinkCheck: %d JoinAccept: %d",
Mike Fiore 14:19fae4509473 67 flags->Bits.Tx, flags->Bits.Rx, flags->Bits.RxData, flags->Bits.RxSlot, flags->Bits.LinkCheck, flags->Bits.JoinAccept);
Mike Fiore 14:19fae4509473 68 logTrace("Info: Status: %d ACK: %d Retries: %d TxDR: %d RxPort: %d RxSize: %d RSSI: %d SNR: %d Energy: %d Margin: %d Gateways: %d",
Mike Fiore 14:19fae4509473 69 info->Status, info->TxAckReceived, info->TxNbRetries, info->TxDatarate, info->RxPort, info->RxBufferSize,
Mike Fiore 14:19fae4509473 70 info->RxRssi, info->RxSnr, info->Energy, info->DemodMargin, info->NbGateways);
Mike Fiore 14:19fae4509473 71 }
Jason Reiss 34:f6486829a451 72
Mike Fiore 14:19fae4509473 73 if (flags->Bits.Rx) {
Jason Reiss 34:f6486829a451 74
Mike Fiore 14:19fae4509473 75 logDebug("Rx %d bytes", info->RxBufferSize);
Mike Fiore 14:19fae4509473 76 if (info->RxBufferSize > 0) {
jreiss 38:2c027824e046 77 #if ACTIVE_EXAMPLE != FOTA_EXAMPLE
Jason Reiss 34:f6486829a451 78 // print RX data as string and hexadecimal
Mike Fiore 14:19fae4509473 79 std::string rx((const char*)info->RxBuffer, info->RxBufferSize);
Mike Fiore 21:09d05faf0e13 80 printf("Rx data: %s [%s]\r\n", rx.c_str(), mts::Text::bin2hexString(info->RxBuffer, info->RxBufferSize).c_str());
Jason Reiss 36:f1053cb17d4f 81 #endif
Mike Fiore 14:19fae4509473 82 }
Mike Fiore 14:19fae4509473 83 }
Mike Fiore 14:19fae4509473 84 }
Jason Reiss 41:67feacfab49c 85
Jason Reiss 41:67feacfab49c 86 #if ACTIVE_EXAMPLE == FOTA_EXAMPLE
Jason Reiss 41:67feacfab49c 87 virtual void ServerTime(uint32_t seconds, uint8_t sub_seconds) {
Jason Reiss 41:67feacfab49c 88 mDotEvent::ServerTime(seconds, sub_seconds);
Jason Reiss 41:67feacfab49c 89
Jason Reiss 41:67feacfab49c 90 Fota::getInstance()->setClockOffset(seconds);
Jason Reiss 41:67feacfab49c 91 }
Jason Reiss 41:67feacfab49c 92 #endif
Mike Fiore 14:19fae4509473 93 };
Mike Fiore 14:19fae4509473 94
Mike Fiore 14:19fae4509473 95 #endif
Mike Fiore 14:19fae4509473 96