diff options
author | Fan Zhang <roy.fan.zhang@intel.com> | 2022-03-10 14:49:19 +0000 |
---|---|---|
committer | Damjan Marion <dmarion@me.com> | 2022-03-14 16:58:16 +0000 |
commit | a9fe20f4b8f7a9bd65cc8ee1b6a0204af7fc3627 (patch) | |
tree | 4c61ee4c6a3ec69cdcfdd05fe13d115466ee5f08 | |
parent | e41fa7790f9a88fb55df6ed017fda75c6343becc (diff) |
dpdk: improve rx burst count per loop
Type: improvement
This patch improves the per dpdk-input loop number of packets
received from the port. The change mimics how packets rx happened
before VPP 22.02/DPDK 21.11: instead of trying to rx huge number
of packets (256) in one go, rx more times with up to 32 packets
max each time.
Signed-off-by: Fan Zhang <roy.fan.zhang@intel.com>
Change-Id: I804dce6d9121ab21b02e53dd0328dc52ac49d80f
-rw-r--r-- | src/plugins/dpdk/device/node.c | 9 |
1 files changed, 5 insertions, 4 deletions
diff --git a/src/plugins/dpdk/device/node.c b/src/plugins/dpdk/device/node.c index 0450c422154..b4600324551 100644 --- a/src/plugins/dpdk/device/node.c +++ b/src/plugins/dpdk/device/node.c @@ -365,12 +365,13 @@ dpdk_device_input (vlib_main_t * vm, dpdk_main_t * dm, dpdk_device_t * xd, /* get up to DPDK_RX_BURST_SZ buffers from PMD */ while (n_rx_packets < DPDK_RX_BURST_SZ) { - n = rte_eth_rx_burst (xd->port_id, queue_id, - ptd->mbufs + n_rx_packets, - DPDK_RX_BURST_SZ - n_rx_packets); + u32 n_to_rx = clib_min (DPDK_RX_BURST_SZ - n_rx_packets, 32); + + n = rte_eth_rx_burst (xd->port_id, queue_id, ptd->mbufs + n_rx_packets, + n_to_rx); n_rx_packets += n; - if (n < 32) + if (n < n_to_rx) break; } |