DPDK  25.11.0
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
24 extern "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 */
88 extern int rte_pmd_ifd_dynfield_proto_xtr_metadata_offs;
89 
90 /* Mask of mbuf dynamic flags for flexible descriptor's extraction type */
91 extern uint64_t rte_pmd_ifd_dynflag_proto_xtr_vlan_mask;
92 extern uint64_t rte_pmd_ifd_dynflag_proto_xtr_ipv4_mask;
93 extern uint64_t rte_pmd_ifd_dynflag_proto_xtr_ipv6_mask;
94 extern uint64_t rte_pmd_ifd_dynflag_proto_xtr_ipv6_flow_mask;
95 extern uint64_t rte_pmd_ifd_dynflag_proto_xtr_tcp_mask;
96 extern uint64_t rte_pmd_ifd_dynflag_proto_xtr_ip_offset_mask;
97 extern uint64_t rte_pmd_ifd_dynflag_proto_xtr_ipsec_crypto_said_mask;
98 
109 __rte_experimental
110 int 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
170 static __rte_always_inline int
172 {
173  return rte_pmd_ifd_dynfield_proto_xtr_metadata_offs != -1;
174 }
175 
184 __rte_experimental
185 static __rte_always_inline uint32_t
187 {
189 }
190 
197 __rte_experimental
198 static inline void
200 {
201 #ifdef ALLOW_EXPERIMENTAL_API
203 
205  return;
206 
207  data.metadata = rte_pmd_ifd_dynf_proto_xtr_metadata_get(m);
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