2019-10-01 06:41:25 +00:00
|
|
|
/* SPDX-License-Identifier: BSD-3-Clause
|
|
|
|
* Copyright(C) 2019 Marvell International Ltd.
|
|
|
|
*/
|
|
|
|
|
|
|
|
#include <rte_cryptodev.h>
|
|
|
|
#include <rte_malloc.h>
|
|
|
|
|
|
|
|
#include "nitrox_qp.h"
|
|
|
|
#include "nitrox_hal.h"
|
|
|
|
#include "nitrox_logs.h"
|
|
|
|
|
|
|
|
#define MAX_CMD_QLEN 16384
|
2019-10-01 06:41:27 +00:00
|
|
|
#define CMDQ_PKT_IN_ALIGN 16
|
|
|
|
|
|
|
|
static int
|
|
|
|
nitrox_setup_cmdq(struct nitrox_qp *qp, uint8_t *bar_addr,
|
|
|
|
const char *dev_name, uint8_t instr_size, int socket_id)
|
|
|
|
{
|
|
|
|
char mz_name[RTE_MEMZONE_NAMESIZE];
|
|
|
|
const struct rte_memzone *mz;
|
|
|
|
size_t cmdq_size = qp->count * instr_size;
|
|
|
|
uint64_t offset;
|
|
|
|
|
|
|
|
snprintf(mz_name, sizeof(mz_name), "%s_cmdq_%d", dev_name, qp->qno);
|
|
|
|
mz = rte_memzone_reserve_aligned(mz_name, cmdq_size, socket_id,
|
|
|
|
RTE_MEMZONE_SIZE_HINT_ONLY |
|
|
|
|
RTE_MEMZONE_256MB,
|
|
|
|
CMDQ_PKT_IN_ALIGN);
|
|
|
|
if (!mz) {
|
|
|
|
NITROX_LOG(ERR, "cmdq memzone reserve failed for %s queue\n",
|
|
|
|
mz_name);
|
|
|
|
return -ENOMEM;
|
|
|
|
}
|
|
|
|
|
|
|
|
qp->cmdq.mz = mz;
|
|
|
|
offset = NPS_PKT_IN_INSTR_BAOFF_DBELLX(qp->qno);
|
|
|
|
qp->cmdq.dbell_csr_addr = NITROX_CSR_ADDR(bar_addr, offset);
|
|
|
|
qp->cmdq.ring = mz->addr;
|
|
|
|
qp->cmdq.instr_size = instr_size;
|
|
|
|
setup_nps_pkt_input_ring(bar_addr, qp->qno, qp->count, mz->iova);
|
|
|
|
setup_nps_pkt_solicit_output_port(bar_addr, qp->qno);
|
|
|
|
|
|
|
|
return 0;
|
|
|
|
}
|
2019-10-01 06:41:25 +00:00
|
|
|
|
|
|
|
static int
|
|
|
|
nitrox_setup_ridq(struct nitrox_qp *qp, int socket_id)
|
|
|
|
{
|
|
|
|
size_t ridq_size = qp->count * sizeof(*qp->ridq);
|
|
|
|
|
|
|
|
qp->ridq = rte_zmalloc_socket("nitrox ridq", ridq_size,
|
|
|
|
RTE_CACHE_LINE_SIZE,
|
|
|
|
socket_id);
|
|
|
|
if (!qp->ridq) {
|
|
|
|
NITROX_LOG(ERR, "Failed to create rid queue\n");
|
|
|
|
return -ENOMEM;
|
|
|
|
}
|
|
|
|
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
2019-10-01 06:41:27 +00:00
|
|
|
static int
|
|
|
|
nitrox_release_cmdq(struct nitrox_qp *qp, uint8_t *bar_addr)
|
|
|
|
{
|
|
|
|
nps_pkt_solicited_port_disable(bar_addr, qp->qno);
|
|
|
|
nps_pkt_input_ring_disable(bar_addr, qp->qno);
|
|
|
|
return rte_memzone_free(qp->cmdq.mz);
|
|
|
|
}
|
|
|
|
|
2019-10-01 06:41:25 +00:00
|
|
|
int
|
|
|
|
nitrox_qp_setup(struct nitrox_qp *qp, uint8_t *bar_addr, const char *dev_name,
|
|
|
|
uint32_t nb_descriptors, uint8_t instr_size, int socket_id)
|
|
|
|
{
|
|
|
|
int err;
|
|
|
|
uint32_t count;
|
|
|
|
|
|
|
|
count = rte_align32pow2(nb_descriptors);
|
|
|
|
if (count > MAX_CMD_QLEN) {
|
|
|
|
NITROX_LOG(ERR, "%s: Number of descriptors too big %d,"
|
|
|
|
" greater than max queue length %d\n",
|
|
|
|
dev_name, count,
|
|
|
|
MAX_CMD_QLEN);
|
|
|
|
return -EINVAL;
|
|
|
|
}
|
|
|
|
|
|
|
|
qp->count = count;
|
|
|
|
qp->head = qp->tail = 0;
|
|
|
|
rte_atomic16_init(&qp->pending_count);
|
2019-10-01 06:41:27 +00:00
|
|
|
err = nitrox_setup_cmdq(qp, bar_addr, dev_name, instr_size, socket_id);
|
|
|
|
if (err)
|
|
|
|
return err;
|
|
|
|
|
2019-10-01 06:41:25 +00:00
|
|
|
err = nitrox_setup_ridq(qp, socket_id);
|
|
|
|
if (err)
|
|
|
|
goto ridq_err;
|
|
|
|
|
|
|
|
return 0;
|
|
|
|
|
|
|
|
ridq_err:
|
2019-10-01 06:41:27 +00:00
|
|
|
nitrox_release_cmdq(qp, bar_addr);
|
2019-10-01 06:41:25 +00:00
|
|
|
return err;
|
|
|
|
}
|
|
|
|
|
|
|
|
static void
|
|
|
|
nitrox_release_ridq(struct nitrox_qp *qp)
|
|
|
|
{
|
|
|
|
rte_free(qp->ridq);
|
|
|
|
}
|
|
|
|
|
|
|
|
int
|
|
|
|
nitrox_qp_release(struct nitrox_qp *qp, uint8_t *bar_addr)
|
|
|
|
{
|
|
|
|
nitrox_release_ridq(qp);
|
2019-10-01 06:41:27 +00:00
|
|
|
return nitrox_release_cmdq(qp, bar_addr);
|
2019-10-01 06:41:25 +00:00
|
|
|
}
|