From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: Received: from mails.dpdk.org (mails.dpdk.org [217.70.189.124]) by inbox.dpdk.org (Postfix) with ESMTP id 54E83A0558; Mon, 5 Sep 2022 15:35:39 +0200 (CEST) Received: from [217.70.189.124] (localhost [127.0.0.1]) by mails.dpdk.org (Postfix) with ESMTP id D7B6C42B8D; Mon, 5 Sep 2022 15:35:04 +0200 (CEST) Received: from mx0b-0016f401.pphosted.com (mx0b-0016f401.pphosted.com [67.231.156.173]) by mails.dpdk.org (Postfix) with ESMTP id 33C2F42B73 for ; Mon, 5 Sep 2022 15:35:04 +0200 (CEST) Received: from pps.filterd (m0045851.ppops.net [127.0.0.1]) by mx0b-0016f401.pphosted.com (8.17.1.5/8.17.1.5) with ESMTP id 285BlwpD019240; Mon, 5 Sep 2022 06:32:57 -0700 DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=marvell.com; h=from : to : cc : subject : date : message-id : in-reply-to : references : mime-version : content-transfer-encoding : content-type; s=pfpt0220; bh=Ai24LKOM/8FphD157Ut1q3Ljz1rRXk5HbKenO/VxANU=; b=BcVM2Q9IgWw6wmGOer1mczVQi12I7UlJ5NTGYLuZS4U0puW49xzXqbMhekcAQul0qnJY V6gLgm8Uyn54GLz3LEzqjhx8FhGnLKldofDWQhlX9z4lPHm+x1ehGOUrzmnQq8EpTFLb HeeCZM9h+w1oGxN3UbS1GNi5/OT1jiFjteOQ8M1E3WAvX6K9IHUbLZkE9i13oBtNe//+ x7SwkWlP4jEBMsHY9jYTWmWgOXeyzu55s6EsBDyqsjvIiv0jU1ksA5XJeKQn+U6P0+34 CwdNSgVscLBBFNDtmROK9ixK1MvbJOSioyzy+MdbixVPYq0HGUwnVfvJWB3jqLrIoNPm hQ== Received: from dc5-exch01.marvell.com ([199.233.59.181]) by mx0b-0016f401.pphosted.com (PPS) with ESMTPS id 3jc6epngdp-1 (version=TLSv1.2 cipher=ECDHE-RSA-AES256-SHA384 bits=256 verify=NOT); Mon, 05 Sep 2022 06:32:57 -0700 Received: from DC5-EXCH02.marvell.com (10.69.176.39) by DC5-EXCH01.marvell.com (10.69.176.38) with Microsoft SMTP Server (TLS) id 15.0.1497.2; Mon, 5 Sep 2022 06:32:54 -0700 Received: from maili.marvell.com (10.69.176.80) by DC5-EXCH02.marvell.com (10.69.176.39) with Microsoft SMTP Server id 15.0.1497.18 via Frontend Transport; Mon, 5 Sep 2022 06:32:54 -0700 Received: from localhost.localdomain (unknown [10.29.52.204]) by maili.marvell.com (Postfix) with ESMTP id 217955E686D; Mon, 5 Sep 2022 06:32:51 -0700 (PDT) From: Nithin Dabilpuram To: Nithin Dabilpuram , Kiran Kumar K , Sunil Kumar Kori , Satha Rao , Ray Kinsella , Ashwin Sekhar T K , Pavan Nikhilesh CC: , Subject: [PATCH v2 08/31] common/cnxk: reserve aura zero on cn10ka NPA Date: Mon, 5 Sep 2022 19:02:05 +0530 Message-ID: <20220905133228.818616-8-ndabilpuram@marvell.com> X-Mailer: git-send-email 2.25.1 In-Reply-To: <20220905133228.818616-1-ndabilpuram@marvell.com> References: <20220809184908.24030-1-ndabilpuram@marvell.com> <20220905133228.818616-1-ndabilpuram@marvell.com> MIME-Version: 1.0 Content-Transfer-Encoding: 8bit Content-Type: text/plain X-Proofpoint-ORIG-GUID: OdndWb159ib9EalZOzqWBDA821Jgyevp X-Proofpoint-GUID: OdndWb159ib9EalZOzqWBDA821Jgyevp X-Proofpoint-Virus-Version: vendor=baseguard engine=ICAP:2.0.205,Aquarius:18.0.895,Hydra:6.0.517,FMLib:17.11.122.1 definitions=2022-09-05_09,2022-09-05_02,2022-06-22_01 X-BeenThere: dev@dpdk.org X-Mailman-Version: 2.1.29 Precedence: list List-Id: DPDK patches and discussions List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , Errors-To: dev-bounces@dpdk.org Reserve aura id 0 on cn10k and provide mechanism to specifically allocate it and free it via roc_npa_* API's. Signed-off-by: Nithin Dabilpuram --- drivers/common/cnxk/roc_dpi.c | 2 +- drivers/common/cnxk/roc_nix_queue.c | 2 +- drivers/common/cnxk/roc_npa.c | 100 +++++++++++++++++++----- drivers/common/cnxk/roc_npa.h | 6 +- drivers/common/cnxk/roc_npa_priv.h | 1 + drivers/common/cnxk/roc_sso.c | 2 +- drivers/common/cnxk/version.map | 1 + drivers/mempool/cnxk/cnxk_mempool_ops.c | 7 +- 8 files changed, 97 insertions(+), 24 deletions(-) diff --git a/drivers/common/cnxk/roc_dpi.c b/drivers/common/cnxk/roc_dpi.c index 23b2cc41a4..93c8318a3d 100644 --- a/drivers/common/cnxk/roc_dpi.c +++ b/drivers/common/cnxk/roc_dpi.c @@ -75,7 +75,7 @@ roc_dpi_configure(struct roc_dpi *roc_dpi) memset(&aura, 0, sizeof(aura)); rc = roc_npa_pool_create(&aura_handle, DPI_CMD_QUEUE_SIZE, - DPI_CMD_QUEUE_BUFS, &aura, &pool); + DPI_CMD_QUEUE_BUFS, &aura, &pool, 0); if (rc) { plt_err("Failed to create NPA pool, err %d\n", rc); return rc; diff --git a/drivers/common/cnxk/roc_nix_queue.c b/drivers/common/cnxk/roc_nix_queue.c index 692b13415a..70b4516eca 100644 --- a/drivers/common/cnxk/roc_nix_queue.c +++ b/drivers/common/cnxk/roc_nix_queue.c @@ -713,7 +713,7 @@ sqb_pool_populate(struct roc_nix *roc_nix, struct roc_nix_sq *sq) aura.fc_addr = (uint64_t)sq->fc; aura.fc_hyst_bits = 0; /* Store count on all updates */ rc = roc_npa_pool_create(&sq->aura_handle, blk_sz, nb_sqb_bufs, &aura, - &pool); + &pool, 0); if (rc) goto fail; diff --git a/drivers/common/cnxk/roc_npa.c b/drivers/common/cnxk/roc_npa.c index 1e60f443f0..760a2315b2 100644 --- a/drivers/common/cnxk/roc_npa.c +++ b/drivers/common/cnxk/roc_npa.c @@ -260,16 +260,60 @@ bitmap_ctzll(uint64_t slab) return __builtin_ctzll(slab); } +static int +find_free_aura(struct npa_lf *lf, uint32_t flags) +{ + struct plt_bitmap *bmp = lf->npa_bmp; + uint64_t aura0_state = 0; + uint64_t slab; + uint32_t pos; + int idx = -1; + int rc; + + if (flags & ROC_NPA_ZERO_AURA_F) { + /* Only look for zero aura */ + if (plt_bitmap_get(bmp, 0)) + return 0; + plt_err("Zero aura already in use"); + return -1; + } + + if (lf->zero_aura_rsvd) { + /* Save and clear zero aura bit if needed */ + aura0_state = plt_bitmap_get(bmp, 0); + if (aura0_state) + plt_bitmap_clear(bmp, 0); + } + + pos = 0; + slab = 0; + /* Scan from the beginning */ + plt_bitmap_scan_init(bmp); + /* Scan bitmap to get the free pool */ + rc = plt_bitmap_scan(bmp, &pos, &slab); + /* Empty bitmap */ + if (rc == 0) { + plt_err("Aura's exhausted"); + goto empty; + } + + idx = pos + bitmap_ctzll(slab); +empty: + if (lf->zero_aura_rsvd && aura0_state) + plt_bitmap_set(bmp, 0); + + return idx; +} + static int npa_aura_pool_pair_alloc(struct npa_lf *lf, const uint32_t block_size, const uint32_t block_count, struct npa_aura_s *aura, - struct npa_pool_s *pool, uint64_t *aura_handle) + struct npa_pool_s *pool, uint64_t *aura_handle, + uint32_t flags) { int rc, aura_id, pool_id, stack_size, alloc_size; char name[PLT_MEMZONE_NAMESIZE]; const struct plt_memzone *mz; - uint64_t slab; - uint32_t pos; /* Sanity check */ if (!lf || !block_size || !block_count || !pool || !aura || @@ -281,20 +325,11 @@ npa_aura_pool_pair_alloc(struct npa_lf *lf, const uint32_t block_size, block_size > ROC_NPA_MAX_BLOCK_SZ) return NPA_ERR_INVALID_BLOCK_SZ; - pos = 0; - slab = 0; - /* Scan from the beginning */ - plt_bitmap_scan_init(lf->npa_bmp); - /* Scan bitmap to get the free pool */ - rc = plt_bitmap_scan(lf->npa_bmp, &pos, &slab); - /* Empty bitmap */ - if (rc == 0) { - plt_err("Mempools exhausted"); - return NPA_ERR_AURA_ID_ALLOC; - } - /* Get aura_id from resource bitmap */ - aura_id = pos + bitmap_ctzll(slab); + aura_id = find_free_aura(lf, flags); + if (aura_id < 0) + return NPA_ERR_AURA_ID_ALLOC; + /* Mark pool as reserved */ plt_bitmap_clear(lf->npa_bmp, aura_id); @@ -374,7 +409,7 @@ npa_aura_pool_pair_alloc(struct npa_lf *lf, const uint32_t block_size, int roc_npa_pool_create(uint64_t *aura_handle, uint32_t block_size, uint32_t block_count, struct npa_aura_s *aura, - struct npa_pool_s *pool) + struct npa_pool_s *pool, uint32_t flags) { struct npa_aura_s defaura; struct npa_pool_s defpool; @@ -394,6 +429,11 @@ roc_npa_pool_create(uint64_t *aura_handle, uint32_t block_size, goto error; } + if (flags & ROC_NPA_ZERO_AURA_F && !lf->zero_aura_rsvd) { + rc = NPA_ERR_ALLOC; + goto error; + } + if (aura == NULL) { memset(&defaura, 0, sizeof(struct npa_aura_s)); aura = &defaura; @@ -406,7 +446,7 @@ roc_npa_pool_create(uint64_t *aura_handle, uint32_t block_size, } rc = npa_aura_pool_pair_alloc(lf, block_size, block_count, aura, pool, - aura_handle); + aura_handle, flags); if (rc) { plt_err("Failed to alloc pool or aura rc=%d", rc); goto error; @@ -522,6 +562,26 @@ roc_npa_pool_range_update_check(uint64_t aura_handle) return 0; } +uint64_t +roc_npa_zero_aura_handle(void) +{ + struct idev_cfg *idev; + struct npa_lf *lf; + + lf = idev_npa_obj_get(); + if (lf == NULL) + return NPA_ERR_DEVICE_NOT_BOUNDED; + + idev = idev_get_cfg(); + if (idev == NULL) + return NPA_ERR_ALLOC; + + /* Return aura handle only if reserved */ + if (lf->zero_aura_rsvd) + return roc_npa_aura_handle_gen(0, lf->base); + return 0; +} + static inline int npa_attach(struct mbox *mbox) { @@ -672,6 +732,10 @@ npa_dev_init(struct npa_lf *lf, uintptr_t base, struct mbox *mbox) for (i = 0; i < nr_pools; i++) plt_bitmap_set(lf->npa_bmp, i); + /* Reserve zero aura for all models other than CN9K */ + if (!roc_model_is_cn9k()) + lf->zero_aura_rsvd = true; + /* Allocate memory for qint context */ lf->npa_qint_mem = plt_zmalloc(sizeof(struct npa_qint) * nr_pools, 0); if (lf->npa_qint_mem == NULL) { diff --git a/drivers/common/cnxk/roc_npa.h b/drivers/common/cnxk/roc_npa.h index 59d13d88a1..69129cb4cc 100644 --- a/drivers/common/cnxk/roc_npa.h +++ b/drivers/common/cnxk/roc_npa.h @@ -711,10 +711,13 @@ struct roc_npa { int __roc_api roc_npa_dev_init(struct roc_npa *roc_npa); int __roc_api roc_npa_dev_fini(struct roc_npa *roc_npa); +/* Flags to pool create */ +#define ROC_NPA_ZERO_AURA_F BIT(0) + /* NPA pool */ int __roc_api roc_npa_pool_create(uint64_t *aura_handle, uint32_t block_size, uint32_t block_count, struct npa_aura_s *aura, - struct npa_pool_s *pool); + struct npa_pool_s *pool, uint32_t flags); int __roc_api roc_npa_aura_limit_modify(uint64_t aura_handle, uint16_t aura_limit); int __roc_api roc_npa_pool_destroy(uint64_t aura_handle); @@ -722,6 +725,7 @@ int __roc_api roc_npa_pool_range_update_check(uint64_t aura_handle); void __roc_api roc_npa_aura_op_range_set(uint64_t aura_handle, uint64_t start_iova, uint64_t end_iova); +uint64_t __roc_api roc_npa_zero_aura_handle(void); /* Init callbacks */ typedef int (*roc_npa_lf_init_cb_t)(struct plt_pci_device *pci_dev); diff --git a/drivers/common/cnxk/roc_npa_priv.h b/drivers/common/cnxk/roc_npa_priv.h index 5a02a61e00..de3d5448ba 100644 --- a/drivers/common/cnxk/roc_npa_priv.h +++ b/drivers/common/cnxk/roc_npa_priv.h @@ -32,6 +32,7 @@ struct npa_lf { uint8_t aura_sz; uint32_t qints; uintptr_t base; + bool zero_aura_rsvd; }; struct npa_qint { diff --git a/drivers/common/cnxk/roc_sso.c b/drivers/common/cnxk/roc_sso.c index 126a9cba99..4bee5a97e1 100644 --- a/drivers/common/cnxk/roc_sso.c +++ b/drivers/common/cnxk/roc_sso.c @@ -473,7 +473,7 @@ sso_hwgrp_init_xaq_aura(struct dev *dev, struct roc_sso_xaq_data *xaq, aura.fc_addr = (uint64_t)xaq->fc; aura.fc_hyst_bits = 0; /* Store count on all updates */ rc = roc_npa_pool_create(&xaq->aura_handle, xaq_buf_size, xaq->nb_xaq, - &aura, &pool); + &aura, &pool, 0); if (rc) { plt_err("Failed to create XAQ pool"); goto npa_fail; diff --git a/drivers/common/cnxk/version.map b/drivers/common/cnxk/version.map index 6d43e37d1e..6c05e893e3 100644 --- a/drivers/common/cnxk/version.map +++ b/drivers/common/cnxk/version.map @@ -318,6 +318,7 @@ INTERNAL { roc_npa_pool_destroy; roc_npa_pool_op_pc_reset; roc_npa_pool_range_update_check; + roc_npa_zero_aura_handle; roc_npc_fini; roc_npc_flow_create; roc_npc_flow_destroy; diff --git a/drivers/mempool/cnxk/cnxk_mempool_ops.c b/drivers/mempool/cnxk/cnxk_mempool_ops.c index c7b75f026d..a0b94bb95c 100644 --- a/drivers/mempool/cnxk/cnxk_mempool_ops.c +++ b/drivers/mempool/cnxk/cnxk_mempool_ops.c @@ -72,10 +72,10 @@ cnxk_mempool_calc_mem_size(const struct rte_mempool *mp, uint32_t obj_num, int cnxk_mempool_alloc(struct rte_mempool *mp) { + uint32_t block_count, flags = 0; uint64_t aura_handle = 0; struct npa_aura_s aura; struct npa_pool_s pool; - uint32_t block_count; size_t block_size; int rc = -ERANGE; @@ -100,8 +100,11 @@ cnxk_mempool_alloc(struct rte_mempool *mp) if (mp->pool_config != NULL) memcpy(&aura, mp->pool_config, sizeof(struct npa_aura_s)); + if (aura.ena && aura.pool_addr == 0) + flags = ROC_NPA_ZERO_AURA_F; + rc = roc_npa_pool_create(&aura_handle, block_size, block_count, &aura, - &pool); + &pool, flags); if (rc) { plt_err("Failed to alloc pool or aura rc=%d", rc); goto error; -- 2.25.1