DPDK
23.07.0
|
#include <stddef.h>
#include <stdint.h>
#include <rte_compat.h>
#include <rte_common.h>
#include <rte_ether.h>
#include <rte_arp.h>
#include <rte_icmp.h>
#include <rte_ip.h>
#include <rte_sctp.h>
#include <rte_tcp.h>
#include <rte_udp.h>
#include <rte_vxlan.h>
#include <rte_esp.h>
#include <rte_higig.h>
#include <rte_ecpri.h>
#include <rte_bitops.h>
#include <rte_mbuf_dyn.h>
#include <rte_meter.h>
#include <rte_gtp.h>
#include <rte_l2tpv2.h>
#include <rte_ppp.h>
#include <rte_gre.h>
#include <rte_macsec.h>
#include <rte_ib.h>
Go to the source code of this file.
Macros | |
#define | RTE_FLOW_CONNTRACK_PKT_STATE_VALID RTE_BIT32(0) |
#define | RTE_FLOW_CONNTRACK_PKT_STATE_CHANGED RTE_BIT32(1) |
#define | RTE_FLOW_CONNTRACK_PKT_STATE_INVALID RTE_BIT32(2) |
#define | RTE_FLOW_CONNTRACK_PKT_STATE_DISABLED RTE_BIT32(3) |
#define | RTE_FLOW_CONNTRACK_PKT_STATE_BAD RTE_BIT32(4) |
#define | RTE_FLOW_RESTORE_INFO_TUNNEL RTE_BIT64(0) |
#define | RTE_FLOW_RESTORE_INFO_ENCAPSULATED RTE_BIT64(1) |
#define | RTE_FLOW_RESTORE_INFO_GROUP_ID RTE_BIT64(2) |
#define | RTE_FLOW_PORT_FLAG_STRICT_QUEUE RTE_BIT32(0) |
#define | RTE_FLOW_PORT_FLAG_SHARE_INDIRECT RTE_BIT32(0) |
Flags for template table attribute. | |
Each bit is an optional hint for table specialization, offering a potential optimization at driver layer. The driver can ignore the hints silently. The hints do not replace any matching criteria. | |
#define | RTE_FLOW_TABLE_SPECIALIZE_TRANSFER_WIRE_ORIG RTE_BIT32(0) |
#define | RTE_FLOW_TABLE_SPECIALIZE_TRANSFER_VPORT_ORIG RTE_BIT32(1) |
Functions | |
__rte_experimental int | rte_flow_dev_dump (uint16_t port_id, struct rte_flow *flow, FILE *file, struct rte_flow_error *error) |
static __rte_experimental int | rte_flow_dynf_metadata_avail (void) |
__rte_experimental int | rte_flow_dynf_metadata_register (void) |
int | rte_flow_validate (uint16_t port_id, const struct rte_flow_attr *attr, const struct rte_flow_item pattern[], const struct rte_flow_action actions[], struct rte_flow_error *error) |
struct rte_flow * | rte_flow_create (uint16_t port_id, const struct rte_flow_attr *attr, const struct rte_flow_item pattern[], const struct rte_flow_action actions[], struct rte_flow_error *error) |
int | rte_flow_destroy (uint16_t port_id, struct rte_flow *flow, struct rte_flow_error *error) |
__rte_experimental int | rte_flow_actions_update (uint16_t port_id, struct rte_flow *flow, const struct rte_flow_action actions[], struct rte_flow_error *error) |
int | rte_flow_flush (uint16_t port_id, struct rte_flow_error *error) |
int | rte_flow_query (uint16_t port_id, struct rte_flow *flow, const struct rte_flow_action *action, void *data, struct rte_flow_error *error) |
int | rte_flow_isolate (uint16_t port_id, int set, struct rte_flow_error *error) |
int | rte_flow_error_set (struct rte_flow_error *error, int code, enum rte_flow_error_type type, const void *cause, const char *message) |
__rte_deprecated size_t | rte_flow_copy (struct rte_flow_desc *fd, size_t len, const struct rte_flow_attr *attr, const struct rte_flow_item *items, const struct rte_flow_action *actions) |
__rte_experimental int | rte_flow_conv (enum rte_flow_conv_op op, void *dst, size_t size, const void *src, struct rte_flow_error *error) |
__rte_experimental int | rte_flow_get_aged_flows (uint16_t port_id, void **contexts, uint32_t nb_contexts, struct rte_flow_error *error) |
__rte_experimental int | rte_flow_get_q_aged_flows (uint16_t port_id, uint32_t queue_id, void **contexts, uint32_t nb_contexts, struct rte_flow_error *error) |
__rte_experimental struct rte_flow_action_handle * | rte_flow_action_handle_create (uint16_t port_id, const struct rte_flow_indir_action_conf *conf, const struct rte_flow_action *action, struct rte_flow_error *error) |
__rte_experimental int | rte_flow_action_handle_destroy (uint16_t port_id, struct rte_flow_action_handle *handle, struct rte_flow_error *error) |
__rte_experimental int | rte_flow_action_handle_update (uint16_t port_id, struct rte_flow_action_handle *handle, const void *update, struct rte_flow_error *error) |
__rte_experimental int | rte_flow_action_handle_query (uint16_t port_id, const struct rte_flow_action_handle *handle, void *data, struct rte_flow_error *error) |
__rte_experimental int | rte_flow_tunnel_decap_set (uint16_t port_id, struct rte_flow_tunnel *tunnel, struct rte_flow_action **actions, uint32_t *num_of_actions, struct rte_flow_error *error) |
__rte_experimental int | rte_flow_tunnel_match (uint16_t port_id, struct rte_flow_tunnel *tunnel, struct rte_flow_item **items, uint32_t *num_of_items, struct rte_flow_error *error) |
__rte_experimental uint64_t | rte_flow_restore_info_dynflag (void) |
__rte_experimental int | rte_flow_get_restore_info (uint16_t port_id, struct rte_mbuf *m, struct rte_flow_restore_info *info, struct rte_flow_error *error) |
__rte_experimental int | rte_flow_tunnel_action_decap_release (uint16_t port_id, struct rte_flow_action *actions, uint32_t num_of_actions, struct rte_flow_error *error) |
__rte_experimental int | rte_flow_tunnel_item_release (uint16_t port_id, struct rte_flow_item *items, uint32_t num_of_items, struct rte_flow_error *error) |
int | rte_flow_pick_transfer_proxy (uint16_t port_id, uint16_t *proxy_port_id, struct rte_flow_error *error) |
__rte_experimental struct rte_flow_item_flex_handle * | rte_flow_flex_item_create (uint16_t port_id, const struct rte_flow_item_flex_conf *conf, struct rte_flow_error *error) |
__rte_experimental int | rte_flow_flex_item_release (uint16_t port_id, const struct rte_flow_item_flex_handle *handle, struct rte_flow_error *error) |
__rte_experimental int | rte_flow_info_get (uint16_t port_id, struct rte_flow_port_info *port_info, struct rte_flow_queue_info *queue_info, struct rte_flow_error *error) |
__rte_experimental int | rte_flow_configure (uint16_t port_id, const struct rte_flow_port_attr *port_attr, uint16_t nb_queue, const struct rte_flow_queue_attr *queue_attr[], struct rte_flow_error *error) |
__rte_experimental struct rte_flow_pattern_template * | rte_flow_pattern_template_create (uint16_t port_id, const struct rte_flow_pattern_template_attr *template_attr, const struct rte_flow_item pattern[], struct rte_flow_error *error) |
__rte_experimental int | rte_flow_pattern_template_destroy (uint16_t port_id, struct rte_flow_pattern_template *pattern_template, struct rte_flow_error *error) |
__rte_experimental struct rte_flow_actions_template * | rte_flow_actions_template_create (uint16_t port_id, const struct rte_flow_actions_template_attr *template_attr, const struct rte_flow_action actions[], const struct rte_flow_action masks[], struct rte_flow_error *error) |
__rte_experimental int | rte_flow_actions_template_destroy (uint16_t port_id, struct rte_flow_actions_template *actions_template, struct rte_flow_error *error) |
__rte_experimental struct rte_flow_template_table * | rte_flow_template_table_create (uint16_t port_id, const struct rte_flow_template_table_attr *table_attr, struct rte_flow_pattern_template *pattern_templates[], uint8_t nb_pattern_templates, struct rte_flow_actions_template *actions_templates[], uint8_t nb_actions_templates, struct rte_flow_error *error) |
__rte_experimental int | rte_flow_template_table_destroy (uint16_t port_id, struct rte_flow_template_table *template_table, struct rte_flow_error *error) |
__rte_experimental struct rte_flow * | rte_flow_async_create (uint16_t port_id, uint32_t queue_id, const struct rte_flow_op_attr *op_attr, struct rte_flow_template_table *template_table, const struct rte_flow_item pattern[], uint8_t pattern_template_index, const struct rte_flow_action actions[], uint8_t actions_template_index, void *user_data, struct rte_flow_error *error) |
__rte_experimental struct rte_flow * | rte_flow_async_create_by_index (uint16_t port_id, uint32_t queue_id, const struct rte_flow_op_attr *op_attr, struct rte_flow_template_table *template_table, uint32_t rule_index, const struct rte_flow_action actions[], uint8_t actions_template_index, void *user_data, struct rte_flow_error *error) |
__rte_experimental int | rte_flow_async_destroy (uint16_t port_id, uint32_t queue_id, const struct rte_flow_op_attr *op_attr, struct rte_flow *flow, void *user_data, struct rte_flow_error *error) |
__rte_experimental int | rte_flow_async_actions_update (uint16_t port_id, uint32_t queue_id, const struct rte_flow_op_attr *op_attr, struct rte_flow *flow, const struct rte_flow_action actions[], uint8_t actions_template_index, void *user_data, struct rte_flow_error *error) |
__rte_experimental int | rte_flow_push (uint16_t port_id, uint32_t queue_id, struct rte_flow_error *error) |
__rte_experimental int | rte_flow_pull (uint16_t port_id, uint32_t queue_id, struct rte_flow_op_result res[], uint16_t n_res, struct rte_flow_error *error) |
__rte_experimental struct rte_flow_action_handle * | rte_flow_async_action_handle_create (uint16_t port_id, uint32_t queue_id, const struct rte_flow_op_attr *op_attr, const struct rte_flow_indir_action_conf *indir_action_conf, const struct rte_flow_action *action, void *user_data, struct rte_flow_error *error) |
__rte_experimental int | rte_flow_async_action_handle_destroy (uint16_t port_id, uint32_t queue_id, const struct rte_flow_op_attr *op_attr, struct rte_flow_action_handle *action_handle, void *user_data, struct rte_flow_error *error) |
__rte_experimental int | rte_flow_async_action_handle_update (uint16_t port_id, uint32_t queue_id, const struct rte_flow_op_attr *op_attr, struct rte_flow_action_handle *action_handle, const void *update, void *user_data, struct rte_flow_error *error) |
__rte_experimental int | rte_flow_async_action_handle_query (uint16_t port_id, uint32_t queue_id, const struct rte_flow_op_attr *op_attr, const struct rte_flow_action_handle *action_handle, void *data, void *user_data, struct rte_flow_error *error) |
__rte_experimental int | rte_flow_action_handle_query_update (uint16_t port_id, struct rte_flow_action_handle *handle, const void *update, void *query, enum rte_flow_query_update_mode mode, struct rte_flow_error *error) |
__rte_experimental int | rte_flow_async_action_handle_query_update (uint16_t port_id, uint32_t queue_id, const struct rte_flow_op_attr *attr, struct rte_flow_action_handle *handle, const void *update, void *query, enum rte_flow_query_update_mode mode, void *user_data, struct rte_flow_error *error) |
__rte_experimental struct rte_flow_action_list_handle * | rte_flow_action_list_handle_create (uint16_t port_id, const struct rte_flow_indir_action_conf *conf, const struct rte_flow_action *actions, struct rte_flow_error *error) |
__rte_experimental struct rte_flow_action_list_handle * | rte_flow_async_action_list_handle_create (uint16_t port_id, uint32_t queue_id, const struct rte_flow_op_attr *attr, const struct rte_flow_indir_action_conf *conf, const struct rte_flow_action *actions, void *user_data, struct rte_flow_error *error) |
__rte_experimental int | rte_flow_action_list_handle_destroy (uint16_t port_id, struct rte_flow_action_list_handle *handle, struct rte_flow_error *error) |
__rte_experimental int | rte_flow_async_action_list_handle_destroy (uint16_t port_id, uint32_t queue_id, const struct rte_flow_op_attr *op_attr, struct rte_flow_action_list_handle *handle, void *user_data, struct rte_flow_error *error) |
__rte_experimental int | rte_flow_action_list_handle_query_update (uint16_t port_id, const struct rte_flow_action_list_handle *handle, const void **update, void **query, enum rte_flow_query_update_mode mode, struct rte_flow_error *error) |
__rte_experimental int | rte_flow_async_action_list_handle_query_update (uint16_t port_id, uint32_t queue_id, const struct rte_flow_op_attr *attr, const struct rte_flow_action_list_handle *handle, const void **update, void **query, enum rte_flow_query_update_mode mode, void *user_data, struct rte_flow_error *error) |
RTE generic flow API
This interface provides the ability to program packet matching and associated actions in hardware through flow rules.
Definition in file rte_flow.h.
#define RTE_FLOW_CONNTRACK_PKT_STATE_VALID RTE_BIT32(0) |
The packet is valid after conntrack checking.
Definition at line 1914 of file rte_flow.h.
#define RTE_FLOW_CONNTRACK_PKT_STATE_CHANGED RTE_BIT32(1) |
The state of the connection is changed.
Definition at line 1918 of file rte_flow.h.
#define RTE_FLOW_CONNTRACK_PKT_STATE_INVALID RTE_BIT32(2) |
Error is detected on this packet for this connection and an invalid state is set.
Definition at line 1923 of file rte_flow.h.
#define RTE_FLOW_CONNTRACK_PKT_STATE_DISABLED RTE_BIT32(3) |
The HW connection tracking module is disabled. It can be due to application command or an invalid state.
Definition at line 1928 of file rte_flow.h.
#define RTE_FLOW_CONNTRACK_PKT_STATE_BAD RTE_BIT32(4) |
The packet contains some bad field(s) and cannot continue with the conntrack module checking.
Definition at line 1933 of file rte_flow.h.
#define RTE_FLOW_RESTORE_INFO_TUNNEL RTE_BIT64(0) |
Indicate that the packet has a tunnel.
Definition at line 5034 of file rte_flow.h.
#define RTE_FLOW_RESTORE_INFO_ENCAPSULATED RTE_BIT64(1) |
Indicate that the packet has a non decapsulated tunnel header.
Definition at line 5039 of file rte_flow.h.
#define RTE_FLOW_RESTORE_INFO_GROUP_ID RTE_BIT64(2) |
Indicate that the packet has a group_id.
Definition at line 5044 of file rte_flow.h.
#define RTE_FLOW_PORT_FLAG_STRICT_QUEUE RTE_BIT32(0) |
Indicate all operations for a given flow rule will strictly happen on the same queue (create/destroy/query/update).
Definition at line 5289 of file rte_flow.h.
#define RTE_FLOW_PORT_FLAG_SHARE_INDIRECT RTE_BIT32(0) |
Indicate all steering objects should be created on contexts of the host port, providing indirect object sharing between ports.
Definition at line 5381 of file rte_flow.h.
#define RTE_FLOW_TABLE_SPECIALIZE_TRANSFER_WIRE_ORIG RTE_BIT32(0) |
Specialize table for transfer flows which come only from wire. It allows PMD not to allocate resources for non-wire originated traffic. This bit is not a matching criteria, just an optimization hint. Flow rules which match non-wire originated traffic will be missed if the hint is supported.
Definition at line 5687 of file rte_flow.h.
#define RTE_FLOW_TABLE_SPECIALIZE_TRANSFER_VPORT_ORIG RTE_BIT32(1) |
Specialize table for transfer flows which come only from vport (e.g. VF, SF). It allows PMD not to allocate resources for non-vport originated traffic. This bit is not a matching criteria, just an optimization hint. Flow rules which match non-vport originated traffic will be missed if the hint is supported.
Definition at line 5695 of file rte_flow.h.
enum rte_flow_item_type |
Matching pattern item types.
Pattern items fall in two categories:
See the description of individual types for more information. Those marked with [META] fall into the second category.
Enumerator | |
---|---|
RTE_FLOW_ITEM_TYPE_END | [META] End marker for item lists. Prevents further processing of items, thereby ending the pattern. No associated specification structure. |
RTE_FLOW_ITEM_TYPE_VOID | [META] Used as a placeholder for convenience. It is ignored and simply discarded by PMDs. No associated specification structure. |
RTE_FLOW_ITEM_TYPE_INVERT | [META] Inverted matching, i.e. process packets that do not match the pattern. No associated specification structure. |
RTE_FLOW_ITEM_TYPE_ANY | Matches any protocol in place of the current layer, a single ANY may also stand for several protocol layers. See struct rte_flow_item_any. |
RTE_FLOW_ITEM_TYPE_PORT_ID |
[META] Matches traffic originating from (ingress) or going to (egress) a given DPDK port ID. See struct rte_flow_item_port_id. |
RTE_FLOW_ITEM_TYPE_RAW | Matches a byte string of a given length at a given offset. See struct rte_flow_item_raw. |
RTE_FLOW_ITEM_TYPE_ETH | Matches an Ethernet header. See struct rte_flow_item_eth. |
RTE_FLOW_ITEM_TYPE_VLAN | Matches an 802.1Q/ad VLAN tag. See struct rte_flow_item_vlan. |
RTE_FLOW_ITEM_TYPE_IPV4 | Matches an IPv4 header. See struct rte_flow_item_ipv4. |
RTE_FLOW_ITEM_TYPE_IPV6 | Matches an IPv6 header. See struct rte_flow_item_ipv6. |
RTE_FLOW_ITEM_TYPE_ICMP | Matches an ICMP header. See struct rte_flow_item_icmp. |
RTE_FLOW_ITEM_TYPE_UDP | Matches a UDP header. See struct rte_flow_item_udp. |
RTE_FLOW_ITEM_TYPE_TCP | Matches a TCP header. See struct rte_flow_item_tcp. |
RTE_FLOW_ITEM_TYPE_SCTP | Matches a SCTP header. See struct rte_flow_item_sctp. |
RTE_FLOW_ITEM_TYPE_VXLAN | Matches a VXLAN header. See struct rte_flow_item_vxlan. |
RTE_FLOW_ITEM_TYPE_E_TAG | Matches a E_TAG header. See struct rte_flow_item_e_tag. |
RTE_FLOW_ITEM_TYPE_NVGRE | Matches a NVGRE header. See struct rte_flow_item_nvgre. |
RTE_FLOW_ITEM_TYPE_MPLS | Matches a MPLS header. See struct rte_flow_item_mpls. |
RTE_FLOW_ITEM_TYPE_GRE | Matches a GRE header. See struct rte_flow_item_gre. |
RTE_FLOW_ITEM_TYPE_FUZZY | [META] Fuzzy pattern match, expect faster than default. This is for device that support fuzzy matching option. Usually a fuzzy matching is fast but the cost is accuracy. See struct rte_flow_item_fuzzy. |
RTE_FLOW_ITEM_TYPE_GTP | Matches a GTP header. Configure flow for GTP packets. See struct rte_flow_item_gtp. |
RTE_FLOW_ITEM_TYPE_GTPC | Matches a GTP header. Configure flow for GTP-C packets. See struct rte_flow_item_gtp. |
RTE_FLOW_ITEM_TYPE_GTPU | Matches a GTP header. Configure flow for GTP-U packets. See struct rte_flow_item_gtp. |
RTE_FLOW_ITEM_TYPE_ESP | Matches a ESP header. See struct rte_flow_item_esp. |
RTE_FLOW_ITEM_TYPE_GENEVE | Matches a GENEVE header. See struct rte_flow_item_geneve. |
RTE_FLOW_ITEM_TYPE_VXLAN_GPE | Matches a VXLAN-GPE header. See struct rte_flow_item_vxlan_gpe. |
RTE_FLOW_ITEM_TYPE_ARP_ETH_IPV4 | Matches an ARP header for Ethernet/IPv4. See struct rte_flow_item_arp_eth_ipv4. |
RTE_FLOW_ITEM_TYPE_IPV6_EXT | Matches the presence of any IPv6 extension header. See struct rte_flow_item_ipv6_ext. |
RTE_FLOW_ITEM_TYPE_ICMP6 | Matches any ICMPv6 header. See struct rte_flow_item_icmp6. |
RTE_FLOW_ITEM_TYPE_ICMP6_ND_NS | Matches an ICMPv6 neighbor discovery solicitation. See struct rte_flow_item_icmp6_nd_ns. |
RTE_FLOW_ITEM_TYPE_ICMP6_ND_NA | Matches an ICMPv6 neighbor discovery advertisement. See struct rte_flow_item_icmp6_nd_na. |
RTE_FLOW_ITEM_TYPE_ICMP6_ND_OPT | Matches the presence of any ICMPv6 neighbor discovery option. See struct rte_flow_item_icmp6_nd_opt. |
RTE_FLOW_ITEM_TYPE_ICMP6_ND_OPT_SLA_ETH | Matches an ICMPv6 neighbor discovery source Ethernet link-layer address option. See struct rte_flow_item_icmp6_nd_opt_sla_eth. |
RTE_FLOW_ITEM_TYPE_ICMP6_ND_OPT_TLA_ETH | Matches an ICMPv6 neighbor discovery target Ethernet link-layer address option. See struct rte_flow_item_icmp6_nd_opt_tla_eth. |
RTE_FLOW_ITEM_TYPE_MARK | Matches specified mark field. See struct rte_flow_item_mark. |
RTE_FLOW_ITEM_TYPE_META | [META] Matches a metadata value. See struct rte_flow_item_meta. |
RTE_FLOW_ITEM_TYPE_GRE_KEY | Matches a GRE optional key field. The value should a big-endian 32bit integer. When this item present the K bit is implicitly matched as "1" in the default mask.
rte_be32_t * |
RTE_FLOW_ITEM_TYPE_GTP_PSC | Matches a GTP extension header: PDU session container. Configure flow for GTP packets with extension header type 0x85. See struct rte_flow_item_gtp_psc. |
RTE_FLOW_ITEM_TYPE_PPPOES | Matches a PPPoE header. Configure flow for PPPoE session packets. See struct rte_flow_item_pppoe. |
RTE_FLOW_ITEM_TYPE_PPPOED | Matches a PPPoE header. Configure flow for PPPoE discovery packets. See struct rte_flow_item_pppoe. |
RTE_FLOW_ITEM_TYPE_PPPOE_PROTO_ID | Matches a PPPoE optional proto_id field. It only applies to PPPoE session packets. See struct rte_flow_item_pppoe_proto_id. |
RTE_FLOW_ITEM_TYPE_NSH | Matches Network service header (NSH). See struct rte_flow_item_nsh. |
RTE_FLOW_ITEM_TYPE_IGMP | Matches Internet Group Management Protocol (IGMP). See struct rte_flow_item_igmp. |
RTE_FLOW_ITEM_TYPE_AH | Matches IP Authentication Header (AH). See struct rte_flow_item_ah. |
RTE_FLOW_ITEM_TYPE_HIGIG2 | Matches a HIGIG header. see struct rte_flow_item_higig2_hdr. |
RTE_FLOW_ITEM_TYPE_TAG | [META] Matches a tag value. See struct rte_flow_item_tag. |
RTE_FLOW_ITEM_TYPE_L2TPV3OIP | Matches a L2TPv3 over IP header. Configure flow for L2TPv3 over IP packets. See struct rte_flow_item_l2tpv3oip. |
RTE_FLOW_ITEM_TYPE_PFCP | Matches PFCP Header. See struct rte_flow_item_pfcp. |
RTE_FLOW_ITEM_TYPE_ECPRI | Matches eCPRI Header. Configure flow for eCPRI over ETH or UDP packets. See struct rte_flow_item_ecpri. |
RTE_FLOW_ITEM_TYPE_IPV6_FRAG_EXT | Matches the presence of IPv6 fragment extension header. See struct rte_flow_item_ipv6_frag_ext. |
RTE_FLOW_ITEM_TYPE_GENEVE_OPT | Matches Geneve Variable Length Option See struct rte_flow_item_geneve_opt |
RTE_FLOW_ITEM_TYPE_INTEGRITY | [META] Matches on packet integrity. For some devices application needs to enable integration checks in HW before using this item.
|
RTE_FLOW_ITEM_TYPE_CONNTRACK | [META] Matches conntrack state.
|
RTE_FLOW_ITEM_TYPE_PORT_REPRESENTOR | [META] Matches traffic entering the embedded switch from the given ethdev.
|
RTE_FLOW_ITEM_TYPE_REPRESENTED_PORT | [META] Matches traffic entering the embedded switch from the entity represented by the given ethdev.
|
RTE_FLOW_ITEM_TYPE_FLEX | Matches a configured set of fields at runtime calculated offsets over the generic network header with variable length and flexible pattern
|
RTE_FLOW_ITEM_TYPE_L2TPV2 | Matches L2TPv2 Header. See struct rte_flow_item_l2tpv2. |
RTE_FLOW_ITEM_TYPE_PPP | Matches PPP Header. See struct rte_flow_item_ppp. |
RTE_FLOW_ITEM_TYPE_GRE_OPTION | Matches GRE optional fields. See struct rte_flow_item_gre_opt. |
RTE_FLOW_ITEM_TYPE_MACSEC | Matches MACsec Ethernet Header. See struct rte_flow_item_macsec. |
RTE_FLOW_ITEM_TYPE_METER_COLOR | Matches Meter Color Marker. See struct rte_flow_item_meter_color. |
RTE_FLOW_ITEM_TYPE_IPV6_ROUTING_EXT | Matches the presence of IPv6 routing extension header.
|
RTE_FLOW_ITEM_TYPE_ICMP6_ECHO_REQUEST | Matches an ICMPv6 echo request.
|
RTE_FLOW_ITEM_TYPE_ICMP6_ECHO_REPLY | Matches an ICMPv6 echo reply.
|
RTE_FLOW_ITEM_TYPE_QUOTA | Match Quota state
|
RTE_FLOW_ITEM_TYPE_AGGR_AFFINITY | Matches on the aggregated port of the received packet. Used in case multiple ports are aggregated to the a DPDK port. First port is number 1.
|
RTE_FLOW_ITEM_TYPE_TX_QUEUE | Match Tx queue number. This is valid only for egress rules.
|
RTE_FLOW_ITEM_TYPE_IB_BTH | Matches an InfiniBand base transport header in RoCE packet.
|
Definition at line 148 of file rte_flow.h.
enum rte_flow_quota_state |
QUOTA state.
Enumerator | |
---|---|
RTE_FLOW_QUOTA_STATE_PASS | PASS quota state |
RTE_FLOW_QUOTA_STATE_BLOCK | BLOCK quota state |
Definition at line 701 of file rte_flow.h.
Field bit offset calculation mode.
Definition at line 2106 of file rte_flow.h.
Flex item field tunnel mode
Definition at line 2139 of file rte_flow.h.
enum rte_flow_action_type |
Action types.
Each possible action is represented by a type. An action can have an associated configuration object. Several actions combined in a list can be assigned to a flow rule and are performed in order.
They fall in three categories:
Flow rules being terminating by default, not specifying any action of the fate kind results in undefined behavior. This applies to both ingress and egress.
PASSTHRU, when supported, makes a flow rule non-terminating.
Enumerator | |
---|---|
RTE_FLOW_ACTION_TYPE_END | End marker for action lists. Prevents further processing of actions, thereby ending the list. No associated configuration structure. |
RTE_FLOW_ACTION_TYPE_VOID | Used as a placeholder for convenience. It is ignored and simply discarded by PMDs. No associated configuration structure. |
RTE_FLOW_ACTION_TYPE_PASSTHRU | Leaves traffic up for additional processing by subsequent flow rules; makes a flow rule non-terminating. No associated configuration structure. |
RTE_FLOW_ACTION_TYPE_JUMP | RTE_FLOW_ACTION_TYPE_JUMP Redirects packets to a group on the current device. See struct rte_flow_action_jump. |
RTE_FLOW_ACTION_TYPE_MARK | Attaches an integer value to packets and sets RTE_MBUF_F_RX_FDIR and RTE_MBUF_F_RX_FDIR_ID mbuf flags. See struct rte_flow_action_mark. One should negotiate mark delivery from the NIC to the PMD. |
RTE_FLOW_ACTION_TYPE_FLAG | Flags packets. Similar to MARK without a specific value; only sets the RTE_MBUF_F_RX_FDIR mbuf flag. No associated configuration structure. One should negotiate flag delivery from the NIC to the PMD. |
RTE_FLOW_ACTION_TYPE_QUEUE | Assigns packets to a given queue index. See struct rte_flow_action_queue. |
RTE_FLOW_ACTION_TYPE_DROP | Drops packets. PASSTHRU overrides this action if both are specified. No associated configuration structure. |
RTE_FLOW_ACTION_TYPE_COUNT | Enables counters for this flow rule. These counters can be retrieved and reset through rte_flow_query() or rte_flow_action_handle_query() if the action provided via handle, see struct rte_flow_query_count. See struct rte_flow_action_count. |
RTE_FLOW_ACTION_TYPE_RSS | Similar to QUEUE, except RSS is additionally performed on packets to spread them among several queues according to the provided parameters. See struct rte_flow_action_rss. |
RTE_FLOW_ACTION_TYPE_PF |
Directs matching traffic to the physical function (PF) of the current device. No associated configuration structure. |
RTE_FLOW_ACTION_TYPE_VF |
Directs matching traffic to a given virtual function of the current device. See struct rte_flow_action_vf. |
RTE_FLOW_ACTION_TYPE_PORT_ID |
Directs matching traffic to a given DPDK port ID. See struct rte_flow_action_port_id. |
RTE_FLOW_ACTION_TYPE_METER | Traffic metering and policing (MTR). See struct rte_flow_action_meter. See file rte_mtr.h for MTR object configuration. |
RTE_FLOW_ACTION_TYPE_SECURITY | Redirects packets to security engine of current device for security processing as specified by security session. See struct rte_flow_action_security. |
RTE_FLOW_ACTION_TYPE_OF_DEC_NW_TTL |
Implements OFPAT_DEC_NW_TTL ("decrement IP TTL") as defined by the OpenFlow Switch Specification. No associated configuration structure. |
RTE_FLOW_ACTION_TYPE_OF_POP_VLAN | Implements OFPAT_POP_VLAN ("pop the outer VLAN tag") as defined by the OpenFlow Switch Specification. No associated configuration structure. |
RTE_FLOW_ACTION_TYPE_OF_PUSH_VLAN | Implements OFPAT_PUSH_VLAN ("push a new VLAN tag") as defined by the OpenFlow Switch Specification. See struct rte_flow_action_of_push_vlan. |
RTE_FLOW_ACTION_TYPE_OF_SET_VLAN_VID | Implements OFPAT_SET_VLAN_VID ("set the 802.1q VLAN ID") as defined by the OpenFlow Switch Specification. See struct rte_flow_action_of_set_vlan_vid. |
RTE_FLOW_ACTION_TYPE_OF_SET_VLAN_PCP | Implements OFPAT_SET_LAN_PCP ("set the 802.1q priority") as defined by the OpenFlow Switch Specification. See struct rte_flow_action_of_set_vlan_pcp. |
RTE_FLOW_ACTION_TYPE_OF_POP_MPLS | Implements OFPAT_POP_MPLS ("pop the outer MPLS tag") as defined by the OpenFlow Switch Specification. See struct rte_flow_action_of_pop_mpls. |
RTE_FLOW_ACTION_TYPE_OF_PUSH_MPLS | Implements OFPAT_PUSH_MPLS ("push a new MPLS tag") as defined by the OpenFlow Switch Specification. See struct rte_flow_action_of_push_mpls. |
RTE_FLOW_ACTION_TYPE_VXLAN_ENCAP | Encapsulate flow in VXLAN tunnel as defined in rte_flow_action_vxlan_encap action structure. See struct rte_flow_action_vxlan_encap. |
RTE_FLOW_ACTION_TYPE_VXLAN_DECAP | Decapsulate outer most VXLAN tunnel from matched flow. If flow pattern does not define a valid VXLAN tunnel (as specified by RFC7348) then the PMD should return a RTE_FLOW_ERROR_TYPE_ACTION error. |
RTE_FLOW_ACTION_TYPE_NVGRE_ENCAP | Encapsulate flow in NVGRE tunnel defined in the rte_flow_action_nvgre_encap action structure. See struct rte_flow_action_nvgre_encap. |
RTE_FLOW_ACTION_TYPE_NVGRE_DECAP | Decapsulate outer most NVGRE tunnel from matched flow. If flow pattern does not define a valid NVGRE tunnel (as specified by RFC7637) then the PMD should return a RTE_FLOW_ERROR_TYPE_ACTION error. |
RTE_FLOW_ACTION_TYPE_RAW_ENCAP | Add outer header whose template is provided in its data buffer See struct rte_flow_action_raw_encap. |
RTE_FLOW_ACTION_TYPE_RAW_DECAP | Remove outer header whose template is provided in its data buffer. See struct rte_flow_action_raw_decap |
RTE_FLOW_ACTION_TYPE_SET_IPV4_SRC |
Modify IPv4 source address in the outermost IPv4 header. If flow pattern does not define a valid RTE_FLOW_ITEM_TYPE_IPV4, then the PMD should return a RTE_FLOW_ERROR_TYPE_ACTION error. See struct rte_flow_action_set_ipv4. |
RTE_FLOW_ACTION_TYPE_SET_IPV4_DST |
Modify IPv4 destination address in the outermost IPv4 header. If flow pattern does not define a valid RTE_FLOW_ITEM_TYPE_IPV4, then the PMD should return a RTE_FLOW_ERROR_TYPE_ACTION error. See struct rte_flow_action_set_ipv4. |
RTE_FLOW_ACTION_TYPE_SET_IPV6_SRC |
Modify IPv6 source address in the outermost IPv6 header. If flow pattern does not define a valid RTE_FLOW_ITEM_TYPE_IPV6, then the PMD should return a RTE_FLOW_ERROR_TYPE_ACTION error. See struct rte_flow_action_set_ipv6. |
RTE_FLOW_ACTION_TYPE_SET_IPV6_DST |
Modify IPv6 destination address in the outermost IPv6 header. If flow pattern does not define a valid RTE_FLOW_ITEM_TYPE_IPV6, then the PMD should return a RTE_FLOW_ERROR_TYPE_ACTION error. See struct rte_flow_action_set_ipv6. |
RTE_FLOW_ACTION_TYPE_SET_TP_SRC |
Modify source port number in the outermost TCP/UDP header. If flow pattern does not define a valid RTE_FLOW_ITEM_TYPE_TCP or RTE_FLOW_ITEM_TYPE_UDP, then the PMD should return a RTE_FLOW_ERROR_TYPE_ACTION error. See struct rte_flow_action_set_tp. |
RTE_FLOW_ACTION_TYPE_SET_TP_DST |
Modify destination port number in the outermost TCP/UDP header. If flow pattern does not define a valid RTE_FLOW_ITEM_TYPE_TCP or RTE_FLOW_ITEM_TYPE_UDP, then the PMD should return a RTE_FLOW_ERROR_TYPE_ACTION error. See struct rte_flow_action_set_tp. |
RTE_FLOW_ACTION_TYPE_MAC_SWAP | Swap the source and destination MAC addresses in the outermost Ethernet header. If flow pattern does not define a valid RTE_FLOW_ITEM_TYPE_ETH, then the PMD should return a RTE_FLOW_ERROR_TYPE_ACTION error. No associated configuration structure. |
RTE_FLOW_ACTION_TYPE_DEC_TTL |
Decrease TTL value directly No associated configuration structure. |
RTE_FLOW_ACTION_TYPE_SET_TTL |
Set TTL value See struct rte_flow_action_set_ttl |
RTE_FLOW_ACTION_TYPE_SET_MAC_SRC |
Set source MAC address from matched flow. If flow pattern does not define a valid RTE_FLOW_ITEM_TYPE_ETH, the PMD should return a RTE_FLOW_ERROR_TYPE_ACTION error. See struct rte_flow_action_set_mac. |
RTE_FLOW_ACTION_TYPE_SET_MAC_DST |
Set destination MAC address from matched flow. If flow pattern does not define a valid RTE_FLOW_ITEM_TYPE_ETH, the PMD should return a RTE_FLOW_ERROR_TYPE_ACTION error. See struct rte_flow_action_set_mac. |
RTE_FLOW_ACTION_TYPE_INC_TCP_SEQ |
Increase sequence number in the outermost TCP header. Action configuration specifies the value to increase TCP sequence number as a big-endian 32 bit integer.
rte_be32_t * Using this action on non-matching traffic will result in undefined behavior. |
RTE_FLOW_ACTION_TYPE_DEC_TCP_SEQ |
Decrease sequence number in the outermost TCP header. Action configuration specifies the value to decrease TCP sequence number as a big-endian 32 bit integer.
rte_be32_t * Using this action on non-matching traffic will result in undefined behavior. |
RTE_FLOW_ACTION_TYPE_INC_TCP_ACK |
Increase acknowledgment number in the outermost TCP header. Action configuration specifies the value to increase TCP acknowledgment number as a big-endian 32 bit integer.
rte_be32_t * Using this action on non-matching traffic will result in undefined behavior. |
RTE_FLOW_ACTION_TYPE_DEC_TCP_ACK |
Decrease acknowledgment number in the outermost TCP header. Action configuration specifies the value to decrease TCP acknowledgment number as a big-endian 32 bit integer.
rte_be32_t * Using this action on non-matching traffic will result in undefined behavior. |
RTE_FLOW_ACTION_TYPE_SET_TAG |
Set Tag. Tag is for internal flow usage only and is not delivered to the application. See struct rte_flow_action_set_tag. |
RTE_FLOW_ACTION_TYPE_SET_META |
Set metadata on ingress or egress path. See struct rte_flow_action_set_meta. |
RTE_FLOW_ACTION_TYPE_SET_IPV4_DSCP |
Modify IPv4 DSCP in the outermost IP header. If flow pattern does not define a valid RTE_FLOW_ITEM_TYPE_IPV4, then the PMD should return a RTE_FLOW_ERROR_TYPE_ACTION error. See struct rte_flow_action_set_dscp. |
RTE_FLOW_ACTION_TYPE_SET_IPV6_DSCP |
Modify IPv6 DSCP in the outermost IP header. If flow pattern does not define a valid RTE_FLOW_ITEM_TYPE_IPV6, then the PMD should return a RTE_FLOW_ERROR_TYPE_ACTION error. See struct rte_flow_action_set_dscp. |
RTE_FLOW_ACTION_TYPE_AGE | Report as aged flow if timeout passed without any matching on the flow. See struct rte_flow_action_age. See function rte_flow_get_q_aged_flows See function rte_flow_get_aged_flows see enum RTE_ETH_EVENT_FLOW_AGED See struct rte_flow_query_age See struct rte_flow_update_age |
RTE_FLOW_ACTION_TYPE_SAMPLE | The matching packets will be duplicated with specified ratio and applied with own set of actions with a fate action. See struct rte_flow_action_sample. |
RTE_FLOW_ACTION_TYPE_SHARED |
Describe action shared across multiple flow rules. Allow multiple rules reference the same action by handle (see struct rte_flow_shared_action). |
RTE_FLOW_ACTION_TYPE_MODIFY_FIELD | Modify a packet header field, tag, mark or metadata. Allow the modification of an arbitrary header field via set, add and sub operations or copying its content into tag, meta or mark for future processing. See struct rte_flow_action_modify_field. |
RTE_FLOW_ACTION_TYPE_INDIRECT | An action handle is referenced in a rule through an indirect action. The same action handle may be used in multiple rules for the same or different ethdev ports. |
RTE_FLOW_ACTION_TYPE_CONNTRACK | [META] Enable tracking a TCP connection state.
|
RTE_FLOW_ACTION_TYPE_METER_COLOR | Color the packet to reflect the meter color result. Set the meter color in the mbuf to the selected color. See struct rte_flow_action_meter_color. |
RTE_FLOW_ACTION_TYPE_PORT_REPRESENTOR | At embedded switch level, sends matching traffic to the given ethdev.
|
RTE_FLOW_ACTION_TYPE_REPRESENTED_PORT | At embedded switch level, send matching traffic to the entity represented by the given ethdev.
|
RTE_FLOW_ACTION_TYPE_METER_MARK | Traffic metering and marking (MTR).
|
RTE_FLOW_ACTION_TYPE_SEND_TO_KERNEL | Send packets to the kernel, without going to userspace at all. The packets will be received by the kernel driver sharing the same device as the DPDK port on which this action is configured. This action mostly suits bifurcated driver model. This is an ingress non-transfer action only. No associated configuration structure. |
RTE_FLOW_ACTION_TYPE_QUOTA | Apply the quota verdict (PASS or BLOCK) to a flow.
|
RTE_FLOW_ACTION_TYPE_SKIP_CMAN | Skip congestion management configuration. Using rte_eth_cman_config_set(), the application can configure ethdev Rx queue's congestion mechanism. This flow action allows to skip the congestion configuration applied to the given ethdev Rx queue. |
RTE_FLOW_ACTION_TYPE_IPV6_EXT_PUSH | RTE_FLOW_ACTION_TYPE_IPV6_EXT_PUSH Push IPv6 extension into IPv6 packet.
|
RTE_FLOW_ACTION_TYPE_IPV6_EXT_REMOVE | RTE_FLOW_ACTION_TYPE_IPV6_EXT_REMOVE Remove IPv6 extension from IPv6 packet whose type is provided in its configuration buffer.
|
RTE_FLOW_ACTION_TYPE_INDIRECT_LIST | Action handle to reference flow actions list.
|
Definition at line 2340 of file rte_flow.h.
enum rte_flow_quota_mode |
QUOTA operational mode.
Enumerator | |
---|---|
RTE_FLOW_QUOTA_MODE_PACKET | Count packets. |
RTE_FLOW_QUOTA_MODE_L2 | Count packet bytes starting from L2. |
RTE_FLOW_QUOTA_MODE_L3 | Count packet bytes starting from L3. |
Definition at line 3002 of file rte_flow.h.
Indirect QUOTA update operations.
Enumerator | |
---|---|
RTE_FLOW_UPDATE_QUOTA_SET | Set new quota value. |
RTE_FLOW_UPDATE_QUOTA_ADD | Increase quota value. |
Definition at line 3041 of file rte_flow.h.
Hash function types.
Definition at line 3197 of file rte_flow.h.
The state of a TCP connection.
Definition at line 3675 of file rte_flow.h.
The last passed TCP packet flags of a connection.
Definition at line 3693 of file rte_flow.h.
enum rte_flow_field_id |
Field IDs for MODIFY_FIELD action.
Definition at line 3845 of file rte_flow.h.
enum rte_flow_modify_op |
Operation types for MODIFY_FIELD action.
Enumerator | |
---|---|
RTE_FLOW_MODIFY_SET | Set a new value. |
RTE_FLOW_MODIFY_ADD | Add a value to a field. |
RTE_FLOW_MODIFY_SUB | Subtract a value from a field. |
Definition at line 3986 of file rte_flow.h.
enum rte_flow_error_type |
Verbose error types.
Most of them provide the type of the object referenced by struct rte_flow_error.cause.
Definition at line 4157 of file rte_flow.h.
enum rte_flow_conv_op |
Conversion operations for flow API objects.
Enumerator | |
---|---|
RTE_FLOW_CONV_OP_NONE | No operation to perform. rte_flow_conv() simply returns 0. |
RTE_FLOW_CONV_OP_ATTR | Convert attributes structure. This is a basic copy of an attributes structure.
|
RTE_FLOW_CONV_OP_ITEM | Convert a single item. Duplicates
|
RTE_FLOW_CONV_OP_ACTION | Convert a single action. Duplicates
|
RTE_FLOW_CONV_OP_PATTERN | Convert an entire pattern. Duplicates all pattern items at once with the same constraints as RTE_FLOW_CONV_OP_ITEM.
|
RTE_FLOW_CONV_OP_ACTIONS | Convert a list of actions. Duplicates the entire list of actions at once with the same constraints as RTE_FLOW_CONV_OP_ACTION.
|
RTE_FLOW_CONV_OP_RULE | Convert a complete flow rule description. Comprises attributes, pattern and actions together at once with the usual constraints.
|
RTE_FLOW_CONV_OP_ITEM_NAME | Convert item type to its name string. Writes a NUL-terminated string to
|
RTE_FLOW_CONV_OP_ACTION_NAME | Convert action type to its name string. Writes a NUL-terminated string to
|
RTE_FLOW_CONV_OP_ITEM_NAME_PTR | Convert item type to pointer to item name. Retrieves item name pointer from its type. The string itself is not copied; instead, a unique pointer to an internal static constant storage is written to
|
RTE_FLOW_CONV_OP_ACTION_NAME_PTR | Convert action type to pointer to action name. Retrieves action name pointer from its type. The string itself is not copied; instead, a unique pointer to an internal static constant storage is written to
|
Definition at line 4224 of file rte_flow.h.
Template table flow rules insertion type.
Enumerator | |
---|---|
RTE_FLOW_TABLE_INSERTION_TYPE_PATTERN | Pattern-based insertion. |
RTE_FLOW_TABLE_INSERTION_TYPE_INDEX | Index-based insertion. |
Definition at line 5704 of file rte_flow.h.
Template table hash index calculation function.
Definition at line 5721 of file rte_flow.h.
enum rte_flow_op_status |
Asynchronous operation status.
Enumerator | |
---|---|
RTE_FLOW_OP_SUCCESS | The operation was completed successfully. |
RTE_FLOW_OP_ERROR | The operation was not completed successfully. |
Definition at line 6059 of file rte_flow.h.
Query and update operational mode.
Enumerator | |
---|---|
RTE_FLOW_QU_QUERY_FIRST | Query before update. |
RTE_FLOW_QU_UPDATE_FIRST | Query after update. |
Definition at line 6284 of file rte_flow.h.
__rte_experimental int rte_flow_dev_dump | ( | uint16_t | port_id, |
struct rte_flow * | flow, | ||
FILE * | file, | ||
struct rte_flow_error * | error | ||
) |
Dump hardware internal representation information of rte flow to file.
[in] | port_id | The port identifier of the Ethernet device. |
[in] | flow | The pointer of flow rule to dump. Dump all rules if NULL. |
[in] | file | A pointer to a file for output. |
[out] | error | Perform verbose error reporting if not NULL. PMDs initialize this structure in case of error only. |
|
inlinestatic |
Check if mbuf dynamic field for metadata is registered.
Definition at line 4396 of file rte_flow.h.
__rte_experimental int rte_flow_dynf_metadata_register | ( | void | ) |
Register mbuf dynamic field and flag for metadata.
This function must be called prior to use SET_META action in order to register the dynamic mbuf field. Otherwise, the data cannot be delivered to application.
int rte_flow_validate | ( | uint16_t | port_id, |
const struct rte_flow_attr * | attr, | ||
const struct rte_flow_item | pattern[], | ||
const struct rte_flow_action | actions[], | ||
struct rte_flow_error * | error | ||
) |
Check whether a flow rule can be created on a given port.
The flow rule is validated for correctness and whether it could be accepted by the device given sufficient resources. The rule is checked against the current device mode and queue configuration. The flow rule may also optionally be validated against existing flow rules and device resources. This function has no effect on the target device.
The returned value is guaranteed to remain valid only as long as no successful calls to rte_flow_create() or rte_flow_destroy() are made in the meantime and no device parameter affecting flow rules in any way are modified, due to possible collisions or resource limitations (although in such cases EINVAL should not be returned).
port_id | Port identifier of Ethernet device. | |
[in] | attr | Flow rule attributes. |
[in] | pattern | Pattern specification (list terminated by the END pattern item). |
[in] | actions | Associated actions (list terminated by the END action). |
[out] | error | Perform verbose error reporting if not NULL. PMDs initialize this structure in case of error only. |
-ENOSYS: underlying device does not support this functionality.
-EIO: underlying device is removed.
-EINVAL: unknown or invalid rule specification.
-ENOTSUP: valid but unsupported rule specification (e.g. partial bit-masks are unsupported).
-EEXIST: collision with an existing rule. Only returned if device supports flow rule collision checking and there was a flow rule collision. Not receiving this return code is no guarantee that creating the rule will not fail due to a collision.
-ENOMEM: not enough memory to execute the function, or if the device supports resource validation, resource limitation on the device.
-EBUSY: action cannot be performed due to busy device resources, may succeed if the affected queues or even the entire port are in a stopped state (see rte_eth_dev_rx_queue_stop() and rte_eth_dev_stop()).
struct rte_flow* rte_flow_create | ( | uint16_t | port_id, |
const struct rte_flow_attr * | attr, | ||
const struct rte_flow_item | pattern[], | ||
const struct rte_flow_action | actions[], | ||
struct rte_flow_error * | error | ||
) |
Create a flow rule on a given port.
port_id | Port identifier of Ethernet device. | |
[in] | attr | Flow rule attributes. |
[in] | pattern | Pattern specification (list terminated by the END pattern item). |
[in] | actions | Associated actions (list terminated by the END action). |
[out] | error | Perform verbose error reporting if not NULL. PMDs initialize this structure in case of error only. |
int rte_flow_destroy | ( | uint16_t | port_id, |
struct rte_flow * | flow, | ||
struct rte_flow_error * | error | ||
) |
Destroy a flow rule on a given port.
Failure to destroy a flow rule handle may occur when other flow rules depend on it, and destroying it would result in an inconsistent state.
This function is only guaranteed to succeed if handles are destroyed in reverse order of their creation.
port_id | Port identifier of Ethernet device. | |
flow | Flow rule handle to destroy. | |
[out] | error | Perform verbose error reporting if not NULL. PMDs initialize this structure in case of error only. |
__rte_experimental int rte_flow_actions_update | ( | uint16_t | port_id, |
struct rte_flow * | flow, | ||
const struct rte_flow_action | actions[], | ||
struct rte_flow_error * | error | ||
) |
Update a flow rule with new actions on a given port.
port_id | Port identifier of Ethernet device. | |
flow | Flow rule handle to update. | |
[in] | actions | Associated actions (list terminated by the END action). |
[out] | error | Perform verbose error reporting if not NULL. PMDs initialize this structure in case of error only. |
int rte_flow_flush | ( | uint16_t | port_id, |
struct rte_flow_error * | error | ||
) |
Destroy all flow rules associated with a port.
In the unlikely event of failure, handles are still considered destroyed and no longer valid but the port must be assumed to be in an inconsistent state.
port_id | Port identifier of Ethernet device. | |
[out] | error | Perform verbose error reporting if not NULL. PMDs initialize this structure in case of error only. |
int rte_flow_query | ( | uint16_t | port_id, |
struct rte_flow * | flow, | ||
const struct rte_flow_action * | action, | ||
void * | data, | ||
struct rte_flow_error * | error | ||
) |
Query an existing flow rule.
This function allows retrieving flow-specific data such as counters. Data is gathered by special actions which must be present in the flow rule definition.
port_id | Port identifier of Ethernet device. | |
flow | Flow rule handle to query. | |
action | Action definition as defined in original flow rule. | |
[in,out] | data | Pointer to storage for the associated query data type. |
[out] | error | Perform verbose error reporting if not NULL. PMDs initialize this structure in case of error only. |
int rte_flow_isolate | ( | uint16_t | port_id, |
int | set, | ||
struct rte_flow_error * | error | ||
) |
Restrict ingress traffic to the defined flow rules.
Isolated mode guarantees that all ingress traffic comes from defined flow rules only (current and future). When enabled with a bifurcated driver, non-matched packets are routed to the kernel driver interface. When disabled (the default), there may be some default rules routing traffic to the DPDK port.
Besides making ingress more deterministic, it allows PMDs to safely reuse resources otherwise assigned to handle the remaining traffic, such as global RSS configuration settings, VLAN filters, MAC address entries, legacy filter API rules and so on in order to expand the set of possible flow rule types.
Calling this function as soon as possible after device initialization, ideally before the first call to rte_eth_dev_configure(), is recommended to avoid possible failures due to conflicting settings.
Once effective, leaving isolated mode may not be possible depending on PMD implementation.
Additionally, the following functionality has no effect on the underlying port and may return errors such as ENOTSUP ("not supported"):
port_id | Port identifier of Ethernet device. | |
set | Nonzero to enter isolated mode, attempt to leave it otherwise. | |
[out] | error | Perform verbose error reporting if not NULL. PMDs initialize this structure in case of error only. |
int rte_flow_error_set | ( | struct rte_flow_error * | error, |
int | code, | ||
enum rte_flow_error_type | type, | ||
const void * | cause, | ||
const char * | message | ||
) |
Initialize flow error structure.
[out] | error | Pointer to flow error structure (may be NULL). |
code | Related error code (rte_errno). | |
type | Cause field and error types. | |
cause | Object responsible for the error. | |
message | Human-readable error message. |
__rte_deprecated size_t rte_flow_copy | ( | struct rte_flow_desc * | fd, |
size_t | len, | ||
const struct rte_flow_attr * | attr, | ||
const struct rte_flow_item * | items, | ||
const struct rte_flow_action * | actions | ||
) |
This interface is kept for compatibility with older applications but is implemented as a wrapper to rte_flow_conv(). It is deprecated due to its lack of flexibility and reliance on a type unusable with C++ programs (struct rte_flow_desc).
[in] | fd | Flow rule description. |
[in] | len | Total size of allocated data for the flow description. |
[in] | attr | Flow rule attributes. |
[in] | items | Pattern specification (list terminated by the END pattern item). |
[in] | actions | Associated actions (list terminated by the END action). |
__rte_experimental int rte_flow_conv | ( | enum rte_flow_conv_op | op, |
void * | dst, | ||
size_t | size, | ||
const void * | src, | ||
struct rte_flow_error * | error | ||
) |
Flow object conversion helper.
This function performs conversion of various flow API objects to a pre-allocated destination buffer. See enum rte_flow_conv_op for possible operations and details about each of them.
Since destination buffer must be large enough, it works in a manner reminiscent of snprintf():
size
is 0, dst
may be a NULL pointer, otherwise dst
must be non-NULL.src
to dst
according to op
regardless of the size
parameter.size
bytes can be written to dst
, output is truncated and may be inconsistent when the returned value is larger than that.dst
contents are unspecified.op | Operation to perform, related to the object type of dst . | |
[out] | dst | Destination buffer address. Must be suitably aligned by the caller. |
size | Destination buffer size in bytes. | |
[in] | src | Source object to copy. Depending on op , its type may differ from that of dst . |
[out] | error | Perform verbose error reporting if not NULL. Initialized in case of error only. |
src
to dst
on success, a negative errno value otherwise and rte_errno is set.__rte_experimental int rte_flow_get_aged_flows | ( | uint16_t | port_id, |
void ** | contexts, | ||
uint32_t | nb_contexts, | ||
struct rte_flow_error * | error | ||
) |
Get aged-out flows of a given port.
RTE_ETH_EVENT_FLOW_AGED event will be triggered when at least one new aged out flow was detected after the last call to rte_flow_get_aged_flows. This function can be called to get the aged flows asynchronously from the event callback or synchronously regardless the event. This is not safe to call rte_flow_get_aged_flows function with other flow functions from multiple threads simultaneously.
port_id | Port identifier of Ethernet device. | |
[in,out] | contexts | The address of an array of pointers to the aged-out flows contexts. |
[in] | nb_contexts | The length of context array pointers. |
[out] | error | Perform verbose error reporting if not NULL. Initialized in case of error only. |
__rte_experimental int rte_flow_get_q_aged_flows | ( | uint16_t | port_id, |
uint32_t | queue_id, | ||
void ** | contexts, | ||
uint32_t | nb_contexts, | ||
struct rte_flow_error * | error | ||
) |
Get aged-out flows of a given port on the given flow queue.
If application configure port attribute with RTE_FLOW_PORT_FLAG_STRICT_QUEUE, there is no RTE_ETH_EVENT_FLOW_AGED event and this function must be called to get the aged flows synchronously.
If application configure port attribute without RTE_FLOW_PORT_FLAG_STRICT_QUEUE, RTE_ETH_EVENT_FLOW_AGED event will be triggered at least one new aged out flow was detected on any flow queue after the last call to rte_flow_get_q_aged_flows. In addition, the queue_id
will be ignored. This function can be called to get the aged flows asynchronously from the event callback or synchronously regardless the event.
[in] | port_id | Port identifier of Ethernet device. |
[in] | queue_id | Flow queue to query. Ignored when RTE_FLOW_PORT_FLAG_STRICT_QUEUE not set. |
[in,out] | contexts | The address of an array of pointers to the aged-out flows contexts. |
[in] | nb_contexts | The length of context array pointers. |
[out] | error | Perform verbose error reporting if not NULL. Initialized in case of error only. |
__rte_experimental struct rte_flow_action_handle* rte_flow_action_handle_create | ( | uint16_t | port_id, |
const struct rte_flow_indir_action_conf * | conf, | ||
const struct rte_flow_action * | action, | ||
struct rte_flow_error * | error | ||
) |
Create an indirect action object that can be used in flow rules via its handle. The created object handle has single state and configuration across all the flow rules using it.
[in] | port_id | The port identifier of the Ethernet device. |
[in] | conf | Action configuration for the indirect action object creation. |
[in] | action | Specific configuration of the indirect action object. |
[out] | error | Perform verbose error reporting if not NULL. PMDs initialize this structure in case of error only. |
__rte_experimental int rte_flow_action_handle_destroy | ( | uint16_t | port_id, |
struct rte_flow_action_handle * | handle, | ||
struct rte_flow_error * | error | ||
) |
Destroy indirect action by handle.
[in] | port_id | The port identifier of the Ethernet device. |
[in] | handle | Handle for the indirect action object to be destroyed. |
[out] | error | Perform verbose error reporting if not NULL. PMDs initialize this structure in case of error only. |
__rte_experimental int rte_flow_action_handle_update | ( | uint16_t | port_id, |
struct rte_flow_action_handle * | handle, | ||
const void * | update, | ||
struct rte_flow_error * | error | ||
) |
Update in-place the action configuration and / or state pointed by action handle with the configuration provided as update argument. The update of the action configuration effects all flow rules reusing the action via handle. The update general pointer provides the ability of partial updating.
[in] | port_id | The port identifier of the Ethernet device. |
[in] | handle | Handle for the indirect action object to be updated. |
[in] | update | Update profile specification used to modify the action pointed by handle. update could be with the same type of the immediate action corresponding to the handle argument when creating, or a wrapper structure includes action configuration to be updated and bit fields to indicate the member of fields inside the action to update. |
[out] | error | Perform verbose error reporting if not NULL. PMDs initialize this structure in case of error only. |
__rte_experimental int rte_flow_action_handle_query | ( | uint16_t | port_id, |
const struct rte_flow_action_handle * | handle, | ||
void * | data, | ||
struct rte_flow_error * | error | ||
) |
Query the direct action by corresponding indirect action object handle.
Retrieve action-specific data such as counters. Data is gathered by special action which may be present/referenced in more than one flow rule definition.
port_id | Port identifier of Ethernet device. | |
[in] | handle | Handle for the action object to query. |
[in,out] | data | Pointer to storage for the associated query data type. |
[out] | error | Perform verbose error reporting if not NULL. PMDs initialize this structure in case of error only. |
__rte_experimental int rte_flow_tunnel_decap_set | ( | uint16_t | port_id, |
struct rte_flow_tunnel * | tunnel, | ||
struct rte_flow_action ** | actions, | ||
uint32_t * | num_of_actions, | ||
struct rte_flow_error * | error | ||
) |
Allocate an array of actions to be used in rte_flow_create, to implement tunnel-decap-set for the given tunnel. Sample usage: actions vxlan_decap / tunnel-decap-set(tunnel properties) / jump group 0 / end
port_id | Port identifier of Ethernet device. | |
[in] | tunnel | Tunnel properties. |
[out] | actions | Array of actions to be allocated by the PMD. This array should be concatenated with the actions array provided to rte_flow_create. |
[out] | num_of_actions | Number of actions allocated. |
[out] | error | Perform verbose error reporting if not NULL. PMDs initialize this structure in case of error only. |
__rte_experimental int rte_flow_tunnel_match | ( | uint16_t | port_id, |
struct rte_flow_tunnel * | tunnel, | ||
struct rte_flow_item ** | items, | ||
uint32_t * | num_of_items, | ||
struct rte_flow_error * | error | ||
) |
Allocate an array of items to be used in rte_flow_create, to implement tunnel-match for the given tunnel. Sample usage: pattern tunnel-match(tunnel properties) / outer-header-matches / inner-header-matches / end
port_id | Port identifier of Ethernet device. | |
[in] | tunnel | Tunnel properties. |
[out] | items | Array of items to be allocated by the PMD. This array should be concatenated with the items array provided to rte_flow_create. |
[out] | num_of_items | Number of items allocated. |
[out] | error | Perform verbose error reporting if not NULL. PMDs initialize this structure in case of error only. |
__rte_experimental uint64_t rte_flow_restore_info_dynflag | ( | void | ) |
On reception of a mbuf from HW, a call to rte_flow_get_restore_info() may be required to retrieve some metadata. This function returns the associated mbuf ol_flags.
Note: the dynamic flag is registered during a call to rte_eth_rx_metadata_negotiate() with RTE_ETH_RX_METADATA_TUNNEL_ID.
__rte_experimental int rte_flow_get_restore_info | ( | uint16_t | port_id, |
struct rte_mbuf * | m, | ||
struct rte_flow_restore_info * | info, | ||
struct rte_flow_error * | error | ||
) |
If a mbuf contains the rte_flow_restore_info_dynflag() flag in ol_flags, populate the current packet processing state.
One should negotiate tunnel metadata delivery from the NIC to the HW.
port_id | Port identifier of Ethernet device. | |
[in] | m | Mbuf struct. |
[out] | info | Restore information. Upon success contains the HW state. |
[out] | error | Perform verbose error reporting if not NULL. PMDs initialize this structure in case of error only. |
__rte_experimental int rte_flow_tunnel_action_decap_release | ( | uint16_t | port_id, |
struct rte_flow_action * | actions, | ||
uint32_t | num_of_actions, | ||
struct rte_flow_error * | error | ||
) |
Release the action array as allocated by rte_flow_tunnel_decap_set.
port_id | Port identifier of Ethernet device. | |
[in] | actions | Array of actions to be released. |
[in] | num_of_actions | Number of elements in actions array. |
[out] | error | Perform verbose error reporting if not NULL. PMDs initialize this structure in case of error only. |
__rte_experimental int rte_flow_tunnel_item_release | ( | uint16_t | port_id, |
struct rte_flow_item * | items, | ||
uint32_t | num_of_items, | ||
struct rte_flow_error * | error | ||
) |
Release the item array as allocated by rte_flow_tunnel_match.
port_id | Port identifier of Ethernet device. | |
[in] | items | Array of items to be released. |
[in] | num_of_items | Number of elements in item array. |
[out] | error | Perform verbose error reporting if not NULL. PMDs initialize this structure in case of error only. |
int rte_flow_pick_transfer_proxy | ( | uint16_t | port_id, |
uint16_t * | proxy_port_id, | ||
struct rte_flow_error * | error | ||
) |
Get a proxy port to manage "transfer" flows.
Managing "transfer" flows requires that the user communicate them via a port which has the privilege to control the embedded switch. For some vendors, all ports in a given switching domain have this privilege. For other vendors, it's only one port.
This API indicates such a privileged port (a "proxy") for a given port in the same switching domain.
port_id
doesn't have the corresponding method implemented, the API will return port_id
via proxy_port_id
.port_id | Indicates the port to get a "proxy" for | |
[out] | proxy_port_id | Indicates the "proxy" port |
[out] | error | If not NULL, allows the PMD to provide verbose report in case of error |
__rte_experimental struct rte_flow_item_flex_handle* rte_flow_flex_item_create | ( | uint16_t | port_id, |
const struct rte_flow_item_flex_conf * | conf, | ||
struct rte_flow_error * | error | ||
) |
Create the flex item with specified configuration over the Ethernet device.
port_id | Port identifier of Ethernet device. | |
[in] | conf | Item configuration. |
[out] | error | Perform verbose error reporting if not NULL. PMDs initialize this structure in case of error only. |
__rte_experimental int rte_flow_flex_item_release | ( | uint16_t | port_id, |
const struct rte_flow_item_flex_handle * | handle, | ||
struct rte_flow_error * | error | ||
) |
Release the flex item on the specified Ethernet device.
port_id | Port identifier of Ethernet device. | |
[in] | handle | Handle of the item existing on the specified device. |
[out] | error | Perform verbose error reporting if not NULL. PMDs initialize this structure in case of error only. |
__rte_experimental int rte_flow_info_get | ( | uint16_t | port_id, |
struct rte_flow_port_info * | port_info, | ||
struct rte_flow_queue_info * | queue_info, | ||
struct rte_flow_error * | error | ||
) |
Get information about flow engine resources.
port_id | Port identifier of Ethernet device. | |
[out] | port_info | A pointer to a structure of type rte_flow_port_info to be filled with the resources information of the port. |
[out] | queue_info | A pointer to a structure of type rte_flow_queue_info to be filled with the asynchronous queues information. |
[out] | error | Perform verbose error reporting if not NULL. PMDs initialize this structure in case of error only. |
__rte_experimental int rte_flow_configure | ( | uint16_t | port_id, |
const struct rte_flow_port_attr * | port_attr, | ||
uint16_t | nb_queue, | ||
const struct rte_flow_queue_attr * | queue_attr[], | ||
struct rte_flow_error * | error | ||
) |
Configure the port's flow API engine.
This API can only be invoked before the application starts using the rest of the flow library functions.
The API can be invoked multiple times to change the settings. The port, however, may reject changes and keep the old config.
Parameters in configuration attributes must not exceed numbers of resources returned by the rte_flow_info_get API.
port_id | Port identifier of Ethernet device. | |
[in] | port_attr | Port configuration attributes. |
[in] | nb_queue | Number of flow queues to be configured. |
[in] | queue_attr | Array that holds attributes for each flow queue. Number of elements is set in port_attr.nb_queues . |
[out] | error | Perform verbose error reporting if not NULL. PMDs initialize this structure in case of error only. |
__rte_experimental struct rte_flow_pattern_template* rte_flow_pattern_template_create | ( | uint16_t | port_id, |
const struct rte_flow_pattern_template_attr * | template_attr, | ||
const struct rte_flow_item | pattern[], | ||
struct rte_flow_error * | error | ||
) |
Create flow pattern template.
The pattern template defines common matching fields without values. For example, matching on 5 tuple TCP flow, the template will be eth(null) + IPv4(source + dest) + TCP(s_port + d_port), while values for each rule will be set during the flow rule creation. The number and order of items in the template must be the same at the rule creation.
port_id | Port identifier of Ethernet device. | |
[in] | template_attr | Pattern template attributes. |
[in] | pattern | Pattern specification (list terminated by the END pattern item). The spec member of an item is not used unless the end member is used. |
[out] | error | Perform verbose error reporting if not NULL. PMDs initialize this structure in case of error only. |
__rte_experimental int rte_flow_pattern_template_destroy | ( | uint16_t | port_id, |
struct rte_flow_pattern_template * | pattern_template, | ||
struct rte_flow_error * | error | ||
) |
Destroy flow pattern template.
This function may be called only when there are no more tables referencing this template.
port_id | Port identifier of Ethernet device. | |
[in] | pattern_template | Handle of the template to be destroyed. |
[out] | error | Perform verbose error reporting if not NULL. PMDs initialize this structure in case of error only. |
__rte_experimental struct rte_flow_actions_template* rte_flow_actions_template_create | ( | uint16_t | port_id, |
const struct rte_flow_actions_template_attr * | template_attr, | ||
const struct rte_flow_action | actions[], | ||
const struct rte_flow_action | masks[], | ||
struct rte_flow_error * | error | ||
) |
Create flow actions template.
The actions template holds a list of action types without values. For example, the template to change TCP ports is TCP(s_port + d_port), while values for each rule will be set during the flow rule creation. The number and order of actions in the template must be the same at the rule creation.
port_id | Port identifier of Ethernet device. | |
[in] | template_attr | Template attributes. |
[in] | actions | Associated actions (list terminated by the END action). The spec member is only used if masks spec is non-zero. |
[in] | masks | List of actions that marks which of the action's member is constant. A mask has the same format as the corresponding action. If the action field in masks is not 0, the corresponding value in an action from actions will be the part of the template and used in all flow rules. The order of actions in masks is the same as in actions . In case of indirect actions present in actions , the actual action type should be present in mask . |
[out] | error | Perform verbose error reporting if not NULL. PMDs initialize this structure in case of error only. |
__rte_experimental int rte_flow_actions_template_destroy | ( | uint16_t | port_id, |
struct rte_flow_actions_template * | actions_template, | ||
struct rte_flow_error * | error | ||
) |
Destroy flow actions template.
This function may be called only when there are no more tables referencing this template.
port_id | Port identifier of Ethernet device. | |
[in] | actions_template | Handle to the template to be destroyed. |
[out] | error | Perform verbose error reporting if not NULL. PMDs initialize this structure in case of error only. |
__rte_experimental struct rte_flow_template_table* rte_flow_template_table_create | ( | uint16_t | port_id, |
const struct rte_flow_template_table_attr * | table_attr, | ||
struct rte_flow_pattern_template * | pattern_templates[], | ||
uint8_t | nb_pattern_templates, | ||
struct rte_flow_actions_template * | actions_templates[], | ||
uint8_t | nb_actions_templates, | ||
struct rte_flow_error * | error | ||
) |
Create flow template table.
A template table consists of multiple pattern templates and actions templates associated with a single set of rule attributes (group ID, priority and traffic direction).
Each rule is free to use any combination of pattern and actions templates and specify particular values for items and actions it would like to change.
port_id | Port identifier of Ethernet device. | |
[in] | table_attr | Template table attributes. |
[in] | pattern_templates | Array of pattern templates to be used in this table. |
[in] | nb_pattern_templates | The number of pattern templates in the pattern_templates array. |
[in] | actions_templates | Array of actions templates to be used in this table. |
[in] | nb_actions_templates | The number of actions templates in the actions_templates array. |
[out] | error | Perform verbose error reporting if not NULL. PMDs initialize this structure in case of error only. |
__rte_experimental int rte_flow_template_table_destroy | ( | uint16_t | port_id, |
struct rte_flow_template_table * | template_table, | ||
struct rte_flow_error * | error | ||
) |
Destroy flow template table.
This function may be called only when there are no more flow rules referencing this table.
port_id | Port identifier of Ethernet device. | |
[in] | template_table | Handle to the table to be destroyed. |
[out] | error | Perform verbose error reporting if not NULL. PMDs initialize this structure in case of error only. |
__rte_experimental struct rte_flow* rte_flow_async_create | ( | uint16_t | port_id, |
uint32_t | queue_id, | ||
const struct rte_flow_op_attr * | op_attr, | ||
struct rte_flow_template_table * | template_table, | ||
const struct rte_flow_item | pattern[], | ||
uint8_t | pattern_template_index, | ||
const struct rte_flow_action | actions[], | ||
uint8_t | actions_template_index, | ||
void * | user_data, | ||
struct rte_flow_error * | error | ||
) |
Enqueue rule creation operation.
port_id | Port identifier of Ethernet device. | |
queue_id | Flow queue used to insert the rule. | |
[in] | op_attr | Rule creation operation attributes. |
[in] | template_table | Template table to select templates from. |
[in] | pattern | List of pattern items to be used. The list order should match the order in the pattern template. The spec is the only relevant member of the item that is being used. |
[in] | pattern_template_index | Pattern template index in the table. |
[in] | actions | List of actions to be used. The list order should match the order in the actions template. |
[in] | actions_template_index | Actions template index in the table. |
[in] | user_data | The user data that will be returned on the completion events. |
[out] | error | Perform verbose error reporting if not NULL. PMDs initialize this structure in case of error only. |
__rte_experimental struct rte_flow* rte_flow_async_create_by_index | ( | uint16_t | port_id, |
uint32_t | queue_id, | ||
const struct rte_flow_op_attr * | op_attr, | ||
struct rte_flow_template_table * | template_table, | ||
uint32_t | rule_index, | ||
const struct rte_flow_action | actions[], | ||
uint8_t | actions_template_index, | ||
void * | user_data, | ||
struct rte_flow_error * | error | ||
) |
Enqueue rule creation operation.
port_id | Port identifier of Ethernet device. | |
queue_id | Flow queue used to insert the rule. | |
[in] | op_attr | Rule creation operation attributes. |
[in] | template_table | Template table to select templates from. |
[in] | rule_index | Rule index in the table. |
[in] | actions | List of actions to be used. The list order should match the order in the actions template. |
[in] | actions_template_index | Actions template index in the table. |
[in] | user_data | The user data that will be returned on the completion events. |
[out] | error | Perform verbose error reporting if not NULL. PMDs initialize this structure in case of error only. |
__rte_experimental int rte_flow_async_destroy | ( | uint16_t | port_id, |
uint32_t | queue_id, | ||
const struct rte_flow_op_attr * | op_attr, | ||
struct rte_flow * | flow, | ||
void * | user_data, | ||
struct rte_flow_error * | error | ||
) |
Enqueue rule destruction operation.
This function enqueues a destruction operation on the queue. Application should assume that after calling this function the rule handle is not valid anymore. Completion indicates the full removal of the rule from the HW.
port_id | Port identifier of Ethernet device. | |
queue_id | Flow queue which is used to destroy the rule. This must match the queue on which the rule was created. | |
[in] | op_attr | Rule destruction operation attributes. |
[in] | flow | Flow handle to be destroyed. |
[in] | user_data | The user data that will be returned on the completion events. |
[out] | error | Perform verbose error reporting if not NULL. PMDs initialize this structure in case of error only. |
__rte_experimental int rte_flow_async_actions_update | ( | uint16_t | port_id, |
uint32_t | queue_id, | ||
const struct rte_flow_op_attr * | op_attr, | ||
struct rte_flow * | flow, | ||
const struct rte_flow_action | actions[], | ||
uint8_t | actions_template_index, | ||
void * | user_data, | ||
struct rte_flow_error * | error | ||
) |
Enqueue rule update operation.
port_id | Port identifier of Ethernet device. | |
queue_id | Flow queue used to insert the rule. | |
[in] | op_attr | Rule creation operation attributes. |
[in] | flow | Flow rule to be updated. |
[in] | actions | List of actions to be used. The list order should match the order in the actions template. |
[in] | actions_template_index | Actions template index in the table. |
[in] | user_data | The user data that will be returned on the completion events. |
[out] | error | Perform verbose error reporting if not NULL. PMDs initialize this structure in case of error only. |
__rte_experimental int rte_flow_push | ( | uint16_t | port_id, |
uint32_t | queue_id, | ||
struct rte_flow_error * | error | ||
) |
Push all internally stored rules to the HW. Postponed rules are rules that were inserted with the postpone flag set. Can be used to notify the HW about batch of rules prepared by the SW to reduce the number of communications between the HW and SW.
port_id | Port identifier of Ethernet device. | |
queue_id | Flow queue to be pushed. | |
[out] | error | Perform verbose error reporting if not NULL. PMDs initialize this structure in case of error only. |
__rte_experimental int rte_flow_pull | ( | uint16_t | port_id, |
uint32_t | queue_id, | ||
struct rte_flow_op_result | res[], | ||
uint16_t | n_res, | ||
struct rte_flow_error * | error | ||
) |
Pull a rte flow operation. The application must invoke this function in order to complete the flow rule offloading and to retrieve the flow rule operation status.
port_id | Port identifier of Ethernet device. | |
queue_id | Flow queue which is used to pull the operation. | |
[out] | res | Array of results that will be set. |
[in] | n_res | Maximum number of results that can be returned. This value is equal to the size of the res array. |
[out] | error | Perform verbose error reporting if not NULL. PMDs initialize this structure in case of error only. |
__rte_experimental struct rte_flow_action_handle* rte_flow_async_action_handle_create | ( | uint16_t | port_id, |
uint32_t | queue_id, | ||
const struct rte_flow_op_attr * | op_attr, | ||
const struct rte_flow_indir_action_conf * | indir_action_conf, | ||
const struct rte_flow_action * | action, | ||
void * | user_data, | ||
struct rte_flow_error * | error | ||
) |
Enqueue indirect action creation operation.
[in] | port_id | Port identifier of Ethernet device. |
[in] | queue_id | Flow queue which is used to create the rule. |
[in] | op_attr | Indirect action creation operation attributes. |
[in] | indir_action_conf | Action configuration for the indirect action object creation. |
[in] | action | Specific configuration of the indirect action object. |
[in] | user_data | The user data that will be returned on the completion events. |
[out] | error | Perform verbose error reporting if not NULL. PMDs initialize this structure in case of error only. |
__rte_experimental int rte_flow_async_action_handle_destroy | ( | uint16_t | port_id, |
uint32_t | queue_id, | ||
const struct rte_flow_op_attr * | op_attr, | ||
struct rte_flow_action_handle * | action_handle, | ||
void * | user_data, | ||
struct rte_flow_error * | error | ||
) |
Enqueue indirect action destruction operation. The destroy queue must be the same as the queue on which the action was created.
[in] | port_id | Port identifier of Ethernet device. |
[in] | queue_id | Flow queue which is used to destroy the rule. |
[in] | op_attr | Indirect action destruction operation attributes. |
[in] | action_handle | Handle for the indirect action object to be destroyed. |
[in] | user_data | The user data that will be returned on the completion events. |
[out] | error | Perform verbose error reporting if not NULL. PMDs initialize this structure in case of error only. |
__rte_experimental int rte_flow_async_action_handle_update | ( | uint16_t | port_id, |
uint32_t | queue_id, | ||
const struct rte_flow_op_attr * | op_attr, | ||
struct rte_flow_action_handle * | action_handle, | ||
const void * | update, | ||
void * | user_data, | ||
struct rte_flow_error * | error | ||
) |
Enqueue indirect action update operation.
[in] | port_id | Port identifier of Ethernet device. |
[in] | queue_id | Flow queue which is used to update the rule. |
[in] | op_attr | Indirect action update operation attributes. |
[in] | action_handle | Handle for the indirect action object to be updated. |
[in] | update | Update profile specification used to modify the action pointed by handle. update could be with the same type of the immediate action corresponding to the handle argument when creating, or a wrapper structure includes action configuration to be updated and bit fields to indicate the member of fields inside the action to update. |
[in] | user_data | The user data that will be returned on the completion events. |
[out] | error | Perform verbose error reporting if not NULL. PMDs initialize this structure in case of error only. |
__rte_experimental int rte_flow_async_action_handle_query | ( | uint16_t | port_id, |
uint32_t | queue_id, | ||
const struct rte_flow_op_attr * | op_attr, | ||
const struct rte_flow_action_handle * | action_handle, | ||
void * | data, | ||
void * | user_data, | ||
struct rte_flow_error * | error | ||
) |
Enqueue indirect action query operation.
Retrieve action-specific data such as counters. Data is gathered by special action which may be present/referenced in more than one flow rule definition. Data will be available only when completion event returns.
port_id | Port identifier of Ethernet device. | |
[in] | queue_id | Flow queue which is used to query the action. |
[in] | op_attr | Indirect action update operation attributes. |
[in] | action_handle | Handle for the action object to query. |
[in,out] | data | Pointer to storage for the associated query data type. The out data will be available only when completion event returns from rte_flow_pull. |
[in] | user_data | The user data that will be returned on the completion events. |
[out] | error | Perform verbose error reporting if not NULL. PMDs initialize this structure in case of error only. |
__rte_experimental int rte_flow_action_handle_query_update | ( | uint16_t | port_id, |
struct rte_flow_action_handle * | handle, | ||
const void * | update, | ||
void * | query, | ||
enum rte_flow_query_update_mode | mode, | ||
struct rte_flow_error * | error | ||
) |
Query and/or update indirect flow action. If both query and update not NULL, the function atomically queries and updates indirect action. Query and update are carried in order specified in the mode parameter. If ether query or update is NULL, the function executes complementing operation.
port_id | Port identifier of Ethernet device. |
handle | Handle for the indirect action object to be updated. |
update | If not NULL, update profile specification used to modify the action pointed by handle. |
query | If not NULL pointer to storage for the associated query data type. |
mode | Operational mode. |
error | Perform verbose error reporting if not NULL. PMDs initialize this structure in case of error only. |
__rte_experimental int rte_flow_async_action_handle_query_update | ( | uint16_t | port_id, |
uint32_t | queue_id, | ||
const struct rte_flow_op_attr * | attr, | ||
struct rte_flow_action_handle * | handle, | ||
const void * | update, | ||
void * | query, | ||
enum rte_flow_query_update_mode | mode, | ||
void * | user_data, | ||
struct rte_flow_error * | error | ||
) |
Enqueue async indirect flow action query and/or update
port_id | Port identifier of Ethernet device. |
queue_id | Flow queue which is used to update the rule. |
attr | Indirect action update operation attributes. |
handle | Handle for the indirect action object to be updated. |
update | If not NULL, update profile specification used to modify the action pointed by handle. |
query | If not NULL, pointer to storage for the associated query data type. Query result returned on async completion event. |
mode | Operational mode. |
user_data | The user data that will be returned on async completion event. |
error | Perform verbose error reporting if not NULL. PMDs initialize this structure in case of error only. |
__rte_experimental struct rte_flow_action_list_handle* rte_flow_action_list_handle_create | ( | uint16_t | port_id, |
const struct rte_flow_indir_action_conf * | conf, | ||
const struct rte_flow_action * | actions, | ||
struct rte_flow_error * | error | ||
) |
Create an indirect flow action object from flow actions list. The object is identified by a unique handle. The handle has single state and configuration across all the flow rules using it.
[in] | port_id | The port identifier of the Ethernet device. |
[in] | conf | Action configuration for the indirect action list creation. |
[in] | actions | Specific configuration of the indirect action lists. |
[out] | error | Perform verbose error reporting if not NULL. PMDs initialize this structure in case of error only. |
__rte_experimental struct rte_flow_action_list_handle* rte_flow_async_action_list_handle_create | ( | uint16_t | port_id, |
uint32_t | queue_id, | ||
const struct rte_flow_op_attr * | attr, | ||
const struct rte_flow_indir_action_conf * | conf, | ||
const struct rte_flow_action * | actions, | ||
void * | user_data, | ||
struct rte_flow_error * | error | ||
) |
Async function call to create an indirect flow action object from flow actions list. The object is identified by a unique handle. The handle has single state and configuration across all the flow rules using it.
[in] | port_id | The port identifier of the Ethernet device. |
[in] | queue_id | Flow queue which is used to update the rule. |
[in] | attr | Indirect action update operation attributes. |
[in] | conf | Action configuration for the indirect action list creation. |
[in] | actions | Specific configuration of the indirect action list. |
[in] | user_data | The user data that will be returned on async completion event. |
[out] | error | Perform verbose error reporting if not NULL. PMDs initialize this structure in case of error only. |
__rte_experimental int rte_flow_action_list_handle_destroy | ( | uint16_t | port_id, |
struct rte_flow_action_list_handle * | handle, | ||
struct rte_flow_error * | error | ||
) |
Destroy indirect actions list by handle.
[in] | port_id | The port identifier of the Ethernet device. |
[in] | handle | Handle for the indirect actions list to be destroyed. |
[out] | error | Perform verbose error reporting if not NULL. PMDs initialize this structure in case of error only. |
__rte_experimental int rte_flow_async_action_list_handle_destroy | ( | uint16_t | port_id, |
uint32_t | queue_id, | ||
const struct rte_flow_op_attr * | op_attr, | ||
struct rte_flow_action_list_handle * | handle, | ||
void * | user_data, | ||
struct rte_flow_error * | error | ||
) |
Enqueue indirect action list destruction operation. The destroy queue must be the same as the queue on which the action was created.
[in] | port_id | Port identifier of Ethernet device. |
[in] | queue_id | Flow queue which is used to destroy the rule. |
[in] | op_attr | Indirect action destruction operation attributes. |
[in] | handle | Handle for the indirect action object to be destroyed. |
[in] | user_data | The user data that will be returned on the completion events. |
[out] | error | Perform verbose error reporting if not NULL. PMDs initialize this structure in case of error only. |
__rte_experimental int rte_flow_action_list_handle_query_update | ( | uint16_t | port_id, |
const struct rte_flow_action_list_handle * | handle, | ||
const void ** | update, | ||
void ** | query, | ||
enum rte_flow_query_update_mode | mode, | ||
struct rte_flow_error * | error | ||
) |
Query and/or update indirect flow actions list. If both query and update not NULL, the function atomically queries and updates indirect action. Query and update are carried in order specified in the mode parameter. If ether query or update is NULL, the function executes complementing operation.
port_id | Port identifier of Ethernet device. |
handle | Handle for the indirect actions list object to be updated. |
update | If the action list handle was created from n actions A1 / A2 ... An / END non-NULL update parameter is an array [U1, U2, ... Un] where Ui points to Ai update context or NULL if Ai should not be updated. |
query | If the action list handle was created from n actions A1 / A2 ... An / END non-NULL query parameter is an array [Q1, Q2, ... Qn] where Qi points to Ai query context or NULL if Ai should not be queried. |
mode | Operational mode. |
error | Perform verbose error reporting if not NULL. PMDs initialize this structure in case of error only. |
__rte_experimental int rte_flow_async_action_list_handle_query_update | ( | uint16_t | port_id, |
uint32_t | queue_id, | ||
const struct rte_flow_op_attr * | attr, | ||
const struct rte_flow_action_list_handle * | handle, | ||
const void ** | update, | ||
void ** | query, | ||
enum rte_flow_query_update_mode | mode, | ||
void * | user_data, | ||
struct rte_flow_error * | error | ||
) |
Enqueue async indirect flow actions list query and/or update If both query and update not NULL, the function atomically queries and updates indirect action. Query and update are carried in order specified in the mode parameter. If ether query or update is NULL, the function executes complementing operation.
port_id | Port identifier of Ethernet device. |
queue_id | Flow queue which is used to update the rule. |
attr | Indirect action update operation attributes. |
handle | Handle for the indirect actions list object to be updated. |
update | If the action list handle was created from n actions A1 / A2 ... An / END non-NULL update parameter is an array [U1, U2, ... Un] where Ui points to Ai update context or NULL if Ai should not be updated. |
query | If the action list handle was created from n actions A1 / A2 ... An / END non-NULL query parameter is an array [Q1, Q2, ... Qn] where Qi points to Ai query context or NULL if Ai should not be queried. Query result returned on async completion event. |
mode | Operational mode. |
user_data | The user data that will be returned on async completion event. |
error | Perform verbose error reporting if not NULL. PMDs initialize this structure in case of error only. |
|
static |
Default mask for RTE_FLOW_ITEM_TYPE_QUOTA
Definition at line 719 of file rte_flow.h.
|
static |
Default mask for RTE_FLOW_ITEM_TYPE_HIGIG2.
Definition at line 736 of file rte_flow.h.
|
static |
Default mask for RTE_FLOW_ITEM_TYPE_ANY.
Definition at line 763 of file rte_flow.h.
|
static |
Default mask for RTE_FLOW_ITEM_TYPE_PORT_ID.
Definition at line 788 of file rte_flow.h.
|
static |
Default mask for RTE_FLOW_ITEM_TYPE_RAW.
Definition at line 823 of file rte_flow.h.
|
static |
Default mask for RTE_FLOW_ITEM_TYPE_ETH.
Definition at line 871 of file rte_flow.h.
|
static |
Default mask for RTE_FLOW_ITEM_TYPE_VLAN.
Definition at line 913 of file rte_flow.h.
|
static |
Default mask for RTE_FLOW_ITEM_TYPE_IPV4.
Definition at line 932 of file rte_flow.h.
|
static |
Default mask for RTE_FLOW_ITEM_TYPE_IPV6.
Definition at line 973 of file rte_flow.h.
|
static |
Default mask for RTE_FLOW_ITEM_TYPE_ICMP.
Definition at line 1008 of file rte_flow.h.
|
static |
Default mask for RTE_FLOW_ITEM_TYPE_UDP.
Definition at line 1027 of file rte_flow.h.
|
static |
Default mask for RTE_FLOW_ITEM_TYPE_TCP.
Definition at line 1046 of file rte_flow.h.
|
static |
Default mask for RTE_FLOW_ITEM_TYPE_SCTP.
Definition at line 1065 of file rte_flow.h.
|
static |
Default mask for RTE_FLOW_ITEM_TYPE_VXLAN.
Definition at line 1097 of file rte_flow.h.
|
static |
Default mask for RTE_FLOW_ITEM_TYPE_E_TAG.
Definition at line 1125 of file rte_flow.h.
|
static |
Default mask for RTE_FLOW_ITEM_TYPE_NVGRE.
Definition at line 1150 of file rte_flow.h.
|
static |
Default mask for RTE_FLOW_ITEM_TYPE_MPLS.
Definition at line 1170 of file rte_flow.h.
|
static |
Default mask for RTE_FLOW_ITEM_TYPE_GRE.
Definition at line 1191 of file rte_flow.h.
|
static |
Default mask for RTE_FLOW_ITEM_TYPE_FUZZY.
Definition at line 1239 of file rte_flow.h.
|
static |
Default mask for RTE_FLOW_ITEM_TYPE_GTP.
Definition at line 1274 of file rte_flow.h.
|
static |
Default mask for RTE_FLOW_ITEM_TYPE_ESP.
Definition at line 1290 of file rte_flow.h.
|
static |
Default mask for RTE_FLOW_ITEM_TYPE_GENEVE.
Definition at line 1315 of file rte_flow.h.
|
static |
Default mask for RTE_FLOW_ITEM_TYPE_VXLAN_GPE.
Definition at line 1345 of file rte_flow.h.
|
static |
Default mask for RTE_FLOW_ITEM_TYPE_ARP_ETH_IPV4.
Definition at line 1380 of file rte_flow.h.
|
static |
Default mask for RTE_FLOW_ITEM_TYPE_IPV6_EXT.
Definition at line 1405 of file rte_flow.h.
|
static |
Default mask for RTE_FLOW_ITEM_TYPE_ICMP6.
Definition at line 1437 of file rte_flow.h.
|
static |
Default mask for RTE_FLOW_ITEM_TYPE_ICMP6_ND_NS.
Definition at line 1469 of file rte_flow.h.
|
static |
Default mask for RTE_FLOW_ITEM_TYPE_ICMP6_ND_NA.
Definition at line 1496 of file rte_flow.h.
|
static |
Default mask for RTE_FLOW_ITEM_TYPE_ICMP6_ND_OPT.
Definition at line 1522 of file rte_flow.h.
|
static |
Default mask for RTE_FLOW_ITEM_TYPE_ICMP6_ND_OPT_SLA_ETH.
Definition at line 1547 of file rte_flow.h.
|
static |
Default mask for RTE_FLOW_ITEM_TYPE_ICMP6_ND_OPT_TLA_ETH.
Definition at line 1572 of file rte_flow.h.
|
static |
Default mask for RTE_FLOW_ITEM_TYPE_META.
Definition at line 1594 of file rte_flow.h.
|
static |
Default mask for RTE_FLOW_ITEM_TYPE_GTP_PSC.
Definition at line 1611 of file rte_flow.h.
|
static |
Default mask for RTE_FLOW_ITEM_TYPE_PPPOE_PROTO_ID.
Definition at line 1650 of file rte_flow.h.
|
static |
Default mask for RTE_FLOW_ITEM_TYPE_TAG.
Definition at line 1670 of file rte_flow.h.
|
static |
Default mask for RTE_FLOW_ITEM_TYPE_L2TPV3OIP.
Definition at line 1687 of file rte_flow.h.
|
static |
Default mask for RTE_FLOW_ITEM_TYPE_MARK.
Definition at line 1717 of file rte_flow.h.
|
static |
Default mask for RTE_FLOW_ITEM_TYPE_NSH.
Definition at line 1745 of file rte_flow.h.
|
static |
Default mask for RTE_FLOW_ITEM_TYPE_IGMP.
Definition at line 1770 of file rte_flow.h.
|
static |
Default mask for RTE_FLOW_ITEM_TYPE_AH.
Definition at line 1793 of file rte_flow.h.
|
static |
Default mask for RTE_FLOW_ITEM_TYPE_PFCP.
Definition at line 1815 of file rte_flow.h.
|
static |
Default mask for RTE_FLOW_ITEM_TYPE_ECPRI.
Definition at line 1835 of file rte_flow.h.
|
static |
Default mask for RTE_FLOW_ITEM_TYPE_GENEVE_OPT.
Definition at line 1859 of file rte_flow.h.
|
static |
Default mask for RTE_FLOW_ITEM_TYPE_CONNTRACK.
Definition at line 1951 of file rte_flow.h.
|
static |
Default mask for items based on struct rte_flow_item_ethdev
Definition at line 1967 of file rte_flow.h.
|
static |
Default mask for RTE_FLOW_ITEM_TYPE_L2TPV2.
Definition at line 1986 of file rte_flow.h.
|
static |
Default mask for RTE_FLOW_ITEM_TYPE_PPP.
Definition at line 2014 of file rte_flow.h.
|
static |
Default mask for RTE_FLOW_ITEM_TYPE_IB_BTH.
Definition at line 2034 of file rte_flow.h.
|
static |
Default mask for RTE_FLOW_ITEM_TYPE_METER_COLOR.
Definition at line 2264 of file rte_flow.h.
|
static |
Default mask for RTE_FLOW_ITEM_TYPE_AGGR_AFFINITY.
Definition at line 2290 of file rte_flow.h.
|
static |
Default mask for RTE_FLOW_ITEM_TX_QUEUE.
Definition at line 2309 of file rte_flow.h.