xref: /linux/drivers/net/ethernet/intel/idpf/idpf_lan_txrx.h (revision 0b364cf53b20204e92bac7c6ebd1ee7d3ec62931)
1 /* SPDX-License-Identifier: GPL-2.0-only */
2 /* Copyright (C) 2023 Intel Corporation */
3 
4 #ifndef _IDPF_LAN_TXRX_H_
5 #define _IDPF_LAN_TXRX_H_
6 
7 #include <linux/bits.h>
8 
9 enum idpf_rss_hash {
10 	IDPF_HASH_INVALID			= 0,
11 	/* Values 1 - 28 are reserved for future use */
12 	IDPF_HASH_NONF_UNICAST_IPV4_UDP		= 29,
13 	IDPF_HASH_NONF_MULTICAST_IPV4_UDP,
14 	IDPF_HASH_NONF_IPV4_UDP,
15 	IDPF_HASH_NONF_IPV4_TCP_SYN_NO_ACK,
16 	IDPF_HASH_NONF_IPV4_TCP,
17 	IDPF_HASH_NONF_IPV4_SCTP,
18 	IDPF_HASH_NONF_IPV4_OTHER,
19 	IDPF_HASH_FRAG_IPV4,
20 	/* Values 37-38 are reserved */
21 	IDPF_HASH_NONF_UNICAST_IPV6_UDP		= 39,
22 	IDPF_HASH_NONF_MULTICAST_IPV6_UDP,
23 	IDPF_HASH_NONF_IPV6_UDP,
24 	IDPF_HASH_NONF_IPV6_TCP_SYN_NO_ACK,
25 	IDPF_HASH_NONF_IPV6_TCP,
26 	IDPF_HASH_NONF_IPV6_SCTP,
27 	IDPF_HASH_NONF_IPV6_OTHER,
28 	IDPF_HASH_FRAG_IPV6,
29 	IDPF_HASH_NONF_RSVD47,
30 	IDPF_HASH_NONF_FCOE_OX,
31 	IDPF_HASH_NONF_FCOE_RX,
32 	IDPF_HASH_NONF_FCOE_OTHER,
33 	/* Values 51-62 are reserved */
34 	IDPF_HASH_L2_PAYLOAD			= 63,
35 
36 	IDPF_HASH_MAX
37 };
38 
39 /* Supported RSS offloads */
40 #define IDPF_DEFAULT_RSS_HASH			\
41 	(BIT_ULL(IDPF_HASH_NONF_IPV4_UDP) |	\
42 	BIT_ULL(IDPF_HASH_NONF_IPV4_SCTP) |	\
43 	BIT_ULL(IDPF_HASH_NONF_IPV4_TCP) |	\
44 	BIT_ULL(IDPF_HASH_NONF_IPV4_OTHER) |	\
45 	BIT_ULL(IDPF_HASH_FRAG_IPV4) |		\
46 	BIT_ULL(IDPF_HASH_NONF_IPV6_UDP) |	\
47 	BIT_ULL(IDPF_HASH_NONF_IPV6_TCP) |	\
48 	BIT_ULL(IDPF_HASH_NONF_IPV6_SCTP) |	\
49 	BIT_ULL(IDPF_HASH_NONF_IPV6_OTHER) |	\
50 	BIT_ULL(IDPF_HASH_FRAG_IPV6) |		\
51 	BIT_ULL(IDPF_HASH_L2_PAYLOAD))
52 
53 #define IDPF_DEFAULT_RSS_HASH_EXPANDED (IDPF_DEFAULT_RSS_HASH | \
54 	BIT_ULL(IDPF_HASH_NONF_IPV4_TCP_SYN_NO_ACK) |		\
55 	BIT_ULL(IDPF_HASH_NONF_UNICAST_IPV4_UDP) |		\
56 	BIT_ULL(IDPF_HASH_NONF_MULTICAST_IPV4_UDP) |		\
57 	BIT_ULL(IDPF_HASH_NONF_IPV6_TCP_SYN_NO_ACK) |		\
58 	BIT_ULL(IDPF_HASH_NONF_UNICAST_IPV6_UDP) |		\
59 	BIT_ULL(IDPF_HASH_NONF_MULTICAST_IPV6_UDP))
60 
61 /* For idpf_splitq_base_tx_compl_desc */
62 #define IDPF_TXD_COMPLQ_GEN_S		15
63 #define IDPF_TXD_COMPLQ_GEN_M		BIT_ULL(IDPF_TXD_COMPLQ_GEN_S)
64 #define IDPF_TXD_COMPLQ_COMPL_TYPE_S	11
65 #define IDPF_TXD_COMPLQ_COMPL_TYPE_M	GENMASK_ULL(13, 11)
66 #define IDPF_TXD_COMPLQ_QID_S		0
67 #define IDPF_TXD_COMPLQ_QID_M		GENMASK_ULL(9, 0)
68 
69 /* For base mode TX descriptors */
70 
71 #define IDPF_TXD_CTX_QW0_TUNN_L4T_CS_S	23
72 #define IDPF_TXD_CTX_QW0_TUNN_L4T_CS_M	BIT_ULL(IDPF_TXD_CTX_QW0_TUNN_L4T_CS_S)
73 #define IDPF_TXD_CTX_QW0_TUNN_DECTTL_S	19
74 #define IDPF_TXD_CTX_QW0_TUNN_DECTTL_M	\
75 	(0xFULL << IDPF_TXD_CTX_QW0_TUNN_DECTTL_S)
76 #define IDPF_TXD_CTX_QW0_TUNN_NATLEN_S	12
77 #define IDPF_TXD_CTX_QW0_TUNN_NATLEN_M	\
78 	(0X7FULL << IDPF_TXD_CTX_QW0_TUNN_NATLEN_S)
79 #define IDPF_TXD_CTX_QW0_TUNN_EIP_NOINC_S	11
80 #define IDPF_TXD_CTX_QW0_TUNN_EIP_NOINC_M    \
81 	BIT_ULL(IDPF_TXD_CTX_QW0_TUNN_EIP_NOINC_S)
82 #define IDPF_TXD_CTX_EIP_NOINC_IPID_CONST	\
83 	IDPF_TXD_CTX_QW0_TUNN_EIP_NOINC_M
84 #define IDPF_TXD_CTX_QW0_TUNN_NATT_S	        9
85 #define IDPF_TXD_CTX_QW0_TUNN_NATT_M	(0x3ULL << IDPF_TXD_CTX_QW0_TUNN_NATT_S)
86 #define IDPF_TXD_CTX_UDP_TUNNELING	BIT_ULL(IDPF_TXD_CTX_QW0_TUNN_NATT_S)
87 #define IDPF_TXD_CTX_GRE_TUNNELING	(0x2ULL << IDPF_TXD_CTX_QW0_TUNN_NATT_S)
88 #define IDPF_TXD_CTX_QW0_TUNN_EXT_IPLEN_S	2
89 #define IDPF_TXD_CTX_QW0_TUNN_EXT_IPLEN_M	\
90 	(0x3FULL << IDPF_TXD_CTX_QW0_TUNN_EXT_IPLEN_S)
91 #define IDPF_TXD_CTX_QW0_TUNN_EXT_IP_S	0
92 #define IDPF_TXD_CTX_QW0_TUNN_EXT_IP_M	\
93 	(0x3ULL << IDPF_TXD_CTX_QW0_TUNN_EXT_IP_S)
94 
95 #define IDPF_TXD_CTX_QW1_MSS_S		50
96 #define IDPF_TXD_CTX_QW1_MSS_M		GENMASK_ULL(63, 50)
97 #define IDPF_TXD_CTX_QW1_TSO_LEN_S	30
98 #define IDPF_TXD_CTX_QW1_TSO_LEN_M	GENMASK_ULL(47, 30)
99 #define IDPF_TXD_CTX_QW1_CMD_S		4
100 #define IDPF_TXD_CTX_QW1_CMD_M		GENMASK_ULL(15, 4)
101 #define IDPF_TXD_CTX_QW1_DTYPE_S	0
102 #define IDPF_TXD_CTX_QW1_DTYPE_M	GENMASK_ULL(3, 0)
103 #define IDPF_TXD_QW1_L2TAG1_S		48
104 #define IDPF_TXD_QW1_L2TAG1_M		GENMASK_ULL(63, 48)
105 #define IDPF_TXD_QW1_TX_BUF_SZ_S	34
106 #define IDPF_TXD_QW1_TX_BUF_SZ_M	GENMASK_ULL(47, 34)
107 #define IDPF_TXD_QW1_OFFSET_S		16
108 #define IDPF_TXD_QW1_OFFSET_M		GENMASK_ULL(33, 16)
109 #define IDPF_TXD_QW1_CMD_S		4
110 #define IDPF_TXD_QW1_CMD_M		GENMASK_ULL(15, 4)
111 #define IDPF_TXD_QW1_DTYPE_S		0
112 #define IDPF_TXD_QW1_DTYPE_M		GENMASK_ULL(3, 0)
113 
114 /* TX Completion Descriptor Completion Types */
115 #define IDPF_TXD_COMPLT_ITR_FLUSH	0
116 /* Descriptor completion type 1 is reserved */
117 #define IDPF_TXD_COMPLT_RS		2
118 /* Descriptor completion type 3 is reserved */
119 #define IDPF_TXD_COMPLT_RE		4
120 #define IDPF_TXD_COMPLT_SW_MARKER	5
121 
122 enum idpf_tx_desc_dtype_value {
123 	IDPF_TX_DESC_DTYPE_DATA				= 0,
124 	IDPF_TX_DESC_DTYPE_CTX				= 1,
125 	/* DTYPE 2 is reserved
126 	 * DTYPE 3 is free for future use
127 	 * DTYPE 4 is reserved
128 	 */
129 	IDPF_TX_DESC_DTYPE_FLEX_TSO_CTX			= 5,
130 	/* DTYPE 6 is reserved */
131 	IDPF_TX_DESC_DTYPE_FLEX_L2TAG1_L2TAG2		= 7,
132 	/* DTYPE 8, 9 are free for future use
133 	 * DTYPE 10 is reserved
134 	 * DTYPE 11 is free for future use
135 	 */
136 	IDPF_TX_DESC_DTYPE_FLEX_FLOW_SCHE		= 12,
137 	/* DTYPE 13, 14 are free for future use */
138 
139 	/* DESC_DONE - HW has completed write-back of descriptor */
140 	IDPF_TX_DESC_DTYPE_DESC_DONE			= 15,
141 };
142 
143 enum idpf_tx_ctx_desc_cmd_bits {
144 	IDPF_TX_CTX_DESC_TSO		= 0x01,
145 	IDPF_TX_CTX_DESC_TSYN		= 0x02,
146 	IDPF_TX_CTX_DESC_IL2TAG2	= 0x04,
147 	IDPF_TX_CTX_DESC_RSVD		= 0x08,
148 	IDPF_TX_CTX_DESC_SWTCH_NOTAG	= 0x00,
149 	IDPF_TX_CTX_DESC_SWTCH_UPLINK	= 0x10,
150 	IDPF_TX_CTX_DESC_SWTCH_LOCAL	= 0x20,
151 	IDPF_TX_CTX_DESC_SWTCH_VSI	= 0x30,
152 	IDPF_TX_CTX_DESC_FILT_AU_EN	= 0x40,
153 	IDPF_TX_CTX_DESC_FILT_AU_EVICT	= 0x80,
154 	IDPF_TX_CTX_DESC_RSVD1		= 0xF00
155 };
156 
157 enum idpf_tx_desc_len_fields {
158 	/* Note: These are predefined bit offsets */
159 	IDPF_TX_DESC_LEN_MACLEN_S	= 0, /* 7 BITS */
160 	IDPF_TX_DESC_LEN_IPLEN_S	= 7, /* 7 BITS */
161 	IDPF_TX_DESC_LEN_L4_LEN_S	= 14 /* 4 BITS */
162 };
163 
164 enum idpf_tx_base_desc_cmd_bits {
165 	IDPF_TX_DESC_CMD_EOP			= BIT(0),
166 	IDPF_TX_DESC_CMD_RS			= BIT(1),
167 	 /* only on VFs else RSVD */
168 	IDPF_TX_DESC_CMD_ICRC			= BIT(2),
169 	IDPF_TX_DESC_CMD_IL2TAG1		= BIT(3),
170 	IDPF_TX_DESC_CMD_RSVD1			= BIT(4),
171 	IDPF_TX_DESC_CMD_IIPT_IPV6		= BIT(5),
172 	IDPF_TX_DESC_CMD_IIPT_IPV4		= BIT(6),
173 	IDPF_TX_DESC_CMD_IIPT_IPV4_CSUM		= GENMASK(6, 5),
174 	IDPF_TX_DESC_CMD_RSVD2			= BIT(7),
175 	IDPF_TX_DESC_CMD_L4T_EOFT_TCP		= BIT(8),
176 	IDPF_TX_DESC_CMD_L4T_EOFT_SCTP		= BIT(9),
177 	IDPF_TX_DESC_CMD_L4T_EOFT_UDP		= GENMASK(9, 8),
178 	IDPF_TX_DESC_CMD_RSVD3			= BIT(10),
179 	IDPF_TX_DESC_CMD_RSVD4			= BIT(11),
180 };
181 
182 /* Transmit descriptors  */
183 /* splitq tx buf, singleq tx buf and singleq compl desc */
184 struct idpf_base_tx_desc {
185 	__le64 buf_addr; /* Address of descriptor's data buf */
186 	__le64 qw1; /* type_cmd_offset_bsz_l2tag1 */
187 }; /* read used with buffer queues */
188 
189 struct idpf_splitq_tx_compl_desc {
190 	/* qid=[10:0] comptype=[13:11] rsvd=[14] gen=[15] */
191 	__le16 qid_comptype_gen;
192 	union {
193 		__le16 q_head; /* Queue head */
194 		__le16 compl_tag; /* Completion tag */
195 	} q_head_compl_tag;
196 	u8 ts[3];
197 	u8 rsvd; /* Reserved */
198 }; /* writeback used with completion queues */
199 
200 /* Context descriptors */
201 struct idpf_base_tx_ctx_desc {
202 	struct {
203 		__le32 tunneling_params;
204 		__le16 l2tag2;
205 		__le16 rsvd1;
206 	} qw0;
207 	__le64 qw1; /* type_cmd_tlen_mss/rt_hint */
208 };
209 
210 /* Common cmd field defines for all desc except Flex Flow Scheduler (0x0C) */
211 enum idpf_tx_flex_desc_cmd_bits {
212 	IDPF_TX_FLEX_DESC_CMD_EOP			= BIT(0),
213 	IDPF_TX_FLEX_DESC_CMD_RS			= BIT(1),
214 	IDPF_TX_FLEX_DESC_CMD_RE			= BIT(2),
215 	IDPF_TX_FLEX_DESC_CMD_IL2TAG1			= BIT(3),
216 	IDPF_TX_FLEX_DESC_CMD_DUMMY			= BIT(4),
217 	IDPF_TX_FLEX_DESC_CMD_CS_EN			= BIT(5),
218 	IDPF_TX_FLEX_DESC_CMD_FILT_AU_EN		= BIT(6),
219 	IDPF_TX_FLEX_DESC_CMD_FILT_AU_EVICT		= BIT(7),
220 };
221 
222 struct idpf_flex_tx_desc {
223 	__le64 buf_addr;	/* Packet buffer address */
224 	struct {
225 #define IDPF_FLEX_TXD_QW1_DTYPE_S	0
226 #define IDPF_FLEX_TXD_QW1_DTYPE_M	GENMASK(4, 0)
227 #define IDPF_FLEX_TXD_QW1_CMD_S		5
228 #define IDPF_FLEX_TXD_QW1_CMD_M		GENMASK(15, 5)
229 		__le16 cmd_dtype;
230 		/* DTYPE=IDPF_TX_DESC_DTYPE_FLEX_L2TAG1_L2TAG2 (0x07) */
231 		struct {
232 			__le16 l2tag1;
233 			__le16 l2tag2;
234 		} l2tags;
235 		__le16 buf_size;
236 	} qw1;
237 };
238 
239 struct idpf_flex_tx_sched_desc {
240 	__le64 buf_addr;	/* Packet buffer address */
241 
242 	/* DTYPE = IDPF_TX_DESC_DTYPE_FLEX_FLOW_SCHE_16B (0x0C) */
243 	struct {
244 		u8 cmd_dtype;
245 #define IDPF_TXD_FLEX_FLOW_DTYPE_M	GENMASK(4, 0)
246 #define IDPF_TXD_FLEX_FLOW_CMD_EOP	BIT(5)
247 #define IDPF_TXD_FLEX_FLOW_CMD_CS_EN	BIT(6)
248 #define IDPF_TXD_FLEX_FLOW_CMD_RE	BIT(7)
249 
250 		/* [23:23] Horizon Overflow bit, [22:0] timestamp */
251 		u8 ts[3];
252 #define IDPF_TXD_FLOW_SCH_HORIZON_OVERFLOW_M	BIT(7)
253 
254 		__le16 compl_tag;
255 		__le16 rxr_bufsize;
256 #define IDPF_TXD_FLEX_FLOW_RXR		BIT(14)
257 #define IDPF_TXD_FLEX_FLOW_BUFSIZE_M	GENMASK(13, 0)
258 	} qw1;
259 };
260 
261 /* Common cmd fields for all flex context descriptors
262  * Note: these defines already account for the 5 bit dtype in the cmd_dtype
263  * field
264  */
265 enum idpf_tx_flex_ctx_desc_cmd_bits {
266 	IDPF_TX_FLEX_CTX_DESC_CMD_TSO			= BIT(5),
267 	IDPF_TX_FLEX_CTX_DESC_CMD_TSYN_EN		= BIT(6),
268 	IDPF_TX_FLEX_CTX_DESC_CMD_L2TAG2		= BIT(7),
269 	IDPF_TX_FLEX_CTX_DESC_CMD_SWTCH_UPLNK		= BIT(9),
270 	IDPF_TX_FLEX_CTX_DESC_CMD_SWTCH_LOCAL		= BIT(10),
271 	IDPF_TX_FLEX_CTX_DESC_CMD_SWTCH_TARGETVSI	= GENMASK(10, 9),
272 };
273 
274 /* Standard flex descriptor TSO context quad word */
275 struct idpf_flex_tx_tso_ctx_qw {
276 	__le32 flex_tlen;
277 #define IDPF_TXD_FLEX_CTX_TLEN_M	GENMASK(17, 0)
278 #define IDPF_TXD_FLEX_TSO_CTX_FLEX_S	24
279 	__le16 mss_rt;
280 #define IDPF_TXD_FLEX_CTX_MSS_RT_M	GENMASK(13, 0)
281 	u8 hdr_len;
282 	u8 flex;
283 };
284 
285 struct idpf_flex_tx_ctx_desc {
286 	/* DTYPE = IDPF_TX_DESC_DTYPE_FLEX_TSO_CTX (0x05) */
287 	struct {
288 		struct idpf_flex_tx_tso_ctx_qw qw0;
289 		struct {
290 			__le16 cmd_dtype;
291 			u8 flex[6];
292 		} qw1;
293 	} tso;
294 };
295 #endif /* _IDPF_LAN_TXRX_H_ */
296