/* * Copyright (C) 2019 Freie Universität Berlin * * 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_gnrc_sixlowpan_config GNRC 6LoWPAN compile configurations * @ingroup net_gnrc_sixlowpan * @ingroup net_gnrc_conf * @brief * @{ * * @file * @brief Configuration macros for @ref net_gnrc_sixlowpan * * @author Martine Lenders */ #ifndef NET_GNRC_SIXLOWPAN_CONFIG_H #define NET_GNRC_SIXLOWPAN_CONFIG_H #include "kernel_defines.h" #include "timex.h" #ifdef __cplusplus extern "C" { #endif /** * @brief Default stack size to use for the 6LoWPAN thread. */ #ifndef GNRC_SIXLOWPAN_STACK_SIZE #define GNRC_SIXLOWPAN_STACK_SIZE (THREAD_STACKSIZE_DEFAULT) #endif /** * @brief Default priority for the 6LoWPAN thread. */ #ifndef GNRC_SIXLOWPAN_PRIO #define GNRC_SIXLOWPAN_PRIO (THREAD_PRIORITY_MAIN - 4) #endif /** * @brief Default message queue size to use for the 6LoWPAN thread. */ #ifndef CONFIG_GNRC_SIXLOWPAN_MSG_QUEUE_SIZE #define CONFIG_GNRC_SIXLOWPAN_MSG_QUEUE_SIZE (8U) #endif /** * @brief Number of datagrams that can be fragmented simultaneously * * This determines the number of @ref gnrc_sixlowpan_frag_fb_t instances * available. * * @note Only applicable with * [gnrc_sixlowpan_frag_fb](@ref net_gnrc_sixlowpan_frag_fb) module */ #ifndef CONFIG_GNRC_SIXLOWPAN_FRAG_FB_SIZE #define CONFIG_GNRC_SIXLOWPAN_FRAG_FB_SIZE (1U) #endif /** * @brief Size of the reassembly buffer * * @note Only applicable with * [gnrc_sixlowpan_frag_rb](@ref net_gnrc_sixlowpan_frag_rb) module */ #ifndef CONFIG_GNRC_SIXLOWPAN_FRAG_RBUF_SIZE #define CONFIG_GNRC_SIXLOWPAN_FRAG_RBUF_SIZE (4U) #endif /** * @brief Timeout for reassembly buffer entries in microseconds * * @note Only applicable with * [gnrc_sixlowpan_frag_rb](@ref net_gnrc_sixlowpan_frag_rb) module */ #ifndef GNRC_SIXLOWPAN_FRAG_RBUF_TIMEOUT_US #define GNRC_SIXLOWPAN_FRAG_RBUF_TIMEOUT_US (3U * US_PER_SEC) #endif /** * @brief Keep all but oldest fragment when reassembly buffer is full * * @note Only applicable with * [gnrc_sixlowpan_frag_rb](@ref net_gnrc_sixlowpan_frag_rb) module * * When not set, it will cause the reassembly buffer to override the oldest entry * if a new entry has to be created and the reassembly buffer is full, no matter what. * When set to 1, only incomplete entries that are older than * @ref GNRC_SIXLOWPAN_FRAG_RBUF_TIMEOUT_US will be overwritten (they will still timeout * normally). */ #ifdef DOXYGEN #define GNRC_SIXLOWPAN_FRAG_RBUF_DO_NOT_OVERRIDE #endif /** * @brief Aggressively override reassembly buffer when full * * @note Only applicable with * [gnrc_sixlowpan_frag_rb](@ref net_gnrc_sixlowpan_frag_rb) module * * When set to a non-zero value this will cause the reassembly buffer to * override the oldest entry no matter what. When set to zero only the oldest * entry that is older than @ref GNRC_SIXLOWPAN_FRAG_RBUF_TIMEOUT_US will be * overwritten (they will still timeout normally if reassembly buffer is not * full). * * @deprecated Use inverse @ref GNRC_SIXLOWPAN_FRAG_RBUF_DO_NOT_OVERRIDE instead. * Will be removed after 2020.10 release. */ #ifndef GNRC_SIXLOWPAN_FRAG_RBUF_AGGRESSIVE_OVERRIDE #if IS_ACTIVE(GNRC_SIXLOWPAN_FRAG_RBUF_DO_NOT_OVERRIDE) #define GNRC_SIXLOWPAN_FRAG_RBUF_AGGRESSIVE_OVERRIDE (0) #else /* GNRC_SIXLOWPAN_FRAG_RBUF_DO_NOT_OVERRIDE */ #define GNRC_SIXLOWPAN_FRAG_RBUF_AGGRESSIVE_OVERRIDE (1) #endif /* GNRC_SIXLOWPAN_FRAG_RBUF_DO_NOT_OVERRIDE */ #endif /* GNRC_SIXLOWPAN_FRAG_RBUF_AGGRESSIVE_OVERRIDE */ /** * @brief Deletion timer for reassembly buffer entries in microseconds * * @note Only applicable with * [gnrc_sixlowpan_frag_rb](@ref net_gnrc_sixlowpan_frag_rb) module * * Time to pass between completion of a datagram and the deletion of its * reassembly buffer entry. If this value is 0, the entry is dropped * immediately. Use this value to prevent re-creation of a reassembly buffer * entry on late arriving link-layer duplicates. */ #ifndef GNRC_SIXLOWPAN_FRAG_RBUF_DEL_TIMER #define GNRC_SIXLOWPAN_FRAG_RBUF_DEL_TIMER (0U) #endif /** * @brief Registration lifetime in minutes for the address registration option * * This value should be adapted to the devices power-lifecycle so that it is * greater than the time the device spends sleeping. * * @see [RFC 6775, section 5.8.1](https://tools.ietf.org/html/rfc6775#section-5.8.1) * * @note Only applicable with [gnrc_ipv6_nib](@ref net_gnrc_ipv6_nib) and * [gnrc_sixlowpan_nd](@ref net_gnrc_sixlowpan_nd) modules. The first * provides automatic sending of neighbor solicitations, the latter * provides capabilities to build the address registration option as a * @ref gnrc_pktsnip_t */ #ifndef GNRC_SIXLOWPAN_ND_AR_LTIME #define GNRC_SIXLOWPAN_ND_AR_LTIME (15U) #endif /** * @brief Size of the virtual reassembly buffer * * @see https://tools.ietf.org/html/draft-ietf-lwig-6lowpan-virtual-reassembly-01 * * @note Only applicable with * [gnrc_sixlowpan_frag_vrb](@ref net_gnrc_sixlowpan_frag_vrb) module, * but has also a direct influence on the number of available * gnrc_sixlowpan_frag_rb_int_t entries (even when * `gnrc_sixlowpan_frag_vrb` is not compiled in). */ #ifndef GNRC_SIXLOWPAN_FRAG_VRB_SIZE #if defined(MODULE_GNRC_SIXLOWPAN_FRAG_VRB) || defined(DOXYGEN) #define GNRC_SIXLOWPAN_FRAG_VRB_SIZE (16U) #else /* defined(MODULE_GNRC_SIXLOWPAN_FRAG_VRB) || defined(DOXYGEN) */ #define GNRC_SIXLOWPAN_FRAG_VRB_SIZE (0U) #endif /* defined(MODULE_GNRC_SIXLOWPAN_FRAG_VRB) || defined(DOXYGEN) */ #endif /* GNRC_SIXLOWPAN_FRAG_VRB_SIZE */ /** * @brief Timeout for a VRB entry in microseconds * * @see https://tools.ietf.org/html/draft-ietf-lwig-6lowpan-virtual-reassembly-01 * * @note Only applicable with * [gnrc_sixlowpan_frag_vrb](@ref net_gnrc_sixlowpan_frag_vrb) module. */ #ifndef GNRC_SIXLOWPAN_FRAG_VRB_TIMEOUT_US #define GNRC_SIXLOWPAN_FRAG_VRB_TIMEOUT_US (GNRC_SIXLOWPAN_FRAG_RBUF_TIMEOUT_US) #endif /* GNRC_SIXLOWPAN_FRAG_VRB_TIMEOUT_US */ /** * @name Selective fragment recovery configuration * @see [draft-ietf-6lo-fragment-recovery-07, section 7.1] * (https://tools.ietf.org/html/draft-ietf-6lo-fragment-recovery-07#section-7.1) * @note Only applicable with gnrc_sixlowpan_frag_sfr module * @{ */ /** * @brief Default minimum value for fragment size (MinFragmentSize) */ #ifndef GNRC_SIXLOWPAN_SFR_MIN_FRAG_SIZE #define GNRC_SIXLOWPAN_SFR_MIN_FRAG_SIZE (96U) #endif /** * @brief Default maximum value for fragment size (MaxFragmentSize) * * It must be lower than the minimum MTU along the path. A large value augments * the chances of buffer bloat and transmission loss. The value must be less * than 512 if the unit is defined for the PHY layer is the octet. */ #ifndef GNRC_SIXLOWPAN_SFR_MAX_FRAG_SIZE #define GNRC_SIXLOWPAN_SFR_MAX_FRAG_SIZE (112U) #endif /** * @brief Default value for fragment size that the sender should use to start * with (OptFragmentSize) */ #ifndef GNRC_SIXLOWPAN_SFR_OPT_FRAG_SIZE #define GNRC_SIXLOWPAN_SFR_OPT_FRAG_SIZE (GNRC_SIXLOWPAN_SFR_MAX_FRAG_SIZE) #endif /** * @brief Indicates whether the sender should react to ECN (UseECN) * * When the sender reacts to ECN its window size will vary between @ref * GNRC_SIXLOWPAN_SFR_MIN_WIN_SIZE and @ref GNRC_SIXLOWPAN_SFR_MAX_WIN_SIZE. */ #define GNRC_SIXLOWPAN_SFR_USE_ECN (0U) /** * @brief Default minimum value of window size that the sender can use * (MinWindowSize) */ #ifndef GNRC_SIXLOWPAN_SFR_MIN_WIN_SIZE #define GNRC_SIXLOWPAN_SFR_MIN_WIN_SIZE (1U) #endif /** * @brief Default maximum value of window size that the sender can use * (MaxWindowSize) * * @warning **Must** be lesser than 32. */ #ifndef GNRC_SIXLOWPAN_SFR_MAX_WIN_SIZE #define GNRC_SIXLOWPAN_SFR_MAX_WIN_SIZE (16U) #endif /** * @brief Default value of window size that the sender should start with * (OptWindowSize) */ #ifndef GNRC_SIXLOWPAN_SFR_OPT_WIN_SIZE #define GNRC_SIXLOWPAN_SFR_OPT_WIN_SIZE (16U) #endif /** * @brief Default minimum amount of time between transmissions in microseconds * (InterFrameGap) * * All packets to a same destination, and in particular fragments, may be * subject to receive while transmitting and hidden terminal collisions with the * next or the previous transmission as the fragments progress along a same * path. The InterFrameGap protects the propagation of to one transmission * before the next one is triggered and creates a duty cycle that controls the * ratio of air and memory in intermediate nodes that a particular datagram will * use. */ #ifndef GNRC_SIXLOWPAN_SFR_INTER_FRAME_GAP_US #define GNRC_SIXLOWPAN_SFR_INTER_FRAME_GAP_US (100U) #endif /** * @brief Default minimum amount of time in milliseconds a node should wait * for an RFRAG Acknowledgment before it takes a next action * (MinARQTimeOut) */ #ifndef GNRC_SIXLOWPAN_SFR_MIN_ARQ_TIMEOUT_MS #define GNRC_SIXLOWPAN_SFR_MIN_ARQ_TIMEOUT_MS (350U) #endif /** * @brief Default maximum amount of time in milliseconds a node should wait * for an RFRAG Acknowledgment before it takes a next action * (MaxARQTimeOut) */ #ifndef GNRC_SIXLOWPAN_SFR_MAX_ARQ_TIMEOUT_MS #define GNRC_SIXLOWPAN_SFR_MAX_ARQ_TIMEOUT_MS (700U) #endif /** * @brief Default starting point of the value of the amount of time in * milliseconds that a sender should wait for an RFRAG Acknowledgment * before it takes a next action (OptARQTimeOut) */ #ifndef GNRC_SIXLOWPAN_SFR_OPT_ARQ_TIMEOUT_MS #define GNRC_SIXLOWPAN_SFR_OPT_ARQ_TIMEOUT_MS (GNRC_SIXLOWPAN_SFR_MAX_ARQ_TIMEOUT_MS) #endif /** * @brief The maximum number of retries for a particular fragment * (MaxFragRetries) */ #ifndef GNRC_SIXLOWPAN_SFR_FRAG_RETRIES #define GNRC_SIXLOWPAN_SFR_FRAG_RETRIES (2U) #endif /** * @brief The maximum number of retries from scratch for a particular * datagram (MaxDatagramRetries) */ #ifndef GNRC_SIXLOWPAN_SFR_DG_RETRIES #define GNRC_SIXLOWPAN_SFR_DG_RETRIES (0U) #endif /** @} */ #ifdef __cplusplus } #endif #endif /* NET_GNRC_SIXLOWPAN_CONFIG_H */ /** @} */