DPDK 25.11.0-rc1
rte_pmd_iavf.h
Go to the documentation of this file.
1/* SPDX-License-Identifier: BSD-3-Clause
2 * Copyright(c) 2019 Intel Corporation
3 */
4
5#ifndef _RTE_PMD_IAVF_H_
6#define _RTE_PMD_IAVF_H_
7
17#include <stdio.h>
18
19#include <rte_compat.h>
20#include <rte_mbuf.h>
21#include <rte_mbuf_dyn.h>
22
23#ifdef __cplusplus
24extern "C" {
25#endif
26
31 uint32_t metadata;
32
33 struct {
34 uint16_t data0;
35 uint16_t data1;
36 } raw;
37
38 struct {
39 uint16_t stag_vid:12,
40 stag_dei:1,
41 stag_pcp:3;
42 uint16_t ctag_vid:12,
43 ctag_dei:1,
44 ctag_pcp:3;
45 } vlan;
46
47 struct {
48 uint16_t protocol:8,
49 ttl:8;
50 uint16_t tos:8,
51 ihl:4,
52 version:4;
53 } ipv4;
54
55 struct {
56 uint16_t hoplimit:8,
57 nexthdr:8;
58 uint16_t flowhi4:4,
59 tc:8,
60 version:4;
61 } ipv6;
62
63 struct {
64 uint16_t flowlo16;
65 uint16_t flowhi4:4,
66 tc:8,
67 version:4;
68 } ipv6_flow;
69
70 struct {
71 uint16_t fin:1,
72 syn:1,
73 rst:1,
74 psh:1,
75 ack:1,
76 urg:1,
77 ece:1,
78 cwr:1,
79 res1:4,
80 doff:4;
81 uint16_t rsvd;
82 } tcp;
83
84 uint32_t ip_ofs;
85};
86
87/* Offset of mbuf dynamic field for flexible descriptor's extraction data */
88extern int rte_pmd_ifd_dynfield_proto_xtr_metadata_offs;
89
90/* Mask of mbuf dynamic flags for flexible descriptor's extraction type */
91extern uint64_t rte_pmd_ifd_dynflag_proto_xtr_vlan_mask;
92extern uint64_t rte_pmd_ifd_dynflag_proto_xtr_ipv4_mask;
93extern uint64_t rte_pmd_ifd_dynflag_proto_xtr_ipv6_mask;
94extern uint64_t rte_pmd_ifd_dynflag_proto_xtr_ipv6_flow_mask;
95extern uint64_t rte_pmd_ifd_dynflag_proto_xtr_tcp_mask;
96extern uint64_t rte_pmd_ifd_dynflag_proto_xtr_ip_offset_mask;
97extern uint64_t rte_pmd_ifd_dynflag_proto_xtr_ipsec_crypto_said_mask;
98
109__rte_experimental
110int rte_pmd_iavf_reinit(uint16_t port);
111
115#define RTE_PMD_IFD_DYNF_PROTO_XTR_METADATA(m) \
116 RTE_MBUF_DYNFIELD((m), \
117 rte_pmd_ifd_dynfield_proto_xtr_metadata_offs, \
118 uint32_t *)
119
124#define RTE_IAVF_PKT_RX_DYNF_PROTO_XTR_VLAN \
125 (rte_pmd_ifd_dynflag_proto_xtr_vlan_mask)
126
131#define RTE_IAVF_PKT_RX_DYNF_PROTO_XTR_IPV4 \
132 (rte_pmd_ifd_dynflag_proto_xtr_ipv4_mask)
133
138#define RTE_IAVF_PKT_RX_DYNF_PROTO_XTR_IPV6 \
139 (rte_pmd_ifd_dynflag_proto_xtr_ipv6_mask)
140
145#define RTE_IAVF_PKT_RX_DYNF_PROTO_XTR_IPV6_FLOW \
146 (rte_pmd_ifd_dynflag_proto_xtr_ipv6_flow_mask)
147
152#define RTE_IAVF_PKT_RX_DYNF_PROTO_XTR_TCP \
153 (rte_pmd_ifd_dynflag_proto_xtr_tcp_mask)
154
159#define RTE_IAVF_PKT_RX_DYNF_PROTO_XTR_IP_OFFSET \
160 (rte_pmd_ifd_dynflag_proto_xtr_ip_offset_mask)
161
169__rte_experimental
170static __rte_always_inline int
172{
173 return rte_pmd_ifd_dynfield_proto_xtr_metadata_offs != -1;
174}
175
184__rte_experimental
185static __rte_always_inline uint32_t
187{
189}
190
197__rte_experimental
198static inline void
200{
201#ifdef ALLOW_EXPERIMENTAL_API
203
205 return;
206
208
210 printf(" - Flexible descriptor's Metadata: [0x%04x:0x%04x],"
211 "vlan,stag=%u:%u:%u,ctag=%u:%u:%u",
212 data.raw.data0, data.raw.data1,
213 data.vlan.stag_pcp,
214 data.vlan.stag_dei,
215 data.vlan.stag_vid,
216 data.vlan.ctag_pcp,
217 data.vlan.ctag_dei,
218 data.vlan.ctag_vid);
220 printf(" - Flexible descriptor's Metadata: [0x%04x:0x%04x],"
221 "ipv4,ver=%u,hdrlen=%u,tos=%u,ttl=%u,proto=%u",
222 data.raw.data0, data.raw.data1,
223 data.ipv4.version,
224 data.ipv4.ihl,
225 data.ipv4.tos,
226 data.ipv4.ttl,
227 data.ipv4.protocol);
229 printf(" - Flexible descriptor's Metadata: [0x%04x:0x%04x],"
230 "ipv6,ver=%u,tc=%u,flow_hi4=0x%x,nexthdr=%u,hoplimit=%u",
231 data.raw.data0, data.raw.data1,
232 data.ipv6.version,
233 data.ipv6.tc,
234 data.ipv6.flowhi4,
235 data.ipv6.nexthdr,
236 data.ipv6.hoplimit);
238 printf(" - Flexible descriptor's Metadata: [0x%04x:0x%04x],"
239 "ipv6_flow,ver=%u,tc=%u,flow=0x%x%04x",
240 data.raw.data0, data.raw.data1,
241 data.ipv6_flow.version,
242 data.ipv6_flow.tc,
243 data.ipv6_flow.flowhi4,
244 data.ipv6_flow.flowlo16);
246 printf(" - Flexible descriptor's Metadata: [0x%04x:0x%04x],"
247 "tcp,doff=%u,flags=%s%s%s%s%s%s%s%s",
248 data.raw.data0, data.raw.data1,
249 data.tcp.doff,
250 data.tcp.cwr ? "C" : "",
251 data.tcp.ece ? "E" : "",
252 data.tcp.urg ? "U" : "",
253 data.tcp.ack ? "A" : "",
254 data.tcp.psh ? "P" : "",
255 data.tcp.rst ? "R" : "",
256 data.tcp.syn ? "S" : "",
257 data.tcp.fin ? "F" : "");
259 printf(" - Flexible descriptor's Extraction: ip_offset=%u",
260 data.ip_ofs);
261#else
262 RTE_SET_USED(m);
263 RTE_VERIFY(false);
264#endif
265}
266
267#ifdef __cplusplus
268}
269#endif
270
271#endif /* _RTE_PMD_IAVF_H_ */
#define RTE_SET_USED(x)
Definition: rte_common.h:264
#define __rte_always_inline
Definition: rte_common.h:490
static __rte_experimental void rte_pmd_ifd_dump_proto_xtr_metadata(struct rte_mbuf *m)
Definition: rte_pmd_iavf.h:199
__rte_experimental int rte_pmd_iavf_reinit(uint16_t port)
#define RTE_IAVF_PKT_RX_DYNF_PROTO_XTR_VLAN
Definition: rte_pmd_iavf.h:124
#define RTE_IAVF_PKT_RX_DYNF_PROTO_XTR_IP_OFFSET
Definition: rte_pmd_iavf.h:159
#define RTE_IAVF_PKT_RX_DYNF_PROTO_XTR_IPV4
Definition: rte_pmd_iavf.h:131
static __rte_experimental __rte_always_inline uint32_t rte_pmd_ifd_dynf_proto_xtr_metadata_get(struct rte_mbuf *m)
Definition: rte_pmd_iavf.h:186
#define RTE_IAVF_PKT_RX_DYNF_PROTO_XTR_TCP
Definition: rte_pmd_iavf.h:152
#define RTE_PMD_IFD_DYNF_PROTO_XTR_METADATA(m)
Definition: rte_pmd_iavf.h:115
#define RTE_IAVF_PKT_RX_DYNF_PROTO_XTR_IPV6_FLOW
Definition: rte_pmd_iavf.h:145
#define RTE_IAVF_PKT_RX_DYNF_PROTO_XTR_IPV6
Definition: rte_pmd_iavf.h:138
static __rte_experimental __rte_always_inline int rte_pmd_ifd_dynf_proto_xtr_metadata_avail(void)
Definition: rte_pmd_iavf.h:171
uint64_t ol_flags