DPDK
25.11.0
Toggle main menu visibility
Loading...
Searching...
No Matches
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
16
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
30
union
rte_pmd_ifd_proto_xtr_metadata
{
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
171
rte_pmd_ifd_dynf_proto_xtr_metadata_avail
(
void
)
172
{
173
return
rte_pmd_ifd_dynfield_proto_xtr_metadata_offs != -1;
174
}
175
184
__rte_experimental
185
static
__rte_always_inline
uint32_t
186
rte_pmd_ifd_dynf_proto_xtr_metadata_get
(
struct
rte_mbuf
*m)
187
{
188
return
*
RTE_PMD_IFD_DYNF_PROTO_XTR_METADATA
(m);
189
}
190
197
__rte_experimental
198
static
inline
void
199
rte_pmd_ifd_dump_proto_xtr_metadata
(
struct
rte_mbuf
*m)
200
{
201
#ifdef ALLOW_EXPERIMENTAL_API
202
union
rte_pmd_ifd_proto_xtr_metadata
data;
203
204
if
(!
rte_pmd_ifd_dynf_proto_xtr_metadata_avail
())
205
return
;
206
207
data.metadata =
rte_pmd_ifd_dynf_proto_xtr_metadata_get
(m);
208
209
if
(m->
ol_flags
&
RTE_IAVF_PKT_RX_DYNF_PROTO_XTR_VLAN
)
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);
219
else
if
(m->
ol_flags
&
RTE_IAVF_PKT_RX_DYNF_PROTO_XTR_IPV4
)
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);
228
else
if
(m->
ol_flags
&
RTE_IAVF_PKT_RX_DYNF_PROTO_XTR_IPV6
)
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);
237
else
if
(m->
ol_flags
&
RTE_IAVF_PKT_RX_DYNF_PROTO_XTR_IPV6_FLOW
)
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);
245
else
if
(m->
ol_flags
&
RTE_IAVF_PKT_RX_DYNF_PROTO_XTR_TCP
)
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"
:
""
);
258
else
if
(m->
ol_flags
&
RTE_IAVF_PKT_RX_DYNF_PROTO_XTR_IP_OFFSET
)
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_ */
RTE_SET_USED
#define RTE_SET_USED(x)
Definition
rte_common.h:264
__rte_always_inline
#define __rte_always_inline
Definition
rte_common.h:490
rte_mbuf.h
rte_mbuf_dyn.h
rte_pmd_ifd_dump_proto_xtr_metadata
static __rte_experimental void rte_pmd_ifd_dump_proto_xtr_metadata(struct rte_mbuf *m)
Definition
rte_pmd_iavf.h:199
rte_pmd_iavf_reinit
__rte_experimental int rte_pmd_iavf_reinit(uint16_t port)
RTE_IAVF_PKT_RX_DYNF_PROTO_XTR_VLAN
#define RTE_IAVF_PKT_RX_DYNF_PROTO_XTR_VLAN
Definition
rte_pmd_iavf.h:124
RTE_IAVF_PKT_RX_DYNF_PROTO_XTR_IP_OFFSET
#define RTE_IAVF_PKT_RX_DYNF_PROTO_XTR_IP_OFFSET
Definition
rte_pmd_iavf.h:159
RTE_IAVF_PKT_RX_DYNF_PROTO_XTR_IPV4
#define RTE_IAVF_PKT_RX_DYNF_PROTO_XTR_IPV4
Definition
rte_pmd_iavf.h:131
rte_pmd_ifd_dynf_proto_xtr_metadata_get
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
RTE_IAVF_PKT_RX_DYNF_PROTO_XTR_TCP
#define RTE_IAVF_PKT_RX_DYNF_PROTO_XTR_TCP
Definition
rte_pmd_iavf.h:152
RTE_PMD_IFD_DYNF_PROTO_XTR_METADATA
#define RTE_PMD_IFD_DYNF_PROTO_XTR_METADATA(m)
Definition
rte_pmd_iavf.h:115
RTE_IAVF_PKT_RX_DYNF_PROTO_XTR_IPV6_FLOW
#define RTE_IAVF_PKT_RX_DYNF_PROTO_XTR_IPV6_FLOW
Definition
rte_pmd_iavf.h:145
RTE_IAVF_PKT_RX_DYNF_PROTO_XTR_IPV6
#define RTE_IAVF_PKT_RX_DYNF_PROTO_XTR_IPV6
Definition
rte_pmd_iavf.h:138
rte_pmd_ifd_dynf_proto_xtr_metadata_avail
static __rte_experimental __rte_always_inline int rte_pmd_ifd_dynf_proto_xtr_metadata_avail(void)
Definition
rte_pmd_iavf.h:171
rte_mbuf
Definition
rte_mbuf_core.h:475
rte_mbuf::ol_flags
uint64_t ol_flags
Definition
rte_mbuf_core.h:529
rte_pmd_ifd_proto_xtr_metadata
Definition
rte_pmd_iavf.h:30
drivers
net
intel
iavf
rte_pmd_iavf.h
Generated by
1.17.0