net/ice: fix outer L4 checksum in scalar Rx
[dpdk.git] / drivers / net / iavf / iavf_generic_flow.h
1 /* SPDX-License-Identifier: BSD-3-Clause
2  * Copyright(c) 2019 Intel Corporation
3  */
4
5 #ifndef _IAVF_GENERIC_FLOW_H_
6 #define _IAVF_GENERIC_FLOW_H_
7
8 #include <rte_flow_driver.h>
9
10 /* protocol */
11
12 #define IAVF_PROT_MAC_INNER         (1ULL << 1)
13 #define IAVF_PROT_MAC_OUTER         (1ULL << 2)
14 #define IAVF_PROT_VLAN_INNER        (1ULL << 3)
15 #define IAVF_PROT_VLAN_OUTER        (1ULL << 4)
16 #define IAVF_PROT_IPV4_INNER        (1ULL << 5)
17 #define IAVF_PROT_IPV4_OUTER        (1ULL << 6)
18 #define IAVF_PROT_IPV6_INNER        (1ULL << 7)
19 #define IAVF_PROT_IPV6_OUTER        (1ULL << 8)
20 #define IAVF_PROT_TCP_INNER         (1ULL << 9)
21 #define IAVF_PROT_TCP_OUTER         (1ULL << 10)
22 #define IAVF_PROT_UDP_INNER         (1ULL << 11)
23 #define IAVF_PROT_UDP_OUTER         (1ULL << 12)
24 #define IAVF_PROT_SCTP_INNER        (1ULL << 13)
25 #define IAVF_PROT_SCTP_OUTER        (1ULL << 14)
26 #define IAVF_PROT_ICMP4_INNER       (1ULL << 15)
27 #define IAVF_PROT_ICMP4_OUTER       (1ULL << 16)
28 #define IAVF_PROT_ICMP6_INNER       (1ULL << 17)
29 #define IAVF_PROT_ICMP6_OUTER       (1ULL << 18)
30 #define IAVF_PROT_VXLAN             (1ULL << 19)
31 #define IAVF_PROT_NVGRE             (1ULL << 20)
32 #define IAVF_PROT_GTPU              (1ULL << 21)
33 #define IAVF_PROT_ESP               (1ULL << 22)
34 #define IAVF_PROT_AH                (1ULL << 23)
35 #define IAVF_PROT_L2TPV3OIP         (1ULL << 24)
36 #define IAVF_PROT_PFCP              (1ULL << 25)
37 #define IAVF_PROT_ECPRI             (1ULL << 26)
38 #define IAVF_PROT_L2TPV2            (1ULL << 27)
39
40
41 /* field */
42
43 #define IAVF_SMAC                   (1ULL << 63)
44 #define IAVF_DMAC                   (1ULL << 62)
45 #define IAVF_ETHERTYPE              (1ULL << 61)
46 #define IAVF_IP_SRC                 (1ULL << 60)
47 #define IAVF_IP_DST                 (1ULL << 59)
48 #define IAVF_IP_PROTO               (1ULL << 58)
49 #define IAVF_IP_TTL                 (1ULL << 57)
50 #define IAVF_IP_TOS                 (1ULL << 56)
51 #define IAVF_SPORT                  (1ULL << 55)
52 #define IAVF_DPORT                  (1ULL << 54)
53 #define IAVF_ICMP_TYPE              (1ULL << 53)
54 #define IAVF_ICMP_CODE              (1ULL << 52)
55 #define IAVF_VXLAN_VNI              (1ULL << 51)
56 #define IAVF_NVGRE_TNI              (1ULL << 50)
57 #define IAVF_GTPU_TEID              (1ULL << 49)
58 #define IAVF_GTPU_QFI               (1ULL << 48)
59 #define IAVF_ESP_SPI                (1ULL << 47)
60 #define IAVF_AH_SPI                 (1ULL << 46)
61 #define IAVF_L2TPV3OIP_SESSION_ID   (1ULL << 45)
62 #define IAVF_PFCP_S_FIELD           (1ULL << 44)
63 #define IAVF_PFCP_SEID              (1ULL << 43)
64 #define IAVF_ECPRI_PC_RTC_ID        (1ULL << 42)
65 #define IAVF_IP_PKID                (1ULL << 41)
66 #define IAVF_L2TPV2_SESSION_ID      (1ULL << 40)
67
68 /* input set */
69
70 #define IAVF_INSET_NONE             0ULL
71
72 /* non-tunnel */
73
74 #define IAVF_INSET_SMAC         (IAVF_PROT_MAC_OUTER | IAVF_SMAC)
75 #define IAVF_INSET_DMAC         (IAVF_PROT_MAC_OUTER | IAVF_DMAC)
76 #define IAVF_INSET_VLAN_INNER   (IAVF_PROT_VLAN_INNER)
77 #define IAVF_INSET_VLAN_OUTER   (IAVF_PROT_VLAN_OUTER)
78 #define IAVF_INSET_ETHERTYPE    (IAVF_ETHERTYPE)
79
80 #define IAVF_INSET_IPV4_SRC \
81         (IAVF_PROT_IPV4_OUTER | IAVF_IP_SRC)
82 #define IAVF_INSET_IPV4_DST \
83         (IAVF_PROT_IPV4_OUTER | IAVF_IP_DST)
84 #define IAVF_INSET_IPV4_TOS \
85         (IAVF_PROT_IPV4_OUTER | IAVF_IP_TOS)
86 #define IAVF_INSET_IPV4_PROTO \
87         (IAVF_PROT_IPV4_OUTER | IAVF_IP_PROTO)
88 #define IAVF_INSET_IPV4_TTL \
89         (IAVF_PROT_IPV4_OUTER | IAVF_IP_TTL)
90 #define IAVF_INSET_IPV4_ID \
91         (IAVF_PROT_IPV4_OUTER | IAVF_IP_PKID)
92 #define IAVF_INSET_IPV6_SRC \
93         (IAVF_PROT_IPV6_OUTER | IAVF_IP_SRC)
94 #define IAVF_INSET_IPV6_DST \
95         (IAVF_PROT_IPV6_OUTER | IAVF_IP_DST)
96 #define IAVF_INSET_IPV6_NEXT_HDR \
97         (IAVF_PROT_IPV6_OUTER | IAVF_IP_PROTO)
98 #define IAVF_INSET_IPV6_HOP_LIMIT \
99         (IAVF_PROT_IPV6_OUTER | IAVF_IP_TTL)
100 #define IAVF_INSET_IPV6_TC \
101         (IAVF_PROT_IPV6_OUTER | IAVF_IP_TOS)
102 #define IAVF_INSET_IPV6_ID \
103         (IAVF_PROT_IPV6_OUTER | IAVF_IP_PKID)
104
105 #define IAVF_INSET_TUN_IPV4_SRC \
106         (IAVF_PROT_IPV4_INNER | IAVF_IP_SRC)
107 #define IAVF_INSET_TUN_IPV4_DST \
108         (IAVF_PROT_IPV4_INNER | IAVF_IP_DST)
109 #define IAVF_INSET_TUN_IPV4_TOS \
110         (IAVF_PROT_IPV4_INNER | IAVF_IP_TOS)
111 #define IAVF_INSET_TUN_IPV4_PROTO \
112         (IAVF_PROT_IPV4_INNER | IAVF_IP_PROTO)
113 #define IAVF_INSET_TUN_IPV4_TTL \
114         (IAVF_PROT_IPV4_INNER | IAVF_IP_TTL)
115 #define IAVF_INSET_TUN_IPV6_SRC \
116         (IAVF_PROT_IPV6_INNER | IAVF_IP_SRC)
117 #define IAVF_INSET_TUN_IPV6_DST \
118         (IAVF_PROT_IPV6_INNER | IAVF_IP_DST)
119 #define IAVF_INSET_TUN_IPV6_NEXT_HDR \
120         (IAVF_PROT_IPV6_INNER | IAVF_IP_PROTO)
121 #define IAVF_INSET_TUN_IPV6_HOP_LIMIT \
122         (IAVF_PROT_IPV6_INNER | IAVF_IP_TTL)
123 #define IAVF_INSET_TUN_IPV6_TC \
124         (IAVF_PROT_IPV6_INNER | IAVF_IP_TOS)
125
126 #define IAVF_INSET_TCP_SRC_PORT \
127         (IAVF_PROT_TCP_OUTER | IAVF_SPORT)
128 #define IAVF_INSET_TCP_DST_PORT \
129         (IAVF_PROT_TCP_OUTER | IAVF_DPORT)
130 #define IAVF_INSET_UDP_SRC_PORT \
131         (IAVF_PROT_UDP_OUTER | IAVF_SPORT)
132 #define IAVF_INSET_UDP_DST_PORT \
133         (IAVF_PROT_UDP_OUTER | IAVF_DPORT)
134
135 #define IAVF_INSET_TUN_TCP_SRC_PORT \
136         (IAVF_PROT_TCP_INNER | IAVF_SPORT)
137 #define IAVF_INSET_TUN_TCP_DST_PORT \
138         (IAVF_PROT_TCP_INNER | IAVF_DPORT)
139 #define IAVF_INSET_TUN_UDP_SRC_PORT \
140         (IAVF_PROT_UDP_INNER | IAVF_SPORT)
141 #define IAVF_INSET_TUN_UDP_DST_PORT \
142         (IAVF_PROT_UDP_INNER | IAVF_DPORT)
143
144 #define IAVF_INSET_SCTP_SRC_PORT \
145         (IAVF_PROT_SCTP_OUTER | IAVF_SPORT)
146 #define IAVF_INSET_SCTP_DST_PORT \
147         (IAVF_PROT_SCTP_OUTER | IAVF_DPORT)
148 #define IAVF_INSET_ICMP4_SRC_PORT \
149         (IAVF_PROT_ICMP4_OUTER | IAVF_SPORT)
150 #define IAVF_INSET_ICMP4_DST_PORT \
151         (IAVF_PROT_ICMP4_OUTER | IAVF_DPORT)
152 #define IAVF_INSET_ICMP6_SRC_PORT \
153         (IAVF_PROT_ICMP6_OUTER | IAVF_SPORT)
154 #define IAVF_INSET_ICMP6_DST_PORT \
155         (IAVF_PROT_ICMP6_OUTER | IAVF_DPORT)
156 #define IAVF_INSET_ICMP4_TYPE \
157         (IAVF_PROT_ICMP4_OUTER | IAVF_ICMP_TYPE)
158 #define IAVF_INSET_ICMP4_CODE \
159         (IAVF_PROT_ICMP4_OUTER | IAVF_ICMP_CODE)
160 #define IAVF_INSET_ICMP6_TYPE \
161         (IAVF_PROT_ICMP6_OUTER | IAVF_ICMP_TYPE)
162 #define IAVF_INSET_ICMP6_CODE \
163         (IAVF_PROT_ICMP6_OUTER | IAVF_ICMP_CODE)
164 #define IAVF_INSET_GTPU_TEID \
165         (IAVF_PROT_GTPU | IAVF_GTPU_TEID)
166 #define IAVF_INSET_GTPU_QFI \
167         (IAVF_PROT_GTPU | IAVF_GTPU_QFI)
168 #define IAVF_INSET_ESP_SPI \
169         (IAVF_PROT_ESP | IAVF_ESP_SPI)
170 #define IAVF_INSET_AH_SPI \
171         (IAVF_PROT_AH | IAVF_AH_SPI)
172 #define IAVF_INSET_L2TPV3OIP_SESSION_ID \
173         (IAVF_PROT_L2TPV3OIP | IAVF_L2TPV3OIP_SESSION_ID)
174 #define IAVF_INSET_PFCP_S_FIELD \
175         (IAVF_PROT_PFCP | IAVF_PFCP_S_FIELD)
176 #define IAVF_INSET_PFCP_SEID \
177         (IAVF_PROT_PFCP | IAVF_PFCP_S_FIELD | IAVF_PFCP_SEID)
178 #define IAVF_INSET_ECPRI \
179         (IAVF_PROT_ECPRI | IAVF_ECPRI_PC_RTC_ID)
180 #define IAVF_INSET_L2TPV2 \
181         (IAVF_PROT_L2TPV2 | IAVF_L2TPV2_SESSION_ID)
182
183 /* raw pattern */
184 extern enum rte_flow_item_type iavf_pattern_raw[];
185
186 /* empty pattern */
187 extern enum rte_flow_item_type iavf_pattern_empty[];
188
189 /* L2 */
190 extern enum rte_flow_item_type iavf_pattern_ethertype[];
191 extern enum rte_flow_item_type iavf_pattern_ethertype_vlan[];
192 extern enum rte_flow_item_type iavf_pattern_ethertype_qinq[];
193
194 /* ARP */
195 extern enum rte_flow_item_type iavf_pattern_eth_arp[];
196
197 /* non-tunnel IPv4 */
198 extern enum rte_flow_item_type iavf_pattern_eth_ipv4[];
199 extern enum rte_flow_item_type iavf_pattern_eth_vlan_ipv4[];
200 extern enum rte_flow_item_type iavf_pattern_eth_qinq_ipv4[];
201 extern enum rte_flow_item_type iavf_pattern_eth_ipv4_udp[];
202 extern enum rte_flow_item_type iavf_pattern_eth_vlan_ipv4_udp[];
203 extern enum rte_flow_item_type iavf_pattern_eth_qinq_ipv4_udp[];
204 extern enum rte_flow_item_type iavf_pattern_eth_ipv4_tcp[];
205 extern enum rte_flow_item_type iavf_pattern_eth_vlan_ipv4_tcp[];
206 extern enum rte_flow_item_type iavf_pattern_eth_qinq_ipv4_tcp[];
207 extern enum rte_flow_item_type iavf_pattern_eth_ipv4_sctp[];
208 extern enum rte_flow_item_type iavf_pattern_eth_vlan_ipv4_sctp[];
209 extern enum rte_flow_item_type iavf_pattern_eth_qinq_ipv4_sctp[];
210 extern enum rte_flow_item_type iavf_pattern_eth_ipv4_icmp[];
211 extern enum rte_flow_item_type iavf_pattern_eth_vlan_ipv4_icmp[];
212 extern enum rte_flow_item_type iavf_pattern_eth_qinq_ipv4_icmp[];
213
214 /* non-tunnel IPv6 */
215 extern enum rte_flow_item_type iavf_pattern_eth_ipv6[];
216 extern enum rte_flow_item_type iavf_pattern_eth_vlan_ipv6[];
217 extern enum rte_flow_item_type iavf_pattern_eth_qinq_ipv6[];
218 extern enum rte_flow_item_type iavf_pattern_eth_ipv6_frag_ext[];
219 extern enum rte_flow_item_type iavf_pattern_eth_vlan_ipv6_frag_ext[];
220 extern enum rte_flow_item_type iavf_pattern_eth_qinq_ipv6_frag_ext[];
221 extern enum rte_flow_item_type iavf_pattern_eth_ipv6_udp[];
222 extern enum rte_flow_item_type iavf_pattern_eth_vlan_ipv6_udp[];
223 extern enum rte_flow_item_type iavf_pattern_eth_qinq_ipv6_udp[];
224 extern enum rte_flow_item_type iavf_pattern_eth_ipv6_tcp[];
225 extern enum rte_flow_item_type iavf_pattern_eth_vlan_ipv6_tcp[];
226 extern enum rte_flow_item_type iavf_pattern_eth_qinq_ipv6_tcp[];
227 extern enum rte_flow_item_type iavf_pattern_eth_ipv6_sctp[];
228 extern enum rte_flow_item_type iavf_pattern_eth_vlan_ipv6_sctp[];
229 extern enum rte_flow_item_type iavf_pattern_eth_qinq_ipv6_sctp[];
230 extern enum rte_flow_item_type iavf_pattern_eth_ipv6_icmp6[];
231 extern enum rte_flow_item_type iavf_pattern_eth_vlan_ipv6_icmp6[];
232 extern enum rte_flow_item_type iavf_pattern_eth_qinq_ipv6_icmp6[];
233
234 /* IPv4 GTPC */
235 extern enum rte_flow_item_type iavf_pattern_eth_ipv4_gtpc[];
236
237 /* IPv4 GTPU (EH) */
238 extern enum rte_flow_item_type iavf_pattern_eth_ipv4_gtpu[];
239 extern enum rte_flow_item_type iavf_pattern_eth_ipv4_gtpu_eh[];
240
241 /* IPv6 GTPC */
242 extern enum rte_flow_item_type iavf_pattern_eth_ipv6_gtpc[];
243
244 /* IPv6 GTPU (EH) */
245 extern enum rte_flow_item_type iavf_pattern_eth_ipv6_gtpu[];
246 extern enum rte_flow_item_type iavf_pattern_eth_ipv6_gtpu_eh[];
247
248 /* IPv4 GTPU IPv4 */
249 extern enum rte_flow_item_type iavf_pattern_eth_ipv4_gtpu_ipv4[];
250 extern enum rte_flow_item_type iavf_pattern_eth_ipv4_gtpu_ipv4_udp[];
251 extern enum rte_flow_item_type iavf_pattern_eth_ipv4_gtpu_ipv4_tcp[];
252 extern enum rte_flow_item_type iavf_pattern_eth_ipv4_gtpu_ipv4_icmp[];
253
254 /* IPv4 GRE IPv4 UDP GTPU IPv4 */
255 extern enum rte_flow_item_type iavf_pattern_eth_ipv4_gre_ipv4_gtpu[];
256 extern enum rte_flow_item_type iavf_pattern_eth_ipv4_gre_ipv4_gtpu_ipv4[];
257 extern enum rte_flow_item_type iavf_pattern_eth_ipv4_gre_ipv4_gtpu_ipv4_udp[];
258 extern enum rte_flow_item_type iavf_pattern_eth_ipv4_gre_ipv4_gtpu_ipv4_tcp[];
259
260 /* IPv4 GRE IPv4 UDP GTPU IPv6 */
261 extern enum rte_flow_item_type iavf_pattern_eth_ipv4_gre_ipv4_gtpu_ipv6[];
262 extern enum rte_flow_item_type iavf_pattern_eth_ipv4_gre_ipv4_gtpu_ipv6_udp[];
263 extern enum rte_flow_item_type iavf_pattern_eth_ipv4_gre_ipv4_gtpu_ipv6_tcp[];
264
265 /* IPv4 GRE IPv6 UDP GTPU IPv4 */
266 extern enum rte_flow_item_type iavf_pattern_eth_ipv4_gre_ipv6_gtpu[];
267 extern enum rte_flow_item_type iavf_pattern_eth_ipv4_gre_ipv6_gtpu_ipv4[];
268 extern enum rte_flow_item_type iavf_pattern_eth_ipv4_gre_ipv6_gtpu_ipv4_udp[];
269 extern enum rte_flow_item_type iavf_pattern_eth_ipv4_gre_ipv6_gtpu_ipv4_tcp[];
270
271 /* IPv4 GRE IPv6 UDP GTPU IPv6 */
272 extern enum rte_flow_item_type iavf_pattern_eth_ipv4_gre_ipv6_gtpu_ipv6[];
273 extern enum rte_flow_item_type iavf_pattern_eth_ipv4_gre_ipv6_gtpu_ipv6_udp[];
274 extern enum rte_flow_item_type iavf_pattern_eth_ipv4_gre_ipv6_gtpu_ipv6_tcp[];
275
276 /* IPv6 GRE IPv4 UDP GTPU IPv4 */
277 extern enum rte_flow_item_type iavf_pattern_eth_ipv6_gre_ipv4_gtpu[];
278 extern enum rte_flow_item_type iavf_pattern_eth_ipv6_gre_ipv4_gtpu_ipv4[];
279 extern enum rte_flow_item_type iavf_pattern_eth_ipv6_gre_ipv4_gtpu_ipv4_udp[];
280 extern enum rte_flow_item_type iavf_pattern_eth_ipv6_gre_ipv4_gtpu_ipv4_tcp[];
281
282 /* IPv6 GRE IPv4 UDP GTPU IPv6 */
283 extern enum rte_flow_item_type iavf_pattern_eth_ipv6_gre_ipv4_gtpu_ipv6[];
284 extern enum rte_flow_item_type iavf_pattern_eth_ipv6_gre_ipv4_gtpu_ipv6_udp[];
285 extern enum rte_flow_item_type iavf_pattern_eth_ipv6_gre_ipv4_gtpu_ipv6_tcp[];
286
287 /* IPv6 GRE IPv6 UDP GTPU IPv4 */
288 extern enum rte_flow_item_type iavf_pattern_eth_ipv6_gre_ipv6_gtpu[];
289 extern enum rte_flow_item_type iavf_pattern_eth_ipv6_gre_ipv6_gtpu_ipv4[];
290 extern enum rte_flow_item_type iavf_pattern_eth_ipv6_gre_ipv6_gtpu_ipv4_udp[];
291 extern enum rte_flow_item_type iavf_pattern_eth_ipv6_gre_ipv6_gtpu_ipv4_tcp[];
292
293 /* IPv6 GRE IPv6 UDP GTPU IPv6 */
294 extern enum rte_flow_item_type iavf_pattern_eth_ipv6_gre_ipv6_gtpu_ipv6[];
295 extern enum rte_flow_item_type iavf_pattern_eth_ipv6_gre_ipv6_gtpu_ipv6_udp[];
296 extern enum rte_flow_item_type iavf_pattern_eth_ipv6_gre_ipv6_gtpu_ipv6_tcp[];
297
298 /* IPv4 GRE IPv4 UDP GTPU EH IPv4 */
299 extern enum rte_flow_item_type iavf_pattern_eth_ipv4_gre_ipv4_gtpu_eh[];
300 extern enum rte_flow_item_type iavf_pattern_eth_ipv4_gre_ipv4_gtpu_eh_ipv4[];
301 extern enum rte_flow_item_type iavf_pattern_eth_ipv4_gre_ipv4_gtpu_eh_ipv4_udp[];
302 extern enum rte_flow_item_type iavf_pattern_eth_ipv4_gre_ipv4_gtpu_eh_ipv4_tcp[];
303
304 /* IPv4 GRE IPv4 UDP GTPU EH IPv6 */
305 extern enum rte_flow_item_type iavf_pattern_eth_ipv4_gre_ipv4_gtpu_eh_ipv6[];
306 extern enum rte_flow_item_type iavf_pattern_eth_ipv4_gre_ipv4_gtpu_eh_ipv6_udp[];
307 extern enum rte_flow_item_type iavf_pattern_eth_ipv4_gre_ipv4_gtpu_eh_ipv6_tcp[];
308
309 /* IPv4 GRE IPv6 UDP GTPU EH IPv4 */
310 extern enum rte_flow_item_type iavf_pattern_eth_ipv4_gre_ipv6_gtpu_eh[];
311 extern enum rte_flow_item_type iavf_pattern_eth_ipv4_gre_ipv6_gtpu_eh_ipv4[];
312 extern enum rte_flow_item_type iavf_pattern_eth_ipv4_gre_ipv6_gtpu_eh_ipv4_udp[];
313 extern enum rte_flow_item_type iavf_pattern_eth_ipv4_gre_ipv6_gtpu_eh_ipv4_tcp[];
314
315 /* IPv4 GRE IPv6 UDP GTPU EH IPv6 */
316 extern enum rte_flow_item_type iavf_pattern_eth_ipv4_gre_ipv6_gtpu_eh_ipv6[];
317 extern enum rte_flow_item_type iavf_pattern_eth_ipv4_gre_ipv6_gtpu_eh_ipv6_udp[];
318 extern enum rte_flow_item_type iavf_pattern_eth_ipv4_gre_ipv6_gtpu_eh_ipv6_tcp[];
319
320 /* IPv6 GRE IPv4 UDP GTPU EH IPv4 */
321 extern enum rte_flow_item_type iavf_pattern_eth_ipv6_gre_ipv4_gtpu_eh[];
322 extern enum rte_flow_item_type iavf_pattern_eth_ipv6_gre_ipv4_gtpu_eh_ipv4[];
323 extern enum rte_flow_item_type iavf_pattern_eth_ipv6_gre_ipv4_gtpu_eh_ipv4_udp[];
324 extern enum rte_flow_item_type iavf_pattern_eth_ipv6_gre_ipv4_gtpu_eh_ipv4_tcp[];
325
326 /* IPv6 GRE IPv4 UDP GTPU EH IPv6 */
327 extern enum rte_flow_item_type iavf_pattern_eth_ipv6_gre_ipv4_gtpu_eh_ipv6[];
328 extern enum rte_flow_item_type iavf_pattern_eth_ipv6_gre_ipv4_gtpu_eh_ipv6_udp[];
329 extern enum rte_flow_item_type iavf_pattern_eth_ipv6_gre_ipv4_gtpu_eh_ipv6_tcp[];
330
331 /* IPv6 GRE IPv6 UDP GTPU EH IPv4 */
332 extern enum rte_flow_item_type iavf_pattern_eth_ipv6_gre_ipv6_gtpu_eh[];
333 extern enum rte_flow_item_type iavf_pattern_eth_ipv6_gre_ipv6_gtpu_eh_ipv4[];
334 extern enum rte_flow_item_type iavf_pattern_eth_ipv6_gre_ipv6_gtpu_eh_ipv4_udp[];
335 extern enum rte_flow_item_type iavf_pattern_eth_ipv6_gre_ipv6_gtpu_eh_ipv4_tcp[];
336
337 /* IPv6 GRE IPv6 UDP GTPU EH IPv6 */
338 extern enum rte_flow_item_type iavf_pattern_eth_ipv6_gre_ipv6_gtpu_eh_ipv6[];
339 extern enum rte_flow_item_type iavf_pattern_eth_ipv6_gre_ipv6_gtpu_eh_ipv6_udp[];
340 extern enum rte_flow_item_type iavf_pattern_eth_ipv6_gre_ipv6_gtpu_eh_ipv6_tcp[];
341
342 /* IPv4 GTPU IPv6 */
343 extern enum rte_flow_item_type iavf_pattern_eth_ipv4_gtpu_ipv6[];
344 extern enum rte_flow_item_type iavf_pattern_eth_ipv4_gtpu_ipv6_udp[];
345 extern enum rte_flow_item_type iavf_pattern_eth_ipv4_gtpu_ipv6_tcp[];
346 extern enum rte_flow_item_type iavf_pattern_eth_ipv4_gtpu_ipv6_icmp[];
347
348 /* IPv6 GTPU IPv4 */
349 extern enum rte_flow_item_type iavf_pattern_eth_ipv6_gtpu_ipv4[];
350 extern enum rte_flow_item_type iavf_pattern_eth_ipv6_gtpu_ipv4_udp[];
351 extern enum rte_flow_item_type iavf_pattern_eth_ipv6_gtpu_ipv4_tcp[];
352 extern enum rte_flow_item_type iavf_pattern_eth_ipv6_gtpu_ipv4_icmp[];
353
354 /* IPv6 GTPU IPv6 */
355 extern enum rte_flow_item_type iavf_pattern_eth_ipv6_gtpu_ipv6[];
356 extern enum rte_flow_item_type iavf_pattern_eth_ipv6_gtpu_ipv6_udp[];
357 extern enum rte_flow_item_type iavf_pattern_eth_ipv6_gtpu_ipv6_tcp[];
358 extern enum rte_flow_item_type iavf_pattern_eth_ipv6_gtpu_ipv6_icmp[];
359
360 /* IPv4 GTPU EH IPv4 */
361 extern enum rte_flow_item_type iavf_pattern_eth_ipv4_gtpu_eh_ipv4[];
362 extern enum rte_flow_item_type iavf_pattern_eth_ipv4_gtpu_eh_ipv4_udp[];
363 extern enum rte_flow_item_type iavf_pattern_eth_ipv4_gtpu_eh_ipv4_tcp[];
364 extern enum rte_flow_item_type iavf_pattern_eth_ipv4_gtpu_eh_ipv4_icmp[];
365
366 /* IPv4 GTPU EH IPv6 */
367 extern enum rte_flow_item_type iavf_pattern_eth_ipv4_gtpu_eh_ipv6[];
368 extern enum rte_flow_item_type iavf_pattern_eth_ipv4_gtpu_eh_ipv6_udp[];
369 extern enum rte_flow_item_type iavf_pattern_eth_ipv4_gtpu_eh_ipv6_tcp[];
370 extern enum rte_flow_item_type iavf_pattern_eth_ipv4_gtpu_eh_ipv6_icmp[];
371
372 /* IPv6 GTPU EH IPv4 */
373 extern enum rte_flow_item_type iavf_pattern_eth_ipv6_gtpu_eh_ipv4[];
374 extern enum rte_flow_item_type iavf_pattern_eth_ipv6_gtpu_eh_ipv4_udp[];
375 extern enum rte_flow_item_type iavf_pattern_eth_ipv6_gtpu_eh_ipv4_tcp[];
376 extern enum rte_flow_item_type iavf_pattern_eth_ipv6_gtpu_eh_ipv4_icmp[];
377
378 /* IPv6 GTPU EH IPv6 */
379 extern enum rte_flow_item_type iavf_pattern_eth_ipv6_gtpu_eh_ipv6[];
380 extern enum rte_flow_item_type iavf_pattern_eth_ipv6_gtpu_eh_ipv6_udp[];
381 extern enum rte_flow_item_type iavf_pattern_eth_ipv6_gtpu_eh_ipv6_tcp[];
382 extern enum rte_flow_item_type iavf_pattern_eth_ipv6_gtpu_eh_ipv6_icmp[];
383
384 /* ESP */
385 extern enum rte_flow_item_type iavf_pattern_eth_ipv4_esp[];
386 extern enum rte_flow_item_type iavf_pattern_eth_ipv4_udp_esp[];
387 extern enum rte_flow_item_type iavf_pattern_eth_ipv6_esp[];
388 extern enum rte_flow_item_type iavf_pattern_eth_ipv6_udp_esp[];
389
390 /* AH */
391 extern enum rte_flow_item_type iavf_pattern_eth_ipv4_ah[];
392 extern enum rte_flow_item_type iavf_pattern_eth_ipv6_ah[];
393
394 /* L2TPV3 */
395 extern enum rte_flow_item_type iavf_pattern_eth_ipv4_l2tpv3[];
396 extern enum rte_flow_item_type iavf_pattern_eth_ipv6_l2tpv3[];
397
398 /* PFCP */
399 extern enum rte_flow_item_type iavf_pattern_eth_ipv4_pfcp[];
400 extern enum rte_flow_item_type iavf_pattern_eth_ipv6_pfcp[];
401
402 /* ECPRI */
403 extern enum rte_flow_item_type iavf_pattern_eth_ecpri[];
404 extern enum rte_flow_item_type iavf_pattern_eth_ipv4_ecpri[];
405
406 /* GRE */
407 extern enum rte_flow_item_type iavf_pattern_eth_ipv4_gre_ipv4[];
408 extern enum rte_flow_item_type iavf_pattern_eth_ipv4_gre_ipv6[];
409 extern enum rte_flow_item_type iavf_pattern_eth_ipv6_gre_ipv4[];
410 extern enum rte_flow_item_type iavf_pattern_eth_ipv6_gre_ipv6[];
411 extern enum rte_flow_item_type iavf_pattern_eth_ipv4_gre_ipv4_tcp[];
412 extern enum rte_flow_item_type iavf_pattern_eth_ipv4_gre_ipv6_tcp[];
413 extern enum rte_flow_item_type iavf_pattern_eth_ipv4_gre_ipv4_udp[];
414 extern enum rte_flow_item_type iavf_pattern_eth_ipv4_gre_ipv6_udp[];
415 extern enum rte_flow_item_type iavf_pattern_eth_ipv6_gre_ipv4_tcp[];
416 extern enum rte_flow_item_type iavf_pattern_eth_ipv6_gre_ipv6_tcp[];
417 extern enum rte_flow_item_type iavf_pattern_eth_ipv6_gre_ipv4_udp[];
418 extern enum rte_flow_item_type iavf_pattern_eth_ipv6_gre_ipv6_udp[];
419
420 /* L2TPv2 */
421 extern enum rte_flow_item_type iavf_pattern_eth_ipv4_udp_l2tpv2[];
422 extern enum rte_flow_item_type iavf_pattern_eth_ipv4_udp_l2tpv2_ppp[];
423 extern enum rte_flow_item_type iavf_pattern_eth_ipv6_udp_l2tpv2[];
424 extern enum rte_flow_item_type iavf_pattern_eth_ipv6_udp_l2tpv2_ppp[];
425
426 /* PPPoL2TPv2oUDP */
427 extern enum rte_flow_item_type iavf_pattern_eth_ipv4_udp_l2tpv2_ppp_ipv4[];
428 extern enum rte_flow_item_type iavf_pattern_eth_ipv4_udp_l2tpv2_ppp_ipv6[];
429 extern enum rte_flow_item_type iavf_pattern_eth_ipv4_udp_l2tpv2_ppp_ipv4_udp[];
430 extern enum rte_flow_item_type iavf_pattern_eth_ipv4_udp_l2tpv2_ppp_ipv4_tcp[];
431 extern enum rte_flow_item_type iavf_pattern_eth_ipv4_udp_l2tpv2_ppp_ipv6_udp[];
432 extern enum rte_flow_item_type iavf_pattern_eth_ipv4_udp_l2tpv2_ppp_ipv6_tcp[];
433 extern enum rte_flow_item_type iavf_pattern_eth_ipv6_udp_l2tpv2_ppp_ipv4[];
434 extern enum rte_flow_item_type iavf_pattern_eth_ipv6_udp_l2tpv2_ppp_ipv6[];
435 extern enum rte_flow_item_type iavf_pattern_eth_ipv6_udp_l2tpv2_ppp_ipv4_udp[];
436 extern enum rte_flow_item_type iavf_pattern_eth_ipv6_udp_l2tpv2_ppp_ipv4_tcp[];
437 extern enum rte_flow_item_type iavf_pattern_eth_ipv6_udp_l2tpv2_ppp_ipv6_udp[];
438 extern enum rte_flow_item_type iavf_pattern_eth_ipv6_udp_l2tpv2_ppp_ipv6_tcp[];
439
440
441 extern const struct rte_flow_ops iavf_flow_ops;
442
443 /* pattern structure */
444 struct iavf_pattern_match_item {
445         enum rte_flow_item_type *pattern_list;
446         /* pattern_list must end with RTE_FLOW_ITEM_TYPE_END */
447         uint64_t input_set_mask;
448         void *meta;
449 };
450
451 typedef int (*engine_init_t)(struct iavf_adapter *ad);
452 typedef void (*engine_uninit_t)(struct iavf_adapter *ad);
453 typedef int (*engine_validation_t)(struct iavf_adapter *ad,
454                 struct rte_flow *flow,
455                 void *meta,
456                 struct rte_flow_error *error);
457 typedef int (*engine_create_t)(struct iavf_adapter *ad,
458                 struct rte_flow *flow,
459                 void *meta,
460                 struct rte_flow_error *error);
461 typedef int (*engine_destroy_t)(struct iavf_adapter *ad,
462                 struct rte_flow *flow,
463                 struct rte_flow_error *error);
464 typedef int (*engine_query_t)(struct iavf_adapter *ad,
465                 struct rte_flow *flow,
466                 struct rte_flow_query_count *count,
467                 struct rte_flow_error *error);
468 typedef void (*engine_free_t) (struct rte_flow *flow);
469 typedef int (*parse_pattern_action_t)(struct iavf_adapter *ad,
470                 struct iavf_pattern_match_item *array,
471                 uint32_t array_len,
472                 const struct rte_flow_item pattern[],
473                 const struct rte_flow_action actions[],
474                 void **meta,
475                 struct rte_flow_error *error);
476
477 /* engine types. */
478 enum iavf_flow_engine_type {
479         IAVF_FLOW_ENGINE_NONE = 0,
480         IAVF_FLOW_ENGINE_IPSEC_CRYPTO,
481         IAVF_FLOW_ENGINE_FDIR,
482         IAVF_FLOW_ENGINE_HASH,
483         IAVF_FLOW_ENGINE_MAX,
484 };
485
486 /**
487  * classification stages.
488  * for non-pipeline mode, we have two classification stages: Distributor/RSS
489  * for pipeline-mode we have three classification stages:
490  * Permission/Distributor/RSS
491  */
492 enum iavf_flow_classification_stage {
493         IAVF_FLOW_STAGE_NONE = 0,
494         IAVF_FLOW_STAGE_IPSEC_CRYPTO,
495         IAVF_FLOW_STAGE_RSS,
496         IAVF_FLOW_STAGE_DISTRIBUTOR,
497         IAVF_FLOW_STAGE_MAX,
498 };
499
500 /* Struct to store engine created. */
501 struct iavf_flow_engine {
502         TAILQ_ENTRY(iavf_flow_engine) node;
503         engine_init_t init;
504         engine_uninit_t uninit;
505         engine_validation_t validation;
506         engine_create_t create;
507         engine_destroy_t destroy;
508         engine_query_t query_count;
509         engine_free_t free;
510         enum iavf_flow_engine_type type;
511 };
512
513 TAILQ_HEAD(iavf_engine_list, iavf_flow_engine);
514
515 /* Struct to store flow created. */
516 struct rte_flow {
517         TAILQ_ENTRY(rte_flow) node;
518         struct iavf_flow_engine *engine;
519         void *rule;
520 };
521
522 struct iavf_flow_parser {
523         struct iavf_flow_engine *engine;
524         struct iavf_pattern_match_item *array;
525         uint32_t array_len;
526         parse_pattern_action_t parse_pattern_action;
527         enum iavf_flow_classification_stage stage;
528 };
529
530 /* Struct to store parser created. */
531 struct iavf_flow_parser_node {
532         TAILQ_ENTRY(iavf_flow_parser_node) node;
533         struct iavf_flow_parser *parser;
534 };
535
536 void iavf_register_flow_engine(struct iavf_flow_engine *engine);
537 int iavf_flow_init(struct iavf_adapter *ad);
538 void iavf_flow_uninit(struct iavf_adapter *ad);
539 int iavf_flow_flush(struct rte_eth_dev *dev,
540                 struct rte_flow_error *error);
541 int iavf_register_parser(struct iavf_flow_parser *parser,
542                          struct iavf_adapter *ad);
543 void iavf_unregister_parser(struct iavf_flow_parser *parser,
544                             struct iavf_adapter *ad);
545 struct iavf_pattern_match_item *
546 iavf_search_pattern_match_item(const struct rte_flow_item pattern[],
547                 struct iavf_pattern_match_item *array,
548                 uint32_t array_len,
549                 struct rte_flow_error *error);
550 #endif