/* * Copyright (C) 2017 Inria * * This file is subject to the terms and conditions of the GNU Lesser * General Public License v2.1. See the file LICENSE in the top level * directory for more details. */ /** * @defgroup net_lora LoRa modulation * @ingroup net * @brief LoRa modulation header definitions * @{ * * @file * @brief LoRa modulation header definitions * * @author Alexandre Abadie */ #ifndef NET_LORA_H #define NET_LORA_H #include #include #include "modules.h" #ifdef __cplusplus extern "C" { #endif /** * @defgroup net_lora_conf LoRa modulation compile configurations * @ingroup config * @{ */ #ifndef LORA_FREQUENCY_RESOLUTION_NANOHERTZ_DEFAULT /** * @brief Frequency resolution in nano Hz * * This is the same as `(32 * 10^15) >> 19` */ #define LORA_FREQUENCY_RESOLUTION_NANOHERTZ_DEFAULT 61035156250 #endif /** @brief Preamble length, same for Tx and Rx * * Configure preamble used in LoRa frame. Each LoRa frame begins with a * preamble. It starts with a series of upchirps to cover the whole frequency * band of the particular channel assigned. The last two upchirps encode the * sync word. Sync word is used to differentiate between LoRa transmissions that * use the same frequency bands. The sync word is followed by two and a quarter * downchirps, for a duration of 2.25 symbols. The total duration of this * preamble can be configured between 10.25 and 65,539.25 symbol hence the value * can range from 8 to 65537. */ #ifndef CONFIG_LORA_PREAMBLE_LENGTH_DEFAULT #define CONFIG_LORA_PREAMBLE_LENGTH_DEFAULT (8U) #endif /** @brief Symbol timeout period in symbols * * Configure symbol time out in terms of number of symbols. One symbol has a * length in time of (2^SF)/BW seconds. */ #ifndef CONFIG_LORA_SYMBOL_TIMEOUT_DEFAULT #define CONFIG_LORA_SYMBOL_TIMEOUT_DEFAULT (10U) #endif /** @brief Set channel bandwidth * * Configure the channel bandwidth. Refer to country specific regulation on * channel usage to identify the correct bandwidth. */ #if IS_ACTIVE(CONFIG_LORA_BW_DEFAULT_125) #define CONFIG_LORA_BW_DEFAULT (LORA_BW_125_KHZ) #elif IS_ACTIVE(CONFIG_LORA_BW_DEFAULT_250) #define CONFIG_LORA_BW_DEFAULT (LORA_BW_250_KHZ) #elif IS_ACTIVE(CONFIG_LORA_BW_DEFAULT_500) #define CONFIG_LORA_BW_DEFAULT (LORA_BW_500_KHZ) #elif IS_ACTIVE(CONFIG_LORA_BW_DEFAULT_200) #define CONFIG_LORA_BW_DEFAULT (LORA_BW_200_KHZ) #elif IS_ACTIVE(CONFIG_LORA_BW_DEFAULT_400) #define CONFIG_LORA_BW_DEFAULT (LORA_BW_400_KHZ) #elif IS_ACTIVE(CONFIG_LORA_BW_DEFAULT_800) #define CONFIG_LORA_BW_DEFAULT (LORA_BW_800_KHZ) #elif IS_ACTIVE(CONFIG_LORA_BW_DEFAULT_1600) #define CONFIG_LORA_BW_DEFAULT (LORA_BW_1600_KHZ) #endif #ifndef CONFIG_LORA_BW_DEFAULT #define CONFIG_LORA_BW_DEFAULT (LORA_BW_125_KHZ) #endif /** @brief Set Spreading Factor (SF) * * Configure Spreading Factor (SF). SF denotes the amount of spreading code * applied to the original data signal. A larger SF increases the time on air, * which increases energy consumption, reduces the data rate, and improves * communication range. Each step up in spreading factor effectively doubles the * time on air to transmit the same amount of data. Refer to country specific * air time usage regulations before varying the SF. To calculate air time refer * https://www.loratools.nl/#/airtime . */ #if IS_ACTIVE(CONFIG_LORA_SF_DEFAULT_SF6) #define CONFIG_LORA_SF_DEFAULT (LORA_SF6) #elif IS_ACTIVE(CONFIG_LORA_SF_DEFAULT_SF7) #define CONFIG_LORA_SF_DEFAULT (LORA_SF7) #elif IS_ACTIVE(CONFIG_LORA_SF_DEFAULT_SF8) #define CONFIG_LORA_SF_DEFAULT (LORA_SF8) #elif IS_ACTIVE(CONFIG_LORA_SF_DEFAULT_SF9) #define CONFIG_LORA_SF_DEFAULT (LORA_SF9) #elif IS_ACTIVE(CONFIG_LORA_SF_DEFAULT_SF10) #define CONFIG_LORA_SF_DEFAULT (LORA_SF10) #elif IS_ACTIVE(CONFIG_LORA_SF_DEFAULT_SF11) #define CONFIG_LORA_SF_DEFAULT (LORA_SF11) #elif IS_ACTIVE(CONFIG_LORA_SF_DEFAULT_SF12) #define CONFIG_LORA_SF_DEFAULT (LORA_SF12) #endif #ifndef CONFIG_LORA_SF_DEFAULT #define CONFIG_LORA_SF_DEFAULT (LORA_SF7) #endif /** @brief Set Coding Rate (CR) * * Configure Coding Rate (CR). CR denotes the implementation of forward error * correction (FEC). This may be done by encoding 4-bit data with redundancies * into 5-bit, 6-bit, 7-bit, or 8-bit. Coding Rate (CR) value need to be * adjusted according to conditions of the channel used for data transmission. * If there are too many interferences in the channel, then it’s recommended to * increase the value of CR. However, the rise in CR value will also increase * the duration for the transmission. Refer to country specific air time usage * regulations before varying the CR. To calculate air time refer * https://www.loratools.nl/#/airtime . */ #if IS_ACTIVE(CONFIG_LORA_CR_DEFAULT_CR_4_5) #define CONFIG_LORA_CR_DEFAULT (LORA_CR_4_5) #elif IS_ACTIVE(CONFIG_LORA_CR_DEFAULT_CR_4_6) #define CONFIG_LORA_CR_DEFAULT (LORA_CR_4_6) #elif IS_ACTIVE(CONFIG_LORA_CR_DEFAULT_CR_4_7) #define CONFIG_LORA_CR_DEFAULT (LORA_CR_4_7) #elif IS_ACTIVE(CONFIG_LORA_CR_DEFAULT_CR_4_8) #define CONFIG_LORA_CR_DEFAULT (LORA_CR_4_8) #elif IS_ACTIVE(CONFIG_LORA_CR_DEFAULT_CR_LI_4_5) #define CONFIG_LORA_CR_DEFAULT (LORA_CR_LI_4_5) #elif IS_ACTIVE(CONFIG_LORA_CR_DEFAULT_CR_LI_4_6) #define CONFIG_LORA_CR_DEFAULT (LORA_CR_LI_4_6) #elif IS_ACTIVE(CONFIG_LORA_CR_DEFAULT_CR_LI_4_8) #define CONFIG_LORA_CR_DEFAULT (LORA_CR_LI_4_8) #endif #ifndef CONFIG_LORA_CR_DEFAULT #define CONFIG_LORA_CR_DEFAULT (LORA_CR_4_5) #endif /** @brief Set this to 1 to enable inverted I/Q mode * * Enable this to invert the IQ signals used in RF modulation circuit. For more * information on I/Q modulation technique visit http://www.ni.com/tutorial/4805/en/ */ #ifdef DOXYGEN #define CONFIG_LORA_IQ_INVERTED_DEFAULT #endif /** @brief Set this to 1 to enable frequency hopping * * If Frequency hopping spread spectrum (FHSS) is enabled a portion of each LoRa * packet is transmitted on each hopping channel from a look up table of * frequencies managed by the host microcontroller. */ #ifdef DOXYGEN #define CONFIG_LORA_FREQUENCY_HOPPING_DEFAULT #endif /** @brief Frequency hopping period in symbols * * Configure the hopping period, in symbols, time which each transmission will * dwell in any given channel. One symbol has a length in time of (2^SF)/BW * seconds. */ #ifndef CONFIG_LORA_FREQUENCY_HOPPING_PERIOD_DEFAULT #define CONFIG_LORA_FREQUENCY_HOPPING_PERIOD_DEFAULT (0U) #endif /** @brief Set this to 1 to enable fixed header length mode (implicit header) * * If fixed header length mode ( implicit header mode) is enabled, PHY header * (`PHDR`) in LoRa frame is discarded. For more information, refer to the * section "LoRa frame structure" in this * publication */ #ifdef DOXYGEN #define CONFIG_LORA_FIXED_HEADER_LEN_MODE_DEFAULT #endif /** * @brief Enable/disable payload CRC, optional */ #ifdef DOXYGEN #define CONFIG_LORA_PAYLOAD_CRC_OFF_DEFAULT #endif /** @brief Configure payload length * * Configure the length of payload. The configuration is unused when using * explicit header mode ( @ref CONFIG_LORA_FIXED_HEADER_LEN_MODE_DEFAULT ) as * `PHDR` carries the length information. */ #ifndef CONFIG_LORA_PAYLOAD_LENGTH_DEFAULT #define CONFIG_LORA_PAYLOAD_LENGTH_DEFAULT (0U) #endif /** @} */ /** * @name LoRa syncword values for network types * @{ */ #define LORA_SYNCWORD_PUBLIC (0x34) /**< Syncword used for public networks */ #define LORA_SYNCWORD_PRIVATE (0x12) /**< Syncword used for private networks */ /* see https://lora-developers.semtech.com/documentation/tech-papers-and-guides/physical-layer-proposal-2.4ghz */ #define LORA_SYNCWORD_ISM2400_PUBLIC (0x21) /**< Syncword used for public networks on ISM2400 */ /** @} */ /** * @name LoRa 2.4Ghz band frequency definitions * * See https://lora-developers.semtech.com/documentation/tech-papers-and-guides/physical-layer-proposal-2.4ghz/ * @{ */ #define LORA_ISM2400_FREQUENCY_LOW 2400000000 /**< lowest frequency ISM24000 band */ #define LORA_ISM2400_FREQUENCY_HIGH 2500000000 /**< highest frequency ISM24000 band */ /** @} */ /** * @name LoRa modulation available values * @{ */ /** * @brief LoRa modulation bandwidth. */ enum { LORA_BW_125_KHZ = 0, /**< 125 kHz bandwidth */ LORA_BW_250_KHZ, /**< 250 kHz bandwidth */ LORA_BW_500_KHZ, /**< 500 kHz bandwidth */ LORA_BW_200_KHZ, /**< 200 kHz bandwidth, only 2.4Ghz */ LORA_BW_400_KHZ, /**< 400 kHz bandwidth, only 2.4Ghz */ LORA_BW_800_KHZ, /**< 800 kHz bandwidth, only 2.4Ghz */ LORA_BW_1600_KHZ, /**< 1600 kHz bandwidth, only 2.4Ghz */ }; /** * @brief LoRa modulation spreading factor rate */ enum { LORA_SF5 = 5, /**< spreading factor 5, sx126x and sx1280 */ LORA_SF6, /**< spreading factor 6 */ LORA_SF7, /**< spreading factor 7 */ LORA_SF8, /**< spreading factor 8 */ LORA_SF9, /**< spreading factor 9 */ LORA_SF10, /**< spreading factor 10 */ LORA_SF11, /**< spreading factor 11 */ LORA_SF12 /**< spreading factor 12 */ }; /** * @brief LoRa modulation error coding rate. */ enum { LORA_CR_4_5 = 1, /**< coding rate 4/5 */ LORA_CR_4_6, /**< coding rate 4/6 */ LORA_CR_4_7, /**< coding rate 4/7 */ LORA_CR_4_8, /**< coding rate 4/8 */ LORA_CR_LI_4_5, /**< coding rate long interleaving 4/5 */ LORA_CR_LI_4_6, /**< coding rate long interleaving 4/6 */ LORA_CR_LI_4_8 /**< coding rate long interleaving 4/8 */ }; /** @} */ #ifdef __cplusplus } #endif #endif /* NET_LORA_H */ /** @} */