1
0
mirror of https://github.com/RIOT-OS/RIOT.git synced 2025-01-15 16:32:45 +01:00
RIOT/sys/include/net/tcp.h
Sören Tempel e5503d62bf gnrc_tcp: check if option length field is present before accessing it
TCP options have up to three fields (kind, length, value). The
current code only checks for the presence of the first field. Before
accessing the second field (length) the code must ensure that a length
field is even present.
2019-09-16 21:13:51 +02:00

92 lines
2.4 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.
*/
/**
* @defgroup net_tcp TCP
* @ingroup net
* @brief Provides TCP header and helper functions
*
* @{
*
* @file
* @brief TCP header and helper functions
*
* @author Simon Brummer <simon.brummer@posteo.de>
*/
#ifndef NET_TCP_H
#define NET_TCP_H
#include "byteorder.h"
#ifdef __cplusplus
extern "C" {
#endif
/**
* @brief TCP offset value boundaries.
* @{
*/
#define TCP_HDR_OFFSET_MIN (0x05)
#define TCP_HDR_OFFSET_MAX (0x0F)
/** @} */
/**
* @brief TCP Option "Kind"-field defines.
* @{
*/
#define TCP_OPTION_KIND_EOL (0x00) /**< "End of List"-Option */
#define TCP_OPTION_KIND_NOP (0x01) /**< "No Operation"-Option */
#define TCP_OPTION_KIND_MSS (0x02) /**< "Maximum Segment Size"-Option */
/** @} */
/**
* @brief TCP option "length"-field values.
* @{
*/
#define TCP_OPTION_LENGTH_MIN (2U) /**< Mimimum amount of bytes needed for an option with a length field */
#define TCP_OPTION_LENGTH_MSS (0x04) /**< MSS Option Size always 4 */
/** @} */
/**
* @brief TCP header definition
*/
typedef struct __attribute__((packed)) {
network_uint16_t src_port; /**< Source port, in network byte order */
network_uint16_t dst_port; /**< Destination port, in network byte order */
network_uint32_t seq_num; /**< Sequence number, in network byte order */
network_uint32_t ack_num; /**< Acknowledgement number, in network byte order */
network_uint16_t off_ctl; /**< Data Offset and control Bits in network byte order */
network_uint16_t window; /**< Window, in network byte order */
network_uint16_t checksum; /**< Checksum, in network byte order */
network_uint16_t urgent_ptr; /**< Urgent pointer, in network byte order */
} tcp_hdr_t;
/**
* @brief TCP option field helper structure
*/
typedef struct __attribute__((packed)) {
uint8_t kind; /**< TCP options "Kind" field */
uint8_t length; /**< TCP options "Length" field */
uint8_t value[]; /**< TCP options "Value" field */
} tcp_hdr_opt_t;
/**
* @brief Print the given TCP header to STDOUT
*
* @param[in] hdr TCP header to print
*/
void tcp_hdr_print(tcp_hdr_t *hdr);
#ifdef __cplusplus
}
#endif
#endif /* NET_TCP_H */
/** @} */