1 /* SPDX-License-Identifier: BSD-3-Clause
2 * Copyright(c) 2017 Intel Corporation
5 #include <rte_malloc.h>
7 #include "rte_cryptodev_pmd.h"
10 * Parse name from argument
13 rte_cryptodev_pmd_parse_name_arg(const char *key __rte_unused,
14 const char *value, void *extra_args)
16 struct rte_cryptodev_pmd_init_params *params = extra_args;
19 n = snprintf(params->name, RTE_CRYPTODEV_NAME_MAX_LEN, "%s", value);
20 if (n >= RTE_CRYPTODEV_NAME_MAX_LEN)
27 * Parse unsigned integer from argument
30 rte_cryptodev_pmd_parse_uint_arg(const char *key __rte_unused,
31 const char *value, void *extra_args)
37 i = strtol(value, &end, 10);
38 if (*end != 0 || errno != 0 || i < 0)
41 *((uint32_t *)extra_args) = i;
46 rte_cryptodev_pmd_parse_input_args(
47 struct rte_cryptodev_pmd_init_params *params,
50 struct rte_kvargs *kvlist = NULL;
57 kvlist = rte_kvargs_parse(args, cryptodev_pmd_valid_params);
61 ret = rte_kvargs_process(kvlist,
62 RTE_CRYPTODEV_PMD_MAX_NB_QP_ARG,
63 &rte_cryptodev_pmd_parse_uint_arg,
64 ¶ms->max_nb_queue_pairs);
68 ret = rte_kvargs_process(kvlist,
69 RTE_CRYPTODEV_PMD_MAX_NB_SESS_ARG,
70 &rte_cryptodev_pmd_parse_uint_arg,
71 ¶ms->max_nb_sessions);
75 ret = rte_kvargs_process(kvlist,
76 RTE_CRYPTODEV_PMD_SOCKET_ID_ARG,
77 &rte_cryptodev_pmd_parse_uint_arg,
82 ret = rte_kvargs_process(kvlist,
83 RTE_CRYPTODEV_PMD_NAME_ARG,
84 &rte_cryptodev_pmd_parse_name_arg,
91 rte_kvargs_free(kvlist);
95 struct rte_cryptodev *
96 rte_cryptodev_pmd_create(const char *name,
97 struct rte_device *device,
98 struct rte_cryptodev_pmd_init_params *params)
100 struct rte_cryptodev *cryptodev;
102 if (params->name[0] != '\0') {
103 CDEV_LOG_INFO("[%s] User specified device name = %s\n",
104 device->driver->name, params->name);
108 CDEV_LOG_INFO("[%s] - Creating cryptodev %s\n",
109 device->driver->name, name);
111 CDEV_LOG_INFO("[%s] - Initialisation parameters - name: %s,"
112 "socket id: %d, max queue pairs: %u, max sessions: %u",
113 device->driver->name, name,
114 params->socket_id, params->max_nb_queue_pairs,
115 params->max_nb_sessions);
117 /* allocate device structure */
118 cryptodev = rte_cryptodev_pmd_allocate(name, params->socket_id);
119 if (cryptodev == NULL) {
120 CDEV_LOG_ERR("[%s] Failed to allocate crypto device for %s",
121 device->driver->name, name);
125 /* allocate private device structure */
126 if (rte_eal_process_type() == RTE_PROC_PRIMARY) {
127 cryptodev->data->dev_private =
128 rte_zmalloc_socket("cryptodev device private",
129 params->private_data_size,
133 if (cryptodev->data->dev_private == NULL) {
134 CDEV_LOG_ERR("[%s] Cannot allocate memory for "
135 "cryptodev %s private data",
136 device->driver->name, name);
138 rte_cryptodev_pmd_release_device(cryptodev);
143 cryptodev->device = device;
145 /* initialise user call-back tail queue */
146 TAILQ_INIT(&(cryptodev->link_intr_cbs));
152 rte_cryptodev_pmd_destroy(struct rte_cryptodev *cryptodev)
156 CDEV_LOG_INFO("[%s] Closing crypto device %s",
157 cryptodev->device->driver->name,
158 cryptodev->device->name);
160 /* free crypto device */
161 retval = rte_cryptodev_pmd_release_device(cryptodev);
165 if (rte_eal_process_type() == RTE_PROC_PRIMARY)
166 rte_free(cryptodev->data->dev_private);
169 cryptodev->device = NULL;
170 cryptodev->data = NULL;