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.
5 */
6
7#ifndef __TCP_COMMON__
8#define __TCP_COMMON__
9
10/********************/
11/* TCP FW CONSTANTS */
12/********************/
13
14#define TCP_INVALID_TIMEOUT_VAL -1
15
16/* OOO opaque data received from LL2 */
17struct ooo_opaque {
18 __le32 cid;
19 u8 drop_isle;
20 u8 drop_size;
21 u8 ooo_opcode;
22 u8 ooo_isle;
23};
24
25/* tcp connect mode enum */
26enum tcp_connect_mode {
27 TCP_CONNECT_ACTIVE,
28 TCP_CONNECT_PASSIVE,
29 MAX_TCP_CONNECT_MODE
30};
31
32/* tcp function init parameters */
33struct tcp_init_params {
34 __le32 two_msl_timer;
35 __le16 tx_sws_timer;
36 u8 max_fin_rt;
37 u8 reserved[9];
38};
39
40/* tcp IPv4/IPv6 enum */
41enum tcp_ip_version {
42 TCP_IPV4,
43 TCP_IPV6,
44 MAX_TCP_IP_VERSION
45};
46
47/* tcp offload parameters */
48struct 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;
55 __le16 vlan_id;
56 __le16 flags;
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
77 u8 ip_version;
78 u8 reserved0[3];
79 __le32 remote_ip[4];
80 __le32 local_ip[4];
81 __le32 flow_label;
82 u8 ttl;
83 u8 tos_or_tc;
84 __le16 remote_port;
85 __le16 local_port;
86 __le16 mss;
87 u8 rcv_wnd_scale;
88 u8 connect_mode;
89 __le16 srtt;
90 __le32 ss_thresh;
91 __le32 rcv_wnd;
92 __le32 cwnd;
93 u8 ka_max_probe_cnt;
94 u8 dup_ack_theshold;
95 __le16 reserved1;
96 __le32 ka_timeout;
97 __le32 ka_interval;
98 __le32 max_rt_time;
99 __le32 initial_rcv_wnd;
100 __le32 rcv_next;
101 __le32 snd_una;
102 __le32 snd_next;
103 __le32 snd_max;
104 __le32 snd_wnd;
105 __le32 snd_wl1;
106 __le32 ts_recent;
107 __le32 ts_recent_age;
108 __le32 total_rt;
109 __le32 ka_timeout_delta;
110 __le32 rt_timeout_delta;
111 u8 dup_ack_cnt;
112 u8 snd_wnd_probe_cnt;
113 u8 ka_probe_cnt;
114 u8 rt_cnt;
115 __le16 rtt_var;
116 __le16 fw_internal;
117 u8 snd_wnd_scale;
118 u8 ack_frequency;
119 __le16 da_timeout_value;
120 __le32 reserved3;
121};
122
123/* tcp offload parameters */
124struct 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;
131 __le16 vlan_id;
132 __le16 flags;
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
143 u8 ip_version;
144 u8 reserved1[3];
145 __le32 remote_ip[4];
146 __le32 local_ip[4];
147 __le32 flow_label;
148 u8 ttl;
149 u8 tos_or_tc;
150 __le16 remote_port;
151 __le16 local_port;
152 __le16 mss;
153 u8 rcv_wnd_scale;
154 u8 connect_mode;
155 __le16 syn_ip_payload_length;
156 __le32 syn_phy_addr_lo;
157 __le32 syn_phy_addr_hi;
158 __le32 cwnd;
159 u8 ka_max_probe_cnt;
160 u8 reserved2[3];
161 __le32 ka_timeout;
162 __le32 ka_interval;
163 __le32 max_rt_time;
164 __le32 reserved3[16];
165};
166
167/* tcp IPv4/IPv6 enum */
168enum tcp_seg_placement_event {
169 TCP_EVENT_ADD_PEN,
170 TCP_EVENT_ADD_NEW_ISLE,
171 TCP_EVENT_ADD_ISLE_RIGHT,
172 TCP_EVENT_ADD_ISLE_LEFT,
173 TCP_EVENT_JOIN,
174 TCP_EVENT_DELETE_ISLES,
175 TCP_EVENT_NOP,
176 MAX_TCP_SEG_PLACEMENT_EVENT
177};
178
179/* tcp init parameters */
180struct tcp_update_params {
181 __le16 flags;
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;
217 __le16 mss;
218 u8 ttl;
219 u8 tos_or_tc;
220 __le32 ka_timeout;
221 __le32 ka_interval;
222 __le32 max_rt_time;
223 __le32 flow_label;
224 __le32 initial_rcv_wnd;
225 u8 ka_max_probe_cnt;
226 u8 reserved1[7];
227};
228
229/* toe upload parameters */
230struct tcp_upload_params {
231 __le32 rcv_next;
232 __le32 snd_una;
233 __le32 snd_next;
234 __le32 snd_max;
235 __le32 snd_wnd;
236 __le32 rcv_wnd;
237 __le32 snd_wl1;
238 __le32 cwnd;
239 __le32 ss_thresh;
240 __le16 srtt;
241 __le16 rtt_var;
242 __le32 ts_time;
243 __le32 ts_recent;
244 __le32 ts_recent_age;
245 __le32 total_rt;
246 __le32 ka_timeout_delta;
247 __le32 rt_timeout_delta;
248 u8 dup_ack_cnt;
249 u8 snd_wnd_probe_cnt;
250 u8 ka_probe_cnt;
251 u8 rt_cnt;
252 __le32 reserved;
253};
254
255#endif /* __TCP_COMMON__ */
256

source code of linux/include/linux/qed/tcp_common.h