1d30ea906Sjfb8856606 /* SPDX-License-Identifier: BSD-3-Clause
2d30ea906Sjfb8856606  * Copyright(c) 2017-2018 Intel Corporation
3d30ea906Sjfb8856606  */
4d30ea906Sjfb8856606 
5*4418919fSjohnjiang #include <rte_string_fns.h>
6d30ea906Sjfb8856606 #include <rte_malloc.h>
7d30ea906Sjfb8856606 #include <rte_kvargs.h>
8d30ea906Sjfb8856606 #include <rte_eal.h>
9d30ea906Sjfb8856606 
10d30ea906Sjfb8856606 #include "rte_compressdev_internal.h"
11d30ea906Sjfb8856606 #include "rte_compressdev_pmd.h"
12d30ea906Sjfb8856606 
13d30ea906Sjfb8856606 /**
14d30ea906Sjfb8856606  * Parse name from argument
15d30ea906Sjfb8856606  */
16d30ea906Sjfb8856606 static int
rte_compressdev_pmd_parse_name_arg(const char * key __rte_unused,const char * value,void * extra_args)17d30ea906Sjfb8856606 rte_compressdev_pmd_parse_name_arg(const char *key __rte_unused,
18d30ea906Sjfb8856606 		const char *value, void *extra_args)
19d30ea906Sjfb8856606 {
20d30ea906Sjfb8856606 	struct rte_compressdev_pmd_init_params *params = extra_args;
21d30ea906Sjfb8856606 	int n;
22d30ea906Sjfb8856606 
23*4418919fSjohnjiang 	n = strlcpy(params->name, value, RTE_COMPRESSDEV_NAME_MAX_LEN);
24d30ea906Sjfb8856606 	if (n >= RTE_COMPRESSDEV_NAME_MAX_LEN)
25d30ea906Sjfb8856606 		return -EINVAL;
26d30ea906Sjfb8856606 
27d30ea906Sjfb8856606 	return 0;
28d30ea906Sjfb8856606 }
29d30ea906Sjfb8856606 
30d30ea906Sjfb8856606 /**
31d30ea906Sjfb8856606  * Parse unsigned integer from argument
32d30ea906Sjfb8856606  */
33d30ea906Sjfb8856606 static int
rte_compressdev_pmd_parse_uint_arg(const char * key __rte_unused,const char * value,void * extra_args)34d30ea906Sjfb8856606 rte_compressdev_pmd_parse_uint_arg(const char *key __rte_unused,
35d30ea906Sjfb8856606 		const char *value, void *extra_args)
36d30ea906Sjfb8856606 {
37d30ea906Sjfb8856606 	int i;
38d30ea906Sjfb8856606 	char *end;
39d30ea906Sjfb8856606 
40d30ea906Sjfb8856606 	errno = 0;
41d30ea906Sjfb8856606 	i = strtol(value, &end, 10);
42d30ea906Sjfb8856606 	if (*end != 0 || errno != 0 || i < 0)
43d30ea906Sjfb8856606 		return -EINVAL;
44d30ea906Sjfb8856606 
45d30ea906Sjfb8856606 	*((uint32_t *)extra_args) = i;
46d30ea906Sjfb8856606 	return 0;
47d30ea906Sjfb8856606 }
48d30ea906Sjfb8856606 
49*4418919fSjohnjiang int
rte_compressdev_pmd_parse_input_args(struct rte_compressdev_pmd_init_params * params,const char * args)50d30ea906Sjfb8856606 rte_compressdev_pmd_parse_input_args(
51d30ea906Sjfb8856606 		struct rte_compressdev_pmd_init_params *params,
52d30ea906Sjfb8856606 		const char *args)
53d30ea906Sjfb8856606 {
54d30ea906Sjfb8856606 	struct rte_kvargs *kvlist = NULL;
55d30ea906Sjfb8856606 	int ret = 0;
56d30ea906Sjfb8856606 
57d30ea906Sjfb8856606 	if (params == NULL)
58d30ea906Sjfb8856606 		return -EINVAL;
59d30ea906Sjfb8856606 
60d30ea906Sjfb8856606 	if (args) {
61d30ea906Sjfb8856606 		kvlist = rte_kvargs_parse(args,	compressdev_pmd_valid_params);
62d30ea906Sjfb8856606 		if (kvlist == NULL)
63d30ea906Sjfb8856606 			return -EINVAL;
64d30ea906Sjfb8856606 
65d30ea906Sjfb8856606 		ret = rte_kvargs_process(kvlist,
66d30ea906Sjfb8856606 				RTE_COMPRESSDEV_PMD_SOCKET_ID_ARG,
67d30ea906Sjfb8856606 				&rte_compressdev_pmd_parse_uint_arg,
68d30ea906Sjfb8856606 				&params->socket_id);
69d30ea906Sjfb8856606 		if (ret < 0)
70d30ea906Sjfb8856606 			goto free_kvlist;
71d30ea906Sjfb8856606 
72d30ea906Sjfb8856606 		ret = rte_kvargs_process(kvlist,
73d30ea906Sjfb8856606 				RTE_COMPRESSDEV_PMD_NAME_ARG,
74d30ea906Sjfb8856606 				&rte_compressdev_pmd_parse_name_arg,
75d30ea906Sjfb8856606 				params);
76d30ea906Sjfb8856606 		if (ret < 0)
77d30ea906Sjfb8856606 			goto free_kvlist;
78d30ea906Sjfb8856606 	}
79d30ea906Sjfb8856606 
80d30ea906Sjfb8856606 free_kvlist:
81d30ea906Sjfb8856606 	rte_kvargs_free(kvlist);
82d30ea906Sjfb8856606 	return ret;
83d30ea906Sjfb8856606 }
84d30ea906Sjfb8856606 
85*4418919fSjohnjiang struct rte_compressdev *
rte_compressdev_pmd_create(const char * name,struct rte_device * device,size_t private_data_size,struct rte_compressdev_pmd_init_params * params)86d30ea906Sjfb8856606 rte_compressdev_pmd_create(const char *name,
87d30ea906Sjfb8856606 		struct rte_device *device,
88d30ea906Sjfb8856606 		size_t private_data_size,
89d30ea906Sjfb8856606 		struct rte_compressdev_pmd_init_params *params)
90d30ea906Sjfb8856606 {
91d30ea906Sjfb8856606 	struct rte_compressdev *compressdev;
92d30ea906Sjfb8856606 
93d30ea906Sjfb8856606 	if (params->name[0] != '\0') {
94d30ea906Sjfb8856606 		COMPRESSDEV_LOG(INFO, "User specified device name = %s\n",
95d30ea906Sjfb8856606 				params->name);
96d30ea906Sjfb8856606 		name = params->name;
97d30ea906Sjfb8856606 	}
98d30ea906Sjfb8856606 
99d30ea906Sjfb8856606 	COMPRESSDEV_LOG(INFO, "Creating compressdev %s\n", name);
100d30ea906Sjfb8856606 
101d30ea906Sjfb8856606 	COMPRESSDEV_LOG(INFO, "Init parameters - name: %s, socket id: %d",
102d30ea906Sjfb8856606 			name, params->socket_id);
103d30ea906Sjfb8856606 
104d30ea906Sjfb8856606 	/* allocate device structure */
105d30ea906Sjfb8856606 	compressdev = rte_compressdev_pmd_allocate(name, params->socket_id);
106d30ea906Sjfb8856606 	if (compressdev == NULL) {
107d30ea906Sjfb8856606 		COMPRESSDEV_LOG(ERR, "Failed to allocate comp device %s", name);
108d30ea906Sjfb8856606 		return NULL;
109d30ea906Sjfb8856606 	}
110d30ea906Sjfb8856606 
111d30ea906Sjfb8856606 	/* allocate private device structure */
112d30ea906Sjfb8856606 	if (rte_eal_process_type() == RTE_PROC_PRIMARY) {
113d30ea906Sjfb8856606 		compressdev->data->dev_private =
114d30ea906Sjfb8856606 				rte_zmalloc_socket("compressdev device private",
115d30ea906Sjfb8856606 						private_data_size,
116d30ea906Sjfb8856606 						RTE_CACHE_LINE_SIZE,
117d30ea906Sjfb8856606 						params->socket_id);
118d30ea906Sjfb8856606 
119d30ea906Sjfb8856606 		if (compressdev->data->dev_private == NULL) {
120d30ea906Sjfb8856606 			COMPRESSDEV_LOG(ERR,
121d30ea906Sjfb8856606 					"Cannot allocate memory for compressdev"
122d30ea906Sjfb8856606 					" %s private data", name);
123d30ea906Sjfb8856606 
124d30ea906Sjfb8856606 			rte_compressdev_pmd_release_device(compressdev);
125d30ea906Sjfb8856606 			return NULL;
126d30ea906Sjfb8856606 		}
127d30ea906Sjfb8856606 	}
128d30ea906Sjfb8856606 
129d30ea906Sjfb8856606 	compressdev->device = device;
130d30ea906Sjfb8856606 
131d30ea906Sjfb8856606 	return compressdev;
132d30ea906Sjfb8856606 }
133d30ea906Sjfb8856606 
134*4418919fSjohnjiang int
rte_compressdev_pmd_destroy(struct rte_compressdev * compressdev)135d30ea906Sjfb8856606 rte_compressdev_pmd_destroy(struct rte_compressdev *compressdev)
136d30ea906Sjfb8856606 {
137d30ea906Sjfb8856606 	int retval;
138d30ea906Sjfb8856606 
139d30ea906Sjfb8856606 	COMPRESSDEV_LOG(INFO, "Closing comp device %s",
140d30ea906Sjfb8856606 			compressdev->device->name);
141d30ea906Sjfb8856606 
142d30ea906Sjfb8856606 	/* free comp device */
143d30ea906Sjfb8856606 	retval = rte_compressdev_pmd_release_device(compressdev);
144d30ea906Sjfb8856606 	if (retval)
145d30ea906Sjfb8856606 		return retval;
146d30ea906Sjfb8856606 
147d30ea906Sjfb8856606 	if (rte_eal_process_type() == RTE_PROC_PRIMARY)
148d30ea906Sjfb8856606 		rte_free(compressdev->data->dev_private);
149d30ea906Sjfb8856606 
150d30ea906Sjfb8856606 	compressdev->device = NULL;
151d30ea906Sjfb8856606 	compressdev->data = NULL;
152d30ea906Sjfb8856606 
153d30ea906Sjfb8856606 	return 0;
154d30ea906Sjfb8856606 }
155