numam-dpdk/lib/librte_cryptodev/rte_cryptodev_pmd.c
Bruce Richardson 369991d997 lib: use SPDX tag for Intel copyright files
Replace the BSD license header with the SPDX tag for files
with only an Intel copyright on them.

Signed-off-by: Bruce Richardson <bruce.richardson@intel.com>
2018-01-04 22:41:39 +01:00

174 lines
3.8 KiB
C

/* SPDX-License-Identifier: BSD-3-Clause
* Copyright(c) 2017 Intel Corporation
*/
#include <rte_malloc.h>
#include "rte_cryptodev_pmd.h"
/**
* Parse name from argument
*/
static int
rte_cryptodev_pmd_parse_name_arg(const char *key __rte_unused,
const char *value, void *extra_args)
{
struct rte_cryptodev_pmd_init_params *params = extra_args;
int n;
n = snprintf(params->name, RTE_CRYPTODEV_NAME_MAX_LEN, "%s", value);
if (n >= RTE_CRYPTODEV_NAME_MAX_LEN)
return -EINVAL;
return 0;
}
/**
* Parse unsigned integer from argument
*/
static int
rte_cryptodev_pmd_parse_uint_arg(const char *key __rte_unused,
const char *value, void *extra_args)
{
int i;
char *end;
errno = 0;
i = strtol(value, &end, 10);
if (*end != 0 || errno != 0 || i < 0)
return -EINVAL;
*((uint32_t *)extra_args) = i;
return 0;
}
int
rte_cryptodev_pmd_parse_input_args(
struct rte_cryptodev_pmd_init_params *params,
const char *args)
{
struct rte_kvargs *kvlist = NULL;
int ret = 0;
if (params == NULL)
return -EINVAL;
if (args) {
kvlist = rte_kvargs_parse(args, cryptodev_pmd_valid_params);
if (kvlist == NULL)
return -EINVAL;
ret = rte_kvargs_process(kvlist,
RTE_CRYPTODEV_PMD_MAX_NB_QP_ARG,
&rte_cryptodev_pmd_parse_uint_arg,
&params->max_nb_queue_pairs);
if (ret < 0)
goto free_kvlist;
ret = rte_kvargs_process(kvlist,
RTE_CRYPTODEV_PMD_MAX_NB_SESS_ARG,
&rte_cryptodev_pmd_parse_uint_arg,
&params->max_nb_sessions);
if (ret < 0)
goto free_kvlist;
ret = rte_kvargs_process(kvlist,
RTE_CRYPTODEV_PMD_SOCKET_ID_ARG,
&rte_cryptodev_pmd_parse_uint_arg,
&params->socket_id);
if (ret < 0)
goto free_kvlist;
ret = rte_kvargs_process(kvlist,
RTE_CRYPTODEV_PMD_NAME_ARG,
&rte_cryptodev_pmd_parse_name_arg,
params);
if (ret < 0)
goto free_kvlist;
}
free_kvlist:
rte_kvargs_free(kvlist);
return ret;
}
struct rte_cryptodev *
rte_cryptodev_pmd_create(const char *name,
struct rte_device *device,
struct rte_cryptodev_pmd_init_params *params)
{
struct rte_cryptodev *cryptodev;
if (params->name[0] != '\0') {
CDEV_LOG_INFO("[%s] User specified device name = %s\n",
device->driver->name, params->name);
name = params->name;
}
CDEV_LOG_INFO("[%s] - Creating cryptodev %s\n",
device->driver->name, name);
CDEV_LOG_INFO("[%s] - Initialisation parameters - name: %s,"
"socket id: %d, max queue pairs: %u, max sessions: %u",
device->driver->name, name,
params->socket_id, params->max_nb_queue_pairs,
params->max_nb_sessions);
/* allocate device structure */
cryptodev = rte_cryptodev_pmd_allocate(name, params->socket_id);
if (cryptodev == NULL) {
CDEV_LOG_ERR("[%s] Failed to allocate crypto device for %s",
device->driver->name, name);
return NULL;
}
/* allocate private device structure */
if (rte_eal_process_type() == RTE_PROC_PRIMARY) {
cryptodev->data->dev_private =
rte_zmalloc_socket("cryptodev device private",
params->private_data_size,
RTE_CACHE_LINE_SIZE,
params->socket_id);
if (cryptodev->data->dev_private == NULL) {
CDEV_LOG_ERR("[%s] Cannot allocate memory for "
"cryptodev %s private data",
device->driver->name, name);
rte_cryptodev_pmd_release_device(cryptodev);
return NULL;
}
}
cryptodev->device = device;
/* initialise user call-back tail queue */
TAILQ_INIT(&(cryptodev->link_intr_cbs));
return cryptodev;
}
int
rte_cryptodev_pmd_destroy(struct rte_cryptodev *cryptodev)
{
int retval;
CDEV_LOG_INFO("[%s] Closing crypto device %s",
cryptodev->device->driver->name,
cryptodev->device->name);
/* free crypto device */
retval = rte_cryptodev_pmd_release_device(cryptodev);
if (retval)
return retval;
if (rte_eal_process_type() == RTE_PROC_PRIMARY)
rte_free(cryptodev->data->dev_private);
cryptodev->device = NULL;
cryptodev->data = NULL;
return 0;
}