From patchwork Mon Mar 2 14:32:06 2020 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: Hemant Agrawal X-Patchwork-Id: 184068 Delivered-To: patch@linaro.org Received: by 2002:a92:1f12:0:0:0:0:0 with SMTP id i18csp2170615ile; Mon, 2 Mar 2020 01:01:34 -0800 (PST) X-Google-Smtp-Source: APXvYqwtA7fpMjgmCc1FYMjGPKjZHr9gKDSKqxgCUTqeF+EFCdzMAFm9tHRvRyaQJJEmKZD7Z2zP X-Received: by 2002:a17:906:4ecc:: with SMTP id i12mr13589036ejv.227.1583139694550; Mon, 02 Mar 2020 01:01:34 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1583139694; cv=none; d=google.com; s=arc-20160816; b=P/JuMq1mu6UByb31EmNQ4Y0Ek4c/QB/rn2/+5TV4mufDnihj+sW8qdpJXHMK25GJcZ Ro70d9tANoG7XTbcthCaUFmE3GXRL60CtrvD8ygWdwicj1uglTTj49vQ783uLcg7Wige ihF+w0pY6aAjEMydtaxHbgmtlvd/Tn5Hm8VxbKSXIjbdDwY1N7hrxzR87hsyMPjCQeda hnHb3iiF+Ed0dFJWCUxdlwykWfw3UWK29EIdwPuk7FagRmBPsFrQsgxRmt4jeETQe6MR Os5Ye/lVAsY9zJFdHotqEgzgD/iHXsf665WcXAWMHlvb7m74hHytvNvlxvElF8s8C+lR 4qUA== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=sender:errors-to:list-subscribe:list-help:list-post:list-archive :list-unsubscribe:list-id:precedence:subject:references:in-reply-to :message-id:date:cc:to:from; bh=WI1nqzdFM3vZiN3yoOzgQlD+WPA6dlTYZuDK9FE7p1I=; b=Tvs/KdL8aU29lZQZPtuH93pE9qPUXE1cnGj7XUXwgvdtyhqlCKctLDmEuJcaaR9Z6d kY86XCcLn7CW6WdghERfNB2Ar78BMCvlpBrinOqoZq7qR/MJFiIQD4Tx3EbqZFa94LIM sNeqIsbqshEkPmg0rKFhUlRu3+EYwHs7MQs+bIv/A1Y1HWJpRuxdsErpD7QP1orwDWAs mRZTcfal0x5WcqJUhs519xtzb8zyPhrJinOja744cGKBBeVrxoCzTLN18dscyafik/Hp svRpk+zbNH7lUMlGqjD2sq9sVvAFKkr8bvq4q1kRzYJUMssdRnGLP43+zdY55Ce/6OwE hLzQ== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: domain of dev-bounces@dpdk.org designates 92.243.14.124 as permitted sender) smtp.mailfrom=dev-bounces@dpdk.org; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=nxp.com Return-Path: Received: from dpdk.org (dpdk.org. [92.243.14.124]) by mx.google.com with ESMTP id w24si6440115eju.308.2020.03.02.01.01.34; Mon, 02 Mar 2020 01:01:34 -0800 (PST) Received-SPF: pass (google.com: domain of dev-bounces@dpdk.org designates 92.243.14.124 as permitted sender) client-ip=92.243.14.124; Authentication-Results: mx.google.com; spf=pass (google.com: domain of dev-bounces@dpdk.org designates 92.243.14.124 as permitted sender) smtp.mailfrom=dev-bounces@dpdk.org; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=nxp.com Received: from [92.243.14.124] (localhost [127.0.0.1]) by dpdk.org (Postfix) with ESMTP id 2AF5E1C08E; Mon, 2 Mar 2020 10:00:26 +0100 (CET) Received: from inva020.nxp.com (inva020.nxp.com [92.121.34.13]) by dpdk.org (Postfix) with ESMTP id E07A81C02C for ; Mon, 2 Mar 2020 10:00:19 +0100 (CET) Received: from inva020.nxp.com (localhost [127.0.0.1]) by inva020.eu-rdc02.nxp.com (Postfix) with ESMTP id C52841A0FC8; Mon, 2 Mar 2020 10:00:19 +0100 (CET) Received: from invc005.ap-rdc01.nxp.com (invc005.ap-rdc01.nxp.com [165.114.16.14]) by inva020.eu-rdc02.nxp.com (Postfix) with ESMTP id 437091A0FB4; Mon, 2 Mar 2020 10:00:17 +0100 (CET) Received: from bf-netperf1.ap.com (bf-netperf1.ap.freescale.net [10.232.133.63]) by invc005.ap-rdc01.nxp.com (Postfix) with ESMTP id 0C67F402D5; Mon, 2 Mar 2020 17:00:13 +0800 (SGT) From: Hemant Agrawal To: ferruh.yigit@intel.com Cc: dev@dpdk.org, g.singh@nxp.com, Alex Marginean Date: Mon, 2 Mar 2020 20:02:06 +0530 Message-Id: <20200302143209.11854-8-hemant.agrawal@nxp.com> X-Mailer: git-send-email 2.17.1 In-Reply-To: <20200302143209.11854-1-hemant.agrawal@nxp.com> References: <20200302143209.11854-1-hemant.agrawal@nxp.com> X-Virus-Scanned: ClamAV using ClamSMTP Subject: [dpdk-dev] [PATCH 07/10] net/enetc: use bulk alloc in Rx refill ring X-BeenThere: dev@dpdk.org X-Mailman-Version: 2.1.15 Precedence: list List-Id: DPDK patches and discussions List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , Errors-To: dev-bounces@dpdk.org Sender: "dev" From: Alex Marginean Since we know in advance that we're going to fill in multiple descriptors it's convenient to allocate the buffers in batches. Signed-off-by: Alex Marginean --- drivers/net/enetc/enetc_rxtx.c | 21 +++++++++++++++++---- 1 file changed, 17 insertions(+), 4 deletions(-) -- 2.17.1 diff --git a/drivers/net/enetc/enetc_rxtx.c b/drivers/net/enetc/enetc_rxtx.c index 262ed8a0f..8b85c5371 100644 --- a/drivers/net/enetc/enetc_rxtx.c +++ b/drivers/net/enetc/enetc_rxtx.c @@ -14,6 +14,8 @@ #include "enetc.h" #include "enetc_logs.h" +#define ENETC_RXBD_BUNDLE 16 /* Number of buffers to allocate at once */ + static int enetc_clean_tx_ring(struct enetc_bdr *tx_ring) { @@ -107,15 +109,25 @@ enetc_refill_rx_ring(struct enetc_bdr *rx_ring, const int buff_cnt) { struct enetc_swbd *rx_swbd; union enetc_rx_bd *rxbd; - int i, j; + int i, j, k = ENETC_RXBD_BUNDLE; + struct rte_mbuf *m[ENETC_RXBD_BUNDLE]; + struct rte_mempool *mb_pool; i = rx_ring->next_to_use; + mb_pool = rx_ring->mb_pool; rx_swbd = &rx_ring->q_swbd[i]; rxbd = ENETC_RXBD(*rx_ring, i); for (j = 0; j < buff_cnt; j++) { - rx_swbd->buffer_addr = (void *)(uintptr_t) - rte_cpu_to_le_64((uint64_t)(uintptr_t) - rte_pktmbuf_alloc(rx_ring->mb_pool)); + /* bulk alloc for the next up to 8 BDs */ + if (k == ENETC_RXBD_BUNDLE) { + k = 0; + int m_cnt = RTE_MIN(buff_cnt - j, ENETC_RXBD_BUNDLE); + + if (rte_pktmbuf_alloc_bulk(mb_pool, m, m_cnt)) + return -1; + } + + rx_swbd->buffer_addr = m[k]; rxbd->w.addr = (uint64_t)(uintptr_t) rx_swbd->buffer_addr->buf_iova + rx_swbd->buffer_addr->data_off; @@ -124,6 +136,7 @@ enetc_refill_rx_ring(struct enetc_bdr *rx_ring, const int buff_cnt) rx_swbd++; rxbd++; i++; + k++; if (unlikely(i == rx_ring->bd_count)) { i = 0; rxbd = ENETC_RXBD(*rx_ring, 0);