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