|
- /*!
- * \file RegionRU864.h
- *
- * \brief Region definition for RU864
- *
- * \copyright Revised BSD License, see section \ref LICENSE.
- *
- * \code
- * ______ _
- * / _____) _ | |
- * ( (____ _____ ____ _| |_ _____ ____| |__
- * \____ \| ___ | (_ _) ___ |/ ___) _ \
- * _____) ) ____| | | || |_| ____( (___| | | |
- * (______/|_____)_|_|_| \__)_____)\____)_| |_|
- * (C)2013-2017 Semtech
- *
- * ___ _____ _ ___ _ _____ ___ ___ ___ ___
- * / __|_ _/_\ / __| |/ / __/ _ \| _ \/ __| __|
- * \__ \ | |/ _ \ (__| ' <| _| (_) | / (__| _|
- * |___/ |_/_/ \_\___|_|\_\_| \___/|_|_\\___|___|
- * embedded.connectivity.solutions===============
- *
- * \endcode
- *
- * \author Miguel Luis ( Semtech )
- *
- * \author Gregory Cristian ( Semtech )
- *
- * \author Daniel Jaeckle ( STACKFORCE )
- *
- * \defgroup REGIONRU864 Region RU864
- * Implementation according to LoRaWAN Specification v1.0.2.
- * \{
- */
- #ifndef __REGION_RU864_H__
- #define __REGION_RU864_H__
-
- #ifdef __cplusplus
- extern "C"
- {
- #endif
-
- #include "region/Region.h"
-
- /*!
- * LoRaMac maximum number of channels
- */
- #define RU864_MAX_NB_CHANNELS 8
-
- /*!
- * Number of default channels
- */
- #define RU864_NUMB_DEFAULT_CHANNELS 2
-
- /*!
- * Number of channels to apply for the CF list
- */
- #define RU864_NUMB_CHANNELS_CF_LIST 5
-
- /*!
- * Minimal datarate that can be used by the node
- */
- #define RU864_TX_MIN_DATARATE DR_0
-
- /*!
- * Maximal datarate that can be used by the node
- */
- #define RU864_TX_MAX_DATARATE DR_7
-
- /*!
- * Minimal datarate that can be used by the node
- */
- #define RU864_RX_MIN_DATARATE DR_0
-
- /*!
- * Maximal datarate that can be used by the node
- */
- #define RU864_RX_MAX_DATARATE DR_7
-
- /*!
- * Default datarate used by the node
- */
- #define RU864_DEFAULT_DATARATE DR_0
-
- /*!
- * Minimal Rx1 receive datarate offset
- */
- #define RU864_MIN_RX1_DR_OFFSET 0
-
- /*!
- * Maximal Rx1 receive datarate offset
- */
- #define RU864_MAX_RX1_DR_OFFSET 5
-
- /*!
- * Minimal Tx output power that can be used by the node
- */
- #define RU864_MIN_TX_POWER TX_POWER_7
-
- /*!
- * Maximal Tx output power that can be used by the node
- */
- #define RU864_MAX_TX_POWER TX_POWER_0
-
- /*!
- * Default Tx output power used by the node
- */
- #define RU864_DEFAULT_TX_POWER TX_POWER_0
-
- /*!
- * Default Max EIRP
- */
- #define RU864_DEFAULT_MAX_EIRP 16.0f
-
- /*!
- * Default antenna gain
- */
- #define RU864_DEFAULT_ANTENNA_GAIN 2.15f
-
- /*!
- * Enabled or disabled the duty cycle
- */
- #define RU864_DUTY_CYCLE_ENABLED 1
-
- /*!
- * Maximum RX window duration
- */
- #define RU864_MAX_RX_WINDOW 3000 //TODO
-
- #if ( RU864_DEFAULT_DATARATE > DR_5 )
- #error "A default DR higher than DR_5 may lead to connectivity loss."
- #endif
-
- /*!
- * Second reception window channel frequency definition.
- */
- #define RU864_RX_WND_2_FREQ 869100000
-
- /*!
- * Second reception window channel datarate definition.
- */
- #define RU864_RX_WND_2_DR DR_0
-
- /*!
- * Default uplink dwell time configuration
- */
- #define RU864_DEFAULT_UPLINK_DWELL_TIME 0
-
- /*
- * CLASS B
- */
- /*!
- * Beacon frequency
- */
- #define RU864_BEACON_CHANNEL_FREQ 869100000
-
- /*!
- * Ping slot channel frequency
- */
- #define RU864_PING_SLOT_CHANNEL_FREQ 868900000
-
- /*!
- * Payload size of a beacon frame
- */
- #define RU864_BEACON_SIZE 17
-
- /*!
- * Size of RFU 1 field
- */
- #define RU864_RFU1_SIZE 1
-
- /*!
- * Size of RFU 2 field
- */
- #define RU864_RFU2_SIZE 0
-
- /*!
- * Datarate of the beacon channel
- */
- #define RU864_BEACON_CHANNEL_DR DR_3
-
- /*!
- * Bandwith of the beacon channel (Index of BandwidthsRU864[])
- */
- #define RU864_BEACON_CHANNEL_BW 0
-
- /*!
- * Datarate of the ping slot channel
- */
- #define RU864_PING_SLOT_CHANNEL_DR DR_3
-
- /*!
- * Ping slot channel datarate
- */
- #define RU864_PING_SLOT_CHANNEL_DR DR_3
-
- /*!
- * Maximum number of bands
- */
- #define RU864_MAX_NB_BANDS 1
-
- /*!
- * Band 0 definition
- * Band = { DutyCycle, TxMaxPower, LastBandUpdateTime, LastMaxCreditAssignTime, TimeCredits, MaxTimeCredits, ReadyForTransmission }
- */
- #define RU864_BAND0 { 100 , RU864_MAX_TX_POWER, 0, 0, 0, 0, 0 } // 1.0 %
-
- /*!
- * LoRaMac default channel 1
- * Channel = { Frequency [Hz], RX1 Frequency [Hz], { ( ( DrMax << 4 ) | DrMin ) }, Band }
- */
- #define RU864_LC1 { 868900000, 0, { ( ( DR_5 << 4 ) | DR_0 ) }, 0 }
-
- /*!
- * LoRaMac default channel 2
- * Channel = { Frequency [Hz], RX1 Frequency [Hz], { ( ( DrMax << 4 ) | DrMin ) }, Band }
- */
- #define RU864_LC2 { 869100000, 0, { ( ( DR_5 << 4 ) | DR_0 ) }, 0 }
-
-
- /*!
- * LoRaMac channels which are allowed for the join procedure
- */
- #define RU864_JOIN_CHANNELS ( uint16_t )( LC( 1 ) | LC( 2 ) )
-
- /*!
- * Data rates table definition
- */
- static const uint8_t DataratesRU864[] = { 12, 11, 10, 9, 8, 7, 7, 50 };
-
- /*!
- * Bandwidths table definition in Hz
- */
- static const uint32_t BandwidthsRU864[] = { 125000, 125000, 125000, 125000, 125000, 125000, 250000, 0 };
-
- /*!
- * Maximum payload with respect to the datarate index.
- */
- static const uint8_t MaxPayloadOfDatarateRU864[] = { 51, 51, 51, 115, 242, 242, 242, 242 };
-
- /*!
- * \brief The function gets a value of a specific phy attribute.
- *
- * \param [IN] getPhy Pointer to the function parameters.
- *
- * \retval Returns a structure containing the PHY parameter.
- */
- PhyParam_t RegionRU864GetPhyParam( GetPhyParams_t* getPhy );
-
- /*!
- * \brief Updates the last TX done parameters of the current channel.
- *
- * \param [IN] txDone Pointer to the function parameters.
- */
- void RegionRU864SetBandTxDone( SetBandTxDoneParams_t* txDone );
-
- /*!
- * \brief Initializes the channels masks and the channels.
- *
- * \param [IN] type Sets the initialization type.
- */
- void RegionRU864InitDefaults( InitDefaultsParams_t* params );
-
- /*!
- * \brief Verifies a parameter.
- *
- * \param [IN] verify Pointer to the function parameters.
- *
- * \param [IN] type Sets the initialization type.
- *
- * \retval Returns true, if the parameter is valid.
- */
- bool RegionRU864Verify( VerifyParams_t* verify, PhyAttribute_t phyAttribute );
-
- /*!
- * \brief The function parses the input buffer and sets up the channels of the
- * CF list.
- *
- * \param [IN] applyCFList Pointer to the function parameters.
- */
- void RegionRU864ApplyCFList( ApplyCFListParams_t* applyCFList );
-
- /*!
- * \brief Sets a channels mask.
- *
- * \param [IN] chanMaskSet Pointer to the function parameters.
- *
- * \retval Returns true, if the channels mask could be set.
- */
- bool RegionRU864ChanMaskSet( ChanMaskSetParams_t* chanMaskSet );
-
- /*!
- * Computes the Rx window timeout and offset.
- *
- * \param [IN] datarate Rx window datarate index to be used
- *
- * \param [IN] minRxSymbols Minimum required number of symbols to detect an Rx frame.
- *
- * \param [IN] rxError System maximum timing error of the receiver. In milliseconds
- * The receiver will turn on in a [-rxError : +rxError] ms
- * interval around RxOffset
- *
- * \param [OUT]rxConfigParams Returns updated WindowTimeout and WindowOffset fields.
- */
- void RegionRU864ComputeRxWindowParameters( int8_t datarate, uint8_t minRxSymbols, uint32_t rxError, RxConfigParams_t *rxConfigParams );
-
- /*!
- * \brief Configuration of the RX windows.
- *
- * \param [IN] rxConfig Pointer to the function parameters.
- *
- * \param [OUT] datarate The datarate index which was set.
- *
- * \retval Returns true, if the configuration was applied successfully.
- */
- bool RegionRU864RxConfig( RxConfigParams_t* rxConfig, int8_t* datarate );
-
- /*!
- * \brief TX configuration.
- *
- * \param [IN] txConfig Pointer to the function parameters.
- *
- * \param [OUT] txPower The tx power index which was set.
- *
- * \param [OUT] txTimeOnAir The time-on-air of the frame.
- *
- * \retval Returns true, if the configuration was applied successfully.
- */
- bool RegionRU864TxConfig( TxConfigParams_t* txConfig, int8_t* txPower, TimerTime_t* txTimeOnAir );
-
- /*!
- * \brief The function processes a Link ADR Request.
- *
- * \param [IN] linkAdrReq Pointer to the function parameters.
- *
- * \retval Returns the status of the operation, according to the LoRaMAC specification.
- */
- uint8_t RegionRU864LinkAdrReq( LinkAdrReqParams_t* linkAdrReq, int8_t* drOut, int8_t* txPowOut, uint8_t* nbRepOut, uint8_t* nbBytesParsed );
-
- /*!
- * \brief The function processes a RX Parameter Setup Request.
- *
- * \param [IN] rxParamSetupReq Pointer to the function parameters.
- *
- * \retval Returns the status of the operation, according to the LoRaMAC specification.
- */
- uint8_t RegionRU864RxParamSetupReq( RxParamSetupReqParams_t* rxParamSetupReq );
-
- /*!
- * \brief The function processes a Channel Request.
- *
- * \param [IN] newChannelReq Pointer to the function parameters.
- *
- * \retval Returns the status of the operation, according to the LoRaMAC specification.
- */
- int8_t RegionRU864NewChannelReq( NewChannelReqParams_t* newChannelReq );
-
- /*!
- * \brief The function processes a TX ParamSetup Request.
- *
- * \param [IN] txParamSetupReq Pointer to the function parameters.
- *
- * \retval Returns the status of the operation, according to the LoRaMAC specification.
- * Returns -1, if the functionality is not implemented. In this case, the end node
- * shall not process the command.
- */
- int8_t RegionRU864TxParamSetupReq( TxParamSetupReqParams_t* txParamSetupReq );
-
- /*!
- * \brief The function processes a DlChannel Request.
- *
- * \param [IN] dlChannelReq Pointer to the function parameters.
- *
- * \retval Returns the status of the operation, according to the LoRaMAC specification.
- */
- int8_t RegionRU864DlChannelReq( DlChannelReqParams_t* dlChannelReq );
-
- /*!
- * \brief Alternates the datarate of the channel for the join request.
- *
- * \param [IN] currentDr Current datarate.
- *
- * \retval Datarate to apply.
- */
- int8_t RegionRU864AlternateDr( int8_t currentDr, AlternateDrType_t type );
-
- /*!
- * \brief Searches and set the next random available channel
- *
- * \param [OUT] channel Next channel to use for TX.
- *
- * \param [OUT] time Time to wait for the next transmission according to the duty
- * cycle.
- *
- * \param [OUT] aggregatedTimeOff Updates the aggregated time off.
- *
- * \retval Function status [1: OK, 0: Unable to find a channel on the current datarate]
- */
- LoRaMacStatus_t RegionRU864NextChannel( NextChanParams_t* nextChanParams, uint8_t* channel, TimerTime_t* time, TimerTime_t* aggregatedTimeOff );
-
- /*!
- * \brief Adds a channel.
- *
- * \param [IN] channelAdd Pointer to the function parameters.
- *
- * \retval Status of the operation.
- */
- LoRaMacStatus_t RegionRU864ChannelAdd( ChannelAddParams_t* channelAdd );
-
- /*!
- * \brief Removes a channel.
- *
- * \param [IN] channelRemove Pointer to the function parameters.
- *
- * \retval Returns true, if the channel was removed successfully.
- */
- bool RegionRU864ChannelsRemove( ChannelRemoveParams_t* channelRemove );
-
- /*!
- * \brief Computes new datarate according to the given offset
- *
- * \param [IN] downlinkDwellTime Downlink dwell time configuration. 0: No limit, 1: 400ms
- *
- * \param [IN] dr Current datarate
- *
- * \param [IN] drOffset Offset to be applied
- *
- * \retval newDr Computed datarate.
- */
- uint8_t RegionRU864ApplyDrOffset( uint8_t downlinkDwellTime, int8_t dr, int8_t drOffset );
-
- /*!
- * \brief Sets the radio into beacon reception mode
- *
- * \param [IN] rxBeaconSetup Pointer to the function parameters
- */
- void RegionRU864RxBeaconSetup( RxBeaconSetup_t* rxBeaconSetup, uint8_t* outDr );
-
- /*! \} defgroup REGIONRU864 */
-
- #ifdef __cplusplus
- }
- #endif
-
- #endif // __REGION_RU864_H__
|