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