mirror of
https://github.com/RIOT-OS/RIOT.git
synced 2024-12-29 04:50:03 +01:00
177 lines
4.2 KiB
C
177 lines
4.2 KiB
C
/*
|
|
* Copyright (C) 2015-2017 Simon Brummer
|
|
*
|
|
* 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.
|
|
*/
|
|
|
|
/**
|
|
* @ingroup net_gnrc_tcp
|
|
*
|
|
* @{
|
|
*
|
|
* @file
|
|
* @brief GNRC TCP configuration
|
|
*
|
|
* @author Simon Brummer <simon.brummer@posteo.de>
|
|
*/
|
|
|
|
#ifndef NET_GNRC_TCP_CONFIG_H
|
|
#define NET_GNRC_TCP_CONFIG_H
|
|
|
|
#include "timex.h"
|
|
|
|
#ifdef __cplusplus
|
|
extern "C" {
|
|
#endif
|
|
|
|
/**
|
|
* @defgroup net_gnrc_tcp_conf GNRC TCP compile configurations
|
|
* @ingroup net_gnrc_conf
|
|
*
|
|
* ## Calculating RTO
|
|
* To calculate retransmission timeout (RTO), Round Trip Time (RTT) needs to be
|
|
* taken into account. SRTT (smoothed round-trip time) and RTTVAR (round-trip
|
|
* time variation) are hence calculated as follows:
|
|
*
|
|
* RTTVAR <- (1 - beta) * RTTVAR + beta * |SRTT - R'|
|
|
* SRTT <- (1 - alpha) * SRTT + alpha * R'
|
|
*
|
|
* where alpha ( 1 / @ref CONFIG_GNRC_TCP_RTO_A_DIV ) and beta
|
|
* ( 1 / @ref CONFIG_GNRC_TCP_RTO_B_DIV) are constants, and R' is the
|
|
* instantaneous RTT value.
|
|
*
|
|
* RTO is then calculated as :
|
|
*
|
|
* RTO <- SRTT + max (G, K*RTTVAR)
|
|
*
|
|
* where K is a constant, and G is clock granularity in seconds
|
|
* ( @ref CONFIG_GNRC_TCP_RTO_GRANULARITY).
|
|
* For more information refer to https://tools.ietf.org/html/rfc6298
|
|
* @{
|
|
*/
|
|
/**
|
|
* @brief Timeout duration for user calls. Default is 2 minutes.
|
|
*/
|
|
#ifndef CONFIG_GNRC_TCP_CONNECTION_TIMEOUT_DURATION
|
|
#define CONFIG_GNRC_TCP_CONNECTION_TIMEOUT_DURATION (120U * US_PER_SEC)
|
|
#endif
|
|
|
|
/**
|
|
* @brief Maximum segment lifetime (MSL). Default is 30 seconds.
|
|
*/
|
|
#ifndef CONFIG_GNRC_TCP_MSL
|
|
#define CONFIG_GNRC_TCP_MSL (30U * US_PER_SEC)
|
|
#endif
|
|
|
|
/**
|
|
* @brief Maximum Segment Size (MSS).
|
|
*/
|
|
#ifndef CONFIG_GNRC_TCP_MSS
|
|
#ifdef MODULE_GNRC_IPV6
|
|
#define CONFIG_GNRC_TCP_MSS (1220U) /**< If IPv6 is used. Get MSS = 1280 - IPv6 Hdr - TCP Hdr = 1220 */
|
|
#else
|
|
#define CONFIG_GNRC_TCP_MSS (576U) /**< Default MSS */
|
|
#endif
|
|
#endif
|
|
|
|
/**
|
|
* @brief MSS Multiplicator = Number of MSS sized packets stored in receive buffer
|
|
*/
|
|
#ifndef CONFIG_GNRC_TCP_MSS_MULTIPLICATOR
|
|
#define CONFIG_GNRC_TCP_MSS_MULTIPLICATOR (1U)
|
|
#endif
|
|
|
|
/**
|
|
* @brief Default receive window size
|
|
*/
|
|
#ifndef GNRC_TCP_DEFAULT_WINDOW
|
|
#define GNRC_TCP_DEFAULT_WINDOW (CONFIG_GNRC_TCP_MSS * CONFIG_GNRC_TCP_MSS_MULTIPLICATOR)
|
|
#endif
|
|
|
|
/**
|
|
* @brief Number of preallocated receive buffers.
|
|
*
|
|
* This value determines how many parallel TCP connections can be active at the
|
|
* same time.
|
|
*/
|
|
#ifndef CONFIG_GNRC_TCP_RCV_BUFFERS
|
|
#define CONFIG_GNRC_TCP_RCV_BUFFERS (1U)
|
|
#endif
|
|
|
|
/**
|
|
* @brief Default receive buffer size
|
|
*/
|
|
#ifndef GNRC_TCP_RCV_BUF_SIZE
|
|
#define GNRC_TCP_RCV_BUF_SIZE (GNRC_TCP_DEFAULT_WINDOW)
|
|
#endif
|
|
|
|
/**
|
|
* @brief Lower bound for RTO = 1 sec (see RFC 6298)
|
|
*
|
|
* @note Retransmission Timeout (RTO) determines how long TCP waits for
|
|
* acknowledgment (ACK) of transmitted segment. If the acknowledgment
|
|
* isn't received within this time it is considered lost.
|
|
*/
|
|
#ifndef CONFIG_GNRC_TCP_RTO_LOWER_BOUND
|
|
#define CONFIG_GNRC_TCP_RTO_LOWER_BOUND (1U * US_PER_SEC)
|
|
#endif
|
|
|
|
/**
|
|
* @brief Upper bound for RTO = 60 sec (see RFC 6298)
|
|
*/
|
|
#ifndef CONFIG_GNRC_TCP_RTO_UPPER_BOUND
|
|
#define CONFIG_GNRC_TCP_RTO_UPPER_BOUND (60U * US_PER_SEC)
|
|
#endif
|
|
|
|
/**
|
|
* @brief Assumes clock granularity for TCP of 10 ms (see RFC 6298)
|
|
*/
|
|
#ifndef CONFIG_GNRC_TCP_RTO_GRANULARITY
|
|
#define CONFIG_GNRC_TCP_RTO_GRANULARITY (10U * MS_PER_SEC)
|
|
#endif
|
|
|
|
/**
|
|
* @brief Alpha value for RTO calculation, default is 1/8
|
|
*/
|
|
#ifndef CONFIG_GNRC_TCP_RTO_A_DIV
|
|
#define CONFIG_GNRC_TCP_RTO_A_DIV (8U)
|
|
#endif
|
|
|
|
/**
|
|
* @brief Beta value for RTO calculation, default is 1/4
|
|
*/
|
|
#ifndef CONFIG_GNRC_TCP_RTO_B_DIV
|
|
#define CONFIG_GNRC_TCP_RTO_B_DIV (4U)
|
|
#endif
|
|
|
|
/**
|
|
* @brief K value for RTO calculation, default is 4
|
|
*/
|
|
#ifndef GNRC_TCP_RTO_K
|
|
#define GNRC_TCP_RTO_K (4U)
|
|
#endif
|
|
|
|
/**
|
|
* @brief Lower bound for the duration between probes
|
|
*/
|
|
#ifndef GNRC_TCP_PROBE_LOWER_BOUND
|
|
#define GNRC_TCP_PROBE_LOWER_BOUND (1U * US_PER_SEC)
|
|
#endif
|
|
|
|
/**
|
|
* @brief Upper bound for the duration between probes
|
|
*/
|
|
#ifndef GNRC_TCP_PROBE_UPPER_BOUND
|
|
#define GNRC_TCP_PROBE_UPPER_BOUND (60U * US_PER_SEC)
|
|
#endif
|
|
/** @} */
|
|
|
|
#ifdef __cplusplus
|
|
}
|
|
#endif
|
|
|
|
#endif /* NET_GNRC_TCP_CONFIG_H */
|
|
/** @} */
|