2010-11-01 07:13:54 +01:00
|
|
|
/** @file
|
|
|
|
Tcp option's routine header file.
|
|
|
|
|
2018-08-16 02:58:04 +02:00
|
|
|
Copyright (c) 2009 - 2018, Intel Corporation. All rights reserved.<BR>
|
2010-11-01 07:13:54 +01:00
|
|
|
|
2019-04-04 01:06:13 +02:00
|
|
|
SPDX-License-Identifier: BSD-2-Clause-Patent
|
2010-11-01 07:13:54 +01:00
|
|
|
|
|
|
|
**/
|
|
|
|
|
|
|
|
#ifndef _TCP_OPTION_H_
|
|
|
|
#define _TCP_OPTION_H_
|
|
|
|
|
|
|
|
//
|
|
|
|
// Supported TCP option types and their length.
|
|
|
|
//
|
|
|
|
#define TCP_OPTION_EOP 0 ///< End Of oPtion
|
|
|
|
#define TCP_OPTION_NOP 1 ///< No-Option.
|
|
|
|
#define TCP_OPTION_MSS 2 ///< Maximum Segment Size
|
|
|
|
#define TCP_OPTION_WS 3 ///< Window scale
|
|
|
|
#define TCP_OPTION_TS 8 ///< Timestamp
|
|
|
|
#define TCP_OPTION_MSS_LEN 4 ///< Length of MSS option
|
|
|
|
#define TCP_OPTION_WS_LEN 3 ///< Length of window scale option
|
|
|
|
#define TCP_OPTION_TS_LEN 10 ///< Length of timestamp option
|
|
|
|
#define TCP_OPTION_WS_ALIGNED_LEN 4 ///< Length of window scale option, aligned
|
|
|
|
#define TCP_OPTION_TS_ALIGNED_LEN 12 ///< Length of timestamp option, aligned
|
|
|
|
|
|
|
|
//
|
|
|
|
// recommend format of timestamp window scale
|
|
|
|
// option for fast process.
|
|
|
|
//
|
|
|
|
#define TCP_OPTION_TS_FAST ((TCP_OPTION_NOP << 24) | \
|
|
|
|
(TCP_OPTION_NOP << 16) | \
|
|
|
|
(TCP_OPTION_TS << 8) | \
|
|
|
|
(TCP_OPTION_TS_LEN))
|
|
|
|
|
|
|
|
#define TCP_OPTION_WS_FAST ((TCP_OPTION_NOP << 24) | \
|
|
|
|
(TCP_OPTION_WS << 16) | \
|
|
|
|
(TCP_OPTION_WS_LEN << 8))
|
|
|
|
|
|
|
|
#define TCP_OPTION_MSS_FAST ((TCP_OPTION_MSS << 24) | (TCP_OPTION_MSS_LEN << 16))
|
|
|
|
|
|
|
|
//
|
|
|
|
// Other misc definations
|
|
|
|
//
|
|
|
|
#define TCP_OPTION_RCVD_MSS 0x01
|
|
|
|
#define TCP_OPTION_RCVD_WS 0x02
|
|
|
|
#define TCP_OPTION_RCVD_TS 0x04
|
|
|
|
#define TCP_OPTION_MAX_WS 14 ///< Maxium window scale value
|
|
|
|
#define TCP_OPTION_MAX_WIN 0xffff ///< Max window size in TCP header
|
|
|
|
|
|
|
|
///
|
|
|
|
/// The structure to store the parse option value.
|
|
|
|
/// ParseOption only parses the options, doesn't process them.
|
|
|
|
///
|
|
|
|
typedef struct _TCP_OPTION {
|
|
|
|
UINT8 Flag; ///< Flag such as TCP_OPTION_RCVD_MSS
|
|
|
|
UINT8 WndScale; ///< The WndScale received
|
|
|
|
UINT16 Mss; ///< The Mss received
|
|
|
|
UINT32 TSVal; ///< The TSVal field in a timestamp option
|
|
|
|
UINT32 TSEcr; ///< The TSEcr field in a timestamp option
|
|
|
|
} TCP_OPTION;
|
|
|
|
|
|
|
|
/**
|
|
|
|
Compute the window scale value according to the given buffer size.
|
|
|
|
|
|
|
|
@param[in] Tcb Pointer to the TCP_CB of this TCP instance.
|
|
|
|
|
|
|
|
@return The scale value.
|
|
|
|
|
|
|
|
**/
|
|
|
|
UINT8
|
|
|
|
TcpComputeScale (
|
|
|
|
IN TCP_CB *Tcb
|
|
|
|
);
|
|
|
|
|
|
|
|
/**
|
|
|
|
Build the TCP option in three-way handshake.
|
|
|
|
|
|
|
|
@param[in] Tcb Pointer to the TCP_CB of this TCP instance.
|
|
|
|
@param[in] Nbuf Pointer to the buffer to store the options.
|
|
|
|
|
|
|
|
@return The total length of the TCP option field.
|
|
|
|
|
|
|
|
**/
|
|
|
|
UINT16
|
|
|
|
TcpSynBuildOption (
|
|
|
|
IN TCP_CB *Tcb,
|
|
|
|
IN NET_BUF *Nbuf
|
|
|
|
);
|
|
|
|
|
|
|
|
/**
|
|
|
|
Build the TCP option in synchronized states.
|
|
|
|
|
|
|
|
@param[in] Tcb Pointer to the TCP_CB of this TCP instance.
|
|
|
|
@param[in] Nbuf Pointer to the buffer to store the options.
|
|
|
|
|
|
|
|
@return The total length of the TCP option field.
|
|
|
|
|
|
|
|
**/
|
|
|
|
UINT16
|
|
|
|
TcpBuildOption (
|
|
|
|
IN TCP_CB *Tcb,
|
|
|
|
IN NET_BUF *Nbuf
|
|
|
|
);
|
|
|
|
|
|
|
|
/**
|
|
|
|
Parse the supported options.
|
|
|
|
|
|
|
|
@param[in] Tcp Pointer to the TCP_CB of this TCP instance.
|
|
|
|
@param[in, out] Option Pointer to the TCP_OPTION used to store the
|
|
|
|
successfully pasrsed options.
|
|
|
|
|
|
|
|
@retval 0 The options successfully pasrsed.
|
|
|
|
@retval -1 Ilegal option was found.
|
|
|
|
|
|
|
|
**/
|
|
|
|
INTN
|
|
|
|
TcpParseOption (
|
|
|
|
IN TCP_HEAD *Tcp,
|
|
|
|
IN OUT TCP_OPTION *Option
|
|
|
|
);
|
|
|
|
|
|
|
|
#endif
|