The Design and Implementation of the FreeBSD Operating System, Second Edition
Now available: The Design and Implementation of the FreeBSD Operating System (Second Edition)


[ source navigation ] [ diff markup ] [ identifier search ] [ freetext search ] [ file search ] [ list types ] [ track identifier ]

FreeBSD/Linux Kernel Cross Reference
sys/dev/qlnx/qlnxe/tcp_common.h

Version: -  FREEBSD  -  FREEBSD-13-STABLE  -  FREEBSD-13-0  -  FREEBSD-12-STABLE  -  FREEBSD-12-0  -  FREEBSD-11-STABLE  -  FREEBSD-11-0  -  FREEBSD-10-STABLE  -  FREEBSD-10-0  -  FREEBSD-9-STABLE  -  FREEBSD-9-0  -  FREEBSD-8-STABLE  -  FREEBSD-8-0  -  FREEBSD-7-STABLE  -  FREEBSD-7-0  -  FREEBSD-6-STABLE  -  FREEBSD-6-0  -  FREEBSD-5-STABLE  -  FREEBSD-5-0  -  FREEBSD-4-STABLE  -  FREEBSD-3-STABLE  -  FREEBSD22  -  l41  -  OPENBSD  -  linux-2.6  -  MK84  -  PLAN9  -  xnu-8792 
SearchContext: -  none  -  3  -  10 

    1 /*
    2  * Copyright (c) 2017-2018 Cavium, Inc. 
    3  * All rights reserved.
    4  *
    5  *  Redistribution and use in source and binary forms, with or without
    6  *  modification, are permitted provided that the following conditions
    7  *  are met:
    8  *
    9  *  1. Redistributions of source code must retain the above copyright
   10  *     notice, this list of conditions and the following disclaimer.
   11  *  2. Redistributions in binary form must reproduce the above copyright
   12  *     notice, this list of conditions and the following disclaimer in the
   13  *     documentation and/or other materials provided with the distribution.
   14  *
   15  *  THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
   16  *  AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
   17  *  IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
   18  *  ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE
   19  *  LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
   20  *  CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
   21  *  SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
   22  *  INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
   23  *  CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
   24  *  ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
   25  *  POSSIBILITY OF SUCH DAMAGE.
   26  *
   27  * $FreeBSD$
   28  *
   29  */
   30 
   31 #ifndef __TCP_COMMON__
   32 #define __TCP_COMMON__ 
   33 /********************/
   34 /* TCP FW CONSTANTS */
   35 /********************/
   36 
   37 #define TCP_INVALID_TIMEOUT_VAL -1
   38 
   39 /*
   40  * OOO opaque data received from LL2
   41  */
   42 struct ooo_opaque
   43 {
   44         __le32 cid /* connection ID  */;
   45         u8 drop_isle /* isle number of the first isle to drop */;
   46         u8 drop_size /* number of isles to drop */;
   47         u8 ooo_opcode /* (use enum tcp_seg_placement_event) */;
   48         u8 ooo_isle /* OOO isle number to add the packet to */;
   49 };
   50 
   51 /*
   52  * tcp connect mode enum
   53  */
   54 enum tcp_connect_mode
   55 {
   56         TCP_CONNECT_ACTIVE,
   57         TCP_CONNECT_PASSIVE,
   58         MAX_TCP_CONNECT_MODE
   59 };
   60 
   61 /*
   62  * tcp function init parameters
   63  */
   64 struct tcp_init_params
   65 {
   66         __le32 two_msl_timer /* 2MSL (used for TIME_WAIT state) timeout value */;
   67         __le16 tx_sws_timer /* Transmission silly window syndrom timeout value */;
   68         u8 max_fin_rt /* Minimum Fin RT */;
   69         u8 reserved[9];
   70 };
   71 
   72 /*
   73  * tcp IPv4/IPv6 enum
   74  */
   75 enum tcp_ip_version
   76 {
   77         TCP_IPV4,
   78         TCP_IPV6,
   79         MAX_TCP_IP_VERSION
   80 };
   81 
   82 /*
   83  * tcp offload parameters
   84  */
   85 struct tcp_offload_params
   86 {
   87         __le16 local_mac_addr_lo;
   88         __le16 local_mac_addr_mid;
   89         __le16 local_mac_addr_hi;
   90         __le16 remote_mac_addr_lo;
   91         __le16 remote_mac_addr_mid;
   92         __le16 remote_mac_addr_hi;
   93         __le16 vlan_id;
   94         __le16 flags;
   95 #define TCP_OFFLOAD_PARAMS_TS_EN_MASK            0x1 /* timestamp enable */
   96 #define TCP_OFFLOAD_PARAMS_TS_EN_SHIFT           0
   97 #define TCP_OFFLOAD_PARAMS_DA_EN_MASK            0x1 /* delayed ack enabled */
   98 #define TCP_OFFLOAD_PARAMS_DA_EN_SHIFT           1
   99 #define TCP_OFFLOAD_PARAMS_KA_EN_MASK            0x1 /* keep alive enabled */
  100 #define TCP_OFFLOAD_PARAMS_KA_EN_SHIFT           2
  101 #define TCP_OFFLOAD_PARAMS_ECN_SENDER_EN_MASK    0x1 /* ECN sender enabled */
  102 #define TCP_OFFLOAD_PARAMS_ECN_SENDER_EN_SHIFT   3
  103 #define TCP_OFFLOAD_PARAMS_ECN_RECEIVER_EN_MASK  0x1 /* ECN receiver enabled */
  104 #define TCP_OFFLOAD_PARAMS_ECN_RECEIVER_EN_SHIFT 4
  105 #define TCP_OFFLOAD_PARAMS_NAGLE_EN_MASK         0x1 /* nagle algorithm enabled */
  106 #define TCP_OFFLOAD_PARAMS_NAGLE_EN_SHIFT        5
  107 #define TCP_OFFLOAD_PARAMS_DA_CNT_EN_MASK        0x1 /* delayed ack counter enabled */
  108 #define TCP_OFFLOAD_PARAMS_DA_CNT_EN_SHIFT       6
  109 #define TCP_OFFLOAD_PARAMS_FIN_SENT_MASK         0x1 /* fin already sent to far end */
  110 #define TCP_OFFLOAD_PARAMS_FIN_SENT_SHIFT        7
  111 #define TCP_OFFLOAD_PARAMS_FIN_RECEIVED_MASK     0x1 /* fin received */
  112 #define TCP_OFFLOAD_PARAMS_FIN_RECEIVED_SHIFT    8
  113 #define TCP_OFFLOAD_PARAMS_RESERVED_MASK         0x7F
  114 #define TCP_OFFLOAD_PARAMS_RESERVED_SHIFT        9
  115         u8 ip_version /*  (use enum tcp_ip_version) */;
  116         u8 reserved0[3];
  117         __le32 remote_ip[4];
  118         __le32 local_ip[4];
  119         __le32 flow_label;
  120         u8 ttl;
  121         u8 tos_or_tc;
  122         __le16 remote_port;
  123         __le16 local_port;
  124         __le16 mss /* the mss derived from remote mss and local mtu, ipVersion options and tags */;
  125         u8 rcv_wnd_scale;
  126         u8 connect_mode /* TCP connect mode: use enum tcp_connect_mode (use enum tcp_connect_mode) */;
  127         __le16 srtt /* in ms */;
  128         __le32 ss_thresh;
  129         __le32 rcv_wnd /* absolute receive window (not scaled) */;
  130         __le32 cwnd /* absolute congestion window */;
  131         u8 ka_max_probe_cnt;
  132         u8 dup_ack_theshold;
  133         __le16 reserved1;
  134         __le32 ka_timeout /* This member specifies, in ms, the timeout interval for inactivity before sending a keepalive probe */;
  135         __le32 ka_interval /* This member specifies, in ms, the timeout after which to retransmit a keepalive frame if no response is received to a keepalive probe  */;
  136         __le32 max_rt_time /* This member specifies, in ms, the maximum time that the offload target should spend retransmitting a segment */;
  137         __le32 initial_rcv_wnd /* Initial receive window */;
  138         __le32 rcv_next;
  139         __le32 snd_una;
  140         __le32 snd_next;
  141         __le32 snd_max;
  142         __le32 snd_wnd /* absolute send window (not scaled) */;
  143         __le32 snd_wl1 /* the segment sequence number used for the last window update */;
  144         __le32 ts_recent /* The timestamp value to send in the next ACK */;
  145         __le32 ts_recent_age /* The length of time, in ms, since the most recent timestamp was received */;
  146         __le32 total_rt /* The total time, in ms, that has been spent retransmitting the current TCP segment */;
  147         __le32 ka_timeout_delta /* The time remaining, in clock ticks, until the next keepalive timeout. A value of -1 indicates that the keepalive timer was not running when the connection was offloaded. */;
  148         __le32 rt_timeout_delta /* The time remaining, in clock ticks, until the next retransmit timeout. A value of -1 indicates that the  retransmit timer was not running when the connection was offloaded. */;
  149         u8 dup_ack_cnt /* The number of ACKs that have been accepted for the same sequence number */;
  150         u8 snd_wnd_probe_cnt /* The current send window probe round */;
  151         u8 ka_probe_cnt /* the number of keepalive probes that have been sent that have not received a response */;
  152         u8 rt_cnt /* The number of retransmits that have been sent */;
  153         __le16 rtt_var /* in ms */;
  154         __le16 fw_internal /* fw internal use - initialize value = 0 */;
  155         u8 snd_wnd_scale;
  156         u8 ack_frequency /* delayed ack counter threshold */;
  157         __le16 da_timeout_value /* delayed ack timeout value in ms */;
  158         __le32 reserved3;
  159 };
  160 
  161 /*
  162  * tcp offload parameters
  163  */
  164 struct tcp_offload_params_opt2
  165 {
  166         __le16 local_mac_addr_lo;
  167         __le16 local_mac_addr_mid;
  168         __le16 local_mac_addr_hi;
  169         __le16 remote_mac_addr_lo;
  170         __le16 remote_mac_addr_mid;
  171         __le16 remote_mac_addr_hi;
  172         __le16 vlan_id;
  173         __le16 flags;
  174 #define TCP_OFFLOAD_PARAMS_OPT2_TS_EN_MASK      0x1 /* timestamp enable */
  175 #define TCP_OFFLOAD_PARAMS_OPT2_TS_EN_SHIFT     0
  176 #define TCP_OFFLOAD_PARAMS_OPT2_DA_EN_MASK      0x1 /* delayed ack enabled */
  177 #define TCP_OFFLOAD_PARAMS_OPT2_DA_EN_SHIFT     1
  178 #define TCP_OFFLOAD_PARAMS_OPT2_KA_EN_MASK      0x1 /* keep alive enabled */
  179 #define TCP_OFFLOAD_PARAMS_OPT2_KA_EN_SHIFT     2
  180 #define TCP_OFFLOAD_PARAMS_OPT2_ECN_EN_MASK     0x1 /* ECN enabled */
  181 #define TCP_OFFLOAD_PARAMS_OPT2_ECN_EN_SHIFT    3
  182 #define TCP_OFFLOAD_PARAMS_OPT2_RESERVED0_MASK  0xFFF
  183 #define TCP_OFFLOAD_PARAMS_OPT2_RESERVED0_SHIFT 4
  184         u8 ip_version /*  (use enum tcp_ip_version) */;
  185         u8 reserved1[3];
  186         __le32 remote_ip[4];
  187         __le32 local_ip[4];
  188         __le32 flow_label;
  189         u8 ttl;
  190         u8 tos_or_tc;
  191         __le16 remote_port;
  192         __le16 local_port;
  193         __le16 mss /* the mss derived from remote mss and local mtu, ipVersion options and tags */;
  194         u8 rcv_wnd_scale;
  195         u8 connect_mode /* TCP connect mode: use enum tcp_connect_mode (use enum tcp_connect_mode) */;
  196         __le16 syn_ip_payload_length /* length of Tcp header in SYN packet - relevent for passive mode */;
  197         __le32 syn_phy_addr_lo /* physical address (low) of SYN buffer - relevent for passive mode */;
  198         __le32 syn_phy_addr_hi /* physical address (high) of SYN buffer - relevent for passive mode */;
  199         __le32 cwnd /* absolute congestion window */;
  200         u8 ka_max_probe_cnt;
  201         u8 reserved2[3];
  202         __le32 ka_timeout /* This member specifies, in ms, the timeout interval for inactivity before sending a keepalive probe */;
  203         __le32 ka_interval /* This member specifies, in ms, the timeout after which to retransmit a keepalive frame if no response is received to a keepalive probe  */;
  204         __le32 max_rt_time /* This member specifies, in ms, the maximum time that the offload target should spend retransmitting a segment */;
  205         __le32 reserved3[16];
  206 };
  207 
  208 /*
  209  * tcp IPv4/IPv6 enum
  210  */
  211 enum tcp_seg_placement_event
  212 {
  213         TCP_EVENT_ADD_PEN,
  214         TCP_EVENT_ADD_NEW_ISLE,
  215         TCP_EVENT_ADD_ISLE_RIGHT,
  216         TCP_EVENT_ADD_ISLE_LEFT,
  217         TCP_EVENT_JOIN,
  218         TCP_EVENT_DELETE_ISLES,
  219         TCP_EVENT_NOP,
  220         MAX_TCP_SEG_PLACEMENT_EVENT
  221 };
  222 
  223 /*
  224  * tcp init parameters
  225  */
  226 struct tcp_update_params
  227 {
  228         __le16 flags;
  229 #define TCP_UPDATE_PARAMS_REMOTE_MAC_ADDR_CHANGED_MASK   0x1
  230 #define TCP_UPDATE_PARAMS_REMOTE_MAC_ADDR_CHANGED_SHIFT  0
  231 #define TCP_UPDATE_PARAMS_MSS_CHANGED_MASK               0x1
  232 #define TCP_UPDATE_PARAMS_MSS_CHANGED_SHIFT              1
  233 #define TCP_UPDATE_PARAMS_TTL_CHANGED_MASK               0x1
  234 #define TCP_UPDATE_PARAMS_TTL_CHANGED_SHIFT              2
  235 #define TCP_UPDATE_PARAMS_TOS_OR_TC_CHANGED_MASK         0x1
  236 #define TCP_UPDATE_PARAMS_TOS_OR_TC_CHANGED_SHIFT        3
  237 #define TCP_UPDATE_PARAMS_KA_TIMEOUT_CHANGED_MASK        0x1
  238 #define TCP_UPDATE_PARAMS_KA_TIMEOUT_CHANGED_SHIFT       4
  239 #define TCP_UPDATE_PARAMS_KA_INTERVAL_CHANGED_MASK       0x1
  240 #define TCP_UPDATE_PARAMS_KA_INTERVAL_CHANGED_SHIFT      5
  241 #define TCP_UPDATE_PARAMS_MAX_RT_TIME_CHANGED_MASK       0x1
  242 #define TCP_UPDATE_PARAMS_MAX_RT_TIME_CHANGED_SHIFT      6
  243 #define TCP_UPDATE_PARAMS_FLOW_LABEL_CHANGED_MASK        0x1
  244 #define TCP_UPDATE_PARAMS_FLOW_LABEL_CHANGED_SHIFT       7
  245 #define TCP_UPDATE_PARAMS_INITIAL_RCV_WND_CHANGED_MASK   0x1
  246 #define TCP_UPDATE_PARAMS_INITIAL_RCV_WND_CHANGED_SHIFT  8
  247 #define TCP_UPDATE_PARAMS_KA_MAX_PROBE_CNT_CHANGED_MASK  0x1
  248 #define TCP_UPDATE_PARAMS_KA_MAX_PROBE_CNT_CHANGED_SHIFT 9
  249 #define TCP_UPDATE_PARAMS_KA_EN_CHANGED_MASK             0x1
  250 #define TCP_UPDATE_PARAMS_KA_EN_CHANGED_SHIFT            10
  251 #define TCP_UPDATE_PARAMS_NAGLE_EN_CHANGED_MASK          0x1
  252 #define TCP_UPDATE_PARAMS_NAGLE_EN_CHANGED_SHIFT         11
  253 #define TCP_UPDATE_PARAMS_KA_EN_MASK                     0x1
  254 #define TCP_UPDATE_PARAMS_KA_EN_SHIFT                    12
  255 #define TCP_UPDATE_PARAMS_NAGLE_EN_MASK                  0x1
  256 #define TCP_UPDATE_PARAMS_NAGLE_EN_SHIFT                 13
  257 #define TCP_UPDATE_PARAMS_KA_RESTART_MASK                0x1
  258 #define TCP_UPDATE_PARAMS_KA_RESTART_SHIFT               14
  259 #define TCP_UPDATE_PARAMS_RETRANSMIT_RESTART_MASK        0x1
  260 #define TCP_UPDATE_PARAMS_RETRANSMIT_RESTART_SHIFT       15
  261         __le16 remote_mac_addr_lo;
  262         __le16 remote_mac_addr_mid;
  263         __le16 remote_mac_addr_hi;
  264         __le16 mss;
  265         u8 ttl;
  266         u8 tos_or_tc;
  267         __le32 ka_timeout;
  268         __le32 ka_interval;
  269         __le32 max_rt_time;
  270         __le32 flow_label;
  271         __le32 initial_rcv_wnd;
  272         u8 ka_max_probe_cnt;
  273         u8 reserved1[7];
  274 };
  275 
  276 /*
  277  * toe upload parameters
  278  */
  279 struct tcp_upload_params
  280 {
  281         __le32 rcv_next;
  282         __le32 snd_una;
  283         __le32 snd_next;
  284         __le32 snd_max;
  285         __le32 snd_wnd /* absolute send window (not scaled) */;
  286         __le32 rcv_wnd /* absolute receive window (not scaled) */;
  287         __le32 snd_wl1 /* the segment sequence number used for the last window update */;
  288         __le32 cwnd /* absolute congestion window */;
  289         __le32 ss_thresh;
  290         __le16 srtt /* in ms */;
  291         __le16 rtt_var /* in ms */;
  292         __le32 ts_time /* The current value of the adjusted timestamp */;
  293         __le32 ts_recent /* The timestamp value to send in the next ACK */;
  294         __le32 ts_recent_age /* The length of time, in ms, since the most recent timestamp was received */;
  295         __le32 total_rt /* The total time, in ms, that has been spent retransmitting the current TCP segment */;
  296         __le32 ka_timeout_delta /* The time remaining, in clock ticks, until the next keepalive timeout. A value of -1 indicates that the keepalive timer was not running when the connection was offloaded. */;
  297         __le32 rt_timeout_delta /* The time remaining, in clock ticks, until the next retransmit timeout. A value of -1 indicates that the  retransmit timer was not running when the connection was offloaded. */;
  298         u8 dup_ack_cnt /* The number of ACKs that have been accepted for the same sequence number */;
  299         u8 snd_wnd_probe_cnt /* The current send window probe round */;
  300         u8 ka_probe_cnt /* the number of keepalive probes that have been sent that have not received a response */;
  301         u8 rt_cnt /* The number of retransmits that have been sent */;
  302         __le32 reserved;
  303 };
  304 
  305 #endif /* __TCP_COMMON__ */

Cache object: 1e62b9a040ef5a1423a0fd9a8090c728


[ source navigation ] [ diff markup ] [ identifier search ] [ freetext search ] [ file search ] [ list types ] [ track identifier ]


This page is part of the FreeBSD/Linux Linux Kernel Cross-Reference, and was automatically generated using a modified version of the LXR engine.