1 /* SPDX-License-Identifier: (GPL-2.0-only OR BSD-3-Clause) */
2 /* QLogic qed NIC Driver
3 * Copyright (c) 2015-2017 QLogic Corporation
4 * Copyright (c) 2019-2020 Marvell International Ltd.
10 /********************/
11 /* TCP FW CONSTANTS */
12 /********************/
14 #define TCP_INVALID_TIMEOUT_VAL -1
16 /* OOO opaque data received from LL2 */
25 /* tcp connect mode enum */
26 enum tcp_connect_mode
{
32 /* tcp function init parameters */
33 struct tcp_init_params
{
40 /* tcp IPv4/IPv6 enum */
47 /* tcp offload parameters */
48 struct tcp_offload_params
{
49 __le16 local_mac_addr_lo
;
50 __le16 local_mac_addr_mid
;
51 __le16 local_mac_addr_hi
;
52 __le16 remote_mac_addr_lo
;
53 __le16 remote_mac_addr_mid
;
54 __le16 remote_mac_addr_hi
;
57 #define TCP_OFFLOAD_PARAMS_TS_EN_MASK 0x1
58 #define TCP_OFFLOAD_PARAMS_TS_EN_SHIFT 0
59 #define TCP_OFFLOAD_PARAMS_DA_EN_MASK 0x1
60 #define TCP_OFFLOAD_PARAMS_DA_EN_SHIFT 1
61 #define TCP_OFFLOAD_PARAMS_KA_EN_MASK 0x1
62 #define TCP_OFFLOAD_PARAMS_KA_EN_SHIFT 2
63 #define TCP_OFFLOAD_PARAMS_ECN_SENDER_EN_MASK 0x1
64 #define TCP_OFFLOAD_PARAMS_ECN_SENDER_EN_SHIFT 3
65 #define TCP_OFFLOAD_PARAMS_ECN_RECEIVER_EN_MASK 0x1
66 #define TCP_OFFLOAD_PARAMS_ECN_RECEIVER_EN_SHIFT 4
67 #define TCP_OFFLOAD_PARAMS_NAGLE_EN_MASK 0x1
68 #define TCP_OFFLOAD_PARAMS_NAGLE_EN_SHIFT 5
69 #define TCP_OFFLOAD_PARAMS_DA_CNT_EN_MASK 0x1
70 #define TCP_OFFLOAD_PARAMS_DA_CNT_EN_SHIFT 6
71 #define TCP_OFFLOAD_PARAMS_FIN_SENT_MASK 0x1
72 #define TCP_OFFLOAD_PARAMS_FIN_SENT_SHIFT 7
73 #define TCP_OFFLOAD_PARAMS_FIN_RECEIVED_MASK 0x1
74 #define TCP_OFFLOAD_PARAMS_FIN_RECEIVED_SHIFT 8
75 #define TCP_OFFLOAD_PARAMS_RESERVED_MASK 0x7F
76 #define TCP_OFFLOAD_PARAMS_RESERVED_SHIFT 9
99 __le32 initial_rcv_wnd
;
107 __le32 ts_recent_age
;
109 __le32 ka_timeout_delta
;
110 __le32 rt_timeout_delta
;
112 u8 snd_wnd_probe_cnt
;
119 __le16 da_timeout_value
;
123 /* tcp offload parameters */
124 struct tcp_offload_params_opt2
{
125 __le16 local_mac_addr_lo
;
126 __le16 local_mac_addr_mid
;
127 __le16 local_mac_addr_hi
;
128 __le16 remote_mac_addr_lo
;
129 __le16 remote_mac_addr_mid
;
130 __le16 remote_mac_addr_hi
;
133 #define TCP_OFFLOAD_PARAMS_OPT2_TS_EN_MASK 0x1
134 #define TCP_OFFLOAD_PARAMS_OPT2_TS_EN_SHIFT 0
135 #define TCP_OFFLOAD_PARAMS_OPT2_DA_EN_MASK 0x1
136 #define TCP_OFFLOAD_PARAMS_OPT2_DA_EN_SHIFT 1
137 #define TCP_OFFLOAD_PARAMS_OPT2_KA_EN_MASK 0x1
138 #define TCP_OFFLOAD_PARAMS_OPT2_KA_EN_SHIFT 2
139 #define TCP_OFFLOAD_PARAMS_OPT2_ECN_EN_MASK 0x1
140 #define TCP_OFFLOAD_PARAMS_OPT2_ECN_EN_SHIFT 3
141 #define TCP_OFFLOAD_PARAMS_OPT2_RESERVED0_MASK 0xFFF
142 #define TCP_OFFLOAD_PARAMS_OPT2_RESERVED0_SHIFT 4
155 __le16 syn_ip_payload_length
;
156 __le32 syn_phy_addr_lo
;
157 __le32 syn_phy_addr_hi
;
164 __le32 reserved3
[16];
167 /* tcp IPv4/IPv6 enum */
168 enum tcp_seg_placement_event
{
170 TCP_EVENT_ADD_NEW_ISLE
,
171 TCP_EVENT_ADD_ISLE_RIGHT
,
172 TCP_EVENT_ADD_ISLE_LEFT
,
174 TCP_EVENT_DELETE_ISLES
,
176 MAX_TCP_SEG_PLACEMENT_EVENT
179 /* tcp init parameters */
180 struct tcp_update_params
{
182 #define TCP_UPDATE_PARAMS_REMOTE_MAC_ADDR_CHANGED_MASK 0x1
183 #define TCP_UPDATE_PARAMS_REMOTE_MAC_ADDR_CHANGED_SHIFT 0
184 #define TCP_UPDATE_PARAMS_MSS_CHANGED_MASK 0x1
185 #define TCP_UPDATE_PARAMS_MSS_CHANGED_SHIFT 1
186 #define TCP_UPDATE_PARAMS_TTL_CHANGED_MASK 0x1
187 #define TCP_UPDATE_PARAMS_TTL_CHANGED_SHIFT 2
188 #define TCP_UPDATE_PARAMS_TOS_OR_TC_CHANGED_MASK 0x1
189 #define TCP_UPDATE_PARAMS_TOS_OR_TC_CHANGED_SHIFT 3
190 #define TCP_UPDATE_PARAMS_KA_TIMEOUT_CHANGED_MASK 0x1
191 #define TCP_UPDATE_PARAMS_KA_TIMEOUT_CHANGED_SHIFT 4
192 #define TCP_UPDATE_PARAMS_KA_INTERVAL_CHANGED_MASK 0x1
193 #define TCP_UPDATE_PARAMS_KA_INTERVAL_CHANGED_SHIFT 5
194 #define TCP_UPDATE_PARAMS_MAX_RT_TIME_CHANGED_MASK 0x1
195 #define TCP_UPDATE_PARAMS_MAX_RT_TIME_CHANGED_SHIFT 6
196 #define TCP_UPDATE_PARAMS_FLOW_LABEL_CHANGED_MASK 0x1
197 #define TCP_UPDATE_PARAMS_FLOW_LABEL_CHANGED_SHIFT 7
198 #define TCP_UPDATE_PARAMS_INITIAL_RCV_WND_CHANGED_MASK 0x1
199 #define TCP_UPDATE_PARAMS_INITIAL_RCV_WND_CHANGED_SHIFT 8
200 #define TCP_UPDATE_PARAMS_KA_MAX_PROBE_CNT_CHANGED_MASK 0x1
201 #define TCP_UPDATE_PARAMS_KA_MAX_PROBE_CNT_CHANGED_SHIFT 9
202 #define TCP_UPDATE_PARAMS_KA_EN_CHANGED_MASK 0x1
203 #define TCP_UPDATE_PARAMS_KA_EN_CHANGED_SHIFT 10
204 #define TCP_UPDATE_PARAMS_NAGLE_EN_CHANGED_MASK 0x1
205 #define TCP_UPDATE_PARAMS_NAGLE_EN_CHANGED_SHIFT 11
206 #define TCP_UPDATE_PARAMS_KA_EN_MASK 0x1
207 #define TCP_UPDATE_PARAMS_KA_EN_SHIFT 12
208 #define TCP_UPDATE_PARAMS_NAGLE_EN_MASK 0x1
209 #define TCP_UPDATE_PARAMS_NAGLE_EN_SHIFT 13
210 #define TCP_UPDATE_PARAMS_KA_RESTART_MASK 0x1
211 #define TCP_UPDATE_PARAMS_KA_RESTART_SHIFT 14
212 #define TCP_UPDATE_PARAMS_RETRANSMIT_RESTART_MASK 0x1
213 #define TCP_UPDATE_PARAMS_RETRANSMIT_RESTART_SHIFT 15
214 __le16 remote_mac_addr_lo
;
215 __le16 remote_mac_addr_mid
;
216 __le16 remote_mac_addr_hi
;
224 __le32 initial_rcv_wnd
;
229 /* toe upload parameters */
230 struct tcp_upload_params
{
244 __le32 ts_recent_age
;
246 __le32 ka_timeout_delta
;
247 __le32 rt_timeout_delta
;
249 u8 snd_wnd_probe_cnt
;
255 #endif /* __TCP_COMMON__ */