27 #define foreach_dpdk_tx_func_error \ 28 _(BAD_RETVAL, "DPDK tx function returned an error") \ 29 _(PKT_DROP, "Tx packet drops (dpdk tx failure)") 33 #define _(f,s) DPDK_TX_FUNC_ERROR_##f, 53 error = rte_eth_dev_default_mac_addr_set (xd->
port_id,
54 (
struct ether_addr *) address);
85 sizeof (buffer[0]) -
sizeof (buffer->
pre_data));
96 struct rte_mbuf *mb, *first_mb, *last_mb;
104 rte_pktmbuf_reset (mb);
105 while (maybe_multiseg && (b2->
flags & VLIB_BUFFER_NEXT_PRESENT))
109 rte_pktmbuf_reset (mb);
114 first_mb->nb_segs = 1;
120 while (maybe_multiseg && (b->
flags & VLIB_BUFFER_NEXT_PRESENT))
145 struct rte_mbuf **mb,
u32 n_left)
166 queue_id = (queue_id + 1) % xd->
tx_q_used;
179 n_sent = rte_ring_sp_enqueue_burst (hqos->
swq, (
void **) mb,
187 n_sent = rte_eth_tx_burst (xd->
port_id, queue_id, mb, n_left);
216 while (n_sent && n_left && (n_retry > 0));
233 u32 ip_cksum = b->
flags & VNET_BUFFER_F_OFFLOAD_IP_CKSUM;
234 u32 tcp_cksum = b->
flags & VNET_BUFFER_F_OFFLOAD_TCP_CKSUM;
235 u32 udp_cksum = b->
flags & VNET_BUFFER_F_OFFLOAD_UDP_CKSUM;
236 int is_ip4 = b->
flags & VNET_BUFFER_F_IS_IP4;
240 if (
PREDICT_TRUE ((ip_cksum | tcp_cksum | udp_cksum) == 0))
246 mb->outer_l3_len = 0;
247 mb->outer_l2_len = 0;
248 ol_flags = is_ip4 ? PKT_TX_IPV4 : PKT_TX_IPV6;
249 ol_flags |= ip_cksum ? PKT_TX_IP_CKSUM : 0;
250 ol_flags |= tcp_cksum ? PKT_TX_TCP_CKSUM : 0;
251 ol_flags |= udp_cksum ? PKT_TX_UDP_CKSUM : 0;
252 mb->ol_flags |= ol_flags;
256 if (xd->
flags & DPDK_DEVICE_FLAG_INTEL_PHDR_CKSUM)
257 rte_net_intel_cksum_flags_prepare (mb, ol_flags);
272 u32 n_packets = f->n_vectors;
275 int queue_id = thread_index;
276 u32 tx_pkts = 0, all_or_flags = 0;
279 struct rte_mbuf **mb;
286 (
void **) ptd->
mbufs, n_packets,
287 -(
i32) sizeof (
struct rte_mbuf));
307 all_or_flags |= or_flags;
314 if (or_flags & VLIB_BUFFER_NEXT_PRESENT)
329 if (
PREDICT_FALSE ((xd->flags & DPDK_DEVICE_FLAG_TX_OFFLOAD) &&
331 (VNET_BUFFER_F_OFFLOAD_TCP_CKSUM
332 | VNET_BUFFER_F_OFFLOAD_IP_CKSUM
333 | VNET_BUFFER_F_OFFLOAD_UDP_CKSUM))))
343 if (b[0]->
flags & VLIB_BUFFER_IS_TRACED)
345 if (b[1]->
flags & VLIB_BUFFER_IS_TRACED)
347 if (b[2]->
flags & VLIB_BUFFER_IS_TRACED)
349 if (b[3]->
flags & VLIB_BUFFER_IS_TRACED)
359 all_or_flags |= b[0]->
flags;
366 if (b[0]->
flags & VLIB_BUFFER_IS_TRACED)
374 tx_pkts = n_packets = mb - ptd->
mbufs;
395 rte_pktmbuf_free (ptd->
mbufs[n_packets - n_left - 1]);
429 if (xd->
flags & DPDK_DEVICE_FLAG_PMD_INIT_FAIL)
434 if ((xd->
flags & DPDK_DEVICE_FLAG_ADMIN_UP) == 0)
436 xd->
flags |= DPDK_DEVICE_FLAG_ADMIN_UP;
444 if ((xd->
flags & DPDK_DEVICE_FLAG_ADMIN_UP) != 0)
446 xd->
flags &= ~DPDK_DEVICE_FLAG_ADMIN_UP;
465 if (node_index == ~0)
494 if ((xd->
flags & DPDK_DEVICE_FLAG_PMD) == 0)
498 if ((xd->
pmd != VNET_DPDK_PMD_IXGBEVF) && (xd->
pmd != VNET_DPDK_PMD_I40EVF))
511 vlan_offload = rte_eth_dev_get_vlan_offload (xd->
port_id);
512 vlan_offload |= ETH_VLAN_FILTER_OFFLOAD;
514 if ((r = rte_eth_dev_set_vlan_offload (xd->
port_id, vlan_offload)))
524 rte_eth_dev_vlan_filter (xd->
port_id,
535 xd->
flags |= DPDK_DEVICE_FLAG_HAVE_SUBIF;
537 xd->
flags &= ~DPDK_DEVICE_FLAG_HAVE_SUBIF;
560 #define UP_DOWN_FLAG_EVENT 1 568 uword *event_data = 0;
586 sw_if_index = event_data[0];
587 flags = event_data[1];
609 .name =
"admin-up-down-process",
610 .process_log2_n_stack_bytes = 17,
u32 flags
buffer flags: VLIB_BUFFER_FREE_LIST_INDEX_MASK: bits used to store free list index, VLIB_BUFFER_IS_TRACED: trace this buffer.
format_function_t format_dpdk_tx_trace
format_function_t format_dpdk_flow
#define vlib_buffer_from_rte_mbuf(x)
static uword * vlib_process_wait_for_event(vlib_main_t *vm)
vnet_main_t * vnet_get_main(void)
vnet_interface_main_t interface_main
i16 current_data
signed offset in data[], pre_data[] that we are currently processing.
static void vlib_error_count(vlib_main_t *vm, uword node_index, uword counter, uword increment)
#define clib_memcpy_fast(a, b, c)
static f64 vlib_time_now(vlib_main_t *vm)
static char * dpdk_tx_func_error_strings[]
#define VLIB_BUFFER_PRE_DATA_SIZE
static vnet_hw_interface_t * vnet_get_hw_interface(vnet_main_t *vnm, u32 hw_if_index)
u16 current_length
Nbytes between current data and the end of this buffer.
static clib_error_t * dpdk_set_mac_address(vnet_hw_interface_t *hi, const u8 *old_address, const u8 *address)
u32 per_interface_next_index
static_always_inline void vlib_get_buffers_with_offset(vlib_main_t *vm, u32 *bi, void **b, int count, i32 offset)
Translate array of buffer indices into buffer pointers with offset.
static void vlib_increment_simple_counter(vlib_simple_counter_main_t *cm, u32 thread_index, u32 index, u64 increment)
Increment a simple counter.
struct rte_eth_xstat * last_cleared_xstats
static uword vlib_buffer_length_in_chain(vlib_main_t *vm, vlib_buffer_t *b)
Get length in bytes of the buffer chain.
static uword vlib_node_add_next(vlib_main_t *vm, uword node, uword next_node)
static void dpdk_tx_trace_buffer(dpdk_main_t *dm, vlib_node_runtime_t *node, dpdk_device_t *xd, u16 queue_id, vlib_buffer_t *buffer)
u8 buffer_pool_index
index of buffer pool this buffer belongs.
#define vec_reset_length(v)
Reset vector length to zero NULL-pointer tolerant.
#define vec_add(V, E, N)
Add N elements to end of vector V (no header, unspecified alignment)
struct rte_eth_stats stats
#define static_always_inline
static uword vlib_process_get_events(vlib_main_t *vm, uword **data_vector)
Return the first event type which has occurred and a vector of per-event data of that type...
vlib_node_registration_t dpdk_input_node
(constructor) VLIB_REGISTER_NODE (dpdk_input_node)
static void dpdk_set_interface_next_node(vnet_main_t *vnm, u32 hw_if_index, u32 node_index)
#define vec_elt_at_index(v, i)
Get vector value at index i checking that i is in bounds.
#define clib_error_return(e, args...)
#define VNET_DEVICE_CLASS_TX_FN(devclass)
vlib_node_registration_t admin_up_down_process_node
(constructor) VLIB_REGISTER_NODE (admin_up_down_process_node)
A collection of simple counters.
dpdk_device_hqos_per_worker_thread_t * hqos_wt
#define clib_atomic_test_and_set(a)
static u32 vlib_get_buffer_index(vlib_main_t *vm, void *p)
Translate buffer pointer into buffer index.
struct vnet_sub_interface_t::@208::@209::@211 flags
vnet_hw_interface_t * hw_interfaces
void dpdk_device_start(dpdk_device_t *xd)
#define clib_atomic_release(a)
dpdk_per_thread_data_t * per_thread_data
#define rte_mbuf_from_vlib_buffer(x)
void dpdk_hqos_metadata_set(dpdk_device_hqos_per_worker_thread_t *hqos, struct rte_mbuf **pkts, u32 n_pkts)
vlib_simple_counter_main_t * sw_if_counters
#define VLIB_REGISTER_NODE(x,...)
struct vnet_sub_interface_t::@208 eth
#define CLIB_PREFETCH(addr, size, type)
static void dpdk_update_counters(dpdk_device_t *xd, f64 now)
#define clib_warning(format, args...)
static_always_inline void dpdk_prefetch_buffer(vlib_main_t *vm, struct rte_mbuf *mb)
format_function_t format_dpdk_device
static_always_inline void dpdk_validate_rte_mbuf(vlib_main_t *vm, vlib_buffer_t *b, int maybe_multiseg)
void dpdk_device_stop(dpdk_device_t *xd)
static_always_inline u32 tx_burst_vector_internal(vlib_main_t *vm, dpdk_device_t *xd, struct rte_mbuf **mb, u32 n_left)
struct rte_eth_xstat * xstats
format_function_t format_dpdk_device_name
u8 pre_data[VLIB_BUFFER_PRE_DATA_SIZE]
Space for inserting data before buffer start.
#define clib_error_report(e)
VNET_DEVICE_CLASS(bond_dev_class)
void dpdk_update_link_state(dpdk_device_t *xd, f64 now)
dpdk_portid_t device_index
static vlib_main_t * vlib_get_main(void)
static void * vlib_add_trace(vlib_main_t *vm, vlib_node_runtime_t *r, vlib_buffer_t *b, u32 n_data_bytes)
static void dpdk_clear_hw_interface_counters(u32 instance)
struct rte_mbuf * mbufs[DPDK_RX_BURST_SZ]
static uword admin_up_down_process(vlib_main_t *vm, vlib_node_runtime_t *rt, vlib_frame_t *f)
VNET_DEVICE_CLASS_TX_FN() dpdk_device_class(vlib_main_t *vm, vlib_node_runtime_t *node, vlib_frame_t *f)
#define foreach_dpdk_tx_func_error
#define vec_len(v)
Number of elements in vector (rvalue-only, NULL tolerant)
u32 next_buffer
Next buffer for this linked-list of buffers.
u8 admin_up_down_in_progress
clib_error_t * vnet_hw_interface_set_flags(vnet_main_t *vnm, u32 hw_if_index, vnet_hw_interface_flags_t flags)
#define VLIB_BUFFER_TRACE_TRAJECTORY_INIT(b)
struct rte_mempool ** dpdk_no_cache_mempool_by_buffer_pool_index
VLIB buffer representation.
static void * vlib_frame_vector_args(vlib_frame_t *f)
Get pointer to frame vector data.
#define UP_DOWN_FLAG_EVENT
static clib_error_t * dpdk_interface_admin_up_down(vnet_main_t *vnm, u32 hw_if_index, u32 flags)
vnet_flow_dev_ops_function_t dpdk_flow_ops_fn
clib_error_t * vnet_sw_interface_set_flags(vnet_main_t *vnm, u32 sw_if_index, vnet_sw_interface_flags_t flags)
struct rte_eth_stats last_cleared_stats
static clib_error_t * dpdk_subif_add_del_function(vnet_main_t *vnm, u32 hw_if_index, struct vnet_sw_interface_t *st, int is_add)
#define VLIB_NODE_FLAG_TRACE
static_always_inline void dpdk_buffer_tx_offload(dpdk_device_t *xd, vlib_buffer_t *b, struct rte_mbuf *mb)
#define CLIB_CACHE_LINE_BYTES
volatile u8 ref_count
Reference count for this buffer.
static vlib_buffer_t * vlib_get_buffer(vlib_main_t *vm, u32 buffer_index)
Translate buffer index into buffer pointer.
CLIB vectors are ubiquitous dynamically resized arrays with by user defined "headers".