29 #include <rte_byteorder.h>
30 #include <rte_ethdev.h>
31 #include <rte_mempool.h>
39 #include "flow_common.h"
44 #define NB_EGRESS_ENTRIES 3
46 #define NB_INGRESS_ENTRIES 2
48 #define NB_VPORT_ENTRIES 3
50 #define NB_TOTAL_ENTRIES (NB_EGRESS_ENTRIES + NB_INGRESS_ENTRIES + NB_VPORT_ENTRIES + 1)
85 uint32_t sw_packet_type;
91 rc = rte_flow_dynf_metadata_register();
101 for (i = 0; i < nb_rx; i++) {
102 sw_packet_type = rte_net_get_ptype(mbufs[i],
NULL, RTE_PTYPE_ALL_MASK);
103 if (mbufs[i]->ol_flags & RTE_MBUF_F_RX_FDIR_ID) {
104 if (sw_packet_type & RTE_PTYPE_L4_TCP)
106 else if (sw_packet_type & RTE_PTYPE_L4_UDP)
111 mbufs[i]->hash.fdir.hi,
113 rte_flow_dynf_metadata_set(mbufs[i],
dst_port);
114 mbufs[i]->ol_flags |= RTE_MBUF_DYNFLAG_TX_METADATA;
121 nb_tx = rte_eth_tx_burst(port_id,
queue_id, &mbufs[i], 1);
126 }
while (++retry < 5);
127 rte_pktmbuf_free(mbufs[i]);
145 struct doca_flow_pipe_cfg *pipe_cfg;
149 memset(&match, 0,
sizeof(match));
150 memset(&
fwd, 0,
sizeof(
fwd));
207 memset(&match, 0,
sizeof(match));
233 struct doca_flow_pipe_cfg *pipe_cfg;
236 memset(&match, 0,
sizeof(match));
238 memset(&
fwd, 0,
sizeof(
fwd));
307 struct doca_flow_pipe **pipe)
312 struct doca_flow_pipe_cfg *pipe_cfg;
316 memset(&match, 0,
sizeof(match));
318 memset(&
fwd, 0,
sizeof(
fwd));
393 struct doca_flow_pipe_cfg *pipe_cfg;
396 memset(&match, 0,
sizeof(match));
398 memset(&
fwd, 0,
sizeof(
fwd));
399 memset(&pipe_cfg, 0,
sizeof(pipe_cfg));
473 memset(&
fwd, 0,
sizeof(
fwd));
474 memset(&match, 0,
sizeof(match));
531 memset(&
fwd, 0,
sizeof(
fwd));
532 memset(&match, 0,
sizeof(match));
584 memset(&
fwd, 0,
sizeof(
fwd));
585 memset(&match, 0,
sizeof(match));
636 uint32_t shared_mirror_ids = 1;
640 struct doca_dev *doca_dev =
ctx->doca_dev[0];
641 const char *start_str;
642 bool is_expert =
ctx->is_expert;
644 memset(&status, 0,
sizeof(status));
649 start_str =
"switch,hws,isolated,hairpinq_num=4,expert";
651 start_str =
"switch,hws,isolated,hairpinq_num=4";
659 memset(dev_arr, 0,
sizeof(
struct doca_dev *) *
nb_ports);
660 dev_arr[0] = doca_dev;
687 mirror_cfg.
target = ⌖
690 cfg.mirror_cfg = mirror_cfg;
743 mirror_cfg.
target = ⌖
746 cfg.mirror_cfg = mirror_cfg;
struct doca_flow_port * init_doca_flow(uint16_t port_id, uint8_t rxq_num)
static doca_error_t destroy_pipe_cfg(struct doca_flow_pipe_cfg *cfg)
static struct doca_flow_fwd fwd_miss
static uint16_t * rss_queues
static struct doca_flow_actions actions
#define BE_IPV4_ADDR(a, b, c, d)
static struct doca_flow_monitor monitor
static struct doca_flow_fwd fwd
#define DEFAULT_TIMEOUT_US
static doca_error_t add_switch_vport_pipe_entries(struct doca_flow_pipe *pipe, struct entries_status *status)
static struct doca_flow_pipe_entry * egress_entries[NB_EGRESS_ENTRIES]
static struct doca_flow_pipe * pipe_rss
static struct doca_flow_pipe * pipe_egress
static doca_error_t add_rss_pipe_entry(struct doca_flow_pipe *pipe, struct entries_status *status)
static doca_error_t create_switch_ingress_pipe(struct doca_flow_port *sw_port, uint32_t mirror_id, struct doca_flow_pipe **pipe)
static struct doca_flow_pipe * pipe_vport
static doca_error_t create_switch_vport_pipe(struct doca_flow_port *sw_port, struct doca_flow_pipe **pipe)
static doca_error_t create_switch_egress_pipe(struct doca_flow_port *sw_port, struct doca_flow_pipe **pipe)
doca_error_t flow_switch_to_wire(int nb_queues, int nb_ports, struct flow_switch_ctx *ctx)
#define NB_EGRESS_ENTRIES
static struct doca_flow_pipe_entry * vport_entries[NB_VPORT_ENTRIES]
static doca_error_t add_switch_ingress_pipe_entries(struct doca_flow_pipe *pipe, struct entries_status *status)
#define NB_INGRESS_ENTRIES
static doca_error_t create_rss_pipe(struct doca_flow_port *port, struct doca_flow_pipe **pipe)
static doca_error_t add_switch_egress_pipe_entries(struct doca_flow_pipe *pipe, struct entries_status *status)
static struct doca_flow_pipe * pipe_ingress
static void handle_rx_tx_pkts(uint32_t port_id, uint16_t nb_queues)
static struct doca_flow_pipe_entry * rss_entry
static struct doca_flow_pipe_entry * ingress_entries[NB_INGRESS_ENTRIES]
DOCA_LOG_REGISTER(FLOW_SWITCH_TO_WIRE)
enum doca_error doca_error_t
DOCA API return codes.
DOCA_STABLE const char * doca_error_get_descr(doca_error_t error)
Returns the description string of an error code.
@ DOCA_FLOW_L4_TYPE_EXT_TCP
DOCA_STABLE doca_error_t doca_flow_pipe_cfg_destroy(struct doca_flow_pipe_cfg *cfg)
Destroy DOCA Flow pipe configuration struct.
DOCA_STABLE doca_error_t doca_flow_pipe_cfg_create(struct doca_flow_pipe_cfg **cfg, struct doca_flow_port *port)
Create DOCA Flow pipe configuration struct.
DOCA_STABLE doca_error_t doca_flow_entries_process(struct doca_flow_port *port, uint16_t pipe_queue, uint64_t timeout, uint32_t max_processed_entries)
Process entries in queue.
DOCA_EXPERIMENTAL doca_error_t doca_flow_pipe_cfg_set_match(struct doca_flow_pipe_cfg *cfg, const struct doca_flow_match *match, const struct doca_flow_match *match_mask)
Set pipe's match and match mask.
DOCA_STABLE doca_error_t doca_flow_shared_resources_bind(enum doca_flow_shared_resource_type type, uint32_t *res_array, uint32_t res_array_len, void *bindable_obj)
Binds a bulk of shared resources to a bindable object.
DOCA_EXPERIMENTAL doca_error_t doca_flow_pipe_create(const struct doca_flow_pipe_cfg *cfg, const struct doca_flow_fwd *fwd, const struct doca_flow_fwd *fwd_miss, struct doca_flow_pipe **pipe)
Create one new pipe.
doca_flow_flags_type
doca flow flags type
DOCA_EXPERIMENTAL doca_error_t doca_flow_shared_resource_set_cfg(enum doca_flow_shared_resource_type type, uint32_t id, struct doca_flow_shared_resource_cfg *cfg)
Configure a single shared resource.
DOCA_EXPERIMENTAL doca_error_t doca_flow_pipe_cfg_set_monitor(struct doca_flow_pipe_cfg *cfg, const struct doca_flow_monitor *monitor)
Set pipe's monitor.
DOCA_EXPERIMENTAL doca_error_t doca_flow_pipe_add_entry(uint16_t pipe_queue, struct doca_flow_pipe *pipe, const struct doca_flow_match *match, const struct doca_flow_actions *actions, const struct doca_flow_monitor *monitor, const struct doca_flow_fwd *fwd, uint32_t flags, void *usr_ctx, struct doca_flow_pipe_entry **entry)
Add one new entry to a pipe.
DOCA_STABLE void doca_flow_destroy(void)
Destroy the doca flow.
DOCA_STABLE doca_error_t doca_flow_pipe_cfg_set_nr_entries(struct doca_flow_pipe_cfg *cfg, uint32_t nr_entries)
Set pipe's maximum number of flow rules.
DOCA_STABLE struct doca_flow_port * doca_flow_port_switch_get(const struct doca_flow_port *port)
Get doca flow switch port.
DOCA_STABLE doca_error_t doca_flow_pipe_cfg_set_domain(struct doca_flow_pipe_cfg *cfg, enum doca_flow_pipe_domain domain)
Set pipe's domain.
DOCA_EXPERIMENTAL doca_error_t doca_flow_resource_query_entry(struct doca_flow_pipe_entry *entry, struct doca_flow_resource_query *query_stats)
Extract information about specific entry.
@ DOCA_FLOW_SHARED_RESOURCE_MIRROR
@ DOCA_FLOW_WAIT_FOR_BATCH
@ DOCA_FLOW_RESOURCE_TYPE_NON_SHARED
@ DOCA_FLOW_PIPE_DOMAIN_EGRESS
@ DOCA_FLOW_PIPE_DOMAIN_DEFAULT
#define DOCA_LOG_ERR(format,...)
Generates an ERROR application log message.
#define DOCA_LOG_INFO(format,...)
Generates an INFO application log message.
uint16_t doca_be16_t
Declare DOCA endianity types.
const struct ip_frag_config * cfg
doca_error_t stop_doca_flow_ports(int nb_ports, struct doca_flow_port *ports[])
doca_error_t init_doca_flow_ports(int nb_ports, struct doca_flow_port *ports[], bool is_hairpin, struct doca_dev *dev_arr[], uint32_t actions_mem_size[])
doca_error_t set_flow_pipe_cfg(struct doca_flow_pipe_cfg *cfg, const char *name, enum doca_flow_pipe_type type, bool is_root)
#define SHARED_RESOURCE_NUM_VALUES
#define ACTIONS_MEM_SIZE(nr_queues, entries)
#define ARRAY_INIT(array, val)
doca flow actions information
struct doca_flow_pipe * next_pipe
struct doca_flow_pipe * pipe
enum doca_flow_fwd_type type
enum doca_flow_resource_type rss_type
struct doca_flow_resource_rss_cfg rss
doca flow matcher information
struct doca_flow_parser_meta parser_meta
struct doca_flow_header_format outer
doca monitor action configuration
uint32_t shared_mirror_id
enum doca_flow_resource_type counter_type
doca flow mirror resource configuration
struct doca_flow_mirror_target * target
struct doca_flow_resource_query::@115::@117 counter
doca flow shared resource configuration
user context struct that will be used in entries process callback
static uint32_t actions_mem_size[FLOW_SWITCH_PORTS_MAX]
static struct doca_flow_port * ports[FLOW_SWITCH_PORTS_MAX]
struct upf_accel_ctx * ctx