006fd00b3988f67ae5c2494e33fc3ea4e6cf3e81
[dpdk.git] / drivers / net / ice / ice_generic_flow.h
1 /* SPDX-License-Identifier: BSD-3-Clause
2  * Copyright(c) 2019 Intel Corporation
3  */
4
5 #ifndef _ICE_GENERIC_FLOW_H_
6 #define _ICE_GENERIC_FLOW_H_
7
8 #include <rte_flow_driver.h>
9
10 /* protocol */
11
12 #define ICE_PROT_MAC_INNER         (1ULL << 1)
13 #define ICE_PROT_MAC_OUTER         (1ULL << 2)
14 #define ICE_PROT_VLAN_INNER        (1ULL << 3)
15 #define ICE_PROT_VLAN_OUTER        (1ULL << 4)
16 #define ICE_PROT_IPV4_INNER        (1ULL << 5)
17 #define ICE_PROT_IPV4_OUTER        (1ULL << 6)
18 #define ICE_PROT_IPV6_INNER        (1ULL << 7)
19 #define ICE_PROT_IPV6_OUTER        (1ULL << 8)
20 #define ICE_PROT_TCP_INNER         (1ULL << 9)
21 #define ICE_PROT_TCP_OUTER         (1ULL << 10)
22 #define ICE_PROT_UDP_INNER         (1ULL << 11)
23 #define ICE_PROT_UDP_OUTER         (1ULL << 12)
24 #define ICE_PROT_SCTP_INNER        (1ULL << 13)
25 #define ICE_PROT_SCTP_OUTER        (1ULL << 14)
26 #define ICE_PROT_ICMP4_INNER       (1ULL << 15)
27 #define ICE_PROT_ICMP4_OUTER       (1ULL << 16)
28 #define ICE_PROT_ICMP6_INNER       (1ULL << 17)
29 #define ICE_PROT_ICMP6_OUTER       (1ULL << 18)
30 #define ICE_PROT_VXLAN             (1ULL << 19)
31 #define ICE_PROT_NVGRE             (1ULL << 20)
32 #define ICE_PROT_GTPU              (1ULL << 21)
33 #define ICE_PROT_PPPOE_S           (1ULL << 22)
34
35 /* field */
36
37 #define ICE_SMAC                   (1ULL << 63)
38 #define ICE_DMAC                   (1ULL << 62)
39 #define ICE_ETHERTYPE              (1ULL << 61)
40 #define ICE_IP_SRC                 (1ULL << 60)
41 #define ICE_IP_DST                 (1ULL << 59)
42 #define ICE_IP_PROTO               (1ULL << 58)
43 #define ICE_IP_TTL                 (1ULL << 57)
44 #define ICE_IP_TOS                 (1ULL << 56)
45 #define ICE_SPORT                  (1ULL << 55)
46 #define ICE_DPORT                  (1ULL << 54)
47 #define ICE_ICMP_TYPE              (1ULL << 53)
48 #define ICE_ICMP_CODE              (1ULL << 52)
49 #define ICE_VXLAN_VNI              (1ULL << 51)
50 #define ICE_NVGRE_TNI              (1ULL << 50)
51 #define ICE_GTPU_TEID              (1ULL << 49)
52 #define ICE_GTPU_QFI               (1ULL << 48)
53 #define ICE_PPPOE_SESSION          (1ULL << 47)
54 #define ICE_PPPOE_PROTO            (1ULL << 46)
55
56 /* input set */
57
58 #define ICE_INSET_NONE             0ULL
59
60 /* non-tunnel */
61
62 #define ICE_INSET_SMAC         (ICE_PROT_MAC_OUTER | ICE_SMAC)
63 #define ICE_INSET_DMAC         (ICE_PROT_MAC_OUTER | ICE_DMAC)
64 #define ICE_INSET_VLAN_INNER   (ICE_PROT_VLAN_INNER)
65 #define ICE_INSET_VLAN_OUTER   (ICE_PROT_VLAN_OUTER)
66 #define ICE_INSET_ETHERTYPE    (ICE_ETHERTYPE)
67
68 #define ICE_INSET_IPV4_SRC \
69         (ICE_PROT_IPV4_OUTER | ICE_IP_SRC)
70 #define ICE_INSET_IPV4_DST \
71         (ICE_PROT_IPV4_OUTER | ICE_IP_DST)
72 #define ICE_INSET_IPV4_TOS \
73         (ICE_PROT_IPV4_OUTER | ICE_IP_TOS)
74 #define ICE_INSET_IPV4_PROTO \
75         (ICE_PROT_IPV4_OUTER | ICE_IP_PROTO)
76 #define ICE_INSET_IPV4_TTL \
77         (ICE_PROT_IPV4_OUTER | ICE_IP_TTL)
78 #define ICE_INSET_IPV6_SRC \
79         (ICE_PROT_IPV6_OUTER | ICE_IP_SRC)
80 #define ICE_INSET_IPV6_DST \
81         (ICE_PROT_IPV6_OUTER | ICE_IP_DST)
82 #define ICE_INSET_IPV6_NEXT_HDR \
83         (ICE_PROT_IPV6_OUTER | ICE_IP_PROTO)
84 #define ICE_INSET_IPV6_HOP_LIMIT \
85         (ICE_PROT_IPV6_OUTER | ICE_IP_TTL)
86 #define ICE_INSET_IPV6_TC \
87         (ICE_PROT_IPV6_OUTER | ICE_IP_TOS)
88
89 #define ICE_INSET_TCP_SRC_PORT \
90         (ICE_PROT_TCP_OUTER | ICE_SPORT)
91 #define ICE_INSET_TCP_DST_PORT \
92         (ICE_PROT_TCP_OUTER | ICE_DPORT)
93 #define ICE_INSET_UDP_SRC_PORT \
94         (ICE_PROT_UDP_OUTER | ICE_SPORT)
95 #define ICE_INSET_UDP_DST_PORT \
96         (ICE_PROT_UDP_OUTER | ICE_DPORT)
97 #define ICE_INSET_SCTP_SRC_PORT \
98         (ICE_PROT_SCTP_OUTER | ICE_SPORT)
99 #define ICE_INSET_SCTP_DST_PORT \
100         (ICE_PROT_SCTP_OUTER | ICE_DPORT)
101 #define ICE_INSET_ICMP4_SRC_PORT \
102         (ICE_PROT_ICMP4_OUTER | ICE_SPORT)
103 #define ICE_INSET_ICMP4_DST_PORT \
104         (ICE_PROT_ICMP4_OUTER | ICE_DPORT)
105 #define ICE_INSET_ICMP6_SRC_PORT \
106         (ICE_PROT_ICMP6_OUTER | ICE_SPORT)
107 #define ICE_INSET_ICMP6_DST_PORT \
108         (ICE_PROT_ICMP6_OUTER | ICE_DPORT)
109 #define ICE_INSET_ICMP4_TYPE \
110         (ICE_PROT_ICMP4_OUTER | ICE_ICMP_TYPE)
111 #define ICE_INSET_ICMP4_CODE \
112         (ICE_PROT_ICMP4_OUTER | ICE_ICMP_CODE)
113 #define ICE_INSET_ICMP6_TYPE \
114         (ICE_PROT_ICMP6_OUTER | ICE_ICMP_TYPE)
115 #define ICE_INSET_ICMP6_CODE \
116         (ICE_PROT_ICMP6_OUTER | ICE_ICMP_CODE)
117
118 /* tunnel */
119
120 #define ICE_INSET_TUN_SMAC \
121         (ICE_PROT_MAC_INNER | ICE_SMAC)
122 #define ICE_INSET_TUN_DMAC \
123         (ICE_PROT_MAC_INNER | ICE_DMAC)
124
125 #define ICE_INSET_TUN_IPV4_SRC \
126         (ICE_PROT_IPV4_INNER | ICE_IP_SRC)
127 #define ICE_INSET_TUN_IPV4_DST \
128         (ICE_PROT_IPV4_INNER | ICE_IP_DST)
129 #define ICE_INSET_TUN_IPV4_TTL \
130         (ICE_PROT_IPV4_INNER | ICE_IP_TTL)
131 #define ICE_INSET_TUN_IPV4_PROTO \
132         (ICE_PROT_IPV4_INNER | ICE_IP_PROTO)
133 #define ICE_INSET_TUN_IPV4_TOS \
134         (ICE_PROT_IPV4_INNER | ICE_IP_TOS)
135 #define ICE_INSET_TUN_IPV6_SRC \
136         (ICE_PROT_IPV6_INNER | ICE_IP_SRC)
137 #define ICE_INSET_TUN_IPV6_DST \
138         (ICE_PROT_IPV6_INNER | ICE_IP_DST)
139 #define ICE_INSET_TUN_IPV6_HOP_LIMIT \
140         (ICE_PROT_IPV6_INNER | ICE_IP_TTL)
141 #define ICE_INSET_TUN_IPV6_NEXT_HDR \
142         (ICE_PROT_IPV6_INNER | ICE_IP_PROTO)
143 #define ICE_INSET_TUN_IPV6_TC \
144         (ICE_PROT_IPV6_INNER | ICE_IP_TOS)
145
146 #define ICE_INSET_TUN_TCP_SRC_PORT \
147         (ICE_PROT_TCP_INNER | ICE_SPORT)
148 #define ICE_INSET_TUN_TCP_DST_PORT \
149         (ICE_PROT_TCP_INNER | ICE_DPORT)
150 #define ICE_INSET_TUN_UDP_SRC_PORT \
151         (ICE_PROT_UDP_INNER | ICE_SPORT)
152 #define ICE_INSET_TUN_UDP_DST_PORT \
153         (ICE_PROT_UDP_INNER | ICE_DPORT)
154 #define ICE_INSET_TUN_SCTP_SRC_PORT \
155         (ICE_PROT_SCTP_INNER | ICE_SPORT)
156 #define ICE_INSET_TUN_SCTP_DST_PORT \
157         (ICE_PROT_SCTP_INNER | ICE_DPORT)
158 #define ICE_INSET_TUN_ICMP4_SRC_PORT \
159         (ICE_PROT_ICMP4_INNER | ICE_SPORT)
160 #define ICE_INSET_TUN_ICMP4_DST_PORT \
161         (ICE_PROT_ICMP4_INNER | ICE_DPORT)
162 #define ICE_INSET_TUN_ICMP6_SRC_PORT \
163         (ICE_PROT_ICMP6_INNER | ICE_SPORT)
164 #define ICE_INSET_TUN_ICMP6_DST_PORT \
165         (ICE_PROT_ICMP6_INNER | ICE_DPORT)
166 #define ICE_INSET_TUN_ICMP4_TYPE \
167         (ICE_PROT_ICMP4_INNER | ICE_ICMP_TYPE)
168 #define ICE_INSET_TUN_ICMP4_CODE \
169         (ICE_PROT_ICMP4_INNER | ICE_ICMP_CODE)
170 #define ICE_INSET_TUN_ICMP6_TYPE \
171         (ICE_PROT_ICMP6_INNER | ICE_ICMP_TYPE)
172 #define ICE_INSET_TUN_ICMP6_CODE \
173         (ICE_PROT_ICMP6_INNER | ICE_ICMP_CODE)
174
175 #define ICE_INSET_TUN_VXLAN_VNI \
176         (ICE_PROT_VXLAN | ICE_VXLAN_VNI)
177 #define ICE_INSET_TUN_NVGRE_TNI \
178         (ICE_PROT_NVGRE | ICE_NVGRE_TNI)
179 #define ICE_INSET_GTPU_TEID \
180         (ICE_PROT_GTPU | ICE_GTPU_TEID)
181 #define ICE_INSET_GTPU_QFI \
182         (ICE_PROT_GTPU | ICE_GTPU_QFI)
183 #define ICE_INSET_PPPOE_SESSION \
184         (ICE_PROT_PPPOE_S | ICE_PPPOE_SESSION)
185 #define ICE_INSET_PPPOE_PROTO \
186         (ICE_PROT_PPPOE_S | ICE_PPPOE_PROTO)
187
188 /* empty pattern */
189 extern enum rte_flow_item_type pattern_empty[];
190
191 /* L2 */
192 extern enum rte_flow_item_type pattern_ethertype[];
193 extern enum rte_flow_item_type pattern_ethertype_vlan[];
194 extern enum rte_flow_item_type pattern_ethertype_qinq[];
195
196 /* ARP */
197 extern enum rte_flow_item_type pattern_eth_arp[];
198
199 /* non-tunnel IPv4 */
200 extern enum rte_flow_item_type pattern_eth_ipv4[];
201 extern enum rte_flow_item_type pattern_eth_vlan_ipv4[];
202 extern enum rte_flow_item_type pattern_eth_qinq_ipv4[];
203 extern enum rte_flow_item_type pattern_eth_ipv4_udp[];
204 extern enum rte_flow_item_type pattern_eth_vlan_ipv4_udp[];
205 extern enum rte_flow_item_type pattern_eth_qinq_ipv4_udp[];
206 extern enum rte_flow_item_type pattern_eth_ipv4_tcp[];
207 extern enum rte_flow_item_type pattern_eth_vlan_ipv4_tcp[];
208 extern enum rte_flow_item_type pattern_eth_qinq_ipv4_tcp[];
209 extern enum rte_flow_item_type pattern_eth_ipv4_sctp[];
210 extern enum rte_flow_item_type pattern_eth_vlan_ipv4_sctp[];
211 extern enum rte_flow_item_type pattern_eth_qinq_ipv4_sctp[];
212 extern enum rte_flow_item_type pattern_eth_ipv4_icmp[];
213 extern enum rte_flow_item_type pattern_eth_vlan_ipv4_icmp[];
214 extern enum rte_flow_item_type pattern_eth_qinq_ipv4_icmp[];
215
216 /* non-tunnel IPv6 */
217 extern enum rte_flow_item_type pattern_eth_ipv6[];
218 extern enum rte_flow_item_type pattern_eth_vlan_ipv6[];
219 extern enum rte_flow_item_type pattern_eth_qinq_ipv6[];
220 extern enum rte_flow_item_type pattern_eth_ipv6_udp[];
221 extern enum rte_flow_item_type pattern_eth_vlan_ipv6_udp[];
222 extern enum rte_flow_item_type pattern_eth_qinq_ipv6_udp[];
223 extern enum rte_flow_item_type pattern_eth_ipv6_tcp[];
224 extern enum rte_flow_item_type pattern_eth_vlan_ipv6_tcp[];
225 extern enum rte_flow_item_type pattern_eth_qinq_ipv6_tcp[];
226 extern enum rte_flow_item_type pattern_eth_ipv6_sctp[];
227 extern enum rte_flow_item_type pattern_eth_vlan_ipv6_sctp[];
228 extern enum rte_flow_item_type pattern_eth_qinq_ipv6_sctp[];
229 extern enum rte_flow_item_type pattern_eth_ipv6_icmp6[];
230 extern enum rte_flow_item_type pattern_eth_vlan_ipv6_icmp6[];
231 extern enum rte_flow_item_type pattern_eth_qinq_ipv6_icmp6[];
232
233 /* IPv4 VXLAN IPv4 */
234 extern enum rte_flow_item_type pattern_eth_ipv4_udp_vxlan_ipv4[];
235 extern enum rte_flow_item_type pattern_eth_ipv4_udp_vxlan_ipv4_udp[];
236 extern enum rte_flow_item_type pattern_eth_ipv4_udp_vxlan_ipv4_tcp[];
237 extern enum rte_flow_item_type pattern_eth_ipv4_udp_vxlan_ipv4_sctp[];
238 extern enum rte_flow_item_type pattern_eth_ipv4_udp_vxlan_ipv4_icmp[];
239
240 /* IPv4 VXLAN MAC IPv4 */
241 extern enum rte_flow_item_type pattern_eth_ipv4_udp_vxlan_eth_ipv4[];
242 extern enum rte_flow_item_type pattern_eth_ipv4_udp_vxlan_eth_ipv4_udp[];
243 extern enum rte_flow_item_type pattern_eth_ipv4_udp_vxlan_eth_ipv4_tcp[];
244 extern enum rte_flow_item_type pattern_eth_ipv4_udp_vxlan_eth_ipv4_sctp[];
245 extern enum rte_flow_item_type pattern_eth_ipv4_udp_vxlan_eth_ipv4_icmp[];
246
247 /* IPv6 VXLAN IPv4 */
248 extern enum rte_flow_item_type pattern_eth_ipv6_udp_vxlan_ipv4[];
249 extern enum rte_flow_item_type pattern_eth_ipv6_udp_vxlan_ipv4_tcp[];
250 extern enum rte_flow_item_type pattern_eth_ipv6_udp_vxlan_ipv4_udp[];
251 extern enum rte_flow_item_type pattern_eth_ipv6_udp_vxlan_ipv4_sctp[];
252 extern enum rte_flow_item_type pattern_eth_ipv6_udp_vxlan_ipv4_icmp[];
253
254 /* IPv6 VXLAN MAC IPv4 */
255 extern enum rte_flow_item_type pattern_eth_ipv6_udp_vxlan_eth_ipv4[];
256 extern enum rte_flow_item_type pattern_eth_ipv6_udp_vxlan_eth_ipv4_tcp[];
257 extern enum rte_flow_item_type pattern_eth_ipv6_udp_vxlan_eth_ipv4_udp[];
258 extern enum rte_flow_item_type pattern_eth_ipv6_udp_vxlan_eth_ipv4_sctp[];
259 extern enum rte_flow_item_type pattern_eth_ipv6_udp_vxlan_eth_ipv4_icmp[];
260
261 /* IPv4 VXLAN IPv6 */
262 extern enum rte_flow_item_type pattern_eth_ipv4_udp_vxlan_ipv6[];
263 extern enum rte_flow_item_type pattern_eth_ipv4_udp_vxlan_ipv6_udp[];
264 extern enum rte_flow_item_type pattern_eth_ipv4_udp_vxlan_ipv6_tcp[];
265 extern enum rte_flow_item_type pattern_eth_ipv4_udp_vxlan_ipv6_sctp[];
266 extern enum rte_flow_item_type pattern_eth_ipv4_udp_vxlan_ipv6_icmp6[];
267
268 /* IPv4 VXLAN MAC IPv6 */
269 extern enum rte_flow_item_type pattern_eth_ipv4_udp_vxlan_eth_ipv6[];
270 extern enum rte_flow_item_type pattern_eth_ipv4_udp_vxlan_eth_ipv6_udp[];
271 extern enum rte_flow_item_type pattern_eth_ipv4_udp_vxlan_eth_ipv6_tcp[];
272 extern enum rte_flow_item_type pattern_eth_ipv4_udp_vxlan_eth_ipv6_sctp[];
273 extern enum rte_flow_item_type pattern_eth_ipv4_udp_vxlan_eth_ipv6_icmp6[];
274
275 /* IPv6 VXLAN IPv6 */
276 extern enum rte_flow_item_type pattern_eth_ipv6_udp_vxlan_ipv6[];
277 extern enum rte_flow_item_type pattern_eth_ipv6_udp_vxlan_ipv6_tcp[];
278 extern enum rte_flow_item_type pattern_eth_ipv6_udp_vxlan_ipv6_udp[];
279 extern enum rte_flow_item_type pattern_eth_ipv6_udp_vxlan_ipv6_sctp[];
280 extern enum rte_flow_item_type pattern_eth_ipv6_udp_vxlan_ipv6_icmp6[];
281
282 /* IPv6 VXLAN MAC IPv6 */
283 extern enum rte_flow_item_type pattern_eth_ipv6_udp_vxlan_eth_ipv6[];
284 extern enum rte_flow_item_type pattern_eth_ipv6_udp_vxlan_eth_ipv6_tcp[];
285 extern enum rte_flow_item_type pattern_eth_ipv6_udp_vxlan_eth_ipv6_udp[];
286 extern enum rte_flow_item_type pattern_eth_ipv6_udp_vxlan_eth_ipv6_sctp[];
287 extern enum rte_flow_item_type pattern_eth_ipv6_udp_vxlan_eth_ipv6_icmp6[];
288
289 /* IPv4 NVGRE IPv4 */
290 extern enum rte_flow_item_type pattern_eth_ipv4_nvgre_ipv4[];
291 extern enum rte_flow_item_type pattern_eth_ipv4_nvgre_ipv4_udp[];
292 extern enum rte_flow_item_type pattern_eth_ipv4_nvgre_ipv4_tcp[];
293 extern enum rte_flow_item_type pattern_eth_ipv4_nvgre_ipv4_sctp[];
294 extern enum rte_flow_item_type pattern_eth_ipv4_nvgre_ipv4_icmp[];
295
296 /* IPv4 NVGRE MAC IPv4 */
297 extern enum rte_flow_item_type pattern_eth_ipv4_nvgre_eth_ipv4[];
298 extern enum rte_flow_item_type pattern_eth_ipv4_nvgre_eth_ipv4_udp[];
299 extern enum rte_flow_item_type pattern_eth_ipv4_nvgre_eth_ipv4_tcp[];
300 extern enum rte_flow_item_type pattern_eth_ipv4_nvgre_eth_ipv4_sctp[];
301 extern enum rte_flow_item_type pattern_eth_ipv4_nvgre_eth_ipv4_icmp[];
302
303 /* IPv6 NVGRE IPv4 */
304 extern enum rte_flow_item_type pattern_eth_ipv6_nvgre_ipv4[];
305 extern enum rte_flow_item_type pattern_eth_ipv6_nvgre_ipv4_tcp[];
306 extern enum rte_flow_item_type pattern_eth_ipv6_nvgre_ipv4_udp[];
307 extern enum rte_flow_item_type pattern_eth_ipv6_nvgre_ipv4_sctp[];
308 extern enum rte_flow_item_type pattern_eth_ipv6_nvgre_ipv4_icmp[];
309
310 /* IPv6 NVGRE MAC IPv4 */
311 extern enum rte_flow_item_type pattern_eth_ipv6_nvgre_eth_ipv4[];
312 extern enum rte_flow_item_type pattern_eth_ipv6_nvgre_eth_ipv4_tcp[];
313 extern enum rte_flow_item_type pattern_eth_ipv6_nvgre_eth_ipv4_udp[];
314 extern enum rte_flow_item_type pattern_eth_ipv6_nvgre_eth_ipv4_sctp[];
315 extern enum rte_flow_item_type pattern_eth_ipv6_nvgre_eth_ipv4_icmp[];
316
317 /* IPv4 NVGRE IPv6 */
318 extern enum rte_flow_item_type pattern_eth_ipv4_nvgre_ipv6[];
319 extern enum rte_flow_item_type pattern_eth_ipv4_nvgre_ipv6_udp[];
320 extern enum rte_flow_item_type pattern_eth_ipv4_nvgre_ipv6_tcp[];
321 extern enum rte_flow_item_type pattern_eth_ipv4_nvgre_ipv6_sctp[];
322 extern enum rte_flow_item_type pattern_eth_ipv4_nvgre_ipv6_icmp6[];
323
324 /* IPv4 NVGRE MAC IPv6 */
325 extern enum rte_flow_item_type pattern_eth_ipv4_nvgre_eth_ipv6[];
326 extern enum rte_flow_item_type pattern_eth_ipv4_nvgre_eth_ipv6_udp[];
327 extern enum rte_flow_item_type pattern_eth_ipv4_nvgre_eth_ipv6_tcp[];
328 extern enum rte_flow_item_type pattern_eth_ipv4_nvgre_eth_ipv6_sctp[];
329 extern enum rte_flow_item_type pattern_eth_ipv4_nvgre_eth_ipv6_icmp6[];
330
331 /* IPv6 NVGRE IPv6 */
332 extern enum rte_flow_item_type pattern_eth_ipv6_nvgre_ipv6[];
333 extern enum rte_flow_item_type pattern_eth_ipv6_nvgre_ipv6_tcp[];
334 extern enum rte_flow_item_type pattern_eth_ipv6_nvgre_ipv6_udp[];
335 extern enum rte_flow_item_type pattern_eth_ipv6_nvgre_ipv6_sctp[];
336 extern enum rte_flow_item_type pattern_eth_ipv6_nvgre_ipv6_icmp6[];
337
338 /* IPv6 NVGRE MAC IPv6 */
339 extern enum rte_flow_item_type pattern_eth_ipv6_nvgre_eth_ipv6[];
340 extern enum rte_flow_item_type pattern_eth_ipv6_nvgre_eth_ipv6_tcp[];
341 extern enum rte_flow_item_type pattern_eth_ipv6_nvgre_eth_ipv6_udp[];
342 extern enum rte_flow_item_type pattern_eth_ipv6_nvgre_eth_ipv6_sctp[];
343 extern enum rte_flow_item_type pattern_eth_ipv6_nvgre_eth_ipv6_icmp6[];
344
345 /* GTPU */
346 extern enum rte_flow_item_type pattern_eth_ipv4_gtpu[];
347 extern enum rte_flow_item_type pattern_eth_ipv4_gtpu_ipv4[];
348 extern enum rte_flow_item_type pattern_eth_ipv4_gtpu_eh[];
349 extern enum rte_flow_item_type pattern_eth_ipv4_gtpu_eh_ipv4[];
350 extern enum rte_flow_item_type pattern_eth_ipv4_gtpu_eh_ipv4_udp[];
351 extern enum rte_flow_item_type pattern_eth_ipv4_gtpu_eh_ipv4_tcp[];
352 extern enum rte_flow_item_type pattern_eth_ipv4_gtpu_eh_ipv4_icmp[];
353
354 /* PPPoE */
355 extern enum rte_flow_item_type pattern_eth_pppoed[];
356 extern enum rte_flow_item_type pattern_eth_vlan_pppoed[];
357 extern enum rte_flow_item_type pattern_eth_qinq_pppoed[];
358 extern enum rte_flow_item_type pattern_eth_pppoes[];
359 extern enum rte_flow_item_type pattern_eth_pppoes_proto[];
360 extern enum rte_flow_item_type pattern_eth_vlan_pppoes[];
361 extern enum rte_flow_item_type pattern_eth_vlan_pppoes_proto[];
362 extern enum rte_flow_item_type pattern_eth_qinq_pppoes[];
363 extern enum rte_flow_item_type pattern_eth_pppoes_ipv4[];
364 extern enum rte_flow_item_type pattern_eth_vlan_pppoes_ipv4[];
365 extern enum rte_flow_item_type pattern_eth_qinq_pppoes_ipv4[];
366 extern enum rte_flow_item_type pattern_eth_pppoes_ipv4_udp[];
367 extern enum rte_flow_item_type pattern_eth_vlan_pppoes_ipv4_udp[];
368 extern enum rte_flow_item_type pattern_eth_qinq_pppoes_ipv4_udp[];
369 extern enum rte_flow_item_type pattern_eth_pppoes_ipv4_tcp[];
370 extern enum rte_flow_item_type pattern_eth_vlan_pppoes_ipv4_tcp[];
371 extern enum rte_flow_item_type pattern_eth_qinq_pppoes_ipv4_tcp[];
372 extern enum rte_flow_item_type pattern_eth_pppoes_ipv4_sctp[];
373 extern enum rte_flow_item_type pattern_eth_vlan_pppoes_ipv4_sctp[];
374 extern enum rte_flow_item_type pattern_eth_qinq_pppoes_ipv4_sctp[];
375 extern enum rte_flow_item_type pattern_eth_pppoes_ipv4_icmp[];
376 extern enum rte_flow_item_type pattern_eth_vlan_pppoes_ipv4_icmp[];
377 extern enum rte_flow_item_type pattern_eth_qinq_pppoes_ipv4_icmp[];
378 extern enum rte_flow_item_type pattern_eth_pppoes_ipv6[];
379 extern enum rte_flow_item_type pattern_eth_vlan_pppoes_ipv6[];
380 extern enum rte_flow_item_type pattern_eth_qinq_pppoes_ipv6[];
381 extern enum rte_flow_item_type pattern_eth_pppoes_ipv6_udp[];
382 extern enum rte_flow_item_type pattern_eth_vlan_pppoes_ipv6_udp[];
383 extern enum rte_flow_item_type pattern_eth_qinq_pppoes_ipv6_udp[];
384 extern enum rte_flow_item_type pattern_eth_pppoes_ipv6_tcp[];
385 extern enum rte_flow_item_type pattern_eth_vlan_pppoes_ipv6_tcp[];
386 extern enum rte_flow_item_type pattern_eth_qinq_pppoes_ipv6_tcp[];
387 extern enum rte_flow_item_type pattern_eth_pppoes_ipv6_sctp[];
388 extern enum rte_flow_item_type pattern_eth_vlan_pppoes_ipv6_sctp[];
389 extern enum rte_flow_item_type pattern_eth_qinq_pppoes_ipv6_sctp[];
390 extern enum rte_flow_item_type pattern_eth_pppoes_ipv6_icmp6[];
391 extern enum rte_flow_item_type pattern_eth_vlan_pppoes_ipv6_icmp6[];
392 extern enum rte_flow_item_type pattern_eth_qinq_pppoes_ipv6_icmp6[];
393
394 /* ESP */
395 extern enum rte_flow_item_type pattern_eth_ipv6_esp[];
396
397 /* AH */
398 extern enum rte_flow_item_type pattern_eth_ipv6_ah[];
399
400 /* L2TP */
401 extern enum rte_flow_item_type pattern_eth_ipv6_l2tp[];
402
403 struct ice_adapter;
404
405 extern const struct rte_flow_ops ice_flow_ops;
406
407 /* engine types. */
408 enum ice_flow_engine_type {
409         ICE_FLOW_ENGINE_NONE = 0,
410         ICE_FLOW_ENGINE_FDIR,
411         ICE_FLOW_ENGINE_SWITCH,
412         ICE_FLOW_ENGINE_HASH,
413         ICE_FLOW_ENGINE_ACL,
414         ICE_FLOW_ENGINE_MAX,
415 };
416
417 /**
418  * classification stages.
419  * for non-pipeline mode, we have two classification stages: Distributor/RSS
420  * for pipeline-mode we have three classification stages:
421  * Permission/Distributor/RSS
422  */
423 enum ice_flow_classification_stage {
424         ICE_FLOW_STAGE_NONE = 0,
425         ICE_FLOW_STAGE_RSS,
426         ICE_FLOW_STAGE_PERMISSION,
427         ICE_FLOW_STAGE_DISTRIBUTOR,
428         ICE_FLOW_STAGE_MAX,
429 };
430 /* pattern structure */
431 struct ice_pattern_match_item {
432         enum rte_flow_item_type *pattern_list;
433         /* pattern_list must end with RTE_FLOW_ITEM_TYPE_END */
434         uint64_t input_set_mask;
435         void *meta;
436 };
437
438 enum ice_flow_redirect_type {
439         ICE_FLOW_REDIRECT_VSI,
440 };
441
442 struct ice_flow_redirect {
443         enum ice_flow_redirect_type type;
444         union {
445                 struct {
446                         uint16_t vsi_handle;
447                         uint16_t new_vsi_num;
448                 };
449         };
450 };
451
452 typedef int (*engine_init_t)(struct ice_adapter *ad);
453 typedef void (*engine_uninit_t)(struct ice_adapter *ad);
454 typedef int (*engine_create_t)(struct ice_adapter *ad,
455                 struct rte_flow *flow,
456                 void *meta,
457                 struct rte_flow_error *error);
458 typedef int (*engine_destroy_t)(struct ice_adapter *ad,
459                 struct rte_flow *flow,
460                 struct rte_flow_error *error);
461 typedef int (*engine_query_t)(struct ice_adapter *ad,
462                 struct rte_flow *flow,
463                 struct rte_flow_query_count *count,
464                 struct rte_flow_error *error);
465 typedef int(*engine_redirect_t)(struct ice_adapter *ad,
466                                 struct rte_flow *flow,
467                                 struct ice_flow_redirect *redirect);
468 typedef void (*engine_free_t) (struct rte_flow *flow);
469 typedef int (*parse_pattern_action_t)(struct ice_adapter *ad,
470                 struct ice_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 /* Struct to store engine created. */
478 struct ice_flow_engine {
479         TAILQ_ENTRY(ice_flow_engine) node;
480         engine_init_t init;
481         engine_uninit_t uninit;
482         engine_create_t create;
483         engine_destroy_t destroy;
484         engine_query_t query_count;
485         engine_redirect_t redirect;
486         engine_free_t free;
487         enum ice_flow_engine_type type;
488 };
489 TAILQ_HEAD(ice_engine_list, ice_flow_engine);
490
491 /* Struct to store flow created. */
492 struct rte_flow {
493         TAILQ_ENTRY(rte_flow) node;
494         struct ice_flow_engine *engine;
495         void *rule;
496 };
497
498 struct ice_flow_parser {
499         struct ice_flow_engine *engine;
500         struct ice_pattern_match_item *array;
501         uint32_t array_len;
502         parse_pattern_action_t parse_pattern_action;
503         enum ice_flow_classification_stage stage;
504 };
505
506 /* Struct to store parser created. */
507 struct ice_flow_parser_node {
508         TAILQ_ENTRY(ice_flow_parser_node) node;
509         struct ice_flow_parser *parser;
510 };
511
512 void ice_register_flow_engine(struct ice_flow_engine *engine);
513 int ice_flow_init(struct ice_adapter *ad);
514 void ice_flow_uninit(struct ice_adapter *ad);
515 int ice_register_parser(struct ice_flow_parser *parser,
516                 struct ice_adapter *ad);
517 void ice_unregister_parser(struct ice_flow_parser *parser,
518                 struct ice_adapter *ad);
519 struct ice_pattern_match_item *
520 ice_search_pattern_match_item(const struct rte_flow_item pattern[],
521                 struct ice_pattern_match_item *array,
522                 uint32_t array_len,
523                 struct rte_flow_error *error);
524 int
525 ice_flow_redirect(struct ice_adapter *ad,
526                   struct ice_flow_redirect *rd);
527 #endif