 |
SX126x-Arduino
1.3.0
|
Go to the documentation of this file.
35 #ifndef __REGION_EU868_H__
36 #define __REGION_EU868_H__
44 #define EU868_MAX_NB_CHANNELS 16
49 #define EU868_NUMB_DEFAULT_CHANNELS 3
54 #define EU868_NUMB_CHANNELS_CF_LIST 5
59 #define EU868_TX_MIN_DATARATE DR_0
64 #define EU868_TX_MAX_DATARATE DR_7
69 #define EU868_RX_MIN_DATARATE DR_0
74 #define EU868_RX_MAX_DATARATE DR_7
79 #define EU868_DEFAULT_DATARATE DR_0
84 #define EU868_MIN_RX1_DR_OFFSET 0
89 #define EU868_MAX_RX1_DR_OFFSET 5
94 #define EU868_DEFAULT_RX1_DR_OFFSET 0
99 #define EU868_MIN_TX_POWER TX_POWER_7
104 #define EU868_MAX_TX_POWER TX_POWER_0
109 #define EU868_DEFAULT_TX_POWER TX_POWER_0
114 #define EU868_DEFAULT_MAX_EIRP 16.0f
119 #define EU868_DEFAULT_ANTENNA_GAIN 2.15f
124 #define EU868_ADR_ACK_LIMIT 64
129 #define EU868_ADR_ACK_DELAY 32
134 #define EU868_DUTY_CYCLE_ENABLED 1
139 #define EU868_MAX_RX_WINDOW 3000
144 #define EU868_RECEIVE_DELAY1 1000
149 #define EU868_RECEIVE_DELAY2 2000
154 #define EU868_JOIN_ACCEPT_DELAY1 5000
159 #define EU868_JOIN_ACCEPT_DELAY2 6000
164 #define EU868_MAX_FCNT_GAP 16384
169 #define EU868_ACKTIMEOUT 2000
174 #define EU868_ACK_TIMEOUT_RND 1000
176 #if (EU868_DEFAULT_DATARATE > DR_5)
177 #error "A default DR higher than DR_5 may lead to connectivity loss."
183 #define EU868_RX_WND_2_FREQ 869525000
188 #define EU868_RX_WND_2_DR DR_0
193 #define EU868_MAX_NB_BANDS 5
199 #define EU868_BAND0 \
201 100, EU868_MAX_TX_POWER, 0, 0 \
208 #define EU868_BAND1 \
210 100, EU868_MAX_TX_POWER, 0, 0 \
217 #define EU868_BAND2 \
219 1000, EU868_MAX_TX_POWER, 0, 0 \
226 #define EU868_BAND3 \
228 10, EU868_MAX_TX_POWER, 0, 0 \
235 #define EU868_BAND4 \
237 100, EU868_MAX_TX_POWER, 0, 0 \
246 868100000, 0, {((DR_5 << 4) | DR_0)}, 1 \
255 868300000, 0, {((DR_5 << 4) | DR_0)}, 1 \
264 868500000, 0, {((DR_5 << 4) | DR_0)}, 1 \
270 #define EU868_JOIN_CHANNELS (uint16_t)(LC(1) | LC(2) | LC(3))
280 static const uint32_t
BandwidthsEU868[] = {125000, 125000, 125000, 125000, 125000, 125000, 250000, 0};
524 #endif // __REGION_EU868_H__
Definition: Region.h:1134
bool RegionEU868NextChannel(NextChanParams_t *nextChanParams, uint8_t *channel, TimerTime_t *time, TimerTime_t *aggregatedTimeOff)
Searches and set the next random available channel.
enum eLoRaMacStatus LoRaMacStatus_t
PhyParam_t RegionEU868GetPhyParam(GetPhyParams_t *getPhy)
The function gets a value of a specific phy attribute.
enum eInitType InitType_t
bool RegionEU868ChannelsRemove(ChannelRemoveParams_t *channelRemove)
Removes a channel.
uint8_t RegionEU868DlChannelReq(DlChannelReqParams_t *dlChannelReq)
The function processes a DlChannel Request.
void RegionEU868ComputeRxWindowParameters(int8_t datarate, uint8_t minRxSymbols, uint32_t rxError, RxConfigParams_t *rxConfigParams)
Definition: Region.h:1050
uint8_t RegionEU868LinkAdrReq(LinkAdrReqParams_t *linkAdrReq, int8_t *drOut, int8_t *txPowOut, uint8_t *nbRepOut, uint8_t *nbBytesParsed)
The function processes a Link ADR Request.
Definition: Region.h:1001
void RegionEU868ApplyCFList(ApplyCFListParams_t *applyCFList)
The function parses the input buffer and sets up the channels of the CF list.
Definition: Region.h:1145
static const uint8_t MaxPayloadOfDatarateEU868[]
Definition: RegionEU868.h:285
int8_t RegionEU868AlternateDr(AlternateDrParams_t *alternateDr)
Alternates the datarate of the channel for the join request.
LoRaMacStatus_t RegionEU868ChannelAdd(ChannelAddParams_t *channelAdd)
Adds a channel.
Definition: Region.h:1061
static const uint8_t DataratesEU868[]
Definition: RegionEU868.h:275
void RegionEU868SetBandTxDone(SetBandTxDoneParams_t *txDone)
Updates the last TX done parameters of the current channel.
Definition: Region.h:1016
void RegionEU868InitDefaults(InitType_t type)
Initializes the channels masks and the channels.
uint8_t RegionEU868RxParamSetupReq(RxParamSetupReqParams_t *rxParamSetupReq)
The function processes a RX Parameter Setup Request.
uint8_t RegionEU868NewChannelReq(NewChannelReqParams_t *newChannelReq)
The function processes a Channel Request.
bool RegionEU868AdrNext(AdrNextParams_t *adrNext, int8_t *drOut, int8_t *txPowOut, uint32_t *adrAckCounter)
Calculates the next datarate to set, when ADR is on or off.
bool RegionEU868ChanMaskSet(ChanMaskSetParams_t *chanMaskSet)
Sets a channels mask.
void RegionEU868SetContinuousWave(ContinuousWaveParams_t *continuousWave)
Sets the radio into continuous wave mode.
Definition: Region.h:1092
uint8_t RegionEU868ApplyDrOffset(uint8_t downlinkDwellTime, int8_t dr, int8_t drOffset)
Computes new datarate according to the given offset.
bool RegionEU868TxConfig(TxConfigParams_t *txConfig, int8_t *txPower, TimerTime_t *txTimeOnAir)
TX configuration.
Definition: Region.h:1119
void RegionEU868CalcBackOff(CalcBackOffParams_t *calcBackOff)
Calculates the back-off time.
Definition: Region.h:1035
bool RegionEU868Verify(VerifyParams_t *verify, PhyAttribute_t phyAttribute)
Verifies a parameter.
bool RegionEU868RxConfig(RxConfigParams_t *rxConfig, int8_t *datarate)
Configuration of the RX windows.
enum ePhyAttribute PhyAttribute_t
static const uint32_t BandwidthsEU868[]
Definition: RegionEU868.h:280
uint32_t TimerTime_t
Timer time variable definition.
Definition: timer.h:68
int8_t RegionEU868TxParamSetupReq(TxParamSetupReqParams_t *txParamSetupReq)
The function processes a TX ParamSetup Request.
static const uint8_t MaxPayloadOfDatarateRepeaterEU868[]
Definition: RegionEU868.h:290