this is the working code for the xdot to read in serial from the pi and send it over LoRa
Mote.h@19:aa5b1fcd05be, 2019-08-29 (annotated)
- Committer:
- Jenkins@KEILDM1.dc.multitech.prv
- Date:
- Thu Aug 29 12:21:40 2019 -0500
- Revision:
- 19:aa5b1fcd05be
- Parent:
- 18:d7332302f5f1
- Child:
- 21:bc12c888e7dc
xdot-library revision 3.2.1 and mbed-os revision mbed-os-5.13.4
Who changed what in which revision?
User | Revision | Line number | New contents of line |
---|---|---|---|
Jenkins@KEILDM1.dc.multitech.prv | 2:4569491293d7 | 1 | /** __ ___ ____ _ ______ __ ____ __ ____ |
Jenkins@KEILDM1.dc.multitech.prv | 2:4569491293d7 | 2 | * / |/ /_ __/ / /_(_)__/_ __/__ ____/ / / __/_ _____ / /____ __ _ ___ / _/__ ____ |
Jenkins@KEILDM1.dc.multitech.prv | 2:4569491293d7 | 3 | * / /|_/ / // / / __/ /___// / / -_) __/ _ \ _\ \/ // (_-</ __/ -_) ' \(_-< _/ // _ \/ __/ __ |
Jenkins@KEILDM1.dc.multitech.prv | 2:4569491293d7 | 4 | * /_/ /_/\_,_/_/\__/_/ /_/ \__/\__/_//_/ /___/\_, /___/\__/\__/_/_/_/___/ /___/_//_/\__/ /_/ |
Jenkins@KEILDM1.dc.multitech.prv | 2:4569491293d7 | 5 | * Copyright (C) 2015 by Multi-Tech Systems /___/ |
Jenkins@KEILDM1.dc.multitech.prv | 2:4569491293d7 | 6 | * |
Jenkins@KEILDM1.dc.multitech.prv | 2:4569491293d7 | 7 | * |
Jenkins@KEILDM1.dc.multitech.prv | 2:4569491293d7 | 8 | * @author Jason Reiss |
Jenkins@KEILDM1.dc.multitech.prv | 2:4569491293d7 | 9 | * @date 10-31-2015 |
Jenkins@KEILDM1.dc.multitech.prv | 2:4569491293d7 | 10 | * @brief lora::Mote provides a user level class that abstracts the complexity of the Mac layer |
Jenkins@KEILDM1.dc.multitech.prv | 2:4569491293d7 | 11 | * |
Jenkins@KEILDM1.dc.multitech.prv | 2:4569491293d7 | 12 | * @details |
Jenkins@KEILDM1.dc.multitech.prv | 2:4569491293d7 | 13 | * |
Jenkins@KEILDM1.dc.multitech.prv | 2:4569491293d7 | 14 | */ |
Jenkins@KEILDM1.dc.multitech.prv | 2:4569491293d7 | 15 | |
Jenkins@KEILDM1.dc.multitech.prv | 2:4569491293d7 | 16 | #ifndef __LORA_MOTE_H__ |
Jenkins@KEILDM1.dc.multitech.prv | 2:4569491293d7 | 17 | #define __LORA_MOTE_H__ |
Jenkins@KEILDM1.dc.multitech.prv | 2:4569491293d7 | 18 | |
Jenkins@KEILDM1.dc.multitech.prv | 16:4a382fe8f51b | 19 | #include "mbed.h" |
Jenkins@KEILDM1.dc.multitech.prv | 16:4a382fe8f51b | 20 | #include "mbed_events.h" |
Jenkins@KEILDM1.dc.multitech.prv | 16:4a382fe8f51b | 21 | |
Jenkins@KEILDM1.dc.multitech.prv | 2:4569491293d7 | 22 | #include "MacEvents.h" |
Jenkins@KEILDM1.dc.multitech.prv | 16:4a382fe8f51b | 23 | |
Jenkins@KEILDM1.dc.multitech.prv | 2:4569491293d7 | 24 | #include <vector> |
Jenkins@KEILDM1.dc.multitech.prv | 2:4569491293d7 | 25 | |
Jenkins@KEILDM1.dc.multitech.prv | 2:4569491293d7 | 26 | class SxRadio; |
Jenkins@KEILDM1.dc.multitech.prv | 2:4569491293d7 | 27 | class SxRadio1272; |
Jenkins@KEILDM1.dc.multitech.prv | 2:4569491293d7 | 28 | |
Jenkins@KEILDM1.dc.multitech.prv | 2:4569491293d7 | 29 | namespace lora { |
Jenkins@KEILDM1.dc.multitech.prv | 2:4569491293d7 | 30 | |
Jenkins@KEILDM1.dc.multitech.prv | 2:4569491293d7 | 31 | class Mac; |
Jenkins@KEILDM1.dc.multitech.prv | 2:4569491293d7 | 32 | class ChannelPlan; |
Jenkins@KEILDM1.dc.multitech.prv | 2:4569491293d7 | 33 | |
Jenkins@KEILDM1.dc.multitech.prv | 2:4569491293d7 | 34 | class MoteEvents: public MacEvents { |
Jenkins@KEILDM1.dc.multitech.prv | 2:4569491293d7 | 35 | |
Jenkins@KEILDM1.dc.multitech.prv | 2:4569491293d7 | 36 | /** |
Jenkins@KEILDM1.dc.multitech.prv | 14:f0c24ce93427 | 37 | * Fired at start of TX |
Jenkins@KEILDM1.dc.multitech.prv | 14:f0c24ce93427 | 38 | */ |
Jenkins@KEILDM1.dc.multitech.prv | 14:f0c24ce93427 | 39 | virtual void TxStart(void); |
Jenkins@KEILDM1.dc.multitech.prv | 14:f0c24ce93427 | 40 | |
Jenkins@KEILDM1.dc.multitech.prv | 14:f0c24ce93427 | 41 | /** |
Jenkins@KEILDM1.dc.multitech.prv | 2:4569491293d7 | 42 | * Fired at end of TX |
Jenkins@KEILDM1.dc.multitech.prv | 2:4569491293d7 | 43 | * @param dr datarate used for TX |
Jenkins@KEILDM1.dc.multitech.prv | 2:4569491293d7 | 44 | */ |
Jenkins@KEILDM1.dc.multitech.prv | 2:4569491293d7 | 45 | virtual void TxDone(uint8_t dr); |
Jenkins@KEILDM1.dc.multitech.prv | 2:4569491293d7 | 46 | |
Jenkins@KEILDM1.dc.multitech.prv | 2:4569491293d7 | 47 | /** |
Jenkins@KEILDM1.dc.multitech.prv | 2:4569491293d7 | 48 | * Fired if TX timed out |
Jenkins@KEILDM1.dc.multitech.prv | 2:4569491293d7 | 49 | */ |
Jenkins@KEILDM1.dc.multitech.prv | 2:4569491293d7 | 50 | virtual void TxTimeout(void); |
Jenkins@KEILDM1.dc.multitech.prv | 2:4569491293d7 | 51 | |
Jenkins@KEILDM1.dc.multitech.prv | 2:4569491293d7 | 52 | /** |
Jenkins@KEILDM1.dc.multitech.prv | 2:4569491293d7 | 53 | * Fired when JoinAccept message is received and MIC is validated |
Jenkins@KEILDM1.dc.multitech.prv | 2:4569491293d7 | 54 | * @param payload received bytes |
Jenkins@KEILDM1.dc.multitech.prv | 2:4569491293d7 | 55 | * @param size number of received bytes |
Jenkins@KEILDM1.dc.multitech.prv | 2:4569491293d7 | 56 | * @param rssi of received packet |
Jenkins@KEILDM1.dc.multitech.prv | 2:4569491293d7 | 57 | * @param snr of received packet |
Jenkins@KEILDM1.dc.multitech.prv | 2:4569491293d7 | 58 | */ |
Jenkins@KEILDM1.dc.multitech.prv | 19:aa5b1fcd05be | 59 | virtual void JoinAccept(uint8_t *payload, uint16_t size, int16_t rssi, int8_t snr); |
Jenkins@KEILDM1.dc.multitech.prv | 2:4569491293d7 | 60 | |
Jenkins@KEILDM1.dc.multitech.prv | 2:4569491293d7 | 61 | /** |
Jenkins@KEILDM1.dc.multitech.prv | 2:4569491293d7 | 62 | * Fired when JoinAccept message is received and MIC is not valid |
Jenkins@KEILDM1.dc.multitech.prv | 2:4569491293d7 | 63 | * @param payload received bytes |
Jenkins@KEILDM1.dc.multitech.prv | 2:4569491293d7 | 64 | * @param size number of received bytes |
Jenkins@KEILDM1.dc.multitech.prv | 2:4569491293d7 | 65 | * @param rssi of received packet |
Jenkins@KEILDM1.dc.multitech.prv | 2:4569491293d7 | 66 | * @param snr of received packet |
Jenkins@KEILDM1.dc.multitech.prv | 2:4569491293d7 | 67 | */ |
Jenkins@KEILDM1.dc.multitech.prv | 19:aa5b1fcd05be | 68 | virtual void JoinFailed(uint8_t *payload, uint16_t size, int16_t rssi, int8_t snr); |
Jenkins@KEILDM1.dc.multitech.prv | 2:4569491293d7 | 69 | |
Jenkins@KEILDM1.dc.multitech.prv | 2:4569491293d7 | 70 | /** |
Jenkins@KEILDM1.dc.multitech.prv | 14:f0c24ce93427 | 71 | * Fired when packet is received and MIC is valid |
Jenkins@KEILDM1.dc.multitech.prv | 2:4569491293d7 | 72 | * @param port of packet |
Jenkins@KEILDM1.dc.multitech.prv | 2:4569491293d7 | 73 | * @param payload received bytes |
Jenkins@KEILDM1.dc.multitech.prv | 2:4569491293d7 | 74 | * @param size number of received bytes |
Jenkins@KEILDM1.dc.multitech.prv | 2:4569491293d7 | 75 | * @param rssi of received packet |
Jenkins@KEILDM1.dc.multitech.prv | 2:4569491293d7 | 76 | * @param snr of received packet |
Jenkins@KEILDM1.dc.multitech.prv | 2:4569491293d7 | 77 | * @param ctrl Downlink control field of packet |
Jenkins@KEILDM1.dc.multitech.prv | 2:4569491293d7 | 78 | * @param slot rx window packet was received |
Jenkins@KEILDM1.dc.multitech.prv | 2:4569491293d7 | 79 | * @param retries number of attempts before ack was received |
Jenkins@KEILDM1.dc.multitech.prv | 14:f0c24ce93427 | 80 | * @param address of the end device |
Jenkins@KEILDM1.dc.multitech.prv | 14:f0c24ce93427 | 81 | * @param dupRx set if this packet has already been received |
Jenkins@KEILDM1.dc.multitech.prv | 2:4569491293d7 | 82 | */ |
Jenkins@KEILDM1.dc.multitech.prv | 19:aa5b1fcd05be | 83 | virtual void PacketRx(uint8_t port, uint8_t *payload, uint16_t size, int16_t rssi, int8_t snr, lora::DownlinkControl ctrl, uint8_t slot, uint8_t retries = 0, uint32_t address = 0, bool dupRx=false); |
Jenkins@KEILDM1.dc.multitech.prv | 2:4569491293d7 | 84 | |
Jenkins@KEILDM1.dc.multitech.prv | 2:4569491293d7 | 85 | /** |
Jenkins@KEILDM1.dc.multitech.prv | 2:4569491293d7 | 86 | * Fired when radio has received a packet, packet is not validated |
Jenkins@KEILDM1.dc.multitech.prv | 2:4569491293d7 | 87 | * @param payload received bytes |
Jenkins@KEILDM1.dc.multitech.prv | 2:4569491293d7 | 88 | * @param size number of received bytes |
Jenkins@KEILDM1.dc.multitech.prv | 2:4569491293d7 | 89 | * @param rssi of received packet |
Jenkins@KEILDM1.dc.multitech.prv | 2:4569491293d7 | 90 | * @param snr of received packet |
Jenkins@KEILDM1.dc.multitech.prv | 2:4569491293d7 | 91 | * @param ctrl Downlink control field of packet |
Jenkins@KEILDM1.dc.multitech.prv | 2:4569491293d7 | 92 | * @param slot rx window packet was received |
Jenkins@KEILDM1.dc.multitech.prv | 2:4569491293d7 | 93 | */ |
Jenkins@KEILDM1.dc.multitech.prv | 19:aa5b1fcd05be | 94 | virtual void RxDone(uint8_t *payload, uint16_t size, int16_t rssi, int8_t snr, lora::DownlinkControl ctrl, uint8_t slot); |
Jenkins@KEILDM1.dc.multitech.prv | 2:4569491293d7 | 95 | |
Jenkins@KEILDM1.dc.multitech.prv | 2:4569491293d7 | 96 | /** |
Jenkins@KEILDM1.dc.multitech.prv | 16:4a382fe8f51b | 97 | * Fired when a beacon is received |
Jenkins@KEILDM1.dc.multitech.prv | 16:4a382fe8f51b | 98 | * @param beacon_data parsed from the beacon payload |
Jenkins@KEILDM1.dc.multitech.prv | 16:4a382fe8f51b | 99 | * @param rssi of received beacon |
Jenkins@KEILDM1.dc.multitech.prv | 16:4a382fe8f51b | 100 | * @param snr of received beacon |
Jenkins@KEILDM1.dc.multitech.prv | 16:4a382fe8f51b | 101 | */ |
Jenkins@KEILDM1.dc.multitech.prv | 19:aa5b1fcd05be | 102 | virtual void BeaconRx(const BeaconData_t& beacon_data, int16_t rssi, int8_t snr); |
Jenkins@KEILDM1.dc.multitech.prv | 16:4a382fe8f51b | 103 | |
Jenkins@KEILDM1.dc.multitech.prv | 16:4a382fe8f51b | 104 | /** |
Jenkins@KEILDM1.dc.multitech.prv | 16:4a382fe8f51b | 105 | * Fired upon losing beacon synchronization (120 minutes elapsed from last beacon reception) |
Jenkins@KEILDM1.dc.multitech.prv | 16:4a382fe8f51b | 106 | */ |
Jenkins@KEILDM1.dc.multitech.prv | 16:4a382fe8f51b | 107 | virtual void BeaconLost(); |
Jenkins@KEILDM1.dc.multitech.prv | 16:4a382fe8f51b | 108 | |
Jenkins@KEILDM1.dc.multitech.prv | 16:4a382fe8f51b | 109 | /** |
Jenkins@KEILDM1.dc.multitech.prv | 2:4569491293d7 | 110 | * Fired if rx window times out |
Jenkins@KEILDM1.dc.multitech.prv | 2:4569491293d7 | 111 | * @param slot rx window that timed out |
Jenkins@KEILDM1.dc.multitech.prv | 2:4569491293d7 | 112 | */ |
Jenkins@KEILDM1.dc.multitech.prv | 2:4569491293d7 | 113 | virtual void RxTimeout(uint8_t slot); |
Jenkins@KEILDM1.dc.multitech.prv | 2:4569491293d7 | 114 | |
Jenkins@KEILDM1.dc.multitech.prv | 2:4569491293d7 | 115 | /** |
Jenkins@KEILDM1.dc.multitech.prv | 2:4569491293d7 | 116 | * Fired if rx CRC error |
Jenkins@KEILDM1.dc.multitech.prv | 2:4569491293d7 | 117 | * @param slot rx window that errored |
Jenkins@KEILDM1.dc.multitech.prv | 2:4569491293d7 | 118 | */ |
Jenkins@KEILDM1.dc.multitech.prv | 2:4569491293d7 | 119 | virtual void RxError(uint8_t slot); |
Jenkins@KEILDM1.dc.multitech.prv | 2:4569491293d7 | 120 | |
Jenkins@KEILDM1.dc.multitech.prv | 2:4569491293d7 | 121 | /** |
Jenkins@KEILDM1.dc.multitech.prv | 2:4569491293d7 | 122 | * Fired if pong packet is received |
Jenkins@KEILDM1.dc.multitech.prv | 2:4569491293d7 | 123 | * @param m_rssi of received packet at mote |
Jenkins@KEILDM1.dc.multitech.prv | 2:4569491293d7 | 124 | * @param m_snr of received packet at mote |
Jenkins@KEILDM1.dc.multitech.prv | 2:4569491293d7 | 125 | * @param s_rssi of received packet at server |
Jenkins@KEILDM1.dc.multitech.prv | 2:4569491293d7 | 126 | * @param s_snr of received packet at server |
Jenkins@KEILDM1.dc.multitech.prv | 2:4569491293d7 | 127 | */ |
Jenkins@KEILDM1.dc.multitech.prv | 19:aa5b1fcd05be | 128 | virtual void Pong(int16_t m_rssi, int8_t m_snr, int16_t s_rssi, int8_t s_snr); |
Jenkins@KEILDM1.dc.multitech.prv | 2:4569491293d7 | 129 | |
Jenkins@KEILDM1.dc.multitech.prv | 2:4569491293d7 | 130 | /** |
Jenkins@KEILDM1.dc.multitech.prv | 2:4569491293d7 | 131 | * Fired if network link check answer is received |
Jenkins@KEILDM1.dc.multitech.prv | 2:4569491293d7 | 132 | * @param m_rssi of received packet at mote |
Jenkins@KEILDM1.dc.multitech.prv | 2:4569491293d7 | 133 | * @param m_snr of received packet at mote |
Jenkins@KEILDM1.dc.multitech.prv | 2:4569491293d7 | 134 | * @param s_snr margin of received packet at server |
Jenkins@KEILDM1.dc.multitech.prv | 2:4569491293d7 | 135 | * @param s_gateways number of gateways reporting the packet |
Jenkins@KEILDM1.dc.multitech.prv | 2:4569491293d7 | 136 | */ |
Jenkins@KEILDM1.dc.multitech.prv | 19:aa5b1fcd05be | 137 | virtual void NetworkLinkCheck(int16_t m_rssi, int8_t m_snr, int8_t s_snr, uint8_t s_gateways); |
Jenkins@KEILDM1.dc.multitech.prv | 2:4569491293d7 | 138 | |
Jenkins@KEILDM1.dc.multitech.prv | 2:4569491293d7 | 139 | /** |
Jenkins@KEILDM1.dc.multitech.prv | 16:4a382fe8f51b | 140 | * Fired upon receiving a server time answer |
Jenkins@KEILDM1.dc.multitech.prv | 16:4a382fe8f51b | 141 | * @param seconds from the GPS epoch |
Jenkins@KEILDM1.dc.multitech.prv | 16:4a382fe8f51b | 142 | * @param sub_seconds from the GPS epoch |
Jenkins@KEILDM1.dc.multitech.prv | 16:4a382fe8f51b | 143 | */ |
Jenkins@KEILDM1.dc.multitech.prv | 16:4a382fe8f51b | 144 | virtual void ServerTime(uint32_t seconds, uint8_t sub_seconds); |
Jenkins@KEILDM1.dc.multitech.prv | 16:4a382fe8f51b | 145 | |
Jenkins@KEILDM1.dc.multitech.prv | 16:4a382fe8f51b | 146 | /** |
Jenkins@KEILDM1.dc.multitech.prv | 2:4569491293d7 | 147 | * Callback to for device to measure the battery level and report to server |
Jenkins@KEILDM1.dc.multitech.prv | 2:4569491293d7 | 148 | * @return battery level 0-255, 0 - external power, 1-254 level min-max, 255 device unable to measure battery |
Jenkins@KEILDM1.dc.multitech.prv | 2:4569491293d7 | 149 | */ |
Jenkins@KEILDM1.dc.multitech.prv | 2:4569491293d7 | 150 | virtual uint8_t MeasureBattery(); |
Jenkins@KEILDM1.dc.multitech.prv | 2:4569491293d7 | 151 | |
Jenkins@KEILDM1.dc.multitech.prv | 2:4569491293d7 | 152 | /** |
Jenkins@KEILDM1.dc.multitech.prv | 2:4569491293d7 | 153 | * Fired when ack attempts are exhausted and RxTimeout or RxError occur |
Jenkins@KEILDM1.dc.multitech.prv | 2:4569491293d7 | 154 | * @param retries number of attempts to resend the packet |
Jenkins@KEILDM1.dc.multitech.prv | 2:4569491293d7 | 155 | */ |
Jenkins@KEILDM1.dc.multitech.prv | 2:4569491293d7 | 156 | virtual void MissedAck(uint8_t retries); |
Jenkins@KEILDM1.dc.multitech.prv | 2:4569491293d7 | 157 | }; |
Jenkins@KEILDM1.dc.multitech.prv | 2:4569491293d7 | 158 | |
Jenkins@KEILDM1.dc.multitech.prv | 2:4569491293d7 | 159 | class Mote { |
Jenkins@KEILDM1.dc.multitech.prv | 2:4569491293d7 | 160 | public: |
Jenkins@KEILDM1.dc.multitech.prv | 10:1e831990a669 | 161 | Mote(Settings* settings, ChannelPlan* plan); |
Jenkins@KEILDM1.dc.multitech.prv | 2:4569491293d7 | 162 | virtual ~Mote(); |
Jenkins@KEILDM1.dc.multitech.prv | 2:4569491293d7 | 163 | |
Jenkins@KEILDM1.dc.multitech.prv | 2:4569491293d7 | 164 | /** |
Jenkins@KEILDM1.dc.multitech.prv | 10:1e831990a669 | 165 | * MTS LoRa version |
Jenkins@KEILDM1.dc.multitech.prv | 10:1e831990a669 | 166 | * @return string containing version information |
Jenkins@KEILDM1.dc.multitech.prv | 10:1e831990a669 | 167 | */ |
Jenkins@KEILDM1.dc.multitech.prv | 10:1e831990a669 | 168 | const char* getId(); |
Jenkins@KEILDM1.dc.multitech.prv | 10:1e831990a669 | 169 | |
Jenkins@KEILDM1.dc.multitech.prv | 10:1e831990a669 | 170 | /** |
Jenkins@KEILDM1.dc.multitech.prv | 2:4569491293d7 | 171 | * Indicator for network session join status |
Jenkins@KEILDM1.dc.multitech.prv | 2:4569491293d7 | 172 | * @return true if joined to network |
Jenkins@KEILDM1.dc.multitech.prv | 2:4569491293d7 | 173 | */ |
Jenkins@KEILDM1.dc.multitech.prv | 2:4569491293d7 | 174 | bool Joined(); |
Jenkins@KEILDM1.dc.multitech.prv | 2:4569491293d7 | 175 | |
Jenkins@KEILDM1.dc.multitech.prv | 2:4569491293d7 | 176 | /** |
Jenkins@KEILDM1.dc.multitech.prv | 2:4569491293d7 | 177 | * Send join request |
Jenkins@KEILDM1.dc.multitech.prv | 2:4569491293d7 | 178 | * @return LORA_OK if request was sent |
Jenkins@KEILDM1.dc.multitech.prv | 2:4569491293d7 | 179 | */ |
Jenkins@KEILDM1.dc.multitech.prv | 2:4569491293d7 | 180 | uint8_t Join(); |
Jenkins@KEILDM1.dc.multitech.prv | 2:4569491293d7 | 181 | |
Jenkins@KEILDM1.dc.multitech.prv | 2:4569491293d7 | 182 | /** |
Jenkins@KEILDM1.dc.multitech.prv | 2:4569491293d7 | 183 | * Send a packet |
Jenkins@KEILDM1.dc.multitech.prv | 2:4569491293d7 | 184 | * @param port to send packet |
Jenkins@KEILDM1.dc.multitech.prv | 2:4569491293d7 | 185 | * @param payload of packet |
Jenkins@KEILDM1.dc.multitech.prv | 2:4569491293d7 | 186 | * @param size in bytes |
Jenkins@KEILDM1.dc.multitech.prv | 2:4569491293d7 | 187 | * @return LORA_OK if successful |
Jenkins@KEILDM1.dc.multitech.prv | 2:4569491293d7 | 188 | * @return LORA_MAX_PAYLOAD_EXCEEDED if payload size exceeds datarate maximum |
Jenkins@KEILDM1.dc.multitech.prv | 2:4569491293d7 | 189 | * @return LORA_NO_CHANS_ENABLED if there is not an available channel that supports the current datarate |
Jenkins@KEILDM1.dc.multitech.prv | 2:4569491293d7 | 190 | * @return LORA_LINK_BUSY if link was busy |
Jenkins@KEILDM1.dc.multitech.prv | 2:4569491293d7 | 191 | * @return LORA_RADIO_BUSY if radio was busy |
Jenkins@KEILDM1.dc.multitech.prv | 2:4569491293d7 | 192 | * @return LORA_BUFFER_FULL if mac commands filled the packet, client should resend the packet |
Jenkins@KEILDM1.dc.multitech.prv | 2:4569491293d7 | 193 | */ |
Jenkins@KEILDM1.dc.multitech.prv | 2:4569491293d7 | 194 | uint8_t Send(uint8_t port, const uint8_t* payload, uint8_t size); |
Jenkins@KEILDM1.dc.multitech.prv | 2:4569491293d7 | 195 | |
Jenkins@KEILDM1.dc.multitech.prv | 2:4569491293d7 | 196 | /** |
Jenkins@KEILDM1.dc.multitech.prv | 2:4569491293d7 | 197 | * Configure the channel plan |
Jenkins@KEILDM1.dc.multitech.prv | 10:1e831990a669 | 198 | * @param plan pointer to ChannelPlan object |
Jenkins@KEILDM1.dc.multitech.prv | 2:4569491293d7 | 199 | * @return LORA_OK |
Jenkins@KEILDM1.dc.multitech.prv | 2:4569491293d7 | 200 | */ |
Jenkins@KEILDM1.dc.multitech.prv | 10:1e831990a669 | 201 | uint8_t SetChannelPlan(ChannelPlan* plan); |
Jenkins@KEILDM1.dc.multitech.prv | 10:1e831990a669 | 202 | |
Jenkins@KEILDM1.dc.multitech.prv | 14:f0c24ce93427 | 203 | |
Jenkins@KEILDM1.dc.multitech.prv | 10:1e831990a669 | 204 | Settings* GetSettings(); |
Jenkins@KEILDM1.dc.multitech.prv | 2:4569491293d7 | 205 | |
Jenkins@KEILDM1.dc.multitech.prv | 2:4569491293d7 | 206 | /** |
Jenkins@KEILDM1.dc.multitech.prv | 2:4569491293d7 | 207 | * Get the channel mask of currently enabled channels |
Jenkins@KEILDM1.dc.multitech.prv | 2:4569491293d7 | 208 | * @return vector containing channel bit masks |
Jenkins@KEILDM1.dc.multitech.prv | 2:4569491293d7 | 209 | */ |
Jenkins@KEILDM1.dc.multitech.prv | 2:4569491293d7 | 210 | std::vector<uint16_t> GetChannelMask(); |
Jenkins@KEILDM1.dc.multitech.prv | 2:4569491293d7 | 211 | |
Jenkins@KEILDM1.dc.multitech.prv | 2:4569491293d7 | 212 | /** |
Jenkins@KEILDM1.dc.multitech.prv | 2:4569491293d7 | 213 | * Set a 16 bit channel mask with index |
Jenkins@KEILDM1.dc.multitech.prv | 2:4569491293d7 | 214 | * @param index of mask to set 0:0-15, 1:16-31 ... |
Jenkins@KEILDM1.dc.multitech.prv | 2:4569491293d7 | 215 | * @param mask 16 bit mask of enabled channels |
Jenkins@KEILDM1.dc.multitech.prv | 2:4569491293d7 | 216 | * @return true |
Jenkins@KEILDM1.dc.multitech.prv | 2:4569491293d7 | 217 | */ |
Jenkins@KEILDM1.dc.multitech.prv | 2:4569491293d7 | 218 | virtual uint8_t SetChannelMask(uint8_t index, uint16_t mask); |
Jenkins@KEILDM1.dc.multitech.prv | 2:4569491293d7 | 219 | |
Jenkins@KEILDM1.dc.multitech.prv | 2:4569491293d7 | 220 | /** |
Jenkins@KEILDM1.dc.multitech.prv | 10:1e831990a669 | 221 | * Set the current frequency sub band for hybrid operation 1-8 else 0 for 64 channel operation |
Jenkins@KEILDM1.dc.multitech.prv | 10:1e831990a669 | 222 | * @param sub_band 0-8 |
Jenkins@KEILDM1.dc.multitech.prv | 2:4569491293d7 | 223 | */ |
Jenkins@KEILDM1.dc.multitech.prv | 10:1e831990a669 | 224 | uint8_t SetFrequencySubBand(uint8_t sub_band); |
Jenkins@KEILDM1.dc.multitech.prv | 2:4569491293d7 | 225 | |
Jenkins@KEILDM1.dc.multitech.prv | 2:4569491293d7 | 226 | /** |
Jenkins@KEILDM1.dc.multitech.prv | 10:1e831990a669 | 227 | * Get the current frequency sub band |
Jenkins@KEILDM1.dc.multitech.prv | 10:1e831990a669 | 228 | * @return sub band 0-8 |
Jenkins@KEILDM1.dc.multitech.prv | 2:4569491293d7 | 229 | */ |
Jenkins@KEILDM1.dc.multitech.prv | 10:1e831990a669 | 230 | uint8_t GetFrequencySubBand(); |
Jenkins@KEILDM1.dc.multitech.prv | 2:4569491293d7 | 231 | |
Jenkins@KEILDM1.dc.multitech.prv | 2:4569491293d7 | 232 | /** |
Jenkins@KEILDM1.dc.multitech.prv | 2:4569491293d7 | 233 | * Add a channel to the channel plan |
Jenkins@KEILDM1.dc.multitech.prv | 10:1e831990a669 | 234 | * EU868, AS923 and KR920 allows additional channels to be added |
Jenkins@KEILDM1.dc.multitech.prv | 2:4569491293d7 | 235 | * Channels 0-2 are fixed default channels |
Jenkins@KEILDM1.dc.multitech.prv | 2:4569491293d7 | 236 | * |
Jenkins@KEILDM1.dc.multitech.prv | 2:4569491293d7 | 237 | * @param index of the channel |
Jenkins@KEILDM1.dc.multitech.prv | 2:4569491293d7 | 238 | * @param frequency of the channel or 0 to remove channel |
Jenkins@KEILDM1.dc.multitech.prv | 2:4569491293d7 | 239 | * @param range of datarates allowed by the channel |
Jenkins@KEILDM1.dc.multitech.prv | 2:4569491293d7 | 240 | * @return LORA_OK if channel was added |
Jenkins@KEILDM1.dc.multitech.prv | 2:4569491293d7 | 241 | */ |
Jenkins@KEILDM1.dc.multitech.prv | 2:4569491293d7 | 242 | uint8_t AddChannel(uint8_t index, uint32_t frequency, lora::DatarateRange range); |
Jenkins@KEILDM1.dc.multitech.prv | 2:4569491293d7 | 243 | |
Jenkins@KEILDM1.dc.multitech.prv | 2:4569491293d7 | 244 | /** |
Jenkins@KEILDM1.dc.multitech.prv | 10:1e831990a669 | 245 | * Add a downlink channel to the channel plan |
Jenkins@KEILDM1.dc.multitech.prv | 10:1e831990a669 | 246 | * EU868, AS923 and KR920 allows downlink channels to be added |
Jenkins@KEILDM1.dc.multitech.prv | 10:1e831990a669 | 247 | * |
Jenkins@KEILDM1.dc.multitech.prv | 10:1e831990a669 | 248 | * @param index of the channel |
Jenkins@KEILDM1.dc.multitech.prv | 10:1e831990a669 | 249 | * @param frequency of the channel or 0 to remove channel |
Jenkins@KEILDM1.dc.multitech.prv | 10:1e831990a669 | 250 | * @return LORA_OK if channel was added |
Jenkins@KEILDM1.dc.multitech.prv | 10:1e831990a669 | 251 | */ |
Jenkins@KEILDM1.dc.multitech.prv | 10:1e831990a669 | 252 | uint8_t AddDownlinkChannel(uint8_t index, uint32_t frequency); |
Jenkins@KEILDM1.dc.multitech.prv | 10:1e831990a669 | 253 | |
Jenkins@KEILDM1.dc.multitech.prv | 10:1e831990a669 | 254 | /** |
Jenkins@KEILDM1.dc.multitech.prv | 2:4569491293d7 | 255 | * Set network mode |
Jenkins@KEILDM1.dc.multitech.prv | 2:4569491293d7 | 256 | * Choose Public LoRaWAN mode or Private Multitech mode |
Jenkins@KEILDM1.dc.multitech.prv | 2:4569491293d7 | 257 | * |
Jenkins@KEILDM1.dc.multitech.prv | 2:4569491293d7 | 258 | * Public mode uses 0x34 sync word with 5/6 second join windows |
Jenkins@KEILDM1.dc.multitech.prv | 2:4569491293d7 | 259 | * Private mode uses 0x12 sync word with 1/2 second join windows |
Jenkins@KEILDM1.dc.multitech.prv | 10:1e831990a669 | 260 | * US915/AU915 Rx1 and Rx2 are fixed per frequency sub band setting |
Jenkins@KEILDM1.dc.multitech.prv | 2:4569491293d7 | 261 | * |
Jenkins@KEILDM1.dc.multitech.prv | 2:4569491293d7 | 262 | * @param mode public or private |
Jenkins@KEILDM1.dc.multitech.prv | 2:4569491293d7 | 263 | * @return LORA_OK |
Jenkins@KEILDM1.dc.multitech.prv | 2:4569491293d7 | 264 | */ |
Jenkins@KEILDM1.dc.multitech.prv | 2:4569491293d7 | 265 | uint8_t SetNetworkMode(uint8_t mode); |
Jenkins@KEILDM1.dc.multitech.prv | 2:4569491293d7 | 266 | |
Jenkins@KEILDM1.dc.multitech.prv | 2:4569491293d7 | 267 | /** |
Jenkins@KEILDM1.dc.multitech.prv | 2:4569491293d7 | 268 | * Get a pointer to the mac layer |
Jenkins@KEILDM1.dc.multitech.prv | 2:4569491293d7 | 269 | * @return Mac mac |
Jenkins@KEILDM1.dc.multitech.prv | 2:4569491293d7 | 270 | */ |
Jenkins@KEILDM1.dc.multitech.prv | 2:4569491293d7 | 271 | Mac* GetMac(); |
Jenkins@KEILDM1.dc.multitech.prv | 2:4569491293d7 | 272 | |
Jenkins@KEILDM1.dc.multitech.prv | 2:4569491293d7 | 273 | /** |
Jenkins@KEILDM1.dc.multitech.prv | 2:4569491293d7 | 274 | * Get a pointer to the radio |
Jenkins@KEILDM1.dc.multitech.prv | 2:4569491293d7 | 275 | * Can be used to read radio registers or get a random value based on RSSI |
Jenkins@KEILDM1.dc.multitech.prv | 2:4569491293d7 | 276 | * |
Jenkins@KEILDM1.dc.multitech.prv | 2:4569491293d7 | 277 | * @return SxRadio pointer |
Jenkins@KEILDM1.dc.multitech.prv | 2:4569491293d7 | 278 | */ |
Jenkins@KEILDM1.dc.multitech.prv | 2:4569491293d7 | 279 | SxRadio* GetRadio(); |
Jenkins@KEILDM1.dc.multitech.prv | 2:4569491293d7 | 280 | |
Jenkins@KEILDM1.dc.multitech.prv | 2:4569491293d7 | 281 | /** |
Jenkins@KEILDM1.dc.multitech.prv | 2:4569491293d7 | 282 | * Get the current statistics for the device |
Jenkins@KEILDM1.dc.multitech.prv | 2:4569491293d7 | 283 | * @return Statistics |
Jenkins@KEILDM1.dc.multitech.prv | 2:4569491293d7 | 284 | */ |
Jenkins@KEILDM1.dc.multitech.prv | 2:4569491293d7 | 285 | Statistics& GetStats(); |
Jenkins@KEILDM1.dc.multitech.prv | 2:4569491293d7 | 286 | |
Jenkins@KEILDM1.dc.multitech.prv | 2:4569491293d7 | 287 | /** |
Jenkins@KEILDM1.dc.multitech.prv | 10:1e831990a669 | 288 | * Reset the current statistics for the device |
Jenkins@KEILDM1.dc.multitech.prv | 10:1e831990a669 | 289 | */ |
Jenkins@KEILDM1.dc.multitech.prv | 10:1e831990a669 | 290 | void ResetStats(); |
Jenkins@KEILDM1.dc.multitech.prv | 10:1e831990a669 | 291 | |
Jenkins@KEILDM1.dc.multitech.prv | 10:1e831990a669 | 292 | /** |
Jenkins@KEILDM1.dc.multitech.prv | 2:4569491293d7 | 293 | * Get time on air with current settings for provided payload bytes |
Jenkins@KEILDM1.dc.multitech.prv | 2:4569491293d7 | 294 | * 13 overhead bytes will be added to payload |
Jenkins@KEILDM1.dc.multitech.prv | 2:4569491293d7 | 295 | * @param bytes of payload data |
Jenkins@KEILDM1.dc.multitech.prv | 2:4569491293d7 | 296 | * @return time-on-air in ms |
Jenkins@KEILDM1.dc.multitech.prv | 2:4569491293d7 | 297 | */ |
Jenkins@KEILDM1.dc.multitech.prv | 2:4569491293d7 | 298 | uint32_t GetTimeOnAir(uint8_t bytes); |
Jenkins@KEILDM1.dc.multitech.prv | 2:4569491293d7 | 299 | |
Jenkins@KEILDM1.dc.multitech.prv | 2:4569491293d7 | 300 | /** |
Jenkins@KEILDM1.dc.multitech.prv | 10:1e831990a669 | 301 | * Get time off air required to adhere to duty-cycle limitations |
Jenkins@KEILDM1.dc.multitech.prv | 10:1e831990a669 | 302 | * @return time-off-air in ms |
Jenkins@KEILDM1.dc.multitech.prv | 10:1e831990a669 | 303 | */ |
Jenkins@KEILDM1.dc.multitech.prv | 10:1e831990a669 | 304 | uint32_t GetTimeOffAir(); |
Jenkins@KEILDM1.dc.multitech.prv | 10:1e831990a669 | 305 | |
Jenkins@KEILDM1.dc.multitech.prv | 10:1e831990a669 | 306 | /** |
Jenkins@KEILDM1.dc.multitech.prv | 2:4569491293d7 | 307 | * Call before setting device in sleep mode to place radio in sleep |
Jenkins@KEILDM1.dc.multitech.prv | 2:4569491293d7 | 308 | */ |
Jenkins@KEILDM1.dc.multitech.prv | 2:4569491293d7 | 309 | void Sleep(); |
Jenkins@KEILDM1.dc.multitech.prv | 2:4569491293d7 | 310 | |
Jenkins@KEILDM1.dc.multitech.prv | 2:4569491293d7 | 311 | protected: |
Jenkins@KEILDM1.dc.multitech.prv | 2:4569491293d7 | 312 | SxRadio1272* _radio; |
Jenkins@KEILDM1.dc.multitech.prv | 2:4569491293d7 | 313 | Settings* _settings; |
Jenkins@KEILDM1.dc.multitech.prv | 2:4569491293d7 | 314 | Mac* _mac; |
Jenkins@KEILDM1.dc.multitech.prv | 2:4569491293d7 | 315 | |
Jenkins@KEILDM1.dc.multitech.prv | 2:4569491293d7 | 316 | private: |
Jenkins@KEILDM1.dc.multitech.prv | 2:4569491293d7 | 317 | ChannelPlan* _plan; |
Jenkins@KEILDM1.dc.multitech.prv | 2:4569491293d7 | 318 | MoteEvents _events; |
Jenkins@KEILDM1.dc.multitech.prv | 16:4a382fe8f51b | 319 | |
Jenkins@KEILDM1.dc.multitech.prv | 16:4a382fe8f51b | 320 | // Event queue objects for timing events |
Jenkins@KEILDM1.dc.multitech.prv | 16:4a382fe8f51b | 321 | EventQueue _evtQueue; |
Jenkins@KEILDM1.dc.multitech.prv | 16:4a382fe8f51b | 322 | Thread _dispatch_thread; |
Jenkins@KEILDM1.dc.multitech.prv | 2:4569491293d7 | 323 | }; |
Jenkins@KEILDM1.dc.multitech.prv | 2:4569491293d7 | 324 | |
Jenkins@KEILDM1.dc.multitech.prv | 2:4569491293d7 | 325 | } |
Jenkins@KEILDM1.dc.multitech.prv | 2:4569491293d7 | 326 | #endif |