khang 230620

Dependencies:   ISL29011

Committer:
hnript
Date:
Tue Jun 23 15:35:35 2020 +0000
Revision:
41:76130744ebe5
Parent:
21:09d05faf0e13
khang_mbed cli 230620

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"
Mike Fiore 14:19fae4509473 6
hnript 41:76130744ebe5 7 extern uint8_t flag_RX_data;
hnript 41:76130744ebe5 8
Mike Fiore 14:19fae4509473 9 class RadioEvent : public mDotEvent
Mike Fiore 14:19fae4509473 10 {
Mike Fiore 14:19fae4509473 11
Mike Fiore 14:19fae4509473 12 public:
Mike Fiore 14:19fae4509473 13 RadioEvent() {}
Mike Fiore 14:19fae4509473 14
Mike Fiore 14:19fae4509473 15 virtual ~RadioEvent() {}
Mike Fiore 14:19fae4509473 16
Mike Fiore 14:19fae4509473 17 /*!
Mike Fiore 14:19fae4509473 18 * MAC layer event callback prototype.
Mike Fiore 14:19fae4509473 19 *
Mike Fiore 14:19fae4509473 20 * \param [IN] flags Bit field indicating the MAC events occurred
Mike Fiore 14:19fae4509473 21 * \param [IN] info Details about MAC events occurred
Mike Fiore 14:19fae4509473 22 */
Mike Fiore 14:19fae4509473 23 virtual void MacEvent(LoRaMacEventFlags* flags, LoRaMacEventInfo* info) {
Mike Fiore 14:19fae4509473 24
Mike Fiore 14:19fae4509473 25 if (mts::MTSLog::getLogLevel() == mts::MTSLog::TRACE_LEVEL) {
Mike Fiore 14:19fae4509473 26 std::string msg = "OK";
Mike Fiore 14:19fae4509473 27 switch (info->Status) {
Mike Fiore 14:19fae4509473 28 case LORAMAC_EVENT_INFO_STATUS_ERROR:
Mike Fiore 14:19fae4509473 29 msg = "ERROR";
Mike Fiore 14:19fae4509473 30 break;
Mike Fiore 14:19fae4509473 31 case LORAMAC_EVENT_INFO_STATUS_TX_TIMEOUT:
Mike Fiore 14:19fae4509473 32 msg = "TX_TIMEOUT";
Mike Fiore 14:19fae4509473 33 break;
Mike Fiore 14:19fae4509473 34 case LORAMAC_EVENT_INFO_STATUS_RX_TIMEOUT:
Mike Fiore 14:19fae4509473 35 msg = "RX_TIMEOUT";
Mike Fiore 14:19fae4509473 36 break;
Mike Fiore 14:19fae4509473 37 case LORAMAC_EVENT_INFO_STATUS_RX_ERROR:
Mike Fiore 14:19fae4509473 38 msg = "RX_ERROR";
Mike Fiore 14:19fae4509473 39 break;
Mike Fiore 14:19fae4509473 40 case LORAMAC_EVENT_INFO_STATUS_JOIN_FAIL:
Mike Fiore 14:19fae4509473 41 msg = "JOIN_FAIL";
Mike Fiore 14:19fae4509473 42 break;
Mike Fiore 14:19fae4509473 43 case LORAMAC_EVENT_INFO_STATUS_DOWNLINK_FAIL:
Mike Fiore 14:19fae4509473 44 msg = "DOWNLINK_FAIL";
Mike Fiore 14:19fae4509473 45 break;
Mike Fiore 14:19fae4509473 46 case LORAMAC_EVENT_INFO_STATUS_ADDRESS_FAIL:
Mike Fiore 14:19fae4509473 47 msg = "ADDRESS_FAIL";
Mike Fiore 14:19fae4509473 48 break;
Mike Fiore 14:19fae4509473 49 case LORAMAC_EVENT_INFO_STATUS_MIC_FAIL:
Mike Fiore 14:19fae4509473 50 msg = "MIC_FAIL";
Mike Fiore 14:19fae4509473 51 break;
Mike Fiore 14:19fae4509473 52 default:
Mike Fiore 14:19fae4509473 53 break;
Mike Fiore 14:19fae4509473 54 }
Mike Fiore 14:19fae4509473 55 logTrace("Event: %s", msg.c_str());
Mike Fiore 14:19fae4509473 56
Mike Fiore 14:19fae4509473 57 logTrace("Flags Tx: %d Rx: %d RxData: %d RxSlot: %d LinkCheck: %d JoinAccept: %d",
Mike Fiore 14:19fae4509473 58 flags->Bits.Tx, flags->Bits.Rx, flags->Bits.RxData, flags->Bits.RxSlot, flags->Bits.LinkCheck, flags->Bits.JoinAccept);
Mike Fiore 14:19fae4509473 59 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 60 info->Status, info->TxAckReceived, info->TxNbRetries, info->TxDatarate, info->RxPort, info->RxBufferSize,
Mike Fiore 14:19fae4509473 61 info->RxRssi, info->RxSnr, info->Energy, info->DemodMargin, info->NbGateways);
Mike Fiore 14:19fae4509473 62 }
Mike Fiore 14:19fae4509473 63
hnript 41:76130744ebe5 64 if (flags->Bits.Rx)
hnript 41:76130744ebe5 65 {
hnript 41:76130744ebe5 66 flag_RX_data =0;
Mike Fiore 14:19fae4509473 67 logDebug("Rx %d bytes", info->RxBufferSize);
hnript 41:76130744ebe5 68 if (info->RxBufferSize > 0)
hnript 41:76130744ebe5 69 {
Mike Fiore 21:09d05faf0e13 70 // print RX data as string and hexadecimal
Mike Fiore 14:19fae4509473 71 std::string rx((const char*)info->RxBuffer, info->RxBufferSize);
Mike Fiore 21:09d05faf0e13 72 printf("Rx data: %s [%s]\r\n", rx.c_str(), mts::Text::bin2hexString(info->RxBuffer, info->RxBufferSize).c_str());
hnript 41:76130744ebe5 73 flag_RX_data = 1;
Mike Fiore 14:19fae4509473 74 }
Mike Fiore 14:19fae4509473 75 }
Mike Fiore 14:19fae4509473 76 }
Mike Fiore 14:19fae4509473 77 };
Mike Fiore 14:19fae4509473 78
Mike Fiore 14:19fae4509473 79 #endif
Mike Fiore 14:19fae4509473 80