Branch data Line data Source code
1 : : /* SPDX-License-Identifier: BSD-3-Clause
2 : : * Copyright(c) 2010-2015 Intel Corporation
3 : : */
4 : :
5 : : #ifndef _I40E_RXTX_H_
6 : : #define _I40E_RXTX_H_
7 : :
8 : : #define RTE_PMD_I40E_RX_MAX_BURST 32
9 : : #define RTE_PMD_I40E_TX_MAX_BURST 32
10 : :
11 : : #define RTE_I40E_VPMD_RX_BURST 32
12 : : #define RTE_I40E_VPMD_TX_BURST 32
13 : : #define RTE_I40E_RXQ_REARM_THRESH 32
14 : : #define RTE_I40E_MAX_RX_BURST RTE_I40E_RXQ_REARM_THRESH
15 : : #define RTE_I40E_TX_MAX_FREE_BUF_SZ 64
16 : : #define RTE_I40E_DESCS_PER_LOOP 4
17 : :
18 : : #define I40E_RXBUF_SZ_1024 1024
19 : : #define I40E_RXBUF_SZ_2048 2048
20 : :
21 : : /* In none-PXE mode QLEN must be whole number of 32 descriptors. */
22 : : #define I40E_ALIGN_RING_DESC 32
23 : :
24 : : /* Max data buffer size must be 16K - 128 bytes */
25 : : #define I40E_RX_MAX_DATA_BUF_SIZE (16 * 1024 - 128)
26 : :
27 : : #define I40E_MIN_RING_DESC 64
28 : : #define I40E_MAX_RING_DESC 8160
29 : :
30 : : #define I40E_FDIR_NUM_TX_DESC (I40E_FDIR_PRG_PKT_CNT << 1)
31 : : #define I40E_FDIR_NUM_RX_DESC (I40E_FDIR_PRG_PKT_CNT << 1)
32 : :
33 : : #define I40E_MIN_TSO_MSS 256
34 : : #define I40E_MAX_TSO_MSS 9674
35 : :
36 : : #define I40E_TX_MAX_SEG UINT8_MAX
37 : : #define I40E_TX_MAX_MTU_SEG 8
38 : :
39 : : #define I40E_TX_MIN_PKT_LEN 17
40 : :
41 : : /* Shared FDIR masks between scalar / vector drivers */
42 : : #define I40E_RX_DESC_EXT_STATUS_FLEXBH_MASK 0x03
43 : : #define I40E_RX_DESC_EXT_STATUS_FLEXBH_FD_ID 0x01
44 : : #define I40E_RX_DESC_EXT_STATUS_FLEXBH_FLEX 0x02
45 : : #define I40E_RX_DESC_EXT_STATUS_FLEXBL_MASK 0x03
46 : : #define I40E_RX_DESC_EXT_STATUS_FLEXBL_FLEX 0x01
47 : :
48 : : #define I40E_TD_CMD (I40E_TX_DESC_CMD_ICRC |\
49 : : I40E_TX_DESC_CMD_EOP)
50 : :
51 : : enum i40e_header_split_mode {
52 : : i40e_header_split_none = 0,
53 : : i40e_header_split_enabled = 1,
54 : : i40e_header_split_always = 2,
55 : : i40e_header_split_reserved
56 : : };
57 : :
58 : : #define I40E_HEADER_SPLIT_NONE ((uint8_t)0)
59 : : #define I40E_HEADER_SPLIT_L2 ((uint8_t)(1 << 0))
60 : : #define I40E_HEADER_SPLIT_IP ((uint8_t)(1 << 1))
61 : : #define I40E_HEADER_SPLIT_UDP_TCP ((uint8_t)(1 << 2))
62 : : #define I40E_HEADER_SPLIT_SCTP ((uint8_t)(1 << 3))
63 : : #define I40E_HEADER_SPLIT_ALL (I40E_HEADER_SPLIT_L2 | \
64 : : I40E_HEADER_SPLIT_IP | \
65 : : I40E_HEADER_SPLIT_UDP_TCP | \
66 : : I40E_HEADER_SPLIT_SCTP)
67 : :
68 : : /* HW desc structure, both 16-byte and 32-byte types are supported */
69 : : #ifdef RTE_LIBRTE_I40E_16BYTE_RX_DESC
70 : : #define i40e_rx_desc i40e_16byte_rx_desc
71 : : #else
72 : : #define i40e_rx_desc i40e_32byte_rx_desc
73 : : #endif
74 : :
75 : : struct i40e_rx_entry {
76 : : struct rte_mbuf *mbuf;
77 : : };
78 : :
79 : : /*
80 : : * Structure associated with each RX queue.
81 : : */
82 : : struct i40e_rx_queue {
83 : : struct rte_mempool *mp; /**< mbuf pool to populate RX ring */
84 : : volatile union i40e_rx_desc *rx_ring;/**< RX ring virtual address */
85 : : uint64_t rx_ring_phys_addr; /**< RX ring DMA address */
86 : : struct i40e_rx_entry *sw_ring; /**< address of RX soft ring */
87 : : uint16_t nb_rx_desc; /**< number of RX descriptors */
88 : : uint16_t rx_free_thresh; /**< max free RX desc to hold */
89 : : uint16_t rx_tail; /**< current value of tail */
90 : : uint16_t nb_rx_hold; /**< number of held free RX desc */
91 : : struct rte_mbuf *pkt_first_seg; /**< first segment of current packet */
92 : : struct rte_mbuf *pkt_last_seg; /**< last segment of current packet */
93 : : struct rte_mbuf fake_mbuf; /**< dummy mbuf */
94 : : #ifdef RTE_LIBRTE_I40E_RX_ALLOW_BULK_ALLOC
95 : : uint16_t rx_nb_avail; /**< number of staged packets ready */
96 : : uint16_t rx_next_avail; /**< index of next staged packets */
97 : : uint16_t rx_free_trigger; /**< triggers rx buffer allocation */
98 : : struct rte_mbuf *rx_stage[RTE_PMD_I40E_RX_MAX_BURST * 2];
99 : : #endif
100 : :
101 : : uint16_t rxrearm_nb; /**< number of remaining to be re-armed */
102 : : uint16_t rxrearm_start; /**< the idx we start the re-arming from */
103 : : uint64_t mbuf_initializer; /**< value to init mbufs */
104 : :
105 : : uint16_t port_id; /**< device port ID */
106 : : uint8_t crc_len; /**< 0 if CRC stripped, 4 otherwise */
107 : : uint8_t fdir_enabled; /**< 0 if FDIR disabled, 1 when enabled */
108 : : uint16_t queue_id; /**< RX queue index */
109 : : uint16_t reg_idx; /**< RX queue register index */
110 : : uint8_t drop_en; /**< if not 0, set register bit */
111 : : volatile uint8_t *qrx_tail; /**< register address of tail */
112 : : struct i40e_vsi *vsi; /**< the VSI this queue belongs to */
113 : : uint16_t rx_buf_len; /* The packet buffer size */
114 : : uint16_t rx_hdr_len; /* The header buffer size */
115 : : uint16_t max_pkt_len; /* Maximum packet length */
116 : : uint8_t hs_mode; /* Header Split mode */
117 : : bool q_set; /**< indicate if rx queue has been configured */
118 : : bool rx_deferred_start; /**< don't start this queue in dev start */
119 : : uint16_t rx_using_sse; /**<flag indicate the usage of vPMD for rx */
120 : : uint8_t dcb_tc; /**< Traffic class of rx queue */
121 : : uint64_t offloads; /**< Rx offload flags of RTE_ETH_RX_OFFLOAD_* */
122 : : const struct rte_memzone *mz;
123 : : };
124 : :
125 : : struct i40e_tx_entry {
126 : : struct rte_mbuf *mbuf;
127 : : uint16_t next_id;
128 : : uint16_t last_id;
129 : : };
130 : :
131 : : struct i40e_vec_tx_entry {
132 : : struct rte_mbuf *mbuf;
133 : : };
134 : :
135 : : /*
136 : : * Structure associated with each TX queue.
137 : : */
138 : : struct i40e_tx_queue {
139 : : uint16_t nb_tx_desc; /**< number of TX descriptors */
140 : : uint64_t tx_ring_phys_addr; /**< TX ring DMA address */
141 : : volatile struct i40e_tx_desc *tx_ring; /**< TX ring virtual address */
142 : : struct i40e_tx_entry *sw_ring; /**< virtual address of SW ring */
143 : : uint16_t tx_tail; /**< current value of tail register */
144 : : volatile uint8_t *qtx_tail; /**< register address of tail */
145 : : uint16_t nb_tx_used; /**< number of TX desc used since RS bit set */
146 : : /**< index to last TX descriptor to have been cleaned */
147 : : uint16_t last_desc_cleaned;
148 : : /**< Total number of TX descriptors ready to be allocated. */
149 : : uint16_t nb_tx_free;
150 : : /**< Start freeing TX buffers if there are less free descriptors than
151 : : this value. */
152 : : uint16_t tx_free_thresh;
153 : : /** Number of TX descriptors to use before RS bit is set. */
154 : : uint16_t tx_rs_thresh;
155 : : uint8_t pthresh; /**< Prefetch threshold register. */
156 : : uint8_t hthresh; /**< Host threshold register. */
157 : : uint8_t wthresh; /**< Write-back threshold reg. */
158 : : uint16_t port_id; /**< Device port identifier. */
159 : : uint16_t queue_id; /**< TX queue index. */
160 : : uint16_t reg_idx;
161 : : struct i40e_vsi *vsi; /**< the VSI this queue belongs to */
162 : : uint16_t tx_next_dd;
163 : : uint16_t tx_next_rs;
164 : : bool q_set; /**< indicate if tx queue has been configured */
165 : : uint64_t mbuf_errors;
166 : :
167 : : bool tx_deferred_start; /**< don't start this queue in dev start */
168 : : uint8_t dcb_tc; /**< Traffic class of tx queue */
169 : : uint64_t offloads; /**< Tx offload flags of RTE_ETH_TX_OFFLOAD_* */
170 : : const struct rte_memzone *mz;
171 : : };
172 : :
173 : : /** Offload features */
174 : : union i40e_tx_offload {
175 : : uint64_t data;
176 : : struct {
177 : : uint64_t l2_len:7; /**< L2 (MAC) Header Length. */
178 : : uint64_t l3_len:9; /**< L3 (IP) Header Length. */
179 : : uint64_t l4_len:8; /**< L4 Header Length. */
180 : : uint64_t tso_segsz:16; /**< TCP TSO segment size */
181 : : uint64_t outer_l2_len:8; /**< outer L2 Header Length */
182 : : uint64_t outer_l3_len:16; /**< outer L3 Header Length */
183 : : };
184 : : };
185 : :
186 : : int i40e_dev_rx_queue_start(struct rte_eth_dev *dev, uint16_t rx_queue_id);
187 : : int i40e_dev_rx_queue_stop(struct rte_eth_dev *dev, uint16_t rx_queue_id);
188 : : int i40e_dev_tx_queue_start(struct rte_eth_dev *dev, uint16_t tx_queue_id);
189 : : int i40e_dev_tx_queue_stop(struct rte_eth_dev *dev, uint16_t tx_queue_id);
190 : : const uint32_t *i40e_dev_supported_ptypes_get(struct rte_eth_dev *dev,
191 : : size_t *no_of_elements);
192 : : int i40e_dev_rx_queue_setup(struct rte_eth_dev *dev,
193 : : uint16_t queue_idx,
194 : : uint16_t nb_desc,
195 : : unsigned int socket_id,
196 : : const struct rte_eth_rxconf *rx_conf,
197 : : struct rte_mempool *mp);
198 : : int i40e_dev_tx_queue_setup(struct rte_eth_dev *dev,
199 : : uint16_t queue_idx,
200 : : uint16_t nb_desc,
201 : : unsigned int socket_id,
202 : : const struct rte_eth_txconf *tx_conf);
203 : : void i40e_rx_queue_release(void *rxq);
204 : : void i40e_tx_queue_release(void *txq);
205 : : void i40e_dev_rx_queue_release(struct rte_eth_dev *dev, uint16_t qid);
206 : : void i40e_dev_tx_queue_release(struct rte_eth_dev *dev, uint16_t qid);
207 : : uint16_t i40e_recv_pkts(void *rx_queue,
208 : : struct rte_mbuf **rx_pkts,
209 : : uint16_t nb_pkts);
210 : : uint16_t i40e_recv_scattered_pkts(void *rx_queue,
211 : : struct rte_mbuf **rx_pkts,
212 : : uint16_t nb_pkts);
213 : : uint16_t i40e_xmit_pkts(void *tx_queue,
214 : : struct rte_mbuf **tx_pkts,
215 : : uint16_t nb_pkts);
216 : : uint16_t i40e_simple_prep_pkts(void *tx_queue, struct rte_mbuf **tx_pkts,
217 : : uint16_t nb_pkts);
218 : : uint16_t i40e_prep_pkts(void *tx_queue, struct rte_mbuf **tx_pkts,
219 : : uint16_t nb_pkts);
220 : : int i40e_tx_queue_init(struct i40e_tx_queue *txq);
221 : : int i40e_rx_queue_init(struct i40e_rx_queue *rxq);
222 : : void i40e_free_tx_resources(struct i40e_tx_queue *txq);
223 : : void i40e_free_rx_resources(struct i40e_rx_queue *rxq);
224 : : void i40e_dev_clear_queues(struct rte_eth_dev *dev);
225 : : void i40e_dev_free_queues(struct rte_eth_dev *dev);
226 : : void i40e_reset_rx_queue(struct i40e_rx_queue *rxq);
227 : : void i40e_reset_tx_queue(struct i40e_tx_queue *txq);
228 : : void i40e_tx_queue_release_mbufs(struct i40e_tx_queue *txq);
229 : : int i40e_tx_done_cleanup(void *txq, uint32_t free_cnt);
230 : : int i40e_alloc_rx_queue_mbufs(struct i40e_rx_queue *rxq);
231 : : void i40e_rx_queue_release_mbufs(struct i40e_rx_queue *rxq);
232 : :
233 : : uint32_t i40e_dev_rx_queue_count(void *rx_queue);
234 : : int i40e_dev_rx_descriptor_status(void *rx_queue, uint16_t offset);
235 : : int i40e_dev_tx_descriptor_status(void *tx_queue, uint16_t offset);
236 : :
237 : : uint16_t i40e_recycle_tx_mbufs_reuse_vec(void *tx_queue,
238 : : struct rte_eth_recycle_rxq_info *recycle_rxq_info);
239 : : void i40e_recycle_rx_descriptors_refill_vec(void *rx_queue, uint16_t nb_mbufs);
240 : :
241 : : uint16_t i40e_recv_pkts_vec(void *rx_queue, struct rte_mbuf **rx_pkts,
242 : : uint16_t nb_pkts);
243 : : uint16_t i40e_recv_scattered_pkts_vec(void *rx_queue,
244 : : struct rte_mbuf **rx_pkts,
245 : : uint16_t nb_pkts);
246 : : int i40e_rx_vec_dev_conf_condition_check(struct rte_eth_dev *dev);
247 : : int i40e_rxq_vec_setup(struct i40e_rx_queue *rxq);
248 : : int i40e_txq_vec_setup(struct i40e_tx_queue *txq);
249 : : void i40e_rx_queue_release_mbufs_vec(struct i40e_rx_queue *rxq);
250 : : uint16_t i40e_xmit_fixed_burst_vec(void *tx_queue, struct rte_mbuf **tx_pkts,
251 : : uint16_t nb_pkts);
252 : : void i40e_set_rx_function(struct rte_eth_dev *dev);
253 : : void i40e_set_tx_function_flag(struct rte_eth_dev *dev,
254 : : struct i40e_tx_queue *txq);
255 : : void i40e_set_tx_function(struct rte_eth_dev *dev);
256 : : void i40e_set_default_ptype_table(struct rte_eth_dev *dev);
257 : : void i40e_set_default_pctype_table(struct rte_eth_dev *dev);
258 : : uint16_t i40e_recv_pkts_vec_avx2(void *rx_queue, struct rte_mbuf **rx_pkts,
259 : : uint16_t nb_pkts);
260 : : uint16_t i40e_recv_scattered_pkts_vec_avx2(void *rx_queue,
261 : : struct rte_mbuf **rx_pkts, uint16_t nb_pkts);
262 : : uint16_t i40e_xmit_pkts_vec_avx2(void *tx_queue, struct rte_mbuf **tx_pkts,
263 : : uint16_t nb_pkts);
264 : : int i40e_get_monitor_addr(void *rx_queue, struct rte_power_monitor_cond *pmc);
265 : : uint16_t i40e_recv_pkts_vec_avx512(void *rx_queue,
266 : : struct rte_mbuf **rx_pkts,
267 : : uint16_t nb_pkts);
268 : : uint16_t i40e_recv_scattered_pkts_vec_avx512(void *rx_queue,
269 : : struct rte_mbuf **rx_pkts,
270 : : uint16_t nb_pkts);
271 : : uint16_t i40e_xmit_pkts_vec_avx512(void *tx_queue,
272 : : struct rte_mbuf **tx_pkts,
273 : : uint16_t nb_pkts);
274 : :
275 : : /* For each value it means, datasheet of hardware can tell more details
276 : : *
277 : : * @note: fix i40e_dev_supported_ptypes_get() if any change here.
278 : : */
279 : : static inline uint32_t
280 : : i40e_get_default_pkt_type(uint8_t ptype)
281 : : {
282 : : static const alignas(RTE_CACHE_LINE_SIZE) uint32_t type_table[UINT8_MAX + 1] = {
283 : : /* L2 types */
284 : : /* [0] reserved */
285 : : [1] = RTE_PTYPE_L2_ETHER,
286 : : [2] = RTE_PTYPE_L2_ETHER_TIMESYNC,
287 : : /* [3] - [5] reserved */
288 : : [6] = RTE_PTYPE_L2_ETHER_LLDP,
289 : : /* [7] - [10] reserved */
290 : : [11] = RTE_PTYPE_L2_ETHER_ARP,
291 : : /* [12] - [21] reserved */
292 : :
293 : : /* Non tunneled IPv4 */
294 : : [22] = RTE_PTYPE_L2_ETHER | RTE_PTYPE_L3_IPV4_EXT_UNKNOWN |
295 : : RTE_PTYPE_L4_FRAG,
296 : : [23] = RTE_PTYPE_L2_ETHER | RTE_PTYPE_L3_IPV4_EXT_UNKNOWN |
297 : : RTE_PTYPE_L4_NONFRAG,
298 : : [24] = RTE_PTYPE_L2_ETHER | RTE_PTYPE_L3_IPV4_EXT_UNKNOWN |
299 : : RTE_PTYPE_L4_UDP,
300 : : /* [25] reserved */
301 : : [26] = RTE_PTYPE_L2_ETHER | RTE_PTYPE_L3_IPV4_EXT_UNKNOWN |
302 : : RTE_PTYPE_L4_TCP,
303 : : [27] = RTE_PTYPE_L2_ETHER | RTE_PTYPE_L3_IPV4_EXT_UNKNOWN |
304 : : RTE_PTYPE_L4_SCTP,
305 : : [28] = RTE_PTYPE_L2_ETHER | RTE_PTYPE_L3_IPV4_EXT_UNKNOWN |
306 : : RTE_PTYPE_L4_ICMP,
307 : :
308 : : /* IPv4 --> IPv4 */
309 : : [29] = RTE_PTYPE_L2_ETHER | RTE_PTYPE_L3_IPV4_EXT_UNKNOWN |
310 : : RTE_PTYPE_TUNNEL_IP |
311 : : RTE_PTYPE_INNER_L3_IPV4_EXT_UNKNOWN |
312 : : RTE_PTYPE_INNER_L4_FRAG,
313 : : [30] = RTE_PTYPE_L2_ETHER | RTE_PTYPE_L3_IPV4_EXT_UNKNOWN |
314 : : RTE_PTYPE_TUNNEL_IP |
315 : : RTE_PTYPE_INNER_L3_IPV4_EXT_UNKNOWN |
316 : : RTE_PTYPE_INNER_L4_NONFRAG,
317 : : [31] = RTE_PTYPE_L2_ETHER | RTE_PTYPE_L3_IPV4_EXT_UNKNOWN |
318 : : RTE_PTYPE_TUNNEL_IP |
319 : : RTE_PTYPE_INNER_L3_IPV4_EXT_UNKNOWN |
320 : : RTE_PTYPE_INNER_L4_UDP,
321 : : /* [32] reserved */
322 : : [33] = RTE_PTYPE_L2_ETHER | RTE_PTYPE_L3_IPV4_EXT_UNKNOWN |
323 : : RTE_PTYPE_TUNNEL_IP |
324 : : RTE_PTYPE_INNER_L3_IPV4_EXT_UNKNOWN |
325 : : RTE_PTYPE_INNER_L4_TCP,
326 : : [34] = RTE_PTYPE_L2_ETHER | RTE_PTYPE_L3_IPV4_EXT_UNKNOWN |
327 : : RTE_PTYPE_TUNNEL_IP |
328 : : RTE_PTYPE_INNER_L3_IPV4_EXT_UNKNOWN |
329 : : RTE_PTYPE_INNER_L4_SCTP,
330 : : [35] = RTE_PTYPE_L2_ETHER | RTE_PTYPE_L3_IPV4_EXT_UNKNOWN |
331 : : RTE_PTYPE_TUNNEL_IP |
332 : : RTE_PTYPE_INNER_L3_IPV4_EXT_UNKNOWN |
333 : : RTE_PTYPE_INNER_L4_ICMP,
334 : :
335 : : /* IPv4 --> IPv6 */
336 : : [36] = RTE_PTYPE_L2_ETHER | RTE_PTYPE_L3_IPV4_EXT_UNKNOWN |
337 : : RTE_PTYPE_TUNNEL_IP |
338 : : RTE_PTYPE_INNER_L3_IPV6_EXT_UNKNOWN |
339 : : RTE_PTYPE_INNER_L4_FRAG,
340 : : [37] = RTE_PTYPE_L2_ETHER | RTE_PTYPE_L3_IPV4_EXT_UNKNOWN |
341 : : RTE_PTYPE_TUNNEL_IP |
342 : : RTE_PTYPE_INNER_L3_IPV6_EXT_UNKNOWN |
343 : : RTE_PTYPE_INNER_L4_NONFRAG,
344 : : [38] = RTE_PTYPE_L2_ETHER | RTE_PTYPE_L3_IPV4_EXT_UNKNOWN |
345 : : RTE_PTYPE_TUNNEL_IP |
346 : : RTE_PTYPE_INNER_L3_IPV6_EXT_UNKNOWN |
347 : : RTE_PTYPE_INNER_L4_UDP,
348 : : /* [39] reserved */
349 : : [40] = RTE_PTYPE_L2_ETHER | RTE_PTYPE_L3_IPV4_EXT_UNKNOWN |
350 : : RTE_PTYPE_TUNNEL_IP |
351 : : RTE_PTYPE_INNER_L3_IPV6_EXT_UNKNOWN |
352 : : RTE_PTYPE_INNER_L4_TCP,
353 : : [41] = RTE_PTYPE_L2_ETHER | RTE_PTYPE_L3_IPV4_EXT_UNKNOWN |
354 : : RTE_PTYPE_TUNNEL_IP |
355 : : RTE_PTYPE_INNER_L3_IPV6_EXT_UNKNOWN |
356 : : RTE_PTYPE_INNER_L4_SCTP,
357 : : [42] = RTE_PTYPE_L2_ETHER | RTE_PTYPE_L3_IPV4_EXT_UNKNOWN |
358 : : RTE_PTYPE_TUNNEL_IP |
359 : : RTE_PTYPE_INNER_L3_IPV6_EXT_UNKNOWN |
360 : : RTE_PTYPE_INNER_L4_ICMP,
361 : :
362 : : /* IPv4 --> GRE/Teredo/VXLAN */
363 : : [43] = RTE_PTYPE_L2_ETHER | RTE_PTYPE_L3_IPV4_EXT_UNKNOWN |
364 : : RTE_PTYPE_TUNNEL_GRENAT,
365 : :
366 : : /* IPv4 --> GRE/Teredo/VXLAN --> IPv4 */
367 : : [44] = RTE_PTYPE_L2_ETHER | RTE_PTYPE_L3_IPV4_EXT_UNKNOWN |
368 : : RTE_PTYPE_TUNNEL_GRENAT |
369 : : RTE_PTYPE_INNER_L3_IPV4_EXT_UNKNOWN |
370 : : RTE_PTYPE_INNER_L4_FRAG,
371 : : [45] = RTE_PTYPE_L2_ETHER | RTE_PTYPE_L3_IPV4_EXT_UNKNOWN |
372 : : RTE_PTYPE_TUNNEL_GRENAT |
373 : : RTE_PTYPE_INNER_L3_IPV4_EXT_UNKNOWN |
374 : : RTE_PTYPE_INNER_L4_NONFRAG,
375 : : [46] = RTE_PTYPE_L2_ETHER | RTE_PTYPE_L3_IPV4_EXT_UNKNOWN |
376 : : RTE_PTYPE_TUNNEL_GRENAT |
377 : : RTE_PTYPE_INNER_L3_IPV4_EXT_UNKNOWN |
378 : : RTE_PTYPE_INNER_L4_UDP,
379 : : /* [47] reserved */
380 : : [48] = RTE_PTYPE_L2_ETHER | RTE_PTYPE_L3_IPV4_EXT_UNKNOWN |
381 : : RTE_PTYPE_TUNNEL_GRENAT |
382 : : RTE_PTYPE_INNER_L3_IPV4_EXT_UNKNOWN |
383 : : RTE_PTYPE_INNER_L4_TCP,
384 : : [49] = RTE_PTYPE_L2_ETHER | RTE_PTYPE_L3_IPV4_EXT_UNKNOWN |
385 : : RTE_PTYPE_TUNNEL_GRENAT |
386 : : RTE_PTYPE_INNER_L3_IPV4_EXT_UNKNOWN |
387 : : RTE_PTYPE_INNER_L4_SCTP,
388 : : [50] = RTE_PTYPE_L2_ETHER | RTE_PTYPE_L3_IPV4_EXT_UNKNOWN |
389 : : RTE_PTYPE_TUNNEL_GRENAT |
390 : : RTE_PTYPE_INNER_L3_IPV4_EXT_UNKNOWN |
391 : : RTE_PTYPE_INNER_L4_ICMP,
392 : :
393 : : /* IPv4 --> GRE/Teredo/VXLAN --> IPv6 */
394 : : [51] = RTE_PTYPE_L2_ETHER | RTE_PTYPE_L3_IPV4_EXT_UNKNOWN |
395 : : RTE_PTYPE_TUNNEL_GRENAT |
396 : : RTE_PTYPE_INNER_L3_IPV6_EXT_UNKNOWN |
397 : : RTE_PTYPE_INNER_L4_FRAG,
398 : : [52] = RTE_PTYPE_L2_ETHER | RTE_PTYPE_L3_IPV4_EXT_UNKNOWN |
399 : : RTE_PTYPE_TUNNEL_GRENAT |
400 : : RTE_PTYPE_INNER_L3_IPV6_EXT_UNKNOWN |
401 : : RTE_PTYPE_INNER_L4_NONFRAG,
402 : : [53] = RTE_PTYPE_L2_ETHER | RTE_PTYPE_L3_IPV4_EXT_UNKNOWN |
403 : : RTE_PTYPE_TUNNEL_GRENAT |
404 : : RTE_PTYPE_INNER_L3_IPV6_EXT_UNKNOWN |
405 : : RTE_PTYPE_INNER_L4_UDP,
406 : : /* [54] reserved */
407 : : [55] = RTE_PTYPE_L2_ETHER | RTE_PTYPE_L3_IPV4_EXT_UNKNOWN |
408 : : RTE_PTYPE_TUNNEL_GRENAT |
409 : : RTE_PTYPE_INNER_L3_IPV6_EXT_UNKNOWN |
410 : : RTE_PTYPE_INNER_L4_TCP,
411 : : [56] = RTE_PTYPE_L2_ETHER | RTE_PTYPE_L3_IPV4_EXT_UNKNOWN |
412 : : RTE_PTYPE_TUNNEL_GRENAT |
413 : : RTE_PTYPE_INNER_L3_IPV6_EXT_UNKNOWN |
414 : : RTE_PTYPE_INNER_L4_SCTP,
415 : : [57] = RTE_PTYPE_L2_ETHER | RTE_PTYPE_L3_IPV4_EXT_UNKNOWN |
416 : : RTE_PTYPE_TUNNEL_GRENAT |
417 : : RTE_PTYPE_INNER_L3_IPV6_EXT_UNKNOWN |
418 : : RTE_PTYPE_INNER_L4_ICMP,
419 : :
420 : : /* IPv4 --> GRE/Teredo/VXLAN --> MAC */
421 : : [58] = RTE_PTYPE_L2_ETHER | RTE_PTYPE_L3_IPV4_EXT_UNKNOWN |
422 : : RTE_PTYPE_TUNNEL_GRENAT | RTE_PTYPE_INNER_L2_ETHER,
423 : :
424 : : /* IPv4 --> GRE/Teredo/VXLAN --> MAC --> IPv4 */
425 : : [59] = RTE_PTYPE_L2_ETHER | RTE_PTYPE_L3_IPV4_EXT_UNKNOWN |
426 : : RTE_PTYPE_TUNNEL_GRENAT | RTE_PTYPE_INNER_L2_ETHER |
427 : : RTE_PTYPE_INNER_L3_IPV4_EXT_UNKNOWN |
428 : : RTE_PTYPE_INNER_L4_FRAG,
429 : : [60] = RTE_PTYPE_L2_ETHER | RTE_PTYPE_L3_IPV4_EXT_UNKNOWN |
430 : : RTE_PTYPE_TUNNEL_GRENAT | RTE_PTYPE_INNER_L2_ETHER |
431 : : RTE_PTYPE_INNER_L3_IPV4_EXT_UNKNOWN |
432 : : RTE_PTYPE_INNER_L4_NONFRAG,
433 : : [61] = RTE_PTYPE_L2_ETHER | RTE_PTYPE_L3_IPV4_EXT_UNKNOWN |
434 : : RTE_PTYPE_TUNNEL_GRENAT | RTE_PTYPE_INNER_L2_ETHER |
435 : : RTE_PTYPE_INNER_L3_IPV4_EXT_UNKNOWN |
436 : : RTE_PTYPE_INNER_L4_UDP,
437 : : /* [62] reserved */
438 : : [63] = RTE_PTYPE_L2_ETHER | RTE_PTYPE_L3_IPV4_EXT_UNKNOWN |
439 : : RTE_PTYPE_TUNNEL_GRENAT | RTE_PTYPE_INNER_L2_ETHER |
440 : : RTE_PTYPE_INNER_L3_IPV4_EXT_UNKNOWN |
441 : : RTE_PTYPE_INNER_L4_TCP,
442 : : [64] = RTE_PTYPE_L2_ETHER | RTE_PTYPE_L3_IPV4_EXT_UNKNOWN |
443 : : RTE_PTYPE_TUNNEL_GRENAT | RTE_PTYPE_INNER_L2_ETHER |
444 : : RTE_PTYPE_INNER_L3_IPV4_EXT_UNKNOWN |
445 : : RTE_PTYPE_INNER_L4_SCTP,
446 : : [65] = RTE_PTYPE_L2_ETHER | RTE_PTYPE_L3_IPV4_EXT_UNKNOWN |
447 : : RTE_PTYPE_TUNNEL_GRENAT | RTE_PTYPE_INNER_L2_ETHER |
448 : : RTE_PTYPE_INNER_L3_IPV4_EXT_UNKNOWN |
449 : : RTE_PTYPE_INNER_L4_ICMP,
450 : :
451 : : /* IPv4 --> GRE/Teredo/VXLAN --> MAC --> IPv6 */
452 : : [66] = RTE_PTYPE_L2_ETHER | RTE_PTYPE_L3_IPV4_EXT_UNKNOWN |
453 : : RTE_PTYPE_TUNNEL_GRENAT | RTE_PTYPE_INNER_L2_ETHER |
454 : : RTE_PTYPE_INNER_L3_IPV6_EXT_UNKNOWN |
455 : : RTE_PTYPE_INNER_L4_FRAG,
456 : : [67] = RTE_PTYPE_L2_ETHER | RTE_PTYPE_L3_IPV4_EXT_UNKNOWN |
457 : : RTE_PTYPE_TUNNEL_GRENAT | RTE_PTYPE_INNER_L2_ETHER |
458 : : RTE_PTYPE_INNER_L3_IPV6_EXT_UNKNOWN |
459 : : RTE_PTYPE_INNER_L4_NONFRAG,
460 : : [68] = RTE_PTYPE_L2_ETHER | RTE_PTYPE_L3_IPV4_EXT_UNKNOWN |
461 : : RTE_PTYPE_TUNNEL_GRENAT | RTE_PTYPE_INNER_L2_ETHER |
462 : : RTE_PTYPE_INNER_L3_IPV6_EXT_UNKNOWN |
463 : : RTE_PTYPE_INNER_L4_UDP,
464 : : /* [69] reserved */
465 : : [70] = RTE_PTYPE_L2_ETHER | RTE_PTYPE_L3_IPV4_EXT_UNKNOWN |
466 : : RTE_PTYPE_TUNNEL_GRENAT | RTE_PTYPE_INNER_L2_ETHER |
467 : : RTE_PTYPE_INNER_L3_IPV6_EXT_UNKNOWN |
468 : : RTE_PTYPE_INNER_L4_TCP,
469 : : [71] = RTE_PTYPE_L2_ETHER | RTE_PTYPE_L3_IPV4_EXT_UNKNOWN |
470 : : RTE_PTYPE_TUNNEL_GRENAT | RTE_PTYPE_INNER_L2_ETHER |
471 : : RTE_PTYPE_INNER_L3_IPV6_EXT_UNKNOWN |
472 : : RTE_PTYPE_INNER_L4_SCTP,
473 : : [72] = RTE_PTYPE_L2_ETHER | RTE_PTYPE_L3_IPV4_EXT_UNKNOWN |
474 : : RTE_PTYPE_TUNNEL_GRENAT | RTE_PTYPE_INNER_L2_ETHER |
475 : : RTE_PTYPE_INNER_L3_IPV6_EXT_UNKNOWN |
476 : : RTE_PTYPE_INNER_L4_ICMP,
477 : :
478 : : /* IPv4 --> GRE/Teredo/VXLAN --> MAC/VLAN */
479 : : [73] = RTE_PTYPE_L2_ETHER | RTE_PTYPE_L3_IPV4_EXT_UNKNOWN |
480 : : RTE_PTYPE_TUNNEL_GRENAT |
481 : : RTE_PTYPE_INNER_L2_ETHER_VLAN,
482 : :
483 : : /* IPv4 --> GRE/Teredo/VXLAN --> MAC/VLAN --> IPv4 */
484 : : [74] = RTE_PTYPE_L2_ETHER | RTE_PTYPE_L3_IPV4_EXT_UNKNOWN |
485 : : RTE_PTYPE_TUNNEL_GRENAT |
486 : : RTE_PTYPE_INNER_L2_ETHER_VLAN |
487 : : RTE_PTYPE_INNER_L3_IPV4_EXT_UNKNOWN |
488 : : RTE_PTYPE_INNER_L4_FRAG,
489 : : [75] = RTE_PTYPE_L2_ETHER | RTE_PTYPE_L3_IPV4_EXT_UNKNOWN |
490 : : RTE_PTYPE_TUNNEL_GRENAT |
491 : : RTE_PTYPE_INNER_L2_ETHER_VLAN |
492 : : RTE_PTYPE_INNER_L3_IPV4_EXT_UNKNOWN |
493 : : RTE_PTYPE_INNER_L4_NONFRAG,
494 : : [76] = RTE_PTYPE_L2_ETHER | RTE_PTYPE_L3_IPV4_EXT_UNKNOWN |
495 : : RTE_PTYPE_TUNNEL_GRENAT |
496 : : RTE_PTYPE_INNER_L2_ETHER_VLAN |
497 : : RTE_PTYPE_INNER_L3_IPV4_EXT_UNKNOWN |
498 : : RTE_PTYPE_INNER_L4_UDP,
499 : : /* [77] reserved */
500 : : [78] = RTE_PTYPE_L2_ETHER | RTE_PTYPE_L3_IPV4_EXT_UNKNOWN |
501 : : RTE_PTYPE_TUNNEL_GRENAT |
502 : : RTE_PTYPE_INNER_L2_ETHER_VLAN |
503 : : RTE_PTYPE_INNER_L3_IPV4_EXT_UNKNOWN |
504 : : RTE_PTYPE_INNER_L4_TCP,
505 : : [79] = RTE_PTYPE_L2_ETHER | RTE_PTYPE_L3_IPV4_EXT_UNKNOWN |
506 : : RTE_PTYPE_TUNNEL_GRENAT |
507 : : RTE_PTYPE_INNER_L2_ETHER_VLAN |
508 : : RTE_PTYPE_INNER_L3_IPV4_EXT_UNKNOWN |
509 : : RTE_PTYPE_INNER_L4_SCTP,
510 : : [80] = RTE_PTYPE_L2_ETHER | RTE_PTYPE_L3_IPV4_EXT_UNKNOWN |
511 : : RTE_PTYPE_TUNNEL_GRENAT |
512 : : RTE_PTYPE_INNER_L2_ETHER_VLAN |
513 : : RTE_PTYPE_INNER_L3_IPV4_EXT_UNKNOWN |
514 : : RTE_PTYPE_INNER_L4_ICMP,
515 : :
516 : : /* IPv4 --> GRE/Teredo/VXLAN --> MAC/VLAN --> IPv6 */
517 : : [81] = RTE_PTYPE_L2_ETHER | RTE_PTYPE_L3_IPV4_EXT_UNKNOWN |
518 : : RTE_PTYPE_TUNNEL_GRENAT |
519 : : RTE_PTYPE_INNER_L2_ETHER_VLAN |
520 : : RTE_PTYPE_INNER_L3_IPV6_EXT_UNKNOWN |
521 : : RTE_PTYPE_INNER_L4_FRAG,
522 : : [82] = RTE_PTYPE_L2_ETHER | RTE_PTYPE_L3_IPV4_EXT_UNKNOWN |
523 : : RTE_PTYPE_TUNNEL_GRENAT |
524 : : RTE_PTYPE_INNER_L2_ETHER_VLAN |
525 : : RTE_PTYPE_INNER_L3_IPV6_EXT_UNKNOWN |
526 : : RTE_PTYPE_INNER_L4_NONFRAG,
527 : : [83] = RTE_PTYPE_L2_ETHER | RTE_PTYPE_L3_IPV4_EXT_UNKNOWN |
528 : : RTE_PTYPE_TUNNEL_GRENAT |
529 : : RTE_PTYPE_INNER_L2_ETHER_VLAN |
530 : : RTE_PTYPE_INNER_L3_IPV6_EXT_UNKNOWN |
531 : : RTE_PTYPE_INNER_L4_UDP,
532 : : /* [84] reserved */
533 : : [85] = RTE_PTYPE_L2_ETHER | RTE_PTYPE_L3_IPV4_EXT_UNKNOWN |
534 : : RTE_PTYPE_TUNNEL_GRENAT |
535 : : RTE_PTYPE_INNER_L2_ETHER_VLAN |
536 : : RTE_PTYPE_INNER_L3_IPV6_EXT_UNKNOWN |
537 : : RTE_PTYPE_INNER_L4_TCP,
538 : : [86] = RTE_PTYPE_L2_ETHER | RTE_PTYPE_L3_IPV4_EXT_UNKNOWN |
539 : : RTE_PTYPE_TUNNEL_GRENAT |
540 : : RTE_PTYPE_INNER_L2_ETHER_VLAN |
541 : : RTE_PTYPE_INNER_L3_IPV6_EXT_UNKNOWN |
542 : : RTE_PTYPE_INNER_L4_SCTP,
543 : : [87] = RTE_PTYPE_L2_ETHER | RTE_PTYPE_L3_IPV4_EXT_UNKNOWN |
544 : : RTE_PTYPE_TUNNEL_GRENAT |
545 : : RTE_PTYPE_INNER_L2_ETHER_VLAN |
546 : : RTE_PTYPE_INNER_L3_IPV6_EXT_UNKNOWN |
547 : : RTE_PTYPE_INNER_L4_ICMP,
548 : :
549 : : /* Non tunneled IPv6 */
550 : : [88] = RTE_PTYPE_L2_ETHER | RTE_PTYPE_L3_IPV6_EXT_UNKNOWN |
551 : : RTE_PTYPE_L4_FRAG,
552 : : [89] = RTE_PTYPE_L2_ETHER | RTE_PTYPE_L3_IPV6_EXT_UNKNOWN |
553 : : RTE_PTYPE_L4_NONFRAG,
554 : : [90] = RTE_PTYPE_L2_ETHER | RTE_PTYPE_L3_IPV6_EXT_UNKNOWN |
555 : : RTE_PTYPE_L4_UDP,
556 : : /* [91] reserved */
557 : : [92] = RTE_PTYPE_L2_ETHER | RTE_PTYPE_L3_IPV6_EXT_UNKNOWN |
558 : : RTE_PTYPE_L4_TCP,
559 : : [93] = RTE_PTYPE_L2_ETHER | RTE_PTYPE_L3_IPV6_EXT_UNKNOWN |
560 : : RTE_PTYPE_L4_SCTP,
561 : : [94] = RTE_PTYPE_L2_ETHER | RTE_PTYPE_L3_IPV6_EXT_UNKNOWN |
562 : : RTE_PTYPE_L4_ICMP,
563 : :
564 : : /* IPv6 --> IPv4 */
565 : : [95] = RTE_PTYPE_L2_ETHER | RTE_PTYPE_L3_IPV6_EXT_UNKNOWN |
566 : : RTE_PTYPE_TUNNEL_IP |
567 : : RTE_PTYPE_INNER_L3_IPV4_EXT_UNKNOWN |
568 : : RTE_PTYPE_INNER_L4_FRAG,
569 : : [96] = RTE_PTYPE_L2_ETHER | RTE_PTYPE_L3_IPV6_EXT_UNKNOWN |
570 : : RTE_PTYPE_TUNNEL_IP |
571 : : RTE_PTYPE_INNER_L3_IPV4_EXT_UNKNOWN |
572 : : RTE_PTYPE_INNER_L4_NONFRAG,
573 : : [97] = RTE_PTYPE_L2_ETHER | RTE_PTYPE_L3_IPV6_EXT_UNKNOWN |
574 : : RTE_PTYPE_TUNNEL_IP |
575 : : RTE_PTYPE_INNER_L3_IPV4_EXT_UNKNOWN |
576 : : RTE_PTYPE_INNER_L4_UDP,
577 : : /* [98] reserved */
578 : : [99] = RTE_PTYPE_L2_ETHER | RTE_PTYPE_L3_IPV6_EXT_UNKNOWN |
579 : : RTE_PTYPE_TUNNEL_IP |
580 : : RTE_PTYPE_INNER_L3_IPV4_EXT_UNKNOWN |
581 : : RTE_PTYPE_INNER_L4_TCP,
582 : : [100] = RTE_PTYPE_L2_ETHER | RTE_PTYPE_L3_IPV6_EXT_UNKNOWN |
583 : : RTE_PTYPE_TUNNEL_IP |
584 : : RTE_PTYPE_INNER_L3_IPV4_EXT_UNKNOWN |
585 : : RTE_PTYPE_INNER_L4_SCTP,
586 : : [101] = RTE_PTYPE_L2_ETHER | RTE_PTYPE_L3_IPV6_EXT_UNKNOWN |
587 : : RTE_PTYPE_TUNNEL_IP |
588 : : RTE_PTYPE_INNER_L3_IPV4_EXT_UNKNOWN |
589 : : RTE_PTYPE_INNER_L4_ICMP,
590 : :
591 : : /* IPv6 --> IPv6 */
592 : : [102] = RTE_PTYPE_L2_ETHER | RTE_PTYPE_L3_IPV6_EXT_UNKNOWN |
593 : : RTE_PTYPE_TUNNEL_IP |
594 : : RTE_PTYPE_INNER_L3_IPV6_EXT_UNKNOWN |
595 : : RTE_PTYPE_INNER_L4_FRAG,
596 : : [103] = RTE_PTYPE_L2_ETHER | RTE_PTYPE_L3_IPV6_EXT_UNKNOWN |
597 : : RTE_PTYPE_TUNNEL_IP |
598 : : RTE_PTYPE_INNER_L3_IPV6_EXT_UNKNOWN |
599 : : RTE_PTYPE_INNER_L4_NONFRAG,
600 : : [104] = RTE_PTYPE_L2_ETHER | RTE_PTYPE_L3_IPV6_EXT_UNKNOWN |
601 : : RTE_PTYPE_TUNNEL_IP |
602 : : RTE_PTYPE_INNER_L3_IPV6_EXT_UNKNOWN |
603 : : RTE_PTYPE_INNER_L4_UDP,
604 : : /* [105] reserved */
605 : : [106] = RTE_PTYPE_L2_ETHER | RTE_PTYPE_L3_IPV6_EXT_UNKNOWN |
606 : : RTE_PTYPE_TUNNEL_IP |
607 : : RTE_PTYPE_INNER_L3_IPV6_EXT_UNKNOWN |
608 : : RTE_PTYPE_INNER_L4_TCP,
609 : : [107] = RTE_PTYPE_L2_ETHER | RTE_PTYPE_L3_IPV6_EXT_UNKNOWN |
610 : : RTE_PTYPE_TUNNEL_IP |
611 : : RTE_PTYPE_INNER_L3_IPV6_EXT_UNKNOWN |
612 : : RTE_PTYPE_INNER_L4_SCTP,
613 : : [108] = RTE_PTYPE_L2_ETHER | RTE_PTYPE_L3_IPV6_EXT_UNKNOWN |
614 : : RTE_PTYPE_TUNNEL_IP |
615 : : RTE_PTYPE_INNER_L3_IPV6_EXT_UNKNOWN |
616 : : RTE_PTYPE_INNER_L4_ICMP,
617 : :
618 : : /* IPv6 --> GRE/Teredo/VXLAN */
619 : : [109] = RTE_PTYPE_L2_ETHER | RTE_PTYPE_L3_IPV6_EXT_UNKNOWN |
620 : : RTE_PTYPE_TUNNEL_GRENAT,
621 : :
622 : : /* IPv6 --> GRE/Teredo/VXLAN --> IPv4 */
623 : : [110] = RTE_PTYPE_L2_ETHER | RTE_PTYPE_L3_IPV6_EXT_UNKNOWN |
624 : : RTE_PTYPE_TUNNEL_GRENAT |
625 : : RTE_PTYPE_INNER_L3_IPV4_EXT_UNKNOWN |
626 : : RTE_PTYPE_INNER_L4_FRAG,
627 : : [111] = RTE_PTYPE_L2_ETHER | RTE_PTYPE_L3_IPV6_EXT_UNKNOWN |
628 : : RTE_PTYPE_TUNNEL_GRENAT |
629 : : RTE_PTYPE_INNER_L3_IPV4_EXT_UNKNOWN |
630 : : RTE_PTYPE_INNER_L4_NONFRAG,
631 : : [112] = RTE_PTYPE_L2_ETHER | RTE_PTYPE_L3_IPV6_EXT_UNKNOWN |
632 : : RTE_PTYPE_TUNNEL_GRENAT |
633 : : RTE_PTYPE_INNER_L3_IPV4_EXT_UNKNOWN |
634 : : RTE_PTYPE_INNER_L4_UDP,
635 : : /* [113] reserved */
636 : : [114] = RTE_PTYPE_L2_ETHER | RTE_PTYPE_L3_IPV6_EXT_UNKNOWN |
637 : : RTE_PTYPE_TUNNEL_GRENAT |
638 : : RTE_PTYPE_INNER_L3_IPV4_EXT_UNKNOWN |
639 : : RTE_PTYPE_INNER_L4_TCP,
640 : : [115] = RTE_PTYPE_L2_ETHER | RTE_PTYPE_L3_IPV6_EXT_UNKNOWN |
641 : : RTE_PTYPE_TUNNEL_GRENAT |
642 : : RTE_PTYPE_INNER_L3_IPV4_EXT_UNKNOWN |
643 : : RTE_PTYPE_INNER_L4_SCTP,
644 : : [116] = RTE_PTYPE_L2_ETHER | RTE_PTYPE_L3_IPV6_EXT_UNKNOWN |
645 : : RTE_PTYPE_TUNNEL_GRENAT |
646 : : RTE_PTYPE_INNER_L3_IPV4_EXT_UNKNOWN |
647 : : RTE_PTYPE_INNER_L4_ICMP,
648 : :
649 : : /* IPv6 --> GRE/Teredo/VXLAN --> IPv6 */
650 : : [117] = RTE_PTYPE_L2_ETHER | RTE_PTYPE_L3_IPV6_EXT_UNKNOWN |
651 : : RTE_PTYPE_TUNNEL_GRENAT |
652 : : RTE_PTYPE_INNER_L3_IPV6_EXT_UNKNOWN |
653 : : RTE_PTYPE_INNER_L4_FRAG,
654 : : [118] = RTE_PTYPE_L2_ETHER | RTE_PTYPE_L3_IPV6_EXT_UNKNOWN |
655 : : RTE_PTYPE_TUNNEL_GRENAT |
656 : : RTE_PTYPE_INNER_L3_IPV6_EXT_UNKNOWN |
657 : : RTE_PTYPE_INNER_L4_NONFRAG,
658 : : [119] = RTE_PTYPE_L2_ETHER | RTE_PTYPE_L3_IPV6_EXT_UNKNOWN |
659 : : RTE_PTYPE_TUNNEL_GRENAT |
660 : : RTE_PTYPE_INNER_L3_IPV6_EXT_UNKNOWN |
661 : : RTE_PTYPE_INNER_L4_UDP,
662 : : /* [120] reserved */
663 : : [121] = RTE_PTYPE_L2_ETHER | RTE_PTYPE_L3_IPV6_EXT_UNKNOWN |
664 : : RTE_PTYPE_TUNNEL_GRENAT |
665 : : RTE_PTYPE_INNER_L3_IPV6_EXT_UNKNOWN |
666 : : RTE_PTYPE_INNER_L4_TCP,
667 : : [122] = RTE_PTYPE_L2_ETHER | RTE_PTYPE_L3_IPV6_EXT_UNKNOWN |
668 : : RTE_PTYPE_TUNNEL_GRENAT |
669 : : RTE_PTYPE_INNER_L3_IPV6_EXT_UNKNOWN |
670 : : RTE_PTYPE_INNER_L4_SCTP,
671 : : [123] = RTE_PTYPE_L2_ETHER | RTE_PTYPE_L3_IPV6_EXT_UNKNOWN |
672 : : RTE_PTYPE_TUNNEL_GRENAT |
673 : : RTE_PTYPE_INNER_L3_IPV6_EXT_UNKNOWN |
674 : : RTE_PTYPE_INNER_L4_ICMP,
675 : :
676 : : /* IPv6 --> GRE/Teredo/VXLAN --> MAC */
677 : : [124] = RTE_PTYPE_L2_ETHER | RTE_PTYPE_L3_IPV6_EXT_UNKNOWN |
678 : : RTE_PTYPE_TUNNEL_GRENAT | RTE_PTYPE_INNER_L2_ETHER,
679 : :
680 : : /* IPv6 --> GRE/Teredo/VXLAN --> MAC --> IPv4 */
681 : : [125] = RTE_PTYPE_L2_ETHER | RTE_PTYPE_L3_IPV6_EXT_UNKNOWN |
682 : : RTE_PTYPE_TUNNEL_GRENAT | RTE_PTYPE_INNER_L2_ETHER |
683 : : RTE_PTYPE_INNER_L3_IPV4_EXT_UNKNOWN |
684 : : RTE_PTYPE_INNER_L4_FRAG,
685 : : [126] = RTE_PTYPE_L2_ETHER | RTE_PTYPE_L3_IPV6_EXT_UNKNOWN |
686 : : RTE_PTYPE_TUNNEL_GRENAT | RTE_PTYPE_INNER_L2_ETHER |
687 : : RTE_PTYPE_INNER_L3_IPV4_EXT_UNKNOWN |
688 : : RTE_PTYPE_INNER_L4_NONFRAG,
689 : : [127] = RTE_PTYPE_L2_ETHER | RTE_PTYPE_L3_IPV6_EXT_UNKNOWN |
690 : : RTE_PTYPE_TUNNEL_GRENAT | RTE_PTYPE_INNER_L2_ETHER |
691 : : RTE_PTYPE_INNER_L3_IPV4_EXT_UNKNOWN |
692 : : RTE_PTYPE_INNER_L4_UDP,
693 : : /* [128] reserved */
694 : : [129] = RTE_PTYPE_L2_ETHER | RTE_PTYPE_L3_IPV6_EXT_UNKNOWN |
695 : : RTE_PTYPE_TUNNEL_GRENAT | RTE_PTYPE_INNER_L2_ETHER |
696 : : RTE_PTYPE_INNER_L3_IPV4_EXT_UNKNOWN |
697 : : RTE_PTYPE_INNER_L4_TCP,
698 : : [130] = RTE_PTYPE_L2_ETHER | RTE_PTYPE_L3_IPV6_EXT_UNKNOWN |
699 : : RTE_PTYPE_TUNNEL_GRENAT | RTE_PTYPE_INNER_L2_ETHER |
700 : : RTE_PTYPE_INNER_L3_IPV4_EXT_UNKNOWN |
701 : : RTE_PTYPE_INNER_L4_SCTP,
702 : : [131] = RTE_PTYPE_L2_ETHER | RTE_PTYPE_L3_IPV6_EXT_UNKNOWN |
703 : : RTE_PTYPE_TUNNEL_GRENAT | RTE_PTYPE_INNER_L2_ETHER |
704 : : RTE_PTYPE_INNER_L3_IPV4_EXT_UNKNOWN |
705 : : RTE_PTYPE_INNER_L4_ICMP,
706 : :
707 : : /* IPv6 --> GRE/Teredo/VXLAN --> MAC --> IPv6 */
708 : : [132] = RTE_PTYPE_L2_ETHER | RTE_PTYPE_L3_IPV6_EXT_UNKNOWN |
709 : : RTE_PTYPE_TUNNEL_GRENAT | RTE_PTYPE_INNER_L2_ETHER |
710 : : RTE_PTYPE_INNER_L3_IPV6_EXT_UNKNOWN |
711 : : RTE_PTYPE_INNER_L4_FRAG,
712 : : [133] = RTE_PTYPE_L2_ETHER | RTE_PTYPE_L3_IPV6_EXT_UNKNOWN |
713 : : RTE_PTYPE_TUNNEL_GRENAT | RTE_PTYPE_INNER_L2_ETHER |
714 : : RTE_PTYPE_INNER_L3_IPV6_EXT_UNKNOWN |
715 : : RTE_PTYPE_INNER_L4_NONFRAG,
716 : : [134] = RTE_PTYPE_L2_ETHER | RTE_PTYPE_L3_IPV6_EXT_UNKNOWN |
717 : : RTE_PTYPE_TUNNEL_GRENAT | RTE_PTYPE_INNER_L2_ETHER |
718 : : RTE_PTYPE_INNER_L3_IPV6_EXT_UNKNOWN |
719 : : RTE_PTYPE_INNER_L4_UDP,
720 : : /* [135] reserved */
721 : : [136] = RTE_PTYPE_L2_ETHER | RTE_PTYPE_L3_IPV6_EXT_UNKNOWN |
722 : : RTE_PTYPE_TUNNEL_GRENAT | RTE_PTYPE_INNER_L2_ETHER |
723 : : RTE_PTYPE_INNER_L3_IPV6_EXT_UNKNOWN |
724 : : RTE_PTYPE_INNER_L4_TCP,
725 : : [137] = RTE_PTYPE_L2_ETHER | RTE_PTYPE_L3_IPV6_EXT_UNKNOWN |
726 : : RTE_PTYPE_TUNNEL_GRENAT | RTE_PTYPE_INNER_L2_ETHER |
727 : : RTE_PTYPE_INNER_L3_IPV6_EXT_UNKNOWN |
728 : : RTE_PTYPE_INNER_L4_SCTP,
729 : : [138] = RTE_PTYPE_L2_ETHER | RTE_PTYPE_L3_IPV6_EXT_UNKNOWN |
730 : : RTE_PTYPE_TUNNEL_GRENAT | RTE_PTYPE_INNER_L2_ETHER |
731 : : RTE_PTYPE_INNER_L3_IPV6_EXT_UNKNOWN |
732 : : RTE_PTYPE_INNER_L4_ICMP,
733 : :
734 : : /* IPv6 --> GRE/Teredo/VXLAN --> MAC/VLAN */
735 : : [139] = RTE_PTYPE_L2_ETHER | RTE_PTYPE_L3_IPV6_EXT_UNKNOWN |
736 : : RTE_PTYPE_TUNNEL_GRENAT |
737 : : RTE_PTYPE_INNER_L2_ETHER_VLAN,
738 : :
739 : : /* IPv6 --> GRE/Teredo/VXLAN --> MAC/VLAN --> IPv4 */
740 : : [140] = RTE_PTYPE_L2_ETHER | RTE_PTYPE_L3_IPV6_EXT_UNKNOWN |
741 : : RTE_PTYPE_TUNNEL_GRENAT |
742 : : RTE_PTYPE_INNER_L2_ETHER_VLAN |
743 : : RTE_PTYPE_INNER_L3_IPV4_EXT_UNKNOWN |
744 : : RTE_PTYPE_INNER_L4_FRAG,
745 : : [141] = RTE_PTYPE_L2_ETHER | RTE_PTYPE_L3_IPV6_EXT_UNKNOWN |
746 : : RTE_PTYPE_TUNNEL_GRENAT |
747 : : RTE_PTYPE_INNER_L2_ETHER_VLAN |
748 : : RTE_PTYPE_INNER_L3_IPV4_EXT_UNKNOWN |
749 : : RTE_PTYPE_INNER_L4_NONFRAG,
750 : : [142] = RTE_PTYPE_L2_ETHER | RTE_PTYPE_L3_IPV6_EXT_UNKNOWN |
751 : : RTE_PTYPE_TUNNEL_GRENAT |
752 : : RTE_PTYPE_INNER_L2_ETHER_VLAN |
753 : : RTE_PTYPE_INNER_L3_IPV4_EXT_UNKNOWN |
754 : : RTE_PTYPE_INNER_L4_UDP,
755 : : /* [143] reserved */
756 : : [144] = RTE_PTYPE_L2_ETHER | RTE_PTYPE_L3_IPV6_EXT_UNKNOWN |
757 : : RTE_PTYPE_TUNNEL_GRENAT |
758 : : RTE_PTYPE_INNER_L2_ETHER_VLAN |
759 : : RTE_PTYPE_INNER_L3_IPV4_EXT_UNKNOWN |
760 : : RTE_PTYPE_INNER_L4_TCP,
761 : : [145] = RTE_PTYPE_L2_ETHER | RTE_PTYPE_L3_IPV6_EXT_UNKNOWN |
762 : : RTE_PTYPE_TUNNEL_GRENAT |
763 : : RTE_PTYPE_INNER_L2_ETHER_VLAN |
764 : : RTE_PTYPE_INNER_L3_IPV4_EXT_UNKNOWN |
765 : : RTE_PTYPE_INNER_L4_SCTP,
766 : : [146] = RTE_PTYPE_L2_ETHER | RTE_PTYPE_L3_IPV6_EXT_UNKNOWN |
767 : : RTE_PTYPE_TUNNEL_GRENAT |
768 : : RTE_PTYPE_INNER_L2_ETHER_VLAN |
769 : : RTE_PTYPE_INNER_L3_IPV4_EXT_UNKNOWN |
770 : : RTE_PTYPE_INNER_L4_ICMP,
771 : :
772 : : /* IPv6 --> GRE/Teredo/VXLAN --> MAC/VLAN --> IPv6 */
773 : : [147] = RTE_PTYPE_L2_ETHER | RTE_PTYPE_L3_IPV6_EXT_UNKNOWN |
774 : : RTE_PTYPE_TUNNEL_GRENAT |
775 : : RTE_PTYPE_INNER_L2_ETHER_VLAN |
776 : : RTE_PTYPE_INNER_L3_IPV6_EXT_UNKNOWN |
777 : : RTE_PTYPE_INNER_L4_FRAG,
778 : : [148] = RTE_PTYPE_L2_ETHER | RTE_PTYPE_L3_IPV6_EXT_UNKNOWN |
779 : : RTE_PTYPE_TUNNEL_GRENAT |
780 : : RTE_PTYPE_INNER_L2_ETHER_VLAN |
781 : : RTE_PTYPE_INNER_L3_IPV6_EXT_UNKNOWN |
782 : : RTE_PTYPE_INNER_L4_NONFRAG,
783 : : [149] = RTE_PTYPE_L2_ETHER | RTE_PTYPE_L3_IPV6_EXT_UNKNOWN |
784 : : RTE_PTYPE_TUNNEL_GRENAT |
785 : : RTE_PTYPE_INNER_L2_ETHER_VLAN |
786 : : RTE_PTYPE_INNER_L3_IPV6_EXT_UNKNOWN |
787 : : RTE_PTYPE_INNER_L4_UDP,
788 : : /* [150] reserved */
789 : : [151] = RTE_PTYPE_L2_ETHER | RTE_PTYPE_L3_IPV6_EXT_UNKNOWN |
790 : : RTE_PTYPE_TUNNEL_GRENAT |
791 : : RTE_PTYPE_INNER_L2_ETHER_VLAN |
792 : : RTE_PTYPE_INNER_L3_IPV6_EXT_UNKNOWN |
793 : : RTE_PTYPE_INNER_L4_TCP,
794 : : [152] = RTE_PTYPE_L2_ETHER | RTE_PTYPE_L3_IPV6_EXT_UNKNOWN |
795 : : RTE_PTYPE_TUNNEL_GRENAT |
796 : : RTE_PTYPE_INNER_L2_ETHER_VLAN |
797 : : RTE_PTYPE_INNER_L3_IPV6_EXT_UNKNOWN |
798 : : RTE_PTYPE_INNER_L4_SCTP,
799 : : [153] = RTE_PTYPE_L2_ETHER | RTE_PTYPE_L3_IPV6_EXT_UNKNOWN |
800 : : RTE_PTYPE_TUNNEL_GRENAT |
801 : : RTE_PTYPE_INNER_L2_ETHER_VLAN |
802 : : RTE_PTYPE_INNER_L3_IPV6_EXT_UNKNOWN |
803 : : RTE_PTYPE_INNER_L4_ICMP,
804 : :
805 : : /* L2 NSH packet type */
806 : : [154] = RTE_PTYPE_L2_ETHER_NSH,
807 : : [155] = RTE_PTYPE_L2_ETHER_NSH | RTE_PTYPE_L3_IPV4_EXT_UNKNOWN |
808 : : RTE_PTYPE_L4_FRAG,
809 : : [156] = RTE_PTYPE_L2_ETHER_NSH | RTE_PTYPE_L3_IPV4_EXT_UNKNOWN |
810 : : RTE_PTYPE_L4_NONFRAG,
811 : : [157] = RTE_PTYPE_L2_ETHER_NSH | RTE_PTYPE_L3_IPV4_EXT_UNKNOWN |
812 : : RTE_PTYPE_L4_UDP,
813 : : [158] = RTE_PTYPE_L2_ETHER_NSH | RTE_PTYPE_L3_IPV4_EXT_UNKNOWN |
814 : : RTE_PTYPE_L4_TCP,
815 : : [159] = RTE_PTYPE_L2_ETHER_NSH | RTE_PTYPE_L3_IPV4_EXT_UNKNOWN |
816 : : RTE_PTYPE_L4_SCTP,
817 : : [160] = RTE_PTYPE_L2_ETHER_NSH | RTE_PTYPE_L3_IPV4_EXT_UNKNOWN |
818 : : RTE_PTYPE_L4_ICMP,
819 : : [161] = RTE_PTYPE_L2_ETHER_NSH | RTE_PTYPE_L3_IPV6_EXT_UNKNOWN |
820 : : RTE_PTYPE_L4_FRAG,
821 : : [162] = RTE_PTYPE_L2_ETHER_NSH | RTE_PTYPE_L3_IPV6_EXT_UNKNOWN |
822 : : RTE_PTYPE_L4_NONFRAG,
823 : : [163] = RTE_PTYPE_L2_ETHER_NSH | RTE_PTYPE_L3_IPV6_EXT_UNKNOWN |
824 : : RTE_PTYPE_L4_UDP,
825 : : [164] = RTE_PTYPE_L2_ETHER_NSH | RTE_PTYPE_L3_IPV6_EXT_UNKNOWN |
826 : : RTE_PTYPE_L4_TCP,
827 : : [165] = RTE_PTYPE_L2_ETHER_NSH | RTE_PTYPE_L3_IPV6_EXT_UNKNOWN |
828 : : RTE_PTYPE_L4_SCTP,
829 : : [166] = RTE_PTYPE_L2_ETHER_NSH | RTE_PTYPE_L3_IPV6_EXT_UNKNOWN |
830 : : RTE_PTYPE_L4_ICMP,
831 : :
832 : : /* All others reserved */
833 : : };
834 : :
835 : 0 : return type_table[ptype];
836 : : }
837 : :
838 : : #endif /* _I40E_RXTX_H_ */
|