xref: /f-stack/dpdk/drivers/bus/vdev/vdev_params.c (revision d30ea906)
1*d30ea906Sjfb8856606 /* SPDX-License-Identifier: BSD-3-Clause
2*d30ea906Sjfb8856606  * Copyright 2018 Gaëtan Rivet
3*d30ea906Sjfb8856606  */
4*d30ea906Sjfb8856606 
5*d30ea906Sjfb8856606 #include <string.h>
6*d30ea906Sjfb8856606 
7*d30ea906Sjfb8856606 #include <rte_dev.h>
8*d30ea906Sjfb8856606 #include <rte_bus.h>
9*d30ea906Sjfb8856606 #include <rte_kvargs.h>
10*d30ea906Sjfb8856606 #include <rte_errno.h>
11*d30ea906Sjfb8856606 
12*d30ea906Sjfb8856606 #include "vdev_logs.h"
13*d30ea906Sjfb8856606 #include "vdev_private.h"
14*d30ea906Sjfb8856606 
15*d30ea906Sjfb8856606 enum vdev_params {
16*d30ea906Sjfb8856606 	RTE_VDEV_PARAM_NAME,
17*d30ea906Sjfb8856606 	RTE_VDEV_PARAM_MAX,
18*d30ea906Sjfb8856606 };
19*d30ea906Sjfb8856606 
20*d30ea906Sjfb8856606 static const char * const vdev_params_keys[] = {
21*d30ea906Sjfb8856606 	[RTE_VDEV_PARAM_NAME] = "name",
22*d30ea906Sjfb8856606 	[RTE_VDEV_PARAM_MAX] = NULL,
23*d30ea906Sjfb8856606 };
24*d30ea906Sjfb8856606 
25*d30ea906Sjfb8856606 static int
vdev_dev_match(const struct rte_device * dev,const void * _kvlist)26*d30ea906Sjfb8856606 vdev_dev_match(const struct rte_device *dev,
27*d30ea906Sjfb8856606 	       const void *_kvlist)
28*d30ea906Sjfb8856606 {
29*d30ea906Sjfb8856606 	int ret;
30*d30ea906Sjfb8856606 	const struct rte_kvargs *kvlist = _kvlist;
31*d30ea906Sjfb8856606 	char *name;
32*d30ea906Sjfb8856606 
33*d30ea906Sjfb8856606 	/* cannot pass const dev->name to rte_kvargs_process() */
34*d30ea906Sjfb8856606 	name = strdup(dev->name);
35*d30ea906Sjfb8856606 	if (name == NULL)
36*d30ea906Sjfb8856606 		return -1;
37*d30ea906Sjfb8856606 	ret = rte_kvargs_process(kvlist,
38*d30ea906Sjfb8856606 		vdev_params_keys[RTE_VDEV_PARAM_NAME],
39*d30ea906Sjfb8856606 		rte_kvargs_strcmp, name);
40*d30ea906Sjfb8856606 	free(name);
41*d30ea906Sjfb8856606 	if (ret != 0)
42*d30ea906Sjfb8856606 		return -1;
43*d30ea906Sjfb8856606 
44*d30ea906Sjfb8856606 	return 0;
45*d30ea906Sjfb8856606 }
46*d30ea906Sjfb8856606 
47*d30ea906Sjfb8856606 void *
rte_vdev_dev_iterate(const void * start,const char * str,const struct rte_dev_iterator * it __rte_unused)48*d30ea906Sjfb8856606 rte_vdev_dev_iterate(const void *start,
49*d30ea906Sjfb8856606 		     const char *str,
50*d30ea906Sjfb8856606 		     const struct rte_dev_iterator *it __rte_unused)
51*d30ea906Sjfb8856606 {
52*d30ea906Sjfb8856606 	struct rte_kvargs *kvargs = NULL;
53*d30ea906Sjfb8856606 	struct rte_device *dev;
54*d30ea906Sjfb8856606 
55*d30ea906Sjfb8856606 	if (str != NULL) {
56*d30ea906Sjfb8856606 		kvargs = rte_kvargs_parse(str, vdev_params_keys);
57*d30ea906Sjfb8856606 		if (kvargs == NULL) {
58*d30ea906Sjfb8856606 			VDEV_LOG(ERR, "cannot parse argument list\n");
59*d30ea906Sjfb8856606 			rte_errno = EINVAL;
60*d30ea906Sjfb8856606 			return NULL;
61*d30ea906Sjfb8856606 		}
62*d30ea906Sjfb8856606 	}
63*d30ea906Sjfb8856606 	dev = rte_vdev_find_device(start, vdev_dev_match, kvargs);
64*d30ea906Sjfb8856606 	rte_kvargs_free(kvargs);
65*d30ea906Sjfb8856606 	return dev;
66*d30ea906Sjfb8856606 }
67