|
LoRaMAC
4.5.2
Documentation of the API
|
Go to the documentation of this file.
37 #ifndef __REGION_EU868_H__
38 #define __REGION_EU868_H__
50 #define EU868_MAX_NB_CHANNELS 16
55 #define EU868_NUMB_DEFAULT_CHANNELS 3
60 #define EU868_NUMB_CHANNELS_CF_LIST 5
65 #define EU868_TX_MIN_DATARATE DR_0
70 #define EU868_TX_MAX_DATARATE DR_7
75 #define EU868_RX_MIN_DATARATE DR_0
80 #define EU868_RX_MAX_DATARATE DR_7
85 #define EU868_DEFAULT_DATARATE DR_0
90 #define EU868_MIN_RX1_DR_OFFSET 0
95 #define EU868_MAX_RX1_DR_OFFSET 5
100 #define EU868_MIN_TX_POWER TX_POWER_7
105 #define EU868_MAX_TX_POWER TX_POWER_0
110 #define EU868_DEFAULT_TX_POWER TX_POWER_0
115 #define EU868_DEFAULT_MAX_EIRP 16.0f
120 #define EU868_DEFAULT_ANTENNA_GAIN 2.15f
125 #define EU868_DUTY_CYCLE_ENABLED 1
130 #define EU868_MAX_RX_WINDOW 3000
132 #if ( EU868_DEFAULT_DATARATE > DR_5 )
133 #error "A default DR higher than DR_5 may lead to connectivity loss."
139 #define EU868_RX_WND_2_FREQ 869525000
144 #define EU868_RX_WND_2_DR DR_0
149 #define EU868_DEFAULT_UPLINK_DWELL_TIME 0
157 #define EU868_BEACON_CHANNEL_FREQ 869525000
162 #define EU868_PING_SLOT_CHANNEL_FREQ 869525000
167 #define EU868_BEACON_SIZE 17
172 #define EU868_RFU1_SIZE 1
177 #define EU868_RFU2_SIZE 0
182 #define EU868_BEACON_CHANNEL_DR DR_3
187 #define EU868_BEACON_CHANNEL_BW 0
192 #define EU868_PING_SLOT_CHANNEL_DR DR_3
197 #define EU868_MAX_NB_BANDS 6
203 #define EU868_BAND0 { 100 , EU868_MAX_TX_POWER, 0, 0, 0, 0, 0 } // 1.0 %
209 #define EU868_BAND1 { 100 , EU868_MAX_TX_POWER, 0, 0, 0, 0, 0 } // 1.0 %
215 #define EU868_BAND2 { 1000, EU868_MAX_TX_POWER, 0, 0, 0, 0, 0 } // 0.1 %
221 #define EU868_BAND3 { 10 , EU868_MAX_TX_POWER, 0, 0, 0, 0, 0 } // 10.0 %
227 #define EU868_BAND4 { 100 , EU868_MAX_TX_POWER, 0, 0, 0, 0, 0 } // 1.0 %
234 #define EU868_BAND5 { 1000, EU868_MAX_TX_POWER, 0, 0, 0, 0, 0 } // 0.1 %
240 #define EU868_LC1 { 868100000, 0, { ( ( DR_5 << 4 ) | DR_0 ) }, 1 }
246 #define EU868_LC2 { 868300000, 0, { ( ( DR_5 << 4 ) | DR_0 ) }, 1 }
252 #define EU868_LC3 { 868500000, 0, { ( ( DR_5 << 4 ) | DR_0 ) }, 1 }
257 #define EU868_JOIN_CHANNELS ( uint16_t )( LC( 1 ) | LC( 2 ) | LC( 3 ) )
262 static const uint8_t DataratesEU868[] = { 12, 11, 10, 9, 8, 7, 7, 50 };
267 static const uint32_t BandwidthsEU868[] = { 125000, 125000, 125000, 125000, 125000, 125000, 250000, 0 };
272 static const uint8_t MaxPayloadOfDatarateEU868[] = { 51, 51, 51, 115, 242, 242, 242, 242 };
478 #endif // __REGION_EU868_H__
AlternateDrType_t
Definition: Region.h:756
LoRaMacStatus_t
Definition: LoRaMac.h:2269
PhyParam_t RegionEU868GetPhyParam(GetPhyParams_t *getPhy)
The function gets a value of a specific phy attribute.
bool RegionEU868ChannelsRemove(ChannelRemoveParams_t *channelRemove)
Removes a channel.
void RegionEU868RxBeaconSetup(RxBeaconSetup_t *rxBeaconSetup, uint8_t *outDr)
Sets the radio into beacon reception mode.
void RegionEU868ComputeRxWindowParameters(int8_t datarate, uint8_t minRxSymbols, uint32_t rxError, RxConfigParams_t *rxConfigParams)
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.
void RegionEU868ApplyCFList(ApplyCFListParams_t *applyCFList)
The function parses the input buffer and sets up the channels of the CF list.
LoRaMacStatus_t RegionEU868NextChannel(NextChanParams_t *nextChanParams, uint8_t *channel, TimerTime_t *time, TimerTime_t *aggregatedTimeOff)
Searches and set the next random available channel.
LoRaMacStatus_t RegionEU868ChannelAdd(ChannelAddParams_t *channelAdd)
Adds a channel.
void RegionEU868SetBandTxDone(SetBandTxDoneParams_t *txDone)
Updates the last TX done parameters of the current channel.
int8_t RegionEU868AlternateDr(int8_t currentDr, AlternateDrType_t type)
Alternates the datarate of the channel for the join request.
uint8_t RegionEU868RxParamSetupReq(RxParamSetupReqParams_t *rxParamSetupReq)
The function processes a RX Parameter Setup Request.
PhyAttribute_t
Definition: Region.h:85
bool RegionEU868ChanMaskSet(ChanMaskSetParams_t *chanMaskSet)
Sets a channels mask.
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.
void RegionEU868InitDefaults(InitDefaultsParams_t *params)
Initializes the channels masks and the channels.
int8_t RegionEU868NewChannelReq(NewChannelReqParams_t *newChannelReq)
The function processes a Channel Request.
bool RegionEU868Verify(VerifyParams_t *verify, PhyAttribute_t phyAttribute)
Verifies a parameter.
int8_t RegionEU868DlChannelReq(DlChannelReqParams_t *dlChannelReq)
The function processes a DlChannel Request.
bool RegionEU868RxConfig(RxConfigParams_t *rxConfig, int8_t *datarate)
Configuration of the RX windows.
int8_t RegionEU868TxParamSetupReq(TxParamSetupReqParams_t *txParamSetupReq)
The function processes a TX ParamSetup Request.