xref: /dpdk/lib/eventdev/rte_eventdev.c (revision cbbba8b87e03a028a2ac2f3542f1927ba4edc598)
199a2dd95SBruce Richardson /* SPDX-License-Identifier: BSD-3-Clause
299a2dd95SBruce Richardson  * Copyright(c) 2016 Cavium, Inc
399a2dd95SBruce Richardson  */
499a2dd95SBruce Richardson 
599a2dd95SBruce Richardson #include <ctype.h>
699a2dd95SBruce Richardson #include <stdio.h>
799a2dd95SBruce Richardson #include <stdlib.h>
899a2dd95SBruce Richardson #include <string.h>
999a2dd95SBruce Richardson #include <errno.h>
1099a2dd95SBruce Richardson #include <stdint.h>
1199a2dd95SBruce Richardson #include <inttypes.h>
1299a2dd95SBruce Richardson 
1399a2dd95SBruce Richardson #include <rte_string_fns.h>
1499a2dd95SBruce Richardson #include <rte_log.h>
151acb7f54SDavid Marchand #include <dev_driver.h>
1699a2dd95SBruce Richardson #include <rte_memzone.h>
1799a2dd95SBruce Richardson #include <rte_eal.h>
1899a2dd95SBruce Richardson #include <rte_common.h>
1999a2dd95SBruce Richardson #include <rte_malloc.h>
2099a2dd95SBruce Richardson #include <rte_errno.h>
21f9bdee26SKonstantin Ananyev #include <ethdev_driver.h>
2299a2dd95SBruce Richardson #include <rte_cryptodev.h>
23d3aa3cd5SAmit Prakash Shukla #include <rte_dmadev.h>
24af668035SAkhil Goyal #include <cryptodev_pmd.h>
2599a2dd95SBruce Richardson #include <rte_telemetry.h>
2699a2dd95SBruce Richardson 
2799a2dd95SBruce Richardson #include "rte_eventdev.h"
2899a2dd95SBruce Richardson #include "eventdev_pmd.h"
29f26f2ca6SPavan Nikhilesh #include "eventdev_trace.h"
3099a2dd95SBruce Richardson 
3199a2dd95SBruce Richardson static struct rte_eventdev rte_event_devices[RTE_EVENT_MAX_DEVS];
3299a2dd95SBruce Richardson 
3399a2dd95SBruce Richardson struct rte_eventdev *rte_eventdevs = rte_event_devices;
3499a2dd95SBruce Richardson 
3599a2dd95SBruce Richardson static struct rte_eventdev_global eventdev_globals = {
3699a2dd95SBruce Richardson 	.nb_devs		= 0
3799a2dd95SBruce Richardson };
3899a2dd95SBruce Richardson 
39d35e6132SPavan Nikhilesh /* Public fastpath APIs. */
40d35e6132SPavan Nikhilesh struct rte_event_fp_ops rte_event_fp_ops[RTE_EVENT_MAX_DEVS];
41d35e6132SPavan Nikhilesh 
4299a2dd95SBruce Richardson /* Event dev north bound API implementation */
4399a2dd95SBruce Richardson 
4499a2dd95SBruce Richardson uint8_t
4599a2dd95SBruce Richardson rte_event_dev_count(void)
4699a2dd95SBruce Richardson {
4799a2dd95SBruce Richardson 	return eventdev_globals.nb_devs;
4899a2dd95SBruce Richardson }
4999a2dd95SBruce Richardson 
5099a2dd95SBruce Richardson int
5199a2dd95SBruce Richardson rte_event_dev_get_dev_id(const char *name)
5299a2dd95SBruce Richardson {
5399a2dd95SBruce Richardson 	int i;
5499a2dd95SBruce Richardson 	uint8_t cmp;
5599a2dd95SBruce Richardson 
5699a2dd95SBruce Richardson 	if (!name)
5799a2dd95SBruce Richardson 		return -EINVAL;
5899a2dd95SBruce Richardson 
5999a2dd95SBruce Richardson 	for (i = 0; i < eventdev_globals.nb_devs; i++) {
6099a2dd95SBruce Richardson 		cmp = (strncmp(rte_event_devices[i].data->name, name,
6199a2dd95SBruce Richardson 				RTE_EVENTDEV_NAME_MAX_LEN) == 0) ||
6299a2dd95SBruce Richardson 			(rte_event_devices[i].dev ? (strncmp(
6399a2dd95SBruce Richardson 				rte_event_devices[i].dev->driver->name, name,
6499a2dd95SBruce Richardson 					 RTE_EVENTDEV_NAME_MAX_LEN) == 0) : 0);
6599a2dd95SBruce Richardson 		if (cmp && (rte_event_devices[i].attached ==
667f2d9df6SAmit Prakash Shukla 					RTE_EVENTDEV_ATTACHED)) {
677f2d9df6SAmit Prakash Shukla 			rte_eventdev_trace_get_dev_id(name, i);
6899a2dd95SBruce Richardson 			return i;
6999a2dd95SBruce Richardson 		}
707f2d9df6SAmit Prakash Shukla 	}
7199a2dd95SBruce Richardson 	return -ENODEV;
7299a2dd95SBruce Richardson }
7399a2dd95SBruce Richardson 
7499a2dd95SBruce Richardson int
7599a2dd95SBruce Richardson rte_event_dev_socket_id(uint8_t dev_id)
7699a2dd95SBruce Richardson {
7799a2dd95SBruce Richardson 	struct rte_eventdev *dev;
7899a2dd95SBruce Richardson 
7999a2dd95SBruce Richardson 	RTE_EVENTDEV_VALID_DEVID_OR_ERR_RET(dev_id, -EINVAL);
8099a2dd95SBruce Richardson 	dev = &rte_eventdevs[dev_id];
8199a2dd95SBruce Richardson 
827f2d9df6SAmit Prakash Shukla 	rte_eventdev_trace_socket_id(dev_id, dev, dev->data->socket_id);
837f2d9df6SAmit Prakash Shukla 
8499a2dd95SBruce Richardson 	return dev->data->socket_id;
8599a2dd95SBruce Richardson }
8699a2dd95SBruce Richardson 
8799a2dd95SBruce Richardson int
8899a2dd95SBruce Richardson rte_event_dev_info_get(uint8_t dev_id, struct rte_event_dev_info *dev_info)
8999a2dd95SBruce Richardson {
9099a2dd95SBruce Richardson 	struct rte_eventdev *dev;
9199a2dd95SBruce Richardson 
9299a2dd95SBruce Richardson 	RTE_EVENTDEV_VALID_DEVID_OR_ERR_RET(dev_id, -EINVAL);
9399a2dd95SBruce Richardson 	dev = &rte_eventdevs[dev_id];
9499a2dd95SBruce Richardson 
9599a2dd95SBruce Richardson 	if (dev_info == NULL)
9699a2dd95SBruce Richardson 		return -EINVAL;
9799a2dd95SBruce Richardson 
9899a2dd95SBruce Richardson 	memset(dev_info, 0, sizeof(struct rte_event_dev_info));
9999a2dd95SBruce Richardson 
1008f1d23ecSDavid Marchand 	if (*dev->dev_ops->dev_infos_get == NULL)
1018f1d23ecSDavid Marchand 		return -ENOTSUP;
10299a2dd95SBruce Richardson 	(*dev->dev_ops->dev_infos_get)(dev, dev_info);
10399a2dd95SBruce Richardson 
10499a2dd95SBruce Richardson 	dev_info->dequeue_timeout_ns = dev->data->dev_conf.dequeue_timeout_ns;
10599a2dd95SBruce Richardson 
10699a2dd95SBruce Richardson 	dev_info->dev = dev->dev;
107*cbbba8b8SBruce Richardson 	if (dev->dev != NULL && dev->dev->driver != NULL)
108*cbbba8b8SBruce Richardson 		dev_info->driver_name = dev->dev->driver->name;
1097f2d9df6SAmit Prakash Shukla 
1107f2d9df6SAmit Prakash Shukla 	rte_eventdev_trace_info_get(dev_id, dev_info, dev_info->dev);
1117f2d9df6SAmit Prakash Shukla 
11299a2dd95SBruce Richardson 	return 0;
11399a2dd95SBruce Richardson }
11499a2dd95SBruce Richardson 
11599a2dd95SBruce Richardson int
11699a2dd95SBruce Richardson rte_event_eth_rx_adapter_caps_get(uint8_t dev_id, uint16_t eth_port_id,
11799a2dd95SBruce Richardson 				uint32_t *caps)
11899a2dd95SBruce Richardson {
11999a2dd95SBruce Richardson 	struct rte_eventdev *dev;
12099a2dd95SBruce Richardson 
1217f2d9df6SAmit Prakash Shukla 	rte_eventdev_trace_eth_rx_adapter_caps_get(dev_id, eth_port_id);
1227f2d9df6SAmit Prakash Shukla 
12399a2dd95SBruce Richardson 	RTE_EVENTDEV_VALID_DEVID_OR_ERR_RET(dev_id, -EINVAL);
12499a2dd95SBruce Richardson 	RTE_ETH_VALID_PORTID_OR_ERR_RET(eth_port_id, -EINVAL);
12599a2dd95SBruce Richardson 
12699a2dd95SBruce Richardson 	dev = &rte_eventdevs[dev_id];
12799a2dd95SBruce Richardson 
12899a2dd95SBruce Richardson 	if (caps == NULL)
12999a2dd95SBruce Richardson 		return -EINVAL;
13099a2dd95SBruce Richardson 
13199a2dd95SBruce Richardson 	if (dev->dev_ops->eth_rx_adapter_caps_get == NULL)
13299a2dd95SBruce Richardson 		*caps = RTE_EVENT_ETH_RX_ADAPTER_SW_CAP;
13399a2dd95SBruce Richardson 	else
13499a2dd95SBruce Richardson 		*caps = 0;
13599a2dd95SBruce Richardson 
13699a2dd95SBruce Richardson 	return dev->dev_ops->eth_rx_adapter_caps_get ?
13799a2dd95SBruce Richardson 				(*dev->dev_ops->eth_rx_adapter_caps_get)(dev,
13899a2dd95SBruce Richardson 						&rte_eth_devices[eth_port_id],
13999a2dd95SBruce Richardson 						caps)
14099a2dd95SBruce Richardson 				: 0;
14199a2dd95SBruce Richardson }
14299a2dd95SBruce Richardson 
14399a2dd95SBruce Richardson int
14499a2dd95SBruce Richardson rte_event_timer_adapter_caps_get(uint8_t dev_id, uint32_t *caps)
14599a2dd95SBruce Richardson {
14699a2dd95SBruce Richardson 	struct rte_eventdev *dev;
14753548ad3SPavan Nikhilesh 	const struct event_timer_adapter_ops *ops;
14899a2dd95SBruce Richardson 
1497f2d9df6SAmit Prakash Shukla 	rte_eventdev_trace_timer_adapter_caps_get(dev_id);
1507f2d9df6SAmit Prakash Shukla 
15199a2dd95SBruce Richardson 	RTE_EVENTDEV_VALID_DEVID_OR_ERR_RET(dev_id, -EINVAL);
15299a2dd95SBruce Richardson 
15399a2dd95SBruce Richardson 	dev = &rte_eventdevs[dev_id];
15499a2dd95SBruce Richardson 
15599a2dd95SBruce Richardson 	if (caps == NULL)
15699a2dd95SBruce Richardson 		return -EINVAL;
1573d9d8adfSNaga Harish K S V 
1583d9d8adfSNaga Harish K S V 	if (dev->dev_ops->timer_adapter_caps_get == NULL)
1593d9d8adfSNaga Harish K S V 		*caps = RTE_EVENT_TIMER_ADAPTER_SW_CAP;
1603d9d8adfSNaga Harish K S V 	else
16199a2dd95SBruce Richardson 		*caps = 0;
16299a2dd95SBruce Richardson 
16399a2dd95SBruce Richardson 	return dev->dev_ops->timer_adapter_caps_get ?
16499a2dd95SBruce Richardson 				(*dev->dev_ops->timer_adapter_caps_get)(dev,
16599a2dd95SBruce Richardson 									0,
16699a2dd95SBruce Richardson 									caps,
16799a2dd95SBruce Richardson 									&ops)
16899a2dd95SBruce Richardson 				: 0;
16999a2dd95SBruce Richardson }
17099a2dd95SBruce Richardson 
17199a2dd95SBruce Richardson int
17299a2dd95SBruce Richardson rte_event_crypto_adapter_caps_get(uint8_t dev_id, uint8_t cdev_id,
17399a2dd95SBruce Richardson 				  uint32_t *caps)
17499a2dd95SBruce Richardson {
17599a2dd95SBruce Richardson 	struct rte_eventdev *dev;
17699a2dd95SBruce Richardson 	struct rte_cryptodev *cdev;
17799a2dd95SBruce Richardson 
17899a2dd95SBruce Richardson 	RTE_EVENTDEV_VALID_DEVID_OR_ERR_RET(dev_id, -EINVAL);
179e74abd48SAkhil Goyal 	if (!rte_cryptodev_is_valid_dev(cdev_id))
18099a2dd95SBruce Richardson 		return -EINVAL;
18199a2dd95SBruce Richardson 
18299a2dd95SBruce Richardson 	dev = &rte_eventdevs[dev_id];
18399a2dd95SBruce Richardson 	cdev = rte_cryptodev_pmd_get_dev(cdev_id);
18499a2dd95SBruce Richardson 
1857f2d9df6SAmit Prakash Shukla 	rte_eventdev_trace_crypto_adapter_caps_get(dev_id, dev, cdev_id, cdev);
1867f2d9df6SAmit Prakash Shukla 
18799a2dd95SBruce Richardson 	if (caps == NULL)
18899a2dd95SBruce Richardson 		return -EINVAL;
1896b946657SGanapati Kundapura 
1906b946657SGanapati Kundapura 	if (dev->dev_ops->crypto_adapter_caps_get == NULL)
1916b946657SGanapati Kundapura 		*caps = RTE_EVENT_CRYPTO_ADAPTER_SW_CAP;
1926b946657SGanapati Kundapura 	else
19399a2dd95SBruce Richardson 		*caps = 0;
19499a2dd95SBruce Richardson 
19599a2dd95SBruce Richardson 	return dev->dev_ops->crypto_adapter_caps_get ?
19699a2dd95SBruce Richardson 		(*dev->dev_ops->crypto_adapter_caps_get)
1976b946657SGanapati Kundapura 		(dev, cdev, caps) : 0;
19899a2dd95SBruce Richardson }
19999a2dd95SBruce Richardson 
20099a2dd95SBruce Richardson int
20199a2dd95SBruce Richardson rte_event_eth_tx_adapter_caps_get(uint8_t dev_id, uint16_t eth_port_id,
20299a2dd95SBruce Richardson 				uint32_t *caps)
20399a2dd95SBruce Richardson {
20499a2dd95SBruce Richardson 	struct rte_eventdev *dev;
20599a2dd95SBruce Richardson 	struct rte_eth_dev *eth_dev;
20699a2dd95SBruce Richardson 
20799a2dd95SBruce Richardson 	RTE_EVENTDEV_VALID_DEVID_OR_ERR_RET(dev_id, -EINVAL);
20899a2dd95SBruce Richardson 	RTE_ETH_VALID_PORTID_OR_ERR_RET(eth_port_id, -EINVAL);
20999a2dd95SBruce Richardson 
21099a2dd95SBruce Richardson 	dev = &rte_eventdevs[dev_id];
21199a2dd95SBruce Richardson 	eth_dev = &rte_eth_devices[eth_port_id];
21299a2dd95SBruce Richardson 
2137f2d9df6SAmit Prakash Shukla 	rte_eventdev_trace_eth_tx_adapter_caps_get(dev_id, dev, eth_port_id, eth_dev);
2147f2d9df6SAmit Prakash Shukla 
21599a2dd95SBruce Richardson 	if (caps == NULL)
21699a2dd95SBruce Richardson 		return -EINVAL;
21799a2dd95SBruce Richardson 
21899a2dd95SBruce Richardson 	if (dev->dev_ops->eth_tx_adapter_caps_get == NULL)
21999a2dd95SBruce Richardson 		*caps = RTE_EVENT_ETH_TX_ADAPTER_CAP_EVENT_VECTOR;
22099a2dd95SBruce Richardson 	else
22199a2dd95SBruce Richardson 		*caps = 0;
22299a2dd95SBruce Richardson 
22399a2dd95SBruce Richardson 	return dev->dev_ops->eth_tx_adapter_caps_get ?
22499a2dd95SBruce Richardson 			(*dev->dev_ops->eth_tx_adapter_caps_get)(dev,
22599a2dd95SBruce Richardson 								eth_dev,
22699a2dd95SBruce Richardson 								caps)
22799a2dd95SBruce Richardson 			: 0;
22899a2dd95SBruce Richardson }
22999a2dd95SBruce Richardson 
230d3aa3cd5SAmit Prakash Shukla int
231d3aa3cd5SAmit Prakash Shukla rte_event_dma_adapter_caps_get(uint8_t dev_id, uint8_t dma_dev_id, uint32_t *caps)
232d3aa3cd5SAmit Prakash Shukla {
233d3aa3cd5SAmit Prakash Shukla 	struct rte_eventdev *dev;
234d3aa3cd5SAmit Prakash Shukla 
235d3aa3cd5SAmit Prakash Shukla 	RTE_EVENTDEV_VALID_DEVID_OR_ERR_RET(dev_id, -EINVAL);
236d3aa3cd5SAmit Prakash Shukla 	if (!rte_dma_is_valid(dma_dev_id))
237d3aa3cd5SAmit Prakash Shukla 		return -EINVAL;
238d3aa3cd5SAmit Prakash Shukla 
239d3aa3cd5SAmit Prakash Shukla 	dev = &rte_eventdevs[dev_id];
240d3aa3cd5SAmit Prakash Shukla 
241d3aa3cd5SAmit Prakash Shukla 	if (caps == NULL)
242d3aa3cd5SAmit Prakash Shukla 		return -EINVAL;
243d3aa3cd5SAmit Prakash Shukla 
244d3aa3cd5SAmit Prakash Shukla 	*caps = 0;
245d3aa3cd5SAmit Prakash Shukla 
246d3aa3cd5SAmit Prakash Shukla 	if (dev->dev_ops->dma_adapter_caps_get)
247d3aa3cd5SAmit Prakash Shukla 		return (*dev->dev_ops->dma_adapter_caps_get)(dev, dma_dev_id, caps);
248d3aa3cd5SAmit Prakash Shukla 
249d3aa3cd5SAmit Prakash Shukla 	return 0;
250d3aa3cd5SAmit Prakash Shukla }
251d3aa3cd5SAmit Prakash Shukla 
25299a2dd95SBruce Richardson static inline int
2539c67fcbfSPavan Nikhilesh event_dev_queue_config(struct rte_eventdev *dev, uint8_t nb_queues)
25499a2dd95SBruce Richardson {
25599a2dd95SBruce Richardson 	uint8_t old_nb_queues = dev->data->nb_queues;
25699a2dd95SBruce Richardson 	struct rte_event_queue_conf *queues_cfg;
25799a2dd95SBruce Richardson 	unsigned int i;
25899a2dd95SBruce Richardson 
25999a2dd95SBruce Richardson 	RTE_EDEV_LOG_DEBUG("Setup %d queues on device %u", nb_queues,
26099a2dd95SBruce Richardson 			 dev->data->dev_id);
26199a2dd95SBruce Richardson 
2629c67fcbfSPavan Nikhilesh 	if (nb_queues != 0) {
2639c67fcbfSPavan Nikhilesh 		queues_cfg = dev->data->queues_cfg;
2648f1d23ecSDavid Marchand 		if (*dev->dev_ops->queue_release == NULL)
2658f1d23ecSDavid Marchand 			return -ENOTSUP;
26699a2dd95SBruce Richardson 
26799a2dd95SBruce Richardson 		for (i = nb_queues; i < old_nb_queues; i++)
26899a2dd95SBruce Richardson 			(*dev->dev_ops->queue_release)(dev, i);
26999a2dd95SBruce Richardson 
27099a2dd95SBruce Richardson 
27199a2dd95SBruce Richardson 		if (nb_queues > old_nb_queues) {
27299a2dd95SBruce Richardson 			uint8_t new_qs = nb_queues - old_nb_queues;
27399a2dd95SBruce Richardson 
27499a2dd95SBruce Richardson 			memset(queues_cfg + old_nb_queues, 0,
27599a2dd95SBruce Richardson 				sizeof(queues_cfg[0]) * new_qs);
27699a2dd95SBruce Richardson 		}
2779c67fcbfSPavan Nikhilesh 	} else {
2788f1d23ecSDavid Marchand 		if (*dev->dev_ops->queue_release == NULL)
2798f1d23ecSDavid Marchand 			return -ENOTSUP;
28099a2dd95SBruce Richardson 
28199a2dd95SBruce Richardson 		for (i = nb_queues; i < old_nb_queues; i++)
28299a2dd95SBruce Richardson 			(*dev->dev_ops->queue_release)(dev, i);
28399a2dd95SBruce Richardson 	}
28499a2dd95SBruce Richardson 
28599a2dd95SBruce Richardson 	dev->data->nb_queues = nb_queues;
28699a2dd95SBruce Richardson 	return 0;
28799a2dd95SBruce Richardson }
28899a2dd95SBruce Richardson 
28999a2dd95SBruce Richardson #define EVENT_QUEUE_SERVICE_PRIORITY_INVALID (0xdead)
29099a2dd95SBruce Richardson 
29199a2dd95SBruce Richardson static inline int
2929c67fcbfSPavan Nikhilesh event_dev_port_config(struct rte_eventdev *dev, uint8_t nb_ports)
29399a2dd95SBruce Richardson {
29499a2dd95SBruce Richardson 	uint8_t old_nb_ports = dev->data->nb_ports;
29599a2dd95SBruce Richardson 	void **ports;
29699a2dd95SBruce Richardson 	uint16_t *links_map;
29799a2dd95SBruce Richardson 	struct rte_event_port_conf *ports_cfg;
298d007a7f3SPavan Nikhilesh 	unsigned int i, j;
29999a2dd95SBruce Richardson 
30099a2dd95SBruce Richardson 	RTE_EDEV_LOG_DEBUG("Setup %d ports on device %u", nb_ports,
30199a2dd95SBruce Richardson 			 dev->data->dev_id);
30299a2dd95SBruce Richardson 
3039c67fcbfSPavan Nikhilesh 	if (nb_ports != 0) { /* re-config */
3048f1d23ecSDavid Marchand 		if (*dev->dev_ops->port_release == NULL)
3058f1d23ecSDavid Marchand 			return -ENOTSUP;
30699a2dd95SBruce Richardson 
30799a2dd95SBruce Richardson 		ports = dev->data->ports;
30899a2dd95SBruce Richardson 		ports_cfg = dev->data->ports_cfg;
30999a2dd95SBruce Richardson 
31099a2dd95SBruce Richardson 		for (i = nb_ports; i < old_nb_ports; i++)
31199a2dd95SBruce Richardson 			(*dev->dev_ops->port_release)(ports[i]);
31299a2dd95SBruce Richardson 
31399a2dd95SBruce Richardson 		if (nb_ports > old_nb_ports) {
31499a2dd95SBruce Richardson 			uint8_t new_ps = nb_ports - old_nb_ports;
31599a2dd95SBruce Richardson 			unsigned int old_links_map_end =
31699a2dd95SBruce Richardson 				old_nb_ports * RTE_EVENT_MAX_QUEUES_PER_DEV;
31799a2dd95SBruce Richardson 			unsigned int links_map_end =
31899a2dd95SBruce Richardson 				nb_ports * RTE_EVENT_MAX_QUEUES_PER_DEV;
31999a2dd95SBruce Richardson 
32099a2dd95SBruce Richardson 			memset(ports + old_nb_ports, 0,
32199a2dd95SBruce Richardson 				sizeof(ports[0]) * new_ps);
32299a2dd95SBruce Richardson 			memset(ports_cfg + old_nb_ports, 0,
32399a2dd95SBruce Richardson 				sizeof(ports_cfg[0]) * new_ps);
324d007a7f3SPavan Nikhilesh 			for (i = 0; i < RTE_EVENT_MAX_PROFILES_PER_PORT; i++) {
325d007a7f3SPavan Nikhilesh 				links_map = dev->data->links_map[i];
326d007a7f3SPavan Nikhilesh 				for (j = old_links_map_end; j < links_map_end; j++)
327d007a7f3SPavan Nikhilesh 					links_map[j] = EVENT_QUEUE_SERVICE_PRIORITY_INVALID;
328d007a7f3SPavan Nikhilesh 			}
32999a2dd95SBruce Richardson 		}
3309c67fcbfSPavan Nikhilesh 	} else {
3318f1d23ecSDavid Marchand 		if (*dev->dev_ops->port_release == NULL)
3328f1d23ecSDavid Marchand 			return -ENOTSUP;
33399a2dd95SBruce Richardson 
33499a2dd95SBruce Richardson 		ports = dev->data->ports;
3359c67fcbfSPavan Nikhilesh 		for (i = nb_ports; i < old_nb_ports; i++) {
33699a2dd95SBruce Richardson 			(*dev->dev_ops->port_release)(ports[i]);
3379c67fcbfSPavan Nikhilesh 			ports[i] = NULL;
3389c67fcbfSPavan Nikhilesh 		}
33999a2dd95SBruce Richardson 	}
34099a2dd95SBruce Richardson 
34199a2dd95SBruce Richardson 	dev->data->nb_ports = nb_ports;
34299a2dd95SBruce Richardson 	return 0;
34399a2dd95SBruce Richardson }
34499a2dd95SBruce Richardson 
34599a2dd95SBruce Richardson int
34699a2dd95SBruce Richardson rte_event_dev_configure(uint8_t dev_id,
34799a2dd95SBruce Richardson 			const struct rte_event_dev_config *dev_conf)
34899a2dd95SBruce Richardson {
34999a2dd95SBruce Richardson 	struct rte_event_dev_info info;
350d35e6132SPavan Nikhilesh 	struct rte_eventdev *dev;
35199a2dd95SBruce Richardson 	int diag;
35299a2dd95SBruce Richardson 
35399a2dd95SBruce Richardson 	RTE_EVENTDEV_VALID_DEVID_OR_ERR_RET(dev_id, -EINVAL);
35499a2dd95SBruce Richardson 	dev = &rte_eventdevs[dev_id];
35599a2dd95SBruce Richardson 
3568f1d23ecSDavid Marchand 	if (*dev->dev_ops->dev_infos_get == NULL)
3578f1d23ecSDavid Marchand 		return -ENOTSUP;
3588f1d23ecSDavid Marchand 	if (*dev->dev_ops->dev_configure == NULL)
3598f1d23ecSDavid Marchand 		return -ENOTSUP;
36099a2dd95SBruce Richardson 
36199a2dd95SBruce Richardson 	if (dev->data->dev_started) {
36299a2dd95SBruce Richardson 		RTE_EDEV_LOG_ERR(
36399a2dd95SBruce Richardson 		    "device %d must be stopped to allow configuration", dev_id);
36499a2dd95SBruce Richardson 		return -EBUSY;
36599a2dd95SBruce Richardson 	}
36699a2dd95SBruce Richardson 
36799a2dd95SBruce Richardson 	if (dev_conf == NULL)
36899a2dd95SBruce Richardson 		return -EINVAL;
36999a2dd95SBruce Richardson 
37099a2dd95SBruce Richardson 	(*dev->dev_ops->dev_infos_get)(dev, &info);
37199a2dd95SBruce Richardson 
37299a2dd95SBruce Richardson 	/* Check dequeue_timeout_ns value is in limit */
37399a2dd95SBruce Richardson 	if (!(dev_conf->event_dev_cfg & RTE_EVENT_DEV_CFG_PER_DEQUEUE_TIMEOUT)) {
37499a2dd95SBruce Richardson 		if (dev_conf->dequeue_timeout_ns &&
37599a2dd95SBruce Richardson 		    (dev_conf->dequeue_timeout_ns < info.min_dequeue_timeout_ns
37699a2dd95SBruce Richardson 			|| dev_conf->dequeue_timeout_ns >
37799a2dd95SBruce Richardson 				 info.max_dequeue_timeout_ns)) {
37899a2dd95SBruce Richardson 			RTE_EDEV_LOG_ERR("dev%d invalid dequeue_timeout_ns=%d"
37999a2dd95SBruce Richardson 			" min_dequeue_timeout_ns=%d max_dequeue_timeout_ns=%d",
38099a2dd95SBruce Richardson 			dev_id, dev_conf->dequeue_timeout_ns,
38199a2dd95SBruce Richardson 			info.min_dequeue_timeout_ns,
38299a2dd95SBruce Richardson 			info.max_dequeue_timeout_ns);
38399a2dd95SBruce Richardson 			return -EINVAL;
38499a2dd95SBruce Richardson 		}
38599a2dd95SBruce Richardson 	}
38699a2dd95SBruce Richardson 
38799a2dd95SBruce Richardson 	/* Check nb_events_limit is in limit */
38899a2dd95SBruce Richardson 	if (dev_conf->nb_events_limit > info.max_num_events) {
38999a2dd95SBruce Richardson 		RTE_EDEV_LOG_ERR("dev%d nb_events_limit=%d > max_num_events=%d",
39099a2dd95SBruce Richardson 		dev_id, dev_conf->nb_events_limit, info.max_num_events);
39199a2dd95SBruce Richardson 		return -EINVAL;
39299a2dd95SBruce Richardson 	}
39399a2dd95SBruce Richardson 
39499a2dd95SBruce Richardson 	/* Check nb_event_queues is in limit */
39599a2dd95SBruce Richardson 	if (!dev_conf->nb_event_queues) {
39699a2dd95SBruce Richardson 		RTE_EDEV_LOG_ERR("dev%d nb_event_queues cannot be zero",
39799a2dd95SBruce Richardson 					dev_id);
39899a2dd95SBruce Richardson 		return -EINVAL;
39999a2dd95SBruce Richardson 	}
40099a2dd95SBruce Richardson 	if (dev_conf->nb_event_queues > info.max_event_queues +
40199a2dd95SBruce Richardson 			info.max_single_link_event_port_queue_pairs) {
40299a2dd95SBruce Richardson 		RTE_EDEV_LOG_ERR("%d nb_event_queues=%d > max_event_queues=%d + max_single_link_event_port_queue_pairs=%d",
40399a2dd95SBruce Richardson 				 dev_id, dev_conf->nb_event_queues,
40499a2dd95SBruce Richardson 				 info.max_event_queues,
40599a2dd95SBruce Richardson 				 info.max_single_link_event_port_queue_pairs);
40699a2dd95SBruce Richardson 		return -EINVAL;
40799a2dd95SBruce Richardson 	}
40899a2dd95SBruce Richardson 	if (dev_conf->nb_event_queues -
40999a2dd95SBruce Richardson 			dev_conf->nb_single_link_event_port_queues >
41099a2dd95SBruce Richardson 			info.max_event_queues) {
41199a2dd95SBruce Richardson 		RTE_EDEV_LOG_ERR("id%d nb_event_queues=%d - nb_single_link_event_port_queues=%d > max_event_queues=%d",
41299a2dd95SBruce Richardson 				 dev_id, dev_conf->nb_event_queues,
41399a2dd95SBruce Richardson 				 dev_conf->nb_single_link_event_port_queues,
41499a2dd95SBruce Richardson 				 info.max_event_queues);
41599a2dd95SBruce Richardson 		return -EINVAL;
41699a2dd95SBruce Richardson 	}
41799a2dd95SBruce Richardson 	if (dev_conf->nb_single_link_event_port_queues >
41899a2dd95SBruce Richardson 			dev_conf->nb_event_queues) {
41999a2dd95SBruce Richardson 		RTE_EDEV_LOG_ERR("dev%d nb_single_link_event_port_queues=%d > nb_event_queues=%d",
42099a2dd95SBruce Richardson 				 dev_id,
42199a2dd95SBruce Richardson 				 dev_conf->nb_single_link_event_port_queues,
42299a2dd95SBruce Richardson 				 dev_conf->nb_event_queues);
42399a2dd95SBruce Richardson 		return -EINVAL;
42499a2dd95SBruce Richardson 	}
42599a2dd95SBruce Richardson 
42699a2dd95SBruce Richardson 	/* Check nb_event_ports is in limit */
42799a2dd95SBruce Richardson 	if (!dev_conf->nb_event_ports) {
42899a2dd95SBruce Richardson 		RTE_EDEV_LOG_ERR("dev%d nb_event_ports cannot be zero", dev_id);
42999a2dd95SBruce Richardson 		return -EINVAL;
43099a2dd95SBruce Richardson 	}
43199a2dd95SBruce Richardson 	if (dev_conf->nb_event_ports > info.max_event_ports +
43299a2dd95SBruce Richardson 			info.max_single_link_event_port_queue_pairs) {
43399a2dd95SBruce Richardson 		RTE_EDEV_LOG_ERR("id%d nb_event_ports=%d > max_event_ports=%d + max_single_link_event_port_queue_pairs=%d",
43499a2dd95SBruce Richardson 				 dev_id, dev_conf->nb_event_ports,
43599a2dd95SBruce Richardson 				 info.max_event_ports,
43699a2dd95SBruce Richardson 				 info.max_single_link_event_port_queue_pairs);
43799a2dd95SBruce Richardson 		return -EINVAL;
43899a2dd95SBruce Richardson 	}
43999a2dd95SBruce Richardson 	if (dev_conf->nb_event_ports -
44099a2dd95SBruce Richardson 			dev_conf->nb_single_link_event_port_queues
44199a2dd95SBruce Richardson 			> info.max_event_ports) {
44299a2dd95SBruce Richardson 		RTE_EDEV_LOG_ERR("id%d nb_event_ports=%d - nb_single_link_event_port_queues=%d > max_event_ports=%d",
44399a2dd95SBruce Richardson 				 dev_id, dev_conf->nb_event_ports,
44499a2dd95SBruce Richardson 				 dev_conf->nb_single_link_event_port_queues,
44599a2dd95SBruce Richardson 				 info.max_event_ports);
44699a2dd95SBruce Richardson 		return -EINVAL;
44799a2dd95SBruce Richardson 	}
44899a2dd95SBruce Richardson 
44999a2dd95SBruce Richardson 	if (dev_conf->nb_single_link_event_port_queues >
45099a2dd95SBruce Richardson 	    dev_conf->nb_event_ports) {
45199a2dd95SBruce Richardson 		RTE_EDEV_LOG_ERR(
45299a2dd95SBruce Richardson 				 "dev%d nb_single_link_event_port_queues=%d > nb_event_ports=%d",
45399a2dd95SBruce Richardson 				 dev_id,
45499a2dd95SBruce Richardson 				 dev_conf->nb_single_link_event_port_queues,
45599a2dd95SBruce Richardson 				 dev_conf->nb_event_ports);
45699a2dd95SBruce Richardson 		return -EINVAL;
45799a2dd95SBruce Richardson 	}
45899a2dd95SBruce Richardson 
45999a2dd95SBruce Richardson 	/* Check nb_event_queue_flows is in limit */
46099a2dd95SBruce Richardson 	if (!dev_conf->nb_event_queue_flows) {
46199a2dd95SBruce Richardson 		RTE_EDEV_LOG_ERR("dev%d nb_flows cannot be zero", dev_id);
46299a2dd95SBruce Richardson 		return -EINVAL;
46399a2dd95SBruce Richardson 	}
46499a2dd95SBruce Richardson 	if (dev_conf->nb_event_queue_flows > info.max_event_queue_flows) {
46599a2dd95SBruce Richardson 		RTE_EDEV_LOG_ERR("dev%d nb_flows=%x > max_flows=%x",
46699a2dd95SBruce Richardson 		dev_id, dev_conf->nb_event_queue_flows,
46799a2dd95SBruce Richardson 		info.max_event_queue_flows);
46899a2dd95SBruce Richardson 		return -EINVAL;
46999a2dd95SBruce Richardson 	}
47099a2dd95SBruce Richardson 
47199a2dd95SBruce Richardson 	/* Check nb_event_port_dequeue_depth is in limit */
47299a2dd95SBruce Richardson 	if (!dev_conf->nb_event_port_dequeue_depth) {
47399a2dd95SBruce Richardson 		RTE_EDEV_LOG_ERR("dev%d nb_dequeue_depth cannot be zero",
47499a2dd95SBruce Richardson 					dev_id);
47599a2dd95SBruce Richardson 		return -EINVAL;
47699a2dd95SBruce Richardson 	}
47799a2dd95SBruce Richardson 	if ((info.event_dev_cap & RTE_EVENT_DEV_CAP_BURST_MODE) &&
47899a2dd95SBruce Richardson 		 (dev_conf->nb_event_port_dequeue_depth >
47999a2dd95SBruce Richardson 			 info.max_event_port_dequeue_depth)) {
48099a2dd95SBruce Richardson 		RTE_EDEV_LOG_ERR("dev%d nb_dq_depth=%d > max_dq_depth=%d",
48199a2dd95SBruce Richardson 		dev_id, dev_conf->nb_event_port_dequeue_depth,
48299a2dd95SBruce Richardson 		info.max_event_port_dequeue_depth);
48399a2dd95SBruce Richardson 		return -EINVAL;
48499a2dd95SBruce Richardson 	}
48599a2dd95SBruce Richardson 
48699a2dd95SBruce Richardson 	/* Check nb_event_port_enqueue_depth is in limit */
48799a2dd95SBruce Richardson 	if (!dev_conf->nb_event_port_enqueue_depth) {
48899a2dd95SBruce Richardson 		RTE_EDEV_LOG_ERR("dev%d nb_enqueue_depth cannot be zero",
48999a2dd95SBruce Richardson 					dev_id);
49099a2dd95SBruce Richardson 		return -EINVAL;
49199a2dd95SBruce Richardson 	}
49299a2dd95SBruce Richardson 	if ((info.event_dev_cap & RTE_EVENT_DEV_CAP_BURST_MODE) &&
49399a2dd95SBruce Richardson 		(dev_conf->nb_event_port_enqueue_depth >
49499a2dd95SBruce Richardson 			 info.max_event_port_enqueue_depth)) {
49599a2dd95SBruce Richardson 		RTE_EDEV_LOG_ERR("dev%d nb_enq_depth=%d > max_enq_depth=%d",
49699a2dd95SBruce Richardson 		dev_id, dev_conf->nb_event_port_enqueue_depth,
49799a2dd95SBruce Richardson 		info.max_event_port_enqueue_depth);
49899a2dd95SBruce Richardson 		return -EINVAL;
49999a2dd95SBruce Richardson 	}
50099a2dd95SBruce Richardson 
50199a2dd95SBruce Richardson 	/* Copy the dev_conf parameter into the dev structure */
50299a2dd95SBruce Richardson 	memcpy(&dev->data->dev_conf, dev_conf, sizeof(dev->data->dev_conf));
50399a2dd95SBruce Richardson 
50499a2dd95SBruce Richardson 	/* Setup new number of queues and reconfigure device. */
5059c67fcbfSPavan Nikhilesh 	diag = event_dev_queue_config(dev, dev_conf->nb_event_queues);
50699a2dd95SBruce Richardson 	if (diag != 0) {
5079c67fcbfSPavan Nikhilesh 		RTE_EDEV_LOG_ERR("dev%d event_dev_queue_config = %d", dev_id,
5089c67fcbfSPavan Nikhilesh 				 diag);
50999a2dd95SBruce Richardson 		return diag;
51099a2dd95SBruce Richardson 	}
51199a2dd95SBruce Richardson 
51299a2dd95SBruce Richardson 	/* Setup new number of ports and reconfigure device. */
5139c67fcbfSPavan Nikhilesh 	diag = event_dev_port_config(dev, dev_conf->nb_event_ports);
51499a2dd95SBruce Richardson 	if (diag != 0) {
5159c67fcbfSPavan Nikhilesh 		event_dev_queue_config(dev, 0);
5169c67fcbfSPavan Nikhilesh 		RTE_EDEV_LOG_ERR("dev%d event_dev_port_config = %d", dev_id,
5179c67fcbfSPavan Nikhilesh 				 diag);
51899a2dd95SBruce Richardson 		return diag;
51999a2dd95SBruce Richardson 	}
52099a2dd95SBruce Richardson 
521d35e6132SPavan Nikhilesh 	event_dev_fp_ops_reset(rte_event_fp_ops + dev_id);
522d35e6132SPavan Nikhilesh 
52399a2dd95SBruce Richardson 	/* Configure the device */
52499a2dd95SBruce Richardson 	diag = (*dev->dev_ops->dev_configure)(dev);
52599a2dd95SBruce Richardson 	if (diag != 0) {
52699a2dd95SBruce Richardson 		RTE_EDEV_LOG_ERR("dev%d dev_configure = %d", dev_id, diag);
527d35e6132SPavan Nikhilesh 		event_dev_fp_ops_reset(rte_event_fp_ops + dev_id);
5289c67fcbfSPavan Nikhilesh 		event_dev_queue_config(dev, 0);
5299c67fcbfSPavan Nikhilesh 		event_dev_port_config(dev, 0);
53099a2dd95SBruce Richardson 	}
53199a2dd95SBruce Richardson 
53299a2dd95SBruce Richardson 	dev->data->event_dev_cap = info.event_dev_cap;
53399a2dd95SBruce Richardson 	rte_eventdev_trace_configure(dev_id, dev_conf, diag);
53499a2dd95SBruce Richardson 	return diag;
53599a2dd95SBruce Richardson }
53699a2dd95SBruce Richardson 
53799a2dd95SBruce Richardson static inline int
53899a2dd95SBruce Richardson is_valid_queue(struct rte_eventdev *dev, uint8_t queue_id)
53999a2dd95SBruce Richardson {
54099a2dd95SBruce Richardson 	if (queue_id < dev->data->nb_queues && queue_id <
54199a2dd95SBruce Richardson 				RTE_EVENT_MAX_QUEUES_PER_DEV)
54299a2dd95SBruce Richardson 		return 1;
54399a2dd95SBruce Richardson 	else
54499a2dd95SBruce Richardson 		return 0;
54599a2dd95SBruce Richardson }
54699a2dd95SBruce Richardson 
54799a2dd95SBruce Richardson int
54899a2dd95SBruce Richardson rte_event_queue_default_conf_get(uint8_t dev_id, uint8_t queue_id,
54999a2dd95SBruce Richardson 				 struct rte_event_queue_conf *queue_conf)
55099a2dd95SBruce Richardson {
55199a2dd95SBruce Richardson 	struct rte_eventdev *dev;
55299a2dd95SBruce Richardson 
55399a2dd95SBruce Richardson 	RTE_EVENTDEV_VALID_DEVID_OR_ERR_RET(dev_id, -EINVAL);
55499a2dd95SBruce Richardson 	dev = &rte_eventdevs[dev_id];
55599a2dd95SBruce Richardson 
55699a2dd95SBruce Richardson 	if (queue_conf == NULL)
55799a2dd95SBruce Richardson 		return -EINVAL;
55899a2dd95SBruce Richardson 
55999a2dd95SBruce Richardson 	if (!is_valid_queue(dev, queue_id)) {
56099a2dd95SBruce Richardson 		RTE_EDEV_LOG_ERR("Invalid queue_id=%" PRIu8, queue_id);
56199a2dd95SBruce Richardson 		return -EINVAL;
56299a2dd95SBruce Richardson 	}
56399a2dd95SBruce Richardson 
5648f1d23ecSDavid Marchand 	if (*dev->dev_ops->queue_def_conf == NULL)
5658f1d23ecSDavid Marchand 		return -ENOTSUP;
56699a2dd95SBruce Richardson 	memset(queue_conf, 0, sizeof(struct rte_event_queue_conf));
56799a2dd95SBruce Richardson 	(*dev->dev_ops->queue_def_conf)(dev, queue_id, queue_conf);
5687f2d9df6SAmit Prakash Shukla 
5697f2d9df6SAmit Prakash Shukla 	rte_eventdev_trace_queue_default_conf_get(dev_id, dev, queue_id, queue_conf);
5707f2d9df6SAmit Prakash Shukla 
57199a2dd95SBruce Richardson 	return 0;
57299a2dd95SBruce Richardson }
57399a2dd95SBruce Richardson 
57499a2dd95SBruce Richardson static inline int
57599a2dd95SBruce Richardson is_valid_atomic_queue_conf(const struct rte_event_queue_conf *queue_conf)
57699a2dd95SBruce Richardson {
57799a2dd95SBruce Richardson 	if (queue_conf &&
57899a2dd95SBruce Richardson 		!(queue_conf->event_queue_cfg &
57999a2dd95SBruce Richardson 		  RTE_EVENT_QUEUE_CFG_SINGLE_LINK) &&
58099a2dd95SBruce Richardson 		((queue_conf->event_queue_cfg &
58199a2dd95SBruce Richardson 			 RTE_EVENT_QUEUE_CFG_ALL_TYPES) ||
58299a2dd95SBruce Richardson 		(queue_conf->schedule_type
58399a2dd95SBruce Richardson 			== RTE_SCHED_TYPE_ATOMIC)
58499a2dd95SBruce Richardson 		))
58599a2dd95SBruce Richardson 		return 1;
58699a2dd95SBruce Richardson 	else
58799a2dd95SBruce Richardson 		return 0;
58899a2dd95SBruce Richardson }
58999a2dd95SBruce Richardson 
59099a2dd95SBruce Richardson static inline int
59199a2dd95SBruce Richardson is_valid_ordered_queue_conf(const struct rte_event_queue_conf *queue_conf)
59299a2dd95SBruce Richardson {
59399a2dd95SBruce Richardson 	if (queue_conf &&
59499a2dd95SBruce Richardson 		!(queue_conf->event_queue_cfg &
59599a2dd95SBruce Richardson 		  RTE_EVENT_QUEUE_CFG_SINGLE_LINK) &&
59699a2dd95SBruce Richardson 		((queue_conf->event_queue_cfg &
59799a2dd95SBruce Richardson 			 RTE_EVENT_QUEUE_CFG_ALL_TYPES) ||
59899a2dd95SBruce Richardson 		(queue_conf->schedule_type
59999a2dd95SBruce Richardson 			== RTE_SCHED_TYPE_ORDERED)
60099a2dd95SBruce Richardson 		))
60199a2dd95SBruce Richardson 		return 1;
60299a2dd95SBruce Richardson 	else
60399a2dd95SBruce Richardson 		return 0;
60499a2dd95SBruce Richardson }
60599a2dd95SBruce Richardson 
60699a2dd95SBruce Richardson 
60799a2dd95SBruce Richardson int
60899a2dd95SBruce Richardson rte_event_queue_setup(uint8_t dev_id, uint8_t queue_id,
60999a2dd95SBruce Richardson 		      const struct rte_event_queue_conf *queue_conf)
61099a2dd95SBruce Richardson {
61199a2dd95SBruce Richardson 	struct rte_eventdev *dev;
61299a2dd95SBruce Richardson 	struct rte_event_queue_conf def_conf;
61399a2dd95SBruce Richardson 
61499a2dd95SBruce Richardson 	RTE_EVENTDEV_VALID_DEVID_OR_ERR_RET(dev_id, -EINVAL);
61599a2dd95SBruce Richardson 	dev = &rte_eventdevs[dev_id];
61699a2dd95SBruce Richardson 
61799a2dd95SBruce Richardson 	if (!is_valid_queue(dev, queue_id)) {
61899a2dd95SBruce Richardson 		RTE_EDEV_LOG_ERR("Invalid queue_id=%" PRIu8, queue_id);
61999a2dd95SBruce Richardson 		return -EINVAL;
62099a2dd95SBruce Richardson 	}
62199a2dd95SBruce Richardson 
62299a2dd95SBruce Richardson 	/* Check nb_atomic_flows limit */
62399a2dd95SBruce Richardson 	if (is_valid_atomic_queue_conf(queue_conf)) {
62499a2dd95SBruce Richardson 		if (queue_conf->nb_atomic_flows == 0 ||
62599a2dd95SBruce Richardson 		    queue_conf->nb_atomic_flows >
62699a2dd95SBruce Richardson 			dev->data->dev_conf.nb_event_queue_flows) {
62799a2dd95SBruce Richardson 			RTE_EDEV_LOG_ERR(
62899a2dd95SBruce Richardson 		"dev%d queue%d Invalid nb_atomic_flows=%d max_flows=%d",
62999a2dd95SBruce Richardson 			dev_id, queue_id, queue_conf->nb_atomic_flows,
63099a2dd95SBruce Richardson 			dev->data->dev_conf.nb_event_queue_flows);
63199a2dd95SBruce Richardson 			return -EINVAL;
63299a2dd95SBruce Richardson 		}
63399a2dd95SBruce Richardson 	}
63499a2dd95SBruce Richardson 
63599a2dd95SBruce Richardson 	/* Check nb_atomic_order_sequences limit */
63699a2dd95SBruce Richardson 	if (is_valid_ordered_queue_conf(queue_conf)) {
63799a2dd95SBruce Richardson 		if (queue_conf->nb_atomic_order_sequences == 0 ||
63899a2dd95SBruce Richardson 		    queue_conf->nb_atomic_order_sequences >
63999a2dd95SBruce Richardson 			dev->data->dev_conf.nb_event_queue_flows) {
64099a2dd95SBruce Richardson 			RTE_EDEV_LOG_ERR(
64199a2dd95SBruce Richardson 		"dev%d queue%d Invalid nb_atomic_order_seq=%d max_flows=%d",
64299a2dd95SBruce Richardson 			dev_id, queue_id, queue_conf->nb_atomic_order_sequences,
64399a2dd95SBruce Richardson 			dev->data->dev_conf.nb_event_queue_flows);
64499a2dd95SBruce Richardson 			return -EINVAL;
64599a2dd95SBruce Richardson 		}
64699a2dd95SBruce Richardson 	}
64799a2dd95SBruce Richardson 
64899a2dd95SBruce Richardson 	if (dev->data->dev_started) {
64999a2dd95SBruce Richardson 		RTE_EDEV_LOG_ERR(
65099a2dd95SBruce Richardson 		    "device %d must be stopped to allow queue setup", dev_id);
65199a2dd95SBruce Richardson 		return -EBUSY;
65299a2dd95SBruce Richardson 	}
65399a2dd95SBruce Richardson 
6548f1d23ecSDavid Marchand 	if (*dev->dev_ops->queue_setup == NULL)
6558f1d23ecSDavid Marchand 		return -ENOTSUP;
65699a2dd95SBruce Richardson 
65799a2dd95SBruce Richardson 	if (queue_conf == NULL) {
6588f1d23ecSDavid Marchand 		if (*dev->dev_ops->queue_def_conf == NULL)
6598f1d23ecSDavid Marchand 			return -ENOTSUP;
66099a2dd95SBruce Richardson 		(*dev->dev_ops->queue_def_conf)(dev, queue_id, &def_conf);
66199a2dd95SBruce Richardson 		queue_conf = &def_conf;
66299a2dd95SBruce Richardson 	}
66399a2dd95SBruce Richardson 
66499a2dd95SBruce Richardson 	dev->data->queues_cfg[queue_id] = *queue_conf;
66599a2dd95SBruce Richardson 	rte_eventdev_trace_queue_setup(dev_id, queue_id, queue_conf);
66699a2dd95SBruce Richardson 	return (*dev->dev_ops->queue_setup)(dev, queue_id, queue_conf);
66799a2dd95SBruce Richardson }
66899a2dd95SBruce Richardson 
66999a2dd95SBruce Richardson static inline int
67099a2dd95SBruce Richardson is_valid_port(struct rte_eventdev *dev, uint8_t port_id)
67199a2dd95SBruce Richardson {
67299a2dd95SBruce Richardson 	if (port_id < dev->data->nb_ports)
67399a2dd95SBruce Richardson 		return 1;
67499a2dd95SBruce Richardson 	else
67599a2dd95SBruce Richardson 		return 0;
67699a2dd95SBruce Richardson }
67799a2dd95SBruce Richardson 
67899a2dd95SBruce Richardson int
67999a2dd95SBruce Richardson rte_event_port_default_conf_get(uint8_t dev_id, uint8_t port_id,
68099a2dd95SBruce Richardson 				 struct rte_event_port_conf *port_conf)
68199a2dd95SBruce Richardson {
68299a2dd95SBruce Richardson 	struct rte_eventdev *dev;
68399a2dd95SBruce Richardson 
68499a2dd95SBruce Richardson 	RTE_EVENTDEV_VALID_DEVID_OR_ERR_RET(dev_id, -EINVAL);
68599a2dd95SBruce Richardson 	dev = &rte_eventdevs[dev_id];
68699a2dd95SBruce Richardson 
68799a2dd95SBruce Richardson 	if (port_conf == NULL)
68899a2dd95SBruce Richardson 		return -EINVAL;
68999a2dd95SBruce Richardson 
69099a2dd95SBruce Richardson 	if (!is_valid_port(dev, port_id)) {
69199a2dd95SBruce Richardson 		RTE_EDEV_LOG_ERR("Invalid port_id=%" PRIu8, port_id);
69299a2dd95SBruce Richardson 		return -EINVAL;
69399a2dd95SBruce Richardson 	}
69499a2dd95SBruce Richardson 
6958f1d23ecSDavid Marchand 	if (*dev->dev_ops->port_def_conf == NULL)
6968f1d23ecSDavid Marchand 		return -ENOTSUP;
69799a2dd95SBruce Richardson 	memset(port_conf, 0, sizeof(struct rte_event_port_conf));
69899a2dd95SBruce Richardson 	(*dev->dev_ops->port_def_conf)(dev, port_id, port_conf);
6997f2d9df6SAmit Prakash Shukla 
7007f2d9df6SAmit Prakash Shukla 	rte_eventdev_trace_port_default_conf_get(dev_id, dev, port_id, port_conf);
7017f2d9df6SAmit Prakash Shukla 
70299a2dd95SBruce Richardson 	return 0;
70399a2dd95SBruce Richardson }
70499a2dd95SBruce Richardson 
70599a2dd95SBruce Richardson int
70699a2dd95SBruce Richardson rte_event_port_setup(uint8_t dev_id, uint8_t port_id,
70799a2dd95SBruce Richardson 		     const struct rte_event_port_conf *port_conf)
70899a2dd95SBruce Richardson {
70999a2dd95SBruce Richardson 	struct rte_eventdev *dev;
71099a2dd95SBruce Richardson 	struct rte_event_port_conf def_conf;
71199a2dd95SBruce Richardson 	int diag;
71299a2dd95SBruce Richardson 
71399a2dd95SBruce Richardson 	RTE_EVENTDEV_VALID_DEVID_OR_ERR_RET(dev_id, -EINVAL);
71499a2dd95SBruce Richardson 	dev = &rte_eventdevs[dev_id];
71599a2dd95SBruce Richardson 
71699a2dd95SBruce Richardson 	if (!is_valid_port(dev, port_id)) {
71799a2dd95SBruce Richardson 		RTE_EDEV_LOG_ERR("Invalid port_id=%" PRIu8, port_id);
71899a2dd95SBruce Richardson 		return -EINVAL;
71999a2dd95SBruce Richardson 	}
72099a2dd95SBruce Richardson 
72199a2dd95SBruce Richardson 	/* Check new_event_threshold limit */
72299a2dd95SBruce Richardson 	if ((port_conf && !port_conf->new_event_threshold) ||
72399a2dd95SBruce Richardson 			(port_conf && port_conf->new_event_threshold >
72499a2dd95SBruce Richardson 				 dev->data->dev_conf.nb_events_limit)) {
72599a2dd95SBruce Richardson 		RTE_EDEV_LOG_ERR(
72699a2dd95SBruce Richardson 		   "dev%d port%d Invalid event_threshold=%d nb_events_limit=%d",
72799a2dd95SBruce Richardson 			dev_id, port_id, port_conf->new_event_threshold,
72899a2dd95SBruce Richardson 			dev->data->dev_conf.nb_events_limit);
72999a2dd95SBruce Richardson 		return -EINVAL;
73099a2dd95SBruce Richardson 	}
73199a2dd95SBruce Richardson 
73299a2dd95SBruce Richardson 	/* Check dequeue_depth limit */
73399a2dd95SBruce Richardson 	if ((port_conf && !port_conf->dequeue_depth) ||
73499a2dd95SBruce Richardson 			(port_conf && port_conf->dequeue_depth >
73599a2dd95SBruce Richardson 		dev->data->dev_conf.nb_event_port_dequeue_depth)) {
73699a2dd95SBruce Richardson 		RTE_EDEV_LOG_ERR(
73799a2dd95SBruce Richardson 		   "dev%d port%d Invalid dequeue depth=%d max_dequeue_depth=%d",
73899a2dd95SBruce Richardson 			dev_id, port_id, port_conf->dequeue_depth,
73999a2dd95SBruce Richardson 			dev->data->dev_conf.nb_event_port_dequeue_depth);
74099a2dd95SBruce Richardson 		return -EINVAL;
74199a2dd95SBruce Richardson 	}
74299a2dd95SBruce Richardson 
74399a2dd95SBruce Richardson 	/* Check enqueue_depth limit */
74499a2dd95SBruce Richardson 	if ((port_conf && !port_conf->enqueue_depth) ||
74599a2dd95SBruce Richardson 			(port_conf && port_conf->enqueue_depth >
74699a2dd95SBruce Richardson 		dev->data->dev_conf.nb_event_port_enqueue_depth)) {
74799a2dd95SBruce Richardson 		RTE_EDEV_LOG_ERR(
74899a2dd95SBruce Richardson 		   "dev%d port%d Invalid enqueue depth=%d max_enqueue_depth=%d",
74999a2dd95SBruce Richardson 			dev_id, port_id, port_conf->enqueue_depth,
75099a2dd95SBruce Richardson 			dev->data->dev_conf.nb_event_port_enqueue_depth);
75199a2dd95SBruce Richardson 		return -EINVAL;
75299a2dd95SBruce Richardson 	}
75399a2dd95SBruce Richardson 
75499a2dd95SBruce Richardson 	if (port_conf &&
75599a2dd95SBruce Richardson 	    (port_conf->event_port_cfg & RTE_EVENT_PORT_CFG_DISABLE_IMPL_REL) &&
75699a2dd95SBruce Richardson 	    !(dev->data->event_dev_cap &
75799a2dd95SBruce Richardson 	      RTE_EVENT_DEV_CAP_IMPLICIT_RELEASE_DISABLE)) {
75899a2dd95SBruce Richardson 		RTE_EDEV_LOG_ERR(
75999a2dd95SBruce Richardson 		   "dev%d port%d Implicit release disable not supported",
76099a2dd95SBruce Richardson 			dev_id, port_id);
76199a2dd95SBruce Richardson 		return -EINVAL;
76299a2dd95SBruce Richardson 	}
76399a2dd95SBruce Richardson 
76499a2dd95SBruce Richardson 	if (dev->data->dev_started) {
76599a2dd95SBruce Richardson 		RTE_EDEV_LOG_ERR(
76699a2dd95SBruce Richardson 		    "device %d must be stopped to allow port setup", dev_id);
76799a2dd95SBruce Richardson 		return -EBUSY;
76899a2dd95SBruce Richardson 	}
76999a2dd95SBruce Richardson 
7708f1d23ecSDavid Marchand 	if (*dev->dev_ops->port_setup == NULL)
7718f1d23ecSDavid Marchand 		return -ENOTSUP;
77299a2dd95SBruce Richardson 
77399a2dd95SBruce Richardson 	if (port_conf == NULL) {
7748f1d23ecSDavid Marchand 		if (*dev->dev_ops->port_def_conf == NULL)
7758f1d23ecSDavid Marchand 			return -ENOTSUP;
77699a2dd95SBruce Richardson 		(*dev->dev_ops->port_def_conf)(dev, port_id, &def_conf);
77799a2dd95SBruce Richardson 		port_conf = &def_conf;
77899a2dd95SBruce Richardson 	}
77999a2dd95SBruce Richardson 
78099a2dd95SBruce Richardson 	dev->data->ports_cfg[port_id] = *port_conf;
78199a2dd95SBruce Richardson 
78299a2dd95SBruce Richardson 	diag = (*dev->dev_ops->port_setup)(dev, port_id, port_conf);
78399a2dd95SBruce Richardson 
78499a2dd95SBruce Richardson 	/* Unlink all the queues from this port(default state after setup) */
78599a2dd95SBruce Richardson 	if (!diag)
78699a2dd95SBruce Richardson 		diag = rte_event_port_unlink(dev_id, port_id, NULL, 0);
78799a2dd95SBruce Richardson 
78899a2dd95SBruce Richardson 	rte_eventdev_trace_port_setup(dev_id, port_id, port_conf, diag);
78999a2dd95SBruce Richardson 	if (diag < 0)
79099a2dd95SBruce Richardson 		return diag;
79199a2dd95SBruce Richardson 
79299a2dd95SBruce Richardson 	return 0;
79399a2dd95SBruce Richardson }
79499a2dd95SBruce Richardson 
7951ff23ce6SPavan Nikhilesh void
7961ff23ce6SPavan Nikhilesh rte_event_port_quiesce(uint8_t dev_id, uint8_t port_id,
7971ff23ce6SPavan Nikhilesh 		       rte_eventdev_port_flush_t release_cb, void *args)
7981ff23ce6SPavan Nikhilesh {
7991ff23ce6SPavan Nikhilesh 	struct rte_eventdev *dev;
8001ff23ce6SPavan Nikhilesh 
8011ff23ce6SPavan Nikhilesh 	RTE_EVENTDEV_VALID_DEVID_OR_RET(dev_id);
8021ff23ce6SPavan Nikhilesh 	dev = &rte_eventdevs[dev_id];
8031ff23ce6SPavan Nikhilesh 
8047f2d9df6SAmit Prakash Shukla 	rte_eventdev_trace_port_quiesce(dev_id, dev, port_id, args);
8057f2d9df6SAmit Prakash Shukla 
8061ff23ce6SPavan Nikhilesh 	if (!is_valid_port(dev, port_id)) {
8071ff23ce6SPavan Nikhilesh 		RTE_EDEV_LOG_ERR("Invalid port_id=%" PRIu8, port_id);
8081ff23ce6SPavan Nikhilesh 		return;
8091ff23ce6SPavan Nikhilesh 	}
8101ff23ce6SPavan Nikhilesh 
8111ff23ce6SPavan Nikhilesh 	if (dev->dev_ops->port_quiesce)
8121ff23ce6SPavan Nikhilesh 		(*dev->dev_ops->port_quiesce)(dev, dev->data->ports[port_id],
8131ff23ce6SPavan Nikhilesh 					      release_cb, args);
8141ff23ce6SPavan Nikhilesh }
8151ff23ce6SPavan Nikhilesh 
81699a2dd95SBruce Richardson int
81799a2dd95SBruce Richardson rte_event_dev_attr_get(uint8_t dev_id, uint32_t attr_id,
81899a2dd95SBruce Richardson 		       uint32_t *attr_value)
81999a2dd95SBruce Richardson {
82099a2dd95SBruce Richardson 	struct rte_eventdev *dev;
82199a2dd95SBruce Richardson 
82299a2dd95SBruce Richardson 	if (!attr_value)
82399a2dd95SBruce Richardson 		return -EINVAL;
82499a2dd95SBruce Richardson 	RTE_EVENTDEV_VALID_DEVID_OR_ERR_RET(dev_id, -EINVAL);
82599a2dd95SBruce Richardson 	dev = &rte_eventdevs[dev_id];
82699a2dd95SBruce Richardson 
82799a2dd95SBruce Richardson 	switch (attr_id) {
82899a2dd95SBruce Richardson 	case RTE_EVENT_DEV_ATTR_PORT_COUNT:
82999a2dd95SBruce Richardson 		*attr_value = dev->data->nb_ports;
83099a2dd95SBruce Richardson 		break;
83199a2dd95SBruce Richardson 	case RTE_EVENT_DEV_ATTR_QUEUE_COUNT:
83299a2dd95SBruce Richardson 		*attr_value = dev->data->nb_queues;
83399a2dd95SBruce Richardson 		break;
83499a2dd95SBruce Richardson 	case RTE_EVENT_DEV_ATTR_STARTED:
83599a2dd95SBruce Richardson 		*attr_value = dev->data->dev_started;
83699a2dd95SBruce Richardson 		break;
83799a2dd95SBruce Richardson 	default:
83899a2dd95SBruce Richardson 		return -EINVAL;
83999a2dd95SBruce Richardson 	}
84099a2dd95SBruce Richardson 
8417f2d9df6SAmit Prakash Shukla 	rte_eventdev_trace_attr_get(dev_id, dev, attr_id, *attr_value);
8427f2d9df6SAmit Prakash Shukla 
84399a2dd95SBruce Richardson 	return 0;
84499a2dd95SBruce Richardson }
84599a2dd95SBruce Richardson 
84699a2dd95SBruce Richardson int
84799a2dd95SBruce Richardson rte_event_port_attr_get(uint8_t dev_id, uint8_t port_id, uint32_t attr_id,
84899a2dd95SBruce Richardson 			uint32_t *attr_value)
84999a2dd95SBruce Richardson {
85099a2dd95SBruce Richardson 	struct rte_eventdev *dev;
85199a2dd95SBruce Richardson 
85299a2dd95SBruce Richardson 	if (!attr_value)
85399a2dd95SBruce Richardson 		return -EINVAL;
85499a2dd95SBruce Richardson 
85599a2dd95SBruce Richardson 	RTE_EVENTDEV_VALID_DEVID_OR_ERR_RET(dev_id, -EINVAL);
85699a2dd95SBruce Richardson 	dev = &rte_eventdevs[dev_id];
85799a2dd95SBruce Richardson 	if (!is_valid_port(dev, port_id)) {
85899a2dd95SBruce Richardson 		RTE_EDEV_LOG_ERR("Invalid port_id=%" PRIu8, port_id);
85999a2dd95SBruce Richardson 		return -EINVAL;
86099a2dd95SBruce Richardson 	}
86199a2dd95SBruce Richardson 
86299a2dd95SBruce Richardson 	switch (attr_id) {
86399a2dd95SBruce Richardson 	case RTE_EVENT_PORT_ATTR_ENQ_DEPTH:
86499a2dd95SBruce Richardson 		*attr_value = dev->data->ports_cfg[port_id].enqueue_depth;
86599a2dd95SBruce Richardson 		break;
86699a2dd95SBruce Richardson 	case RTE_EVENT_PORT_ATTR_DEQ_DEPTH:
86799a2dd95SBruce Richardson 		*attr_value = dev->data->ports_cfg[port_id].dequeue_depth;
86899a2dd95SBruce Richardson 		break;
86999a2dd95SBruce Richardson 	case RTE_EVENT_PORT_ATTR_NEW_EVENT_THRESHOLD:
87099a2dd95SBruce Richardson 		*attr_value = dev->data->ports_cfg[port_id].new_event_threshold;
87199a2dd95SBruce Richardson 		break;
87299a2dd95SBruce Richardson 	case RTE_EVENT_PORT_ATTR_IMPLICIT_RELEASE_DISABLE:
87399a2dd95SBruce Richardson 	{
87499a2dd95SBruce Richardson 		uint32_t config;
87599a2dd95SBruce Richardson 
87699a2dd95SBruce Richardson 		config = dev->data->ports_cfg[port_id].event_port_cfg;
87799a2dd95SBruce Richardson 		*attr_value = !!(config & RTE_EVENT_PORT_CFG_DISABLE_IMPL_REL);
87899a2dd95SBruce Richardson 		break;
87999a2dd95SBruce Richardson 	}
88099a2dd95SBruce Richardson 	default:
88199a2dd95SBruce Richardson 		return -EINVAL;
88299a2dd95SBruce Richardson 	};
8837f2d9df6SAmit Prakash Shukla 
8847f2d9df6SAmit Prakash Shukla 	rte_eventdev_trace_port_attr_get(dev_id, dev, port_id, attr_id, *attr_value);
8857f2d9df6SAmit Prakash Shukla 
88699a2dd95SBruce Richardson 	return 0;
88799a2dd95SBruce Richardson }
88899a2dd95SBruce Richardson 
88999a2dd95SBruce Richardson int
89099a2dd95SBruce Richardson rte_event_queue_attr_get(uint8_t dev_id, uint8_t queue_id, uint32_t attr_id,
89199a2dd95SBruce Richardson 			uint32_t *attr_value)
89299a2dd95SBruce Richardson {
89399a2dd95SBruce Richardson 	struct rte_event_queue_conf *conf;
89499a2dd95SBruce Richardson 	struct rte_eventdev *dev;
89599a2dd95SBruce Richardson 
89699a2dd95SBruce Richardson 	if (!attr_value)
89799a2dd95SBruce Richardson 		return -EINVAL;
89899a2dd95SBruce Richardson 
89999a2dd95SBruce Richardson 	RTE_EVENTDEV_VALID_DEVID_OR_ERR_RET(dev_id, -EINVAL);
90099a2dd95SBruce Richardson 	dev = &rte_eventdevs[dev_id];
90199a2dd95SBruce Richardson 	if (!is_valid_queue(dev, queue_id)) {
90299a2dd95SBruce Richardson 		RTE_EDEV_LOG_ERR("Invalid queue_id=%" PRIu8, queue_id);
90399a2dd95SBruce Richardson 		return -EINVAL;
90499a2dd95SBruce Richardson 	}
90599a2dd95SBruce Richardson 
90699a2dd95SBruce Richardson 	conf = &dev->data->queues_cfg[queue_id];
90799a2dd95SBruce Richardson 
90899a2dd95SBruce Richardson 	switch (attr_id) {
90999a2dd95SBruce Richardson 	case RTE_EVENT_QUEUE_ATTR_PRIORITY:
91099a2dd95SBruce Richardson 		*attr_value = RTE_EVENT_DEV_PRIORITY_NORMAL;
91199a2dd95SBruce Richardson 		if (dev->data->event_dev_cap & RTE_EVENT_DEV_CAP_QUEUE_QOS)
91299a2dd95SBruce Richardson 			*attr_value = conf->priority;
91399a2dd95SBruce Richardson 		break;
91499a2dd95SBruce Richardson 	case RTE_EVENT_QUEUE_ATTR_NB_ATOMIC_FLOWS:
91599a2dd95SBruce Richardson 		*attr_value = conf->nb_atomic_flows;
91699a2dd95SBruce Richardson 		break;
91799a2dd95SBruce Richardson 	case RTE_EVENT_QUEUE_ATTR_NB_ATOMIC_ORDER_SEQUENCES:
91899a2dd95SBruce Richardson 		*attr_value = conf->nb_atomic_order_sequences;
91999a2dd95SBruce Richardson 		break;
92099a2dd95SBruce Richardson 	case RTE_EVENT_QUEUE_ATTR_EVENT_QUEUE_CFG:
92199a2dd95SBruce Richardson 		*attr_value = conf->event_queue_cfg;
92299a2dd95SBruce Richardson 		break;
92399a2dd95SBruce Richardson 	case RTE_EVENT_QUEUE_ATTR_SCHEDULE_TYPE:
92499a2dd95SBruce Richardson 		if (conf->event_queue_cfg & RTE_EVENT_QUEUE_CFG_ALL_TYPES)
92599a2dd95SBruce Richardson 			return -EOVERFLOW;
92699a2dd95SBruce Richardson 
92799a2dd95SBruce Richardson 		*attr_value = conf->schedule_type;
92899a2dd95SBruce Richardson 		break;
92944516e6bSShijith Thotton 	case RTE_EVENT_QUEUE_ATTR_WEIGHT:
93044516e6bSShijith Thotton 		*attr_value = RTE_EVENT_QUEUE_WEIGHT_LOWEST;
9312f279a1bSShijith Thotton 		if (dev->data->event_dev_cap & RTE_EVENT_DEV_CAP_QUEUE_QOS)
9322f279a1bSShijith Thotton 			*attr_value = conf->weight;
93344516e6bSShijith Thotton 		break;
93444516e6bSShijith Thotton 	case RTE_EVENT_QUEUE_ATTR_AFFINITY:
93544516e6bSShijith Thotton 		*attr_value = RTE_EVENT_QUEUE_AFFINITY_LOWEST;
9362f279a1bSShijith Thotton 		if (dev->data->event_dev_cap & RTE_EVENT_DEV_CAP_QUEUE_QOS)
9372f279a1bSShijith Thotton 			*attr_value = conf->affinity;
93844516e6bSShijith Thotton 		break;
93999a2dd95SBruce Richardson 	default:
94099a2dd95SBruce Richardson 		return -EINVAL;
94199a2dd95SBruce Richardson 	};
9427f2d9df6SAmit Prakash Shukla 
9437f2d9df6SAmit Prakash Shukla 	rte_eventdev_trace_queue_attr_get(dev_id, dev, queue_id, attr_id, *attr_value);
9447f2d9df6SAmit Prakash Shukla 
94599a2dd95SBruce Richardson 	return 0;
94699a2dd95SBruce Richardson }
94799a2dd95SBruce Richardson 
94899a2dd95SBruce Richardson int
94997b914f4SShijith Thotton rte_event_queue_attr_set(uint8_t dev_id, uint8_t queue_id, uint32_t attr_id,
95097b914f4SShijith Thotton 			 uint64_t attr_value)
95197b914f4SShijith Thotton {
95297b914f4SShijith Thotton 	struct rte_eventdev *dev;
95397b914f4SShijith Thotton 
9547f2d9df6SAmit Prakash Shukla 	rte_eventdev_trace_queue_attr_set(dev_id, queue_id, attr_id, attr_value);
9557f2d9df6SAmit Prakash Shukla 
95697b914f4SShijith Thotton 	RTE_EVENTDEV_VALID_DEVID_OR_ERR_RET(dev_id, -EINVAL);
95797b914f4SShijith Thotton 	dev = &rte_eventdevs[dev_id];
95897b914f4SShijith Thotton 	if (!is_valid_queue(dev, queue_id)) {
95997b914f4SShijith Thotton 		RTE_EDEV_LOG_ERR("Invalid queue_id=%" PRIu8, queue_id);
96097b914f4SShijith Thotton 		return -EINVAL;
96197b914f4SShijith Thotton 	}
96297b914f4SShijith Thotton 
96397b914f4SShijith Thotton 	if (!(dev->data->event_dev_cap &
96497b914f4SShijith Thotton 	      RTE_EVENT_DEV_CAP_RUNTIME_QUEUE_ATTR)) {
96597b914f4SShijith Thotton 		RTE_EDEV_LOG_ERR(
96697b914f4SShijith Thotton 			"Device %" PRIu8 "does not support changing queue attributes at runtime",
96797b914f4SShijith Thotton 			dev_id);
96897b914f4SShijith Thotton 		return -ENOTSUP;
96997b914f4SShijith Thotton 	}
97097b914f4SShijith Thotton 
9718f1d23ecSDavid Marchand 	if (*dev->dev_ops->queue_attr_set == NULL)
9728f1d23ecSDavid Marchand 		return -ENOTSUP;
97397b914f4SShijith Thotton 	return (*dev->dev_ops->queue_attr_set)(dev, queue_id, attr_id,
97497b914f4SShijith Thotton 					       attr_value);
97597b914f4SShijith Thotton }
97697b914f4SShijith Thotton 
97797b914f4SShijith Thotton int
97899a2dd95SBruce Richardson rte_event_port_link(uint8_t dev_id, uint8_t port_id,
97999a2dd95SBruce Richardson 		    const uint8_t queues[], const uint8_t priorities[],
98099a2dd95SBruce Richardson 		    uint16_t nb_links)
98199a2dd95SBruce Richardson {
982d007a7f3SPavan Nikhilesh 	return rte_event_port_profile_links_set(dev_id, port_id, queues, priorities, nb_links, 0);
983d007a7f3SPavan Nikhilesh }
984d007a7f3SPavan Nikhilesh 
985d007a7f3SPavan Nikhilesh int
986d007a7f3SPavan Nikhilesh rte_event_port_profile_links_set(uint8_t dev_id, uint8_t port_id, const uint8_t queues[],
987d007a7f3SPavan Nikhilesh 				 const uint8_t priorities[], uint16_t nb_links, uint8_t profile_id)
988d007a7f3SPavan Nikhilesh {
98999a2dd95SBruce Richardson 	uint8_t priorities_list[RTE_EVENT_MAX_QUEUES_PER_DEV];
990d007a7f3SPavan Nikhilesh 	uint8_t queues_list[RTE_EVENT_MAX_QUEUES_PER_DEV];
991d007a7f3SPavan Nikhilesh 	struct rte_event_dev_info info;
992d007a7f3SPavan Nikhilesh 	struct rte_eventdev *dev;
99399a2dd95SBruce Richardson 	uint16_t *links_map;
99499a2dd95SBruce Richardson 	int i, diag;
99599a2dd95SBruce Richardson 
99699a2dd95SBruce Richardson 	RTE_EVENTDEV_VALID_DEVID_OR_ERRNO_RET(dev_id, EINVAL, 0);
99799a2dd95SBruce Richardson 	dev = &rte_eventdevs[dev_id];
99899a2dd95SBruce Richardson 
999d007a7f3SPavan Nikhilesh 	if (*dev->dev_ops->dev_infos_get == NULL)
1000d007a7f3SPavan Nikhilesh 		return -ENOTSUP;
1001d007a7f3SPavan Nikhilesh 
1002d007a7f3SPavan Nikhilesh 	(*dev->dev_ops->dev_infos_get)(dev, &info);
1003d007a7f3SPavan Nikhilesh 	if (profile_id >= RTE_EVENT_MAX_PROFILES_PER_PORT ||
1004d007a7f3SPavan Nikhilesh 	    profile_id >= info.max_profiles_per_port) {
1005d007a7f3SPavan Nikhilesh 		RTE_EDEV_LOG_ERR("Invalid profile_id=%" PRIu8, profile_id);
1006d007a7f3SPavan Nikhilesh 		return -EINVAL;
1007d007a7f3SPavan Nikhilesh 	}
1008d007a7f3SPavan Nikhilesh 
100999a2dd95SBruce Richardson 	if (*dev->dev_ops->port_link == NULL) {
101099a2dd95SBruce Richardson 		RTE_EDEV_LOG_ERR("Function not supported\n");
101199a2dd95SBruce Richardson 		rte_errno = ENOTSUP;
101299a2dd95SBruce Richardson 		return 0;
101399a2dd95SBruce Richardson 	}
101499a2dd95SBruce Richardson 
1015d007a7f3SPavan Nikhilesh 	if (profile_id && *dev->dev_ops->port_link_profile == NULL) {
1016d007a7f3SPavan Nikhilesh 		RTE_EDEV_LOG_ERR("Function not supported\n");
1017d007a7f3SPavan Nikhilesh 		rte_errno = ENOTSUP;
1018d007a7f3SPavan Nikhilesh 		return 0;
1019d007a7f3SPavan Nikhilesh 	}
1020d007a7f3SPavan Nikhilesh 
102199a2dd95SBruce Richardson 	if (!is_valid_port(dev, port_id)) {
102299a2dd95SBruce Richardson 		RTE_EDEV_LOG_ERR("Invalid port_id=%" PRIu8, port_id);
102399a2dd95SBruce Richardson 		rte_errno = EINVAL;
102499a2dd95SBruce Richardson 		return 0;
102599a2dd95SBruce Richardson 	}
102699a2dd95SBruce Richardson 
102799a2dd95SBruce Richardson 	if (queues == NULL) {
102899a2dd95SBruce Richardson 		for (i = 0; i < dev->data->nb_queues; i++)
102999a2dd95SBruce Richardson 			queues_list[i] = i;
103099a2dd95SBruce Richardson 
103199a2dd95SBruce Richardson 		queues = queues_list;
103299a2dd95SBruce Richardson 		nb_links = dev->data->nb_queues;
103399a2dd95SBruce Richardson 	}
103499a2dd95SBruce Richardson 
103599a2dd95SBruce Richardson 	if (priorities == NULL) {
103699a2dd95SBruce Richardson 		for (i = 0; i < nb_links; i++)
103799a2dd95SBruce Richardson 			priorities_list[i] = RTE_EVENT_DEV_PRIORITY_NORMAL;
103899a2dd95SBruce Richardson 
103999a2dd95SBruce Richardson 		priorities = priorities_list;
104099a2dd95SBruce Richardson 	}
104199a2dd95SBruce Richardson 
104299a2dd95SBruce Richardson 	for (i = 0; i < nb_links; i++)
104399a2dd95SBruce Richardson 		if (queues[i] >= dev->data->nb_queues) {
104499a2dd95SBruce Richardson 			rte_errno = EINVAL;
104599a2dd95SBruce Richardson 			return 0;
104699a2dd95SBruce Richardson 		}
104799a2dd95SBruce Richardson 
1048d007a7f3SPavan Nikhilesh 	if (profile_id)
1049d007a7f3SPavan Nikhilesh 		diag = (*dev->dev_ops->port_link_profile)(dev, dev->data->ports[port_id], queues,
1050d007a7f3SPavan Nikhilesh 							  priorities, nb_links, profile_id);
1051d007a7f3SPavan Nikhilesh 	else
1052d007a7f3SPavan Nikhilesh 		diag = (*dev->dev_ops->port_link)(dev, dev->data->ports[port_id], queues,
1053d007a7f3SPavan Nikhilesh 						  priorities, nb_links);
105499a2dd95SBruce Richardson 	if (diag < 0)
105599a2dd95SBruce Richardson 		return diag;
105699a2dd95SBruce Richardson 
1057d007a7f3SPavan Nikhilesh 	links_map = dev->data->links_map[profile_id];
105899a2dd95SBruce Richardson 	/* Point links_map to this port specific area */
105999a2dd95SBruce Richardson 	links_map += (port_id * RTE_EVENT_MAX_QUEUES_PER_DEV);
106099a2dd95SBruce Richardson 	for (i = 0; i < diag; i++)
106199a2dd95SBruce Richardson 		links_map[queues[i]] = (uint8_t)priorities[i];
106299a2dd95SBruce Richardson 
1063d007a7f3SPavan Nikhilesh 	rte_eventdev_trace_port_profile_links_set(dev_id, port_id, nb_links, profile_id, diag);
106499a2dd95SBruce Richardson 	return diag;
106599a2dd95SBruce Richardson }
106699a2dd95SBruce Richardson 
106799a2dd95SBruce Richardson int
106899a2dd95SBruce Richardson rte_event_port_unlink(uint8_t dev_id, uint8_t port_id,
106999a2dd95SBruce Richardson 		      uint8_t queues[], uint16_t nb_unlinks)
107099a2dd95SBruce Richardson {
1071d007a7f3SPavan Nikhilesh 	return rte_event_port_profile_unlink(dev_id, port_id, queues, nb_unlinks, 0);
1072d007a7f3SPavan Nikhilesh }
1073d007a7f3SPavan Nikhilesh 
1074d007a7f3SPavan Nikhilesh int
1075d007a7f3SPavan Nikhilesh rte_event_port_profile_unlink(uint8_t dev_id, uint8_t port_id, uint8_t queues[],
1076d007a7f3SPavan Nikhilesh 			      uint16_t nb_unlinks, uint8_t profile_id)
1077d007a7f3SPavan Nikhilesh {
107899a2dd95SBruce Richardson 	uint8_t all_queues[RTE_EVENT_MAX_QUEUES_PER_DEV];
1079d007a7f3SPavan Nikhilesh 	struct rte_event_dev_info info;
1080d007a7f3SPavan Nikhilesh 	struct rte_eventdev *dev;
108199a2dd95SBruce Richardson 	uint16_t *links_map;
1082d007a7f3SPavan Nikhilesh 	int i, diag, j;
108399a2dd95SBruce Richardson 
108499a2dd95SBruce Richardson 	RTE_EVENTDEV_VALID_DEVID_OR_ERRNO_RET(dev_id, EINVAL, 0);
108599a2dd95SBruce Richardson 	dev = &rte_eventdevs[dev_id];
108699a2dd95SBruce Richardson 
1087d007a7f3SPavan Nikhilesh 	if (*dev->dev_ops->dev_infos_get == NULL)
1088d007a7f3SPavan Nikhilesh 		return -ENOTSUP;
1089d007a7f3SPavan Nikhilesh 
1090d007a7f3SPavan Nikhilesh 	(*dev->dev_ops->dev_infos_get)(dev, &info);
1091d007a7f3SPavan Nikhilesh 	if (profile_id >= RTE_EVENT_MAX_PROFILES_PER_PORT ||
1092d007a7f3SPavan Nikhilesh 	    profile_id >= info.max_profiles_per_port) {
1093d007a7f3SPavan Nikhilesh 		RTE_EDEV_LOG_ERR("Invalid profile_id=%" PRIu8, profile_id);
1094d007a7f3SPavan Nikhilesh 		return -EINVAL;
1095d007a7f3SPavan Nikhilesh 	}
1096d007a7f3SPavan Nikhilesh 
109799a2dd95SBruce Richardson 	if (*dev->dev_ops->port_unlink == NULL) {
109899a2dd95SBruce Richardson 		RTE_EDEV_LOG_ERR("Function not supported");
109999a2dd95SBruce Richardson 		rte_errno = ENOTSUP;
110099a2dd95SBruce Richardson 		return 0;
110199a2dd95SBruce Richardson 	}
110299a2dd95SBruce Richardson 
1103d007a7f3SPavan Nikhilesh 	if (profile_id && *dev->dev_ops->port_unlink_profile == NULL) {
1104d007a7f3SPavan Nikhilesh 		RTE_EDEV_LOG_ERR("Function not supported");
1105d007a7f3SPavan Nikhilesh 		rte_errno = ENOTSUP;
1106d007a7f3SPavan Nikhilesh 		return 0;
1107d007a7f3SPavan Nikhilesh 	}
1108d007a7f3SPavan Nikhilesh 
110999a2dd95SBruce Richardson 	if (!is_valid_port(dev, port_id)) {
111099a2dd95SBruce Richardson 		RTE_EDEV_LOG_ERR("Invalid port_id=%" PRIu8, port_id);
111199a2dd95SBruce Richardson 		rte_errno = EINVAL;
111299a2dd95SBruce Richardson 		return 0;
111399a2dd95SBruce Richardson 	}
111499a2dd95SBruce Richardson 
1115d007a7f3SPavan Nikhilesh 	links_map = dev->data->links_map[profile_id];
111699a2dd95SBruce Richardson 	/* Point links_map to this port specific area */
111799a2dd95SBruce Richardson 	links_map += (port_id * RTE_EVENT_MAX_QUEUES_PER_DEV);
111899a2dd95SBruce Richardson 
111999a2dd95SBruce Richardson 	if (queues == NULL) {
112099a2dd95SBruce Richardson 		j = 0;
112199a2dd95SBruce Richardson 		for (i = 0; i < dev->data->nb_queues; i++) {
112299a2dd95SBruce Richardson 			if (links_map[i] !=
112399a2dd95SBruce Richardson 					EVENT_QUEUE_SERVICE_PRIORITY_INVALID) {
112499a2dd95SBruce Richardson 				all_queues[j] = i;
112599a2dd95SBruce Richardson 				j++;
112699a2dd95SBruce Richardson 			}
112799a2dd95SBruce Richardson 		}
112899a2dd95SBruce Richardson 		queues = all_queues;
112999a2dd95SBruce Richardson 	} else {
113099a2dd95SBruce Richardson 		for (j = 0; j < nb_unlinks; j++) {
113199a2dd95SBruce Richardson 			if (links_map[queues[j]] ==
113299a2dd95SBruce Richardson 					EVENT_QUEUE_SERVICE_PRIORITY_INVALID)
113399a2dd95SBruce Richardson 				break;
113499a2dd95SBruce Richardson 		}
113599a2dd95SBruce Richardson 	}
113699a2dd95SBruce Richardson 
113799a2dd95SBruce Richardson 	nb_unlinks = j;
113899a2dd95SBruce Richardson 	for (i = 0; i < nb_unlinks; i++)
113999a2dd95SBruce Richardson 		if (queues[i] >= dev->data->nb_queues) {
114099a2dd95SBruce Richardson 			rte_errno = EINVAL;
114199a2dd95SBruce Richardson 			return 0;
114299a2dd95SBruce Richardson 		}
114399a2dd95SBruce Richardson 
1144d007a7f3SPavan Nikhilesh 	if (profile_id)
1145d007a7f3SPavan Nikhilesh 		diag = (*dev->dev_ops->port_unlink_profile)(dev, dev->data->ports[port_id], queues,
1146d007a7f3SPavan Nikhilesh 							    nb_unlinks, profile_id);
1147d007a7f3SPavan Nikhilesh 	else
1148d007a7f3SPavan Nikhilesh 		diag = (*dev->dev_ops->port_unlink)(dev, dev->data->ports[port_id], queues,
1149d007a7f3SPavan Nikhilesh 						    nb_unlinks);
115099a2dd95SBruce Richardson 	if (diag < 0)
115199a2dd95SBruce Richardson 		return diag;
115299a2dd95SBruce Richardson 
115399a2dd95SBruce Richardson 	for (i = 0; i < diag; i++)
115499a2dd95SBruce Richardson 		links_map[queues[i]] = EVENT_QUEUE_SERVICE_PRIORITY_INVALID;
115599a2dd95SBruce Richardson 
1156d007a7f3SPavan Nikhilesh 	rte_eventdev_trace_port_profile_unlink(dev_id, port_id, nb_unlinks, profile_id, diag);
115799a2dd95SBruce Richardson 	return diag;
115899a2dd95SBruce Richardson }
115999a2dd95SBruce Richardson 
116099a2dd95SBruce Richardson int
116199a2dd95SBruce Richardson rte_event_port_unlinks_in_progress(uint8_t dev_id, uint8_t port_id)
116299a2dd95SBruce Richardson {
116399a2dd95SBruce Richardson 	struct rte_eventdev *dev;
116499a2dd95SBruce Richardson 
11657f2d9df6SAmit Prakash Shukla 	rte_eventdev_trace_port_unlinks_in_progress(dev_id, port_id);
11667f2d9df6SAmit Prakash Shukla 
116799a2dd95SBruce Richardson 	RTE_EVENTDEV_VALID_DEVID_OR_ERR_RET(dev_id, -EINVAL);
116899a2dd95SBruce Richardson 	dev = &rte_eventdevs[dev_id];
116999a2dd95SBruce Richardson 	if (!is_valid_port(dev, port_id)) {
117099a2dd95SBruce Richardson 		RTE_EDEV_LOG_ERR("Invalid port_id=%" PRIu8, port_id);
117199a2dd95SBruce Richardson 		return -EINVAL;
117299a2dd95SBruce Richardson 	}
117399a2dd95SBruce Richardson 
117499a2dd95SBruce Richardson 	/* Return 0 if the PMD does not implement unlinks in progress.
117599a2dd95SBruce Richardson 	 * This allows PMDs which handle unlink synchronously to not implement
117699a2dd95SBruce Richardson 	 * this function at all.
117799a2dd95SBruce Richardson 	 */
11788f1d23ecSDavid Marchand 	if (*dev->dev_ops->port_unlinks_in_progress == NULL)
11798f1d23ecSDavid Marchand 		return 0;
118099a2dd95SBruce Richardson 
118199a2dd95SBruce Richardson 	return (*dev->dev_ops->port_unlinks_in_progress)(dev,
118299a2dd95SBruce Richardson 			dev->data->ports[port_id]);
118399a2dd95SBruce Richardson }
118499a2dd95SBruce Richardson 
118599a2dd95SBruce Richardson int
118699a2dd95SBruce Richardson rte_event_port_links_get(uint8_t dev_id, uint8_t port_id,
118799a2dd95SBruce Richardson 			 uint8_t queues[], uint8_t priorities[])
118899a2dd95SBruce Richardson {
118999a2dd95SBruce Richardson 	struct rte_eventdev *dev;
119099a2dd95SBruce Richardson 	uint16_t *links_map;
119199a2dd95SBruce Richardson 	int i, count = 0;
119299a2dd95SBruce Richardson 
119399a2dd95SBruce Richardson 	RTE_EVENTDEV_VALID_DEVID_OR_ERR_RET(dev_id, -EINVAL);
119499a2dd95SBruce Richardson 	dev = &rte_eventdevs[dev_id];
119599a2dd95SBruce Richardson 	if (!is_valid_port(dev, port_id)) {
119699a2dd95SBruce Richardson 		RTE_EDEV_LOG_ERR("Invalid port_id=%" PRIu8, port_id);
119799a2dd95SBruce Richardson 		return -EINVAL;
119899a2dd95SBruce Richardson 	}
119999a2dd95SBruce Richardson 
1200d007a7f3SPavan Nikhilesh 	/* Use the default profile_id. */
1201d007a7f3SPavan Nikhilesh 	links_map = dev->data->links_map[0];
120299a2dd95SBruce Richardson 	/* Point links_map to this port specific area */
120399a2dd95SBruce Richardson 	links_map += (port_id * RTE_EVENT_MAX_QUEUES_PER_DEV);
120499a2dd95SBruce Richardson 	for (i = 0; i < dev->data->nb_queues; i++) {
120599a2dd95SBruce Richardson 		if (links_map[i] != EVENT_QUEUE_SERVICE_PRIORITY_INVALID) {
120699a2dd95SBruce Richardson 			queues[count] = i;
120799a2dd95SBruce Richardson 			priorities[count] = (uint8_t)links_map[i];
120899a2dd95SBruce Richardson 			++count;
120999a2dd95SBruce Richardson 		}
121099a2dd95SBruce Richardson 	}
12117f2d9df6SAmit Prakash Shukla 
12127f2d9df6SAmit Prakash Shukla 	rte_eventdev_trace_port_links_get(dev_id, port_id, count);
12137f2d9df6SAmit Prakash Shukla 
121499a2dd95SBruce Richardson 	return count;
121599a2dd95SBruce Richardson }
121699a2dd95SBruce Richardson 
121799a2dd95SBruce Richardson int
1218d007a7f3SPavan Nikhilesh rte_event_port_profile_links_get(uint8_t dev_id, uint8_t port_id, uint8_t queues[],
1219d007a7f3SPavan Nikhilesh 				 uint8_t priorities[], uint8_t profile_id)
1220d007a7f3SPavan Nikhilesh {
1221d007a7f3SPavan Nikhilesh 	struct rte_event_dev_info info;
1222d007a7f3SPavan Nikhilesh 	struct rte_eventdev *dev;
1223d007a7f3SPavan Nikhilesh 	uint16_t *links_map;
1224d007a7f3SPavan Nikhilesh 	int i, count = 0;
1225d007a7f3SPavan Nikhilesh 
1226d007a7f3SPavan Nikhilesh 	RTE_EVENTDEV_VALID_DEVID_OR_ERR_RET(dev_id, -EINVAL);
1227d007a7f3SPavan Nikhilesh 
1228d007a7f3SPavan Nikhilesh 	dev = &rte_eventdevs[dev_id];
1229d007a7f3SPavan Nikhilesh 	if (*dev->dev_ops->dev_infos_get == NULL)
1230d007a7f3SPavan Nikhilesh 		return -ENOTSUP;
1231d007a7f3SPavan Nikhilesh 
1232d007a7f3SPavan Nikhilesh 	(*dev->dev_ops->dev_infos_get)(dev, &info);
1233d007a7f3SPavan Nikhilesh 	if (profile_id >= RTE_EVENT_MAX_PROFILES_PER_PORT ||
1234d007a7f3SPavan Nikhilesh 	    profile_id >= info.max_profiles_per_port) {
1235d007a7f3SPavan Nikhilesh 		RTE_EDEV_LOG_ERR("Invalid profile_id=%" PRIu8, profile_id);
1236d007a7f3SPavan Nikhilesh 		return -EINVAL;
1237d007a7f3SPavan Nikhilesh 	}
1238d007a7f3SPavan Nikhilesh 
1239d007a7f3SPavan Nikhilesh 	if (!is_valid_port(dev, port_id)) {
1240d007a7f3SPavan Nikhilesh 		RTE_EDEV_LOG_ERR("Invalid port_id=%" PRIu8, port_id);
1241d007a7f3SPavan Nikhilesh 		return -EINVAL;
1242d007a7f3SPavan Nikhilesh 	}
1243d007a7f3SPavan Nikhilesh 
1244d007a7f3SPavan Nikhilesh 	links_map = dev->data->links_map[profile_id];
1245d007a7f3SPavan Nikhilesh 	/* Point links_map to this port specific area */
1246d007a7f3SPavan Nikhilesh 	links_map += (port_id * RTE_EVENT_MAX_QUEUES_PER_DEV);
1247d007a7f3SPavan Nikhilesh 	for (i = 0; i < dev->data->nb_queues; i++) {
1248d007a7f3SPavan Nikhilesh 		if (links_map[i] != EVENT_QUEUE_SERVICE_PRIORITY_INVALID) {
1249d007a7f3SPavan Nikhilesh 			queues[count] = i;
1250d007a7f3SPavan Nikhilesh 			priorities[count] = (uint8_t)links_map[i];
1251d007a7f3SPavan Nikhilesh 			++count;
1252d007a7f3SPavan Nikhilesh 		}
1253d007a7f3SPavan Nikhilesh 	}
1254d007a7f3SPavan Nikhilesh 
1255d007a7f3SPavan Nikhilesh 	rte_eventdev_trace_port_profile_links_get(dev_id, port_id, profile_id, count);
1256d007a7f3SPavan Nikhilesh 
1257d007a7f3SPavan Nikhilesh 	return count;
1258d007a7f3SPavan Nikhilesh }
1259d007a7f3SPavan Nikhilesh 
1260d007a7f3SPavan Nikhilesh int
126199a2dd95SBruce Richardson rte_event_dequeue_timeout_ticks(uint8_t dev_id, uint64_t ns,
126299a2dd95SBruce Richardson 				 uint64_t *timeout_ticks)
126399a2dd95SBruce Richardson {
126499a2dd95SBruce Richardson 	struct rte_eventdev *dev;
126599a2dd95SBruce Richardson 
12667f2d9df6SAmit Prakash Shukla 	rte_eventdev_trace_dequeue_timeout_ticks(dev_id, ns, timeout_ticks);
12677f2d9df6SAmit Prakash Shukla 
126899a2dd95SBruce Richardson 	RTE_EVENTDEV_VALID_DEVID_OR_ERR_RET(dev_id, -EINVAL);
126999a2dd95SBruce Richardson 	dev = &rte_eventdevs[dev_id];
12708f1d23ecSDavid Marchand 	if (*dev->dev_ops->timeout_ticks == NULL)
12718f1d23ecSDavid Marchand 		return -ENOTSUP;
127299a2dd95SBruce Richardson 
127399a2dd95SBruce Richardson 	if (timeout_ticks == NULL)
127499a2dd95SBruce Richardson 		return -EINVAL;
127599a2dd95SBruce Richardson 
127699a2dd95SBruce Richardson 	return (*dev->dev_ops->timeout_ticks)(dev, ns, timeout_ticks);
127799a2dd95SBruce Richardson }
127899a2dd95SBruce Richardson 
127999a2dd95SBruce Richardson int
128099a2dd95SBruce Richardson rte_event_dev_service_id_get(uint8_t dev_id, uint32_t *service_id)
128199a2dd95SBruce Richardson {
128299a2dd95SBruce Richardson 	struct rte_eventdev *dev;
128399a2dd95SBruce Richardson 
128499a2dd95SBruce Richardson 	RTE_EVENTDEV_VALID_DEVID_OR_ERR_RET(dev_id, -EINVAL);
128599a2dd95SBruce Richardson 	dev = &rte_eventdevs[dev_id];
128699a2dd95SBruce Richardson 
128799a2dd95SBruce Richardson 	if (service_id == NULL)
128899a2dd95SBruce Richardson 		return -EINVAL;
128999a2dd95SBruce Richardson 
129099a2dd95SBruce Richardson 	if (dev->data->service_inited)
129199a2dd95SBruce Richardson 		*service_id = dev->data->service_id;
129299a2dd95SBruce Richardson 
12937f2d9df6SAmit Prakash Shukla 	rte_eventdev_trace_service_id_get(dev_id, *service_id);
12947f2d9df6SAmit Prakash Shukla 
129599a2dd95SBruce Richardson 	return dev->data->service_inited ? 0 : -ESRCH;
129699a2dd95SBruce Richardson }
129799a2dd95SBruce Richardson 
129899a2dd95SBruce Richardson int
129999a2dd95SBruce Richardson rte_event_dev_dump(uint8_t dev_id, FILE *f)
130099a2dd95SBruce Richardson {
130199a2dd95SBruce Richardson 	struct rte_eventdev *dev;
130299a2dd95SBruce Richardson 
130399a2dd95SBruce Richardson 	RTE_EVENTDEV_VALID_DEVID_OR_ERR_RET(dev_id, -EINVAL);
130499a2dd95SBruce Richardson 	dev = &rte_eventdevs[dev_id];
13058f1d23ecSDavid Marchand 	if (*dev->dev_ops->dump == NULL)
13068f1d23ecSDavid Marchand 		return -ENOTSUP;
130799a2dd95SBruce Richardson 	if (f == NULL)
130899a2dd95SBruce Richardson 		return -EINVAL;
130999a2dd95SBruce Richardson 
131099a2dd95SBruce Richardson 	(*dev->dev_ops->dump)(dev, f);
131199a2dd95SBruce Richardson 	return 0;
131299a2dd95SBruce Richardson 
131399a2dd95SBruce Richardson }
131499a2dd95SBruce Richardson 
131599a2dd95SBruce Richardson static int
131699a2dd95SBruce Richardson xstats_get_count(uint8_t dev_id, enum rte_event_dev_xstats_mode mode,
131799a2dd95SBruce Richardson 		uint8_t queue_port_id)
131899a2dd95SBruce Richardson {
131999a2dd95SBruce Richardson 	struct rte_eventdev *dev = &rte_eventdevs[dev_id];
132099a2dd95SBruce Richardson 	if (dev->dev_ops->xstats_get_names != NULL)
132199a2dd95SBruce Richardson 		return (*dev->dev_ops->xstats_get_names)(dev, mode,
132299a2dd95SBruce Richardson 							queue_port_id,
132399a2dd95SBruce Richardson 							NULL, NULL, 0);
132499a2dd95SBruce Richardson 	return 0;
132599a2dd95SBruce Richardson }
132699a2dd95SBruce Richardson 
132799a2dd95SBruce Richardson int
132899a2dd95SBruce Richardson rte_event_dev_xstats_names_get(uint8_t dev_id,
132999a2dd95SBruce Richardson 		enum rte_event_dev_xstats_mode mode, uint8_t queue_port_id,
133099a2dd95SBruce Richardson 		struct rte_event_dev_xstats_name *xstats_names,
13311bdfe4d7SPavan Nikhilesh 		uint64_t *ids, unsigned int size)
133299a2dd95SBruce Richardson {
133399a2dd95SBruce Richardson 	RTE_EVENTDEV_VALID_DEVID_OR_ERR_RET(dev_id, -ENODEV);
133499a2dd95SBruce Richardson 	const int cnt_expected_entries = xstats_get_count(dev_id, mode,
133599a2dd95SBruce Richardson 							  queue_port_id);
133699a2dd95SBruce Richardson 	if (xstats_names == NULL || cnt_expected_entries < 0 ||
133799a2dd95SBruce Richardson 			(int)size < cnt_expected_entries)
133899a2dd95SBruce Richardson 		return cnt_expected_entries;
133999a2dd95SBruce Richardson 
134099a2dd95SBruce Richardson 	/* dev_id checked above */
134199a2dd95SBruce Richardson 	const struct rte_eventdev *dev = &rte_eventdevs[dev_id];
134299a2dd95SBruce Richardson 
134399a2dd95SBruce Richardson 	if (dev->dev_ops->xstats_get_names != NULL)
134499a2dd95SBruce Richardson 		return (*dev->dev_ops->xstats_get_names)(dev, mode,
134599a2dd95SBruce Richardson 				queue_port_id, xstats_names, ids, size);
134699a2dd95SBruce Richardson 
134799a2dd95SBruce Richardson 	return -ENOTSUP;
134899a2dd95SBruce Richardson }
134999a2dd95SBruce Richardson 
135099a2dd95SBruce Richardson /* retrieve eventdev extended statistics */
135199a2dd95SBruce Richardson int
135299a2dd95SBruce Richardson rte_event_dev_xstats_get(uint8_t dev_id, enum rte_event_dev_xstats_mode mode,
13531bdfe4d7SPavan Nikhilesh 		uint8_t queue_port_id, const uint64_t ids[],
135499a2dd95SBruce Richardson 		uint64_t values[], unsigned int n)
135599a2dd95SBruce Richardson {
135699a2dd95SBruce Richardson 	RTE_EVENTDEV_VALID_DEVID_OR_ERR_RET(dev_id, -ENODEV);
135799a2dd95SBruce Richardson 	const struct rte_eventdev *dev = &rte_eventdevs[dev_id];
135899a2dd95SBruce Richardson 
135999a2dd95SBruce Richardson 	/* implemented by the driver */
136099a2dd95SBruce Richardson 	if (dev->dev_ops->xstats_get != NULL)
136199a2dd95SBruce Richardson 		return (*dev->dev_ops->xstats_get)(dev, mode, queue_port_id,
136299a2dd95SBruce Richardson 				ids, values, n);
136399a2dd95SBruce Richardson 	return -ENOTSUP;
136499a2dd95SBruce Richardson }
136599a2dd95SBruce Richardson 
136699a2dd95SBruce Richardson uint64_t
136799a2dd95SBruce Richardson rte_event_dev_xstats_by_name_get(uint8_t dev_id, const char *name,
13681bdfe4d7SPavan Nikhilesh 		uint64_t *id)
136999a2dd95SBruce Richardson {
137099a2dd95SBruce Richardson 	RTE_EVENTDEV_VALID_DEVID_OR_ERR_RET(dev_id, 0);
137199a2dd95SBruce Richardson 	const struct rte_eventdev *dev = &rte_eventdevs[dev_id];
13721bdfe4d7SPavan Nikhilesh 	uint64_t temp = -1;
137399a2dd95SBruce Richardson 
137499a2dd95SBruce Richardson 	if (id != NULL)
137599a2dd95SBruce Richardson 		*id = (unsigned int)-1;
137699a2dd95SBruce Richardson 	else
137799a2dd95SBruce Richardson 		id = &temp; /* ensure driver never gets a NULL value */
137899a2dd95SBruce Richardson 
137999a2dd95SBruce Richardson 	/* implemented by driver */
138099a2dd95SBruce Richardson 	if (dev->dev_ops->xstats_get_by_name != NULL)
138199a2dd95SBruce Richardson 		return (*dev->dev_ops->xstats_get_by_name)(dev, name, id);
138299a2dd95SBruce Richardson 	return -ENOTSUP;
138399a2dd95SBruce Richardson }
138499a2dd95SBruce Richardson 
138599a2dd95SBruce Richardson int rte_event_dev_xstats_reset(uint8_t dev_id,
138699a2dd95SBruce Richardson 		enum rte_event_dev_xstats_mode mode, int16_t queue_port_id,
13871bdfe4d7SPavan Nikhilesh 		const uint64_t ids[], uint32_t nb_ids)
138899a2dd95SBruce Richardson {
138999a2dd95SBruce Richardson 	RTE_EVENTDEV_VALID_DEVID_OR_ERR_RET(dev_id, -EINVAL);
139099a2dd95SBruce Richardson 	struct rte_eventdev *dev = &rte_eventdevs[dev_id];
139199a2dd95SBruce Richardson 
139299a2dd95SBruce Richardson 	if (dev->dev_ops->xstats_reset != NULL)
139399a2dd95SBruce Richardson 		return (*dev->dev_ops->xstats_reset)(dev, mode, queue_port_id,
139499a2dd95SBruce Richardson 							ids, nb_ids);
139599a2dd95SBruce Richardson 	return -ENOTSUP;
139699a2dd95SBruce Richardson }
139799a2dd95SBruce Richardson 
139899a2dd95SBruce Richardson int rte_event_pmd_selftest_seqn_dynfield_offset = -1;
139999a2dd95SBruce Richardson 
140099a2dd95SBruce Richardson int rte_event_dev_selftest(uint8_t dev_id)
140199a2dd95SBruce Richardson {
140299a2dd95SBruce Richardson 	RTE_EVENTDEV_VALID_DEVID_OR_ERR_RET(dev_id, -EINVAL);
140399a2dd95SBruce Richardson 	static const struct rte_mbuf_dynfield test_seqn_dynfield_desc = {
140499a2dd95SBruce Richardson 		.name = "rte_event_pmd_selftest_seqn_dynfield",
140599a2dd95SBruce Richardson 		.size = sizeof(rte_event_pmd_selftest_seqn_t),
140699a2dd95SBruce Richardson 		.align = __alignof__(rte_event_pmd_selftest_seqn_t),
140799a2dd95SBruce Richardson 	};
140899a2dd95SBruce Richardson 	struct rte_eventdev *dev = &rte_eventdevs[dev_id];
140999a2dd95SBruce Richardson 
141099a2dd95SBruce Richardson 	if (dev->dev_ops->dev_selftest != NULL) {
141199a2dd95SBruce Richardson 		rte_event_pmd_selftest_seqn_dynfield_offset =
141299a2dd95SBruce Richardson 			rte_mbuf_dynfield_register(&test_seqn_dynfield_desc);
141399a2dd95SBruce Richardson 		if (rte_event_pmd_selftest_seqn_dynfield_offset < 0)
141499a2dd95SBruce Richardson 			return -ENOMEM;
141599a2dd95SBruce Richardson 		return (*dev->dev_ops->dev_selftest)();
141699a2dd95SBruce Richardson 	}
141799a2dd95SBruce Richardson 	return -ENOTSUP;
141899a2dd95SBruce Richardson }
141999a2dd95SBruce Richardson 
142099a2dd95SBruce Richardson struct rte_mempool *
142199a2dd95SBruce Richardson rte_event_vector_pool_create(const char *name, unsigned int n,
142299a2dd95SBruce Richardson 			     unsigned int cache_size, uint16_t nb_elem,
142399a2dd95SBruce Richardson 			     int socket_id)
142499a2dd95SBruce Richardson {
142599a2dd95SBruce Richardson 	const char *mp_ops_name;
142699a2dd95SBruce Richardson 	struct rte_mempool *mp;
142799a2dd95SBruce Richardson 	unsigned int elt_sz;
142899a2dd95SBruce Richardson 	int ret;
142999a2dd95SBruce Richardson 
143099a2dd95SBruce Richardson 	if (!nb_elem) {
143199a2dd95SBruce Richardson 		RTE_LOG(ERR, EVENTDEV,
143299a2dd95SBruce Richardson 			"Invalid number of elements=%d requested\n", nb_elem);
143399a2dd95SBruce Richardson 		rte_errno = EINVAL;
143499a2dd95SBruce Richardson 		return NULL;
143599a2dd95SBruce Richardson 	}
143699a2dd95SBruce Richardson 
143799a2dd95SBruce Richardson 	elt_sz =
143899a2dd95SBruce Richardson 		sizeof(struct rte_event_vector) + (nb_elem * sizeof(uintptr_t));
143999a2dd95SBruce Richardson 	mp = rte_mempool_create_empty(name, n, elt_sz, cache_size, 0, socket_id,
144099a2dd95SBruce Richardson 				      0);
144199a2dd95SBruce Richardson 	if (mp == NULL)
144299a2dd95SBruce Richardson 		return NULL;
144399a2dd95SBruce Richardson 
144499a2dd95SBruce Richardson 	mp_ops_name = rte_mbuf_best_mempool_ops();
144599a2dd95SBruce Richardson 	ret = rte_mempool_set_ops_byname(mp, mp_ops_name, NULL);
144699a2dd95SBruce Richardson 	if (ret != 0) {
144799a2dd95SBruce Richardson 		RTE_LOG(ERR, EVENTDEV, "error setting mempool handler\n");
144899a2dd95SBruce Richardson 		goto err;
144999a2dd95SBruce Richardson 	}
145099a2dd95SBruce Richardson 
145199a2dd95SBruce Richardson 	ret = rte_mempool_populate_default(mp);
145299a2dd95SBruce Richardson 	if (ret < 0)
145399a2dd95SBruce Richardson 		goto err;
145499a2dd95SBruce Richardson 
14557f2d9df6SAmit Prakash Shukla 	rte_eventdev_trace_vector_pool_create(mp, mp->name, mp->socket_id,
14567f2d9df6SAmit Prakash Shukla 		mp->size, mp->cache_size, mp->elt_size);
14577f2d9df6SAmit Prakash Shukla 
145899a2dd95SBruce Richardson 	return mp;
145999a2dd95SBruce Richardson err:
146099a2dd95SBruce Richardson 	rte_mempool_free(mp);
146199a2dd95SBruce Richardson 	rte_errno = -ret;
146299a2dd95SBruce Richardson 	return NULL;
146399a2dd95SBruce Richardson }
146499a2dd95SBruce Richardson 
146599a2dd95SBruce Richardson int
146699a2dd95SBruce Richardson rte_event_dev_start(uint8_t dev_id)
146799a2dd95SBruce Richardson {
146899a2dd95SBruce Richardson 	struct rte_eventdev *dev;
146999a2dd95SBruce Richardson 	int diag;
147099a2dd95SBruce Richardson 
147199a2dd95SBruce Richardson 	RTE_EDEV_LOG_DEBUG("Start dev_id=%" PRIu8, dev_id);
147299a2dd95SBruce Richardson 
147399a2dd95SBruce Richardson 	RTE_EVENTDEV_VALID_DEVID_OR_ERR_RET(dev_id, -EINVAL);
147499a2dd95SBruce Richardson 	dev = &rte_eventdevs[dev_id];
14758f1d23ecSDavid Marchand 	if (*dev->dev_ops->dev_start == NULL)
14768f1d23ecSDavid Marchand 		return -ENOTSUP;
147799a2dd95SBruce Richardson 
147899a2dd95SBruce Richardson 	if (dev->data->dev_started != 0) {
147999a2dd95SBruce Richardson 		RTE_EDEV_LOG_ERR("Device with dev_id=%" PRIu8 "already started",
148099a2dd95SBruce Richardson 			dev_id);
148199a2dd95SBruce Richardson 		return 0;
148299a2dd95SBruce Richardson 	}
148399a2dd95SBruce Richardson 
148499a2dd95SBruce Richardson 	diag = (*dev->dev_ops->dev_start)(dev);
148599a2dd95SBruce Richardson 	rte_eventdev_trace_start(dev_id, diag);
148699a2dd95SBruce Richardson 	if (diag == 0)
148799a2dd95SBruce Richardson 		dev->data->dev_started = 1;
148899a2dd95SBruce Richardson 	else
148999a2dd95SBruce Richardson 		return diag;
149099a2dd95SBruce Richardson 
1491d35e6132SPavan Nikhilesh 	event_dev_fp_ops_set(rte_event_fp_ops + dev_id, dev);
1492d35e6132SPavan Nikhilesh 
149399a2dd95SBruce Richardson 	return 0;
149499a2dd95SBruce Richardson }
149599a2dd95SBruce Richardson 
149699a2dd95SBruce Richardson int
149799a2dd95SBruce Richardson rte_event_dev_stop_flush_callback_register(uint8_t dev_id,
1498d986276fSPavan Nikhilesh 					   rte_eventdev_stop_flush_t callback,
1499d986276fSPavan Nikhilesh 					   void *userdata)
150099a2dd95SBruce Richardson {
150199a2dd95SBruce Richardson 	struct rte_eventdev *dev;
150299a2dd95SBruce Richardson 
150399a2dd95SBruce Richardson 	RTE_EDEV_LOG_DEBUG("Stop flush register dev_id=%" PRIu8, dev_id);
150499a2dd95SBruce Richardson 
15057f2d9df6SAmit Prakash Shukla 	rte_eventdev_trace_stop_flush_callback_register(dev_id, callback, userdata);
15067f2d9df6SAmit Prakash Shukla 
150799a2dd95SBruce Richardson 	RTE_EVENTDEV_VALID_DEVID_OR_ERR_RET(dev_id, -EINVAL);
150899a2dd95SBruce Richardson 	dev = &rte_eventdevs[dev_id];
150999a2dd95SBruce Richardson 
151099a2dd95SBruce Richardson 	dev->dev_ops->dev_stop_flush = callback;
151199a2dd95SBruce Richardson 	dev->data->dev_stop_flush_arg = userdata;
151299a2dd95SBruce Richardson 
151399a2dd95SBruce Richardson 	return 0;
151499a2dd95SBruce Richardson }
151599a2dd95SBruce Richardson 
151699a2dd95SBruce Richardson void
151799a2dd95SBruce Richardson rte_event_dev_stop(uint8_t dev_id)
151899a2dd95SBruce Richardson {
151999a2dd95SBruce Richardson 	struct rte_eventdev *dev;
152099a2dd95SBruce Richardson 
152199a2dd95SBruce Richardson 	RTE_EDEV_LOG_DEBUG("Stop dev_id=%" PRIu8, dev_id);
152299a2dd95SBruce Richardson 
152399a2dd95SBruce Richardson 	RTE_EVENTDEV_VALID_DEVID_OR_RET(dev_id);
152499a2dd95SBruce Richardson 	dev = &rte_eventdevs[dev_id];
15258f1d23ecSDavid Marchand 	if (*dev->dev_ops->dev_stop == NULL)
15268f1d23ecSDavid Marchand 		return;
152799a2dd95SBruce Richardson 
152899a2dd95SBruce Richardson 	if (dev->data->dev_started == 0) {
152999a2dd95SBruce Richardson 		RTE_EDEV_LOG_ERR("Device with dev_id=%" PRIu8 "already stopped",
153099a2dd95SBruce Richardson 			dev_id);
153199a2dd95SBruce Richardson 		return;
153299a2dd95SBruce Richardson 	}
153399a2dd95SBruce Richardson 
153499a2dd95SBruce Richardson 	dev->data->dev_started = 0;
153599a2dd95SBruce Richardson 	(*dev->dev_ops->dev_stop)(dev);
153699a2dd95SBruce Richardson 	rte_eventdev_trace_stop(dev_id);
1537d35e6132SPavan Nikhilesh 	event_dev_fp_ops_reset(rte_event_fp_ops + dev_id);
153899a2dd95SBruce Richardson }
153999a2dd95SBruce Richardson 
154099a2dd95SBruce Richardson int
154199a2dd95SBruce Richardson rte_event_dev_close(uint8_t dev_id)
154299a2dd95SBruce Richardson {
154399a2dd95SBruce Richardson 	struct rte_eventdev *dev;
154499a2dd95SBruce Richardson 
154599a2dd95SBruce Richardson 	RTE_EVENTDEV_VALID_DEVID_OR_ERR_RET(dev_id, -EINVAL);
154699a2dd95SBruce Richardson 	dev = &rte_eventdevs[dev_id];
15478f1d23ecSDavid Marchand 	if (*dev->dev_ops->dev_close == NULL)
15488f1d23ecSDavid Marchand 		return -ENOTSUP;
154999a2dd95SBruce Richardson 
155099a2dd95SBruce Richardson 	/* Device must be stopped before it can be closed */
155199a2dd95SBruce Richardson 	if (dev->data->dev_started == 1) {
155299a2dd95SBruce Richardson 		RTE_EDEV_LOG_ERR("Device %u must be stopped before closing",
155399a2dd95SBruce Richardson 				dev_id);
155499a2dd95SBruce Richardson 		return -EBUSY;
155599a2dd95SBruce Richardson 	}
155699a2dd95SBruce Richardson 
1557d35e6132SPavan Nikhilesh 	event_dev_fp_ops_reset(rte_event_fp_ops + dev_id);
155899a2dd95SBruce Richardson 	rte_eventdev_trace_close(dev_id);
155999a2dd95SBruce Richardson 	return (*dev->dev_ops->dev_close)(dev);
156099a2dd95SBruce Richardson }
156199a2dd95SBruce Richardson 
156299a2dd95SBruce Richardson static inline int
15639c67fcbfSPavan Nikhilesh eventdev_data_alloc(uint8_t dev_id, struct rte_eventdev_data **data,
156499a2dd95SBruce Richardson 		    int socket_id)
156599a2dd95SBruce Richardson {
156699a2dd95SBruce Richardson 	char mz_name[RTE_EVENTDEV_NAME_MAX_LEN];
156799a2dd95SBruce Richardson 	const struct rte_memzone *mz;
1568d007a7f3SPavan Nikhilesh 	int i, n;
156999a2dd95SBruce Richardson 
157099a2dd95SBruce Richardson 	/* Generate memzone name */
157199a2dd95SBruce Richardson 	n = snprintf(mz_name, sizeof(mz_name), "rte_eventdev_data_%u", dev_id);
157299a2dd95SBruce Richardson 	if (n >= (int)sizeof(mz_name))
157399a2dd95SBruce Richardson 		return -EINVAL;
157499a2dd95SBruce Richardson 
157599a2dd95SBruce Richardson 	if (rte_eal_process_type() == RTE_PROC_PRIMARY) {
157699a2dd95SBruce Richardson 		mz = rte_memzone_reserve(mz_name,
157799a2dd95SBruce Richardson 				sizeof(struct rte_eventdev_data),
157899a2dd95SBruce Richardson 				socket_id, 0);
157999a2dd95SBruce Richardson 	} else
158099a2dd95SBruce Richardson 		mz = rte_memzone_lookup(mz_name);
158199a2dd95SBruce Richardson 
158299a2dd95SBruce Richardson 	if (mz == NULL)
158399a2dd95SBruce Richardson 		return -ENOMEM;
158499a2dd95SBruce Richardson 
158599a2dd95SBruce Richardson 	*data = mz->addr;
15869c67fcbfSPavan Nikhilesh 	if (rte_eal_process_type() == RTE_PROC_PRIMARY) {
158799a2dd95SBruce Richardson 		memset(*data, 0, sizeof(struct rte_eventdev_data));
1588d007a7f3SPavan Nikhilesh 		for (i = 0; i < RTE_EVENT_MAX_PROFILES_PER_PORT; i++)
1589d007a7f3SPavan Nikhilesh 			for (n = 0; n < RTE_EVENT_MAX_PORTS_PER_DEV * RTE_EVENT_MAX_QUEUES_PER_DEV;
15909c67fcbfSPavan Nikhilesh 			     n++)
1591d007a7f3SPavan Nikhilesh 				(*data)->links_map[i][n] = EVENT_QUEUE_SERVICE_PRIORITY_INVALID;
15929c67fcbfSPavan Nikhilesh 	}
159399a2dd95SBruce Richardson 
159499a2dd95SBruce Richardson 	return 0;
159599a2dd95SBruce Richardson }
159699a2dd95SBruce Richardson 
159799a2dd95SBruce Richardson static inline uint8_t
15989c67fcbfSPavan Nikhilesh eventdev_find_free_device_index(void)
159999a2dd95SBruce Richardson {
160099a2dd95SBruce Richardson 	uint8_t dev_id;
160199a2dd95SBruce Richardson 
160299a2dd95SBruce Richardson 	for (dev_id = 0; dev_id < RTE_EVENT_MAX_DEVS; dev_id++) {
160399a2dd95SBruce Richardson 		if (rte_eventdevs[dev_id].attached ==
160499a2dd95SBruce Richardson 				RTE_EVENTDEV_DETACHED)
160599a2dd95SBruce Richardson 			return dev_id;
160699a2dd95SBruce Richardson 	}
160799a2dd95SBruce Richardson 	return RTE_EVENT_MAX_DEVS;
160899a2dd95SBruce Richardson }
160999a2dd95SBruce Richardson 
161099a2dd95SBruce Richardson struct rte_eventdev *
161199a2dd95SBruce Richardson rte_event_pmd_allocate(const char *name, int socket_id)
161299a2dd95SBruce Richardson {
161399a2dd95SBruce Richardson 	struct rte_eventdev *eventdev;
161499a2dd95SBruce Richardson 	uint8_t dev_id;
161599a2dd95SBruce Richardson 
161699a2dd95SBruce Richardson 	if (rte_event_pmd_get_named_dev(name) != NULL) {
161799a2dd95SBruce Richardson 		RTE_EDEV_LOG_ERR("Event device with name %s already "
161899a2dd95SBruce Richardson 				"allocated!", name);
161999a2dd95SBruce Richardson 		return NULL;
162099a2dd95SBruce Richardson 	}
162199a2dd95SBruce Richardson 
16229c67fcbfSPavan Nikhilesh 	dev_id = eventdev_find_free_device_index();
162399a2dd95SBruce Richardson 	if (dev_id == RTE_EVENT_MAX_DEVS) {
162499a2dd95SBruce Richardson 		RTE_EDEV_LOG_ERR("Reached maximum number of event devices");
162599a2dd95SBruce Richardson 		return NULL;
162699a2dd95SBruce Richardson 	}
162799a2dd95SBruce Richardson 
162899a2dd95SBruce Richardson 	eventdev = &rte_eventdevs[dev_id];
162999a2dd95SBruce Richardson 
163099a2dd95SBruce Richardson 	if (eventdev->data == NULL) {
163199a2dd95SBruce Richardson 		struct rte_eventdev_data *eventdev_data = NULL;
163299a2dd95SBruce Richardson 
16339c67fcbfSPavan Nikhilesh 		int retval =
16349c67fcbfSPavan Nikhilesh 			eventdev_data_alloc(dev_id, &eventdev_data, socket_id);
163599a2dd95SBruce Richardson 
163699a2dd95SBruce Richardson 		if (retval < 0 || eventdev_data == NULL)
163799a2dd95SBruce Richardson 			return NULL;
163899a2dd95SBruce Richardson 
163999a2dd95SBruce Richardson 		eventdev->data = eventdev_data;
164099a2dd95SBruce Richardson 
164199a2dd95SBruce Richardson 		if (rte_eal_process_type() == RTE_PROC_PRIMARY) {
164299a2dd95SBruce Richardson 
164399a2dd95SBruce Richardson 			strlcpy(eventdev->data->name, name,
164499a2dd95SBruce Richardson 				RTE_EVENTDEV_NAME_MAX_LEN);
164599a2dd95SBruce Richardson 
164699a2dd95SBruce Richardson 			eventdev->data->dev_id = dev_id;
164799a2dd95SBruce Richardson 			eventdev->data->socket_id = socket_id;
164899a2dd95SBruce Richardson 			eventdev->data->dev_started = 0;
164999a2dd95SBruce Richardson 		}
165099a2dd95SBruce Richardson 
165199a2dd95SBruce Richardson 		eventdev->attached = RTE_EVENTDEV_ATTACHED;
165299a2dd95SBruce Richardson 		eventdev_globals.nb_devs++;
165399a2dd95SBruce Richardson 	}
165499a2dd95SBruce Richardson 
165599a2dd95SBruce Richardson 	return eventdev;
165699a2dd95SBruce Richardson }
165799a2dd95SBruce Richardson 
165899a2dd95SBruce Richardson int
165999a2dd95SBruce Richardson rte_event_pmd_release(struct rte_eventdev *eventdev)
166099a2dd95SBruce Richardson {
166199a2dd95SBruce Richardson 	int ret;
166299a2dd95SBruce Richardson 	char mz_name[RTE_EVENTDEV_NAME_MAX_LEN];
166399a2dd95SBruce Richardson 	const struct rte_memzone *mz;
166499a2dd95SBruce Richardson 
166599a2dd95SBruce Richardson 	if (eventdev == NULL)
166699a2dd95SBruce Richardson 		return -EINVAL;
166799a2dd95SBruce Richardson 
1668d35e6132SPavan Nikhilesh 	event_dev_fp_ops_reset(rte_event_fp_ops + eventdev->data->dev_id);
166999a2dd95SBruce Richardson 	eventdev->attached = RTE_EVENTDEV_DETACHED;
167099a2dd95SBruce Richardson 	eventdev_globals.nb_devs--;
167199a2dd95SBruce Richardson 
167299a2dd95SBruce Richardson 	if (rte_eal_process_type() == RTE_PROC_PRIMARY) {
167399a2dd95SBruce Richardson 		rte_free(eventdev->data->dev_private);
167499a2dd95SBruce Richardson 
167599a2dd95SBruce Richardson 		/* Generate memzone name */
167699a2dd95SBruce Richardson 		ret = snprintf(mz_name, sizeof(mz_name), "rte_eventdev_data_%u",
167799a2dd95SBruce Richardson 				eventdev->data->dev_id);
167899a2dd95SBruce Richardson 		if (ret >= (int)sizeof(mz_name))
167999a2dd95SBruce Richardson 			return -EINVAL;
168099a2dd95SBruce Richardson 
168199a2dd95SBruce Richardson 		mz = rte_memzone_lookup(mz_name);
168299a2dd95SBruce Richardson 		if (mz == NULL)
168399a2dd95SBruce Richardson 			return -ENOMEM;
168499a2dd95SBruce Richardson 
168599a2dd95SBruce Richardson 		ret = rte_memzone_free(mz);
168699a2dd95SBruce Richardson 		if (ret)
168799a2dd95SBruce Richardson 			return ret;
168899a2dd95SBruce Richardson 	}
168999a2dd95SBruce Richardson 
169099a2dd95SBruce Richardson 	eventdev->data = NULL;
169199a2dd95SBruce Richardson 	return 0;
169299a2dd95SBruce Richardson }
169399a2dd95SBruce Richardson 
1694d35e6132SPavan Nikhilesh void
1695d35e6132SPavan Nikhilesh event_dev_probing_finish(struct rte_eventdev *eventdev)
1696d35e6132SPavan Nikhilesh {
1697d35e6132SPavan Nikhilesh 	if (eventdev == NULL)
1698d35e6132SPavan Nikhilesh 		return;
1699d35e6132SPavan Nikhilesh 
1700d35e6132SPavan Nikhilesh 	event_dev_fp_ops_set(rte_event_fp_ops + eventdev->data->dev_id,
1701d35e6132SPavan Nikhilesh 			     eventdev);
1702d35e6132SPavan Nikhilesh }
170399a2dd95SBruce Richardson 
170499a2dd95SBruce Richardson static int
170599a2dd95SBruce Richardson handle_dev_list(const char *cmd __rte_unused,
170699a2dd95SBruce Richardson 		const char *params __rte_unused,
170799a2dd95SBruce Richardson 		struct rte_tel_data *d)
170899a2dd95SBruce Richardson {
170999a2dd95SBruce Richardson 	uint8_t dev_id;
171099a2dd95SBruce Richardson 	int ndev = rte_event_dev_count();
171199a2dd95SBruce Richardson 
171299a2dd95SBruce Richardson 	if (ndev < 1)
171399a2dd95SBruce Richardson 		return -1;
171499a2dd95SBruce Richardson 
171599a2dd95SBruce Richardson 	rte_tel_data_start_array(d, RTE_TEL_INT_VAL);
171699a2dd95SBruce Richardson 	for (dev_id = 0; dev_id < RTE_EVENT_MAX_DEVS; dev_id++) {
171799a2dd95SBruce Richardson 		if (rte_eventdevs[dev_id].attached ==
171899a2dd95SBruce Richardson 				RTE_EVENTDEV_ATTACHED)
171999a2dd95SBruce Richardson 			rte_tel_data_add_array_int(d, dev_id);
172099a2dd95SBruce Richardson 	}
172199a2dd95SBruce Richardson 
172299a2dd95SBruce Richardson 	return 0;
172399a2dd95SBruce Richardson }
172499a2dd95SBruce Richardson 
172599a2dd95SBruce Richardson static int
172699a2dd95SBruce Richardson handle_port_list(const char *cmd __rte_unused,
172799a2dd95SBruce Richardson 		 const char *params,
172899a2dd95SBruce Richardson 		 struct rte_tel_data *d)
172999a2dd95SBruce Richardson {
173099a2dd95SBruce Richardson 	int i;
173199a2dd95SBruce Richardson 	uint8_t dev_id;
173299a2dd95SBruce Richardson 	struct rte_eventdev *dev;
173399a2dd95SBruce Richardson 	char *end_param;
173499a2dd95SBruce Richardson 
173599a2dd95SBruce Richardson 	if (params == NULL || strlen(params) == 0 || !isdigit(*params))
173699a2dd95SBruce Richardson 		return -1;
173799a2dd95SBruce Richardson 
173899a2dd95SBruce Richardson 	dev_id = strtoul(params, &end_param, 10);
173999a2dd95SBruce Richardson 	if (*end_param != '\0')
174099a2dd95SBruce Richardson 		RTE_EDEV_LOG_DEBUG(
174199a2dd95SBruce Richardson 			"Extra parameters passed to eventdev telemetry command, ignoring");
174299a2dd95SBruce Richardson 
174399a2dd95SBruce Richardson 	RTE_EVENTDEV_VALID_DEVID_OR_ERR_RET(dev_id, -EINVAL);
174499a2dd95SBruce Richardson 	dev = &rte_eventdevs[dev_id];
174599a2dd95SBruce Richardson 
174699a2dd95SBruce Richardson 	rte_tel_data_start_array(d, RTE_TEL_INT_VAL);
174799a2dd95SBruce Richardson 	for (i = 0; i < dev->data->nb_ports; i++)
174899a2dd95SBruce Richardson 		rte_tel_data_add_array_int(d, i);
174999a2dd95SBruce Richardson 
175099a2dd95SBruce Richardson 	return 0;
175199a2dd95SBruce Richardson }
175299a2dd95SBruce Richardson 
175399a2dd95SBruce Richardson static int
175499a2dd95SBruce Richardson handle_queue_list(const char *cmd __rte_unused,
175599a2dd95SBruce Richardson 		  const char *params,
175699a2dd95SBruce Richardson 		  struct rte_tel_data *d)
175799a2dd95SBruce Richardson {
175899a2dd95SBruce Richardson 	int i;
175999a2dd95SBruce Richardson 	uint8_t dev_id;
176099a2dd95SBruce Richardson 	struct rte_eventdev *dev;
176199a2dd95SBruce Richardson 	char *end_param;
176299a2dd95SBruce Richardson 
176399a2dd95SBruce Richardson 	if (params == NULL || strlen(params) == 0 || !isdigit(*params))
176499a2dd95SBruce Richardson 		return -1;
176599a2dd95SBruce Richardson 
176699a2dd95SBruce Richardson 	dev_id = strtoul(params, &end_param, 10);
176799a2dd95SBruce Richardson 	if (*end_param != '\0')
176899a2dd95SBruce Richardson 		RTE_EDEV_LOG_DEBUG(
176999a2dd95SBruce Richardson 			"Extra parameters passed to eventdev telemetry command, ignoring");
177099a2dd95SBruce Richardson 
177199a2dd95SBruce Richardson 	RTE_EVENTDEV_VALID_DEVID_OR_ERR_RET(dev_id, -EINVAL);
177299a2dd95SBruce Richardson 	dev = &rte_eventdevs[dev_id];
177399a2dd95SBruce Richardson 
177499a2dd95SBruce Richardson 	rte_tel_data_start_array(d, RTE_TEL_INT_VAL);
177599a2dd95SBruce Richardson 	for (i = 0; i < dev->data->nb_queues; i++)
177699a2dd95SBruce Richardson 		rte_tel_data_add_array_int(d, i);
177799a2dd95SBruce Richardson 
177899a2dd95SBruce Richardson 	return 0;
177999a2dd95SBruce Richardson }
178099a2dd95SBruce Richardson 
178199a2dd95SBruce Richardson static int
178299a2dd95SBruce Richardson handle_queue_links(const char *cmd __rte_unused,
178399a2dd95SBruce Richardson 		   const char *params,
178499a2dd95SBruce Richardson 		   struct rte_tel_data *d)
178599a2dd95SBruce Richardson {
178699a2dd95SBruce Richardson 	int i, ret, port_id = 0;
178799a2dd95SBruce Richardson 	char *end_param;
178899a2dd95SBruce Richardson 	uint8_t dev_id;
178999a2dd95SBruce Richardson 	uint8_t queues[RTE_EVENT_MAX_QUEUES_PER_DEV];
179099a2dd95SBruce Richardson 	uint8_t priorities[RTE_EVENT_MAX_QUEUES_PER_DEV];
179199a2dd95SBruce Richardson 	const char *p_param;
179299a2dd95SBruce Richardson 
179399a2dd95SBruce Richardson 	if (params == NULL || strlen(params) == 0 || !isdigit(*params))
179499a2dd95SBruce Richardson 		return -1;
179599a2dd95SBruce Richardson 
179699a2dd95SBruce Richardson 	/* Get dev ID from parameter string */
179799a2dd95SBruce Richardson 	dev_id = strtoul(params, &end_param, 10);
179899a2dd95SBruce Richardson 	RTE_EVENTDEV_VALID_DEVID_OR_ERR_RET(dev_id, -EINVAL);
179999a2dd95SBruce Richardson 
180099a2dd95SBruce Richardson 	p_param = strtok(end_param, ",");
180199a2dd95SBruce Richardson 	if (p_param == NULL || strlen(p_param) == 0 || !isdigit(*p_param))
180299a2dd95SBruce Richardson 		return -1;
180399a2dd95SBruce Richardson 
180499a2dd95SBruce Richardson 	port_id = strtoul(p_param, &end_param, 10);
180599a2dd95SBruce Richardson 	p_param = strtok(NULL, "\0");
180699a2dd95SBruce Richardson 	if (p_param != NULL)
180799a2dd95SBruce Richardson 		RTE_EDEV_LOG_DEBUG(
180899a2dd95SBruce Richardson 			"Extra parameters passed to eventdev telemetry command, ignoring");
180999a2dd95SBruce Richardson 
181099a2dd95SBruce Richardson 	ret = rte_event_port_links_get(dev_id, port_id, queues, priorities);
181199a2dd95SBruce Richardson 	if (ret < 0)
181299a2dd95SBruce Richardson 		return -1;
181399a2dd95SBruce Richardson 
181499a2dd95SBruce Richardson 	rte_tel_data_start_dict(d);
181599a2dd95SBruce Richardson 	for (i = 0; i < ret; i++) {
181699a2dd95SBruce Richardson 		char qid_name[32];
181799a2dd95SBruce Richardson 
181899a2dd95SBruce Richardson 		snprintf(qid_name, 31, "qid_%u", queues[i]);
1819af0785a2SBruce Richardson 		rte_tel_data_add_dict_uint(d, qid_name, priorities[i]);
182099a2dd95SBruce Richardson 	}
182199a2dd95SBruce Richardson 
182299a2dd95SBruce Richardson 	return 0;
182399a2dd95SBruce Richardson }
182499a2dd95SBruce Richardson 
182599a2dd95SBruce Richardson static int
182699a2dd95SBruce Richardson eventdev_build_telemetry_data(int dev_id,
182799a2dd95SBruce Richardson 			      enum rte_event_dev_xstats_mode mode,
182899a2dd95SBruce Richardson 			      int port_queue_id,
182999a2dd95SBruce Richardson 			      struct rte_tel_data *d)
183099a2dd95SBruce Richardson {
183199a2dd95SBruce Richardson 	struct rte_event_dev_xstats_name *xstat_names;
18321bdfe4d7SPavan Nikhilesh 	uint64_t *ids;
183399a2dd95SBruce Richardson 	uint64_t *values;
183499a2dd95SBruce Richardson 	int i, ret, num_xstats;
183599a2dd95SBruce Richardson 
183699a2dd95SBruce Richardson 	num_xstats = rte_event_dev_xstats_names_get(dev_id,
183799a2dd95SBruce Richardson 						    mode,
183899a2dd95SBruce Richardson 						    port_queue_id,
183999a2dd95SBruce Richardson 						    NULL,
184099a2dd95SBruce Richardson 						    NULL,
184199a2dd95SBruce Richardson 						    0);
184299a2dd95SBruce Richardson 
184399a2dd95SBruce Richardson 	if (num_xstats < 0)
184499a2dd95SBruce Richardson 		return -1;
184599a2dd95SBruce Richardson 
184699a2dd95SBruce Richardson 	/* use one malloc for names */
184799a2dd95SBruce Richardson 	xstat_names = malloc((sizeof(struct rte_event_dev_xstats_name))
184899a2dd95SBruce Richardson 			     * num_xstats);
184999a2dd95SBruce Richardson 	if (xstat_names == NULL)
185099a2dd95SBruce Richardson 		return -1;
185199a2dd95SBruce Richardson 
1852e0fb0051SAbdullah Sevincer 	ids = malloc((sizeof(uint64_t)) * num_xstats);
185399a2dd95SBruce Richardson 	if (ids == NULL) {
185499a2dd95SBruce Richardson 		free(xstat_names);
185599a2dd95SBruce Richardson 		return -1;
185699a2dd95SBruce Richardson 	}
185799a2dd95SBruce Richardson 
185899a2dd95SBruce Richardson 	values = malloc((sizeof(uint64_t)) * num_xstats);
185999a2dd95SBruce Richardson 	if (values == NULL) {
186099a2dd95SBruce Richardson 		free(xstat_names);
186199a2dd95SBruce Richardson 		free(ids);
186299a2dd95SBruce Richardson 		return -1;
186399a2dd95SBruce Richardson 	}
186499a2dd95SBruce Richardson 
186599a2dd95SBruce Richardson 	ret = rte_event_dev_xstats_names_get(dev_id, mode, port_queue_id,
186699a2dd95SBruce Richardson 					     xstat_names, ids, num_xstats);
186799a2dd95SBruce Richardson 	if (ret < 0 || ret > num_xstats) {
186899a2dd95SBruce Richardson 		free(xstat_names);
186999a2dd95SBruce Richardson 		free(ids);
187099a2dd95SBruce Richardson 		free(values);
187199a2dd95SBruce Richardson 		return -1;
187299a2dd95SBruce Richardson 	}
187399a2dd95SBruce Richardson 
187499a2dd95SBruce Richardson 	ret = rte_event_dev_xstats_get(dev_id, mode, port_queue_id,
187599a2dd95SBruce Richardson 				       ids, values, num_xstats);
187699a2dd95SBruce Richardson 	if (ret < 0 || ret > num_xstats) {
187799a2dd95SBruce Richardson 		free(xstat_names);
187899a2dd95SBruce Richardson 		free(ids);
187999a2dd95SBruce Richardson 		free(values);
188099a2dd95SBruce Richardson 		return -1;
188199a2dd95SBruce Richardson 	}
188299a2dd95SBruce Richardson 
188399a2dd95SBruce Richardson 	rte_tel_data_start_dict(d);
188499a2dd95SBruce Richardson 	for (i = 0; i < num_xstats; i++)
1885af0785a2SBruce Richardson 		rte_tel_data_add_dict_uint(d, xstat_names[i].name, values[i]);
188699a2dd95SBruce Richardson 
188799a2dd95SBruce Richardson 	free(xstat_names);
188899a2dd95SBruce Richardson 	free(ids);
188999a2dd95SBruce Richardson 	free(values);
189099a2dd95SBruce Richardson 	return 0;
189199a2dd95SBruce Richardson }
189299a2dd95SBruce Richardson 
189399a2dd95SBruce Richardson static int
189499a2dd95SBruce Richardson handle_dev_xstats(const char *cmd __rte_unused,
189599a2dd95SBruce Richardson 		  const char *params,
189699a2dd95SBruce Richardson 		  struct rte_tel_data *d)
189799a2dd95SBruce Richardson {
189899a2dd95SBruce Richardson 	int dev_id;
189999a2dd95SBruce Richardson 	enum rte_event_dev_xstats_mode mode;
190099a2dd95SBruce Richardson 	char *end_param;
190199a2dd95SBruce Richardson 
190299a2dd95SBruce Richardson 	if (params == NULL || strlen(params) == 0 || !isdigit(*params))
190399a2dd95SBruce Richardson 		return -1;
190499a2dd95SBruce Richardson 
190599a2dd95SBruce Richardson 	/* Get dev ID from parameter string */
190699a2dd95SBruce Richardson 	dev_id = strtoul(params, &end_param, 10);
190799a2dd95SBruce Richardson 	if (*end_param != '\0')
190899a2dd95SBruce Richardson 		RTE_EDEV_LOG_DEBUG(
190999a2dd95SBruce Richardson 			"Extra parameters passed to eventdev telemetry command, ignoring");
191099a2dd95SBruce Richardson 
191199a2dd95SBruce Richardson 	RTE_EVENTDEV_VALID_DEVID_OR_ERR_RET(dev_id, -EINVAL);
191299a2dd95SBruce Richardson 
191399a2dd95SBruce Richardson 	mode = RTE_EVENT_DEV_XSTATS_DEVICE;
191499a2dd95SBruce Richardson 	return eventdev_build_telemetry_data(dev_id, mode, 0, d);
191599a2dd95SBruce Richardson }
191699a2dd95SBruce Richardson 
191799a2dd95SBruce Richardson static int
191899a2dd95SBruce Richardson handle_port_xstats(const char *cmd __rte_unused,
191999a2dd95SBruce Richardson 		   const char *params,
192099a2dd95SBruce Richardson 		   struct rte_tel_data *d)
192199a2dd95SBruce Richardson {
192299a2dd95SBruce Richardson 	int dev_id;
192399a2dd95SBruce Richardson 	int port_queue_id = 0;
192499a2dd95SBruce Richardson 	enum rte_event_dev_xstats_mode mode;
192599a2dd95SBruce Richardson 	char *end_param;
192699a2dd95SBruce Richardson 	const char *p_param;
192799a2dd95SBruce Richardson 
192899a2dd95SBruce Richardson 	if (params == NULL || strlen(params) == 0 || !isdigit(*params))
192999a2dd95SBruce Richardson 		return -1;
193099a2dd95SBruce Richardson 
193199a2dd95SBruce Richardson 	/* Get dev ID from parameter string */
193299a2dd95SBruce Richardson 	dev_id = strtoul(params, &end_param, 10);
193399a2dd95SBruce Richardson 	RTE_EVENTDEV_VALID_DEVID_OR_ERR_RET(dev_id, -EINVAL);
193499a2dd95SBruce Richardson 
193599a2dd95SBruce Richardson 	p_param = strtok(end_param, ",");
193699a2dd95SBruce Richardson 	mode = RTE_EVENT_DEV_XSTATS_PORT;
193799a2dd95SBruce Richardson 
193899a2dd95SBruce Richardson 	if (p_param == NULL || strlen(p_param) == 0 || !isdigit(*p_param))
193999a2dd95SBruce Richardson 		return -1;
194099a2dd95SBruce Richardson 
194199a2dd95SBruce Richardson 	port_queue_id = strtoul(p_param, &end_param, 10);
194299a2dd95SBruce Richardson 
194399a2dd95SBruce Richardson 	p_param = strtok(NULL, "\0");
194499a2dd95SBruce Richardson 	if (p_param != NULL)
194599a2dd95SBruce Richardson 		RTE_EDEV_LOG_DEBUG(
194699a2dd95SBruce Richardson 			"Extra parameters passed to eventdev telemetry command, ignoring");
194799a2dd95SBruce Richardson 
194899a2dd95SBruce Richardson 	return eventdev_build_telemetry_data(dev_id, mode, port_queue_id, d);
194999a2dd95SBruce Richardson }
195099a2dd95SBruce Richardson 
195199a2dd95SBruce Richardson static int
195299a2dd95SBruce Richardson handle_queue_xstats(const char *cmd __rte_unused,
195399a2dd95SBruce Richardson 		    const char *params,
195499a2dd95SBruce Richardson 		    struct rte_tel_data *d)
195599a2dd95SBruce Richardson {
195699a2dd95SBruce Richardson 	int dev_id;
195799a2dd95SBruce Richardson 	int port_queue_id = 0;
195899a2dd95SBruce Richardson 	enum rte_event_dev_xstats_mode mode;
195999a2dd95SBruce Richardson 	char *end_param;
196099a2dd95SBruce Richardson 	const char *p_param;
196199a2dd95SBruce Richardson 
196299a2dd95SBruce Richardson 	if (params == NULL || strlen(params) == 0 || !isdigit(*params))
196399a2dd95SBruce Richardson 		return -1;
196499a2dd95SBruce Richardson 
196599a2dd95SBruce Richardson 	/* Get dev ID from parameter string */
196699a2dd95SBruce Richardson 	dev_id = strtoul(params, &end_param, 10);
196799a2dd95SBruce Richardson 	RTE_EVENTDEV_VALID_DEVID_OR_ERR_RET(dev_id, -EINVAL);
196899a2dd95SBruce Richardson 
196999a2dd95SBruce Richardson 	p_param = strtok(end_param, ",");
197099a2dd95SBruce Richardson 	mode = RTE_EVENT_DEV_XSTATS_QUEUE;
197199a2dd95SBruce Richardson 
197299a2dd95SBruce Richardson 	if (p_param == NULL || strlen(p_param) == 0 || !isdigit(*p_param))
197399a2dd95SBruce Richardson 		return -1;
197499a2dd95SBruce Richardson 
197599a2dd95SBruce Richardson 	port_queue_id = strtoul(p_param, &end_param, 10);
197699a2dd95SBruce Richardson 
197799a2dd95SBruce Richardson 	p_param = strtok(NULL, "\0");
197899a2dd95SBruce Richardson 	if (p_param != NULL)
197999a2dd95SBruce Richardson 		RTE_EDEV_LOG_DEBUG(
198099a2dd95SBruce Richardson 			"Extra parameters passed to eventdev telemetry command, ignoring");
198199a2dd95SBruce Richardson 
198299a2dd95SBruce Richardson 	return eventdev_build_telemetry_data(dev_id, mode, port_queue_id, d);
198399a2dd95SBruce Richardson }
198499a2dd95SBruce Richardson 
1985a3b7b476SChengwen Feng static int
1986a3b7b476SChengwen Feng handle_dev_dump(const char *cmd __rte_unused,
1987a3b7b476SChengwen Feng 		const char *params,
1988a3b7b476SChengwen Feng 		struct rte_tel_data *d)
1989a3b7b476SChengwen Feng {
1990a3b7b476SChengwen Feng 	char *buf, *end_param;
1991a3b7b476SChengwen Feng 	int dev_id, ret;
1992a3b7b476SChengwen Feng 	FILE *f;
1993a3b7b476SChengwen Feng 
1994a3b7b476SChengwen Feng 	if (params == NULL || strlen(params) == 0 || !isdigit(*params))
1995a3b7b476SChengwen Feng 		return -1;
1996a3b7b476SChengwen Feng 
1997a3b7b476SChengwen Feng 	/* Get dev ID from parameter string */
1998a3b7b476SChengwen Feng 	dev_id = strtoul(params, &end_param, 10);
1999a3b7b476SChengwen Feng 	if (*end_param != '\0')
2000a3b7b476SChengwen Feng 		RTE_EDEV_LOG_DEBUG(
2001a3b7b476SChengwen Feng 			"Extra parameters passed to eventdev telemetry command, ignoring");
2002a3b7b476SChengwen Feng 
2003a3b7b476SChengwen Feng 	RTE_EVENTDEV_VALID_DEVID_OR_ERR_RET(dev_id, -EINVAL);
2004a3b7b476SChengwen Feng 
2005a3b7b476SChengwen Feng 	buf = calloc(sizeof(char), RTE_TEL_MAX_SINGLE_STRING_LEN);
2006a3b7b476SChengwen Feng 	if (buf == NULL)
2007a3b7b476SChengwen Feng 		return -ENOMEM;
2008a3b7b476SChengwen Feng 
2009a3b7b476SChengwen Feng 	f = fmemopen(buf, RTE_TEL_MAX_SINGLE_STRING_LEN - 1, "w+");
2010a3b7b476SChengwen Feng 	if (f == NULL) {
2011a3b7b476SChengwen Feng 		free(buf);
2012a3b7b476SChengwen Feng 		return -EINVAL;
2013a3b7b476SChengwen Feng 	}
2014a3b7b476SChengwen Feng 
2015a3b7b476SChengwen Feng 	ret = rte_event_dev_dump(dev_id, f);
2016a3b7b476SChengwen Feng 	fclose(f);
2017a3b7b476SChengwen Feng 	if (ret == 0) {
2018a3b7b476SChengwen Feng 		rte_tel_data_start_dict(d);
2019a3b7b476SChengwen Feng 		rte_tel_data_string(d, buf);
2020a3b7b476SChengwen Feng 	}
2021a3b7b476SChengwen Feng 
2022a3b7b476SChengwen Feng 	free(buf);
2023a3b7b476SChengwen Feng 	return ret;
2024a3b7b476SChengwen Feng }
2025a3b7b476SChengwen Feng 
202699a2dd95SBruce Richardson RTE_INIT(eventdev_init_telemetry)
202799a2dd95SBruce Richardson {
202899a2dd95SBruce Richardson 	rte_telemetry_register_cmd("/eventdev/dev_list", handle_dev_list,
202999a2dd95SBruce Richardson 			"Returns list of available eventdevs. Takes no parameters");
203099a2dd95SBruce Richardson 	rte_telemetry_register_cmd("/eventdev/port_list", handle_port_list,
203199a2dd95SBruce Richardson 			"Returns list of available ports. Parameter: DevID");
203299a2dd95SBruce Richardson 	rte_telemetry_register_cmd("/eventdev/queue_list", handle_queue_list,
203399a2dd95SBruce Richardson 			"Returns list of available queues. Parameter: DevID");
203499a2dd95SBruce Richardson 
203599a2dd95SBruce Richardson 	rte_telemetry_register_cmd("/eventdev/dev_xstats", handle_dev_xstats,
203699a2dd95SBruce Richardson 			"Returns stats for an eventdev. Parameter: DevID");
203799a2dd95SBruce Richardson 	rte_telemetry_register_cmd("/eventdev/port_xstats", handle_port_xstats,
203899a2dd95SBruce Richardson 			"Returns stats for an eventdev port. Params: DevID,PortID");
203999a2dd95SBruce Richardson 	rte_telemetry_register_cmd("/eventdev/queue_xstats",
204099a2dd95SBruce Richardson 			handle_queue_xstats,
204199a2dd95SBruce Richardson 			"Returns stats for an eventdev queue. Params: DevID,QueueID");
2042a3b7b476SChengwen Feng 	rte_telemetry_register_cmd("/eventdev/dev_dump", handle_dev_dump,
2043a3b7b476SChengwen Feng 			"Returns dump information for an eventdev. Parameter: DevID");
204499a2dd95SBruce Richardson 	rte_telemetry_register_cmd("/eventdev/queue_links", handle_queue_links,
204599a2dd95SBruce Richardson 			"Returns links for an eventdev port. Params: DevID,QueueID");
204699a2dd95SBruce Richardson }
2047