xref: /dpdk/lib/cryptodev/cryptodev_pmd.c (revision a7db3afce75346832059d8bfe54a8f81945fb213)
1 /* SPDX-License-Identifier: BSD-3-Clause
2  * Copyright(c) 2017 Intel Corporation
3  */
4 
5 #include <rte_string_fns.h>
6 #include <rte_malloc.h>
7 
8 #include "cryptodev_pmd.h"
9 
10 /**
11  * Parse name from argument
12  */
13 static int
14 rte_cryptodev_pmd_parse_name_arg(const char *key __rte_unused,
15 		const char *value, void *extra_args)
16 {
17 	struct rte_cryptodev_pmd_init_params *params = extra_args;
18 	int n;
19 
20 	n = strlcpy(params->name, value, RTE_CRYPTODEV_NAME_MAX_LEN);
21 	if (n >= RTE_CRYPTODEV_NAME_MAX_LEN)
22 		return -EINVAL;
23 
24 	return 0;
25 }
26 
27 /**
28  * Parse unsigned integer from argument
29  */
30 static int
31 rte_cryptodev_pmd_parse_uint_arg(const char *key __rte_unused,
32 		const char *value, void *extra_args)
33 {
34 	int i;
35 	char *end;
36 	errno = 0;
37 
38 	i = strtol(value, &end, 10);
39 	if (*end != 0 || errno != 0 || i < 0)
40 		return -EINVAL;
41 
42 	*((uint32_t *)extra_args) = i;
43 	return 0;
44 }
45 
46 int
47 rte_cryptodev_pmd_parse_input_args(
48 		struct rte_cryptodev_pmd_init_params *params,
49 		const char *args)
50 {
51 	struct rte_kvargs *kvlist = NULL;
52 	int ret = 0;
53 
54 	if (params == NULL)
55 		return -EINVAL;
56 
57 	if (args) {
58 		kvlist = rte_kvargs_parse(args,	cryptodev_pmd_valid_params);
59 		if (kvlist == NULL)
60 			return -EINVAL;
61 
62 		ret = rte_kvargs_process(kvlist,
63 				RTE_CRYPTODEV_PMD_MAX_NB_QP_ARG,
64 				&rte_cryptodev_pmd_parse_uint_arg,
65 				&params->max_nb_queue_pairs);
66 		if (ret < 0)
67 			goto free_kvlist;
68 
69 		ret = rte_kvargs_process(kvlist,
70 				RTE_CRYPTODEV_PMD_SOCKET_ID_ARG,
71 				&rte_cryptodev_pmd_parse_uint_arg,
72 				&params->socket_id);
73 		if (ret < 0)
74 			goto free_kvlist;
75 
76 		ret = rte_kvargs_process(kvlist,
77 				RTE_CRYPTODEV_PMD_NAME_ARG,
78 				&rte_cryptodev_pmd_parse_name_arg,
79 				params);
80 		if (ret < 0)
81 			goto free_kvlist;
82 	}
83 
84 free_kvlist:
85 	rte_kvargs_free(kvlist);
86 	return ret;
87 }
88 
89 struct rte_cryptodev *
90 rte_cryptodev_pmd_create(const char *name,
91 		struct rte_device *device,
92 		struct rte_cryptodev_pmd_init_params *params)
93 {
94 	struct rte_cryptodev *cryptodev;
95 
96 	if (params->name[0] != '\0') {
97 		CDEV_LOG_INFO("User specified device name = %s\n", params->name);
98 		name = params->name;
99 	}
100 
101 	CDEV_LOG_INFO("Creating cryptodev %s\n", name);
102 
103 	CDEV_LOG_INFO("Initialisation parameters - name: %s,"
104 			"socket id: %d, max queue pairs: %u",
105 			name, params->socket_id, params->max_nb_queue_pairs);
106 
107 	/* allocate device structure */
108 	cryptodev = rte_cryptodev_pmd_allocate(name, params->socket_id);
109 	if (cryptodev == NULL) {
110 		CDEV_LOG_ERR("Failed to allocate crypto device for %s", name);
111 		return NULL;
112 	}
113 
114 	/* allocate private device structure */
115 	if (rte_eal_process_type() == RTE_PROC_PRIMARY) {
116 		cryptodev->data->dev_private =
117 				rte_zmalloc_socket("cryptodev device private",
118 						params->private_data_size,
119 						RTE_CACHE_LINE_SIZE,
120 						params->socket_id);
121 
122 		if (cryptodev->data->dev_private == NULL) {
123 			CDEV_LOG_ERR("Cannot allocate memory for cryptodev %s"
124 					" private data", name);
125 
126 			rte_cryptodev_pmd_release_device(cryptodev);
127 			return NULL;
128 		}
129 	}
130 
131 	cryptodev->device = device;
132 
133 	/* initialise user call-back tail queue */
134 	TAILQ_INIT(&(cryptodev->link_intr_cbs));
135 
136 	return cryptodev;
137 }
138 
139 int
140 rte_cryptodev_pmd_destroy(struct rte_cryptodev *cryptodev)
141 {
142 	int retval;
143 	void *dev_priv = cryptodev->data->dev_private;
144 
145 	CDEV_LOG_INFO("Closing crypto device %s", cryptodev->device->name);
146 
147 	/* free crypto device */
148 	retval = rte_cryptodev_pmd_release_device(cryptodev);
149 	if (retval)
150 		return retval;
151 
152 	if (rte_eal_process_type() == RTE_PROC_PRIMARY)
153 		rte_free(dev_priv);
154 
155 
156 	cryptodev->device = NULL;
157 	cryptodev->data = NULL;
158 
159 	return 0;
160 }
161