2017-10-08 12:24:06 +02:00
|
|
|
|
/*
|
|
|
|
|
* 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>
|
|
|
|
|
|
2020-09-08 15:31:04 +02:00
|
|
|
|
#include "kernel_defines.h"
|
|
|
|
|
|
2017-10-08 12:24:06 +02:00
|
|
|
|
#ifdef __cplusplus
|
|
|
|
|
extern "C" {
|
|
|
|
|
#endif
|
|
|
|
|
|
|
|
|
|
/**
|
2018-12-18 10:52:24 +01:00
|
|
|
|
* @defgroup net_lora_conf LoRa modulation compile configurations
|
|
|
|
|
* @ingroup config
|
2017-10-08 12:24:06 +02:00
|
|
|
|
* @{
|
|
|
|
|
*/
|
|
|
|
|
/** @brief Frequency resolution in Hz */
|
2018-12-18 10:59:03 +01:00
|
|
|
|
#ifndef LORA_FREQUENCY_RESOLUTION_DEFAULT
|
2017-10-08 12:24:06 +02:00
|
|
|
|
#define LORA_FREQUENCY_RESOLUTION_DEFAULT (61.03515625)
|
|
|
|
|
#endif
|
2018-12-18 10:59:03 +01:00
|
|
|
|
|
2020-09-11 06:56:15 +02:00
|
|
|
|
/** @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.
|
|
|
|
|
*/
|
2020-09-08 15:11:55 +02:00
|
|
|
|
#ifndef CONFIG_LORA_PREAMBLE_LENGTH_DEFAULT
|
|
|
|
|
#define CONFIG_LORA_PREAMBLE_LENGTH_DEFAULT (8U)
|
2017-10-08 12:24:06 +02:00
|
|
|
|
#endif
|
2018-12-18 10:59:03 +01:00
|
|
|
|
|
2020-09-11 06:56:15 +02:00
|
|
|
|
/** @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.
|
|
|
|
|
*/
|
2020-09-08 15:13:07 +02:00
|
|
|
|
#ifndef CONFIG_LORA_SYMBOL_TIMEOUT_DEFAULT
|
|
|
|
|
#define CONFIG_LORA_SYMBOL_TIMEOUT_DEFAULT (10U)
|
2017-10-08 12:24:06 +02:00
|
|
|
|
#endif
|
2018-12-18 10:59:03 +01:00
|
|
|
|
|
2020-09-11 06:56:15 +02:00
|
|
|
|
/** @brief Set channel bandwidth
|
|
|
|
|
*
|
|
|
|
|
* Configure the channel bandwidth. Refer to country specific regulation on
|
|
|
|
|
* channel usage to identify the correct bandwidth.
|
|
|
|
|
*/
|
2020-09-08 15:31:04 +02:00
|
|
|
|
#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)
|
2022-05-17 15:30:01 +02:00
|
|
|
|
#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)
|
2020-09-08 15:31:04 +02:00
|
|
|
|
#endif
|
|
|
|
|
|
|
|
|
|
#ifndef CONFIG_LORA_BW_DEFAULT
|
|
|
|
|
#define CONFIG_LORA_BW_DEFAULT (LORA_BW_125_KHZ)
|
2017-10-08 12:24:06 +02:00
|
|
|
|
#endif
|
2018-12-18 10:59:03 +01:00
|
|
|
|
|
2020-09-11 06:56:15 +02:00
|
|
|
|
/** @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 .
|
|
|
|
|
*/
|
2020-09-08 15:37:01 +02:00
|
|
|
|
#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
|
2020-09-11 07:18:54 +02:00
|
|
|
|
#define CONFIG_LORA_SF_DEFAULT (LORA_SF7)
|
2017-10-08 12:24:06 +02:00
|
|
|
|
#endif
|
2018-12-18 10:59:03 +01:00
|
|
|
|
|
2020-09-11 06:56:15 +02:00
|
|
|
|
/** @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 .
|
|
|
|
|
*/
|
2020-09-08 15:46:03 +02:00
|
|
|
|
#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)
|
2022-05-17 15:30:01 +02:00
|
|
|
|
#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)
|
2020-09-08 15:46:03 +02:00
|
|
|
|
#endif
|
|
|
|
|
|
|
|
|
|
#ifndef CONFIG_LORA_CR_DEFAULT
|
2020-09-11 07:18:54 +02:00
|
|
|
|
#define CONFIG_LORA_CR_DEFAULT (LORA_CR_4_5)
|
2017-10-08 12:24:06 +02:00
|
|
|
|
#endif
|
2018-12-18 10:59:03 +01:00
|
|
|
|
|
2020-09-11 06:56:15 +02:00
|
|
|
|
/** @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/
|
|
|
|
|
*/
|
2020-09-08 16:20:41 +02:00
|
|
|
|
#ifdef DOXYGEN
|
|
|
|
|
#define CONFIG_LORA_IQ_INVERTED_DEFAULT
|
2017-10-08 12:24:06 +02:00
|
|
|
|
#endif
|
2018-12-18 10:59:03 +01:00
|
|
|
|
|
2020-09-11 06:56:15 +02:00
|
|
|
|
/** @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.
|
|
|
|
|
*/
|
2020-09-08 16:29:56 +02:00
|
|
|
|
#ifdef DOXYGEN
|
|
|
|
|
#define CONFIG_LORA_FREQUENCY_HOPPING_DEFAULT
|
2017-10-08 12:24:06 +02:00
|
|
|
|
#endif
|
2018-12-18 10:59:03 +01:00
|
|
|
|
|
2020-09-11 06:56:15 +02:00
|
|
|
|
/** @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.
|
|
|
|
|
*/
|
2020-09-08 16:56:59 +02:00
|
|
|
|
#ifndef CONFIG_LORA_FREQUENCY_HOPPING_PERIOD_DEFAULT
|
|
|
|
|
#define CONFIG_LORA_FREQUENCY_HOPPING_PERIOD_DEFAULT (0U)
|
2017-10-08 12:24:06 +02:00
|
|
|
|
#endif
|
2018-12-18 10:59:03 +01:00
|
|
|
|
|
2020-09-11 06:56:15 +02:00
|
|
|
|
/** @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>
|
|
|
|
|
*/
|
2020-09-09 19:48:54 +02:00
|
|
|
|
#ifdef DOXYGEN
|
|
|
|
|
#define CONFIG_LORA_FIXED_HEADER_LEN_MODE_DEFAULT
|
2017-10-08 12:24:06 +02:00
|
|
|
|
#endif
|
2018-12-18 10:59:03 +01:00
|
|
|
|
|
2022-01-14 10:32:29 +01:00
|
|
|
|
/**
|
|
|
|
|
* @brief Enable/disable payload CRC, optional
|
2020-09-09 20:07:10 +02:00
|
|
|
|
*/
|
2022-01-14 10:32:29 +01:00
|
|
|
|
#ifdef DOXYGEN
|
|
|
|
|
#define CONFIG_LORA_PAYLOAD_CRC_OFF_DEFAULT
|
2017-10-08 12:24:06 +02:00
|
|
|
|
#endif
|
2018-12-18 10:59:03 +01:00
|
|
|
|
|
2020-09-11 06:56:15 +02:00
|
|
|
|
/** @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.
|
|
|
|
|
*/
|
2020-09-09 20:15:17 +02:00
|
|
|
|
#ifndef CONFIG_LORA_PAYLOAD_LENGTH_DEFAULT
|
|
|
|
|
#define CONFIG_LORA_PAYLOAD_LENGTH_DEFAULT (0U)
|
2017-10-08 12:24:06 +02:00
|
|
|
|
#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 */
|
2022-05-17 15:30:01 +02:00
|
|
|
|
/* 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 */
|
2017-10-08 12:24:06 +02:00
|
|
|
|
/** @} */
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* @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 */
|
2022-05-17 15:30:01 +02:00
|
|
|
|
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 */
|
2017-10-08 12:24:06 +02:00
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* @brief LoRa modulation spreading factor rate
|
|
|
|
|
*/
|
|
|
|
|
enum {
|
2022-05-17 15:30:01 +02:00
|
|
|
|
LORA_SF5 = 5, /**< spreading factor 5, sx126x and sx1280 */
|
|
|
|
|
LORA_SF6, /**< spreading factor 6 */
|
2017-10-08 12:24:06 +02:00
|
|
|
|
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 */
|
2022-05-17 15:30:01 +02:00
|
|
|
|
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 */
|
2017-10-08 12:24:06 +02:00
|
|
|
|
};
|
|
|
|
|
/** @} */
|
|
|
|
|
|
|
|
|
|
#ifdef __cplusplus
|
|
|
|
|
}
|
|
|
|
|
#endif
|
|
|
|
|
|
|
|
|
|
#endif /* NET_LORA_H */
|
|
|
|
|
/** @} */
|