DPDK 26.03.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
28typedef void (*iavf_pre_reset_cb_t)(uint16_t port_id, void *arg);
30typedef void (*iavf_post_reset_cb_t)(uint16_t port_id, int reset_state, void *arg);
31
36 uint32_t metadata;
37
38 struct {
39 uint16_t data0;
40 uint16_t data1;
41 } raw;
42
43 struct {
44 uint16_t stag_vid:12,
45 stag_dei:1,
46 stag_pcp:3;
47 uint16_t ctag_vid:12,
48 ctag_dei:1,
49 ctag_pcp:3;
50 } vlan;
51
52 struct {
53 uint16_t protocol:8,
54 ttl:8;
55 uint16_t tos:8,
56 ihl:4,
57 version:4;
58 } ipv4;
59
60 struct {
61 uint16_t hoplimit:8,
62 nexthdr:8;
63 uint16_t flowhi4:4,
64 tc:8,
65 version:4;
66 } ipv6;
67
68 struct {
69 uint16_t flowlo16;
70 uint16_t flowhi4:4,
71 tc:8,
72 version:4;
73 } ipv6_flow;
74
75 struct {
76 uint16_t fin:1,
77 syn:1,
78 rst:1,
79 psh:1,
80 ack:1,
81 urg:1,
82 ece:1,
83 cwr:1,
84 res1:4,
85 doff:4;
86 uint16_t rsvd;
87 } tcp;
88
89 uint32_t ip_ofs;
90};
91
92/* Offset of mbuf dynamic field for flexible descriptor's extraction data */
93extern int rte_pmd_ifd_dynfield_proto_xtr_metadata_offs;
94
95/* Mask of mbuf dynamic flags for flexible descriptor's extraction type */
96extern uint64_t rte_pmd_ifd_dynflag_proto_xtr_vlan_mask;
97extern uint64_t rte_pmd_ifd_dynflag_proto_xtr_ipv4_mask;
98extern uint64_t rte_pmd_ifd_dynflag_proto_xtr_ipv6_mask;
99extern uint64_t rte_pmd_ifd_dynflag_proto_xtr_ipv6_flow_mask;
100extern uint64_t rte_pmd_ifd_dynflag_proto_xtr_tcp_mask;
101extern uint64_t rte_pmd_ifd_dynflag_proto_xtr_ip_offset_mask;
102extern uint64_t rte_pmd_ifd_dynflag_proto_xtr_ipsec_crypto_said_mask;
103
114__rte_experimental
115int rte_pmd_iavf_reinit(uint16_t port);
116
132__rte_experimental
134 iavf_pre_reset_cb_t pre_reset_cb,
135 void *pre_reset_cb_arg);
136
152__rte_experimental
154 iavf_post_reset_cb_t post_reset_cb,
155 void *post_reset_cb_arg);
156
160#define RTE_PMD_IFD_DYNF_PROTO_XTR_METADATA(m) \
161 RTE_MBUF_DYNFIELD((m), \
162 rte_pmd_ifd_dynfield_proto_xtr_metadata_offs, \
163 uint32_t *)
164
169#define RTE_IAVF_PKT_RX_DYNF_PROTO_XTR_VLAN \
170 (rte_pmd_ifd_dynflag_proto_xtr_vlan_mask)
171
176#define RTE_IAVF_PKT_RX_DYNF_PROTO_XTR_IPV4 \
177 (rte_pmd_ifd_dynflag_proto_xtr_ipv4_mask)
178
183#define RTE_IAVF_PKT_RX_DYNF_PROTO_XTR_IPV6 \
184 (rte_pmd_ifd_dynflag_proto_xtr_ipv6_mask)
185
190#define RTE_IAVF_PKT_RX_DYNF_PROTO_XTR_IPV6_FLOW \
191 (rte_pmd_ifd_dynflag_proto_xtr_ipv6_flow_mask)
192
197#define RTE_IAVF_PKT_RX_DYNF_PROTO_XTR_TCP \
198 (rte_pmd_ifd_dynflag_proto_xtr_tcp_mask)
199
204#define RTE_IAVF_PKT_RX_DYNF_PROTO_XTR_IP_OFFSET \
205 (rte_pmd_ifd_dynflag_proto_xtr_ip_offset_mask)
206
214__rte_experimental
215static __rte_always_inline int
217{
218 return rte_pmd_ifd_dynfield_proto_xtr_metadata_offs != -1;
219}
220
229__rte_experimental
230static __rte_always_inline uint32_t
232{
234}
235
242__rte_experimental
243static inline void
245{
246#ifdef ALLOW_EXPERIMENTAL_API
248
250 return;
251
253
255 printf(" - Flexible descriptor's Metadata: [0x%04x:0x%04x],"
256 "vlan,stag=%u:%u:%u,ctag=%u:%u:%u",
257 data.raw.data0, data.raw.data1,
258 data.vlan.stag_pcp,
259 data.vlan.stag_dei,
260 data.vlan.stag_vid,
261 data.vlan.ctag_pcp,
262 data.vlan.ctag_dei,
263 data.vlan.ctag_vid);
265 printf(" - Flexible descriptor's Metadata: [0x%04x:0x%04x],"
266 "ipv4,ver=%u,hdrlen=%u,tos=%u,ttl=%u,proto=%u",
267 data.raw.data0, data.raw.data1,
268 data.ipv4.version,
269 data.ipv4.ihl,
270 data.ipv4.tos,
271 data.ipv4.ttl,
272 data.ipv4.protocol);
274 printf(" - Flexible descriptor's Metadata: [0x%04x:0x%04x],"
275 "ipv6,ver=%u,tc=%u,flow_hi4=0x%x,nexthdr=%u,hoplimit=%u",
276 data.raw.data0, data.raw.data1,
277 data.ipv6.version,
278 data.ipv6.tc,
279 data.ipv6.flowhi4,
280 data.ipv6.nexthdr,
281 data.ipv6.hoplimit);
283 printf(" - Flexible descriptor's Metadata: [0x%04x:0x%04x],"
284 "ipv6_flow,ver=%u,tc=%u,flow=0x%x%04x",
285 data.raw.data0, data.raw.data1,
286 data.ipv6_flow.version,
287 data.ipv6_flow.tc,
288 data.ipv6_flow.flowhi4,
289 data.ipv6_flow.flowlo16);
291 printf(" - Flexible descriptor's Metadata: [0x%04x:0x%04x],"
292 "tcp,doff=%u,flags=%s%s%s%s%s%s%s%s",
293 data.raw.data0, data.raw.data1,
294 data.tcp.doff,
295 data.tcp.cwr ? "C" : "",
296 data.tcp.ece ? "E" : "",
297 data.tcp.urg ? "U" : "",
298 data.tcp.ack ? "A" : "",
299 data.tcp.psh ? "P" : "",
300 data.tcp.rst ? "R" : "",
301 data.tcp.syn ? "S" : "",
302 data.tcp.fin ? "F" : "");
304 printf(" - Flexible descriptor's Extraction: ip_offset=%u",
305 data.ip_ofs);
306#else
307 RTE_SET_USED(m);
308 RTE_VERIFY(false);
309#endif
310}
311
312#ifdef __cplusplus
313}
314#endif
315
316#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:244
__rte_experimental int rte_pmd_iavf_reinit(uint16_t port)
void(* iavf_pre_reset_cb_t)(uint16_t port_id, void *arg)
Definition: rte_pmd_iavf.h:28
#define RTE_IAVF_PKT_RX_DYNF_PROTO_XTR_VLAN
Definition: rte_pmd_iavf.h:169
#define RTE_IAVF_PKT_RX_DYNF_PROTO_XTR_IP_OFFSET
Definition: rte_pmd_iavf.h:204
#define RTE_IAVF_PKT_RX_DYNF_PROTO_XTR_IPV4
Definition: rte_pmd_iavf.h:176
void(* iavf_post_reset_cb_t)(uint16_t port_id, int reset_state, void *arg)
Definition: rte_pmd_iavf.h:30
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:231
__rte_experimental int rte_pmd_iavf_register_post_reset_cb(uint16_t port, iavf_post_reset_cb_t post_reset_cb, void *post_reset_cb_arg)
#define RTE_IAVF_PKT_RX_DYNF_PROTO_XTR_TCP
Definition: rte_pmd_iavf.h:197
#define RTE_PMD_IFD_DYNF_PROTO_XTR_METADATA(m)
Definition: rte_pmd_iavf.h:160
__rte_experimental int rte_pmd_iavf_register_pre_reset_cb(uint16_t port, iavf_pre_reset_cb_t pre_reset_cb, void *pre_reset_cb_arg)
#define RTE_IAVF_PKT_RX_DYNF_PROTO_XTR_IPV6_FLOW
Definition: rte_pmd_iavf.h:190
#define RTE_IAVF_PKT_RX_DYNF_PROTO_XTR_IPV6
Definition: rte_pmd_iavf.h:183
static __rte_experimental __rte_always_inline int rte_pmd_ifd_dynf_proto_xtr_metadata_avail(void)
Definition: rte_pmd_iavf.h:216
uint64_t ol_flags