The Modified Dot Library for SX1272

This version has been restoring as initial changes.

Verify the following dependencies:

Mbed-os 5.11 libmdot 3.2.0 for Mbed OS5.11

Committer:
DanistyWuKids
Date:
Fri Jul 10 23:47:58 2020 +1000
Branch:
old_stable_update
Revision:
82:bfca91bb8341
Parent:
65:acc0468b9aec
Child:
68:5f787643e7d7
Update same as on 75:268c51ddfc06

Who changed what in which revision?

UserRevisionLine numberNew contents of line
Jenkins@KEILDM1.dc.multitech.prv 61:58ed1e136af5 1 /*
Jenkins@KEILDM1.dc.multitech.prv 61:58ed1e136af5 2 / _____) _ | |
Jenkins@KEILDM1.dc.multitech.prv 61:58ed1e136af5 3 ( (____ _____ ____ _| |_ _____ ____| |__
Jenkins@KEILDM1.dc.multitech.prv 61:58ed1e136af5 4 \____ \| ___ | (_ _) ___ |/ ___) _ \
Jenkins@KEILDM1.dc.multitech.prv 61:58ed1e136af5 5 _____) ) ____| | | || |_| ____( (___| | | |
Jenkins@KEILDM1.dc.multitech.prv 61:58ed1e136af5 6 (______/|_____)_|_|_| \__)_____)\____)_| |_|
Jenkins@KEILDM1.dc.multitech.prv 61:58ed1e136af5 7 (C)2013 Semtech
Jenkins@KEILDM1.dc.multitech.prv 61:58ed1e136af5 8
Jenkins@KEILDM1.dc.multitech.prv 61:58ed1e136af5 9 Description: Generic radio driver definition
Jenkins@KEILDM1.dc.multitech.prv 61:58ed1e136af5 10
Jenkins@KEILDM1.dc.multitech.prv 61:58ed1e136af5 11 License: Revised BSD License, see LICENSE.TXT file include in the project
Jenkins@KEILDM1.dc.multitech.prv 61:58ed1e136af5 12
Jenkins@KEILDM1.dc.multitech.prv 61:58ed1e136af5 13 Maintainer: Miguel Luis and Gregory Cristian
Jenkins@KEILDM1.dc.multitech.prv 61:58ed1e136af5 14 */
Jenkins@KEILDM1.dc.multitech.prv 61:58ed1e136af5 15 #ifndef __SXRADIO_H__
Jenkins@KEILDM1.dc.multitech.prv 61:58ed1e136af5 16 #define __SXRADIO_H__
Jenkins@KEILDM1.dc.multitech.prv 61:58ed1e136af5 17
Jenkins@KEILDM1.dc.multitech.prv 61:58ed1e136af5 18 #include <stdint.h>
Jenkins@KEILDM1.dc.multitech.prv 61:58ed1e136af5 19 #include "rtos.h"
Jenkins@KEILDM1.dc.multitech.prv 61:58ed1e136af5 20 #include "SxRadioEvents.h"
Jenkins@KEILDM1.dc.multitech.prv 61:58ed1e136af5 21
Jenkins@KEILDM1.dc.multitech.prv 61:58ed1e136af5 22 /*!
Jenkins@KEILDM1.dc.multitech.prv 61:58ed1e136af5 23 * \brief Radio driver definition
Jenkins@KEILDM1.dc.multitech.prv 61:58ed1e136af5 24 */
Jenkins@KEILDM1.dc.multitech.prv 61:58ed1e136af5 25 class SxRadio
Jenkins@KEILDM1.dc.multitech.prv 61:58ed1e136af5 26 {
Jenkins@KEILDM1.dc.multitech.prv 61:58ed1e136af5 27 public:
Jenkins@KEILDM1.dc.multitech.prv 61:58ed1e136af5 28 /*!
Jenkins@KEILDM1.dc.multitech.prv 61:58ed1e136af5 29 * Radio driver supported modems
Jenkins@KEILDM1.dc.multitech.prv 61:58ed1e136af5 30 */
Jenkins@KEILDM1.dc.multitech.prv 61:58ed1e136af5 31 typedef enum
Jenkins@KEILDM1.dc.multitech.prv 61:58ed1e136af5 32 {
Jenkins@KEILDM1.dc.multitech.prv 61:58ed1e136af5 33 MODEM_FSK = 0,
Jenkins@KEILDM1.dc.multitech.prv 61:58ed1e136af5 34 MODEM_LORA,
Jenkins@KEILDM1.dc.multitech.prv 61:58ed1e136af5 35 }RadioModems_t;
Jenkins@KEILDM1.dc.multitech.prv 61:58ed1e136af5 36
Jenkins@KEILDM1.dc.multitech.prv 61:58ed1e136af5 37 /*!
Jenkins@KEILDM1.dc.multitech.prv 61:58ed1e136af5 38 * Radio driver internal state machine states definition
Jenkins@KEILDM1.dc.multitech.prv 61:58ed1e136af5 39 */
Jenkins@KEILDM1.dc.multitech.prv 61:58ed1e136af5 40 typedef enum
Jenkins@KEILDM1.dc.multitech.prv 61:58ed1e136af5 41 {
Jenkins@KEILDM1.dc.multitech.prv 61:58ed1e136af5 42 RF_IDLE = 0,
Jenkins@KEILDM1.dc.multitech.prv 61:58ed1e136af5 43 RF_RX_RUNNING,
Jenkins@KEILDM1.dc.multitech.prv 61:58ed1e136af5 44 RF_TX_RUNNING,
Jenkins@KEILDM1.dc.multitech.prv 61:58ed1e136af5 45 RF_CAD,
Jenkins@KEILDM1.dc.multitech.prv 61:58ed1e136af5 46 }RadioState_t;
Jenkins@KEILDM1.dc.multitech.prv 61:58ed1e136af5 47
Jenkins@KEILDM1.dc.multitech.prv 65:acc0468b9aec 48 SxRadio(uint32_t WakeupTime) : WakeupTime(WakeupTime), freq_offset(0), State(RF_IDLE), Modem(MODEM_LORA) { }
Jenkins@KEILDM1.dc.multitech.prv 61:58ed1e136af5 49 virtual ~SxRadio() {};
Jenkins@KEILDM1.dc.multitech.prv 61:58ed1e136af5 50
Jenkins@KEILDM1.dc.multitech.prv 61:58ed1e136af5 51 /*!
Jenkins@KEILDM1.dc.multitech.prv 61:58ed1e136af5 52 * \brief Initializes the radio
Jenkins@KEILDM1.dc.multitech.prv 61:58ed1e136af5 53 *
Jenkins@KEILDM1.dc.multitech.prv 61:58ed1e136af5 54 * \param [IN] events Structure containing the driver callback functions
Jenkins@KEILDM1.dc.multitech.prv 61:58ed1e136af5 55 */
Jenkins@KEILDM1.dc.multitech.prv 61:58ed1e136af5 56 virtual void Init( SxRadioEvents *events ) = 0;
Jenkins@KEILDM1.dc.multitech.prv 61:58ed1e136af5 57 /*!
Jenkins@KEILDM1.dc.multitech.prv 61:58ed1e136af5 58 * \brief Prepares the radio for destruction
Jenkins@KEILDM1.dc.multitech.prv 61:58ed1e136af5 59 */
Jenkins@KEILDM1.dc.multitech.prv 61:58ed1e136af5 60 virtual void Terminate( void ) = 0;
Jenkins@KEILDM1.dc.multitech.prv 61:58ed1e136af5 61 /*!
Jenkins@KEILDM1.dc.multitech.prv 61:58ed1e136af5 62 * Return current radio status
Jenkins@KEILDM1.dc.multitech.prv 61:58ed1e136af5 63 *
Jenkins@KEILDM1.dc.multitech.prv 61:58ed1e136af5 64 * \param status Radio status.[RF_IDLE, RF_RX_RUNNING, RF_TX_RUNNING]
Jenkins@KEILDM1.dc.multitech.prv 61:58ed1e136af5 65 */
Jenkins@KEILDM1.dc.multitech.prv 61:58ed1e136af5 66 virtual RadioState_t Status( void ) { return State; }
Jenkins@KEILDM1.dc.multitech.prv 61:58ed1e136af5 67 /*!
Jenkins@KEILDM1.dc.multitech.prv 61:58ed1e136af5 68 * \brief Configures the radio with the given modem
Jenkins@KEILDM1.dc.multitech.prv 61:58ed1e136af5 69 *
Jenkins@KEILDM1.dc.multitech.prv 65:acc0468b9aec 70 * \param [IN] modem Modem to be used [0: FSK, 1: LoRa]
Jenkins@KEILDM1.dc.multitech.prv 61:58ed1e136af5 71 */
Jenkins@KEILDM1.dc.multitech.prv 61:58ed1e136af5 72 virtual void SetModem( RadioModems_t modem ) = 0;
Jenkins@KEILDM1.dc.multitech.prv 65:acc0468b9aec 73 virtual RadioModems_t GetModem( void ) { return Modem; }
Jenkins@KEILDM1.dc.multitech.prv 61:58ed1e136af5 74 /*!
Jenkins@KEILDM1.dc.multitech.prv 61:58ed1e136af5 75 * \brief Sets the channel frequency
Jenkins@KEILDM1.dc.multitech.prv 61:58ed1e136af5 76 *
Jenkins@KEILDM1.dc.multitech.prv 61:58ed1e136af5 77 * \param [IN] freq Channel RF frequency
Jenkins@KEILDM1.dc.multitech.prv 61:58ed1e136af5 78 */
Jenkins@KEILDM1.dc.multitech.prv 61:58ed1e136af5 79 virtual void SetChannel( uint32_t freq ) = 0;
Jenkins@KEILDM1.dc.multitech.prv 61:58ed1e136af5 80 /*!
Jenkins@KEILDM1.dc.multitech.prv 61:58ed1e136af5 81 * \brief Sets the channels configuration
Jenkins@KEILDM1.dc.multitech.prv 61:58ed1e136af5 82 *
Jenkins@KEILDM1.dc.multitech.prv 61:58ed1e136af5 83 * \param [IN] modem Radio modem to be used [0: FSK, 1: LoRa]
Jenkins@KEILDM1.dc.multitech.prv 61:58ed1e136af5 84 * \param [IN] freq Channel RF frequency
Jenkins@KEILDM1.dc.multitech.prv 61:58ed1e136af5 85 * \param [IN] rssiThresh RSSI threshold
Jenkins@KEILDM1.dc.multitech.prv 61:58ed1e136af5 86 * \param [IN] rssiVal pointer to variable to hold RSSI value if desired - ignored if NULL
Jenkins@KEILDM1.dc.multitech.prv 61:58ed1e136af5 87 *
Jenkins@KEILDM1.dc.multitech.prv 61:58ed1e136af5 88 * \retval isFree [true: Channel is free, false: Channel is not free]
Jenkins@KEILDM1.dc.multitech.prv 61:58ed1e136af5 89 */
Jenkins@KEILDM1.dc.multitech.prv 61:58ed1e136af5 90 virtual bool IsChannelFree( RadioModems_t modem, uint32_t freq, uint8_t datarate, int16_t rssiThresh, uint8_t bandwidth, uint32_t timeout = 5000, int16_t *rssiVal = NULL ) = 0;
Jenkins@KEILDM1.dc.multitech.prv 61:58ed1e136af5 91 /*!
Jenkins@KEILDM1.dc.multitech.prv 61:58ed1e136af5 92 * \brief Generates a 32 bits random value based on the RSSI readings
Jenkins@KEILDM1.dc.multitech.prv 61:58ed1e136af5 93 *
Jenkins@KEILDM1.dc.multitech.prv 65:acc0468b9aec 94 * \remark This function sets the radio in LoRa modem mode and disables
Jenkins@KEILDM1.dc.multitech.prv 61:58ed1e136af5 95 * all interrupts.
Jenkins@KEILDM1.dc.multitech.prv 61:58ed1e136af5 96 * After calling this function either Radio.SetRxConfig or
Jenkins@KEILDM1.dc.multitech.prv 61:58ed1e136af5 97 * Radio.SetTxConfig functions must be called.
Jenkins@KEILDM1.dc.multitech.prv 61:58ed1e136af5 98 *
Jenkins@KEILDM1.dc.multitech.prv 61:58ed1e136af5 99 * \retval randomValue 32 bits random value
Jenkins@KEILDM1.dc.multitech.prv 61:58ed1e136af5 100 */
Jenkins@KEILDM1.dc.multitech.prv 61:58ed1e136af5 101 virtual uint32_t Random( void ) = 0;
Jenkins@KEILDM1.dc.multitech.prv 61:58ed1e136af5 102 /*!
Jenkins@KEILDM1.dc.multitech.prv 61:58ed1e136af5 103 * \brief Sets the reception parameters
Jenkins@KEILDM1.dc.multitech.prv 61:58ed1e136af5 104 *
Jenkins@KEILDM1.dc.multitech.prv 61:58ed1e136af5 105 * \param [IN] modem Radio modem to be used [0: FSK, 1: LoRa]
Jenkins@KEILDM1.dc.multitech.prv 61:58ed1e136af5 106 * \param [IN] bandwidth Sets the bandwidth
Jenkins@KEILDM1.dc.multitech.prv 61:58ed1e136af5 107 * FSK : >= 2600 and <= 250000 Hz
Jenkins@KEILDM1.dc.multitech.prv 61:58ed1e136af5 108 * LoRa: [0: 125 kHz, 1: 250 kHz,
Jenkins@KEILDM1.dc.multitech.prv 65:acc0468b9aec 109 * 2: 500 kHz, 3: Reserved]
Jenkins@KEILDM1.dc.multitech.prv 61:58ed1e136af5 110 * \param [IN] datarate Sets the Datarate
Jenkins@KEILDM1.dc.multitech.prv 61:58ed1e136af5 111 * FSK : 600..300000 bits/s
Jenkins@KEILDM1.dc.multitech.prv 61:58ed1e136af5 112 * LoRa: [6: 64, 7: 128, 8: 256, 9: 512,
Jenkins@KEILDM1.dc.multitech.prv 61:58ed1e136af5 113 * 10: 1024, 11: 2048, 12: 4096 chips]
Jenkins@KEILDM1.dc.multitech.prv 61:58ed1e136af5 114 * \param [IN] coderate Sets the coding rate (LoRa only)
Jenkins@KEILDM1.dc.multitech.prv 61:58ed1e136af5 115 * FSK : N/A ( set to 0 )
Jenkins@KEILDM1.dc.multitech.prv 65:acc0468b9aec 116 * LoRa: [1: 4/5, 2: 4/6, 3: 4/7, 4: 4/8]
Jenkins@KEILDM1.dc.multitech.prv 65:acc0468b9aec 117 * \param [IN] bandwidthAfc Sets the AFC Bandwidth (FSK only)
Jenkins@KEILDM1.dc.multitech.prv 61:58ed1e136af5 118 * FSK : >= 2600 and <= 250000 Hz
Jenkins@KEILDM1.dc.multitech.prv 65:acc0468b9aec 119 * LoRa: N/A ( set to 0 )
Jenkins@KEILDM1.dc.multitech.prv 61:58ed1e136af5 120 * \param [IN] preambleLen Sets the Preamble length
Jenkins@KEILDM1.dc.multitech.prv 65:acc0468b9aec 121 * FSK : Number of bytes
Jenkins@KEILDM1.dc.multitech.prv 61:58ed1e136af5 122 * LoRa: Length in symbols (the hardware adds 4 more symbols)
Jenkins@KEILDM1.dc.multitech.prv 65:acc0468b9aec 123 * \param [IN] symbTimeout Sets the RxSingle timeout value (LoRa only)
Jenkins@KEILDM1.dc.multitech.prv 65:acc0468b9aec 124 * FSK : N/A ( set to 0 )
Jenkins@KEILDM1.dc.multitech.prv 61:58ed1e136af5 125 * LoRa: timeout in symbols
Jenkins@KEILDM1.dc.multitech.prv 61:58ed1e136af5 126 * \param [IN] fixLen Fixed length packets [0: variable, 1: fixed]
Jenkins@KEILDM1.dc.multitech.prv 61:58ed1e136af5 127 * \param [IN] payloadLen Sets payload length when fixed length is used
Jenkins@KEILDM1.dc.multitech.prv 61:58ed1e136af5 128 * \param [IN] crcOn Enables/Disables the CRC [0: OFF, 1: ON]
Jenkins@KEILDM1.dc.multitech.prv 61:58ed1e136af5 129 * \param [IN] FreqHopOn Enables disables the intra-packet frequency hopping
Jenkins@KEILDM1.dc.multitech.prv 61:58ed1e136af5 130 * FSK : N/A ( set to 0 )
Jenkins@KEILDM1.dc.multitech.prv 61:58ed1e136af5 131 * LoRa: [0: OFF, 1: ON]
Jenkins@KEILDM1.dc.multitech.prv 61:58ed1e136af5 132 * \param [IN] HopPeriod Number of symbols bewteen each hop
Jenkins@KEILDM1.dc.multitech.prv 61:58ed1e136af5 133 * FSK : N/A ( set to 0 )
Jenkins@KEILDM1.dc.multitech.prv 61:58ed1e136af5 134 * LoRa: Number of symbols
Jenkins@KEILDM1.dc.multitech.prv 61:58ed1e136af5 135 * \param [IN] iqInverted Inverts IQ signals (LoRa only)
Jenkins@KEILDM1.dc.multitech.prv 61:58ed1e136af5 136 * FSK : N/A ( set to 0 )
Jenkins@KEILDM1.dc.multitech.prv 61:58ed1e136af5 137 * LoRa: [0: not inverted, 1: inverted]
Jenkins@KEILDM1.dc.multitech.prv 61:58ed1e136af5 138 * \param [IN] rxContinuous Sets the reception in continuous mode
Jenkins@KEILDM1.dc.multitech.prv 61:58ed1e136af5 139 * [false: single mode, true: continuous mode]
Jenkins@KEILDM1.dc.multitech.prv 65:acc0468b9aec 140 * \param [IN] fskPad Duration in ms to increase FSK rx window
Jenkins@KEILDM1.dc.multitech.prv 65:acc0468b9aec 141 * FSK: time in ms to increase FSK rx window duration
Jenkins@KEILDM1.dc.multitech.prv 65:acc0468b9aec 142 * LoRa: N/A
Jenkins@KEILDM1.dc.multitech.prv 61:58ed1e136af5 143 */
Jenkins@KEILDM1.dc.multitech.prv 61:58ed1e136af5 144 virtual void SetRxConfig( RadioModems_t modem, uint32_t bandwidth,
Jenkins@KEILDM1.dc.multitech.prv 61:58ed1e136af5 145 uint32_t datarate, uint8_t coderate,
Jenkins@KEILDM1.dc.multitech.prv 61:58ed1e136af5 146 uint32_t bandwidthAfc, uint16_t preambleLen,
Jenkins@KEILDM1.dc.multitech.prv 61:58ed1e136af5 147 uint16_t symbTimeout, bool fixLen,
Jenkins@KEILDM1.dc.multitech.prv 61:58ed1e136af5 148 uint8_t payloadLen,
Jenkins@KEILDM1.dc.multitech.prv 61:58ed1e136af5 149 bool crcOn, bool FreqHopOn, uint8_t HopPeriod,
Jenkins@KEILDM1.dc.multitech.prv 65:acc0468b9aec 150 bool iqInverted, bool rxContinuous , uint32_t fskPad = 0) = 0;
Jenkins@KEILDM1.dc.multitech.prv 61:58ed1e136af5 151 /*!
Jenkins@KEILDM1.dc.multitech.prv 61:58ed1e136af5 152 * \brief Sets the transmission parameters
Jenkins@KEILDM1.dc.multitech.prv 61:58ed1e136af5 153 *
Jenkins@KEILDM1.dc.multitech.prv 65:acc0468b9aec 154 * \param [IN] modem Radio modem to be used [0: FSK, 1: LoRa]
Jenkins@KEILDM1.dc.multitech.prv 61:58ed1e136af5 155 * \param [IN] power Sets the output power [dBm]
Jenkins@KEILDM1.dc.multitech.prv 61:58ed1e136af5 156 * \param [IN] fdev Sets the frequency deviation (FSK only)
Jenkins@KEILDM1.dc.multitech.prv 61:58ed1e136af5 157 * FSK : [Hz]
Jenkins@KEILDM1.dc.multitech.prv 61:58ed1e136af5 158 * LoRa: 0
Jenkins@KEILDM1.dc.multitech.prv 61:58ed1e136af5 159 * \param [IN] bandwidth Sets the bandwidth (LoRa only)
Jenkins@KEILDM1.dc.multitech.prv 61:58ed1e136af5 160 * FSK : 0
Jenkins@KEILDM1.dc.multitech.prv 61:58ed1e136af5 161 * LoRa: [0: 125 kHz, 1: 250 kHz,
Jenkins@KEILDM1.dc.multitech.prv 65:acc0468b9aec 162 * 2: 500 kHz, 3: Reserved]
Jenkins@KEILDM1.dc.multitech.prv 61:58ed1e136af5 163 * \param [IN] datarate Sets the Datarate
Jenkins@KEILDM1.dc.multitech.prv 61:58ed1e136af5 164 * FSK : 600..300000 bits/s
Jenkins@KEILDM1.dc.multitech.prv 61:58ed1e136af5 165 * LoRa: [6: 64, 7: 128, 8: 256, 9: 512,
Jenkins@KEILDM1.dc.multitech.prv 61:58ed1e136af5 166 * 10: 1024, 11: 2048, 12: 4096 chips]
Jenkins@KEILDM1.dc.multitech.prv 61:58ed1e136af5 167 * \param [IN] coderate Sets the coding rate (LoRa only)
Jenkins@KEILDM1.dc.multitech.prv 61:58ed1e136af5 168 * FSK : N/A ( set to 0 )
Jenkins@KEILDM1.dc.multitech.prv 65:acc0468b9aec 169 * LoRa: [1: 4/5, 2: 4/6, 3: 4/7, 4: 4/8]
Jenkins@KEILDM1.dc.multitech.prv 61:58ed1e136af5 170 * \param [IN] preambleLen Sets the preamble length
Jenkins@KEILDM1.dc.multitech.prv 65:acc0468b9aec 171 * FSK : Number of bytes
Jenkins@KEILDM1.dc.multitech.prv 61:58ed1e136af5 172 * LoRa: Length in symbols (the hardware adds 4 more symbols)
Jenkins@KEILDM1.dc.multitech.prv 61:58ed1e136af5 173 * \param [IN] fixLen Fixed length packets [0: variable, 1: fixed]
Jenkins@KEILDM1.dc.multitech.prv 61:58ed1e136af5 174 * \param [IN] crcOn Enables disables the CRC [0: OFF, 1: ON]
Jenkins@KEILDM1.dc.multitech.prv 61:58ed1e136af5 175 * \param [IN] FreqHopOn Enables disables the intra-packet frequency hopping
Jenkins@KEILDM1.dc.multitech.prv 61:58ed1e136af5 176 * FSK : N/A ( set to 0 )
Jenkins@KEILDM1.dc.multitech.prv 61:58ed1e136af5 177 * LoRa: [0: OFF, 1: ON]
Jenkins@KEILDM1.dc.multitech.prv 61:58ed1e136af5 178 * \param [IN] HopPeriod Number of symbols bewteen each hop
Jenkins@KEILDM1.dc.multitech.prv 61:58ed1e136af5 179 * FSK : N/A ( set to 0 )
Jenkins@KEILDM1.dc.multitech.prv 61:58ed1e136af5 180 * LoRa: Number of symbols
Jenkins@KEILDM1.dc.multitech.prv 61:58ed1e136af5 181 * \param [IN] iqInverted Inverts IQ signals (LoRa only)
Jenkins@KEILDM1.dc.multitech.prv 61:58ed1e136af5 182 * FSK : N/A ( set to 0 )
Jenkins@KEILDM1.dc.multitech.prv 61:58ed1e136af5 183 * LoRa: [0: not inverted, 1: inverted]
Jenkins@KEILDM1.dc.multitech.prv 61:58ed1e136af5 184 * \param [IN] timeout Transmission timeout [us]
Jenkins@KEILDM1.dc.multitech.prv 61:58ed1e136af5 185 */
Jenkins@KEILDM1.dc.multitech.prv 65:acc0468b9aec 186 virtual void SetTxConfig( RadioModems_t modem, int8_t power, uint32_t fdev,
Jenkins@KEILDM1.dc.multitech.prv 61:58ed1e136af5 187 uint32_t bandwidth, uint32_t datarate,
Jenkins@KEILDM1.dc.multitech.prv 61:58ed1e136af5 188 uint8_t coderate, uint16_t preambleLen,
Jenkins@KEILDM1.dc.multitech.prv 61:58ed1e136af5 189 bool fixLen, bool crcOn, bool FreqHopOn,
Jenkins@KEILDM1.dc.multitech.prv 61:58ed1e136af5 190 uint8_t HopPeriod, bool iqInverted, uint32_t timeout ) = 0;
Jenkins@KEILDM1.dc.multitech.prv 61:58ed1e136af5 191
Jenkins@KEILDM1.dc.multitech.prv 65:acc0468b9aec 192 virtual void SetTxPower(int8_t power) = 0;
Jenkins@KEILDM1.dc.multitech.prv 65:acc0468b9aec 193
Jenkins@KEILDM1.dc.multitech.prv 65:acc0468b9aec 194 virtual void SetTxContinuousWave( uint32_t freq, int8_t power, uint16_t time ) = 0;
Jenkins@KEILDM1.dc.multitech.prv 61:58ed1e136af5 195
Jenkins@KEILDM1.dc.multitech.prv 61:58ed1e136af5 196 /*!
Jenkins@KEILDM1.dc.multitech.prv 61:58ed1e136af5 197 * \brief Checks if the given RF frequency is supported by the hardware
Jenkins@KEILDM1.dc.multitech.prv 61:58ed1e136af5 198 *
Jenkins@KEILDM1.dc.multitech.prv 61:58ed1e136af5 199 * \param [IN] frequency RF frequency to be checked
Jenkins@KEILDM1.dc.multitech.prv 61:58ed1e136af5 200 * \retval isSupported [true: supported, false: unsupported]
Jenkins@KEILDM1.dc.multitech.prv 61:58ed1e136af5 201 */
Jenkins@KEILDM1.dc.multitech.prv 61:58ed1e136af5 202 virtual bool CheckRfFrequency( uint32_t frequency ) { return true; }
Jenkins@KEILDM1.dc.multitech.prv 61:58ed1e136af5 203 /*!
Jenkins@KEILDM1.dc.multitech.prv 61:58ed1e136af5 204 * \brief Computes the packet time on air for the given payload
Jenkins@KEILDM1.dc.multitech.prv 61:58ed1e136af5 205 *
Jenkins@KEILDM1.dc.multitech.prv 61:58ed1e136af5 206 * \Remark Can only be called once SetRxConfig or SetTxConfig have been called
Jenkins@KEILDM1.dc.multitech.prv 61:58ed1e136af5 207 *
Jenkins@KEILDM1.dc.multitech.prv 61:58ed1e136af5 208 * \param [IN] modem Radio modem to be used [0: FSK, 1: LoRa]
Jenkins@KEILDM1.dc.multitech.prv 61:58ed1e136af5 209 * \param [IN] pktLen Packet payload length
Jenkins@KEILDM1.dc.multitech.prv 61:58ed1e136af5 210 *
Jenkins@KEILDM1.dc.multitech.prv 61:58ed1e136af5 211 * \retval airTime Computed airTime for the given packet payload length
Jenkins@KEILDM1.dc.multitech.prv 61:58ed1e136af5 212 */
Jenkins@KEILDM1.dc.multitech.prv 61:58ed1e136af5 213 virtual double TimeOnAir( RadioModems_t modem, uint8_t pktLen ) = 0;
Jenkins@KEILDM1.dc.multitech.prv 61:58ed1e136af5 214 /*!
Jenkins@KEILDM1.dc.multitech.prv 61:58ed1e136af5 215 * \brief Sends the buffer of size. Prepares the packet to be sent and sets
Jenkins@KEILDM1.dc.multitech.prv 61:58ed1e136af5 216 * the radio in transmission
Jenkins@KEILDM1.dc.multitech.prv 61:58ed1e136af5 217 *
Jenkins@KEILDM1.dc.multitech.prv 61:58ed1e136af5 218 * \param [IN]: buffer Buffer pointer
Jenkins@KEILDM1.dc.multitech.prv 61:58ed1e136af5 219 * \param [IN]: size Buffer size
Jenkins@KEILDM1.dc.multitech.prv 61:58ed1e136af5 220 */
Jenkins@KEILDM1.dc.multitech.prv 61:58ed1e136af5 221 virtual void Send( const uint8_t *buffer, uint8_t size ) = 0;
Jenkins@KEILDM1.dc.multitech.prv 61:58ed1e136af5 222 /*!
Jenkins@KEILDM1.dc.multitech.prv 61:58ed1e136af5 223 * \brief Sets the radio in sleep mode
Jenkins@KEILDM1.dc.multitech.prv 61:58ed1e136af5 224 */
Jenkins@KEILDM1.dc.multitech.prv 61:58ed1e136af5 225 virtual void Sleep( void ) = 0;
Jenkins@KEILDM1.dc.multitech.prv 61:58ed1e136af5 226 /*!
Jenkins@KEILDM1.dc.multitech.prv 61:58ed1e136af5 227 * \brief Sets the radio in standby mode
Jenkins@KEILDM1.dc.multitech.prv 61:58ed1e136af5 228 */
Jenkins@KEILDM1.dc.multitech.prv 61:58ed1e136af5 229 virtual void Standby( void ) = 0;
Jenkins@KEILDM1.dc.multitech.prv 61:58ed1e136af5 230 /*!
Jenkins@KEILDM1.dc.multitech.prv 61:58ed1e136af5 231 * \brief Sets the radio in reception mode for the given time
Jenkins@KEILDM1.dc.multitech.prv 61:58ed1e136af5 232 * \param [IN] timeout Reception timeout [us]
Jenkins@KEILDM1.dc.multitech.prv 61:58ed1e136af5 233 * [0: continuous, others timeout]
Jenkins@KEILDM1.dc.multitech.prv 61:58ed1e136af5 234 */
Jenkins@KEILDM1.dc.multitech.prv 61:58ed1e136af5 235 virtual void Rx( uint32_t timeout ) = 0;
Jenkins@KEILDM1.dc.multitech.prv 61:58ed1e136af5 236 /*!
Jenkins@KEILDM1.dc.multitech.prv 61:58ed1e136af5 237 * \brief Start a Channel Activity Detection
Jenkins@KEILDM1.dc.multitech.prv 61:58ed1e136af5 238 */
Jenkins@KEILDM1.dc.multitech.prv 61:58ed1e136af5 239 virtual void StartCad( void ) = 0;
Jenkins@KEILDM1.dc.multitech.prv 61:58ed1e136af5 240 /*!
Jenkins@KEILDM1.dc.multitech.prv 61:58ed1e136af5 241 * \brief Reads the current RSSI value
Jenkins@KEILDM1.dc.multitech.prv 61:58ed1e136af5 242 *
Jenkins@KEILDM1.dc.multitech.prv 61:58ed1e136af5 243 * \retval rssiValue Current RSSI value in [dBm]
Jenkins@KEILDM1.dc.multitech.prv 61:58ed1e136af5 244 */
Jenkins@KEILDM1.dc.multitech.prv 61:58ed1e136af5 245 virtual int16_t Rssi( RadioModems_t modem ) = 0;
Jenkins@KEILDM1.dc.multitech.prv 61:58ed1e136af5 246 /*!
Jenkins@KEILDM1.dc.multitech.prv 61:58ed1e136af5 247 * \brief Writes the radio register at the specified address
Jenkins@KEILDM1.dc.multitech.prv 61:58ed1e136af5 248 *
Jenkins@KEILDM1.dc.multitech.prv 61:58ed1e136af5 249 * \param [IN]: addr Register address
Jenkins@KEILDM1.dc.multitech.prv 61:58ed1e136af5 250 * \param [IN]: data New register value
Jenkins@KEILDM1.dc.multitech.prv 61:58ed1e136af5 251 */
Jenkins@KEILDM1.dc.multitech.prv 61:58ed1e136af5 252 virtual void Write( uint8_t addr, uint8_t data ) = 0;
Jenkins@KEILDM1.dc.multitech.prv 61:58ed1e136af5 253 /*!
Jenkins@KEILDM1.dc.multitech.prv 61:58ed1e136af5 254 * \brief Reads the radio register at the specified address
Jenkins@KEILDM1.dc.multitech.prv 61:58ed1e136af5 255 *
Jenkins@KEILDM1.dc.multitech.prv 61:58ed1e136af5 256 * \param [IN]: addr Register address
Jenkins@KEILDM1.dc.multitech.prv 61:58ed1e136af5 257 * \retval data Register value
Jenkins@KEILDM1.dc.multitech.prv 61:58ed1e136af5 258 */
Jenkins@KEILDM1.dc.multitech.prv 61:58ed1e136af5 259 virtual uint8_t Read ( uint8_t addr ) = 0;
Jenkins@KEILDM1.dc.multitech.prv 61:58ed1e136af5 260 /*!
Jenkins@KEILDM1.dc.multitech.prv 61:58ed1e136af5 261 * \brief Writes multiple radio registers starting at address
Jenkins@KEILDM1.dc.multitech.prv 61:58ed1e136af5 262 *
Jenkins@KEILDM1.dc.multitech.prv 61:58ed1e136af5 263 * \param [IN] addr First Radio register address
Jenkins@KEILDM1.dc.multitech.prv 61:58ed1e136af5 264 * \param [IN] buffer Buffer containing the new register's values
Jenkins@KEILDM1.dc.multitech.prv 61:58ed1e136af5 265 * \param [IN] size Number of registers to be written
Jenkins@KEILDM1.dc.multitech.prv 61:58ed1e136af5 266 */
Jenkins@KEILDM1.dc.multitech.prv 61:58ed1e136af5 267 virtual void WriteBuffer( uint8_t addr, const uint8_t *buffer, uint8_t size ) = 0;
Jenkins@KEILDM1.dc.multitech.prv 61:58ed1e136af5 268 /*!
Jenkins@KEILDM1.dc.multitech.prv 61:58ed1e136af5 269 * \brief Reads multiple radio registers starting at address
Jenkins@KEILDM1.dc.multitech.prv 61:58ed1e136af5 270 *
Jenkins@KEILDM1.dc.multitech.prv 61:58ed1e136af5 271 * \param [IN] addr First Radio register address
Jenkins@KEILDM1.dc.multitech.prv 61:58ed1e136af5 272 * \param [OUT] buffer Buffer where to copy the registers data
Jenkins@KEILDM1.dc.multitech.prv 61:58ed1e136af5 273 * \param [IN] size Number of registers to be read
Jenkins@KEILDM1.dc.multitech.prv 61:58ed1e136af5 274 */
Jenkins@KEILDM1.dc.multitech.prv 61:58ed1e136af5 275 virtual void ReadBuffer( uint8_t addr, uint8_t *buffer, uint8_t size ) = 0;
Jenkins@KEILDM1.dc.multitech.prv 61:58ed1e136af5 276
Jenkins@KEILDM1.dc.multitech.prv 61:58ed1e136af5 277 virtual void SignalMacEvent(void) {};
Jenkins@KEILDM1.dc.multitech.prv 65:acc0468b9aec 278 virtual void SignalLinkEvent(void) {};
Jenkins@KEILDM1.dc.multitech.prv 61:58ed1e136af5 279
Jenkins@KEILDM1.dc.multitech.prv 64:64982192a2af 280 virtual void ResetRadio(void) {};
Jenkins@KEILDM1.dc.multitech.prv 64:64982192a2af 281
Jenkins@KEILDM1.dc.multitech.prv 64:64982192a2af 282 virtual uint32_t GetTimeOnAir(void) = 0;
Jenkins@KEILDM1.dc.multitech.prv 64:64982192a2af 283
Jenkins@KEILDM1.dc.multitech.prv 61:58ed1e136af5 284 void GrabMutex(void) { mutex.lock(); }
Jenkins@KEILDM1.dc.multitech.prv 61:58ed1e136af5 285 void ReleaseMutex(void) { mutex.unlock(); }
Jenkins@KEILDM1.dc.multitech.prv 61:58ed1e136af5 286
Jenkins@KEILDM1.dc.multitech.prv 65:acc0468b9aec 287 int32_t GetFrequencyOffset() { return freq_offset; }
Jenkins@KEILDM1.dc.multitech.prv 65:acc0468b9aec 288 void SetFrequencyOffset(int32_t offset) { freq_offset = offset; }
Jenkins@KEILDM1.dc.multitech.prv 65:acc0468b9aec 289
Jenkins@KEILDM1.dc.multitech.prv 61:58ed1e136af5 290 const uint32_t WakeupTime;
Jenkins@KEILDM1.dc.multitech.prv 61:58ed1e136af5 291
Jenkins@KEILDM1.dc.multitech.prv 65:acc0468b9aec 292
Jenkins@KEILDM1.dc.multitech.prv 65:acc0468b9aec 293
Jenkins@KEILDM1.dc.multitech.prv 65:acc0468b9aec 294
Jenkins@KEILDM1.dc.multitech.prv 61:58ed1e136af5 295 protected:
Jenkins@KEILDM1.dc.multitech.prv 65:acc0468b9aec 296 int32_t freq_offset;
Jenkins@KEILDM1.dc.multitech.prv 65:acc0468b9aec 297
Jenkins@KEILDM1.dc.multitech.prv 61:58ed1e136af5 298 RadioState_t State;
Jenkins@KEILDM1.dc.multitech.prv 61:58ed1e136af5 299
Jenkins@KEILDM1.dc.multitech.prv 61:58ed1e136af5 300 RadioModems_t Modem;
Jenkins@KEILDM1.dc.multitech.prv 61:58ed1e136af5 301
Jenkins@KEILDM1.dc.multitech.prv 61:58ed1e136af5 302 /*!
Jenkins@KEILDM1.dc.multitech.prv 61:58ed1e136af5 303 * Access protection
Jenkins@KEILDM1.dc.multitech.prv 61:58ed1e136af5 304 */
Jenkins@KEILDM1.dc.multitech.prv 61:58ed1e136af5 305 Mutex mutex;
Jenkins@KEILDM1.dc.multitech.prv 65:acc0468b9aec 306
Jenkins@KEILDM1.dc.multitech.prv 61:58ed1e136af5 307 };
Jenkins@KEILDM1.dc.multitech.prv 61:58ed1e136af5 308
Jenkins@KEILDM1.dc.multitech.prv 61:58ed1e136af5 309 #endif // __SXRADIO_H__
Jenkins@KEILDM1.dc.multitech.prv 61:58ed1e136af5 310