2019-04-17 21:26:27 +02:00
|
|
|
/*
|
|
|
|
* 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
|
2019-12-06 12:23:34 +01:00
|
|
|
* @ingroup net_gnrc_conf
|
2019-04-17 21:26:27 +02:00
|
|
|
* @brief
|
|
|
|
* @{
|
|
|
|
*
|
|
|
|
* @file
|
|
|
|
* @brief Configuration macros for @ref net_gnrc_sixlowpan
|
|
|
|
*
|
|
|
|
* @author Martine Lenders <m.lenders@fu-berlin.de>
|
|
|
|
*/
|
|
|
|
#ifndef NET_GNRC_SIXLOWPAN_CONFIG_H
|
|
|
|
#define NET_GNRC_SIXLOWPAN_CONFIG_H
|
|
|
|
|
2020-01-15 16:37:42 +01:00
|
|
|
#include "kernel_defines.h"
|
2019-04-17 21:39:17 +02:00
|
|
|
#include "timex.h"
|
|
|
|
|
2019-04-17 21:26:27 +02:00
|
|
|
#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
|
|
|
|
|
|
|
|
/**
|
2020-05-15 11:16:47 +02:00
|
|
|
* @brief Default message queue size to use for the 6LoWPAN thread (as
|
|
|
|
* exponent of 2^n).
|
|
|
|
*
|
|
|
|
* As the queue size ALWAYS needs to be power of two, this option represents the
|
|
|
|
* exponent of 2^n, which will be used as the size of the queue.
|
2019-04-17 21:26:27 +02:00
|
|
|
*/
|
2020-05-15 11:16:47 +02:00
|
|
|
#ifndef CONFIG_GNRC_SIXLOWPAN_MSG_QUEUE_SIZE_EXP
|
|
|
|
#define CONFIG_GNRC_SIXLOWPAN_MSG_QUEUE_SIZE_EXP (3U)
|
2019-04-17 21:26:27 +02:00
|
|
|
#endif
|
|
|
|
|
2019-02-15 11:54:19 +01:00
|
|
|
/**
|
|
|
|
* @brief Number of datagrams that can be fragmented simultaneously
|
|
|
|
*
|
2019-10-17 16:56:38 +02:00
|
|
|
* This determines the number of @ref gnrc_sixlowpan_frag_fb_t instances
|
2019-02-15 11:54:19 +01:00
|
|
|
* available.
|
|
|
|
*
|
|
|
|
* @note Only applicable with
|
2019-10-17 16:56:38 +02:00
|
|
|
* [gnrc_sixlowpan_frag_fb](@ref net_gnrc_sixlowpan_frag_fb) module
|
2019-02-15 11:54:19 +01:00
|
|
|
*/
|
2020-01-14 12:16:03 +01:00
|
|
|
#ifndef CONFIG_GNRC_SIXLOWPAN_FRAG_FB_SIZE
|
|
|
|
#define CONFIG_GNRC_SIXLOWPAN_FRAG_FB_SIZE (1U)
|
2019-02-15 11:54:19 +01:00
|
|
|
#endif
|
|
|
|
|
2019-04-17 21:39:17 +02:00
|
|
|
/**
|
|
|
|
* @brief Size of the reassembly buffer
|
|
|
|
*
|
|
|
|
* @note Only applicable with
|
2019-10-18 08:42:50 +02:00
|
|
|
* [gnrc_sixlowpan_frag_rb](@ref net_gnrc_sixlowpan_frag_rb) module
|
2019-04-17 21:39:17 +02:00
|
|
|
*/
|
2020-01-14 12:19:37 +01:00
|
|
|
#ifndef CONFIG_GNRC_SIXLOWPAN_FRAG_RBUF_SIZE
|
|
|
|
#define CONFIG_GNRC_SIXLOWPAN_FRAG_RBUF_SIZE (4U)
|
2019-04-17 21:39:17 +02:00
|
|
|
#endif
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Timeout for reassembly buffer entries in microseconds
|
|
|
|
*
|
|
|
|
* @note Only applicable with
|
2019-10-18 08:42:50 +02:00
|
|
|
* [gnrc_sixlowpan_frag_rb](@ref net_gnrc_sixlowpan_frag_rb) module
|
2019-04-17 21:39:17 +02:00
|
|
|
*/
|
2020-01-14 12:22:57 +01:00
|
|
|
#ifndef CONFIG_GNRC_SIXLOWPAN_FRAG_RBUF_TIMEOUT_US
|
|
|
|
#define CONFIG_GNRC_SIXLOWPAN_FRAG_RBUF_TIMEOUT_US (3U * US_PER_SEC)
|
2019-04-17 21:39:17 +02:00
|
|
|
#endif
|
|
|
|
|
2020-01-15 16:37:42 +01:00
|
|
|
/**
|
2020-01-30 17:04:18 +01:00
|
|
|
* @brief Do not override oldest datagram when reassembly buffer is full
|
2020-01-15 16:37:42 +01:00
|
|
|
*
|
|
|
|
* @note Only applicable with
|
|
|
|
* [gnrc_sixlowpan_frag_rb](@ref net_gnrc_sixlowpan_frag_rb) module
|
|
|
|
*
|
2020-01-30 17:04:18 +01:00
|
|
|
* When not set, it will cause the reassembly buffer to override the oldest
|
|
|
|
* entry when a fragment for a new datagram is received. When set, only the
|
|
|
|
* oldest entry that is older than @ref
|
|
|
|
* CONFIG_GNRC_SIXLOWPAN_FRAG_RBUF_TIMEOUT_US will be overwritten (they will
|
|
|
|
* still timeout normally if reassembly buffer is not full).
|
2020-01-15 16:37:42 +01:00
|
|
|
*/
|
|
|
|
#ifdef DOXYGEN
|
2020-01-17 18:07:23 +01:00
|
|
|
#define CONFIG_GNRC_SIXLOWPAN_FRAG_RBUF_DO_NOT_OVERRIDE
|
2020-01-15 16:37:42 +01:00
|
|
|
#endif
|
|
|
|
|
2019-10-28 14:09:30 +01:00
|
|
|
/**
|
|
|
|
* @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.
|
|
|
|
*/
|
2020-01-14 12:27:24 +01:00
|
|
|
#ifndef CONFIG_GNRC_SIXLOWPAN_FRAG_RBUF_DEL_TIMER
|
|
|
|
#define CONFIG_GNRC_SIXLOWPAN_FRAG_RBUF_DEL_TIMER (0U)
|
2019-10-28 14:09:30 +01:00
|
|
|
#endif
|
|
|
|
|
2019-04-17 21:26:27 +02:00
|
|
|
/**
|
|
|
|
* @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
|
|
|
|
*/
|
2020-01-14 12:29:31 +01:00
|
|
|
#ifndef CONFIG_GNRC_SIXLOWPAN_ND_AR_LTIME
|
|
|
|
#define CONFIG_GNRC_SIXLOWPAN_ND_AR_LTIME (15U)
|
2019-04-17 21:26:27 +02:00
|
|
|
#endif
|
|
|
|
|
2019-02-06 14:48:13 +01:00
|
|
|
/**
|
|
|
|
* @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
|
2020-01-14 12:31:49 +01:00
|
|
|
* gnrc_sixlowpan_frag_rb_int_t entries.
|
2019-02-06 14:48:13 +01:00
|
|
|
*/
|
2020-01-14 12:31:49 +01:00
|
|
|
#ifndef CONFIG_GNRC_SIXLOWPAN_FRAG_VRB_SIZE
|
|
|
|
#define CONFIG_GNRC_SIXLOWPAN_FRAG_VRB_SIZE (16U)
|
|
|
|
#endif /* CONFIG_GNRC_SIXLOWPAN_FRAG_VRB_SIZE */
|
2019-02-06 14:48:13 +01:00
|
|
|
|
|
|
|
/**
|
|
|
|
* @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.
|
|
|
|
*/
|
2020-01-14 12:33:41 +01:00
|
|
|
#ifndef CONFIG_GNRC_SIXLOWPAN_FRAG_VRB_TIMEOUT_US
|
|
|
|
#define CONFIG_GNRC_SIXLOWPAN_FRAG_VRB_TIMEOUT_US (CONFIG_GNRC_SIXLOWPAN_FRAG_RBUF_TIMEOUT_US)
|
|
|
|
#endif /* CONFIG_GNRC_SIXLOWPAN_FRAG_VRB_TIMEOUT_US */
|
2019-02-06 14:48:13 +01:00
|
|
|
|
2019-09-13 13:17:36 +02:00
|
|
|
/**
|
|
|
|
* @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
|
|
|
|
/** @} */
|
|
|
|
|
2020-05-15 11:16:47 +02:00
|
|
|
/**
|
|
|
|
* @brief Message queue size to use for the 6LoWPAN thread.
|
|
|
|
*/
|
|
|
|
#ifndef GNRC_SIXLOWPAN_MSG_QUEUE_SIZE
|
|
|
|
#define GNRC_SIXLOWPAN_MSG_QUEUE_SIZE (1 << CONFIG_GNRC_SIXLOWPAN_MSG_QUEUE_SIZE_EXP)
|
|
|
|
#endif
|
|
|
|
|
2019-04-17 21:26:27 +02:00
|
|
|
#ifdef __cplusplus
|
|
|
|
}
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#endif /* NET_GNRC_SIXLOWPAN_CONFIG_H */
|
|
|
|
/** @} */
|