1
0
mirror of https://github.com/RIOT-OS/RIOT.git synced 2025-01-18 12:52:44 +01:00
RIOT/sys/net/gnrc/transport_layer/tcp/internal/option.h
2017-01-22 09:27:58 +01:00

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_*/
/** @} */