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 4096
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 : : bool tx_deferred_start; /**< don't start this queue in dev start */
166 : : uint8_t dcb_tc; /**< Traffic class of tx queue */
167 : : uint64_t offloads; /**< Tx offload flags of RTE_ETH_TX_OFFLOAD_* */
168 : : const struct rte_memzone *mz;
169 : : };
170 : :
171 : : /** Offload features */
172 : : union i40e_tx_offload {
173 : : uint64_t data;
174 : : struct {
175 : : uint64_t l2_len:7; /**< L2 (MAC) Header Length. */
176 : : uint64_t l3_len:9; /**< L3 (IP) Header Length. */
177 : : uint64_t l4_len:8; /**< L4 Header Length. */
178 : : uint64_t tso_segsz:16; /**< TCP TSO segment size */
179 : : uint64_t outer_l2_len:8; /**< outer L2 Header Length */
180 : : uint64_t outer_l3_len:16; /**< outer L3 Header Length */
181 : : };
182 : : };
183 : :
184 : : int i40e_dev_rx_queue_start(struct rte_eth_dev *dev, uint16_t rx_queue_id);
185 : : int i40e_dev_rx_queue_stop(struct rte_eth_dev *dev, uint16_t rx_queue_id);
186 : : int i40e_dev_tx_queue_start(struct rte_eth_dev *dev, uint16_t tx_queue_id);
187 : : int i40e_dev_tx_queue_stop(struct rte_eth_dev *dev, uint16_t tx_queue_id);
188 : : const uint32_t *i40e_dev_supported_ptypes_get(struct rte_eth_dev *dev,
189 : : size_t *no_of_elements);
190 : : int i40e_dev_rx_queue_setup(struct rte_eth_dev *dev,
191 : : uint16_t queue_idx,
192 : : uint16_t nb_desc,
193 : : unsigned int socket_id,
194 : : const struct rte_eth_rxconf *rx_conf,
195 : : struct rte_mempool *mp);
196 : : int i40e_dev_tx_queue_setup(struct rte_eth_dev *dev,
197 : : uint16_t queue_idx,
198 : : uint16_t nb_desc,
199 : : unsigned int socket_id,
200 : : const struct rte_eth_txconf *tx_conf);
201 : : void i40e_rx_queue_release(void *rxq);
202 : : void i40e_tx_queue_release(void *txq);
203 : : void i40e_dev_rx_queue_release(struct rte_eth_dev *dev, uint16_t qid);
204 : : void i40e_dev_tx_queue_release(struct rte_eth_dev *dev, uint16_t qid);
205 : : uint16_t i40e_recv_pkts(void *rx_queue,
206 : : struct rte_mbuf **rx_pkts,
207 : : uint16_t nb_pkts);
208 : : uint16_t i40e_recv_scattered_pkts(void *rx_queue,
209 : : struct rte_mbuf **rx_pkts,
210 : : uint16_t nb_pkts);
211 : : uint16_t i40e_xmit_pkts(void *tx_queue,
212 : : struct rte_mbuf **tx_pkts,
213 : : uint16_t nb_pkts);
214 : : uint16_t i40e_simple_prep_pkts(void *tx_queue, struct rte_mbuf **tx_pkts,
215 : : uint16_t nb_pkts);
216 : : uint16_t i40e_prep_pkts(void *tx_queue, struct rte_mbuf **tx_pkts,
217 : : uint16_t nb_pkts);
218 : : int i40e_tx_queue_init(struct i40e_tx_queue *txq);
219 : : int i40e_rx_queue_init(struct i40e_rx_queue *rxq);
220 : : void i40e_free_tx_resources(struct i40e_tx_queue *txq);
221 : : void i40e_free_rx_resources(struct i40e_rx_queue *rxq);
222 : : void i40e_dev_clear_queues(struct rte_eth_dev *dev);
223 : : void i40e_dev_free_queues(struct rte_eth_dev *dev);
224 : : void i40e_reset_rx_queue(struct i40e_rx_queue *rxq);
225 : : void i40e_reset_tx_queue(struct i40e_tx_queue *txq);
226 : : void i40e_tx_queue_release_mbufs(struct i40e_tx_queue *txq);
227 : : int i40e_tx_done_cleanup(void *txq, uint32_t free_cnt);
228 : : int i40e_alloc_rx_queue_mbufs(struct i40e_rx_queue *rxq);
229 : : void i40e_rx_queue_release_mbufs(struct i40e_rx_queue *rxq);
230 : :
231 : : uint32_t i40e_dev_rx_queue_count(void *rx_queue);
232 : : int i40e_dev_rx_descriptor_status(void *rx_queue, uint16_t offset);
233 : : int i40e_dev_tx_descriptor_status(void *tx_queue, uint16_t offset);
234 : :
235 : : uint16_t i40e_recycle_tx_mbufs_reuse_vec(void *tx_queue,
236 : : struct rte_eth_recycle_rxq_info *recycle_rxq_info);
237 : : void i40e_recycle_rx_descriptors_refill_vec(void *rx_queue, uint16_t nb_mbufs);
238 : :
239 : : uint16_t i40e_recv_pkts_vec(void *rx_queue, struct rte_mbuf **rx_pkts,
240 : : uint16_t nb_pkts);
241 : : uint16_t i40e_recv_scattered_pkts_vec(void *rx_queue,
242 : : struct rte_mbuf **rx_pkts,
243 : : uint16_t nb_pkts);
244 : : int i40e_rx_vec_dev_conf_condition_check(struct rte_eth_dev *dev);
245 : : int i40e_rxq_vec_setup(struct i40e_rx_queue *rxq);
246 : : int i40e_txq_vec_setup(struct i40e_tx_queue *txq);
247 : : void i40e_rx_queue_release_mbufs_vec(struct i40e_rx_queue *rxq);
248 : : uint16_t i40e_xmit_fixed_burst_vec(void *tx_queue, struct rte_mbuf **tx_pkts,
249 : : uint16_t nb_pkts);
250 : : void i40e_set_rx_function(struct rte_eth_dev *dev);
251 : : void i40e_set_tx_function_flag(struct rte_eth_dev *dev,
252 : : struct i40e_tx_queue *txq);
253 : : void i40e_set_tx_function(struct rte_eth_dev *dev);
254 : : void i40e_set_default_ptype_table(struct rte_eth_dev *dev);
255 : : void i40e_set_default_pctype_table(struct rte_eth_dev *dev);
256 : : uint16_t i40e_recv_pkts_vec_avx2(void *rx_queue, struct rte_mbuf **rx_pkts,
257 : : uint16_t nb_pkts);
258 : : uint16_t i40e_recv_scattered_pkts_vec_avx2(void *rx_queue,
259 : : struct rte_mbuf **rx_pkts, uint16_t nb_pkts);
260 : : uint16_t i40e_xmit_pkts_vec_avx2(void *tx_queue, struct rte_mbuf **tx_pkts,
261 : : uint16_t nb_pkts);
262 : : int i40e_get_monitor_addr(void *rx_queue, struct rte_power_monitor_cond *pmc);
263 : : uint16_t i40e_recv_pkts_vec_avx512(void *rx_queue,
264 : : struct rte_mbuf **rx_pkts,
265 : : uint16_t nb_pkts);
266 : : uint16_t i40e_recv_scattered_pkts_vec_avx512(void *rx_queue,
267 : : struct rte_mbuf **rx_pkts,
268 : : uint16_t nb_pkts);
269 : : uint16_t i40e_xmit_pkts_vec_avx512(void *tx_queue,
270 : : struct rte_mbuf **tx_pkts,
271 : : uint16_t nb_pkts);
272 : :
273 : : /* For each value it means, datasheet of hardware can tell more details
274 : : *
275 : : * @note: fix i40e_dev_supported_ptypes_get() if any change here.
276 : : */
277 : : static inline uint32_t
278 : : i40e_get_default_pkt_type(uint8_t ptype)
279 : : {
280 : : static const uint32_t type_table[UINT8_MAX + 1] __rte_cache_aligned = {
281 : : /* L2 types */
282 : : /* [0] reserved */
283 : : [1] = RTE_PTYPE_L2_ETHER,
284 : : [2] = RTE_PTYPE_L2_ETHER_TIMESYNC,
285 : : /* [3] - [5] reserved */
286 : : [6] = RTE_PTYPE_L2_ETHER_LLDP,
287 : : /* [7] - [10] reserved */
288 : : [11] = RTE_PTYPE_L2_ETHER_ARP,
289 : : /* [12] - [21] reserved */
290 : :
291 : : /* Non tunneled IPv4 */
292 : : [22] = RTE_PTYPE_L2_ETHER | RTE_PTYPE_L3_IPV4_EXT_UNKNOWN |
293 : : RTE_PTYPE_L4_FRAG,
294 : : [23] = RTE_PTYPE_L2_ETHER | RTE_PTYPE_L3_IPV4_EXT_UNKNOWN |
295 : : RTE_PTYPE_L4_NONFRAG,
296 : : [24] = RTE_PTYPE_L2_ETHER | RTE_PTYPE_L3_IPV4_EXT_UNKNOWN |
297 : : RTE_PTYPE_L4_UDP,
298 : : /* [25] reserved */
299 : : [26] = RTE_PTYPE_L2_ETHER | RTE_PTYPE_L3_IPV4_EXT_UNKNOWN |
300 : : RTE_PTYPE_L4_TCP,
301 : : [27] = RTE_PTYPE_L2_ETHER | RTE_PTYPE_L3_IPV4_EXT_UNKNOWN |
302 : : RTE_PTYPE_L4_SCTP,
303 : : [28] = RTE_PTYPE_L2_ETHER | RTE_PTYPE_L3_IPV4_EXT_UNKNOWN |
304 : : RTE_PTYPE_L4_ICMP,
305 : :
306 : : /* IPv4 --> IPv4 */
307 : : [29] = RTE_PTYPE_L2_ETHER | RTE_PTYPE_L3_IPV4_EXT_UNKNOWN |
308 : : RTE_PTYPE_TUNNEL_IP |
309 : : RTE_PTYPE_INNER_L3_IPV4_EXT_UNKNOWN |
310 : : RTE_PTYPE_INNER_L4_FRAG,
311 : : [30] = RTE_PTYPE_L2_ETHER | RTE_PTYPE_L3_IPV4_EXT_UNKNOWN |
312 : : RTE_PTYPE_TUNNEL_IP |
313 : : RTE_PTYPE_INNER_L3_IPV4_EXT_UNKNOWN |
314 : : RTE_PTYPE_INNER_L4_NONFRAG,
315 : : [31] = RTE_PTYPE_L2_ETHER | RTE_PTYPE_L3_IPV4_EXT_UNKNOWN |
316 : : RTE_PTYPE_TUNNEL_IP |
317 : : RTE_PTYPE_INNER_L3_IPV4_EXT_UNKNOWN |
318 : : RTE_PTYPE_INNER_L4_UDP,
319 : : /* [32] reserved */
320 : : [33] = RTE_PTYPE_L2_ETHER | RTE_PTYPE_L3_IPV4_EXT_UNKNOWN |
321 : : RTE_PTYPE_TUNNEL_IP |
322 : : RTE_PTYPE_INNER_L3_IPV4_EXT_UNKNOWN |
323 : : RTE_PTYPE_INNER_L4_TCP,
324 : : [34] = RTE_PTYPE_L2_ETHER | RTE_PTYPE_L3_IPV4_EXT_UNKNOWN |
325 : : RTE_PTYPE_TUNNEL_IP |
326 : : RTE_PTYPE_INNER_L3_IPV4_EXT_UNKNOWN |
327 : : RTE_PTYPE_INNER_L4_SCTP,
328 : : [35] = RTE_PTYPE_L2_ETHER | RTE_PTYPE_L3_IPV4_EXT_UNKNOWN |
329 : : RTE_PTYPE_TUNNEL_IP |
330 : : RTE_PTYPE_INNER_L3_IPV4_EXT_UNKNOWN |
331 : : RTE_PTYPE_INNER_L4_ICMP,
332 : :
333 : : /* IPv4 --> IPv6 */
334 : : [36] = RTE_PTYPE_L2_ETHER | RTE_PTYPE_L3_IPV4_EXT_UNKNOWN |
335 : : RTE_PTYPE_TUNNEL_IP |
336 : : RTE_PTYPE_INNER_L3_IPV6_EXT_UNKNOWN |
337 : : RTE_PTYPE_INNER_L4_FRAG,
338 : : [37] = RTE_PTYPE_L2_ETHER | RTE_PTYPE_L3_IPV4_EXT_UNKNOWN |
339 : : RTE_PTYPE_TUNNEL_IP |
340 : : RTE_PTYPE_INNER_L3_IPV6_EXT_UNKNOWN |
341 : : RTE_PTYPE_INNER_L4_NONFRAG,
342 : : [38] = RTE_PTYPE_L2_ETHER | RTE_PTYPE_L3_IPV4_EXT_UNKNOWN |
343 : : RTE_PTYPE_TUNNEL_IP |
344 : : RTE_PTYPE_INNER_L3_IPV6_EXT_UNKNOWN |
345 : : RTE_PTYPE_INNER_L4_UDP,
346 : : /* [39] reserved */
347 : : [40] = RTE_PTYPE_L2_ETHER | RTE_PTYPE_L3_IPV4_EXT_UNKNOWN |
348 : : RTE_PTYPE_TUNNEL_IP |
349 : : RTE_PTYPE_INNER_L3_IPV6_EXT_UNKNOWN |
350 : : RTE_PTYPE_INNER_L4_TCP,
351 : : [41] = RTE_PTYPE_L2_ETHER | RTE_PTYPE_L3_IPV4_EXT_UNKNOWN |
352 : : RTE_PTYPE_TUNNEL_IP |
353 : : RTE_PTYPE_INNER_L3_IPV6_EXT_UNKNOWN |
354 : : RTE_PTYPE_INNER_L4_SCTP,
355 : : [42] = RTE_PTYPE_L2_ETHER | RTE_PTYPE_L3_IPV4_EXT_UNKNOWN |
356 : : RTE_PTYPE_TUNNEL_IP |
357 : : RTE_PTYPE_INNER_L3_IPV6_EXT_UNKNOWN |
358 : : RTE_PTYPE_INNER_L4_ICMP,
359 : :
360 : : /* IPv4 --> GRE/Teredo/VXLAN */
361 : : [43] = RTE_PTYPE_L2_ETHER | RTE_PTYPE_L3_IPV4_EXT_UNKNOWN |
362 : : RTE_PTYPE_TUNNEL_GRENAT,
363 : :
364 : : /* IPv4 --> GRE/Teredo/VXLAN --> IPv4 */
365 : : [44] = RTE_PTYPE_L2_ETHER | RTE_PTYPE_L3_IPV4_EXT_UNKNOWN |
366 : : RTE_PTYPE_TUNNEL_GRENAT |
367 : : RTE_PTYPE_INNER_L3_IPV4_EXT_UNKNOWN |
368 : : RTE_PTYPE_INNER_L4_FRAG,
369 : : [45] = RTE_PTYPE_L2_ETHER | RTE_PTYPE_L3_IPV4_EXT_UNKNOWN |
370 : : RTE_PTYPE_TUNNEL_GRENAT |
371 : : RTE_PTYPE_INNER_L3_IPV4_EXT_UNKNOWN |
372 : : RTE_PTYPE_INNER_L4_NONFRAG,
373 : : [46] = RTE_PTYPE_L2_ETHER | RTE_PTYPE_L3_IPV4_EXT_UNKNOWN |
374 : : RTE_PTYPE_TUNNEL_GRENAT |
375 : : RTE_PTYPE_INNER_L3_IPV4_EXT_UNKNOWN |
376 : : RTE_PTYPE_INNER_L4_UDP,
377 : : /* [47] reserved */
378 : : [48] = RTE_PTYPE_L2_ETHER | RTE_PTYPE_L3_IPV4_EXT_UNKNOWN |
379 : : RTE_PTYPE_TUNNEL_GRENAT |
380 : : RTE_PTYPE_INNER_L3_IPV4_EXT_UNKNOWN |
381 : : RTE_PTYPE_INNER_L4_TCP,
382 : : [49] = RTE_PTYPE_L2_ETHER | RTE_PTYPE_L3_IPV4_EXT_UNKNOWN |
383 : : RTE_PTYPE_TUNNEL_GRENAT |
384 : : RTE_PTYPE_INNER_L3_IPV4_EXT_UNKNOWN |
385 : : RTE_PTYPE_INNER_L4_SCTP,
386 : : [50] = RTE_PTYPE_L2_ETHER | RTE_PTYPE_L3_IPV4_EXT_UNKNOWN |
387 : : RTE_PTYPE_TUNNEL_GRENAT |
388 : : RTE_PTYPE_INNER_L3_IPV4_EXT_UNKNOWN |
389 : : RTE_PTYPE_INNER_L4_ICMP,
390 : :
391 : : /* IPv4 --> GRE/Teredo/VXLAN --> IPv6 */
392 : : [51] = RTE_PTYPE_L2_ETHER | RTE_PTYPE_L3_IPV4_EXT_UNKNOWN |
393 : : RTE_PTYPE_TUNNEL_GRENAT |
394 : : RTE_PTYPE_INNER_L3_IPV6_EXT_UNKNOWN |
395 : : RTE_PTYPE_INNER_L4_FRAG,
396 : : [52] = RTE_PTYPE_L2_ETHER | RTE_PTYPE_L3_IPV4_EXT_UNKNOWN |
397 : : RTE_PTYPE_TUNNEL_GRENAT |
398 : : RTE_PTYPE_INNER_L3_IPV6_EXT_UNKNOWN |
399 : : RTE_PTYPE_INNER_L4_NONFRAG,
400 : : [53] = RTE_PTYPE_L2_ETHER | RTE_PTYPE_L3_IPV4_EXT_UNKNOWN |
401 : : RTE_PTYPE_TUNNEL_GRENAT |
402 : : RTE_PTYPE_INNER_L3_IPV6_EXT_UNKNOWN |
403 : : RTE_PTYPE_INNER_L4_UDP,
404 : : /* [54] reserved */
405 : : [55] = RTE_PTYPE_L2_ETHER | RTE_PTYPE_L3_IPV4_EXT_UNKNOWN |
406 : : RTE_PTYPE_TUNNEL_GRENAT |
407 : : RTE_PTYPE_INNER_L3_IPV6_EXT_UNKNOWN |
408 : : RTE_PTYPE_INNER_L4_TCP,
409 : : [56] = RTE_PTYPE_L2_ETHER | RTE_PTYPE_L3_IPV4_EXT_UNKNOWN |
410 : : RTE_PTYPE_TUNNEL_GRENAT |
411 : : RTE_PTYPE_INNER_L3_IPV6_EXT_UNKNOWN |
412 : : RTE_PTYPE_INNER_L4_SCTP,
413 : : [57] = RTE_PTYPE_L2_ETHER | RTE_PTYPE_L3_IPV4_EXT_UNKNOWN |
414 : : RTE_PTYPE_TUNNEL_GRENAT |
415 : : RTE_PTYPE_INNER_L3_IPV6_EXT_UNKNOWN |
416 : : RTE_PTYPE_INNER_L4_ICMP,
417 : :
418 : : /* IPv4 --> GRE/Teredo/VXLAN --> MAC */
419 : : [58] = RTE_PTYPE_L2_ETHER | RTE_PTYPE_L3_IPV4_EXT_UNKNOWN |
420 : : RTE_PTYPE_TUNNEL_GRENAT | RTE_PTYPE_INNER_L2_ETHER,
421 : :
422 : : /* IPv4 --> GRE/Teredo/VXLAN --> MAC --> IPv4 */
423 : : [59] = RTE_PTYPE_L2_ETHER | RTE_PTYPE_L3_IPV4_EXT_UNKNOWN |
424 : : RTE_PTYPE_TUNNEL_GRENAT | RTE_PTYPE_INNER_L2_ETHER |
425 : : RTE_PTYPE_INNER_L3_IPV4_EXT_UNKNOWN |
426 : : RTE_PTYPE_INNER_L4_FRAG,
427 : : [60] = RTE_PTYPE_L2_ETHER | RTE_PTYPE_L3_IPV4_EXT_UNKNOWN |
428 : : RTE_PTYPE_TUNNEL_GRENAT | RTE_PTYPE_INNER_L2_ETHER |
429 : : RTE_PTYPE_INNER_L3_IPV4_EXT_UNKNOWN |
430 : : RTE_PTYPE_INNER_L4_NONFRAG,
431 : : [61] = RTE_PTYPE_L2_ETHER | RTE_PTYPE_L3_IPV4_EXT_UNKNOWN |
432 : : RTE_PTYPE_TUNNEL_GRENAT | RTE_PTYPE_INNER_L2_ETHER |
433 : : RTE_PTYPE_INNER_L3_IPV4_EXT_UNKNOWN |
434 : : RTE_PTYPE_INNER_L4_UDP,
435 : : /* [62] reserved */
436 : : [63] = RTE_PTYPE_L2_ETHER | RTE_PTYPE_L3_IPV4_EXT_UNKNOWN |
437 : : RTE_PTYPE_TUNNEL_GRENAT | RTE_PTYPE_INNER_L2_ETHER |
438 : : RTE_PTYPE_INNER_L3_IPV4_EXT_UNKNOWN |
439 : : RTE_PTYPE_INNER_L4_TCP,
440 : : [64] = RTE_PTYPE_L2_ETHER | RTE_PTYPE_L3_IPV4_EXT_UNKNOWN |
441 : : RTE_PTYPE_TUNNEL_GRENAT | RTE_PTYPE_INNER_L2_ETHER |
442 : : RTE_PTYPE_INNER_L3_IPV4_EXT_UNKNOWN |
443 : : RTE_PTYPE_INNER_L4_SCTP,
444 : : [65] = RTE_PTYPE_L2_ETHER | RTE_PTYPE_L3_IPV4_EXT_UNKNOWN |
445 : : RTE_PTYPE_TUNNEL_GRENAT | RTE_PTYPE_INNER_L2_ETHER |
446 : : RTE_PTYPE_INNER_L3_IPV4_EXT_UNKNOWN |
447 : : RTE_PTYPE_INNER_L4_ICMP,
448 : :
449 : : /* IPv4 --> GRE/Teredo/VXLAN --> MAC --> IPv6 */
450 : : [66] = RTE_PTYPE_L2_ETHER | RTE_PTYPE_L3_IPV4_EXT_UNKNOWN |
451 : : RTE_PTYPE_TUNNEL_GRENAT | RTE_PTYPE_INNER_L2_ETHER |
452 : : RTE_PTYPE_INNER_L3_IPV6_EXT_UNKNOWN |
453 : : RTE_PTYPE_INNER_L4_FRAG,
454 : : [67] = RTE_PTYPE_L2_ETHER | RTE_PTYPE_L3_IPV4_EXT_UNKNOWN |
455 : : RTE_PTYPE_TUNNEL_GRENAT | RTE_PTYPE_INNER_L2_ETHER |
456 : : RTE_PTYPE_INNER_L3_IPV6_EXT_UNKNOWN |
457 : : RTE_PTYPE_INNER_L4_NONFRAG,
458 : : [68] = RTE_PTYPE_L2_ETHER | RTE_PTYPE_L3_IPV4_EXT_UNKNOWN |
459 : : RTE_PTYPE_TUNNEL_GRENAT | RTE_PTYPE_INNER_L2_ETHER |
460 : : RTE_PTYPE_INNER_L3_IPV6_EXT_UNKNOWN |
461 : : RTE_PTYPE_INNER_L4_UDP,
462 : : /* [69] reserved */
463 : : [70] = RTE_PTYPE_L2_ETHER | RTE_PTYPE_L3_IPV4_EXT_UNKNOWN |
464 : : RTE_PTYPE_TUNNEL_GRENAT | RTE_PTYPE_INNER_L2_ETHER |
465 : : RTE_PTYPE_INNER_L3_IPV6_EXT_UNKNOWN |
466 : : RTE_PTYPE_INNER_L4_TCP,
467 : : [71] = RTE_PTYPE_L2_ETHER | RTE_PTYPE_L3_IPV4_EXT_UNKNOWN |
468 : : RTE_PTYPE_TUNNEL_GRENAT | RTE_PTYPE_INNER_L2_ETHER |
469 : : RTE_PTYPE_INNER_L3_IPV6_EXT_UNKNOWN |
470 : : RTE_PTYPE_INNER_L4_SCTP,
471 : : [72] = RTE_PTYPE_L2_ETHER | RTE_PTYPE_L3_IPV4_EXT_UNKNOWN |
472 : : RTE_PTYPE_TUNNEL_GRENAT | RTE_PTYPE_INNER_L2_ETHER |
473 : : RTE_PTYPE_INNER_L3_IPV6_EXT_UNKNOWN |
474 : : RTE_PTYPE_INNER_L4_ICMP,
475 : :
476 : : /* IPv4 --> GRE/Teredo/VXLAN --> MAC/VLAN */
477 : : [73] = RTE_PTYPE_L2_ETHER | RTE_PTYPE_L3_IPV4_EXT_UNKNOWN |
478 : : RTE_PTYPE_TUNNEL_GRENAT |
479 : : RTE_PTYPE_INNER_L2_ETHER_VLAN,
480 : :
481 : : /* IPv4 --> GRE/Teredo/VXLAN --> MAC/VLAN --> IPv4 */
482 : : [74] = RTE_PTYPE_L2_ETHER | RTE_PTYPE_L3_IPV4_EXT_UNKNOWN |
483 : : RTE_PTYPE_TUNNEL_GRENAT |
484 : : RTE_PTYPE_INNER_L2_ETHER_VLAN |
485 : : RTE_PTYPE_INNER_L3_IPV4_EXT_UNKNOWN |
486 : : RTE_PTYPE_INNER_L4_FRAG,
487 : : [75] = RTE_PTYPE_L2_ETHER | RTE_PTYPE_L3_IPV4_EXT_UNKNOWN |
488 : : RTE_PTYPE_TUNNEL_GRENAT |
489 : : RTE_PTYPE_INNER_L2_ETHER_VLAN |
490 : : RTE_PTYPE_INNER_L3_IPV4_EXT_UNKNOWN |
491 : : RTE_PTYPE_INNER_L4_NONFRAG,
492 : : [76] = RTE_PTYPE_L2_ETHER | RTE_PTYPE_L3_IPV4_EXT_UNKNOWN |
493 : : RTE_PTYPE_TUNNEL_GRENAT |
494 : : RTE_PTYPE_INNER_L2_ETHER_VLAN |
495 : : RTE_PTYPE_INNER_L3_IPV4_EXT_UNKNOWN |
496 : : RTE_PTYPE_INNER_L4_UDP,
497 : : /* [77] reserved */
498 : : [78] = RTE_PTYPE_L2_ETHER | RTE_PTYPE_L3_IPV4_EXT_UNKNOWN |
499 : : RTE_PTYPE_TUNNEL_GRENAT |
500 : : RTE_PTYPE_INNER_L2_ETHER_VLAN |
501 : : RTE_PTYPE_INNER_L3_IPV4_EXT_UNKNOWN |
502 : : RTE_PTYPE_INNER_L4_TCP,
503 : : [79] = RTE_PTYPE_L2_ETHER | RTE_PTYPE_L3_IPV4_EXT_UNKNOWN |
504 : : RTE_PTYPE_TUNNEL_GRENAT |
505 : : RTE_PTYPE_INNER_L2_ETHER_VLAN |
506 : : RTE_PTYPE_INNER_L3_IPV4_EXT_UNKNOWN |
507 : : RTE_PTYPE_INNER_L4_SCTP,
508 : : [80] = RTE_PTYPE_L2_ETHER | RTE_PTYPE_L3_IPV4_EXT_UNKNOWN |
509 : : RTE_PTYPE_TUNNEL_GRENAT |
510 : : RTE_PTYPE_INNER_L2_ETHER_VLAN |
511 : : RTE_PTYPE_INNER_L3_IPV4_EXT_UNKNOWN |
512 : : RTE_PTYPE_INNER_L4_ICMP,
513 : :
514 : : /* IPv4 --> GRE/Teredo/VXLAN --> MAC/VLAN --> IPv6 */
515 : : [81] = RTE_PTYPE_L2_ETHER | RTE_PTYPE_L3_IPV4_EXT_UNKNOWN |
516 : : RTE_PTYPE_TUNNEL_GRENAT |
517 : : RTE_PTYPE_INNER_L2_ETHER_VLAN |
518 : : RTE_PTYPE_INNER_L3_IPV6_EXT_UNKNOWN |
519 : : RTE_PTYPE_INNER_L4_FRAG,
520 : : [82] = RTE_PTYPE_L2_ETHER | RTE_PTYPE_L3_IPV4_EXT_UNKNOWN |
521 : : RTE_PTYPE_TUNNEL_GRENAT |
522 : : RTE_PTYPE_INNER_L2_ETHER_VLAN |
523 : : RTE_PTYPE_INNER_L3_IPV6_EXT_UNKNOWN |
524 : : RTE_PTYPE_INNER_L4_NONFRAG,
525 : : [83] = RTE_PTYPE_L2_ETHER | RTE_PTYPE_L3_IPV4_EXT_UNKNOWN |
526 : : RTE_PTYPE_TUNNEL_GRENAT |
527 : : RTE_PTYPE_INNER_L2_ETHER_VLAN |
528 : : RTE_PTYPE_INNER_L3_IPV6_EXT_UNKNOWN |
529 : : RTE_PTYPE_INNER_L4_UDP,
530 : : /* [84] reserved */
531 : : [85] = RTE_PTYPE_L2_ETHER | RTE_PTYPE_L3_IPV4_EXT_UNKNOWN |
532 : : RTE_PTYPE_TUNNEL_GRENAT |
533 : : RTE_PTYPE_INNER_L2_ETHER_VLAN |
534 : : RTE_PTYPE_INNER_L3_IPV6_EXT_UNKNOWN |
535 : : RTE_PTYPE_INNER_L4_TCP,
536 : : [86] = RTE_PTYPE_L2_ETHER | RTE_PTYPE_L3_IPV4_EXT_UNKNOWN |
537 : : RTE_PTYPE_TUNNEL_GRENAT |
538 : : RTE_PTYPE_INNER_L2_ETHER_VLAN |
539 : : RTE_PTYPE_INNER_L3_IPV6_EXT_UNKNOWN |
540 : : RTE_PTYPE_INNER_L4_SCTP,
541 : : [87] = RTE_PTYPE_L2_ETHER | RTE_PTYPE_L3_IPV4_EXT_UNKNOWN |
542 : : RTE_PTYPE_TUNNEL_GRENAT |
543 : : RTE_PTYPE_INNER_L2_ETHER_VLAN |
544 : : RTE_PTYPE_INNER_L3_IPV6_EXT_UNKNOWN |
545 : : RTE_PTYPE_INNER_L4_ICMP,
546 : :
547 : : /* Non tunneled IPv6 */
548 : : [88] = RTE_PTYPE_L2_ETHER | RTE_PTYPE_L3_IPV6_EXT_UNKNOWN |
549 : : RTE_PTYPE_L4_FRAG,
550 : : [89] = RTE_PTYPE_L2_ETHER | RTE_PTYPE_L3_IPV6_EXT_UNKNOWN |
551 : : RTE_PTYPE_L4_NONFRAG,
552 : : [90] = RTE_PTYPE_L2_ETHER | RTE_PTYPE_L3_IPV6_EXT_UNKNOWN |
553 : : RTE_PTYPE_L4_UDP,
554 : : /* [91] reserved */
555 : : [92] = RTE_PTYPE_L2_ETHER | RTE_PTYPE_L3_IPV6_EXT_UNKNOWN |
556 : : RTE_PTYPE_L4_TCP,
557 : : [93] = RTE_PTYPE_L2_ETHER | RTE_PTYPE_L3_IPV6_EXT_UNKNOWN |
558 : : RTE_PTYPE_L4_SCTP,
559 : : [94] = RTE_PTYPE_L2_ETHER | RTE_PTYPE_L3_IPV6_EXT_UNKNOWN |
560 : : RTE_PTYPE_L4_ICMP,
561 : :
562 : : /* IPv6 --> IPv4 */
563 : : [95] = RTE_PTYPE_L2_ETHER | RTE_PTYPE_L3_IPV6_EXT_UNKNOWN |
564 : : RTE_PTYPE_TUNNEL_IP |
565 : : RTE_PTYPE_INNER_L3_IPV4_EXT_UNKNOWN |
566 : : RTE_PTYPE_INNER_L4_FRAG,
567 : : [96] = RTE_PTYPE_L2_ETHER | RTE_PTYPE_L3_IPV6_EXT_UNKNOWN |
568 : : RTE_PTYPE_TUNNEL_IP |
569 : : RTE_PTYPE_INNER_L3_IPV4_EXT_UNKNOWN |
570 : : RTE_PTYPE_INNER_L4_NONFRAG,
571 : : [97] = RTE_PTYPE_L2_ETHER | RTE_PTYPE_L3_IPV6_EXT_UNKNOWN |
572 : : RTE_PTYPE_TUNNEL_IP |
573 : : RTE_PTYPE_INNER_L3_IPV4_EXT_UNKNOWN |
574 : : RTE_PTYPE_INNER_L4_UDP,
575 : : /* [98] reserved */
576 : : [99] = RTE_PTYPE_L2_ETHER | RTE_PTYPE_L3_IPV6_EXT_UNKNOWN |
577 : : RTE_PTYPE_TUNNEL_IP |
578 : : RTE_PTYPE_INNER_L3_IPV4_EXT_UNKNOWN |
579 : : RTE_PTYPE_INNER_L4_TCP,
580 : : [100] = RTE_PTYPE_L2_ETHER | RTE_PTYPE_L3_IPV6_EXT_UNKNOWN |
581 : : RTE_PTYPE_TUNNEL_IP |
582 : : RTE_PTYPE_INNER_L3_IPV4_EXT_UNKNOWN |
583 : : RTE_PTYPE_INNER_L4_SCTP,
584 : : [101] = RTE_PTYPE_L2_ETHER | RTE_PTYPE_L3_IPV6_EXT_UNKNOWN |
585 : : RTE_PTYPE_TUNNEL_IP |
586 : : RTE_PTYPE_INNER_L3_IPV4_EXT_UNKNOWN |
587 : : RTE_PTYPE_INNER_L4_ICMP,
588 : :
589 : : /* IPv6 --> IPv6 */
590 : : [102] = RTE_PTYPE_L2_ETHER | RTE_PTYPE_L3_IPV6_EXT_UNKNOWN |
591 : : RTE_PTYPE_TUNNEL_IP |
592 : : RTE_PTYPE_INNER_L3_IPV6_EXT_UNKNOWN |
593 : : RTE_PTYPE_INNER_L4_FRAG,
594 : : [103] = RTE_PTYPE_L2_ETHER | RTE_PTYPE_L3_IPV6_EXT_UNKNOWN |
595 : : RTE_PTYPE_TUNNEL_IP |
596 : : RTE_PTYPE_INNER_L3_IPV6_EXT_UNKNOWN |
597 : : RTE_PTYPE_INNER_L4_NONFRAG,
598 : : [104] = RTE_PTYPE_L2_ETHER | RTE_PTYPE_L3_IPV6_EXT_UNKNOWN |
599 : : RTE_PTYPE_TUNNEL_IP |
600 : : RTE_PTYPE_INNER_L3_IPV6_EXT_UNKNOWN |
601 : : RTE_PTYPE_INNER_L4_UDP,
602 : : /* [105] reserved */
603 : : [106] = RTE_PTYPE_L2_ETHER | RTE_PTYPE_L3_IPV6_EXT_UNKNOWN |
604 : : RTE_PTYPE_TUNNEL_IP |
605 : : RTE_PTYPE_INNER_L3_IPV6_EXT_UNKNOWN |
606 : : RTE_PTYPE_INNER_L4_TCP,
607 : : [107] = RTE_PTYPE_L2_ETHER | RTE_PTYPE_L3_IPV6_EXT_UNKNOWN |
608 : : RTE_PTYPE_TUNNEL_IP |
609 : : RTE_PTYPE_INNER_L3_IPV6_EXT_UNKNOWN |
610 : : RTE_PTYPE_INNER_L4_SCTP,
611 : : [108] = RTE_PTYPE_L2_ETHER | RTE_PTYPE_L3_IPV6_EXT_UNKNOWN |
612 : : RTE_PTYPE_TUNNEL_IP |
613 : : RTE_PTYPE_INNER_L3_IPV6_EXT_UNKNOWN |
614 : : RTE_PTYPE_INNER_L4_ICMP,
615 : :
616 : : /* IPv6 --> GRE/Teredo/VXLAN */
617 : : [109] = RTE_PTYPE_L2_ETHER | RTE_PTYPE_L3_IPV6_EXT_UNKNOWN |
618 : : RTE_PTYPE_TUNNEL_GRENAT,
619 : :
620 : : /* IPv6 --> GRE/Teredo/VXLAN --> IPv4 */
621 : : [110] = RTE_PTYPE_L2_ETHER | RTE_PTYPE_L3_IPV6_EXT_UNKNOWN |
622 : : RTE_PTYPE_TUNNEL_GRENAT |
623 : : RTE_PTYPE_INNER_L3_IPV4_EXT_UNKNOWN |
624 : : RTE_PTYPE_INNER_L4_FRAG,
625 : : [111] = RTE_PTYPE_L2_ETHER | RTE_PTYPE_L3_IPV6_EXT_UNKNOWN |
626 : : RTE_PTYPE_TUNNEL_GRENAT |
627 : : RTE_PTYPE_INNER_L3_IPV4_EXT_UNKNOWN |
628 : : RTE_PTYPE_INNER_L4_NONFRAG,
629 : : [112] = RTE_PTYPE_L2_ETHER | RTE_PTYPE_L3_IPV6_EXT_UNKNOWN |
630 : : RTE_PTYPE_TUNNEL_GRENAT |
631 : : RTE_PTYPE_INNER_L3_IPV4_EXT_UNKNOWN |
632 : : RTE_PTYPE_INNER_L4_UDP,
633 : : /* [113] reserved */
634 : : [114] = RTE_PTYPE_L2_ETHER | RTE_PTYPE_L3_IPV6_EXT_UNKNOWN |
635 : : RTE_PTYPE_TUNNEL_GRENAT |
636 : : RTE_PTYPE_INNER_L3_IPV4_EXT_UNKNOWN |
637 : : RTE_PTYPE_INNER_L4_TCP,
638 : : [115] = RTE_PTYPE_L2_ETHER | RTE_PTYPE_L3_IPV6_EXT_UNKNOWN |
639 : : RTE_PTYPE_TUNNEL_GRENAT |
640 : : RTE_PTYPE_INNER_L3_IPV4_EXT_UNKNOWN |
641 : : RTE_PTYPE_INNER_L4_SCTP,
642 : : [116] = RTE_PTYPE_L2_ETHER | RTE_PTYPE_L3_IPV6_EXT_UNKNOWN |
643 : : RTE_PTYPE_TUNNEL_GRENAT |
644 : : RTE_PTYPE_INNER_L3_IPV4_EXT_UNKNOWN |
645 : : RTE_PTYPE_INNER_L4_ICMP,
646 : :
647 : : /* IPv6 --> GRE/Teredo/VXLAN --> IPv6 */
648 : : [117] = RTE_PTYPE_L2_ETHER | RTE_PTYPE_L3_IPV6_EXT_UNKNOWN |
649 : : RTE_PTYPE_TUNNEL_GRENAT |
650 : : RTE_PTYPE_INNER_L3_IPV6_EXT_UNKNOWN |
651 : : RTE_PTYPE_INNER_L4_FRAG,
652 : : [118] = RTE_PTYPE_L2_ETHER | RTE_PTYPE_L3_IPV6_EXT_UNKNOWN |
653 : : RTE_PTYPE_TUNNEL_GRENAT |
654 : : RTE_PTYPE_INNER_L3_IPV6_EXT_UNKNOWN |
655 : : RTE_PTYPE_INNER_L4_NONFRAG,
656 : : [119] = RTE_PTYPE_L2_ETHER | RTE_PTYPE_L3_IPV6_EXT_UNKNOWN |
657 : : RTE_PTYPE_TUNNEL_GRENAT |
658 : : RTE_PTYPE_INNER_L3_IPV6_EXT_UNKNOWN |
659 : : RTE_PTYPE_INNER_L4_UDP,
660 : : /* [120] reserved */
661 : : [121] = RTE_PTYPE_L2_ETHER | RTE_PTYPE_L3_IPV6_EXT_UNKNOWN |
662 : : RTE_PTYPE_TUNNEL_GRENAT |
663 : : RTE_PTYPE_INNER_L3_IPV6_EXT_UNKNOWN |
664 : : RTE_PTYPE_INNER_L4_TCP,
665 : : [122] = RTE_PTYPE_L2_ETHER | RTE_PTYPE_L3_IPV6_EXT_UNKNOWN |
666 : : RTE_PTYPE_TUNNEL_GRENAT |
667 : : RTE_PTYPE_INNER_L3_IPV6_EXT_UNKNOWN |
668 : : RTE_PTYPE_INNER_L4_SCTP,
669 : : [123] = RTE_PTYPE_L2_ETHER | RTE_PTYPE_L3_IPV6_EXT_UNKNOWN |
670 : : RTE_PTYPE_TUNNEL_GRENAT |
671 : : RTE_PTYPE_INNER_L3_IPV6_EXT_UNKNOWN |
672 : : RTE_PTYPE_INNER_L4_ICMP,
673 : :
674 : : /* IPv6 --> GRE/Teredo/VXLAN --> MAC */
675 : : [124] = RTE_PTYPE_L2_ETHER | RTE_PTYPE_L3_IPV6_EXT_UNKNOWN |
676 : : RTE_PTYPE_TUNNEL_GRENAT | RTE_PTYPE_INNER_L2_ETHER,
677 : :
678 : : /* IPv6 --> GRE/Teredo/VXLAN --> MAC --> IPv4 */
679 : : [125] = RTE_PTYPE_L2_ETHER | RTE_PTYPE_L3_IPV6_EXT_UNKNOWN |
680 : : RTE_PTYPE_TUNNEL_GRENAT | RTE_PTYPE_INNER_L2_ETHER |
681 : : RTE_PTYPE_INNER_L3_IPV4_EXT_UNKNOWN |
682 : : RTE_PTYPE_INNER_L4_FRAG,
683 : : [126] = RTE_PTYPE_L2_ETHER | RTE_PTYPE_L3_IPV6_EXT_UNKNOWN |
684 : : RTE_PTYPE_TUNNEL_GRENAT | RTE_PTYPE_INNER_L2_ETHER |
685 : : RTE_PTYPE_INNER_L3_IPV4_EXT_UNKNOWN |
686 : : RTE_PTYPE_INNER_L4_NONFRAG,
687 : : [127] = RTE_PTYPE_L2_ETHER | RTE_PTYPE_L3_IPV6_EXT_UNKNOWN |
688 : : RTE_PTYPE_TUNNEL_GRENAT | RTE_PTYPE_INNER_L2_ETHER |
689 : : RTE_PTYPE_INNER_L3_IPV4_EXT_UNKNOWN |
690 : : RTE_PTYPE_INNER_L4_UDP,
691 : : /* [128] reserved */
692 : : [129] = RTE_PTYPE_L2_ETHER | RTE_PTYPE_L3_IPV6_EXT_UNKNOWN |
693 : : RTE_PTYPE_TUNNEL_GRENAT | RTE_PTYPE_INNER_L2_ETHER |
694 : : RTE_PTYPE_INNER_L3_IPV4_EXT_UNKNOWN |
695 : : RTE_PTYPE_INNER_L4_TCP,
696 : : [130] = RTE_PTYPE_L2_ETHER | RTE_PTYPE_L3_IPV6_EXT_UNKNOWN |
697 : : RTE_PTYPE_TUNNEL_GRENAT | RTE_PTYPE_INNER_L2_ETHER |
698 : : RTE_PTYPE_INNER_L3_IPV4_EXT_UNKNOWN |
699 : : RTE_PTYPE_INNER_L4_SCTP,
700 : : [131] = RTE_PTYPE_L2_ETHER | RTE_PTYPE_L3_IPV6_EXT_UNKNOWN |
701 : : RTE_PTYPE_TUNNEL_GRENAT | RTE_PTYPE_INNER_L2_ETHER |
702 : : RTE_PTYPE_INNER_L3_IPV4_EXT_UNKNOWN |
703 : : RTE_PTYPE_INNER_L4_ICMP,
704 : :
705 : : /* IPv6 --> GRE/Teredo/VXLAN --> MAC --> IPv6 */
706 : : [132] = RTE_PTYPE_L2_ETHER | RTE_PTYPE_L3_IPV6_EXT_UNKNOWN |
707 : : RTE_PTYPE_TUNNEL_GRENAT | RTE_PTYPE_INNER_L2_ETHER |
708 : : RTE_PTYPE_INNER_L3_IPV6_EXT_UNKNOWN |
709 : : RTE_PTYPE_INNER_L4_FRAG,
710 : : [133] = RTE_PTYPE_L2_ETHER | RTE_PTYPE_L3_IPV6_EXT_UNKNOWN |
711 : : RTE_PTYPE_TUNNEL_GRENAT | RTE_PTYPE_INNER_L2_ETHER |
712 : : RTE_PTYPE_INNER_L3_IPV6_EXT_UNKNOWN |
713 : : RTE_PTYPE_INNER_L4_NONFRAG,
714 : : [134] = RTE_PTYPE_L2_ETHER | RTE_PTYPE_L3_IPV6_EXT_UNKNOWN |
715 : : RTE_PTYPE_TUNNEL_GRENAT | RTE_PTYPE_INNER_L2_ETHER |
716 : : RTE_PTYPE_INNER_L3_IPV6_EXT_UNKNOWN |
717 : : RTE_PTYPE_INNER_L4_UDP,
718 : : /* [135] reserved */
719 : : [136] = RTE_PTYPE_L2_ETHER | RTE_PTYPE_L3_IPV6_EXT_UNKNOWN |
720 : : RTE_PTYPE_TUNNEL_GRENAT | RTE_PTYPE_INNER_L2_ETHER |
721 : : RTE_PTYPE_INNER_L3_IPV6_EXT_UNKNOWN |
722 : : RTE_PTYPE_INNER_L4_TCP,
723 : : [137] = RTE_PTYPE_L2_ETHER | RTE_PTYPE_L3_IPV6_EXT_UNKNOWN |
724 : : RTE_PTYPE_TUNNEL_GRENAT | RTE_PTYPE_INNER_L2_ETHER |
725 : : RTE_PTYPE_INNER_L3_IPV6_EXT_UNKNOWN |
726 : : RTE_PTYPE_INNER_L4_SCTP,
727 : : [138] = RTE_PTYPE_L2_ETHER | RTE_PTYPE_L3_IPV6_EXT_UNKNOWN |
728 : : RTE_PTYPE_TUNNEL_GRENAT | RTE_PTYPE_INNER_L2_ETHER |
729 : : RTE_PTYPE_INNER_L3_IPV6_EXT_UNKNOWN |
730 : : RTE_PTYPE_INNER_L4_ICMP,
731 : :
732 : : /* IPv6 --> GRE/Teredo/VXLAN --> MAC/VLAN */
733 : : [139] = RTE_PTYPE_L2_ETHER | RTE_PTYPE_L3_IPV6_EXT_UNKNOWN |
734 : : RTE_PTYPE_TUNNEL_GRENAT |
735 : : RTE_PTYPE_INNER_L2_ETHER_VLAN,
736 : :
737 : : /* IPv6 --> GRE/Teredo/VXLAN --> MAC/VLAN --> IPv4 */
738 : : [140] = RTE_PTYPE_L2_ETHER | RTE_PTYPE_L3_IPV6_EXT_UNKNOWN |
739 : : RTE_PTYPE_TUNNEL_GRENAT |
740 : : RTE_PTYPE_INNER_L2_ETHER_VLAN |
741 : : RTE_PTYPE_INNER_L3_IPV4_EXT_UNKNOWN |
742 : : RTE_PTYPE_INNER_L4_FRAG,
743 : : [141] = RTE_PTYPE_L2_ETHER | RTE_PTYPE_L3_IPV6_EXT_UNKNOWN |
744 : : RTE_PTYPE_TUNNEL_GRENAT |
745 : : RTE_PTYPE_INNER_L2_ETHER_VLAN |
746 : : RTE_PTYPE_INNER_L3_IPV4_EXT_UNKNOWN |
747 : : RTE_PTYPE_INNER_L4_NONFRAG,
748 : : [142] = RTE_PTYPE_L2_ETHER | RTE_PTYPE_L3_IPV6_EXT_UNKNOWN |
749 : : RTE_PTYPE_TUNNEL_GRENAT |
750 : : RTE_PTYPE_INNER_L2_ETHER_VLAN |
751 : : RTE_PTYPE_INNER_L3_IPV4_EXT_UNKNOWN |
752 : : RTE_PTYPE_INNER_L4_UDP,
753 : : /* [143] reserved */
754 : : [144] = RTE_PTYPE_L2_ETHER | RTE_PTYPE_L3_IPV6_EXT_UNKNOWN |
755 : : RTE_PTYPE_TUNNEL_GRENAT |
756 : : RTE_PTYPE_INNER_L2_ETHER_VLAN |
757 : : RTE_PTYPE_INNER_L3_IPV4_EXT_UNKNOWN |
758 : : RTE_PTYPE_INNER_L4_TCP,
759 : : [145] = RTE_PTYPE_L2_ETHER | RTE_PTYPE_L3_IPV6_EXT_UNKNOWN |
760 : : RTE_PTYPE_TUNNEL_GRENAT |
761 : : RTE_PTYPE_INNER_L2_ETHER_VLAN |
762 : : RTE_PTYPE_INNER_L3_IPV4_EXT_UNKNOWN |
763 : : RTE_PTYPE_INNER_L4_SCTP,
764 : : [146] = RTE_PTYPE_L2_ETHER | RTE_PTYPE_L3_IPV6_EXT_UNKNOWN |
765 : : RTE_PTYPE_TUNNEL_GRENAT |
766 : : RTE_PTYPE_INNER_L2_ETHER_VLAN |
767 : : RTE_PTYPE_INNER_L3_IPV4_EXT_UNKNOWN |
768 : : RTE_PTYPE_INNER_L4_ICMP,
769 : :
770 : : /* IPv6 --> GRE/Teredo/VXLAN --> MAC/VLAN --> IPv6 */
771 : : [147] = RTE_PTYPE_L2_ETHER | RTE_PTYPE_L3_IPV6_EXT_UNKNOWN |
772 : : RTE_PTYPE_TUNNEL_GRENAT |
773 : : RTE_PTYPE_INNER_L2_ETHER_VLAN |
774 : : RTE_PTYPE_INNER_L3_IPV6_EXT_UNKNOWN |
775 : : RTE_PTYPE_INNER_L4_FRAG,
776 : : [148] = RTE_PTYPE_L2_ETHER | RTE_PTYPE_L3_IPV6_EXT_UNKNOWN |
777 : : RTE_PTYPE_TUNNEL_GRENAT |
778 : : RTE_PTYPE_INNER_L2_ETHER_VLAN |
779 : : RTE_PTYPE_INNER_L3_IPV6_EXT_UNKNOWN |
780 : : RTE_PTYPE_INNER_L4_NONFRAG,
781 : : [149] = RTE_PTYPE_L2_ETHER | RTE_PTYPE_L3_IPV6_EXT_UNKNOWN |
782 : : RTE_PTYPE_TUNNEL_GRENAT |
783 : : RTE_PTYPE_INNER_L2_ETHER_VLAN |
784 : : RTE_PTYPE_INNER_L3_IPV6_EXT_UNKNOWN |
785 : : RTE_PTYPE_INNER_L4_UDP,
786 : : /* [150] reserved */
787 : : [151] = RTE_PTYPE_L2_ETHER | RTE_PTYPE_L3_IPV6_EXT_UNKNOWN |
788 : : RTE_PTYPE_TUNNEL_GRENAT |
789 : : RTE_PTYPE_INNER_L2_ETHER_VLAN |
790 : : RTE_PTYPE_INNER_L3_IPV6_EXT_UNKNOWN |
791 : : RTE_PTYPE_INNER_L4_TCP,
792 : : [152] = RTE_PTYPE_L2_ETHER | RTE_PTYPE_L3_IPV6_EXT_UNKNOWN |
793 : : RTE_PTYPE_TUNNEL_GRENAT |
794 : : RTE_PTYPE_INNER_L2_ETHER_VLAN |
795 : : RTE_PTYPE_INNER_L3_IPV6_EXT_UNKNOWN |
796 : : RTE_PTYPE_INNER_L4_SCTP,
797 : : [153] = RTE_PTYPE_L2_ETHER | RTE_PTYPE_L3_IPV6_EXT_UNKNOWN |
798 : : RTE_PTYPE_TUNNEL_GRENAT |
799 : : RTE_PTYPE_INNER_L2_ETHER_VLAN |
800 : : RTE_PTYPE_INNER_L3_IPV6_EXT_UNKNOWN |
801 : : RTE_PTYPE_INNER_L4_ICMP,
802 : :
803 : : /* L2 NSH packet type */
804 : : [154] = RTE_PTYPE_L2_ETHER_NSH,
805 : : [155] = RTE_PTYPE_L2_ETHER_NSH | RTE_PTYPE_L3_IPV4_EXT_UNKNOWN |
806 : : RTE_PTYPE_L4_FRAG,
807 : : [156] = RTE_PTYPE_L2_ETHER_NSH | RTE_PTYPE_L3_IPV4_EXT_UNKNOWN |
808 : : RTE_PTYPE_L4_NONFRAG,
809 : : [157] = RTE_PTYPE_L2_ETHER_NSH | RTE_PTYPE_L3_IPV4_EXT_UNKNOWN |
810 : : RTE_PTYPE_L4_UDP,
811 : : [158] = RTE_PTYPE_L2_ETHER_NSH | RTE_PTYPE_L3_IPV4_EXT_UNKNOWN |
812 : : RTE_PTYPE_L4_TCP,
813 : : [159] = RTE_PTYPE_L2_ETHER_NSH | RTE_PTYPE_L3_IPV4_EXT_UNKNOWN |
814 : : RTE_PTYPE_L4_SCTP,
815 : : [160] = RTE_PTYPE_L2_ETHER_NSH | RTE_PTYPE_L3_IPV4_EXT_UNKNOWN |
816 : : RTE_PTYPE_L4_ICMP,
817 : : [161] = RTE_PTYPE_L2_ETHER_NSH | RTE_PTYPE_L3_IPV6_EXT_UNKNOWN |
818 : : RTE_PTYPE_L4_FRAG,
819 : : [162] = RTE_PTYPE_L2_ETHER_NSH | RTE_PTYPE_L3_IPV6_EXT_UNKNOWN |
820 : : RTE_PTYPE_L4_NONFRAG,
821 : : [163] = RTE_PTYPE_L2_ETHER_NSH | RTE_PTYPE_L3_IPV6_EXT_UNKNOWN |
822 : : RTE_PTYPE_L4_UDP,
823 : : [164] = RTE_PTYPE_L2_ETHER_NSH | RTE_PTYPE_L3_IPV6_EXT_UNKNOWN |
824 : : RTE_PTYPE_L4_TCP,
825 : : [165] = RTE_PTYPE_L2_ETHER_NSH | RTE_PTYPE_L3_IPV6_EXT_UNKNOWN |
826 : : RTE_PTYPE_L4_SCTP,
827 : : [166] = RTE_PTYPE_L2_ETHER_NSH | RTE_PTYPE_L3_IPV6_EXT_UNKNOWN |
828 : : RTE_PTYPE_L4_ICMP,
829 : :
830 : : /* All others reserved */
831 : : };
832 : :
833 : 0 : return type_table[ptype];
834 : : }
835 : :
836 : : #endif /* _I40E_RXTX_H_ */
|