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