From 149ba779cff4ffc48d87ca67a2a8d4afd49b05f5 Mon Sep 17 00:00:00 2001 From: Damjan Marion Date: Thu, 12 Oct 2017 13:09:26 +0200 Subject: vlib: add support for multiple buffer pools Change-Id: Icaf7d7ad47284aea7a56e8006b69f45874d64202 Signed-off-by: Damjan Marion --- src/plugins/dpdk/device/common.c | 6 ++++++ 1 file changed, 6 insertions(+) (limited to 'src/plugins/dpdk/device/common.c') diff --git a/src/plugins/dpdk/device/common.c b/src/plugins/dpdk/device/common.c index aedc3f5227d..c65cec6734d 100644 --- a/src/plugins/dpdk/device/common.c +++ b/src/plugins/dpdk/device/common.c @@ -78,8 +78,11 @@ dpdk_device_setup (dpdk_device_t * xd) dpdk_device_error (xd, "rte_eth_tx_queue_setup", rv); } + vec_validate_aligned (xd->buffer_pool_for_queue, xd->rx_q_used - 1, + CLIB_CACHE_LINE_BYTES); for (j = 0; j < xd->rx_q_used; j++) { + dpdk_mempool_private_t *privp; uword tidx = vnet_get_device_input_thread_index (dm->vnet_main, xd->hw_if_index, j); unsigned lcore = vlib_worker_threads[tidx].lcore_id; @@ -95,6 +98,9 @@ dpdk_device_setup (dpdk_device_t * xd) SOCKET_ID_ANY, 0, dm->pktmbuf_pools[socket_id]); + privp = rte_mempool_get_priv (dm->pktmbuf_pools[socket_id]); + xd->buffer_pool_for_queue[j] = privp->buffer_pool_index; + if (rv < 0) dpdk_device_error (xd, "rte_eth_rx_queue_setup", rv); } -- cgit 1.2.3-korg