5#ifndef _RTE_PMD_IAVF_H_
6#define _RTE_PMD_IAVF_H_
19#include <rte_compat.h>
93extern int rte_pmd_ifd_dynfield_proto_xtr_metadata_offs;
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;
135 void *pre_reset_cb_arg);
155 void *post_reset_cb_arg);
160#define RTE_PMD_IFD_DYNF_PROTO_XTR_METADATA(m) \
161 RTE_MBUF_DYNFIELD((m), \
162 rte_pmd_ifd_dynfield_proto_xtr_metadata_offs, \
169#define RTE_IAVF_PKT_RX_DYNF_PROTO_XTR_VLAN \
170 (rte_pmd_ifd_dynflag_proto_xtr_vlan_mask)
176#define RTE_IAVF_PKT_RX_DYNF_PROTO_XTR_IPV4 \
177 (rte_pmd_ifd_dynflag_proto_xtr_ipv4_mask)
183#define RTE_IAVF_PKT_RX_DYNF_PROTO_XTR_IPV6 \
184 (rte_pmd_ifd_dynflag_proto_xtr_ipv6_mask)
190#define RTE_IAVF_PKT_RX_DYNF_PROTO_XTR_IPV6_FLOW \
191 (rte_pmd_ifd_dynflag_proto_xtr_ipv6_flow_mask)
197#define RTE_IAVF_PKT_RX_DYNF_PROTO_XTR_TCP \
198 (rte_pmd_ifd_dynflag_proto_xtr_tcp_mask)
204#define RTE_IAVF_PKT_RX_DYNF_PROTO_XTR_IP_OFFSET \
205 (rte_pmd_ifd_dynflag_proto_xtr_ip_offset_mask)
218 return rte_pmd_ifd_dynfield_proto_xtr_metadata_offs != -1;
246#ifdef ALLOW_EXPERIMENTAL_API
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,
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,
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,
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,
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,
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",
#define __rte_always_inline
static __rte_experimental void rte_pmd_ifd_dump_proto_xtr_metadata(struct rte_mbuf *m)
__rte_experimental int rte_pmd_iavf_reinit(uint16_t port)
void(* iavf_pre_reset_cb_t)(uint16_t port_id, void *arg)
#define RTE_IAVF_PKT_RX_DYNF_PROTO_XTR_VLAN
#define RTE_IAVF_PKT_RX_DYNF_PROTO_XTR_IP_OFFSET
#define RTE_IAVF_PKT_RX_DYNF_PROTO_XTR_IPV4
void(* iavf_post_reset_cb_t)(uint16_t port_id, int reset_state, void *arg)
static __rte_experimental __rte_always_inline uint32_t rte_pmd_ifd_dynf_proto_xtr_metadata_get(struct rte_mbuf *m)
__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
#define RTE_PMD_IFD_DYNF_PROTO_XTR_METADATA(m)
__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
#define RTE_IAVF_PKT_RX_DYNF_PROTO_XTR_IPV6
static __rte_experimental __rte_always_inline int rte_pmd_ifd_dynf_proto_xtr_metadata_avail(void)