:orphan: .. index:: pair: group; TCP .. _doxid-group__tapi__tad__tcp: TCP === .. toctree:: :hidden: enum_tapi_tcp_mode_t.rst enum_tapi_tcp_protocol_mode_t.rst struct_tapi_tcp_reset_hack_t.rst struct_tcp4_message.rst struct_tcp_message_t.rst Overview ~~~~~~~~ Declarations of TAPI methods for raw-TCP CSAP. :ref:`More...` .. ref-code-block:: cpp :class: doxyrest-overview-code-block // typedefs typedef uint32_t :ref:`tapi_tcp_pos_t`; typedef struct :ref:`tcp_message_t` :target:`tcp_message_t`; typedef struct :ref:`tcp4_message` :target:`tcp4_message`; typedef void (*:ref:`tcp_callback`)( const tcp_message_t *pkt, void *userdata ); typedef void (*:target:`tcp4_callback`)( const tcp4_message *pkt, void *userdata ); typedef int :target:`tapi_tcp_handler_t`; // enums enum :ref:`tapi_tcp_mode_t`; enum :ref:`tapi_tcp_protocol_mode_t`; // structs struct :ref:`tapi_tcp_reset_hack_t`; struct :ref:`tcp4_message`; struct :ref:`tcp_message_t`; // global functions :ref:`te_errno` :ref:`tapi_tcp_add_csap_layer`(:ref:`asn_value`** csap_spec, int local_port, int remote_port); :ref:`te_errno` :ref:`tapi_tcp_ip4_eth_csap_create`(const char* ta_name, int sid, const char* eth_dev, unsigned int receive_mode, const uint8_t* loc_mac, const uint8_t* rem_mac, in_addr_t loc_addr, in_addr_t rem_addr, int loc_port, int rem_port, :ref:`csap_handle_t`* tcp_csap); :ref:`te_errno` :ref:`tapi_tcp_ip4_csap_create`(const char* ta_name, int sid, const char* ifname, in_addr_t loc_addr, in_addr_t rem_addr, int loc_port, int rem_port, :ref:`csap_handle_t`* tcp_csap); :ref:`te_errno` :ref:`tapi_tcp_ip4_eth_recv_start`(const char* ta_name, int sid, :ref:`csap_handle_t` csap, in_addr_t src_addr, in_addr_t dst_addr, int src_port, int dst_port, unsigned int timeout, unsigned int num, :ref:`rcf_trrecv_mode` mode); :ref:`te_errno` :ref:`tapi_tcp_ip4_pattern_unit`(in_addr_t src_addr, in_addr_t dst_addr, int src_port, int dst_port, :ref:`asn_value`** result_value); int :ref:`ndn_tcp4_message_to_plain`(:ref:`asn_value`* pkt, struct :ref:`tcp4_message`** tcp_msg); :ref:`tapi_tad_trrecv_cb_data`* :ref:`tapi_tcp_ip4_eth_trrecv_cb_data`(tcp4_callback callback, void* user_data); :ref:`te_errno` :ref:`ndn_tcp_message_to_plain`(:ref:`asn_value`* pkt, struct :ref:`tcp_message_t`** tcp_msg); :ref:`tapi_tad_trrecv_cb_data`* :ref:`tapi_tcp_ip_eth_trrecv_cb_data`(:ref:`tcp_callback` callback, void* user_data); :ref:`te_errno` :ref:`tapi_tcp_make_msg`(uint16_t src_port, uint16_t dst_port, :ref:`tapi_tcp_pos_t` seqn, :ref:`tapi_tcp_pos_t` ackn, bool syn_flag, bool ack_flag, uint8_t* msg); :ref:`te_errno` :ref:`tapi_tcp_pdu`(int src_port, int dst_port, :ref:`tapi_tcp_pos_t` seqn, :ref:`tapi_tcp_pos_t` ackn, bool syn_flag, bool ack_flag, :ref:`asn_value`** pdu); int :ref:`tapi_tcp_template_gen`(bool is_eth_pdu, bool force_ip6, :ref:`tapi_tcp_pos_t` seqn, :ref:`tapi_tcp_pos_t` ackn, bool syn_flag, bool ack_flag, uint8_t* data, size_t pld_len, :ref:`asn_value`** tmpl); int :ref:`tapi_tcp_template`(bool force_ip6, :ref:`tapi_tcp_pos_t` seqn, :ref:`tapi_tcp_pos_t` ackn, bool syn_flag, bool ack_flag, uint8_t* data, size_t pld_len, :ref:`asn_value`** tmpl); int :ref:`tapi_tcp_pattern_gen`(bool is_eth_pdu, :ref:`tapi_tcp_pos_t` seqn, :ref:`tapi_tcp_pos_t` ackn, bool syn_flag, bool ack_flag, :ref:`asn_value`** pattern); int :ref:`tapi_tcp_pattern`(:ref:`tapi_tcp_pos_t` seqn, :ref:`tapi_tcp_pos_t` ackn, bool syn_flag, bool ack_flag, :ref:`asn_value`** pattern); int :ref:`tapi_tcp_ip_segment_pattern_gen`(bool is_eth_layer, bool force_ip6, :ref:`tapi_tcp_pos_t` seqn, :ref:`tapi_tcp_pos_t` ackn, bool urg_flag, bool ack_flag, bool psh_flag, bool rst_flag, bool syn_flag, bool fin_flag, :ref:`asn_value`** pattern); int :ref:`tapi_tcp_ip_pattern_gen`(bool is_eth_layer, bool force_ip6, :ref:`tapi_tcp_pos_t` seqn, :ref:`tapi_tcp_pos_t` ackn, bool syn_flag, bool ack_flag, :ref:`asn_value`** pattern); int :ref:`tapi_tcp_segment_pattern`(:ref:`tapi_tcp_pos_t` seqn, :ref:`tapi_tcp_pos_t` ackn, bool urg_flag, bool ack_flag, bool psh_flag, bool rst_flag, bool syn_flag, bool fin_flag, :ref:`asn_value`** pattern); int :ref:`tapi_tcp_ip_segment_pattern`(bool force_ip6, :ref:`tapi_tcp_pos_t` seqn, :ref:`tapi_tcp_pos_t` ackn, bool urg_flag, bool ack_flag, bool psh_flag, bool rst_flag, bool syn_flag, bool fin_flag, :ref:`asn_value`** pattern); int :ref:`tapi_tcp_segment_pdu`(int src_port, int dst_port, :ref:`tapi_tcp_pos_t` seqn, :ref:`tapi_tcp_pos_t` ackn, bool urg_flag, bool ack_flag, bool psh_flag, bool rst_flag, bool syn_flag, bool fin_flag, :ref:`asn_value`** pdu); int :ref:`tapi_tcp_ip_segment_template_gen`(bool is_eth_layer, bool force_ip6, :ref:`tapi_tcp_pos_t` seqn, :ref:`tapi_tcp_pos_t` ackn, bool urg_flag, bool ack_flag, bool psh_flag, bool rst_flag, bool syn_flag, bool fin_flag, uint8_t* data, size_t pld_len, :ref:`asn_value`** tmpl); int :ref:`tapi_tcp_ip_template_gen`(bool is_eth_layer, bool force_ip6, :ref:`tapi_tcp_pos_t` seqn, :ref:`tapi_tcp_pos_t` ackn, bool syn_flag, bool ack_flag, uint8_t* data, size_t pld_len, :ref:`asn_value`** tmpl); int :ref:`tapi_tcp_segment_template`(:ref:`tapi_tcp_pos_t` seqn, :ref:`tapi_tcp_pos_t` ackn, bool urg_flag, bool ack_flag, bool psh_flag, bool rst_flag, bool syn_flag, bool fin_flag, uint8_t* data, size_t pld_len, :ref:`asn_value`** tmpl); int :ref:`tapi_tcp_ip_segment_template`(bool force_ip6, :ref:`tapi_tcp_pos_t` seqn, :ref:`tapi_tcp_pos_t` ackn, bool urg_flag, bool ack_flag, bool psh_flag, bool rst_flag, bool syn_flag, bool fin_flag, uint8_t* data, size_t pld_len, :ref:`asn_value`** tmpl); :ref:`te_errno` :ref:`tapi_tcp_create_conn`(const char* agt, const struct sockaddr* local_addr, const struct sockaddr* remote_addr, const char* local_iface, const uint8_t* local_mac, const uint8_t* remote_mac, int window, tapi_tcp_handler_t* handler); :ref:`te_errno` :ref:`tapi_tcp_start_conn`(tapi_tcp_handler_t handler, :ref:`tapi_tcp_mode_t` mode); :ref:`te_errno` :ref:`tapi_tcp_init_connection`(const char* agt, :ref:`tapi_tcp_mode_t` mode, const struct sockaddr* local_addr, const struct sockaddr* remote_addr, const char* local_iface, const uint8_t* local_mac, const uint8_t* remote_mac, int window, tapi_tcp_handler_t* handler); int :ref:`tapi_tcp_init_connection_enc`(const char* agt, :ref:`tapi_tcp_mode_t` mode, const struct sockaddr* local_addr, const struct sockaddr* remote_addr, const char* local_iface, const uint8_t* local_mac, const uint8_t* remote_mac, int window, bool enc_vlan, bool enc_snap, tapi_tcp_handler_t* handler); int :ref:`tapi_tcp_destroy_connection`(tapi_tcp_handler_t handler); int :ref:`tapi_tcp_wait_open`(tapi_tcp_handler_t handler, int timeout); int :ref:`tapi_tcp_wait_msg`(tapi_tcp_handler_t handler, int timeout); int :ref:`tapi_tcp_send_fin`(tapi_tcp_handler_t handler, int timeout); int :ref:`tapi_tcp_send_fin_ack`(tapi_tcp_handler_t handler, int timeout); int :ref:`tapi_tcp_send_rst`(tapi_tcp_handler_t handler); int :ref:`tapi_tcp_send_msg`(tapi_tcp_handler_t handler, uint8_t* payload, size_t len, :ref:`tapi_tcp_protocol_mode_t` seq_mode, :ref:`tapi_tcp_pos_t` seqn, :ref:`tapi_tcp_protocol_mode_t` ack_mode, :ref:`tapi_tcp_pos_t` ackn, :ref:`tapi_ip_frag_spec`* frags, size_t frag_num); int :ref:`tapi_tcp_conn_template`(tapi_tcp_handler_t handler, uint8_t* payload, size_t len, :ref:`asn_value`** tmpl); int :ref:`tapi_tcp_send_template`(tapi_tcp_handler_t handler, const :ref:`asn_value`* template, :ref:`rcf_call_mode_t` blk_mode); int :ref:`tapi_tcp_recv_msg_gen`(tapi_tcp_handler_t handler, int timeout, :ref:`tapi_tcp_protocol_mode_t` ack_mode, uint8_t* buffer, size_t* len, :ref:`tapi_tcp_pos_t`* seqn_got, :ref:`tapi_tcp_pos_t`* ackn_got, uint8_t* flags, bool no_unexp_seqn); int :ref:`tapi_tcp_recv_msg`(tapi_tcp_handler_t handler, int timeout, :ref:`tapi_tcp_protocol_mode_t` ack_mode, uint8_t* buffer, size_t* len, :ref:`tapi_tcp_pos_t`* seqn_got, :ref:`tapi_tcp_pos_t`* ackn_got, uint8_t* flags); int :ref:`tapi_tcp_recv_data`(tapi_tcp_handler_t handler, int time2wait, :ref:`tapi_tcp_protocol_mode_t` ack_mode, :ref:`te_dbuf`* data); int :ref:`tapi_tcp_send_ack`(tapi_tcp_handler_t handler, :ref:`tapi_tcp_pos_t` ackn); int :ref:`tapi_tcp_ack_all`(tapi_tcp_handler_t handler); :ref:`tapi_tcp_pos_t` :ref:`tapi_tcp_first_seqn_got`(tapi_tcp_handler_t handler); :ref:`tapi_tcp_pos_t` :ref:`tapi_tcp_last_seqn_got`(tapi_tcp_handler_t handler); :ref:`tapi_tcp_pos_t` :ref:`tapi_tcp_last_ackn_got`(tapi_tcp_handler_t handler); :ref:`tapi_tcp_pos_t` :ref:`tapi_tcp_first_seqn_sent`(tapi_tcp_handler_t handler); :ref:`tapi_tcp_pos_t` :ref:`tapi_tcp_last_seqn_sent`(tapi_tcp_handler_t handler); :ref:`tapi_tcp_pos_t` :ref:`tapi_tcp_last_ackn_sent`(tapi_tcp_handler_t handler); size_t :ref:`tapi_tcp_last_win_got`(tapi_tcp_handler_t handler); bool :ref:`tapi_tcp_fin_got`(tapi_tcp_handler_t handler); bool :ref:`tapi_tcp_rst_got`(tapi_tcp_handler_t handler); :ref:`tapi_tcp_pos_t` :ref:`tapi_tcp_next_seqn`(tapi_tcp_handler_t handler); :ref:`tapi_tcp_pos_t` :ref:`tapi_tcp_next_ackn`(tapi_tcp_handler_t handler); int :ref:`tapi_tcp_update_sent_seq`(tapi_tcp_handler_t handler, size_t new_sent_len); int :ref:`tapi_tcp_get_window`(tapi_tcp_handler_t handler); :ref:`te_errno` :ref:`tapi_tcp_set_window`(tapi_tcp_handler_t handler, int window); int :ref:`tapi_tcp_reset_hack_init`(const char* ta_name, int session, const char* iface, bool dir_out, :ref:`tapi_tcp_reset_hack_t`* context); int :ref:`tapi_tcp_reset_hack_catch`(const char* ta_name, int session, :ref:`tapi_tcp_reset_hack_t`* context); int :ref:`tapi_tcp_reset_hack_send`(const char* ta_name, int session, :ref:`tapi_tcp_reset_hack_t`* context, size_t received, size_t sent); int :ref:`tapi_tcp_reset_hack_clear`(const char* ta_name, int session, :ref:`tapi_tcp_reset_hack_t`* context); :ref:`te_errno` :ref:`tapi_tcp_ip6_eth_csap_create`(const char* ta_name, int sid, const char* eth_dev, unsigned int receive_mode, const uint8_t* loc_mac, const uint8_t* rem_mac, const uint8_t* loc_addr, const uint8_t* rem_addr, int loc_port, int rem_port, :ref:`csap_handle_t`* tcp_csap); :ref:`csap_handle_t` :ref:`tapi_tcp_conn_snd_csap`(tapi_tcp_handler_t handler); :ref:`csap_handle_t` :ref:`tapi_tcp_conn_rcv_csap`(tapi_tcp_handler_t handler); int :ref:`tapi_tcp_update_sent_ack`(tapi_tcp_handler_t handler, size_t ack); int :ref:`tapi_tcp_wait_packet`(tapi_tcp_handler_t handler, int timeout); int :ref:`tapi_tcp_get_packets`(tapi_tcp_handler_t handler); :ref:`te_errno` :ref:`tapi_tcp_conn_enable_ts`(tapi_tcp_handler_t handler, bool enable, uint32_t start_value); :ref:`te_errno` :ref:`tapi_tcp_conn_get_ts`(tapi_tcp_handler_t handler, bool* enabled, bool* dst_enabled, uint32_t* ts_value, uint32_t* last_ts_sent, uint32_t* last_ts_got, uint32_t* ts_to_echo, uint32_t* last_ts_echo_sent, uint32_t* last_ts_echo_got); :ref:`te_errno` :ref:`tapi_tcp_get_ts_opt`(const :ref:`asn_value`* val, uint32_t* ts_value, uint32_t* ts_echo); :ref:`te_errno` :ref:`tapi_tcp_set_ts_opt`(:ref:`asn_value`* val, uint32_t ts_value, uint32_t ts_echo); int :ref:`tapi_tcp_compare_seqn`(uint32_t seqn1, uint32_t seqn2); :ref:`te_errno` :ref:`tapi_tcp_ip_eth_csap_create`(const char* ta_name, int sid, const char* eth_dev, unsigned int receive_mode, const uint8_t* loc_mac, const uint8_t* rem_mac, int ip_family, const void* loc_addr, const void* rem_addr, int loc_port, int rem_port, :ref:`csap_handle_t`* tcp_csap); :ref:`te_errno` :ref:`tapi_tcp_get_hdrs_payload_len`(:ref:`asn_value`* pkt, unsigned int* hdrs_len, unsigned int* pld_len); // macros #define :ref:`TAPI_TCP_DEF_WINDOW` #define :ref:`TAPI_TCP_ZERO_WINDOW` #define :target:`TCP_ACK_FLAG` #define :target:`TCP_CWR_FLAG` #define :target:`TCP_ECE_FLAG` #define :target:`TCP_FIN_FLAG` #define :target:`TCP_PSH_FLAG` #define :target:`TCP_RST_FLAG` #define :target:`TCP_SYN_FLAG` #define :target:`TCP_URG_FLAG` .. _details-group__tapi__tad__tcp: Detailed Documentation ~~~~~~~~~~~~~~~~~~~~~~ Declarations of TAPI methods for raw-TCP CSAP. Copyright (C) 2004-2022 OKTET Labs Ltd. All rights reserved. Typedefs -------- .. index:: pair: typedef; tapi_tcp_pos_t .. _doxid-group__tapi__tad__tcp_1gaf11249a289e0daac9c297245863d52dd: .. ref-code-block:: cpp :class: doxyrest-title-code-block typedef uint32_t tapi_tcp_pos_t Type for SEQ and ACK numbers (host byte order). .. index:: pair: typedef; tcp_callback .. _doxid-group__tapi__tad__tcp_1ga1242c83ebe0ed610f5413d6e3723eead: .. ref-code-block:: cpp :class: doxyrest-title-code-block typedef void (*tcp_callback)( const tcp_message_t *pkt, void *userdata ) Callback types for receiving data in TCP connection. .. rubric:: Parameters: .. list-table:: :widths: 20 80 * - pkt - Received TCP datagram. After return from this callback memory block under this datagram will be freed. * - userdata - Parameter, provided by the caller. Global Functions ---------------- .. index:: pair: function; tapi_tcp_add_csap_layer .. _doxid-group__tapi__tad__tcp_1gae9f8eddfd7bd594e0a3723212218aa15: .. ref-code-block:: cpp :class: doxyrest-title-code-block :ref:`te_errno` tapi_tcp_add_csap_layer(:ref:`asn_value`** csap_spec, int local_port, int remote_port) Add TCP layer in CSAP specification. .. rubric:: Parameters: .. list-table:: :widths: 20 80 * - csap_spec - Location of CSAP specification pointer. * - local_port - Default local port in network byte order or -1 to keep unspecified * - remote_port - Default remote port in network byte order or -1 to keep unspecified * - Status - code. .. index:: pair: function; tapi_tcp_ip4_eth_csap_create .. _doxid-group__tapi__tad__tcp_1ga4170174a26d6c4ae03c7745ff33be4bf: .. ref-code-block:: cpp :class: doxyrest-title-code-block :ref:`te_errno` tapi_tcp_ip4_eth_csap_create(const char* ta_name, int sid, const char* eth_dev, unsigned int receive_mode, const uint8_t* loc_mac, const uint8_t* rem_mac, in_addr_t loc_addr, in_addr_t rem_addr, int loc_port, int rem_port, :ref:`csap_handle_t`* tcp_csap) Creates 'tcp.ip4.eth' CSAP. .. rubric:: Parameters: .. list-table:: :widths: 20 80 * - ta_name - Test Agent name * - sid - RCF SID * - eth_dev - Name of Ethernet interface * - receive_mode - Bitmask with receive mode, see 'enum tad_eth_recv_mode' in ``tad_common.h``. Use TAD_ETH_RECV_DEF by default. * - loc_mac - Local MAC address (or NULL) * - rem_mac - Remote MAC address (or NULL) * - loc_addr - Local IP address in network order or htonl(INADDR_ANY) * - rem_addr - Remote IP address in network order or htonl(INADDR_ANY) * - loc_port - Local TCP port in network byte order or -1 * - rem_port - Remote TCP port in network byte order or -1 * - tcp_csap - Location for the IPv4 CSAP handle (OUT) .. rubric:: Returns: Status of the operation .. index:: pair: function; tapi_tcp_ip4_csap_create .. _doxid-group__tapi__tad__tcp_1gab3a56dece938495a288916029f447ce2: .. ref-code-block:: cpp :class: doxyrest-title-code-block :ref:`te_errno` tapi_tcp_ip4_csap_create(const char* ta_name, int sid, const char* ifname, in_addr_t loc_addr, in_addr_t rem_addr, int loc_port, int rem_port, :ref:`csap_handle_t`* tcp_csap) Creates 'tcp.ip4' CSAP. .. rubric:: Parameters: .. list-table:: :widths: 20 80 * - ta_name - Test Agent name * - sid - RCF SID * - ifname - Interface name * - loc_addr - Local IP address in network order or htonl(INADDR_ANY) * - rem_addr - Remote IP address in network order or htonl(INADDR_ANY) * - loc_port - Local TCP port in network byte order or -1 * - rem_port - Remote TCP port in network byte order or -1 * - tcp_csap - Location for the IPv4 CSAP handle (OUT) .. rubric:: Returns: Status of the operation .. index:: pair: function; tapi_tcp_ip4_eth_recv_start .. _doxid-group__tapi__tad__tcp_1ga5362351376e35f5bfc00852178a97dd9: .. ref-code-block:: cpp :class: doxyrest-title-code-block :ref:`te_errno` tapi_tcp_ip4_eth_recv_start(const char* ta_name, int sid, :ref:`csap_handle_t` csap, in_addr_t src_addr, in_addr_t dst_addr, int src_port, int dst_port, unsigned int timeout, unsigned int num, :ref:`rcf_trrecv_mode` mode) Start receiving of IPv4 packets 'tcp.ip4.eth' CSAP, non-block method. Started receiving process may be controlled by rcf_ta_trrecv_get, rcf_ta_trrecv_wait, and rcf_ta_trrecv_stop methods. .. rubric:: Parameters: .. list-table:: :widths: 20 80 * - ta_name - Test Agent name * - sid - RCF SID * - csap - Identifier of CSAP * - src_addr - Source IP address in network order or htonl(INADDR_ANY) * - dst_addr - Destination IP address in network order or htonl(INADDR_ANY) * - src_port - Source TCP port in network byte order or -1 * - dst_port - Destination TCP port in network byte order or -1 * - timeout - Timeout of operation (in milliseconds, zero for infinitive) * - num - nubmer of packets to be caugth * - mode - Count received packets only or store packets to get to the test side later .. rubric:: Returns: Zero on success or error code. .. index:: pair: function; tapi_tcp_ip4_pattern_unit .. _doxid-group__tapi__tad__tcp_1ga6dafb7e2b39ae1591705a95472d214b9: .. ref-code-block:: cpp :class: doxyrest-title-code-block :ref:`te_errno` tapi_tcp_ip4_pattern_unit(in_addr_t src_addr, in_addr_t dst_addr, int src_port, int dst_port, :ref:`asn_value`** result_value) Prepare ASN Pattern-Unit value for 'tcp.ip4.eth' CSAP. .. rubric:: Parameters: .. list-table:: :widths: 20 80 * - src_addr - Source IP address in network order or htonl(INADDR_ANY) * - dst_addr - Destination IP address in network order or htonl(INADDR_ANY) * - src_port - Source TCP port in network byte order or -1 * - dst_port - Destination TCP port in network byte order or -1 * - result_value - Location for pointer to new ASN value .. rubric:: Returns: Zero on success or error code. .. index:: pair: function; ndn_tcp4_message_to_plain .. _doxid-group__tapi__tad__tcp_1gac0e82bbfa6729b11ca5ee65cf9f92d65: .. ref-code-block:: cpp :class: doxyrest-title-code-block int ndn_tcp4_message_to_plain(:ref:`asn_value`* pkt, struct :ref:`tcp4_message`** tcp_msg) Convert TCP.IPv4 datagram ASN.1 value to plain C structure. Function allocates memory under :ref:`dhcp_message ` data structure, which should be freed with dhcpv4_message_destroy .. rubric:: Parameters: .. list-table:: :widths: 20 80 * - pkt - ASN.1 value of type Raw-Packet. * - tcp_message - converted structure (OUT). .. rubric:: Returns: zero on success or error code. .. index:: pair: function; tapi_tcp_ip4_eth_trrecv_cb_data .. _doxid-group__tapi__tad__tcp_1ga487dbc7fd622f06dd3108a0719a05686: .. ref-code-block:: cpp :class: doxyrest-title-code-block :ref:`tapi_tad_trrecv_cb_data`* tapi_tcp_ip4_eth_trrecv_cb_data(tcp4_callback callback, void* user_data) Prepare callback data to be passed in tapi_tad_trrecv\_{wait,stop,get} to process received TCP packet. .. rubric:: Parameters: .. list-table:: :widths: 20 80 * - callback - Callback for TCP packets handling * - user_data - User-supplied data to be passed to *callback* .. rubric:: Returns: Pointer to allocated callback data or NULL. .. index:: pair: function; ndn_tcp_message_to_plain .. _doxid-group__tapi__tad__tcp_1gaddc4aeb135e92e3361ecdac62073c1e1: .. ref-code-block:: cpp :class: doxyrest-title-code-block :ref:`te_errno` ndn_tcp_message_to_plain(:ref:`asn_value`* pkt, struct :ref:`tcp_message_t`** tcp_msg) Convert TCP.IPv4 or TCP.IPv6 datagram ASN.1 value to plain C structure. Function allocates memory for tcp payload data. It should be freed with :ref:`tcp_message_t ` structure .. rubric:: Parameters: .. list-table:: :widths: 20 80 * - pkt - ASN.1 value of type Raw-Packet. * - tcp_msg - converted structure (OUT). .. rubric:: Returns: zero on success or error code. .. index:: pair: function; tapi_tcp_ip_eth_trrecv_cb_data .. _doxid-group__tapi__tad__tcp_1gaaed6ab84948b412f0e6c7872aab82b30: .. ref-code-block:: cpp :class: doxyrest-title-code-block :ref:`tapi_tad_trrecv_cb_data`* tapi_tcp_ip_eth_trrecv_cb_data(:ref:`tcp_callback` callback, void* user_data) Prepare callback data to be passed in tapi_tad_trrecv\_{wait,stop,get} to process received TCP packet. .. rubric:: Parameters: .. list-table:: :widths: 20 80 * - callback - Callback for TCP packets handling * - user_data - User-supplied data to be passed to *callback* .. rubric:: Returns: Pointer to allocated callback data or NULL. .. index:: pair: function; tapi_tcp_make_msg .. _doxid-group__tapi__tad__tcp_1ga56c7d2b744a0c4951abb5b9d57794f64: .. ref-code-block:: cpp :class: doxyrest-title-code-block :ref:`te_errno` tapi_tcp_make_msg(uint16_t src_port, uint16_t dst_port, :ref:`tapi_tcp_pos_t` seqn, :ref:`tapi_tcp_pos_t` ackn, bool syn_flag, bool ack_flag, uint8_t* msg) Correct fill TCP header by specified parameter values. .. rubric:: Parameters: .. list-table:: :widths: 20 80 * - src_port - source port in network byte order * - dst_port - destination port in network byte order * - seqn - sequence number in host byte order * - ackn - acknowledge number in host byte order * - syn_flag - syn flag * - ack_flag - ack flag * - msg - location where TCP header should be placed (OUT) .. rubric:: Returns: Status code. .. index:: pair: function; tapi_tcp_pdu .. _doxid-group__tapi__tad__tcp_1gaef6c4a14e85719ab5dafb7c78c9c9ddf: .. ref-code-block:: cpp :class: doxyrest-title-code-block :ref:`te_errno` tapi_tcp_pdu(int src_port, int dst_port, :ref:`tapi_tcp_pos_t` seqn, :ref:`tapi_tcp_pos_t` ackn, bool syn_flag, bool ack_flag, :ref:`asn_value`** pdu) Prepare TCP header PDU by specified parameter values. .. rubric:: Parameters: .. list-table:: :widths: 20 80 * - src_port - source TCP port in network byte order * - dst_port - destination TCP port in network byte order * - seqn - sequence number in host byte order * - ackn - acknowledge number in host byte order * - syn_flag - syn flag * - ack_flag - ack flag * - pdu - location for pointer to ASN value (OUT) .. rubric:: Returns: Status code. .. index:: pair: function; tapi_tcp_template_gen .. _doxid-group__tapi__tad__tcp_1ga77222acbdc2b0266ad2c12122cc4eeb4: .. ref-code-block:: cpp :class: doxyrest-title-code-block int tapi_tcp_template_gen(bool is_eth_pdu, bool force_ip6, :ref:`tapi_tcp_pos_t` seqn, :ref:`tapi_tcp_pos_t` ackn, bool syn_flag, bool ack_flag, uint8_t* data, size_t pld_len, :ref:`asn_value`** tmpl) Prepare Traffic-Template ASN value for 'tcp.ip(4\|6).eth' or 'tcp.ip(4\|6)' CSAP. It is assumed that all connection parameters (src/dst MACs, IP, and ports) are already set in CSAP. If it is not, fill there parameters in obtained traffic template explicitely. .. rubric:: Parameters: .. list-table:: :widths: 20 80 * - is_eth_pdu - if ``true`` include eth header PDU * - force_ip6 - ``true`` for IPv6 PDU ``false`` for IPv4 PDU * - seqn - sequence number in host byte order * - ackn - acknowledge number in host byte order * - syn_flag - syn flag * - ack_flag - ack flag * - data - pointer to data with payload or NULL * - pld_len - length of payload * - tmpl - location for pointer to ASN value (OUT) .. rubric:: Returns: Status code. .. index:: pair: function; tapi_tcp_template .. _doxid-group__tapi__tad__tcp_1ga6bdbae144dfc5c994a897f22c4ba5c2c: .. ref-code-block:: cpp :class: doxyrest-title-code-block int tapi_tcp_template(bool force_ip6, :ref:`tapi_tcp_pos_t` seqn, :ref:`tapi_tcp_pos_t` ackn, bool syn_flag, bool ack_flag, uint8_t* data, size_t pld_len, :ref:`asn_value`** tmpl) The same function as :ref:`tapi_tcp_template_gen() ` with is_eth_pdu parameter set to ``true``, so it prepares value for 'tcp.ip(4\|6).eth' CSAP. .. index:: pair: function; tapi_tcp_pattern_gen .. _doxid-group__tapi__tad__tcp_1gad5832491b5dea538c53ab060e0627730: .. ref-code-block:: cpp :class: doxyrest-title-code-block int tapi_tcp_pattern_gen(bool is_eth_pdu, :ref:`tapi_tcp_pos_t` seqn, :ref:`tapi_tcp_pos_t` ackn, bool syn_flag, bool ack_flag, :ref:`asn_value`** pattern) Prepare Traffic-Pattern ASN value for 'tcp.ip4.eth' or 'tcp.ip4' CSAP. It is assumed that all connection parameters (src/dst MACs, IP, and ports) are already set in CSAP. If it is not, fill there parameters in obtained traffic template explicitely. .. rubric:: Parameters: .. list-table:: :widths: 20 80 * - is_eth_pdu - if ``true`` include eth header PDU * - seqn - sequence number in host byte order * - ackn - acknowledge number in host byte order * - syn_flag - syn flag * - ack_flag - ack flag * - pattern - location for pointer to ASN value (OUT) .. rubric:: Returns: Status code. .. index:: pair: function; tapi_tcp_pattern .. _doxid-group__tapi__tad__tcp_1ga9b80113d9ad6e25f022ca8f60223a5ea: .. ref-code-block:: cpp :class: doxyrest-title-code-block int tapi_tcp_pattern(:ref:`tapi_tcp_pos_t` seqn, :ref:`tapi_tcp_pos_t` ackn, bool syn_flag, bool ack_flag, :ref:`asn_value`** pattern) The same function as :ref:`tapi_tcp_template_gen() ` with is_eth_pdu parameter set to ``true``, so it prepares value for 'tcp.ip4.eth' CSAP. .. index:: pair: function; tapi_tcp_ip_segment_pattern_gen .. _doxid-group__tapi__tad__tcp_1gadfeef5c6a5c44ba1f88b82637f47877e: .. ref-code-block:: cpp :class: doxyrest-title-code-block int tapi_tcp_ip_segment_pattern_gen(bool is_eth_layer, bool force_ip6, :ref:`tapi_tcp_pos_t` seqn, :ref:`tapi_tcp_pos_t` ackn, bool urg_flag, bool ack_flag, bool psh_flag, bool rst_flag, bool syn_flag, bool fin_flag, :ref:`asn_value`** pattern) Prepare pattern for TCP segment to receive via tcp.[ip4\|ip6].eth and tcp.[ip4\|ip6] CSAPs .. rubric:: Parameters: .. list-table:: :widths: 20 80 * - is_eth_layer - ``true`` for tcp.[ip4\|ip6].eth CSAPs ``false`` for tcp.[ip4\|ip6] CSAPs * - force_ip6 - ``true`` for tcp.ip6.eth and tcp.ip6 CSAPs ``false`` for tcp.ip4.eth and tcp.ip4 CSAPs * - seqn - sequence number in host byte order * - ackn - acknowledge number in host byte order * - urg_flag - URG flag * - ack_flag - ACK flag * - psh_flag - PSH flag * - rst_flag - RST flag * - syn_flag - SYN flag * - fin_flag - FIN flag * - pattern - location for pointer to ASN value (OUT) .. rubric:: Returns: Status code. .. index:: pair: function; tapi_tcp_ip_pattern_gen .. _doxid-group__tapi__tad__tcp_1ga3c24d0e885fa68fe302e42831acb4420: .. ref-code-block:: cpp :class: doxyrest-title-code-block int tapi_tcp_ip_pattern_gen(bool is_eth_layer, bool force_ip6, :ref:`tapi_tcp_pos_t` seqn, :ref:`tapi_tcp_pos_t` ackn, bool syn_flag, bool ack_flag, :ref:`asn_value`** pattern) Prepare pattern for TCP segment to receive via tcp.[ip4\|ip6].eth and tcp.[ip4\|ip6] CSAPs .. rubric:: Parameters: .. list-table:: :widths: 20 80 * - is_eth_layer - ``true`` for tcp.[ip4\|ip6].eth CSAPs ``false`` for tcp.[ip4\|ip6] CSAPs * - force_ip6 - ``true`` for tcp.ip6.eth and tcp.ip6 CSAPs ``false`` for tcp.ip4.eth and tcp.ip4 CSAPs * - seqn - sequence number in host byte order * - ackn - acknowledge number in host byte order * - syn_flag - SYN flag * - ack_flag - ACK flag * - pattern - location for pointer to ASN value (OUT) .. rubric:: Returns: Status code. .. index:: pair: function; tapi_tcp_segment_pattern .. _doxid-group__tapi__tad__tcp_1ga4f1971a2b01ac3855c15cd50be036fbd: .. ref-code-block:: cpp :class: doxyrest-title-code-block int tapi_tcp_segment_pattern(:ref:`tapi_tcp_pos_t` seqn, :ref:`tapi_tcp_pos_t` ackn, bool urg_flag, bool ack_flag, bool psh_flag, bool rst_flag, bool syn_flag, bool fin_flag, :ref:`asn_value`** pattern) The same function as tapi_tcp_segment_pattern_gen() with force_ip6 parameter set to ``false`` and is_eth_pdu parameter set to ``true`` to prepare pattern for 'tcp.ip4.eth' CSAP. .. index:: pair: function; tapi_tcp_ip_segment_pattern .. _doxid-group__tapi__tad__tcp_1gac5bd96e25cd989c30634d65fed1aea32: .. ref-code-block:: cpp :class: doxyrest-title-code-block int tapi_tcp_ip_segment_pattern(bool force_ip6, :ref:`tapi_tcp_pos_t` seqn, :ref:`tapi_tcp_pos_t` ackn, bool urg_flag, bool ack_flag, bool psh_flag, bool rst_flag, bool syn_flag, bool fin_flag, :ref:`asn_value`** pattern) The same function as :ref:`tapi_tcp_segment_pattern() ` with force_ip6 boolean parameter to create pattern for tcp.ip6.eth or tcp.ip4.eth CSAP .. index:: pair: function; tapi_tcp_segment_pdu .. _doxid-group__tapi__tad__tcp_1ga73b549cf3382acb805de9981a55cd39b: .. ref-code-block:: cpp :class: doxyrest-title-code-block int tapi_tcp_segment_pdu(int src_port, int dst_port, :ref:`tapi_tcp_pos_t` seqn, :ref:`tapi_tcp_pos_t` ackn, bool urg_flag, bool ack_flag, bool psh_flag, bool rst_flag, bool syn_flag, bool fin_flag, :ref:`asn_value`** pdu) Prepare TCP header PDU by specified parameter values. Modified version of tapi_tcp_pdu. .. rubric:: Parameters: .. list-table:: :widths: 20 80 * - src_port - source TCP port in network byte order * - dst_port - destination TCP port in network byte order * - seqn - sequence number in host byte order * - ackn - acknowledge number in host byte order * - urg_flag - URG flag * - ack_flag - ACK flag * - psh_flag - PSH flag * - rst_flag - RST flag * - syn_flag - SYN flag * - fin_flag - FIN flag * - pdu - location for pointer to ASN value (OUT) .. rubric:: Returns: Status code. .. index:: pair: function; tapi_tcp_ip_segment_template_gen .. _doxid-group__tapi__tad__tcp_1ga728375a0da96c339d31040656e58b3f3: .. ref-code-block:: cpp :class: doxyrest-title-code-block int tapi_tcp_ip_segment_template_gen(bool is_eth_layer, bool force_ip6, :ref:`tapi_tcp_pos_t` seqn, :ref:`tapi_tcp_pos_t` ackn, bool urg_flag, bool ack_flag, bool psh_flag, bool rst_flag, bool syn_flag, bool fin_flag, uint8_t* data, size_t pld_len, :ref:`asn_value`** tmpl) Prepare template for TCP segment to send via tcp.[ip4\|ip6].eth and tcp.[ip4\|ip6] CSAPs .. rubric:: Parameters: .. list-table:: :widths: 20 80 * - is_eth_layer - ``true`` for tcp.[ip4\|ip6].eth CSAPs ``false`` for tcp.[ip4\|ip6] CSAPs * - force_ip6 - ``true`` for tcp.ip6.eth and tcp.ip6 CSAPs ``false`` for tcp.ip4.eth and tcp.ip4 CSAPs * - seqn - sequence number in host byte order * - ackn - acknowledge number in host byte order * - urg_flag - URG flag * - ack_flag - ACK flag * - psh_flag - PSH flag * - rst_flag - RST flag * - syn_flag - SYN flag * - fin_flag - FIN flag * - data - pointer to buffer with payload octets * - pld_len - payload length * - tmpl - location for pointer to ASN value (OUT) .. rubric:: Returns: Status code. .. index:: pair: function; tapi_tcp_ip_template_gen .. _doxid-group__tapi__tad__tcp_1ga51f242d8defc74bf2b041514f39b9835: .. ref-code-block:: cpp :class: doxyrest-title-code-block int tapi_tcp_ip_template_gen(bool is_eth_layer, bool force_ip6, :ref:`tapi_tcp_pos_t` seqn, :ref:`tapi_tcp_pos_t` ackn, bool syn_flag, bool ack_flag, uint8_t* data, size_t pld_len, :ref:`asn_value`** tmpl) Prepare template for TCP segment to send via tcp.[ip4\|ip6].eth and tcp.[ip4\|ip6] CSAPs .. rubric:: Parameters: .. list-table:: :widths: 20 80 * - is_eth_layer - ``true`` for tcp.[ip4\|ip6].eth CSAPs ``false`` for tcp.[ip4\|ip6] CSAPs * - force_ip6 - ``true`` for tcp.ip6.eth and tcp.ip6 CSAPs ``false`` for tcp.ip4.eth and tcp.ip4 CSAPs * - seqn - sequence number in host byte order * - ackn - acknowledge number in host byte order * - syn_flag - SYN flag * - ack_flag - ACK flag * - data - pointer to buffer with payload octets * - pld_len - payload length * - tmpl - location for pointer to ASN value (OUT) .. rubric:: Returns: Status code. .. index:: pair: function; tapi_tcp_segment_template .. _doxid-group__tapi__tad__tcp_1gaa8bfe273c66b1ed50a6b1629f1ffff6e: .. ref-code-block:: cpp :class: doxyrest-title-code-block int tapi_tcp_segment_template(:ref:`tapi_tcp_pos_t` seqn, :ref:`tapi_tcp_pos_t` ackn, bool urg_flag, bool ack_flag, bool psh_flag, bool rst_flag, bool syn_flag, bool fin_flag, uint8_t* data, size_t pld_len, :ref:`asn_value`** tmpl) The same function as :ref:`tapi_tcp_ip_segment_template_gen() ` with force_ip6 parameter set to ``false`` and is_eth_pdu parameter set to ``true`` to prepare template for 'tcp.ip4.eth' CSAP. .. index:: pair: function; tapi_tcp_ip_segment_template .. _doxid-group__tapi__tad__tcp_1ga977b48512559d91ee3e682d28d4bfe74: .. ref-code-block:: cpp :class: doxyrest-title-code-block int tapi_tcp_ip_segment_template(bool force_ip6, :ref:`tapi_tcp_pos_t` seqn, :ref:`tapi_tcp_pos_t` ackn, bool urg_flag, bool ack_flag, bool psh_flag, bool rst_flag, bool syn_flag, bool fin_flag, uint8_t* data, size_t pld_len, :ref:`asn_value`** tmpl) The same function as :ref:`tapi_tcp_segment_template() ` with force_ip6 parameter to create template for tcp.ip6.eth or tcp.ip4.eth CSAP .. index:: pair: function; tapi_tcp_create_conn .. _doxid-group__tapi__tad__tcp_1gaa569de5e17cf62cec5be1d5df1615880: .. ref-code-block:: cpp :class: doxyrest-title-code-block :ref:`te_errno` tapi_tcp_create_conn(const char* agt, const struct sockaddr* local_addr, const struct sockaddr* remote_addr, const char* local_iface, const uint8_t* local_mac, const uint8_t* remote_mac, int window, tapi_tcp_handler_t* handler) Initialize TCP connection internal state. This method does not start connection establishing. Use :ref:`tapi_tcp_start_conn() ` and :ref:`tapi_tcp_wait_open() ` for establishing connection. Local IP address should be fake, not registered on host with TA, because otherwise OS will respond to TCP packets too. Local MAC address may be fake, and it is better to use fake one, because OS sometimes may respond with ICMP messages to IP packets which are received on its Ethernet device but have foreign IP destination address. If local MAC address is fake, Ethernet device will be turned to promiscuous mode. .. rubric:: Parameters: .. list-table:: :widths: 20 80 * - agt - TA name. * - local_addr - Local socket address. * - remote_addr - Remote socket address. * - local_iface - Local interface name. * - local_mac - Local MAC address. * - remote_mac - Remote MAC address. * - window - Window size, or zero (``TAPI_TCP_DEF_WINDOW``) to use default window size. To specify zero window size, pass ``TAPI_TCP_ZERO_WINDOW``. * - handler - Where to save TAPI handler of created TCP connection. .. rubric:: Returns: Status code. .. index:: pair: function; tapi_tcp_start_conn .. _doxid-group__tapi__tad__tcp_1ga4d260ddeadcc58f6f928c5f8e325434e: .. ref-code-block:: cpp :class: doxyrest-title-code-block :ref:`te_errno` tapi_tcp_start_conn(tapi_tcp_handler_t handler, :ref:`tapi_tcp_mode_t` mode) Start TCP connection establishing. .. rubric:: Parameters: .. list-table:: :widths: 20 80 * - handler - TAPI handler of TCP connection. * - mode - Connection establishment mode. If ``TAPI_TCP_CLIENT``, ``SYN`` will be sent. .. rubric:: Returns: Status code. .. index:: pair: function; tapi_tcp_init_connection .. _doxid-group__tapi__tad__tcp_1ga6b4e5e9b2155fe822f46c0ea81b16506: .. ref-code-block:: cpp :class: doxyrest-title-code-block :ref:`te_errno` tapi_tcp_init_connection(const char* agt, :ref:`tapi_tcp_mode_t` mode, const struct sockaddr* local_addr, const struct sockaddr* remote_addr, const char* local_iface, const uint8_t* local_mac, const uint8_t* remote_mac, int window, tapi_tcp_handler_t* handler) Initialize process for open TCP connection. This method does not blocks, only sends SYN (in client mode) or SYN-ACK (in server mode). Use 'tapi_tcp_wait_open' for wait complete open of TCP connection. Local IP address should be fake, not retistered on host with TA, because running OS will respond to TCP messages also, and it will make side effects on IUT. Local MAC address may be fake, and it is desired to use fake, because running OS sometimes may respond with ICMP messages to IP packets which is got in its Ethernet device and have foreign IP dst address. If local MAC address is fake, Ethernet device will be turned to promiscuous mode. .. rubric:: Parameters: .. list-table:: :widths: 20 80 * - agt - name of TA; * - mode - TCP mode: server or client, really, this means choice "wait for SYN" or "send SYN first"; * - local_addr - local socket address, unspecified values are zeroes, (IN/OUT); * - remote_addr - remote socket address, unspecified values are zeroes, (IN/OUT); * - local_iface - name of Ethernet interface on 'agt' host; * - local_mac - local MAC address, may be fake; * - remote_mac - remote MAC address, must be real address of peer device; * - window - Window size, or zero (TAPI_TCP_DEF_WINDOW) to use default window size. To specify zero window size, pass TAPI_TCP_ZERO_WINDOW. * - handler - TAPI handler of created TCP connection (OUT); .. rubric:: Returns: Status code .. index:: pair: function; tapi_tcp_init_connection_enc .. _doxid-group__tapi__tad__tcp_1ga87cbd1e42c8ac746334d522b88948f7c: .. ref-code-block:: cpp :class: doxyrest-title-code-block int tapi_tcp_init_connection_enc(const char* agt, :ref:`tapi_tcp_mode_t` mode, const struct sockaddr* local_addr, const struct sockaddr* remote_addr, const char* local_iface, const uint8_t* local_mac, const uint8_t* remote_mac, int window, bool enc_vlan, bool enc_snap, tapi_tcp_handler_t* handler) Modification of :ref:`tapi_tcp_init_connection() ` that supports Layer2 encapsulation. Parameters are same as above plus: .. rubric:: Parameters: .. list-table:: :widths: 20 80 * - enc_vlan - Use VLAN encapsulation * - enc_llc - Use LLC/SNAP encapsulation .. index:: pair: function; tapi_tcp_destroy_connection .. _doxid-group__tapi__tad__tcp_1ga17c0870454417b5a99d55bc93e79be5d: .. ref-code-block:: cpp :class: doxyrest-title-code-block int tapi_tcp_destroy_connection(tapi_tcp_handler_t handler) Destroy TAPI TCP connection handler: stop receive process on CSAPs, etc. This method DOES NOT close TCP connection! .. rubric:: Parameters: .. list-table:: :widths: 20 80 * - handler - TAPI handler of TCP connection; .. rubric:: Returns: Status code .. index:: pair: function; tapi_tcp_wait_open .. _doxid-group__tapi__tad__tcp_1ga2471181d512d3d25ae294407d6ad51a0: .. ref-code-block:: cpp :class: doxyrest-title-code-block int tapi_tcp_wait_open(tapi_tcp_handler_t handler, int timeout) Wait for complete process of opening TCP connection: blocks until SYN and ACKs from peer will be received. If timed out, TAPI connection handler will be destroyed. .. rubric:: Parameters: .. list-table:: :widths: 20 80 * - handler - TAPI handler of TCP connection; * - timeout - time in milliseconds, while TA should wait for SYN or ACK for his SYN; .. rubric:: Returns: Status code .. index:: pair: function; tapi_tcp_wait_msg .. _doxid-group__tapi__tad__tcp_1ga63dc0d47f9bdad9ae2b367abdaca7fe3: .. ref-code-block:: cpp :class: doxyrest-title-code-block int tapi_tcp_wait_msg(tapi_tcp_handler_t handler, int timeout) Wait for some incoming message in emulated TCP connection. If message was got, all internal state fields will be updated in accordance. If it was PUSH, it will be stored in internal buffer, and may be got with :ref:`tapi_tcp_recv_msg() `. .. rubric:: Parameters: .. list-table:: :widths: 20 80 * - handler - TAPI handler of TCP connection; * - timeout - time in milliseconds, while TA should wait for SYN or ACK for his SYN; .. rubric:: Returns: Status code .. index:: pair: function; tapi_tcp_send_fin .. _doxid-group__tapi__tad__tcp_1gae87b9e19165410c3ebb1567d8dff2170: .. ref-code-block:: cpp :class: doxyrest-title-code-block int tapi_tcp_send_fin(tapi_tcp_handler_t handler, int timeout) Send FIN in TCP connection, and wait ACK for it. This is either part of close process, or shutdown for writing. This method blocks until ACK will be received. .. rubric:: Parameters: .. list-table:: :widths: 20 80 * - handler - TAPI handler of TCP connection; * - timeout - time in milliseconds, while TA should wait for answer for FIN; .. rubric:: Returns: Status code .. index:: pair: function; tapi_tcp_send_fin_ack .. _doxid-group__tapi__tad__tcp_1ga371f68c420593772845b32e7178753a5: .. ref-code-block:: cpp :class: doxyrest-title-code-block int tapi_tcp_send_fin_ack(tapi_tcp_handler_t handler, int timeout) Send FIN in TCP connection with ACK (possibly to FIN sent by peer), and wait ACK for it. This is either part of close process, or shutdown for writing. This method blocks until ACK will be received. .. rubric:: Parameters: .. list-table:: :widths: 20 80 * - handler - TAPI handler of TCP connection; * - timeout - time in milliseconds, while TA should wait for answer for FIN; .. rubric:: Returns: Status code .. index:: pair: function; tapi_tcp_send_rst .. _doxid-group__tapi__tad__tcp_1ga8045232fef58c66c0344c0d791cd2c7e: .. ref-code-block:: cpp :class: doxyrest-title-code-block int tapi_tcp_send_rst(tapi_tcp_handler_t handler) Send RST in TCP connection. .. rubric:: Parameters: .. list-table:: :widths: 20 80 * - handler - TAPI handler of TCP connection; * - timeout - time in milliseconds, while TA should wait for answer for FIN; .. rubric:: Returns: Status code .. index:: pair: function; tapi_tcp_send_msg .. _doxid-group__tapi__tad__tcp_1ga685264289c925ac4e83e5395bc529737: .. ref-code-block:: cpp :class: doxyrest-title-code-block int tapi_tcp_send_msg(tapi_tcp_handler_t handler, uint8_t* payload, size_t len, :ref:`tapi_tcp_protocol_mode_t` seq_mode, :ref:`tapi_tcp_pos_t` seqn, :ref:`tapi_tcp_protocol_mode_t` ack_mode, :ref:`tapi_tcp_pos_t` ackn, :ref:`tapi_ip_frag_spec`* frags, size_t frag_num) Send TCP message via established connection. With seq_mode = TAPI_TCP_AUTO it should be used ONLY for sending subsequent flow of data. If user need to send some strange sequence numbers, he have to use TAPI_TCP_EXPLICIT. First seqn for 'explicit' data block should be get with method 'tapi_tcp_next_seqn'. To send some more data in automatic mode after explicit mode user have to store total length of all data, sent in explicit mode, by method 'tapi_tcp_set_next_sent' .. rubric:: Parameters: .. list-table:: :widths: 20 80 * - handler - TAPI handler of TCP connection; * - payload - data for message payload; * - len - length of payload; * - seq_mode - mode of insertion SEQ number into message; * - seqn - explicit SEQ number for message, used only if 'seq_mode' passed is TAPI_TCP_EXPLICIT; * - ack_mode - mode of insertion ACK number into message; * - ackn - explicit ACK number for message, used only if 'ack_mode' passed is TAPI_TCP_EXPLICIT; .. rubric:: Returns: Status code .. index:: pair: function; tapi_tcp_conn_template .. _doxid-group__tapi__tad__tcp_1gac1555426b20da4d4f114ace3fc2626a7: .. ref-code-block:: cpp :class: doxyrest-title-code-block int tapi_tcp_conn_template(tapi_tcp_handler_t handler, uint8_t* payload, size_t len, :ref:`asn_value`** tmpl) Prepare template for TCP message via established connection. Fields SEQN and ACKN are filled by default, if user want to set them explicitly , one can do it via ASN lib API. .. rubric:: Parameters: .. list-table:: :widths: 20 80 * - handler - TAPI handler of TCP connection; * - payload - data for message payload; * - len - length of payload; * - tmpl - location for new ASN value with traffic template(OUT); .. rubric:: Returns: Status code .. index:: pair: function; tapi_tcp_send_template .. _doxid-group__tapi__tad__tcp_1gafd5fcebd30ac2ed12a0acbdbb7b810db: .. ref-code-block:: cpp :class: doxyrest-title-code-block int tapi_tcp_send_template(tapi_tcp_handler_t handler, const :ref:`asn_value`* template, :ref:`rcf_call_mode_t` blk_mode) Send explicitely formed traffic template. Note, that template should be prepareed accurately, if you want to send valid TCP message in connection. IP addresses and TCP pors should NOT be mentioned in template. .. rubric:: Parameters: .. list-table:: :widths: 20 80 * - handler - TAPI handler of TCP connection; * - template - ASN value of type Traffic-Template; * - blk_mode - mode of the operation: in blocking mode it suspends the caller until sending of all the traffic finishes .. rubric:: Returns: Status code .. index:: pair: function; tapi_tcp_recv_msg_gen .. _doxid-group__tapi__tad__tcp_1ga479e5690f69998d8ab1924adf1e62656: .. ref-code-block:: cpp :class: doxyrest-title-code-block int tapi_tcp_recv_msg_gen(tapi_tcp_handler_t handler, int timeout, :ref:`tapi_tcp_protocol_mode_t` ack_mode, uint8_t* buffer, size_t* len, :ref:`tapi_tcp_pos_t`* seqn_got, :ref:`tapi_tcp_pos_t`* ackn_got, uint8_t* flags, bool no_unexp_seqn) Wait for next incoming TCP message in connection, if buffer is empty, or get oldest received message in buffer queue. Ignore packets having unexpected SEQN (such as retransmits) if requested. .. rubric:: Parameters: .. list-table:: :widths: 20 80 * - handler - TAPI handler of TCP connection. * - timeout - Timeout in milliseconds. * - ack_mode - Mode of sending ACK to the message, for this method valid values are TAPI_TCP_AUTO or TAPI_TCP_QUIET only. * - payload - Pointer to message payload buffer (OUT). * - len - Length of buffer / got payload (IN/OUT). * - seqn_got - Place for received SEQ number or NULL (OUT). * - ackn_got - Place for received ACK number or NULL (OUT). * - flags - Location for TCP flags or NULL (OUT). * - no_unexp_seqn - If ``true``, ignore packets with unexpected TCP SEQN. .. rubric:: Returns: Status code .. index:: pair: function; tapi_tcp_recv_msg .. _doxid-group__tapi__tad__tcp_1gaf9db6ec07b55d8e64a03b2d8b6c0c20b: .. ref-code-block:: cpp :class: doxyrest-title-code-block int tapi_tcp_recv_msg(tapi_tcp_handler_t handler, int timeout, :ref:`tapi_tcp_protocol_mode_t` ack_mode, uint8_t* buffer, size_t* len, :ref:`tapi_tcp_pos_t`* seqn_got, :ref:`tapi_tcp_pos_t`* ackn_got, uint8_t* flags) Wait for next incoming TCP message in connection, if buffer is empty, or get oldest received message in buffer queue. .. rubric:: Parameters: .. list-table:: :widths: 20 80 * - handler - TAPI handler of TCP connection; * - timeout - timeout in milliseconds; * - ack_mode - mode of sending ACK to the message, for this method valid values are 'AUTO' or 'QUIET' only; * - payload - pointer to message payload buffer (OUT); * - len - length of buffer / got payload (IN/OUT); * - seqn_got - place for received SEQ number or NULL (OUT); * - ackn_got - place for received ACK number or NULL (OUT); * - flags - location for TCP flags or NULL (OUT). .. rubric:: Returns: Status code .. index:: pair: function; tapi_tcp_recv_data .. _doxid-group__tapi__tad__tcp_1gac24feae401f1f5fec66c1b1e5c718546: .. ref-code-block:: cpp :class: doxyrest-title-code-block int tapi_tcp_recv_data(tapi_tcp_handler_t handler, int time2wait, :ref:`tapi_tcp_protocol_mode_t` ack_mode, :ref:`te_dbuf`* data) Read all received data from TCP connection. .. rubric:: Parameters: .. list-table:: :widths: 20 80 * - handler - TAPI handler of TCP connection. * - time2wait - How long to wait for the next message, milliseconds. * - ack_mode - Mode of sending ACKs, for this method valid values are TAPI_TCP_AUTO or TAPI_TCP_QUIET only. * - data - Dynamic buffer to which received data should be appended. .. rubric:: Returns: Status code. .. index:: pair: function; tapi_tcp_send_ack .. _doxid-group__tapi__tad__tcp_1ga0473edd00b7e1efd0382979b6acabe65: .. ref-code-block:: cpp :class: doxyrest-title-code-block int tapi_tcp_send_ack(tapi_tcp_handler_t handler, :ref:`tapi_tcp_pos_t` ackn) Send ACK via established TCP connection. .. rubric:: Parameters: .. list-table:: :widths: 20 80 * - handler - TAPI handler of TCP connection; * - ackn - ACK number .. rubric:: Returns: Status code .. index:: pair: function; tapi_tcp_ack_all .. _doxid-group__tapi__tad__tcp_1ga4b6668322aa74b1a1e9c4859ea07e1cf: .. ref-code-block:: cpp :class: doxyrest-title-code-block int tapi_tcp_ack_all(tapi_tcp_handler_t handler) Send ACK to all data received from established TCP connection. .. rubric:: Parameters: .. list-table:: :widths: 20 80 * - handler - TAPI handler of TCP connection. .. rubric:: Returns: Status code. .. index:: pair: function; tapi_tcp_first_seqn_got .. _doxid-group__tapi__tad__tcp_1ga0e2df697b61e9384b02015a928b7b799: .. ref-code-block:: cpp :class: doxyrest-title-code-block :ref:`tapi_tcp_pos_t` tapi_tcp_first_seqn_got(tapi_tcp_handler_t handler) Return the first received SEQ number in established TCP connection. .. rubric:: Parameters: .. list-table:: :widths: 20 80 * - handler - TAPI handler of TCP connection. .. rubric:: Returns: SEQ number or zero if ``handler`` is not valid. .. index:: pair: function; tapi_tcp_last_seqn_got .. _doxid-group__tapi__tad__tcp_1ga510b0a559657e89d3a8a5523e978e93e: .. ref-code-block:: cpp :class: doxyrest-title-code-block :ref:`tapi_tcp_pos_t` tapi_tcp_last_seqn_got(tapi_tcp_handler_t handler) Return last received SEQ number in established TCP connection. .. rubric:: Parameters: .. list-table:: :widths: 20 80 * - handler - TAPI handler of TCP connection; .. rubric:: Returns: SEQ number of zero if 'handler' not valid. .. index:: pair: function; tapi_tcp_last_ackn_got .. _doxid-group__tapi__tad__tcp_1ga88936949864dff594247d94f62379364: .. ref-code-block:: cpp :class: doxyrest-title-code-block :ref:`tapi_tcp_pos_t` tapi_tcp_last_ackn_got(tapi_tcp_handler_t handler) Return last received ACK number in established TCP connection. .. rubric:: Parameters: .. list-table:: :widths: 20 80 * - handler - TAPI handler of TCP connection; .. rubric:: Returns: ACK number of zero if 'handler' not valid. .. index:: pair: function; tapi_tcp_first_seqn_sent .. _doxid-group__tapi__tad__tcp_1ga580b5f0a071917f21eabdc8030cd1b25: .. ref-code-block:: cpp :class: doxyrest-title-code-block :ref:`tapi_tcp_pos_t` tapi_tcp_first_seqn_sent(tapi_tcp_handler_t handler) Return the first sent SEQ number in established TCP connection. .. rubric:: Parameters: .. list-table:: :widths: 20 80 * - handler - TAPI handler of TCP connection. .. rubric:: Returns: SEQ number or zero if ``handler`` is not valid. .. index:: pair: function; tapi_tcp_last_seqn_sent .. _doxid-group__tapi__tad__tcp_1ga3772fb87b1fefcd895cfd54636c58114: .. ref-code-block:: cpp :class: doxyrest-title-code-block :ref:`tapi_tcp_pos_t` tapi_tcp_last_seqn_sent(tapi_tcp_handler_t handler) Return last sent SEQ number in established TCP connection. .. rubric:: Parameters: .. list-table:: :widths: 20 80 * - handler - TAPI handler of TCP connection; .. rubric:: Returns: SEQ number of zero if 'handler' not valid. .. index:: pair: function; tapi_tcp_last_ackn_sent .. _doxid-group__tapi__tad__tcp_1ga2e6edecb6a2d79a3d77e01b351876be9: .. ref-code-block:: cpp :class: doxyrest-title-code-block :ref:`tapi_tcp_pos_t` tapi_tcp_last_ackn_sent(tapi_tcp_handler_t handler) Return last sent ACK number in established TCP connection. .. rubric:: Parameters: .. list-table:: :widths: 20 80 * - handler - TAPI handler of TCP connection; .. rubric:: Returns: ACK number of zero if 'handler' not valid. .. index:: pair: function; tapi_tcp_last_win_got .. _doxid-group__tapi__tad__tcp_1ga5bc524091e89d7c5997a09bcab7b0f21: .. ref-code-block:: cpp :class: doxyrest-title-code-block size_t tapi_tcp_last_win_got(tapi_tcp_handler_t handler) Return last received window in established TCP connection. .. rubric:: Parameters: .. list-table:: :widths: 20 80 * - handler - TAPI handler of TCP connection; .. rubric:: Returns: SEQ number of zero if 'handler' not valid. .. index:: pair: function; tapi_tcp_fin_got .. _doxid-group__tapi__tad__tcp_1gacae8521bd001f10067f4f5fc4d9b9796: .. ref-code-block:: cpp :class: doxyrest-title-code-block bool tapi_tcp_fin_got(tapi_tcp_handler_t handler) Check that a message with FIN flag set was got. .. rubric:: Parameters: .. list-table:: :widths: 20 80 * - handler - TAPI handler of TCP connection; .. rubric:: Returns: ``true`` if a message with FIN flag set was got, ``false`` otherwise. .. index:: pair: function; tapi_tcp_rst_got .. _doxid-group__tapi__tad__tcp_1ga59a93a41d87e3f2aed04f0d5404ba253: .. ref-code-block:: cpp :class: doxyrest-title-code-block bool tapi_tcp_rst_got(tapi_tcp_handler_t handler) Check that a message with RST flag set was got. .. rubric:: Parameters: .. list-table:: :widths: 20 80 * - handler - TAPI handler of TCP connection; .. rubric:: Returns: ``true`` if a message with RST flag set was got, ``false`` otherwise. .. index:: pair: function; tapi_tcp_next_seqn .. _doxid-group__tapi__tad__tcp_1ga06dc8b36c7367d02e2b342beeab9a3f5: .. ref-code-block:: cpp :class: doxyrest-title-code-block :ref:`tapi_tcp_pos_t` tapi_tcp_next_seqn(tapi_tcp_handler_t handler) Return next SEQ number to be sent in established TCP connection. .. rubric:: Parameters: .. list-table:: :widths: 20 80 * - handler - TAPI handler of TCP connection; .. rubric:: Returns: SEQ number of zero if 'handler' not valid. .. index:: pair: function; tapi_tcp_next_ackn .. _doxid-group__tapi__tad__tcp_1ga7c07230bc630c873fa9c8e701d66d062: .. ref-code-block:: cpp :class: doxyrest-title-code-block :ref:`tapi_tcp_pos_t` tapi_tcp_next_ackn(tapi_tcp_handler_t handler) Return next ACK number to be sent in established TCP connection. .. rubric:: Parameters: .. list-table:: :widths: 20 80 * - handler - TAPI handler of TCP connection; .. rubric:: Returns: ACK number of zero if 'handler' not valid. .. index:: pair: function; tapi_tcp_update_sent_seq .. _doxid-group__tapi__tad__tcp_1gae1cf815f1abc616a06dd32ba97b15bc3: .. ref-code-block:: cpp :class: doxyrest-title-code-block int tapi_tcp_update_sent_seq(tapi_tcp_handler_t handler, size_t new_sent_len) Update internal TAPI TCP connection fields according with next sent data in connection. This is necessary ONLY after sending data in 'explicit' mode. .. rubric:: Parameters: .. list-table:: :widths: 20 80 * - handler - TAPI handler of TCP connection * - new_sent_len - length of sent data .. rubric:: Returns: status code .. index:: pair: function; tapi_tcp_get_window .. _doxid-group__tapi__tad__tcp_1ga6dc735e44b65dbcc380c8ef1016ee95c: .. ref-code-block:: cpp :class: doxyrest-title-code-block int tapi_tcp_get_window(tapi_tcp_handler_t handler) Get TCP window size currently advertised by TCP connection. .. rubric:: Parameters: .. list-table:: :widths: 20 80 * - handler - TAPI handler of TCP connection. .. rubric:: Returns: TCP window size on success, negative value in case of failure. .. index:: pair: function; tapi_tcp_set_window .. _doxid-group__tapi__tad__tcp_1gab874a6a08f5f5708fc1be0219baf90d0: .. ref-code-block:: cpp :class: doxyrest-title-code-block :ref:`te_errno` tapi_tcp_set_window(tapi_tcp_handler_t handler, int window) Set TCP window size to be advertised by TCP connection. .. rubric:: Parameters: .. list-table:: :widths: 20 80 * - handler - TAPI handler of TCP connection. * - window - Window size. .. rubric:: Returns: Status code. .. index:: pair: function; tapi_tcp_reset_hack_init .. _doxid-group__tapi__tad__tcp_1ga50c99e5a5f8f20b77ba87e9b224a905f: .. ref-code-block:: cpp :class: doxyrest-title-code-block int tapi_tcp_reset_hack_init(const char* ta_name, int session, const char* iface, bool dir_out, :ref:`tapi_tcp_reset_hack_t`* context) Initialize RST sending hack framework: create CSAP, start listening of SYN-ACK. Note, that it will catch FIRST SYN-ACK, matching passed filtering parameters, which user fill in 'context' structure. All unset fields have to be zero. .. rubric:: Parameters: .. list-table:: :widths: 20 80 * - ta_name - TA name * - sid - RCF session id * - iface - Ethernet interface * - dir_out - boolean flag wheather SYN-ACK will be outgoing; ``true`` if it is. * - context - pointer to structure with context data, IN/OUT .. rubric:: Returns: status code .. index:: pair: function; tapi_tcp_reset_hack_catch .. _doxid-group__tapi__tad__tcp_1ga8962e28da72c810b9732a5c8b7253d2b: .. ref-code-block:: cpp :class: doxyrest-title-code-block int tapi_tcp_reset_hack_catch(const char* ta_name, int session, :ref:`tapi_tcp_reset_hack_t`* context) Catch SYN-ACK in RST sending hack framework. Note, that it will catch FIRST SYN-ACK, matching passed filtering parameters, which user fill in 'context' structure before call 'init'. .. rubric:: Parameters: .. list-table:: :widths: 20 80 * - ta_name - TA name * - sid - RCF session id * - context - pointer to structure with context data, IN/OUT .. rubric:: Returns: status code .. index:: pair: function; tapi_tcp_reset_hack_send .. _doxid-group__tapi__tad__tcp_1ga80ccebb0664698dc7e90e2ec0cc3effc: .. ref-code-block:: cpp :class: doxyrest-title-code-block int tapi_tcp_reset_hack_send(const char* ta_name, int session, :ref:`tapi_tcp_reset_hack_t`* context, size_t received, size_t sent) Send TCP RST. .. rubric:: Parameters: .. list-table:: :widths: 20 80 * - ta_name - TA name * - sid - RCF session id * - context - pointer to structure with context data * - received - received bytes during TCP connection life * - sent - sent bytes during TCP connection life .. rubric:: Returns: status code .. index:: pair: function; tapi_tcp_reset_hack_clear .. _doxid-group__tapi__tad__tcp_1gaec24de8929e4b934e872bb97b917306f: .. ref-code-block:: cpp :class: doxyrest-title-code-block int tapi_tcp_reset_hack_clear(const char* ta_name, int session, :ref:`tapi_tcp_reset_hack_t`* context) Clear TCP reset hack context .. rubric:: Parameters: .. list-table:: :widths: 20 80 * - ta_name - TA name * - sid - RCF session id * - context - pointer to structure with context data, IN/OUT .. rubric:: Returns: status code .. index:: pair: function; tapi_tcp_ip6_eth_csap_create .. _doxid-group__tapi__tad__tcp_1ga161ac63ed4fb41362ed061f6696e7b68: .. ref-code-block:: cpp :class: doxyrest-title-code-block :ref:`te_errno` tapi_tcp_ip6_eth_csap_create(const char* ta_name, int sid, const char* eth_dev, unsigned int receive_mode, const uint8_t* loc_mac, const uint8_t* rem_mac, const uint8_t* loc_addr, const uint8_t* rem_addr, int loc_port, int rem_port, :ref:`csap_handle_t`* tcp_csap) Creates 'tcp.ip6.eth' CSAP. .. rubric:: Parameters: .. list-table:: :widths: 20 80 * - ta_name - Test Agent name * - sid - RCF SID * - eth_dev - Name of Ethernet interface * - receive_mode - Bitmask with receive mode, see 'enum tad_eth_recv_mode' in ``tad_common.h``. Use TAD_ETH_RECV_DEF by default. * - loc_mac - Local MAC address (or NULL) * - rem_mac - Remote MAC address (or NULL) * - loc_addr - Local IPv6 address * - rem_addr - Remote IPv6 address * - loc_port - Local TCP port in network byte order or -1 * - rem_port - Remote TCP port in network byte order or -1 * - tcp_csap - Location for the IPv4 CSAP handle (OUT) .. rubric:: Returns: Status of the operation .. index:: pair: function; tapi_tcp_conn_snd_csap .. _doxid-group__tapi__tad__tcp_1ga294a8013e6e2a3c8f00d53612ca179aa: .. ref-code-block:: cpp :class: doxyrest-title-code-block :ref:`csap_handle_t` tapi_tcp_conn_snd_csap(tapi_tcp_handler_t handler) Get sender CSAP from TCP connection context. .. rubric:: Parameters: .. list-table:: :widths: 20 80 * - handler - TAPI handler of the TCP connection .. rubric:: Returns: CSAP id .. index:: pair: function; tapi_tcp_conn_rcv_csap .. _doxid-group__tapi__tad__tcp_1ga0cd6ebc3d24ea21eb69dc2aaebc6b3a5: .. ref-code-block:: cpp :class: doxyrest-title-code-block :ref:`csap_handle_t` tapi_tcp_conn_rcv_csap(tapi_tcp_handler_t handler) Get receiver CSAP from TCP connection context. .. rubric:: Parameters: .. list-table:: :widths: 20 80 * - handler - TAPI handler of the TCP connection .. rubric:: Returns: CSAP id .. index:: pair: function; tapi_tcp_update_sent_ack .. _doxid-group__tapi__tad__tcp_1ga88e6cc9008c68fb26400c36010c01596: .. ref-code-block:: cpp :class: doxyrest-title-code-block int tapi_tcp_update_sent_ack(tapi_tcp_handler_t handler, size_t ack) Set last sent ACK number of the sender CSAP in TCP connection context. .. rubric:: Parameters: .. list-table:: :widths: 20 80 * - handler - TAPI handler of the TCP connection * - ack - ACK number to set .. rubric:: Returns: Status code .. index:: pair: function; tapi_tcp_wait_packet .. _doxid-group__tapi__tad__tcp_1ga71a9c5e249d6ab24836e5929b48cf0e8: .. ref-code-block:: cpp :class: doxyrest-title-code-block int tapi_tcp_wait_packet(tapi_tcp_handler_t handler, int timeout) Wait for any packet in this connection while timeout expired. .. rubric:: Parameters: .. list-table:: :widths: 20 80 * - handler - TAPI handler of the TCP connection * - timeout - Timeout in milliseconds .. rubric:: Returns: zero on success (one or more messages got), errno otherwise .. index:: pair: function; tapi_tcp_get_packets .. _doxid-group__tapi__tad__tcp_1gac73e4877748b93d54a133a1dbe3d2c22: .. ref-code-block:: cpp :class: doxyrest-title-code-block int tapi_tcp_get_packets(tapi_tcp_handler_t handler) Pull received packets. .. rubric:: Parameters: .. list-table:: :widths: 20 80 * - handler - TAPI handler of the TCP connection .. rubric:: Returns: Packets number or ``-1`` in case of error .. index:: pair: function; tapi_tcp_conn_enable_ts .. _doxid-group__tapi__tad__tcp_1ga96dd62062fdc74c8425027ef4caf3b68: .. ref-code-block:: cpp :class: doxyrest-title-code-block :ref:`te_errno` tapi_tcp_conn_enable_ts(tapi_tcp_handler_t handler, bool enable, uint32_t start_value) Enable or disable TCP timestamp option for emulated TCP connection. .. rubric:: Parameters: .. list-table:: :widths: 20 80 * - handler - TAPI TCP connection handler. * - enable - Whether to enable or disable timestamp. * - start_time - If ``enable`` is ``true``, this is the start value for TCP timestamp. Each new TCP timestamp will be computed as this value + number of milliseconds since the moment of time when the first packet was sent (for which this value will be used as TCP timestamp). .. rubric:: Returns: Status code. .. index:: pair: function; tapi_tcp_conn_get_ts .. _doxid-group__tapi__tad__tcp_1ga1d4ead89e6c486f468c9b3f2f78a0ee7: .. ref-code-block:: cpp :class: doxyrest-title-code-block :ref:`te_errno` tapi_tcp_conn_get_ts(tapi_tcp_handler_t handler, bool* enabled, bool* dst_enabled, uint32_t* ts_value, uint32_t* last_ts_sent, uint32_t* last_ts_got, uint32_t* ts_to_echo, uint32_t* last_ts_echo_sent, uint32_t* last_ts_echo_got) Get current status of TCP timestamp option in a given TCP connection emulation. .. rubric:: Parameters: .. list-table:: :widths: 20 80 * - handler - TAPI TCP connection handler. * - enabled - Whether TCP timestamp is enabled. Other parameters are filled only if this is ``true``. * - dst_enabled - Whether peer sends TCP timestamp. If peer did not sent TCP timestamp in its first packet, we will not send it too. * - ts_value - Current TCP timestamp value (such that would be used if a packet is sent now). * - last_ts_sent - Last timestamp sent to peer. * - last_ts_got - Last timestamp received from peer. * - ts_to_echo - Value to be sent in echo-reply field in the next ``ACK``. * - last_ts_echo_sent - Timestamp echo-reply sent in the last packet. * - last_ts_echo_got - Last timestamp echo-reply received from peer. .. rubric:: Returns: Status code. .. index:: pair: function; tapi_tcp_get_ts_opt .. _doxid-group__tapi__tad__tcp_1ga798df635db2d0c62f688d546e7215b84: .. ref-code-block:: cpp :class: doxyrest-title-code-block :ref:`te_errno` tapi_tcp_get_ts_opt(const :ref:`asn_value`* val, uint32_t* ts_value, uint32_t* ts_echo) Get TCP timestamp option parameters. .. rubric:: Parameters: .. list-table:: :widths: 20 80 * - val - Pointer to ASN value which stores either whole network packet or TCP PDU. * - ts_value - Where to save timestamp value. * - ts_echo - Where to save timestamp echo reply. .. rubric:: Returns: Status code. .. index:: pair: function; tapi_tcp_set_ts_opt .. _doxid-group__tapi__tad__tcp_1gaa586b9603e6f12d96359e9530274ab2d: .. ref-code-block:: cpp :class: doxyrest-title-code-block :ref:`te_errno` tapi_tcp_set_ts_opt(:ref:`asn_value`* val, uint32_t ts_value, uint32_t ts_echo) Set TCP timestamp option parameters. .. rubric:: Parameters: .. list-table:: :widths: 20 80 * - val - Pointer to ASN value which stores either whole network packet or TCP PDU. * - ts_value - Timestamp value. * - ts_echo - Timestamp echo reply. .. rubric:: Returns: Status code. .. index:: pair: function; tapi_tcp_compare_seqn .. _doxid-group__tapi__tad__tcp_1ga86cafcf40b8ed857b4037ff434a9023e: .. ref-code-block:: cpp :class: doxyrest-title-code-block int tapi_tcp_compare_seqn(uint32_t seqn1, uint32_t seqn2) Compare two TCP sequence numbers. .. rubric:: Parameters: .. list-table:: :widths: 20 80 * - seqn1 - The first SEQN. * - seqn2 - The second SEQN. .. rubric:: Returns: ``-1`` if the first SEQN is smaller than the second SEQN, ``1`` if the first SEQN is greater than the second SEQN, ``0`` if they are equal. .. index:: pair: function; tapi_tcp_ip_eth_csap_create .. _doxid-group__tapi__tad__tcp_1gade015de3e489cdc8a5eda4ed9435dc16: .. ref-code-block:: cpp :class: doxyrest-title-code-block :ref:`te_errno` tapi_tcp_ip_eth_csap_create(const char* ta_name, int sid, const char* eth_dev, unsigned int receive_mode, const uint8_t* loc_mac, const uint8_t* rem_mac, int ip_family, const void* loc_addr, const void* rem_addr, int loc_port, int rem_port, :ref:`csap_handle_t`* tcp_csap) Create TCP CSAP for given IP address family on Ethernet. .. rubric:: Parameters: .. list-table:: :widths: 20 80 * - ta_name - Test Agent name * - sid - RCF SID * - eth_dev - Name of Ethernet interface * - receive_mode - Receive mode bitmask, see :ref:`tad_eth_recv_mode ` in ``tad_common.h``. Use ``TAD_ETH_RECV_DEF`` by default. * - loc_mac - Local MAC address (or NULL) * - rem_mac - Remote MAC address (or NULL) * - ip_family - Address family of created CSAP (``AF_INET`` or ``AF_INET6``) * - loc_addr - Local IP address in network byte order (or ``NULL``) * - rem_addr - Remote IP address in network byte order (or ``NULL``) * - loc_port - Local TCP port in network byte order or ``-1`` * - rem_port - Remote TCP port in network byte order or ``-1`` * - tcp_csap - Location for the TCP CSAP handle .. rubric:: Returns: Status code. .. index:: pair: function; tapi_tcp_get_hdrs_payload_len .. _doxid-group__tapi__tad__tcp_1ga23329cf4336cd5d0e90e529cdae20f29: .. ref-code-block:: cpp :class: doxyrest-title-code-block :ref:`te_errno` tapi_tcp_get_hdrs_payload_len(:ref:`asn_value`* pkt, unsigned int* hdrs_len, unsigned int* pld_len) Get length of TCP/IP headers and length of TCP payload from a packet captured by TCP/IP/Eth CSAP. This function is used because CSAP sometimes reports extra zero bytes in payload, so payload.len may be not reliable. This function does not take into account IPv6 extension headers and will probably work incorrectly in their presence. .. rubric:: Parameters: .. list-table:: :widths: 20 80 * - pkt - Packet captured by CSAP. * - hrds_len - Where to save headers length (may be ``NULL``). * - pld_len - Where to save payload length (may be ``NULL``). .. rubric:: Returns: Status code. Macros ------ .. index:: pair: define; TAPI_TCP_DEF_WINDOW .. _doxid-group__tapi__tad__tcp_1gad4137607278c8070cde4a66f294460b2: .. ref-code-block:: cpp :class: doxyrest-title-code-block #define TAPI_TCP_DEF_WINDOW Pass this as window parameter to :ref:`tapi_tcp_init_connection() ` to use default window size. .. index:: pair: define; TAPI_TCP_ZERO_WINDOW .. _doxid-group__tapi__tad__tcp_1ga1512834f8b8cded73beedcfeb1a0dd4a: .. ref-code-block:: cpp :class: doxyrest-title-code-block #define TAPI_TCP_ZERO_WINDOW Pass this as window parameter to :ref:`tapi_tcp_init_connection() ` to use zero window size.