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 				&params->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 				&params->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