1d30ea906Sjfb8856606 /* SPDX-License-Identifier: BSD-3-Clause
2d30ea906Sjfb8856606 * Copyright(c) 2017 Intel Corporation
32bfe3f2eSlogwang */
42bfe3f2eSlogwang
5*4418919fSjohnjiang #include <rte_string_fns.h>
62bfe3f2eSlogwang #include <rte_malloc.h>
72bfe3f2eSlogwang
82bfe3f2eSlogwang #include "rte_cryptodev_pmd.h"
92bfe3f2eSlogwang
102bfe3f2eSlogwang /**
112bfe3f2eSlogwang * Parse name from argument
122bfe3f2eSlogwang */
132bfe3f2eSlogwang static int
rte_cryptodev_pmd_parse_name_arg(const char * key __rte_unused,const char * value,void * extra_args)142bfe3f2eSlogwang rte_cryptodev_pmd_parse_name_arg(const char *key __rte_unused,
152bfe3f2eSlogwang const char *value, void *extra_args)
162bfe3f2eSlogwang {
172bfe3f2eSlogwang struct rte_cryptodev_pmd_init_params *params = extra_args;
182bfe3f2eSlogwang int n;
192bfe3f2eSlogwang
20*4418919fSjohnjiang n = strlcpy(params->name, value, RTE_CRYPTODEV_NAME_MAX_LEN);
212bfe3f2eSlogwang if (n >= RTE_CRYPTODEV_NAME_MAX_LEN)
222bfe3f2eSlogwang return -EINVAL;
232bfe3f2eSlogwang
242bfe3f2eSlogwang return 0;
252bfe3f2eSlogwang }
262bfe3f2eSlogwang
272bfe3f2eSlogwang /**
282bfe3f2eSlogwang * Parse unsigned integer from argument
292bfe3f2eSlogwang */
302bfe3f2eSlogwang static int
rte_cryptodev_pmd_parse_uint_arg(const char * key __rte_unused,const char * value,void * extra_args)312bfe3f2eSlogwang rte_cryptodev_pmd_parse_uint_arg(const char *key __rte_unused,
322bfe3f2eSlogwang const char *value, void *extra_args)
332bfe3f2eSlogwang {
342bfe3f2eSlogwang int i;
352bfe3f2eSlogwang char *end;
362bfe3f2eSlogwang errno = 0;
372bfe3f2eSlogwang
382bfe3f2eSlogwang i = strtol(value, &end, 10);
392bfe3f2eSlogwang if (*end != 0 || errno != 0 || i < 0)
402bfe3f2eSlogwang return -EINVAL;
412bfe3f2eSlogwang
422bfe3f2eSlogwang *((uint32_t *)extra_args) = i;
432bfe3f2eSlogwang return 0;
442bfe3f2eSlogwang }
452bfe3f2eSlogwang
462bfe3f2eSlogwang int
rte_cryptodev_pmd_parse_input_args(struct rte_cryptodev_pmd_init_params * params,const char * args)472bfe3f2eSlogwang rte_cryptodev_pmd_parse_input_args(
482bfe3f2eSlogwang struct rte_cryptodev_pmd_init_params *params,
492bfe3f2eSlogwang const char *args)
502bfe3f2eSlogwang {
512bfe3f2eSlogwang struct rte_kvargs *kvlist = NULL;
522bfe3f2eSlogwang int ret = 0;
532bfe3f2eSlogwang
542bfe3f2eSlogwang if (params == NULL)
552bfe3f2eSlogwang return -EINVAL;
562bfe3f2eSlogwang
572bfe3f2eSlogwang if (args) {
582bfe3f2eSlogwang kvlist = rte_kvargs_parse(args, cryptodev_pmd_valid_params);
592bfe3f2eSlogwang if (kvlist == NULL)
602bfe3f2eSlogwang return -EINVAL;
612bfe3f2eSlogwang
622bfe3f2eSlogwang ret = rte_kvargs_process(kvlist,
632bfe3f2eSlogwang RTE_CRYPTODEV_PMD_MAX_NB_QP_ARG,
642bfe3f2eSlogwang &rte_cryptodev_pmd_parse_uint_arg,
652bfe3f2eSlogwang ¶ms->max_nb_queue_pairs);
662bfe3f2eSlogwang if (ret < 0)
672bfe3f2eSlogwang goto free_kvlist;
682bfe3f2eSlogwang
692bfe3f2eSlogwang ret = rte_kvargs_process(kvlist,
702bfe3f2eSlogwang RTE_CRYPTODEV_PMD_SOCKET_ID_ARG,
712bfe3f2eSlogwang &rte_cryptodev_pmd_parse_uint_arg,
722bfe3f2eSlogwang ¶ms->socket_id);
732bfe3f2eSlogwang if (ret < 0)
742bfe3f2eSlogwang goto free_kvlist;
752bfe3f2eSlogwang
762bfe3f2eSlogwang ret = rte_kvargs_process(kvlist,
772bfe3f2eSlogwang RTE_CRYPTODEV_PMD_NAME_ARG,
782bfe3f2eSlogwang &rte_cryptodev_pmd_parse_name_arg,
792bfe3f2eSlogwang params);
802bfe3f2eSlogwang if (ret < 0)
812bfe3f2eSlogwang goto free_kvlist;
822bfe3f2eSlogwang }
832bfe3f2eSlogwang
842bfe3f2eSlogwang free_kvlist:
852bfe3f2eSlogwang rte_kvargs_free(kvlist);
862bfe3f2eSlogwang return ret;
872bfe3f2eSlogwang }
882bfe3f2eSlogwang
892bfe3f2eSlogwang struct rte_cryptodev *
rte_cryptodev_pmd_create(const char * name,struct rte_device * device,struct rte_cryptodev_pmd_init_params * params)902bfe3f2eSlogwang rte_cryptodev_pmd_create(const char *name,
912bfe3f2eSlogwang struct rte_device *device,
922bfe3f2eSlogwang struct rte_cryptodev_pmd_init_params *params)
932bfe3f2eSlogwang {
942bfe3f2eSlogwang struct rte_cryptodev *cryptodev;
952bfe3f2eSlogwang
962bfe3f2eSlogwang if (params->name[0] != '\0') {
97d30ea906Sjfb8856606 CDEV_LOG_INFO("User specified device name = %s\n", params->name);
982bfe3f2eSlogwang name = params->name;
992bfe3f2eSlogwang }
1002bfe3f2eSlogwang
101d30ea906Sjfb8856606 CDEV_LOG_INFO("Creating cryptodev %s\n", name);
1022bfe3f2eSlogwang
103d30ea906Sjfb8856606 CDEV_LOG_INFO("Initialisation parameters - name: %s,"
104d30ea906Sjfb8856606 "socket id: %d, max queue pairs: %u",
105d30ea906Sjfb8856606 name, params->socket_id, params->max_nb_queue_pairs);
1062bfe3f2eSlogwang
1072bfe3f2eSlogwang /* allocate device structure */
1082bfe3f2eSlogwang cryptodev = rte_cryptodev_pmd_allocate(name, params->socket_id);
1092bfe3f2eSlogwang if (cryptodev == NULL) {
110d30ea906Sjfb8856606 CDEV_LOG_ERR("Failed to allocate crypto device for %s", name);
1112bfe3f2eSlogwang return NULL;
1122bfe3f2eSlogwang }
1132bfe3f2eSlogwang
1142bfe3f2eSlogwang /* allocate private device structure */
1152bfe3f2eSlogwang if (rte_eal_process_type() == RTE_PROC_PRIMARY) {
1162bfe3f2eSlogwang cryptodev->data->dev_private =
1172bfe3f2eSlogwang rte_zmalloc_socket("cryptodev device private",
1182bfe3f2eSlogwang params->private_data_size,
1192bfe3f2eSlogwang RTE_CACHE_LINE_SIZE,
1202bfe3f2eSlogwang params->socket_id);
1212bfe3f2eSlogwang
1222bfe3f2eSlogwang if (cryptodev->data->dev_private == NULL) {
123d30ea906Sjfb8856606 CDEV_LOG_ERR("Cannot allocate memory for cryptodev %s"
124d30ea906Sjfb8856606 " private data", name);
1252bfe3f2eSlogwang
1262bfe3f2eSlogwang rte_cryptodev_pmd_release_device(cryptodev);
1272bfe3f2eSlogwang return NULL;
1282bfe3f2eSlogwang }
1292bfe3f2eSlogwang }
1302bfe3f2eSlogwang
1312bfe3f2eSlogwang cryptodev->device = device;
1322bfe3f2eSlogwang
1332bfe3f2eSlogwang /* initialise user call-back tail queue */
1342bfe3f2eSlogwang TAILQ_INIT(&(cryptodev->link_intr_cbs));
1352bfe3f2eSlogwang
1362bfe3f2eSlogwang return cryptodev;
1372bfe3f2eSlogwang }
1382bfe3f2eSlogwang
1392bfe3f2eSlogwang int
rte_cryptodev_pmd_destroy(struct rte_cryptodev * cryptodev)1402bfe3f2eSlogwang rte_cryptodev_pmd_destroy(struct rte_cryptodev *cryptodev)
1412bfe3f2eSlogwang {
1422bfe3f2eSlogwang int retval;
1432bfe3f2eSlogwang
144d30ea906Sjfb8856606 CDEV_LOG_INFO("Closing crypto device %s", cryptodev->device->name);
1452bfe3f2eSlogwang
1462bfe3f2eSlogwang /* free crypto device */
1472bfe3f2eSlogwang retval = rte_cryptodev_pmd_release_device(cryptodev);
1482bfe3f2eSlogwang if (retval)
1492bfe3f2eSlogwang return retval;
1502bfe3f2eSlogwang
1512bfe3f2eSlogwang if (rte_eal_process_type() == RTE_PROC_PRIMARY)
1522bfe3f2eSlogwang rte_free(cryptodev->data->dev_private);
1532bfe3f2eSlogwang
1542bfe3f2eSlogwang
1552bfe3f2eSlogwang cryptodev->device = NULL;
1562bfe3f2eSlogwang cryptodev->data = NULL;
1572bfe3f2eSlogwang
1582bfe3f2eSlogwang return 0;
1592bfe3f2eSlogwang }
160