|
LoRaMAC
4.5.2
Documentation of the API
|
Go to the documentation of this file.
37 #ifndef __REGION_EU433_H__
38 #define __REGION_EU433_H__
50 #define EU433_MAX_NB_CHANNELS 16
55 #define EU433_NUMB_DEFAULT_CHANNELS 3
60 #define EU433_NUMB_CHANNELS_CF_LIST 5
65 #define EU433_TX_MIN_DATARATE DR_0
70 #define EU433_TX_MAX_DATARATE DR_7
75 #define EU433_RX_MIN_DATARATE DR_0
80 #define EU433_RX_MAX_DATARATE DR_7
85 #define EU433_DEFAULT_DATARATE DR_0
90 #define EU433_MIN_RX1_DR_OFFSET 0
95 #define EU433_MAX_RX1_DR_OFFSET 5
100 #define EU433_MIN_TX_POWER TX_POWER_5
105 #define EU433_MAX_TX_POWER TX_POWER_0
110 #define EU433_DEFAULT_TX_POWER TX_POWER_0
115 #define EU433_DEFAULT_MAX_EIRP 12.15f
120 #define EU433_DEFAULT_ANTENNA_GAIN 2.15f
125 #define EU433_DUTY_CYCLE_ENABLED 1
130 #define EU433_MAX_RX_WINDOW 3000
135 #if ( EU433_DEFAULT_DATARATE > DR_5 )
136 #error "A default DR higher than DR_5 may lead to connectivity loss."
142 #define EU433_RX_WND_2_FREQ 434665000
147 #define EU433_RX_WND_2_DR DR_0
152 #define EU433_MAX_NB_BANDS 1
157 #define EU433_DEFAULT_UPLINK_DWELL_TIME 0
165 #define EU433_BEACON_CHANNEL_FREQ 434665000
170 #define EU433_PING_SLOT_CHANNEL_FREQ 434665000
175 #define EU433_BEACON_SIZE 17
180 #define EU433_RFU1_SIZE 1
185 #define EU433_RFU2_SIZE 0
190 #define EU433_BEACON_CHANNEL_DR DR_3
195 #define EU433_BEACON_CHANNEL_BW 0
200 #define EU433_PING_SLOT_CHANNEL_DR DR_3
206 #define EU433_BAND0 { 100, EU433_MAX_TX_POWER, 0, 0, 0, 0, 0 } // 1.0 %
212 #define EU433_LC1 { 433175000, 0, { ( ( DR_5 << 4 ) | DR_0 ) }, 0 }
218 #define EU433_LC2 { 433375000, 0, { ( ( DR_5 << 4 ) | DR_0 ) }, 0 }
224 #define EU433_LC3 { 433575000, 0, { ( ( DR_5 << 4 ) | DR_0 ) }, 0 }
229 #define EU433_JOIN_CHANNELS ( uint16_t )( LC( 1 ) | LC( 2 ) | LC( 3 ) )
234 static const uint8_t DataratesEU433[] = { 12, 11, 10, 9, 8, 7, 7, 50 };
239 static const uint32_t BandwidthsEU433[] = { 125000, 125000, 125000, 125000, 125000, 125000, 250000, 0 };
244 static const uint8_t MaxPayloadOfDatarateEU433[] = { 51, 51, 51, 115, 242, 242, 242, 242 };
450 #endif // __REGION_EU433_H__
uint8_t RegionEU433RxParamSetupReq(RxParamSetupReqParams_t *rxParamSetupReq)
The function processes a RX Parameter Setup Request.
AlternateDrType_t
Definition: Region.h:756
LoRaMacStatus_t
Definition: LoRaMac.h:2269
bool RegionEU433TxConfig(TxConfigParams_t *txConfig, int8_t *txPower, TimerTime_t *txTimeOnAir)
TX configuration.
int8_t RegionEU433NewChannelReq(NewChannelReqParams_t *newChannelReq)
The function processes a Channel Request.
void RegionEU433ApplyCFList(ApplyCFListParams_t *applyCFList)
The function parses the input buffer and sets up the channels of the CF list.
void RegionEU433InitDefaults(InitDefaultsParams_t *params)
Initializes the channels masks and the channels.
PhyParam_t RegionEU433GetPhyParam(GetPhyParams_t *getPhy)
The function gets a value of a specific phy attribute.
uint8_t RegionEU433LinkAdrReq(LinkAdrReqParams_t *linkAdrReq, int8_t *drOut, int8_t *txPowOut, uint8_t *nbRepOut, uint8_t *nbBytesParsed)
The function processes a Link ADR Request.
void RegionEU433RxBeaconSetup(RxBeaconSetup_t *rxBeaconSetup, uint8_t *outDr)
Sets the radio into beacon reception mode.
void RegionEU433ComputeRxWindowParameters(int8_t datarate, uint8_t minRxSymbols, uint32_t rxError, RxConfigParams_t *rxConfigParams)
int8_t RegionEU433DlChannelReq(DlChannelReqParams_t *dlChannelReq)
The function processes a DlChannel Request.
void RegionEU433SetBandTxDone(SetBandTxDoneParams_t *txDone)
Updates the last TX done parameters of the current channel.
bool RegionEU433Verify(VerifyParams_t *verify, PhyAttribute_t phyAttribute)
Verifies a parameter.
PhyAttribute_t
Definition: Region.h:85
bool RegionEU433ChanMaskSet(ChanMaskSetParams_t *chanMaskSet)
Sets a channels mask.
LoRaMacStatus_t RegionEU433ChannelAdd(ChannelAddParams_t *channelAdd)
Adds a channel.
LoRaMacStatus_t RegionEU433NextChannel(NextChanParams_t *nextChanParams, uint8_t *channel, TimerTime_t *time, TimerTime_t *aggregatedTimeOff)
Searches and set the next random available channel.
bool RegionEU433RxConfig(RxConfigParams_t *rxConfig, int8_t *datarate)
Configuration of the RX windows.
uint8_t RegionEU433ApplyDrOffset(uint8_t downlinkDwellTime, int8_t dr, int8_t drOffset)
Computes new datarate according to the given offset.
int8_t RegionEU433TxParamSetupReq(TxParamSetupReqParams_t *txParamSetupReq)
The function processes a TX ParamSetup Request.
bool RegionEU433ChannelsRemove(ChannelRemoveParams_t *channelRemove)
Removes a channel.
int8_t RegionEU433AlternateDr(int8_t currentDr, AlternateDrType_t type)
Alternates the datarate of the channel for the join request.