mirror of
https://github.com/RIOT-OS/RIOT.git
synced 2025-01-18 12:52:44 +01:00
283 lines
10 KiB
C
283 lines
10 KiB
C
/*
|
||
* 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 <alexandre.abadie@inria.fr>
|
||
*/
|
||
|
||
#ifndef NET_LORA_H
|
||
#define NET_LORA_H
|
||
|
||
#include <stdint.h>
|
||
#include <stdlib.h>
|
||
|
||
#include "modules.h"
|
||
|
||
#ifdef __cplusplus
|
||
extern "C" {
|
||
#endif
|
||
|
||
/**
|
||
* @defgroup net_lora_conf LoRa modulation compile configurations
|
||
* @ingroup config
|
||
* @{
|
||
*/
|
||
/** @brief Frequency resolution in Hz */
|
||
#ifndef LORA_FREQUENCY_RESOLUTION_DEFAULT
|
||
#define LORA_FREQUENCY_RESOLUTION_DEFAULT (61.03515625)
|
||
#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
|
||
* <a href="https://link.springer.com/article/10.1186/s13638-019-1542-x">publication</a>
|
||
*/
|
||
#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 */
|
||
/** @} */
|