mirror of
https://github.com/RIOT-OS/RIOT.git
synced 2024-12-29 04:50:03 +01:00
113 lines
2.5 KiB
C
113 lines
2.5 KiB
C
|
/*
|
||
|
* Copyright (C) 2015 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.
|
||
|
*/
|
||
|
|
||
|
/**
|
||
|
* @defgroup net_gnrc_tcp TCP
|
||
|
* @ingroup net_gnrc
|
||
|
* @brief RIOT's tcp implementation for the gnrc stack
|
||
|
*
|
||
|
* @{
|
||
|
*
|
||
|
* @file
|
||
|
* @brief Defines and Macros for TCP option handling
|
||
|
*
|
||
|
* @author Simon Brummer <brummer.simon@googlemail.com>
|
||
|
*/
|
||
|
|
||
|
#ifndef GNRC_TCP_INTERNAL_OPTION_H_
|
||
|
#define GNRC_TCP_INTERNAL_OPTION_H_
|
||
|
|
||
|
#include "helper.h"
|
||
|
#include "net/gnrc/tcp.h"
|
||
|
#include "net/gnrc/tcp/hdr.h"
|
||
|
|
||
|
#ifdef __cplusplus
|
||
|
extern "C" {
|
||
|
#endif
|
||
|
|
||
|
/**
|
||
|
* @brief TCP Option field boundries
|
||
|
* @{
|
||
|
*/
|
||
|
#define OPTION_OFFSET_BASE (0x5)
|
||
|
#define OPTION_OFFSET_MAX (0xF)
|
||
|
/** @} */
|
||
|
|
||
|
/**
|
||
|
* @brief Extract offset value from offet and ctl bit field.
|
||
|
*/
|
||
|
#define GET_OFFSET( x ) (((x) & MSK_OFFSET) >> 12)
|
||
|
|
||
|
/**
|
||
|
* @brief TCP Option Kind Field Values
|
||
|
* @{
|
||
|
*/
|
||
|
#define OPT_KIND_EOL (00) /**< End of List */
|
||
|
#define OPT_KIND_NOP (01) /**< No Operatrion */
|
||
|
#define OPT_KIND_MSS (02) /**< Maximum Segment Size */
|
||
|
/** @} */
|
||
|
|
||
|
/**
|
||
|
* @brief TCP Option Length Field Values
|
||
|
* @{
|
||
|
*/
|
||
|
#define OPT_LENGTH_MSS (04) /**< MSS Option Size is 4 byte */
|
||
|
/** @} */
|
||
|
|
||
|
/**
|
||
|
* @brief Extract kind field value from 4-byte option field
|
||
|
*/
|
||
|
#define OPT_GET_KIND( x ) (((x) & 0xFF000000) >> 24)
|
||
|
|
||
|
/**
|
||
|
* @brief Extract length field value from 4-byte option field
|
||
|
*/
|
||
|
#define OPT_GET_LENGTH( x ) (((x) & 0x00FF0000) >> 16)
|
||
|
|
||
|
/**
|
||
|
* @brief Extract two byte option value from 4-byte option field
|
||
|
*/
|
||
|
#define OPT_GET_VAL_2B( x ) (((x) & 0x0000FFFF))
|
||
|
|
||
|
/**
|
||
|
* @brief Helper Function to build the MSS Option
|
||
|
*
|
||
|
* @param[in] mss tcp header to be checked
|
||
|
*
|
||
|
* @return Valid MSS Option.
|
||
|
*/
|
||
|
uint32_t _option_build_mss(uint16_t mss);
|
||
|
|
||
|
/**
|
||
|
* @brief Helper Function to build the combined option and control flag field
|
||
|
*
|
||
|
* @param[in] nopts Number of Options
|
||
|
* @param[in] ctl Control Flags
|
||
|
*
|
||
|
* @return Valid option size and control field.
|
||
|
*/
|
||
|
uint16_t _option_build_offset_control(uint16_t nopts, uint16_t ctl);
|
||
|
|
||
|
/**
|
||
|
* @brief Parses options of a given tcp-header pktsnip.
|
||
|
*
|
||
|
* @param[out] tcb transmission control block to memorize options.
|
||
|
* @param[in] hdr tcp header to be checked
|
||
|
*
|
||
|
* @return Zero on success
|
||
|
* @return A negative value on error
|
||
|
*/
|
||
|
int _option_parse(gnrc_tcp_tcb_t* tcb, tcp_hdr_t *hdr);
|
||
|
|
||
|
#ifdef __cplusplus
|
||
|
}
|
||
|
#endif
|
||
|
|
||
|
#endif /* GNRC_TCP_INTERNAL_OPTION_H_*/
|
||
|
/** @} */
|