Important changes to repositories hosted on mbed.com
Mbed hosted mercurial repositories are deprecated and are due to be permanently deleted in July 2026.
To keep a copy of this software download the repository Zip archive or clone locally using Mercurial.
It is also possible to export all your personal repositories from the account settings page.
Fork of libxDot-dev-mbed5-deprecated by
The Connect example can be used as a starting point for an xDot application.
Import programmDot_LoRa_Connect_Example_CUSTOM_AS923
Example configuration of frequencies and datarates for AS923 channel plan.
Change the libmDot-Custom library to libxDot-Custom after importing the above example.
Change the platform for the project to xDot in upper right corner of the compiler page.
Ensure the mbed-os version matches the with the library commit.
Currently the AT Firmware cannot be built online for the xDot.
Creating new channel plans
Copy EU868 or US915 custom channel plan as a starting point
Import librarymDot_Channel_Plans
Channel plans to enable libmDot-Custom
EU868 provides a framework for a DYNAMIC channel plan with duty-cycle limitations
US915 provides a framework for a FIXED channel plan
RADIO_POWERS are measured output in dBm for each radio tx power setting.
Additional MAC Commands can be implemented by overriding the HandleMacCommand function.
Steps
- Setup datarates, duty-cycle bands and channels in ChannelPlan_* constructor
- Modify GetJoinDatarate and CalculateJoinBackoff to change join datarates and backoff
- Customize HandleJoinAccept datarates
- Use GetRxWindow(int) to define how the device open Rx window 1 and 2
- GetNextChannel will pick a channel from the enabled channel at the current datarate before each TX
Diff: ChannelPlans/CustomChannelPlan_AU915.h
- Revision:
- 23:17a25e16ccf1
--- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/ChannelPlans/CustomChannelPlan_AU915.h Mon Oct 31 14:51:55 2016 +0000 @@ -0,0 +1,246 @@ +/** __ ___ ____ _ ______ __ ____ __ ____ + * / |/ /_ __/ / /_(_)__/_ __/__ ____/ / / __/_ _____ / /____ __ _ ___ / _/__ ____ + * / /|_/ / // / / __/ /___// / / -_) __/ _ \ _\ \/ // (_-</ __/ -_) ' \(_-< _/ // _ \/ __/ __ + * /_/ /_/\_,_/_/\__/_/ /_/ \__/\__/_//_/ /___/\_, /___/\__/\__/_/_/_/___/ /___/_//_/\__/ /_/ + * Copyright (C) 2015 by Multi-Tech Systems /___/ + * + * + * @author Jason Reiss + * @date 10-31-2015 + * @brief lora::ChannelPlan provides an interface for LoRaWAN channel schemes + * + * @details + * + */ + +#ifndef __CUSTOM_CHANNEL_PLAN_AU915_H__ +#define __CUSTOM_CHANNEL_PLAN_AU915_H__ + +#include "Lora.h" +#include "SxRadio.h" +#include "ChannelPlan.h" +#include <vector> + +namespace lora { + + class CustomChannelPlan_AU915 : public lora::ChannelPlan { + public: + + /** + * ChannelPlan constructor + * @param radio SxRadio object used to set Tx/Rx config + * @param settings Settings object + */ + CustomChannelPlan_AU915(SxRadio& radio, Settings& settings); + + /** + * ChannelPlan destructor + */ + virtual ~CustomChannelPlan_AU915(); + + /** + * Initialize channels, datarates and duty cycle bands according to current channel plan in settings + */ + virtual void Init(); + + /** + * Get the next channel to use to transmit + * @return LORA_OK if channel was found + * @return LORA_NO_CHANS_ENABLED + */ + virtual uint8_t GetNextChannel(); + + /** + * Set the number of channels in the plan + */ + virtual void SetNumberOfChannels(uint8_t channels, bool resize = true); + + /** + * Check if channel is enabled + * @return true if enabled + */ + virtual bool IsChannelEnabled(uint8_t channel); + + + /** + * Add a channel to the ChannelPlan + * @param index of channel, use -1 to add to end + * @param channel settings to add + */ + virtual uint8_t AddChannel(int8_t index, Channel channel); + + /** + * Get channel at index + * @return Channel + */ + virtual Channel GetChannel(int8_t index); + + /** + * Get rx window settings for requested window + * RX_1, RX_2, RX_BEACON, RX_SLOT + * @param window + * @return RxWindow + */ + virtual RxWindow GetRxWindow(uint8_t window); + + /** + * Get datarate to use on the join request + * @return datarate index + */ + virtual uint8_t GetJoinDatarate(); + + /** + * Calculate the next time a join request is possible + * @param size of join frame + * @returns LORA_OK + */ + virtual uint8_t CalculateJoinBackoff(uint8_t size); + + /** + * Set the datarate offset used for first receive window + * @param offset + * @return LORA_OK + */ + virtual uint8_t SetRx1Offset(uint8_t offset); + + /** + * Set the frequency for second receive window + * @param freq + * @return LORA_OK + */ + virtual uint8_t SetRx2Frequency(uint32_t freq); + + /** + * Set the datarate index used for second receive window + * @param index + * @return LORA_OK + */ + virtual uint8_t SetRx2DatarateIndex(uint8_t index); + + /** + * Get next channel and set the SxRadio tx config with current settings + * @return LORA_OK + */ + virtual uint8_t SetTxConfig(); + + /** + * Set the SxRadio rx config provided window + * @param window to be opened + * @param continuous keep window open + * @return LORA_OK + */ + virtual uint8_t SetRxConfig(uint8_t window, bool continuous); + + /** + * Set channel group if supported by plan + * @param group + * @return LORA_OK + */ + virtual uint8_t SetChannelGroup(uint8_t group); + + /** + * Callback for Join Accept packet to load optional channels + * @return LORA_OK + */ + virtual uint8_t HandleJoinAccept(const uint8_t* buffer, uint8_t size); + + /** + * Callback to for rx parameter setup ServerCommand + * @param payload packet data + * @param index of start of command buffer + * @param size number of bytes in command buffer + * @param[out] status to be returned in MoteCommand answer + * @return LORA_OK + */ + virtual uint8_t HandleRxParamSetup(const uint8_t* payload, uint8_t index, uint8_t size, uint8_t& status); + + /** + * Callback to for new channel ServerCommand + * @param payload packet data + * @param index of start of command buffer + * @param size number of bytes in command buffer + * @param[out] status to be returned in MoteCommand answer + * @return LORA_OK + */ + virtual uint8_t HandleNewChannel(const uint8_t* payload, uint8_t index, uint8_t size, uint8_t& status); + + /** + * Callback to for ping slot channel request ServerCommand + * @param payload packet data + * @param index of start of command buffer + * @param size number of bytes in command buffer + * @param[out] status to be returned in MoteCommand answer + * @return LORA_OK + */ + virtual uint8_t HandlePingSlotChannelReq(const uint8_t* payload, uint8_t index, uint8_t size, uint8_t& status); + + /** + * Callback to for beacon frequency request ServerCommand + * @param payload packet data + * @param index of start of command buffer + * @param size number of bytes in command buffer + * @param[out] status to be returned in MoteCommand answer + * @return LORA_OK + */ + virtual uint8_t HandleBeaconFrequencyReq(const uint8_t* payload, uint8_t index, uint8_t size, uint8_t& status); + + /** + * Callback to for adaptive datarate ServerCommand + * @param payload packet data + * @param index of start of command buffer + * @param size number of bytes in command buffer + * @param[out] status to be returned in MoteCommand answer + * @return LORA_OK + */ + virtual uint8_t HandleAdrCommand(const uint8_t* payload, uint8_t index, uint8_t size, uint8_t& status); + + /** + * Flag if ADR ACK should be sent in next packet + * @return true when flag should be set + */ + virtual bool AdrAckReq(); + + /** + * Get the time the radio must be off air to comply with regulations + * Time to wait may be dependent on duty-cycle restrictions per channel + * Or duty-cycle of join requests if OTAA is being attempted + * @return ms of time to wait for next tx opportunity + */ + virtual uint32_t GetTimeOffAir(); + + /** + * Get the channels in use by current channel plan + * @return channel frequencies + */ + virtual std::vector<uint32_t> GetChannels(); + + /** + * Get the channel datarate ranges in use by current channel plan + * @return channel datarate ranges + */ + virtual std::vector<uint8_t> GetChannelRanges(); + + + /** + * Print log message for given rx window + * @param wnd 1 or 2 + */ + virtual void LogRxWindow(uint8_t wnd); + + /** + * Enable the default channels of the channel plan + */ + virtual void EnableDefaultChannels(); + + protected: + + static const uint8_t AU915_TX_POWERS[11]; //!< List of available tx powers + static const uint8_t AU915_RADIO_POWERS[21]; //!< List of calibrated tx powers + static const uint8_t AU915_MAX_PAYLOAD_SIZE[]; //!< List of max payload sizes for each datarate + static const uint8_t AU915_MAX_PAYLOAD_SIZE_REPEATER[]; //!< List of repeater compatible max payload sizes for each datarate + + }; +} + +#endif // __CUSTOM_CHANNEL_PLAN_AU915_H__ +