mempool/octeontx2: add mempool free op

The DPDK mempool free operation frees HW AURA
and POOL reserved in alloc operation. In addition to that it free all
the memory resources allocated in mempool alloc operations.

Signed-off-by: Jerin Jacob <jerinj@marvell.com>
This commit is contained in:
Jerin Jacob 2019-06-22 18:54:12 +05:30 committed by Thomas Monjalon
parent 7bcc47cbe2
commit ae930c2cd6

View File

@ -47,6 +47,62 @@ npa_lf_aura_pool_init(struct otx2_mbox *mbox, uint32_t aura_id,
return NPA_LF_ERR_AURA_POOL_INIT; return NPA_LF_ERR_AURA_POOL_INIT;
} }
static int
npa_lf_aura_pool_fini(struct otx2_mbox *mbox,
uint32_t aura_id,
uint64_t aura_handle)
{
struct npa_aq_enq_req *aura_req, *pool_req;
struct npa_aq_enq_rsp *aura_rsp, *pool_rsp;
struct otx2_mbox_dev *mdev = &mbox->dev[0];
struct ndc_sync_op *ndc_req;
int rc, off;
/* Procedure for disabling an aura/pool */
rte_delay_us(10);
npa_lf_aura_op_alloc(aura_handle, 0);
pool_req = otx2_mbox_alloc_msg_npa_aq_enq(mbox);
pool_req->aura_id = aura_id;
pool_req->ctype = NPA_AQ_CTYPE_POOL;
pool_req->op = NPA_AQ_INSTOP_WRITE;
pool_req->pool.ena = 0;
pool_req->pool_mask.ena = ~pool_req->pool_mask.ena;
aura_req = otx2_mbox_alloc_msg_npa_aq_enq(mbox);
aura_req->aura_id = aura_id;
aura_req->ctype = NPA_AQ_CTYPE_AURA;
aura_req->op = NPA_AQ_INSTOP_WRITE;
aura_req->aura.ena = 0;
aura_req->aura_mask.ena = ~aura_req->aura_mask.ena;
otx2_mbox_msg_send(mbox, 0);
rc = otx2_mbox_wait_for_rsp(mbox, 0);
if (rc < 0)
return rc;
off = mbox->rx_start +
RTE_ALIGN(sizeof(struct mbox_hdr), MBOX_MSG_ALIGN);
pool_rsp = (struct npa_aq_enq_rsp *)((uintptr_t)mdev->mbase + off);
off = mbox->rx_start + pool_rsp->hdr.next_msgoff;
aura_rsp = (struct npa_aq_enq_rsp *)((uintptr_t)mdev->mbase + off);
if (rc != 2 || aura_rsp->hdr.rc != 0 || pool_rsp->hdr.rc != 0)
return NPA_LF_ERR_AURA_POOL_FINI;
/* Sync NDC-NPA for LF */
ndc_req = otx2_mbox_alloc_msg_ndc_sync_op(mbox);
ndc_req->npa_lf_sync = 1;
rc = otx2_mbox_process(mbox);
if (rc) {
otx2_err("Error on NDC-NPA LF sync, rc %d", rc);
return NPA_LF_ERR_AURA_POOL_FINI;
}
return 0;
}
static inline char* static inline char*
npa_lf_stack_memzone_name(struct otx2_npa_lf *lf, int pool_id, char *name) npa_lf_stack_memzone_name(struct otx2_npa_lf *lf, int pool_id, char *name)
{ {
@ -65,6 +121,18 @@ npa_lf_stack_dma_alloc(struct otx2_npa_lf *lf, char *name,
RTE_MEMZONE_IOVA_CONTIG, OTX2_ALIGN); RTE_MEMZONE_IOVA_CONTIG, OTX2_ALIGN);
} }
static inline int
npa_lf_stack_dma_free(struct otx2_npa_lf *lf, char *name, int pool_id)
{
const struct rte_memzone *mz;
mz = rte_memzone_lookup(npa_lf_stack_memzone_name(lf, pool_id, name));
if (mz == NULL)
return -EINVAL;
return rte_memzone_free(mz);
}
static inline int static inline int
bitmap_ctzll(uint64_t slab) bitmap_ctzll(uint64_t slab)
{ {
@ -179,6 +247,24 @@ exit:
return rc; return rc;
} }
static int
npa_lf_aura_pool_pair_free(struct otx2_npa_lf *lf, uint64_t aura_handle)
{
char name[RTE_MEMZONE_NAMESIZE];
int aura_id, pool_id, rc;
if (!lf || !aura_handle)
return NPA_LF_ERR_PARAM;
aura_id = pool_id = npa_lf_aura_handle_to_aura(aura_handle);
rc = npa_lf_aura_pool_fini(lf->mbox, aura_id, aura_handle);
rc |= npa_lf_stack_dma_free(lf, name, pool_id);
rte_bitmap_set(lf->npa_bmp, aura_id);
return rc;
}
static int static int
otx2_npa_alloc(struct rte_mempool *mp) otx2_npa_alloc(struct rte_mempool *mp)
{ {
@ -238,9 +324,27 @@ error:
return rc; return rc;
} }
static void
otx2_npa_free(struct rte_mempool *mp)
{
struct otx2_npa_lf *lf = otx2_npa_lf_obj_get();
int rc = 0;
otx2_npa_dbg("lf=%p aura_handle=0x%"PRIx64, lf, mp->pool_id);
if (lf != NULL)
rc = npa_lf_aura_pool_pair_free(lf, mp->pool_id);
if (rc)
otx2_err("Failed to free pool or aura rc=%d", rc);
/* Release the reference of npalf */
otx2_npa_lf_fini();
}
static struct rte_mempool_ops otx2_npa_ops = { static struct rte_mempool_ops otx2_npa_ops = {
.name = "octeontx2_npa", .name = "octeontx2_npa",
.alloc = otx2_npa_alloc, .alloc = otx2_npa_alloc,
.free = otx2_npa_free,
}; };
MEMPOOL_REGISTER_OPS(otx2_npa_ops); MEMPOOL_REGISTER_OPS(otx2_npa_ops);