X-Git-Url: http://git.droids-corp.org/?a=blobdiff_plain;f=examples%2Fl3fwd%2Fl3fwd_event.h;h=f139632016e2c3317f494c5f31a7a672cf4c6990;hb=79aab97c94024c4f969308ec806efb168cccc83d;hp=3ad1902ab57f99f8af783b870dddc1af19c3fcc7;hpb=9510dd1feb71fac0b71c74e71bd2618ad14301ac;p=dpdk.git diff --git a/examples/l3fwd/l3fwd_event.h b/examples/l3fwd/l3fwd_event.h index 3ad1902ab5..f139632016 100644 --- a/examples/l3fwd/l3fwd_event.h +++ b/examples/l3fwd/l3fwd_event.h @@ -65,6 +65,7 @@ struct l3fwd_event_resources { uint8_t disable_implicit_release; struct l3fwd_event_setup_ops ops; struct rte_mempool * (*pkt_pool)[NB_SOCKETS]; + struct rte_mempool **vec_pool; struct l3fwd_event_queues evq; struct l3fwd_event_ports evp; uint32_t port_mask; @@ -76,8 +77,32 @@ struct l3fwd_event_resources { uint8_t has_burst; uint8_t enabled; uint8_t eth_rx_queues; + uint8_t vector_enabled; + uint16_t vector_size; + uint64_t vector_tmo_ns; }; +static inline void +event_vector_attr_validate(struct rte_event_vector *vec, struct rte_mbuf *mbuf) +{ + /* l3fwd application only changes mbuf port while processing */ + if (vec->attr_valid && (vec->port != mbuf->port)) + vec->attr_valid = 0; +} + +static inline void +event_vector_txq_set(struct rte_event_vector *vec, uint16_t txq) +{ + if (vec->attr_valid) { + vec->queue = txq; + } else { + int i; + + for (i = 0; i < vec->nb_elem; i++) + rte_event_eth_tx_adapter_txq_set(vec->mbufs[i], txq); + } +} + struct l3fwd_event_resources *l3fwd_get_eventdev_rsrc(void); void l3fwd_event_resource_setup(struct rte_eth_conf *port_conf); int l3fwd_get_free_event_port(struct l3fwd_event_resources *eventdev_rsrc);