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>
1599a2dd95SBruce Richardson #include <rte_dev.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>
23af668035SAkhil Goyal #include <cryptodev_pmd.h>
2499a2dd95SBruce Richardson #include <rte_telemetry.h>
2599a2dd95SBruce Richardson
2699a2dd95SBruce Richardson #include "rte_eventdev.h"
2799a2dd95SBruce Richardson #include "eventdev_pmd.h"
28f26f2ca6SPavan Nikhilesh #include "eventdev_trace.h"
2999a2dd95SBruce Richardson
3099a2dd95SBruce Richardson static struct rte_eventdev rte_event_devices[RTE_EVENT_MAX_DEVS];
3199a2dd95SBruce Richardson
3299a2dd95SBruce Richardson struct rte_eventdev *rte_eventdevs = rte_event_devices;
3399a2dd95SBruce Richardson
3499a2dd95SBruce Richardson static struct rte_eventdev_global eventdev_globals = {
3599a2dd95SBruce Richardson .nb_devs = 0
3699a2dd95SBruce Richardson };
3799a2dd95SBruce Richardson
38d35e6132SPavan Nikhilesh /* Public fastpath APIs. */
39d35e6132SPavan Nikhilesh struct rte_event_fp_ops rte_event_fp_ops[RTE_EVENT_MAX_DEVS];
40d35e6132SPavan Nikhilesh
4199a2dd95SBruce Richardson /* Event dev north bound API implementation */
4299a2dd95SBruce Richardson
4399a2dd95SBruce Richardson uint8_t
rte_event_dev_count(void)4499a2dd95SBruce Richardson rte_event_dev_count(void)
4599a2dd95SBruce Richardson {
4699a2dd95SBruce Richardson return eventdev_globals.nb_devs;
4799a2dd95SBruce Richardson }
4899a2dd95SBruce Richardson
4999a2dd95SBruce Richardson int
rte_event_dev_get_dev_id(const char * name)5099a2dd95SBruce Richardson rte_event_dev_get_dev_id(const char *name)
5199a2dd95SBruce Richardson {
5299a2dd95SBruce Richardson int i;
5399a2dd95SBruce Richardson uint8_t cmp;
5499a2dd95SBruce Richardson
5599a2dd95SBruce Richardson if (!name)
5699a2dd95SBruce Richardson return -EINVAL;
5799a2dd95SBruce Richardson
5899a2dd95SBruce Richardson for (i = 0; i < eventdev_globals.nb_devs; i++) {
5999a2dd95SBruce Richardson cmp = (strncmp(rte_event_devices[i].data->name, name,
6099a2dd95SBruce Richardson RTE_EVENTDEV_NAME_MAX_LEN) == 0) ||
6199a2dd95SBruce Richardson (rte_event_devices[i].dev ? (strncmp(
6299a2dd95SBruce Richardson rte_event_devices[i].dev->driver->name, name,
6399a2dd95SBruce Richardson RTE_EVENTDEV_NAME_MAX_LEN) == 0) : 0);
6499a2dd95SBruce Richardson if (cmp && (rte_event_devices[i].attached ==
6599a2dd95SBruce Richardson RTE_EVENTDEV_ATTACHED))
6699a2dd95SBruce Richardson return i;
6799a2dd95SBruce Richardson }
6899a2dd95SBruce Richardson return -ENODEV;
6999a2dd95SBruce Richardson }
7099a2dd95SBruce Richardson
7199a2dd95SBruce Richardson int
rte_event_dev_socket_id(uint8_t dev_id)7299a2dd95SBruce Richardson rte_event_dev_socket_id(uint8_t dev_id)
7399a2dd95SBruce Richardson {
7499a2dd95SBruce Richardson struct rte_eventdev *dev;
7599a2dd95SBruce Richardson
7699a2dd95SBruce Richardson RTE_EVENTDEV_VALID_DEVID_OR_ERR_RET(dev_id, -EINVAL);
7799a2dd95SBruce Richardson dev = &rte_eventdevs[dev_id];
7899a2dd95SBruce Richardson
7999a2dd95SBruce Richardson return dev->data->socket_id;
8099a2dd95SBruce Richardson }
8199a2dd95SBruce Richardson
8299a2dd95SBruce Richardson int
rte_event_dev_info_get(uint8_t dev_id,struct rte_event_dev_info * dev_info)8399a2dd95SBruce Richardson rte_event_dev_info_get(uint8_t dev_id, struct rte_event_dev_info *dev_info)
8499a2dd95SBruce Richardson {
8599a2dd95SBruce Richardson struct rte_eventdev *dev;
8699a2dd95SBruce Richardson
8799a2dd95SBruce Richardson RTE_EVENTDEV_VALID_DEVID_OR_ERR_RET(dev_id, -EINVAL);
8899a2dd95SBruce Richardson dev = &rte_eventdevs[dev_id];
8999a2dd95SBruce Richardson
9099a2dd95SBruce Richardson if (dev_info == NULL)
9199a2dd95SBruce Richardson return -EINVAL;
9299a2dd95SBruce Richardson
9399a2dd95SBruce Richardson memset(dev_info, 0, sizeof(struct rte_event_dev_info));
9499a2dd95SBruce Richardson
9599a2dd95SBruce Richardson RTE_FUNC_PTR_OR_ERR_RET(*dev->dev_ops->dev_infos_get, -ENOTSUP);
9699a2dd95SBruce Richardson (*dev->dev_ops->dev_infos_get)(dev, dev_info);
9799a2dd95SBruce Richardson
9899a2dd95SBruce Richardson dev_info->dequeue_timeout_ns = dev->data->dev_conf.dequeue_timeout_ns;
9999a2dd95SBruce Richardson
10099a2dd95SBruce Richardson dev_info->dev = dev->dev;
10199a2dd95SBruce Richardson return 0;
10299a2dd95SBruce Richardson }
10399a2dd95SBruce Richardson
10499a2dd95SBruce Richardson int
rte_event_eth_rx_adapter_caps_get(uint8_t dev_id,uint16_t eth_port_id,uint32_t * caps)10599a2dd95SBruce Richardson rte_event_eth_rx_adapter_caps_get(uint8_t dev_id, uint16_t eth_port_id,
10699a2dd95SBruce Richardson uint32_t *caps)
10799a2dd95SBruce Richardson {
10899a2dd95SBruce Richardson struct rte_eventdev *dev;
10999a2dd95SBruce Richardson
11099a2dd95SBruce Richardson RTE_EVENTDEV_VALID_DEVID_OR_ERR_RET(dev_id, -EINVAL);
11199a2dd95SBruce Richardson RTE_ETH_VALID_PORTID_OR_ERR_RET(eth_port_id, -EINVAL);
11299a2dd95SBruce Richardson
11399a2dd95SBruce Richardson dev = &rte_eventdevs[dev_id];
11499a2dd95SBruce Richardson
11599a2dd95SBruce Richardson if (caps == NULL)
11699a2dd95SBruce Richardson return -EINVAL;
11799a2dd95SBruce Richardson
11899a2dd95SBruce Richardson if (dev->dev_ops->eth_rx_adapter_caps_get == NULL)
11999a2dd95SBruce Richardson *caps = RTE_EVENT_ETH_RX_ADAPTER_SW_CAP;
12099a2dd95SBruce Richardson else
12199a2dd95SBruce Richardson *caps = 0;
12299a2dd95SBruce Richardson
12399a2dd95SBruce Richardson return dev->dev_ops->eth_rx_adapter_caps_get ?
12499a2dd95SBruce Richardson (*dev->dev_ops->eth_rx_adapter_caps_get)(dev,
12599a2dd95SBruce Richardson &rte_eth_devices[eth_port_id],
12699a2dd95SBruce Richardson caps)
12799a2dd95SBruce Richardson : 0;
12899a2dd95SBruce Richardson }
12999a2dd95SBruce Richardson
13099a2dd95SBruce Richardson int
rte_event_timer_adapter_caps_get(uint8_t dev_id,uint32_t * caps)13199a2dd95SBruce Richardson rte_event_timer_adapter_caps_get(uint8_t dev_id, uint32_t *caps)
13299a2dd95SBruce Richardson {
13399a2dd95SBruce Richardson struct rte_eventdev *dev;
13453548ad3SPavan Nikhilesh const struct event_timer_adapter_ops *ops;
13599a2dd95SBruce Richardson
13699a2dd95SBruce Richardson RTE_EVENTDEV_VALID_DEVID_OR_ERR_RET(dev_id, -EINVAL);
13799a2dd95SBruce Richardson
13899a2dd95SBruce Richardson dev = &rte_eventdevs[dev_id];
13999a2dd95SBruce Richardson
14099a2dd95SBruce Richardson if (caps == NULL)
14199a2dd95SBruce Richardson return -EINVAL;
14299a2dd95SBruce Richardson *caps = 0;
14399a2dd95SBruce Richardson
14499a2dd95SBruce Richardson return dev->dev_ops->timer_adapter_caps_get ?
14599a2dd95SBruce Richardson (*dev->dev_ops->timer_adapter_caps_get)(dev,
14699a2dd95SBruce Richardson 0,
14799a2dd95SBruce Richardson caps,
14899a2dd95SBruce Richardson &ops)
14999a2dd95SBruce Richardson : 0;
15099a2dd95SBruce Richardson }
15199a2dd95SBruce Richardson
15299a2dd95SBruce Richardson int
rte_event_crypto_adapter_caps_get(uint8_t dev_id,uint8_t cdev_id,uint32_t * caps)15399a2dd95SBruce Richardson rte_event_crypto_adapter_caps_get(uint8_t dev_id, uint8_t cdev_id,
15499a2dd95SBruce Richardson uint32_t *caps)
15599a2dd95SBruce Richardson {
15699a2dd95SBruce Richardson struct rte_eventdev *dev;
15799a2dd95SBruce Richardson struct rte_cryptodev *cdev;
15899a2dd95SBruce Richardson
15999a2dd95SBruce Richardson RTE_EVENTDEV_VALID_DEVID_OR_ERR_RET(dev_id, -EINVAL);
160e74abd48SAkhil Goyal if (!rte_cryptodev_is_valid_dev(cdev_id))
16199a2dd95SBruce Richardson return -EINVAL;
16299a2dd95SBruce Richardson
16399a2dd95SBruce Richardson dev = &rte_eventdevs[dev_id];
16499a2dd95SBruce Richardson cdev = rte_cryptodev_pmd_get_dev(cdev_id);
16599a2dd95SBruce Richardson
16699a2dd95SBruce Richardson if (caps == NULL)
16799a2dd95SBruce Richardson return -EINVAL;
1686b946657SGanapati Kundapura
1696b946657SGanapati Kundapura if (dev->dev_ops->crypto_adapter_caps_get == NULL)
1706b946657SGanapati Kundapura *caps = RTE_EVENT_CRYPTO_ADAPTER_SW_CAP;
1716b946657SGanapati Kundapura else
17299a2dd95SBruce Richardson *caps = 0;
17399a2dd95SBruce Richardson
17499a2dd95SBruce Richardson return dev->dev_ops->crypto_adapter_caps_get ?
17599a2dd95SBruce Richardson (*dev->dev_ops->crypto_adapter_caps_get)
1766b946657SGanapati Kundapura (dev, cdev, caps) : 0;
17799a2dd95SBruce Richardson }
17899a2dd95SBruce Richardson
17999a2dd95SBruce Richardson int
rte_event_eth_tx_adapter_caps_get(uint8_t dev_id,uint16_t eth_port_id,uint32_t * caps)18099a2dd95SBruce Richardson rte_event_eth_tx_adapter_caps_get(uint8_t dev_id, uint16_t eth_port_id,
18199a2dd95SBruce Richardson uint32_t *caps)
18299a2dd95SBruce Richardson {
18399a2dd95SBruce Richardson struct rte_eventdev *dev;
18499a2dd95SBruce Richardson struct rte_eth_dev *eth_dev;
18599a2dd95SBruce Richardson
18699a2dd95SBruce Richardson RTE_EVENTDEV_VALID_DEVID_OR_ERR_RET(dev_id, -EINVAL);
18799a2dd95SBruce Richardson RTE_ETH_VALID_PORTID_OR_ERR_RET(eth_port_id, -EINVAL);
18899a2dd95SBruce Richardson
18999a2dd95SBruce Richardson dev = &rte_eventdevs[dev_id];
19099a2dd95SBruce Richardson eth_dev = &rte_eth_devices[eth_port_id];
19199a2dd95SBruce Richardson
19299a2dd95SBruce Richardson if (caps == NULL)
19399a2dd95SBruce Richardson return -EINVAL;
19499a2dd95SBruce Richardson
19599a2dd95SBruce Richardson if (dev->dev_ops->eth_tx_adapter_caps_get == NULL)
19699a2dd95SBruce Richardson *caps = RTE_EVENT_ETH_TX_ADAPTER_CAP_EVENT_VECTOR;
19799a2dd95SBruce Richardson else
19899a2dd95SBruce Richardson *caps = 0;
19999a2dd95SBruce Richardson
20099a2dd95SBruce Richardson return dev->dev_ops->eth_tx_adapter_caps_get ?
20199a2dd95SBruce Richardson (*dev->dev_ops->eth_tx_adapter_caps_get)(dev,
20299a2dd95SBruce Richardson eth_dev,
20399a2dd95SBruce Richardson caps)
20499a2dd95SBruce Richardson : 0;
20599a2dd95SBruce Richardson }
20699a2dd95SBruce Richardson
20799a2dd95SBruce Richardson static inline int
event_dev_queue_config(struct rte_eventdev * dev,uint8_t nb_queues)2089c67fcbfSPavan Nikhilesh event_dev_queue_config(struct rte_eventdev *dev, uint8_t nb_queues)
20999a2dd95SBruce Richardson {
21099a2dd95SBruce Richardson uint8_t old_nb_queues = dev->data->nb_queues;
21199a2dd95SBruce Richardson struct rte_event_queue_conf *queues_cfg;
21299a2dd95SBruce Richardson unsigned int i;
21399a2dd95SBruce Richardson
21499a2dd95SBruce Richardson RTE_EDEV_LOG_DEBUG("Setup %d queues on device %u", nb_queues,
21599a2dd95SBruce Richardson dev->data->dev_id);
21699a2dd95SBruce Richardson
2179c67fcbfSPavan Nikhilesh if (nb_queues != 0) {
2189c67fcbfSPavan Nikhilesh queues_cfg = dev->data->queues_cfg;
21999a2dd95SBruce Richardson RTE_FUNC_PTR_OR_ERR_RET(*dev->dev_ops->queue_release, -ENOTSUP);
22099a2dd95SBruce Richardson
22199a2dd95SBruce Richardson for (i = nb_queues; i < old_nb_queues; i++)
22299a2dd95SBruce Richardson (*dev->dev_ops->queue_release)(dev, i);
22399a2dd95SBruce Richardson
22499a2dd95SBruce Richardson
22599a2dd95SBruce Richardson if (nb_queues > old_nb_queues) {
22699a2dd95SBruce Richardson uint8_t new_qs = nb_queues - old_nb_queues;
22799a2dd95SBruce Richardson
22899a2dd95SBruce Richardson memset(queues_cfg + old_nb_queues, 0,
22999a2dd95SBruce Richardson sizeof(queues_cfg[0]) * new_qs);
23099a2dd95SBruce Richardson }
2319c67fcbfSPavan Nikhilesh } else {
23299a2dd95SBruce Richardson RTE_FUNC_PTR_OR_ERR_RET(*dev->dev_ops->queue_release, -ENOTSUP);
23399a2dd95SBruce Richardson
23499a2dd95SBruce Richardson for (i = nb_queues; i < old_nb_queues; i++)
23599a2dd95SBruce Richardson (*dev->dev_ops->queue_release)(dev, i);
23699a2dd95SBruce Richardson }
23799a2dd95SBruce Richardson
23899a2dd95SBruce Richardson dev->data->nb_queues = nb_queues;
23999a2dd95SBruce Richardson return 0;
24099a2dd95SBruce Richardson }
24199a2dd95SBruce Richardson
24299a2dd95SBruce Richardson #define EVENT_QUEUE_SERVICE_PRIORITY_INVALID (0xdead)
24399a2dd95SBruce Richardson
24499a2dd95SBruce Richardson static inline int
event_dev_port_config(struct rte_eventdev * dev,uint8_t nb_ports)2459c67fcbfSPavan Nikhilesh event_dev_port_config(struct rte_eventdev *dev, uint8_t nb_ports)
24699a2dd95SBruce Richardson {
24799a2dd95SBruce Richardson uint8_t old_nb_ports = dev->data->nb_ports;
24899a2dd95SBruce Richardson void **ports;
24999a2dd95SBruce Richardson uint16_t *links_map;
25099a2dd95SBruce Richardson struct rte_event_port_conf *ports_cfg;
25199a2dd95SBruce Richardson unsigned int i;
25299a2dd95SBruce Richardson
25399a2dd95SBruce Richardson RTE_EDEV_LOG_DEBUG("Setup %d ports on device %u", nb_ports,
25499a2dd95SBruce Richardson dev->data->dev_id);
25599a2dd95SBruce Richardson
2569c67fcbfSPavan Nikhilesh if (nb_ports != 0) { /* re-config */
25799a2dd95SBruce Richardson RTE_FUNC_PTR_OR_ERR_RET(*dev->dev_ops->port_release, -ENOTSUP);
25899a2dd95SBruce Richardson
25999a2dd95SBruce Richardson ports = dev->data->ports;
26099a2dd95SBruce Richardson ports_cfg = dev->data->ports_cfg;
26199a2dd95SBruce Richardson links_map = dev->data->links_map;
26299a2dd95SBruce Richardson
26399a2dd95SBruce Richardson for (i = nb_ports; i < old_nb_ports; i++)
26499a2dd95SBruce Richardson (*dev->dev_ops->port_release)(ports[i]);
26599a2dd95SBruce Richardson
26699a2dd95SBruce Richardson if (nb_ports > old_nb_ports) {
26799a2dd95SBruce Richardson uint8_t new_ps = nb_ports - old_nb_ports;
26899a2dd95SBruce Richardson unsigned int old_links_map_end =
26999a2dd95SBruce Richardson old_nb_ports * RTE_EVENT_MAX_QUEUES_PER_DEV;
27099a2dd95SBruce Richardson unsigned int links_map_end =
27199a2dd95SBruce Richardson nb_ports * RTE_EVENT_MAX_QUEUES_PER_DEV;
27299a2dd95SBruce Richardson
27399a2dd95SBruce Richardson memset(ports + old_nb_ports, 0,
27499a2dd95SBruce Richardson sizeof(ports[0]) * new_ps);
27599a2dd95SBruce Richardson memset(ports_cfg + old_nb_ports, 0,
27699a2dd95SBruce Richardson sizeof(ports_cfg[0]) * new_ps);
27799a2dd95SBruce Richardson for (i = old_links_map_end; i < links_map_end; i++)
27899a2dd95SBruce Richardson links_map[i] =
27999a2dd95SBruce Richardson EVENT_QUEUE_SERVICE_PRIORITY_INVALID;
28099a2dd95SBruce Richardson }
2819c67fcbfSPavan Nikhilesh } else {
28299a2dd95SBruce Richardson RTE_FUNC_PTR_OR_ERR_RET(*dev->dev_ops->port_release, -ENOTSUP);
28399a2dd95SBruce Richardson
28499a2dd95SBruce Richardson ports = dev->data->ports;
2859c67fcbfSPavan Nikhilesh for (i = nb_ports; i < old_nb_ports; i++) {
28699a2dd95SBruce Richardson (*dev->dev_ops->port_release)(ports[i]);
2879c67fcbfSPavan Nikhilesh ports[i] = NULL;
2889c67fcbfSPavan Nikhilesh }
28999a2dd95SBruce Richardson }
29099a2dd95SBruce Richardson
29199a2dd95SBruce Richardson dev->data->nb_ports = nb_ports;
29299a2dd95SBruce Richardson return 0;
29399a2dd95SBruce Richardson }
29499a2dd95SBruce Richardson
29599a2dd95SBruce Richardson int
rte_event_dev_configure(uint8_t dev_id,const struct rte_event_dev_config * dev_conf)29699a2dd95SBruce Richardson rte_event_dev_configure(uint8_t dev_id,
29799a2dd95SBruce Richardson const struct rte_event_dev_config *dev_conf)
29899a2dd95SBruce Richardson {
29999a2dd95SBruce Richardson struct rte_event_dev_info info;
300d35e6132SPavan Nikhilesh struct rte_eventdev *dev;
30199a2dd95SBruce Richardson int diag;
30299a2dd95SBruce Richardson
30399a2dd95SBruce Richardson RTE_EVENTDEV_VALID_DEVID_OR_ERR_RET(dev_id, -EINVAL);
30499a2dd95SBruce Richardson dev = &rte_eventdevs[dev_id];
30599a2dd95SBruce Richardson
30699a2dd95SBruce Richardson RTE_FUNC_PTR_OR_ERR_RET(*dev->dev_ops->dev_infos_get, -ENOTSUP);
30799a2dd95SBruce Richardson RTE_FUNC_PTR_OR_ERR_RET(*dev->dev_ops->dev_configure, -ENOTSUP);
30899a2dd95SBruce Richardson
30999a2dd95SBruce Richardson if (dev->data->dev_started) {
31099a2dd95SBruce Richardson RTE_EDEV_LOG_ERR(
31199a2dd95SBruce Richardson "device %d must be stopped to allow configuration", dev_id);
31299a2dd95SBruce Richardson return -EBUSY;
31399a2dd95SBruce Richardson }
31499a2dd95SBruce Richardson
31599a2dd95SBruce Richardson if (dev_conf == NULL)
31699a2dd95SBruce Richardson return -EINVAL;
31799a2dd95SBruce Richardson
31899a2dd95SBruce Richardson (*dev->dev_ops->dev_infos_get)(dev, &info);
31999a2dd95SBruce Richardson
32099a2dd95SBruce Richardson /* Check dequeue_timeout_ns value is in limit */
32199a2dd95SBruce Richardson if (!(dev_conf->event_dev_cfg & RTE_EVENT_DEV_CFG_PER_DEQUEUE_TIMEOUT)) {
32299a2dd95SBruce Richardson if (dev_conf->dequeue_timeout_ns &&
32399a2dd95SBruce Richardson (dev_conf->dequeue_timeout_ns < info.min_dequeue_timeout_ns
32499a2dd95SBruce Richardson || dev_conf->dequeue_timeout_ns >
32599a2dd95SBruce Richardson info.max_dequeue_timeout_ns)) {
32699a2dd95SBruce Richardson RTE_EDEV_LOG_ERR("dev%d invalid dequeue_timeout_ns=%d"
32799a2dd95SBruce Richardson " min_dequeue_timeout_ns=%d max_dequeue_timeout_ns=%d",
32899a2dd95SBruce Richardson dev_id, dev_conf->dequeue_timeout_ns,
32999a2dd95SBruce Richardson info.min_dequeue_timeout_ns,
33099a2dd95SBruce Richardson info.max_dequeue_timeout_ns);
33199a2dd95SBruce Richardson return -EINVAL;
33299a2dd95SBruce Richardson }
33399a2dd95SBruce Richardson }
33499a2dd95SBruce Richardson
33599a2dd95SBruce Richardson /* Check nb_events_limit is in limit */
33699a2dd95SBruce Richardson if (dev_conf->nb_events_limit > info.max_num_events) {
33799a2dd95SBruce Richardson RTE_EDEV_LOG_ERR("dev%d nb_events_limit=%d > max_num_events=%d",
33899a2dd95SBruce Richardson dev_id, dev_conf->nb_events_limit, info.max_num_events);
33999a2dd95SBruce Richardson return -EINVAL;
34099a2dd95SBruce Richardson }
34199a2dd95SBruce Richardson
34299a2dd95SBruce Richardson /* Check nb_event_queues is in limit */
34399a2dd95SBruce Richardson if (!dev_conf->nb_event_queues) {
34499a2dd95SBruce Richardson RTE_EDEV_LOG_ERR("dev%d nb_event_queues cannot be zero",
34599a2dd95SBruce Richardson dev_id);
34699a2dd95SBruce Richardson return -EINVAL;
34799a2dd95SBruce Richardson }
34899a2dd95SBruce Richardson if (dev_conf->nb_event_queues > info.max_event_queues +
34999a2dd95SBruce Richardson info.max_single_link_event_port_queue_pairs) {
35099a2dd95SBruce Richardson RTE_EDEV_LOG_ERR("%d nb_event_queues=%d > max_event_queues=%d + max_single_link_event_port_queue_pairs=%d",
35199a2dd95SBruce Richardson dev_id, dev_conf->nb_event_queues,
35299a2dd95SBruce Richardson info.max_event_queues,
35399a2dd95SBruce Richardson info.max_single_link_event_port_queue_pairs);
35499a2dd95SBruce Richardson return -EINVAL;
35599a2dd95SBruce Richardson }
35699a2dd95SBruce Richardson if (dev_conf->nb_event_queues -
35799a2dd95SBruce Richardson dev_conf->nb_single_link_event_port_queues >
35899a2dd95SBruce Richardson info.max_event_queues) {
35999a2dd95SBruce Richardson RTE_EDEV_LOG_ERR("id%d nb_event_queues=%d - nb_single_link_event_port_queues=%d > max_event_queues=%d",
36099a2dd95SBruce Richardson dev_id, dev_conf->nb_event_queues,
36199a2dd95SBruce Richardson dev_conf->nb_single_link_event_port_queues,
36299a2dd95SBruce Richardson info.max_event_queues);
36399a2dd95SBruce Richardson return -EINVAL;
36499a2dd95SBruce Richardson }
36599a2dd95SBruce Richardson if (dev_conf->nb_single_link_event_port_queues >
36699a2dd95SBruce Richardson dev_conf->nb_event_queues) {
36799a2dd95SBruce Richardson RTE_EDEV_LOG_ERR("dev%d nb_single_link_event_port_queues=%d > nb_event_queues=%d",
36899a2dd95SBruce Richardson dev_id,
36999a2dd95SBruce Richardson dev_conf->nb_single_link_event_port_queues,
37099a2dd95SBruce Richardson dev_conf->nb_event_queues);
37199a2dd95SBruce Richardson return -EINVAL;
37299a2dd95SBruce Richardson }
37399a2dd95SBruce Richardson
37499a2dd95SBruce Richardson /* Check nb_event_ports is in limit */
37599a2dd95SBruce Richardson if (!dev_conf->nb_event_ports) {
37699a2dd95SBruce Richardson RTE_EDEV_LOG_ERR("dev%d nb_event_ports cannot be zero", dev_id);
37799a2dd95SBruce Richardson return -EINVAL;
37899a2dd95SBruce Richardson }
37999a2dd95SBruce Richardson if (dev_conf->nb_event_ports > info.max_event_ports +
38099a2dd95SBruce Richardson info.max_single_link_event_port_queue_pairs) {
38199a2dd95SBruce Richardson RTE_EDEV_LOG_ERR("id%d nb_event_ports=%d > max_event_ports=%d + max_single_link_event_port_queue_pairs=%d",
38299a2dd95SBruce Richardson dev_id, dev_conf->nb_event_ports,
38399a2dd95SBruce Richardson info.max_event_ports,
38499a2dd95SBruce Richardson info.max_single_link_event_port_queue_pairs);
38599a2dd95SBruce Richardson return -EINVAL;
38699a2dd95SBruce Richardson }
38799a2dd95SBruce Richardson if (dev_conf->nb_event_ports -
38899a2dd95SBruce Richardson dev_conf->nb_single_link_event_port_queues
38999a2dd95SBruce Richardson > info.max_event_ports) {
39099a2dd95SBruce Richardson RTE_EDEV_LOG_ERR("id%d nb_event_ports=%d - nb_single_link_event_port_queues=%d > max_event_ports=%d",
39199a2dd95SBruce Richardson dev_id, dev_conf->nb_event_ports,
39299a2dd95SBruce Richardson dev_conf->nb_single_link_event_port_queues,
39399a2dd95SBruce Richardson info.max_event_ports);
39499a2dd95SBruce Richardson return -EINVAL;
39599a2dd95SBruce Richardson }
39699a2dd95SBruce Richardson
39799a2dd95SBruce Richardson if (dev_conf->nb_single_link_event_port_queues >
39899a2dd95SBruce Richardson dev_conf->nb_event_ports) {
39999a2dd95SBruce Richardson RTE_EDEV_LOG_ERR(
40099a2dd95SBruce Richardson "dev%d nb_single_link_event_port_queues=%d > nb_event_ports=%d",
40199a2dd95SBruce Richardson dev_id,
40299a2dd95SBruce Richardson dev_conf->nb_single_link_event_port_queues,
40399a2dd95SBruce Richardson dev_conf->nb_event_ports);
40499a2dd95SBruce Richardson return -EINVAL;
40599a2dd95SBruce Richardson }
40699a2dd95SBruce Richardson
40799a2dd95SBruce Richardson /* Check nb_event_queue_flows is in limit */
40899a2dd95SBruce Richardson if (!dev_conf->nb_event_queue_flows) {
40999a2dd95SBruce Richardson RTE_EDEV_LOG_ERR("dev%d nb_flows cannot be zero", dev_id);
41099a2dd95SBruce Richardson return -EINVAL;
41199a2dd95SBruce Richardson }
41299a2dd95SBruce Richardson if (dev_conf->nb_event_queue_flows > info.max_event_queue_flows) {
41399a2dd95SBruce Richardson RTE_EDEV_LOG_ERR("dev%d nb_flows=%x > max_flows=%x",
41499a2dd95SBruce Richardson dev_id, dev_conf->nb_event_queue_flows,
41599a2dd95SBruce Richardson info.max_event_queue_flows);
41699a2dd95SBruce Richardson return -EINVAL;
41799a2dd95SBruce Richardson }
41899a2dd95SBruce Richardson
41999a2dd95SBruce Richardson /* Check nb_event_port_dequeue_depth is in limit */
42099a2dd95SBruce Richardson if (!dev_conf->nb_event_port_dequeue_depth) {
42199a2dd95SBruce Richardson RTE_EDEV_LOG_ERR("dev%d nb_dequeue_depth cannot be zero",
42299a2dd95SBruce Richardson dev_id);
42399a2dd95SBruce Richardson return -EINVAL;
42499a2dd95SBruce Richardson }
42599a2dd95SBruce Richardson if ((info.event_dev_cap & RTE_EVENT_DEV_CAP_BURST_MODE) &&
42699a2dd95SBruce Richardson (dev_conf->nb_event_port_dequeue_depth >
42799a2dd95SBruce Richardson info.max_event_port_dequeue_depth)) {
42899a2dd95SBruce Richardson RTE_EDEV_LOG_ERR("dev%d nb_dq_depth=%d > max_dq_depth=%d",
42999a2dd95SBruce Richardson dev_id, dev_conf->nb_event_port_dequeue_depth,
43099a2dd95SBruce Richardson info.max_event_port_dequeue_depth);
43199a2dd95SBruce Richardson return -EINVAL;
43299a2dd95SBruce Richardson }
43399a2dd95SBruce Richardson
43499a2dd95SBruce Richardson /* Check nb_event_port_enqueue_depth is in limit */
43599a2dd95SBruce Richardson if (!dev_conf->nb_event_port_enqueue_depth) {
43699a2dd95SBruce Richardson RTE_EDEV_LOG_ERR("dev%d nb_enqueue_depth cannot be zero",
43799a2dd95SBruce Richardson dev_id);
43899a2dd95SBruce Richardson return -EINVAL;
43999a2dd95SBruce Richardson }
44099a2dd95SBruce Richardson if ((info.event_dev_cap & RTE_EVENT_DEV_CAP_BURST_MODE) &&
44199a2dd95SBruce Richardson (dev_conf->nb_event_port_enqueue_depth >
44299a2dd95SBruce Richardson info.max_event_port_enqueue_depth)) {
44399a2dd95SBruce Richardson RTE_EDEV_LOG_ERR("dev%d nb_enq_depth=%d > max_enq_depth=%d",
44499a2dd95SBruce Richardson dev_id, dev_conf->nb_event_port_enqueue_depth,
44599a2dd95SBruce Richardson info.max_event_port_enqueue_depth);
44699a2dd95SBruce Richardson return -EINVAL;
44799a2dd95SBruce Richardson }
44899a2dd95SBruce Richardson
44999a2dd95SBruce Richardson /* Copy the dev_conf parameter into the dev structure */
45099a2dd95SBruce Richardson memcpy(&dev->data->dev_conf, dev_conf, sizeof(dev->data->dev_conf));
45199a2dd95SBruce Richardson
45299a2dd95SBruce Richardson /* Setup new number of queues and reconfigure device. */
4539c67fcbfSPavan Nikhilesh diag = event_dev_queue_config(dev, dev_conf->nb_event_queues);
45499a2dd95SBruce Richardson if (diag != 0) {
4559c67fcbfSPavan Nikhilesh RTE_EDEV_LOG_ERR("dev%d event_dev_queue_config = %d", dev_id,
4569c67fcbfSPavan Nikhilesh diag);
45799a2dd95SBruce Richardson return diag;
45899a2dd95SBruce Richardson }
45999a2dd95SBruce Richardson
46099a2dd95SBruce Richardson /* Setup new number of ports and reconfigure device. */
4619c67fcbfSPavan Nikhilesh diag = event_dev_port_config(dev, dev_conf->nb_event_ports);
46299a2dd95SBruce Richardson if (diag != 0) {
4639c67fcbfSPavan Nikhilesh event_dev_queue_config(dev, 0);
4649c67fcbfSPavan Nikhilesh RTE_EDEV_LOG_ERR("dev%d event_dev_port_config = %d", dev_id,
4659c67fcbfSPavan Nikhilesh diag);
46699a2dd95SBruce Richardson return diag;
46799a2dd95SBruce Richardson }
46899a2dd95SBruce Richardson
469d35e6132SPavan Nikhilesh event_dev_fp_ops_reset(rte_event_fp_ops + dev_id);
470d35e6132SPavan Nikhilesh
47199a2dd95SBruce Richardson /* Configure the device */
47299a2dd95SBruce Richardson diag = (*dev->dev_ops->dev_configure)(dev);
47399a2dd95SBruce Richardson if (diag != 0) {
47499a2dd95SBruce Richardson RTE_EDEV_LOG_ERR("dev%d dev_configure = %d", dev_id, diag);
475d35e6132SPavan Nikhilesh event_dev_fp_ops_reset(rte_event_fp_ops + dev_id);
4769c67fcbfSPavan Nikhilesh event_dev_queue_config(dev, 0);
4779c67fcbfSPavan Nikhilesh event_dev_port_config(dev, 0);
47899a2dd95SBruce Richardson }
47999a2dd95SBruce Richardson
48099a2dd95SBruce Richardson dev->data->event_dev_cap = info.event_dev_cap;
48199a2dd95SBruce Richardson rte_eventdev_trace_configure(dev_id, dev_conf, diag);
48299a2dd95SBruce Richardson return diag;
48399a2dd95SBruce Richardson }
48499a2dd95SBruce Richardson
48599a2dd95SBruce Richardson static inline int
is_valid_queue(struct rte_eventdev * dev,uint8_t queue_id)48699a2dd95SBruce Richardson is_valid_queue(struct rte_eventdev *dev, uint8_t queue_id)
48799a2dd95SBruce Richardson {
48899a2dd95SBruce Richardson if (queue_id < dev->data->nb_queues && queue_id <
48999a2dd95SBruce Richardson RTE_EVENT_MAX_QUEUES_PER_DEV)
49099a2dd95SBruce Richardson return 1;
49199a2dd95SBruce Richardson else
49299a2dd95SBruce Richardson return 0;
49399a2dd95SBruce Richardson }
49499a2dd95SBruce Richardson
49599a2dd95SBruce Richardson int
rte_event_queue_default_conf_get(uint8_t dev_id,uint8_t queue_id,struct rte_event_queue_conf * queue_conf)49699a2dd95SBruce Richardson rte_event_queue_default_conf_get(uint8_t dev_id, uint8_t queue_id,
49799a2dd95SBruce Richardson struct rte_event_queue_conf *queue_conf)
49899a2dd95SBruce Richardson {
49999a2dd95SBruce Richardson struct rte_eventdev *dev;
50099a2dd95SBruce Richardson
50199a2dd95SBruce Richardson RTE_EVENTDEV_VALID_DEVID_OR_ERR_RET(dev_id, -EINVAL);
50299a2dd95SBruce Richardson dev = &rte_eventdevs[dev_id];
50399a2dd95SBruce Richardson
50499a2dd95SBruce Richardson if (queue_conf == NULL)
50599a2dd95SBruce Richardson return -EINVAL;
50699a2dd95SBruce Richardson
50799a2dd95SBruce Richardson if (!is_valid_queue(dev, queue_id)) {
50899a2dd95SBruce Richardson RTE_EDEV_LOG_ERR("Invalid queue_id=%" PRIu8, queue_id);
50999a2dd95SBruce Richardson return -EINVAL;
51099a2dd95SBruce Richardson }
51199a2dd95SBruce Richardson
51299a2dd95SBruce Richardson RTE_FUNC_PTR_OR_ERR_RET(*dev->dev_ops->queue_def_conf, -ENOTSUP);
51399a2dd95SBruce Richardson memset(queue_conf, 0, sizeof(struct rte_event_queue_conf));
51499a2dd95SBruce Richardson (*dev->dev_ops->queue_def_conf)(dev, queue_id, queue_conf);
51599a2dd95SBruce Richardson return 0;
51699a2dd95SBruce Richardson }
51799a2dd95SBruce Richardson
51899a2dd95SBruce Richardson static inline int
is_valid_atomic_queue_conf(const struct rte_event_queue_conf * queue_conf)51999a2dd95SBruce Richardson is_valid_atomic_queue_conf(const struct rte_event_queue_conf *queue_conf)
52099a2dd95SBruce Richardson {
52199a2dd95SBruce Richardson if (queue_conf &&
52299a2dd95SBruce Richardson !(queue_conf->event_queue_cfg &
52399a2dd95SBruce Richardson RTE_EVENT_QUEUE_CFG_SINGLE_LINK) &&
52499a2dd95SBruce Richardson ((queue_conf->event_queue_cfg &
52599a2dd95SBruce Richardson RTE_EVENT_QUEUE_CFG_ALL_TYPES) ||
52699a2dd95SBruce Richardson (queue_conf->schedule_type
52799a2dd95SBruce Richardson == RTE_SCHED_TYPE_ATOMIC)
52899a2dd95SBruce Richardson ))
52999a2dd95SBruce Richardson return 1;
53099a2dd95SBruce Richardson else
53199a2dd95SBruce Richardson return 0;
53299a2dd95SBruce Richardson }
53399a2dd95SBruce Richardson
53499a2dd95SBruce Richardson static inline int
is_valid_ordered_queue_conf(const struct rte_event_queue_conf * queue_conf)53599a2dd95SBruce Richardson is_valid_ordered_queue_conf(const struct rte_event_queue_conf *queue_conf)
53699a2dd95SBruce Richardson {
53799a2dd95SBruce Richardson if (queue_conf &&
53899a2dd95SBruce Richardson !(queue_conf->event_queue_cfg &
53999a2dd95SBruce Richardson RTE_EVENT_QUEUE_CFG_SINGLE_LINK) &&
54099a2dd95SBruce Richardson ((queue_conf->event_queue_cfg &
54199a2dd95SBruce Richardson RTE_EVENT_QUEUE_CFG_ALL_TYPES) ||
54299a2dd95SBruce Richardson (queue_conf->schedule_type
54399a2dd95SBruce Richardson == RTE_SCHED_TYPE_ORDERED)
54499a2dd95SBruce Richardson ))
54599a2dd95SBruce Richardson return 1;
54699a2dd95SBruce Richardson else
54799a2dd95SBruce Richardson return 0;
54899a2dd95SBruce Richardson }
54999a2dd95SBruce Richardson
55099a2dd95SBruce Richardson
55199a2dd95SBruce Richardson int
rte_event_queue_setup(uint8_t dev_id,uint8_t queue_id,const struct rte_event_queue_conf * queue_conf)55299a2dd95SBruce Richardson rte_event_queue_setup(uint8_t dev_id, uint8_t queue_id,
55399a2dd95SBruce Richardson const struct rte_event_queue_conf *queue_conf)
55499a2dd95SBruce Richardson {
55599a2dd95SBruce Richardson struct rte_eventdev *dev;
55699a2dd95SBruce Richardson struct rte_event_queue_conf def_conf;
55799a2dd95SBruce Richardson
55899a2dd95SBruce Richardson RTE_EVENTDEV_VALID_DEVID_OR_ERR_RET(dev_id, -EINVAL);
55999a2dd95SBruce Richardson dev = &rte_eventdevs[dev_id];
56099a2dd95SBruce Richardson
56199a2dd95SBruce Richardson if (!is_valid_queue(dev, queue_id)) {
56299a2dd95SBruce Richardson RTE_EDEV_LOG_ERR("Invalid queue_id=%" PRIu8, queue_id);
56399a2dd95SBruce Richardson return -EINVAL;
56499a2dd95SBruce Richardson }
56599a2dd95SBruce Richardson
56699a2dd95SBruce Richardson /* Check nb_atomic_flows limit */
56799a2dd95SBruce Richardson if (is_valid_atomic_queue_conf(queue_conf)) {
56899a2dd95SBruce Richardson if (queue_conf->nb_atomic_flows == 0 ||
56999a2dd95SBruce Richardson queue_conf->nb_atomic_flows >
57099a2dd95SBruce Richardson dev->data->dev_conf.nb_event_queue_flows) {
57199a2dd95SBruce Richardson RTE_EDEV_LOG_ERR(
57299a2dd95SBruce Richardson "dev%d queue%d Invalid nb_atomic_flows=%d max_flows=%d",
57399a2dd95SBruce Richardson dev_id, queue_id, queue_conf->nb_atomic_flows,
57499a2dd95SBruce Richardson dev->data->dev_conf.nb_event_queue_flows);
57599a2dd95SBruce Richardson return -EINVAL;
57699a2dd95SBruce Richardson }
57799a2dd95SBruce Richardson }
57899a2dd95SBruce Richardson
57999a2dd95SBruce Richardson /* Check nb_atomic_order_sequences limit */
58099a2dd95SBruce Richardson if (is_valid_ordered_queue_conf(queue_conf)) {
58199a2dd95SBruce Richardson if (queue_conf->nb_atomic_order_sequences == 0 ||
58299a2dd95SBruce Richardson queue_conf->nb_atomic_order_sequences >
58399a2dd95SBruce Richardson dev->data->dev_conf.nb_event_queue_flows) {
58499a2dd95SBruce Richardson RTE_EDEV_LOG_ERR(
58599a2dd95SBruce Richardson "dev%d queue%d Invalid nb_atomic_order_seq=%d max_flows=%d",
58699a2dd95SBruce Richardson dev_id, queue_id, queue_conf->nb_atomic_order_sequences,
58799a2dd95SBruce Richardson dev->data->dev_conf.nb_event_queue_flows);
58899a2dd95SBruce Richardson return -EINVAL;
58999a2dd95SBruce Richardson }
59099a2dd95SBruce Richardson }
59199a2dd95SBruce Richardson
59299a2dd95SBruce Richardson if (dev->data->dev_started) {
59399a2dd95SBruce Richardson RTE_EDEV_LOG_ERR(
59499a2dd95SBruce Richardson "device %d must be stopped to allow queue setup", dev_id);
59599a2dd95SBruce Richardson return -EBUSY;
59699a2dd95SBruce Richardson }
59799a2dd95SBruce Richardson
59899a2dd95SBruce Richardson RTE_FUNC_PTR_OR_ERR_RET(*dev->dev_ops->queue_setup, -ENOTSUP);
59999a2dd95SBruce Richardson
60099a2dd95SBruce Richardson if (queue_conf == NULL) {
60199a2dd95SBruce Richardson RTE_FUNC_PTR_OR_ERR_RET(*dev->dev_ops->queue_def_conf,
60299a2dd95SBruce Richardson -ENOTSUP);
60399a2dd95SBruce Richardson (*dev->dev_ops->queue_def_conf)(dev, queue_id, &def_conf);
60499a2dd95SBruce Richardson queue_conf = &def_conf;
60599a2dd95SBruce Richardson }
60699a2dd95SBruce Richardson
60799a2dd95SBruce Richardson dev->data->queues_cfg[queue_id] = *queue_conf;
60899a2dd95SBruce Richardson rte_eventdev_trace_queue_setup(dev_id, queue_id, queue_conf);
60999a2dd95SBruce Richardson return (*dev->dev_ops->queue_setup)(dev, queue_id, queue_conf);
61099a2dd95SBruce Richardson }
61199a2dd95SBruce Richardson
61299a2dd95SBruce Richardson static inline int
is_valid_port(struct rte_eventdev * dev,uint8_t port_id)61399a2dd95SBruce Richardson is_valid_port(struct rte_eventdev *dev, uint8_t port_id)
61499a2dd95SBruce Richardson {
61599a2dd95SBruce Richardson if (port_id < dev->data->nb_ports)
61699a2dd95SBruce Richardson return 1;
61799a2dd95SBruce Richardson else
61899a2dd95SBruce Richardson return 0;
61999a2dd95SBruce Richardson }
62099a2dd95SBruce Richardson
62199a2dd95SBruce Richardson int
rte_event_port_default_conf_get(uint8_t dev_id,uint8_t port_id,struct rte_event_port_conf * port_conf)62299a2dd95SBruce Richardson rte_event_port_default_conf_get(uint8_t dev_id, uint8_t port_id,
62399a2dd95SBruce Richardson struct rte_event_port_conf *port_conf)
62499a2dd95SBruce Richardson {
62599a2dd95SBruce Richardson struct rte_eventdev *dev;
62699a2dd95SBruce Richardson
62799a2dd95SBruce Richardson RTE_EVENTDEV_VALID_DEVID_OR_ERR_RET(dev_id, -EINVAL);
62899a2dd95SBruce Richardson dev = &rte_eventdevs[dev_id];
62999a2dd95SBruce Richardson
63099a2dd95SBruce Richardson if (port_conf == NULL)
63199a2dd95SBruce Richardson return -EINVAL;
63299a2dd95SBruce Richardson
63399a2dd95SBruce Richardson if (!is_valid_port(dev, port_id)) {
63499a2dd95SBruce Richardson RTE_EDEV_LOG_ERR("Invalid port_id=%" PRIu8, port_id);
63599a2dd95SBruce Richardson return -EINVAL;
63699a2dd95SBruce Richardson }
63799a2dd95SBruce Richardson
63899a2dd95SBruce Richardson RTE_FUNC_PTR_OR_ERR_RET(*dev->dev_ops->port_def_conf, -ENOTSUP);
63999a2dd95SBruce Richardson memset(port_conf, 0, sizeof(struct rte_event_port_conf));
64099a2dd95SBruce Richardson (*dev->dev_ops->port_def_conf)(dev, port_id, port_conf);
64199a2dd95SBruce Richardson return 0;
64299a2dd95SBruce Richardson }
64399a2dd95SBruce Richardson
64499a2dd95SBruce Richardson int
rte_event_port_setup(uint8_t dev_id,uint8_t port_id,const struct rte_event_port_conf * port_conf)64599a2dd95SBruce Richardson rte_event_port_setup(uint8_t dev_id, uint8_t port_id,
64699a2dd95SBruce Richardson const struct rte_event_port_conf *port_conf)
64799a2dd95SBruce Richardson {
64899a2dd95SBruce Richardson struct rte_eventdev *dev;
64999a2dd95SBruce Richardson struct rte_event_port_conf def_conf;
65099a2dd95SBruce Richardson int diag;
65199a2dd95SBruce Richardson
65299a2dd95SBruce Richardson RTE_EVENTDEV_VALID_DEVID_OR_ERR_RET(dev_id, -EINVAL);
65399a2dd95SBruce Richardson dev = &rte_eventdevs[dev_id];
65499a2dd95SBruce Richardson
65599a2dd95SBruce Richardson if (!is_valid_port(dev, port_id)) {
65699a2dd95SBruce Richardson RTE_EDEV_LOG_ERR("Invalid port_id=%" PRIu8, port_id);
65799a2dd95SBruce Richardson return -EINVAL;
65899a2dd95SBruce Richardson }
65999a2dd95SBruce Richardson
66099a2dd95SBruce Richardson /* Check new_event_threshold limit */
66199a2dd95SBruce Richardson if ((port_conf && !port_conf->new_event_threshold) ||
66299a2dd95SBruce Richardson (port_conf && port_conf->new_event_threshold >
66399a2dd95SBruce Richardson dev->data->dev_conf.nb_events_limit)) {
66499a2dd95SBruce Richardson RTE_EDEV_LOG_ERR(
66599a2dd95SBruce Richardson "dev%d port%d Invalid event_threshold=%d nb_events_limit=%d",
66699a2dd95SBruce Richardson dev_id, port_id, port_conf->new_event_threshold,
66799a2dd95SBruce Richardson dev->data->dev_conf.nb_events_limit);
66899a2dd95SBruce Richardson return -EINVAL;
66999a2dd95SBruce Richardson }
67099a2dd95SBruce Richardson
67199a2dd95SBruce Richardson /* Check dequeue_depth limit */
67299a2dd95SBruce Richardson if ((port_conf && !port_conf->dequeue_depth) ||
67399a2dd95SBruce Richardson (port_conf && port_conf->dequeue_depth >
67499a2dd95SBruce Richardson dev->data->dev_conf.nb_event_port_dequeue_depth)) {
67599a2dd95SBruce Richardson RTE_EDEV_LOG_ERR(
67699a2dd95SBruce Richardson "dev%d port%d Invalid dequeue depth=%d max_dequeue_depth=%d",
67799a2dd95SBruce Richardson dev_id, port_id, port_conf->dequeue_depth,
67899a2dd95SBruce Richardson dev->data->dev_conf.nb_event_port_dequeue_depth);
67999a2dd95SBruce Richardson return -EINVAL;
68099a2dd95SBruce Richardson }
68199a2dd95SBruce Richardson
68299a2dd95SBruce Richardson /* Check enqueue_depth limit */
68399a2dd95SBruce Richardson if ((port_conf && !port_conf->enqueue_depth) ||
68499a2dd95SBruce Richardson (port_conf && port_conf->enqueue_depth >
68599a2dd95SBruce Richardson dev->data->dev_conf.nb_event_port_enqueue_depth)) {
68699a2dd95SBruce Richardson RTE_EDEV_LOG_ERR(
68799a2dd95SBruce Richardson "dev%d port%d Invalid enqueue depth=%d max_enqueue_depth=%d",
68899a2dd95SBruce Richardson dev_id, port_id, port_conf->enqueue_depth,
68999a2dd95SBruce Richardson dev->data->dev_conf.nb_event_port_enqueue_depth);
69099a2dd95SBruce Richardson return -EINVAL;
69199a2dd95SBruce Richardson }
69299a2dd95SBruce Richardson
69399a2dd95SBruce Richardson if (port_conf &&
69499a2dd95SBruce Richardson (port_conf->event_port_cfg & RTE_EVENT_PORT_CFG_DISABLE_IMPL_REL) &&
69599a2dd95SBruce Richardson !(dev->data->event_dev_cap &
69699a2dd95SBruce Richardson RTE_EVENT_DEV_CAP_IMPLICIT_RELEASE_DISABLE)) {
69799a2dd95SBruce Richardson RTE_EDEV_LOG_ERR(
69899a2dd95SBruce Richardson "dev%d port%d Implicit release disable not supported",
69999a2dd95SBruce Richardson dev_id, port_id);
70099a2dd95SBruce Richardson return -EINVAL;
70199a2dd95SBruce Richardson }
70299a2dd95SBruce Richardson
70399a2dd95SBruce Richardson if (dev->data->dev_started) {
70499a2dd95SBruce Richardson RTE_EDEV_LOG_ERR(
70599a2dd95SBruce Richardson "device %d must be stopped to allow port setup", dev_id);
70699a2dd95SBruce Richardson return -EBUSY;
70799a2dd95SBruce Richardson }
70899a2dd95SBruce Richardson
70999a2dd95SBruce Richardson RTE_FUNC_PTR_OR_ERR_RET(*dev->dev_ops->port_setup, -ENOTSUP);
71099a2dd95SBruce Richardson
71199a2dd95SBruce Richardson if (port_conf == NULL) {
71299a2dd95SBruce Richardson RTE_FUNC_PTR_OR_ERR_RET(*dev->dev_ops->port_def_conf,
71399a2dd95SBruce Richardson -ENOTSUP);
71499a2dd95SBruce Richardson (*dev->dev_ops->port_def_conf)(dev, port_id, &def_conf);
71599a2dd95SBruce Richardson port_conf = &def_conf;
71699a2dd95SBruce Richardson }
71799a2dd95SBruce Richardson
71899a2dd95SBruce Richardson dev->data->ports_cfg[port_id] = *port_conf;
71999a2dd95SBruce Richardson
72099a2dd95SBruce Richardson diag = (*dev->dev_ops->port_setup)(dev, port_id, port_conf);
72199a2dd95SBruce Richardson
72299a2dd95SBruce Richardson /* Unlink all the queues from this port(default state after setup) */
72399a2dd95SBruce Richardson if (!diag)
72499a2dd95SBruce Richardson diag = rte_event_port_unlink(dev_id, port_id, NULL, 0);
72599a2dd95SBruce Richardson
72699a2dd95SBruce Richardson rte_eventdev_trace_port_setup(dev_id, port_id, port_conf, diag);
72799a2dd95SBruce Richardson if (diag < 0)
72899a2dd95SBruce Richardson return diag;
72999a2dd95SBruce Richardson
73099a2dd95SBruce Richardson return 0;
73199a2dd95SBruce Richardson }
73299a2dd95SBruce Richardson
7331ff23ce6SPavan Nikhilesh void
rte_event_port_quiesce(uint8_t dev_id,uint8_t port_id,rte_eventdev_port_flush_t release_cb,void * args)7341ff23ce6SPavan Nikhilesh rte_event_port_quiesce(uint8_t dev_id, uint8_t port_id,
7351ff23ce6SPavan Nikhilesh rte_eventdev_port_flush_t release_cb, void *args)
7361ff23ce6SPavan Nikhilesh {
7371ff23ce6SPavan Nikhilesh struct rte_eventdev *dev;
7381ff23ce6SPavan Nikhilesh
7391ff23ce6SPavan Nikhilesh RTE_EVENTDEV_VALID_DEVID_OR_RET(dev_id);
7401ff23ce6SPavan Nikhilesh dev = &rte_eventdevs[dev_id];
7411ff23ce6SPavan Nikhilesh
7421ff23ce6SPavan Nikhilesh if (!is_valid_port(dev, port_id)) {
7431ff23ce6SPavan Nikhilesh RTE_EDEV_LOG_ERR("Invalid port_id=%" PRIu8, port_id);
7441ff23ce6SPavan Nikhilesh return;
7451ff23ce6SPavan Nikhilesh }
7461ff23ce6SPavan Nikhilesh
7471ff23ce6SPavan Nikhilesh if (dev->dev_ops->port_quiesce)
7481ff23ce6SPavan Nikhilesh (*dev->dev_ops->port_quiesce)(dev, dev->data->ports[port_id],
7491ff23ce6SPavan Nikhilesh release_cb, args);
7501ff23ce6SPavan Nikhilesh }
7511ff23ce6SPavan Nikhilesh
75299a2dd95SBruce Richardson int
rte_event_dev_attr_get(uint8_t dev_id,uint32_t attr_id,uint32_t * attr_value)75399a2dd95SBruce Richardson rte_event_dev_attr_get(uint8_t dev_id, uint32_t attr_id,
75499a2dd95SBruce Richardson uint32_t *attr_value)
75599a2dd95SBruce Richardson {
75699a2dd95SBruce Richardson struct rte_eventdev *dev;
75799a2dd95SBruce Richardson
75899a2dd95SBruce Richardson if (!attr_value)
75999a2dd95SBruce Richardson return -EINVAL;
76099a2dd95SBruce Richardson RTE_EVENTDEV_VALID_DEVID_OR_ERR_RET(dev_id, -EINVAL);
76199a2dd95SBruce Richardson dev = &rte_eventdevs[dev_id];
76299a2dd95SBruce Richardson
76399a2dd95SBruce Richardson switch (attr_id) {
76499a2dd95SBruce Richardson case RTE_EVENT_DEV_ATTR_PORT_COUNT:
76599a2dd95SBruce Richardson *attr_value = dev->data->nb_ports;
76699a2dd95SBruce Richardson break;
76799a2dd95SBruce Richardson case RTE_EVENT_DEV_ATTR_QUEUE_COUNT:
76899a2dd95SBruce Richardson *attr_value = dev->data->nb_queues;
76999a2dd95SBruce Richardson break;
77099a2dd95SBruce Richardson case RTE_EVENT_DEV_ATTR_STARTED:
77199a2dd95SBruce Richardson *attr_value = dev->data->dev_started;
77299a2dd95SBruce Richardson break;
77399a2dd95SBruce Richardson default:
77499a2dd95SBruce Richardson return -EINVAL;
77599a2dd95SBruce Richardson }
77699a2dd95SBruce Richardson
77799a2dd95SBruce Richardson return 0;
77899a2dd95SBruce Richardson }
77999a2dd95SBruce Richardson
78099a2dd95SBruce Richardson int
rte_event_port_attr_get(uint8_t dev_id,uint8_t port_id,uint32_t attr_id,uint32_t * attr_value)78199a2dd95SBruce Richardson rte_event_port_attr_get(uint8_t dev_id, uint8_t port_id, uint32_t attr_id,
78299a2dd95SBruce Richardson uint32_t *attr_value)
78399a2dd95SBruce Richardson {
78499a2dd95SBruce Richardson struct rte_eventdev *dev;
78599a2dd95SBruce Richardson
78699a2dd95SBruce Richardson if (!attr_value)
78799a2dd95SBruce Richardson return -EINVAL;
78899a2dd95SBruce Richardson
78999a2dd95SBruce Richardson RTE_EVENTDEV_VALID_DEVID_OR_ERR_RET(dev_id, -EINVAL);
79099a2dd95SBruce Richardson dev = &rte_eventdevs[dev_id];
79199a2dd95SBruce Richardson if (!is_valid_port(dev, port_id)) {
79299a2dd95SBruce Richardson RTE_EDEV_LOG_ERR("Invalid port_id=%" PRIu8, port_id);
79399a2dd95SBruce Richardson return -EINVAL;
79499a2dd95SBruce Richardson }
79599a2dd95SBruce Richardson
79699a2dd95SBruce Richardson switch (attr_id) {
79799a2dd95SBruce Richardson case RTE_EVENT_PORT_ATTR_ENQ_DEPTH:
79899a2dd95SBruce Richardson *attr_value = dev->data->ports_cfg[port_id].enqueue_depth;
79999a2dd95SBruce Richardson break;
80099a2dd95SBruce Richardson case RTE_EVENT_PORT_ATTR_DEQ_DEPTH:
80199a2dd95SBruce Richardson *attr_value = dev->data->ports_cfg[port_id].dequeue_depth;
80299a2dd95SBruce Richardson break;
80399a2dd95SBruce Richardson case RTE_EVENT_PORT_ATTR_NEW_EVENT_THRESHOLD:
80499a2dd95SBruce Richardson *attr_value = dev->data->ports_cfg[port_id].new_event_threshold;
80599a2dd95SBruce Richardson break;
80699a2dd95SBruce Richardson case RTE_EVENT_PORT_ATTR_IMPLICIT_RELEASE_DISABLE:
80799a2dd95SBruce Richardson {
80899a2dd95SBruce Richardson uint32_t config;
80999a2dd95SBruce Richardson
81099a2dd95SBruce Richardson config = dev->data->ports_cfg[port_id].event_port_cfg;
81199a2dd95SBruce Richardson *attr_value = !!(config & RTE_EVENT_PORT_CFG_DISABLE_IMPL_REL);
81299a2dd95SBruce Richardson break;
81399a2dd95SBruce Richardson }
81499a2dd95SBruce Richardson default:
81599a2dd95SBruce Richardson return -EINVAL;
81699a2dd95SBruce Richardson };
81799a2dd95SBruce Richardson return 0;
81899a2dd95SBruce Richardson }
81999a2dd95SBruce Richardson
82099a2dd95SBruce Richardson int
rte_event_queue_attr_get(uint8_t dev_id,uint8_t queue_id,uint32_t attr_id,uint32_t * attr_value)82199a2dd95SBruce Richardson rte_event_queue_attr_get(uint8_t dev_id, uint8_t queue_id, uint32_t attr_id,
82299a2dd95SBruce Richardson uint32_t *attr_value)
82399a2dd95SBruce Richardson {
82499a2dd95SBruce Richardson struct rte_event_queue_conf *conf;
82599a2dd95SBruce Richardson struct rte_eventdev *dev;
82699a2dd95SBruce Richardson
82799a2dd95SBruce Richardson if (!attr_value)
82899a2dd95SBruce Richardson return -EINVAL;
82999a2dd95SBruce Richardson
83099a2dd95SBruce Richardson RTE_EVENTDEV_VALID_DEVID_OR_ERR_RET(dev_id, -EINVAL);
83199a2dd95SBruce Richardson dev = &rte_eventdevs[dev_id];
83299a2dd95SBruce Richardson if (!is_valid_queue(dev, queue_id)) {
83399a2dd95SBruce Richardson RTE_EDEV_LOG_ERR("Invalid queue_id=%" PRIu8, queue_id);
83499a2dd95SBruce Richardson return -EINVAL;
83599a2dd95SBruce Richardson }
83699a2dd95SBruce Richardson
83799a2dd95SBruce Richardson conf = &dev->data->queues_cfg[queue_id];
83899a2dd95SBruce Richardson
83999a2dd95SBruce Richardson switch (attr_id) {
84099a2dd95SBruce Richardson case RTE_EVENT_QUEUE_ATTR_PRIORITY:
84199a2dd95SBruce Richardson *attr_value = RTE_EVENT_DEV_PRIORITY_NORMAL;
84299a2dd95SBruce Richardson if (dev->data->event_dev_cap & RTE_EVENT_DEV_CAP_QUEUE_QOS)
84399a2dd95SBruce Richardson *attr_value = conf->priority;
84499a2dd95SBruce Richardson break;
84599a2dd95SBruce Richardson case RTE_EVENT_QUEUE_ATTR_NB_ATOMIC_FLOWS:
84699a2dd95SBruce Richardson *attr_value = conf->nb_atomic_flows;
84799a2dd95SBruce Richardson break;
84899a2dd95SBruce Richardson case RTE_EVENT_QUEUE_ATTR_NB_ATOMIC_ORDER_SEQUENCES:
84999a2dd95SBruce Richardson *attr_value = conf->nb_atomic_order_sequences;
85099a2dd95SBruce Richardson break;
85199a2dd95SBruce Richardson case RTE_EVENT_QUEUE_ATTR_EVENT_QUEUE_CFG:
85299a2dd95SBruce Richardson *attr_value = conf->event_queue_cfg;
85399a2dd95SBruce Richardson break;
85499a2dd95SBruce Richardson case RTE_EVENT_QUEUE_ATTR_SCHEDULE_TYPE:
85599a2dd95SBruce Richardson if (conf->event_queue_cfg & RTE_EVENT_QUEUE_CFG_ALL_TYPES)
85699a2dd95SBruce Richardson return -EOVERFLOW;
85799a2dd95SBruce Richardson
85899a2dd95SBruce Richardson *attr_value = conf->schedule_type;
85999a2dd95SBruce Richardson break;
860*44516e6bSShijith Thotton case RTE_EVENT_QUEUE_ATTR_WEIGHT:
861*44516e6bSShijith Thotton *attr_value = RTE_EVENT_QUEUE_WEIGHT_LOWEST;
862*44516e6bSShijith Thotton if (dev->dev_ops->queue_attr_get)
863*44516e6bSShijith Thotton return (*dev->dev_ops->queue_attr_get)(
864*44516e6bSShijith Thotton dev, queue_id, attr_id, attr_value);
865*44516e6bSShijith Thotton break;
866*44516e6bSShijith Thotton case RTE_EVENT_QUEUE_ATTR_AFFINITY:
867*44516e6bSShijith Thotton *attr_value = RTE_EVENT_QUEUE_AFFINITY_LOWEST;
868*44516e6bSShijith Thotton if (dev->dev_ops->queue_attr_get)
869*44516e6bSShijith Thotton return (*dev->dev_ops->queue_attr_get)(
870*44516e6bSShijith Thotton dev, queue_id, attr_id, attr_value);
871*44516e6bSShijith Thotton break;
87299a2dd95SBruce Richardson default:
87399a2dd95SBruce Richardson return -EINVAL;
87499a2dd95SBruce Richardson };
87599a2dd95SBruce Richardson return 0;
87699a2dd95SBruce Richardson }
87799a2dd95SBruce Richardson
87899a2dd95SBruce Richardson int
rte_event_queue_attr_set(uint8_t dev_id,uint8_t queue_id,uint32_t attr_id,uint64_t attr_value)87997b914f4SShijith Thotton rte_event_queue_attr_set(uint8_t dev_id, uint8_t queue_id, uint32_t attr_id,
88097b914f4SShijith Thotton uint64_t attr_value)
88197b914f4SShijith Thotton {
88297b914f4SShijith Thotton struct rte_eventdev *dev;
88397b914f4SShijith Thotton
88497b914f4SShijith Thotton RTE_EVENTDEV_VALID_DEVID_OR_ERR_RET(dev_id, -EINVAL);
88597b914f4SShijith Thotton dev = &rte_eventdevs[dev_id];
88697b914f4SShijith Thotton if (!is_valid_queue(dev, queue_id)) {
88797b914f4SShijith Thotton RTE_EDEV_LOG_ERR("Invalid queue_id=%" PRIu8, queue_id);
88897b914f4SShijith Thotton return -EINVAL;
88997b914f4SShijith Thotton }
89097b914f4SShijith Thotton
89197b914f4SShijith Thotton if (!(dev->data->event_dev_cap &
89297b914f4SShijith Thotton RTE_EVENT_DEV_CAP_RUNTIME_QUEUE_ATTR)) {
89397b914f4SShijith Thotton RTE_EDEV_LOG_ERR(
89497b914f4SShijith Thotton "Device %" PRIu8 "does not support changing queue attributes at runtime",
89597b914f4SShijith Thotton dev_id);
89697b914f4SShijith Thotton return -ENOTSUP;
89797b914f4SShijith Thotton }
89897b914f4SShijith Thotton
89997b914f4SShijith Thotton RTE_FUNC_PTR_OR_ERR_RET(*dev->dev_ops->queue_attr_set, -ENOTSUP);
90097b914f4SShijith Thotton return (*dev->dev_ops->queue_attr_set)(dev, queue_id, attr_id,
90197b914f4SShijith Thotton attr_value);
90297b914f4SShijith Thotton }
90397b914f4SShijith Thotton
90497b914f4SShijith Thotton int
rte_event_port_link(uint8_t dev_id,uint8_t port_id,const uint8_t queues[],const uint8_t priorities[],uint16_t nb_links)90599a2dd95SBruce Richardson rte_event_port_link(uint8_t dev_id, uint8_t port_id,
90699a2dd95SBruce Richardson const uint8_t queues[], const uint8_t priorities[],
90799a2dd95SBruce Richardson uint16_t nb_links)
90899a2dd95SBruce Richardson {
90999a2dd95SBruce Richardson struct rte_eventdev *dev;
91099a2dd95SBruce Richardson uint8_t queues_list[RTE_EVENT_MAX_QUEUES_PER_DEV];
91199a2dd95SBruce Richardson uint8_t priorities_list[RTE_EVENT_MAX_QUEUES_PER_DEV];
91299a2dd95SBruce Richardson uint16_t *links_map;
91399a2dd95SBruce Richardson int i, diag;
91499a2dd95SBruce Richardson
91599a2dd95SBruce Richardson RTE_EVENTDEV_VALID_DEVID_OR_ERRNO_RET(dev_id, EINVAL, 0);
91699a2dd95SBruce Richardson dev = &rte_eventdevs[dev_id];
91799a2dd95SBruce Richardson
91899a2dd95SBruce Richardson if (*dev->dev_ops->port_link == NULL) {
91999a2dd95SBruce Richardson RTE_EDEV_LOG_ERR("Function not supported\n");
92099a2dd95SBruce Richardson rte_errno = ENOTSUP;
92199a2dd95SBruce Richardson return 0;
92299a2dd95SBruce Richardson }
92399a2dd95SBruce Richardson
92499a2dd95SBruce Richardson if (!is_valid_port(dev, port_id)) {
92599a2dd95SBruce Richardson RTE_EDEV_LOG_ERR("Invalid port_id=%" PRIu8, port_id);
92699a2dd95SBruce Richardson rte_errno = EINVAL;
92799a2dd95SBruce Richardson return 0;
92899a2dd95SBruce Richardson }
92999a2dd95SBruce Richardson
93099a2dd95SBruce Richardson if (queues == NULL) {
93199a2dd95SBruce Richardson for (i = 0; i < dev->data->nb_queues; i++)
93299a2dd95SBruce Richardson queues_list[i] = i;
93399a2dd95SBruce Richardson
93499a2dd95SBruce Richardson queues = queues_list;
93599a2dd95SBruce Richardson nb_links = dev->data->nb_queues;
93699a2dd95SBruce Richardson }
93799a2dd95SBruce Richardson
93899a2dd95SBruce Richardson if (priorities == NULL) {
93999a2dd95SBruce Richardson for (i = 0; i < nb_links; i++)
94099a2dd95SBruce Richardson priorities_list[i] = RTE_EVENT_DEV_PRIORITY_NORMAL;
94199a2dd95SBruce Richardson
94299a2dd95SBruce Richardson priorities = priorities_list;
94399a2dd95SBruce Richardson }
94499a2dd95SBruce Richardson
94599a2dd95SBruce Richardson for (i = 0; i < nb_links; i++)
94699a2dd95SBruce Richardson if (queues[i] >= dev->data->nb_queues) {
94799a2dd95SBruce Richardson rte_errno = EINVAL;
94899a2dd95SBruce Richardson return 0;
94999a2dd95SBruce Richardson }
95099a2dd95SBruce Richardson
95199a2dd95SBruce Richardson diag = (*dev->dev_ops->port_link)(dev, dev->data->ports[port_id],
95299a2dd95SBruce Richardson queues, priorities, nb_links);
95399a2dd95SBruce Richardson if (diag < 0)
95499a2dd95SBruce Richardson return diag;
95599a2dd95SBruce Richardson
95699a2dd95SBruce Richardson links_map = dev->data->links_map;
95799a2dd95SBruce Richardson /* Point links_map to this port specific area */
95899a2dd95SBruce Richardson links_map += (port_id * RTE_EVENT_MAX_QUEUES_PER_DEV);
95999a2dd95SBruce Richardson for (i = 0; i < diag; i++)
96099a2dd95SBruce Richardson links_map[queues[i]] = (uint8_t)priorities[i];
96199a2dd95SBruce Richardson
96299a2dd95SBruce Richardson rte_eventdev_trace_port_link(dev_id, port_id, nb_links, diag);
96399a2dd95SBruce Richardson return diag;
96499a2dd95SBruce Richardson }
96599a2dd95SBruce Richardson
96699a2dd95SBruce Richardson int
rte_event_port_unlink(uint8_t dev_id,uint8_t port_id,uint8_t queues[],uint16_t nb_unlinks)96799a2dd95SBruce Richardson rte_event_port_unlink(uint8_t dev_id, uint8_t port_id,
96899a2dd95SBruce Richardson uint8_t queues[], uint16_t nb_unlinks)
96999a2dd95SBruce Richardson {
97099a2dd95SBruce Richardson struct rte_eventdev *dev;
97199a2dd95SBruce Richardson uint8_t all_queues[RTE_EVENT_MAX_QUEUES_PER_DEV];
97299a2dd95SBruce Richardson int i, diag, j;
97399a2dd95SBruce Richardson uint16_t *links_map;
97499a2dd95SBruce Richardson
97599a2dd95SBruce Richardson RTE_EVENTDEV_VALID_DEVID_OR_ERRNO_RET(dev_id, EINVAL, 0);
97699a2dd95SBruce Richardson dev = &rte_eventdevs[dev_id];
97799a2dd95SBruce Richardson
97899a2dd95SBruce Richardson if (*dev->dev_ops->port_unlink == NULL) {
97999a2dd95SBruce Richardson RTE_EDEV_LOG_ERR("Function not supported");
98099a2dd95SBruce Richardson rte_errno = ENOTSUP;
98199a2dd95SBruce Richardson return 0;
98299a2dd95SBruce Richardson }
98399a2dd95SBruce Richardson
98499a2dd95SBruce Richardson if (!is_valid_port(dev, port_id)) {
98599a2dd95SBruce Richardson RTE_EDEV_LOG_ERR("Invalid port_id=%" PRIu8, port_id);
98699a2dd95SBruce Richardson rte_errno = EINVAL;
98799a2dd95SBruce Richardson return 0;
98899a2dd95SBruce Richardson }
98999a2dd95SBruce Richardson
99099a2dd95SBruce Richardson links_map = dev->data->links_map;
99199a2dd95SBruce Richardson /* Point links_map to this port specific area */
99299a2dd95SBruce Richardson links_map += (port_id * RTE_EVENT_MAX_QUEUES_PER_DEV);
99399a2dd95SBruce Richardson
99499a2dd95SBruce Richardson if (queues == NULL) {
99599a2dd95SBruce Richardson j = 0;
99699a2dd95SBruce Richardson for (i = 0; i < dev->data->nb_queues; i++) {
99799a2dd95SBruce Richardson if (links_map[i] !=
99899a2dd95SBruce Richardson EVENT_QUEUE_SERVICE_PRIORITY_INVALID) {
99999a2dd95SBruce Richardson all_queues[j] = i;
100099a2dd95SBruce Richardson j++;
100199a2dd95SBruce Richardson }
100299a2dd95SBruce Richardson }
100399a2dd95SBruce Richardson queues = all_queues;
100499a2dd95SBruce Richardson } else {
100599a2dd95SBruce Richardson for (j = 0; j < nb_unlinks; j++) {
100699a2dd95SBruce Richardson if (links_map[queues[j]] ==
100799a2dd95SBruce Richardson EVENT_QUEUE_SERVICE_PRIORITY_INVALID)
100899a2dd95SBruce Richardson break;
100999a2dd95SBruce Richardson }
101099a2dd95SBruce Richardson }
101199a2dd95SBruce Richardson
101299a2dd95SBruce Richardson nb_unlinks = j;
101399a2dd95SBruce Richardson for (i = 0; i < nb_unlinks; i++)
101499a2dd95SBruce Richardson if (queues[i] >= dev->data->nb_queues) {
101599a2dd95SBruce Richardson rte_errno = EINVAL;
101699a2dd95SBruce Richardson return 0;
101799a2dd95SBruce Richardson }
101899a2dd95SBruce Richardson
101999a2dd95SBruce Richardson diag = (*dev->dev_ops->port_unlink)(dev, dev->data->ports[port_id],
102099a2dd95SBruce Richardson queues, nb_unlinks);
102199a2dd95SBruce Richardson
102299a2dd95SBruce Richardson if (diag < 0)
102399a2dd95SBruce Richardson return diag;
102499a2dd95SBruce Richardson
102599a2dd95SBruce Richardson for (i = 0; i < diag; i++)
102699a2dd95SBruce Richardson links_map[queues[i]] = EVENT_QUEUE_SERVICE_PRIORITY_INVALID;
102799a2dd95SBruce Richardson
102899a2dd95SBruce Richardson rte_eventdev_trace_port_unlink(dev_id, port_id, nb_unlinks, diag);
102999a2dd95SBruce Richardson return diag;
103099a2dd95SBruce Richardson }
103199a2dd95SBruce Richardson
103299a2dd95SBruce Richardson int
rte_event_port_unlinks_in_progress(uint8_t dev_id,uint8_t port_id)103399a2dd95SBruce Richardson rte_event_port_unlinks_in_progress(uint8_t dev_id, uint8_t port_id)
103499a2dd95SBruce Richardson {
103599a2dd95SBruce Richardson struct rte_eventdev *dev;
103699a2dd95SBruce Richardson
103799a2dd95SBruce Richardson RTE_EVENTDEV_VALID_DEVID_OR_ERR_RET(dev_id, -EINVAL);
103899a2dd95SBruce Richardson dev = &rte_eventdevs[dev_id];
103999a2dd95SBruce Richardson if (!is_valid_port(dev, port_id)) {
104099a2dd95SBruce Richardson RTE_EDEV_LOG_ERR("Invalid port_id=%" PRIu8, port_id);
104199a2dd95SBruce Richardson return -EINVAL;
104299a2dd95SBruce Richardson }
104399a2dd95SBruce Richardson
104499a2dd95SBruce Richardson /* Return 0 if the PMD does not implement unlinks in progress.
104599a2dd95SBruce Richardson * This allows PMDs which handle unlink synchronously to not implement
104699a2dd95SBruce Richardson * this function at all.
104799a2dd95SBruce Richardson */
104899a2dd95SBruce Richardson RTE_FUNC_PTR_OR_ERR_RET(*dev->dev_ops->port_unlinks_in_progress, 0);
104999a2dd95SBruce Richardson
105099a2dd95SBruce Richardson return (*dev->dev_ops->port_unlinks_in_progress)(dev,
105199a2dd95SBruce Richardson dev->data->ports[port_id]);
105299a2dd95SBruce Richardson }
105399a2dd95SBruce Richardson
105499a2dd95SBruce Richardson int
rte_event_port_links_get(uint8_t dev_id,uint8_t port_id,uint8_t queues[],uint8_t priorities[])105599a2dd95SBruce Richardson rte_event_port_links_get(uint8_t dev_id, uint8_t port_id,
105699a2dd95SBruce Richardson uint8_t queues[], uint8_t priorities[])
105799a2dd95SBruce Richardson {
105899a2dd95SBruce Richardson struct rte_eventdev *dev;
105999a2dd95SBruce Richardson uint16_t *links_map;
106099a2dd95SBruce Richardson int i, count = 0;
106199a2dd95SBruce Richardson
106299a2dd95SBruce Richardson RTE_EVENTDEV_VALID_DEVID_OR_ERR_RET(dev_id, -EINVAL);
106399a2dd95SBruce Richardson dev = &rte_eventdevs[dev_id];
106499a2dd95SBruce Richardson if (!is_valid_port(dev, port_id)) {
106599a2dd95SBruce Richardson RTE_EDEV_LOG_ERR("Invalid port_id=%" PRIu8, port_id);
106699a2dd95SBruce Richardson return -EINVAL;
106799a2dd95SBruce Richardson }
106899a2dd95SBruce Richardson
106999a2dd95SBruce Richardson links_map = dev->data->links_map;
107099a2dd95SBruce Richardson /* Point links_map to this port specific area */
107199a2dd95SBruce Richardson links_map += (port_id * RTE_EVENT_MAX_QUEUES_PER_DEV);
107299a2dd95SBruce Richardson for (i = 0; i < dev->data->nb_queues; i++) {
107399a2dd95SBruce Richardson if (links_map[i] != EVENT_QUEUE_SERVICE_PRIORITY_INVALID) {
107499a2dd95SBruce Richardson queues[count] = i;
107599a2dd95SBruce Richardson priorities[count] = (uint8_t)links_map[i];
107699a2dd95SBruce Richardson ++count;
107799a2dd95SBruce Richardson }
107899a2dd95SBruce Richardson }
107999a2dd95SBruce Richardson return count;
108099a2dd95SBruce Richardson }
108199a2dd95SBruce Richardson
108299a2dd95SBruce Richardson int
rte_event_dequeue_timeout_ticks(uint8_t dev_id,uint64_t ns,uint64_t * timeout_ticks)108399a2dd95SBruce Richardson rte_event_dequeue_timeout_ticks(uint8_t dev_id, uint64_t ns,
108499a2dd95SBruce Richardson uint64_t *timeout_ticks)
108599a2dd95SBruce Richardson {
108699a2dd95SBruce Richardson struct rte_eventdev *dev;
108799a2dd95SBruce Richardson
108899a2dd95SBruce Richardson RTE_EVENTDEV_VALID_DEVID_OR_ERR_RET(dev_id, -EINVAL);
108999a2dd95SBruce Richardson dev = &rte_eventdevs[dev_id];
109099a2dd95SBruce Richardson RTE_FUNC_PTR_OR_ERR_RET(*dev->dev_ops->timeout_ticks, -ENOTSUP);
109199a2dd95SBruce Richardson
109299a2dd95SBruce Richardson if (timeout_ticks == NULL)
109399a2dd95SBruce Richardson return -EINVAL;
109499a2dd95SBruce Richardson
109599a2dd95SBruce Richardson return (*dev->dev_ops->timeout_ticks)(dev, ns, timeout_ticks);
109699a2dd95SBruce Richardson }
109799a2dd95SBruce Richardson
109899a2dd95SBruce Richardson int
rte_event_dev_service_id_get(uint8_t dev_id,uint32_t * service_id)109999a2dd95SBruce Richardson rte_event_dev_service_id_get(uint8_t dev_id, uint32_t *service_id)
110099a2dd95SBruce Richardson {
110199a2dd95SBruce Richardson struct rte_eventdev *dev;
110299a2dd95SBruce Richardson
110399a2dd95SBruce Richardson RTE_EVENTDEV_VALID_DEVID_OR_ERR_RET(dev_id, -EINVAL);
110499a2dd95SBruce Richardson dev = &rte_eventdevs[dev_id];
110599a2dd95SBruce Richardson
110699a2dd95SBruce Richardson if (service_id == NULL)
110799a2dd95SBruce Richardson return -EINVAL;
110899a2dd95SBruce Richardson
110999a2dd95SBruce Richardson if (dev->data->service_inited)
111099a2dd95SBruce Richardson *service_id = dev->data->service_id;
111199a2dd95SBruce Richardson
111299a2dd95SBruce Richardson return dev->data->service_inited ? 0 : -ESRCH;
111399a2dd95SBruce Richardson }
111499a2dd95SBruce Richardson
111599a2dd95SBruce Richardson int
rte_event_dev_dump(uint8_t dev_id,FILE * f)111699a2dd95SBruce Richardson rte_event_dev_dump(uint8_t dev_id, FILE *f)
111799a2dd95SBruce Richardson {
111899a2dd95SBruce Richardson struct rte_eventdev *dev;
111999a2dd95SBruce Richardson
112099a2dd95SBruce Richardson RTE_EVENTDEV_VALID_DEVID_OR_ERR_RET(dev_id, -EINVAL);
112199a2dd95SBruce Richardson dev = &rte_eventdevs[dev_id];
112299a2dd95SBruce Richardson RTE_FUNC_PTR_OR_ERR_RET(*dev->dev_ops->dump, -ENOTSUP);
112399a2dd95SBruce Richardson if (f == NULL)
112499a2dd95SBruce Richardson return -EINVAL;
112599a2dd95SBruce Richardson
112699a2dd95SBruce Richardson (*dev->dev_ops->dump)(dev, f);
112799a2dd95SBruce Richardson return 0;
112899a2dd95SBruce Richardson
112999a2dd95SBruce Richardson }
113099a2dd95SBruce Richardson
113199a2dd95SBruce Richardson static int
xstats_get_count(uint8_t dev_id,enum rte_event_dev_xstats_mode mode,uint8_t queue_port_id)113299a2dd95SBruce Richardson xstats_get_count(uint8_t dev_id, enum rte_event_dev_xstats_mode mode,
113399a2dd95SBruce Richardson uint8_t queue_port_id)
113499a2dd95SBruce Richardson {
113599a2dd95SBruce Richardson struct rte_eventdev *dev = &rte_eventdevs[dev_id];
113699a2dd95SBruce Richardson if (dev->dev_ops->xstats_get_names != NULL)
113799a2dd95SBruce Richardson return (*dev->dev_ops->xstats_get_names)(dev, mode,
113899a2dd95SBruce Richardson queue_port_id,
113999a2dd95SBruce Richardson NULL, NULL, 0);
114099a2dd95SBruce Richardson return 0;
114199a2dd95SBruce Richardson }
114299a2dd95SBruce Richardson
114399a2dd95SBruce Richardson int
rte_event_dev_xstats_names_get(uint8_t dev_id,enum rte_event_dev_xstats_mode mode,uint8_t queue_port_id,struct rte_event_dev_xstats_name * xstats_names,unsigned int * ids,unsigned int size)114499a2dd95SBruce Richardson rte_event_dev_xstats_names_get(uint8_t dev_id,
114599a2dd95SBruce Richardson enum rte_event_dev_xstats_mode mode, uint8_t queue_port_id,
114699a2dd95SBruce Richardson struct rte_event_dev_xstats_name *xstats_names,
114799a2dd95SBruce Richardson unsigned int *ids, unsigned int size)
114899a2dd95SBruce Richardson {
114999a2dd95SBruce Richardson RTE_EVENTDEV_VALID_DEVID_OR_ERR_RET(dev_id, -ENODEV);
115099a2dd95SBruce Richardson const int cnt_expected_entries = xstats_get_count(dev_id, mode,
115199a2dd95SBruce Richardson queue_port_id);
115299a2dd95SBruce Richardson if (xstats_names == NULL || cnt_expected_entries < 0 ||
115399a2dd95SBruce Richardson (int)size < cnt_expected_entries)
115499a2dd95SBruce Richardson return cnt_expected_entries;
115599a2dd95SBruce Richardson
115699a2dd95SBruce Richardson /* dev_id checked above */
115799a2dd95SBruce Richardson const struct rte_eventdev *dev = &rte_eventdevs[dev_id];
115899a2dd95SBruce Richardson
115999a2dd95SBruce Richardson if (dev->dev_ops->xstats_get_names != NULL)
116099a2dd95SBruce Richardson return (*dev->dev_ops->xstats_get_names)(dev, mode,
116199a2dd95SBruce Richardson queue_port_id, xstats_names, ids, size);
116299a2dd95SBruce Richardson
116399a2dd95SBruce Richardson return -ENOTSUP;
116499a2dd95SBruce Richardson }
116599a2dd95SBruce Richardson
116699a2dd95SBruce Richardson /* retrieve eventdev extended statistics */
116799a2dd95SBruce Richardson int
rte_event_dev_xstats_get(uint8_t dev_id,enum rte_event_dev_xstats_mode mode,uint8_t queue_port_id,const unsigned int ids[],uint64_t values[],unsigned int n)116899a2dd95SBruce Richardson rte_event_dev_xstats_get(uint8_t dev_id, enum rte_event_dev_xstats_mode mode,
116999a2dd95SBruce Richardson uint8_t queue_port_id, const unsigned int ids[],
117099a2dd95SBruce Richardson uint64_t values[], unsigned int n)
117199a2dd95SBruce Richardson {
117299a2dd95SBruce Richardson RTE_EVENTDEV_VALID_DEVID_OR_ERR_RET(dev_id, -ENODEV);
117399a2dd95SBruce Richardson const struct rte_eventdev *dev = &rte_eventdevs[dev_id];
117499a2dd95SBruce Richardson
117599a2dd95SBruce Richardson /* implemented by the driver */
117699a2dd95SBruce Richardson if (dev->dev_ops->xstats_get != NULL)
117799a2dd95SBruce Richardson return (*dev->dev_ops->xstats_get)(dev, mode, queue_port_id,
117899a2dd95SBruce Richardson ids, values, n);
117999a2dd95SBruce Richardson return -ENOTSUP;
118099a2dd95SBruce Richardson }
118199a2dd95SBruce Richardson
118299a2dd95SBruce Richardson uint64_t
rte_event_dev_xstats_by_name_get(uint8_t dev_id,const char * name,unsigned int * id)118399a2dd95SBruce Richardson rte_event_dev_xstats_by_name_get(uint8_t dev_id, const char *name,
118499a2dd95SBruce Richardson unsigned int *id)
118599a2dd95SBruce Richardson {
118699a2dd95SBruce Richardson RTE_EVENTDEV_VALID_DEVID_OR_ERR_RET(dev_id, 0);
118799a2dd95SBruce Richardson const struct rte_eventdev *dev = &rte_eventdevs[dev_id];
118899a2dd95SBruce Richardson unsigned int temp = -1;
118999a2dd95SBruce Richardson
119099a2dd95SBruce Richardson if (id != NULL)
119199a2dd95SBruce Richardson *id = (unsigned int)-1;
119299a2dd95SBruce Richardson else
119399a2dd95SBruce Richardson id = &temp; /* ensure driver never gets a NULL value */
119499a2dd95SBruce Richardson
119599a2dd95SBruce Richardson /* implemented by driver */
119699a2dd95SBruce Richardson if (dev->dev_ops->xstats_get_by_name != NULL)
119799a2dd95SBruce Richardson return (*dev->dev_ops->xstats_get_by_name)(dev, name, id);
119899a2dd95SBruce Richardson return -ENOTSUP;
119999a2dd95SBruce Richardson }
120099a2dd95SBruce Richardson
rte_event_dev_xstats_reset(uint8_t dev_id,enum rte_event_dev_xstats_mode mode,int16_t queue_port_id,const uint32_t ids[],uint32_t nb_ids)120199a2dd95SBruce Richardson int rte_event_dev_xstats_reset(uint8_t dev_id,
120299a2dd95SBruce Richardson enum rte_event_dev_xstats_mode mode, int16_t queue_port_id,
120399a2dd95SBruce Richardson const uint32_t ids[], uint32_t nb_ids)
120499a2dd95SBruce Richardson {
120599a2dd95SBruce Richardson RTE_EVENTDEV_VALID_DEVID_OR_ERR_RET(dev_id, -EINVAL);
120699a2dd95SBruce Richardson struct rte_eventdev *dev = &rte_eventdevs[dev_id];
120799a2dd95SBruce Richardson
120899a2dd95SBruce Richardson if (dev->dev_ops->xstats_reset != NULL)
120999a2dd95SBruce Richardson return (*dev->dev_ops->xstats_reset)(dev, mode, queue_port_id,
121099a2dd95SBruce Richardson ids, nb_ids);
121199a2dd95SBruce Richardson return -ENOTSUP;
121299a2dd95SBruce Richardson }
121399a2dd95SBruce Richardson
121499a2dd95SBruce Richardson int rte_event_pmd_selftest_seqn_dynfield_offset = -1;
121599a2dd95SBruce Richardson
rte_event_dev_selftest(uint8_t dev_id)121699a2dd95SBruce Richardson int rte_event_dev_selftest(uint8_t dev_id)
121799a2dd95SBruce Richardson {
121899a2dd95SBruce Richardson RTE_EVENTDEV_VALID_DEVID_OR_ERR_RET(dev_id, -EINVAL);
121999a2dd95SBruce Richardson static const struct rte_mbuf_dynfield test_seqn_dynfield_desc = {
122099a2dd95SBruce Richardson .name = "rte_event_pmd_selftest_seqn_dynfield",
122199a2dd95SBruce Richardson .size = sizeof(rte_event_pmd_selftest_seqn_t),
122299a2dd95SBruce Richardson .align = __alignof__(rte_event_pmd_selftest_seqn_t),
122399a2dd95SBruce Richardson };
122499a2dd95SBruce Richardson struct rte_eventdev *dev = &rte_eventdevs[dev_id];
122599a2dd95SBruce Richardson
122699a2dd95SBruce Richardson if (dev->dev_ops->dev_selftest != NULL) {
122799a2dd95SBruce Richardson rte_event_pmd_selftest_seqn_dynfield_offset =
122899a2dd95SBruce Richardson rte_mbuf_dynfield_register(&test_seqn_dynfield_desc);
122999a2dd95SBruce Richardson if (rte_event_pmd_selftest_seqn_dynfield_offset < 0)
123099a2dd95SBruce Richardson return -ENOMEM;
123199a2dd95SBruce Richardson return (*dev->dev_ops->dev_selftest)();
123299a2dd95SBruce Richardson }
123399a2dd95SBruce Richardson return -ENOTSUP;
123499a2dd95SBruce Richardson }
123599a2dd95SBruce Richardson
123699a2dd95SBruce Richardson struct rte_mempool *
rte_event_vector_pool_create(const char * name,unsigned int n,unsigned int cache_size,uint16_t nb_elem,int socket_id)123799a2dd95SBruce Richardson rte_event_vector_pool_create(const char *name, unsigned int n,
123899a2dd95SBruce Richardson unsigned int cache_size, uint16_t nb_elem,
123999a2dd95SBruce Richardson int socket_id)
124099a2dd95SBruce Richardson {
124199a2dd95SBruce Richardson const char *mp_ops_name;
124299a2dd95SBruce Richardson struct rte_mempool *mp;
124399a2dd95SBruce Richardson unsigned int elt_sz;
124499a2dd95SBruce Richardson int ret;
124599a2dd95SBruce Richardson
124699a2dd95SBruce Richardson if (!nb_elem) {
124799a2dd95SBruce Richardson RTE_LOG(ERR, EVENTDEV,
124899a2dd95SBruce Richardson "Invalid number of elements=%d requested\n", nb_elem);
124999a2dd95SBruce Richardson rte_errno = EINVAL;
125099a2dd95SBruce Richardson return NULL;
125199a2dd95SBruce Richardson }
125299a2dd95SBruce Richardson
125399a2dd95SBruce Richardson elt_sz =
125499a2dd95SBruce Richardson sizeof(struct rte_event_vector) + (nb_elem * sizeof(uintptr_t));
125599a2dd95SBruce Richardson mp = rte_mempool_create_empty(name, n, elt_sz, cache_size, 0, socket_id,
125699a2dd95SBruce Richardson 0);
125799a2dd95SBruce Richardson if (mp == NULL)
125899a2dd95SBruce Richardson return NULL;
125999a2dd95SBruce Richardson
126099a2dd95SBruce Richardson mp_ops_name = rte_mbuf_best_mempool_ops();
126199a2dd95SBruce Richardson ret = rte_mempool_set_ops_byname(mp, mp_ops_name, NULL);
126299a2dd95SBruce Richardson if (ret != 0) {
126399a2dd95SBruce Richardson RTE_LOG(ERR, EVENTDEV, "error setting mempool handler\n");
126499a2dd95SBruce Richardson goto err;
126599a2dd95SBruce Richardson }
126699a2dd95SBruce Richardson
126799a2dd95SBruce Richardson ret = rte_mempool_populate_default(mp);
126899a2dd95SBruce Richardson if (ret < 0)
126999a2dd95SBruce Richardson goto err;
127099a2dd95SBruce Richardson
127199a2dd95SBruce Richardson return mp;
127299a2dd95SBruce Richardson err:
127399a2dd95SBruce Richardson rte_mempool_free(mp);
127499a2dd95SBruce Richardson rte_errno = -ret;
127599a2dd95SBruce Richardson return NULL;
127699a2dd95SBruce Richardson }
127799a2dd95SBruce Richardson
127899a2dd95SBruce Richardson int
rte_event_dev_start(uint8_t dev_id)127999a2dd95SBruce Richardson rte_event_dev_start(uint8_t dev_id)
128099a2dd95SBruce Richardson {
128199a2dd95SBruce Richardson struct rte_eventdev *dev;
128299a2dd95SBruce Richardson int diag;
128399a2dd95SBruce Richardson
128499a2dd95SBruce Richardson RTE_EDEV_LOG_DEBUG("Start dev_id=%" PRIu8, dev_id);
128599a2dd95SBruce Richardson
128699a2dd95SBruce Richardson RTE_EVENTDEV_VALID_DEVID_OR_ERR_RET(dev_id, -EINVAL);
128799a2dd95SBruce Richardson dev = &rte_eventdevs[dev_id];
128899a2dd95SBruce Richardson RTE_FUNC_PTR_OR_ERR_RET(*dev->dev_ops->dev_start, -ENOTSUP);
128999a2dd95SBruce Richardson
129099a2dd95SBruce Richardson if (dev->data->dev_started != 0) {
129199a2dd95SBruce Richardson RTE_EDEV_LOG_ERR("Device with dev_id=%" PRIu8 "already started",
129299a2dd95SBruce Richardson dev_id);
129399a2dd95SBruce Richardson return 0;
129499a2dd95SBruce Richardson }
129599a2dd95SBruce Richardson
129699a2dd95SBruce Richardson diag = (*dev->dev_ops->dev_start)(dev);
129799a2dd95SBruce Richardson rte_eventdev_trace_start(dev_id, diag);
129899a2dd95SBruce Richardson if (diag == 0)
129999a2dd95SBruce Richardson dev->data->dev_started = 1;
130099a2dd95SBruce Richardson else
130199a2dd95SBruce Richardson return diag;
130299a2dd95SBruce Richardson
1303d35e6132SPavan Nikhilesh event_dev_fp_ops_set(rte_event_fp_ops + dev_id, dev);
1304d35e6132SPavan Nikhilesh
130599a2dd95SBruce Richardson return 0;
130699a2dd95SBruce Richardson }
130799a2dd95SBruce Richardson
130899a2dd95SBruce Richardson int
rte_event_dev_stop_flush_callback_register(uint8_t dev_id,eventdev_stop_flush_t callback,void * userdata)130999a2dd95SBruce Richardson rte_event_dev_stop_flush_callback_register(uint8_t dev_id,
131099a2dd95SBruce Richardson eventdev_stop_flush_t callback, void *userdata)
131199a2dd95SBruce Richardson {
131299a2dd95SBruce Richardson struct rte_eventdev *dev;
131399a2dd95SBruce Richardson
131499a2dd95SBruce Richardson RTE_EDEV_LOG_DEBUG("Stop flush register dev_id=%" PRIu8, dev_id);
131599a2dd95SBruce Richardson
131699a2dd95SBruce Richardson RTE_EVENTDEV_VALID_DEVID_OR_ERR_RET(dev_id, -EINVAL);
131799a2dd95SBruce Richardson dev = &rte_eventdevs[dev_id];
131899a2dd95SBruce Richardson
131999a2dd95SBruce Richardson dev->dev_ops->dev_stop_flush = callback;
132099a2dd95SBruce Richardson dev->data->dev_stop_flush_arg = userdata;
132199a2dd95SBruce Richardson
132299a2dd95SBruce Richardson return 0;
132399a2dd95SBruce Richardson }
132499a2dd95SBruce Richardson
132599a2dd95SBruce Richardson void
rte_event_dev_stop(uint8_t dev_id)132699a2dd95SBruce Richardson rte_event_dev_stop(uint8_t dev_id)
132799a2dd95SBruce Richardson {
132899a2dd95SBruce Richardson struct rte_eventdev *dev;
132999a2dd95SBruce Richardson
133099a2dd95SBruce Richardson RTE_EDEV_LOG_DEBUG("Stop dev_id=%" PRIu8, dev_id);
133199a2dd95SBruce Richardson
133299a2dd95SBruce Richardson RTE_EVENTDEV_VALID_DEVID_OR_RET(dev_id);
133399a2dd95SBruce Richardson dev = &rte_eventdevs[dev_id];
133499a2dd95SBruce Richardson RTE_FUNC_PTR_OR_RET(*dev->dev_ops->dev_stop);
133599a2dd95SBruce Richardson
133699a2dd95SBruce Richardson if (dev->data->dev_started == 0) {
133799a2dd95SBruce Richardson RTE_EDEV_LOG_ERR("Device with dev_id=%" PRIu8 "already stopped",
133899a2dd95SBruce Richardson dev_id);
133999a2dd95SBruce Richardson return;
134099a2dd95SBruce Richardson }
134199a2dd95SBruce Richardson
134299a2dd95SBruce Richardson dev->data->dev_started = 0;
134399a2dd95SBruce Richardson (*dev->dev_ops->dev_stop)(dev);
134499a2dd95SBruce Richardson rte_eventdev_trace_stop(dev_id);
1345d35e6132SPavan Nikhilesh event_dev_fp_ops_reset(rte_event_fp_ops + dev_id);
134699a2dd95SBruce Richardson }
134799a2dd95SBruce Richardson
134899a2dd95SBruce Richardson int
rte_event_dev_close(uint8_t dev_id)134999a2dd95SBruce Richardson rte_event_dev_close(uint8_t dev_id)
135099a2dd95SBruce Richardson {
135199a2dd95SBruce Richardson struct rte_eventdev *dev;
135299a2dd95SBruce Richardson
135399a2dd95SBruce Richardson RTE_EVENTDEV_VALID_DEVID_OR_ERR_RET(dev_id, -EINVAL);
135499a2dd95SBruce Richardson dev = &rte_eventdevs[dev_id];
135599a2dd95SBruce Richardson RTE_FUNC_PTR_OR_ERR_RET(*dev->dev_ops->dev_close, -ENOTSUP);
135699a2dd95SBruce Richardson
135799a2dd95SBruce Richardson /* Device must be stopped before it can be closed */
135899a2dd95SBruce Richardson if (dev->data->dev_started == 1) {
135999a2dd95SBruce Richardson RTE_EDEV_LOG_ERR("Device %u must be stopped before closing",
136099a2dd95SBruce Richardson dev_id);
136199a2dd95SBruce Richardson return -EBUSY;
136299a2dd95SBruce Richardson }
136399a2dd95SBruce Richardson
1364d35e6132SPavan Nikhilesh event_dev_fp_ops_reset(rte_event_fp_ops + dev_id);
136599a2dd95SBruce Richardson rte_eventdev_trace_close(dev_id);
136699a2dd95SBruce Richardson return (*dev->dev_ops->dev_close)(dev);
136799a2dd95SBruce Richardson }
136899a2dd95SBruce Richardson
136999a2dd95SBruce Richardson static inline int
eventdev_data_alloc(uint8_t dev_id,struct rte_eventdev_data ** data,int socket_id)13709c67fcbfSPavan Nikhilesh eventdev_data_alloc(uint8_t dev_id, struct rte_eventdev_data **data,
137199a2dd95SBruce Richardson int socket_id)
137299a2dd95SBruce Richardson {
137399a2dd95SBruce Richardson char mz_name[RTE_EVENTDEV_NAME_MAX_LEN];
137499a2dd95SBruce Richardson const struct rte_memzone *mz;
137599a2dd95SBruce Richardson int n;
137699a2dd95SBruce Richardson
137799a2dd95SBruce Richardson /* Generate memzone name */
137899a2dd95SBruce Richardson n = snprintf(mz_name, sizeof(mz_name), "rte_eventdev_data_%u", dev_id);
137999a2dd95SBruce Richardson if (n >= (int)sizeof(mz_name))
138099a2dd95SBruce Richardson return -EINVAL;
138199a2dd95SBruce Richardson
138299a2dd95SBruce Richardson if (rte_eal_process_type() == RTE_PROC_PRIMARY) {
138399a2dd95SBruce Richardson mz = rte_memzone_reserve(mz_name,
138499a2dd95SBruce Richardson sizeof(struct rte_eventdev_data),
138599a2dd95SBruce Richardson socket_id, 0);
138699a2dd95SBruce Richardson } else
138799a2dd95SBruce Richardson mz = rte_memzone_lookup(mz_name);
138899a2dd95SBruce Richardson
138999a2dd95SBruce Richardson if (mz == NULL)
139099a2dd95SBruce Richardson return -ENOMEM;
139199a2dd95SBruce Richardson
139299a2dd95SBruce Richardson *data = mz->addr;
13939c67fcbfSPavan Nikhilesh if (rte_eal_process_type() == RTE_PROC_PRIMARY) {
139499a2dd95SBruce Richardson memset(*data, 0, sizeof(struct rte_eventdev_data));
13959c67fcbfSPavan Nikhilesh for (n = 0; n < RTE_EVENT_MAX_PORTS_PER_DEV *
13969c67fcbfSPavan Nikhilesh RTE_EVENT_MAX_QUEUES_PER_DEV;
13979c67fcbfSPavan Nikhilesh n++)
13989c67fcbfSPavan Nikhilesh (*data)->links_map[n] =
13999c67fcbfSPavan Nikhilesh EVENT_QUEUE_SERVICE_PRIORITY_INVALID;
14009c67fcbfSPavan Nikhilesh }
140199a2dd95SBruce Richardson
140299a2dd95SBruce Richardson return 0;
140399a2dd95SBruce Richardson }
140499a2dd95SBruce Richardson
140599a2dd95SBruce Richardson static inline uint8_t
eventdev_find_free_device_index(void)14069c67fcbfSPavan Nikhilesh eventdev_find_free_device_index(void)
140799a2dd95SBruce Richardson {
140899a2dd95SBruce Richardson uint8_t dev_id;
140999a2dd95SBruce Richardson
141099a2dd95SBruce Richardson for (dev_id = 0; dev_id < RTE_EVENT_MAX_DEVS; dev_id++) {
141199a2dd95SBruce Richardson if (rte_eventdevs[dev_id].attached ==
141299a2dd95SBruce Richardson RTE_EVENTDEV_DETACHED)
141399a2dd95SBruce Richardson return dev_id;
141499a2dd95SBruce Richardson }
141599a2dd95SBruce Richardson return RTE_EVENT_MAX_DEVS;
141699a2dd95SBruce Richardson }
141799a2dd95SBruce Richardson
141899a2dd95SBruce Richardson struct rte_eventdev *
rte_event_pmd_allocate(const char * name,int socket_id)141999a2dd95SBruce Richardson rte_event_pmd_allocate(const char *name, int socket_id)
142099a2dd95SBruce Richardson {
142199a2dd95SBruce Richardson struct rte_eventdev *eventdev;
142299a2dd95SBruce Richardson uint8_t dev_id;
142399a2dd95SBruce Richardson
142499a2dd95SBruce Richardson if (rte_event_pmd_get_named_dev(name) != NULL) {
142599a2dd95SBruce Richardson RTE_EDEV_LOG_ERR("Event device with name %s already "
142699a2dd95SBruce Richardson "allocated!", name);
142799a2dd95SBruce Richardson return NULL;
142899a2dd95SBruce Richardson }
142999a2dd95SBruce Richardson
14309c67fcbfSPavan Nikhilesh dev_id = eventdev_find_free_device_index();
143199a2dd95SBruce Richardson if (dev_id == RTE_EVENT_MAX_DEVS) {
143299a2dd95SBruce Richardson RTE_EDEV_LOG_ERR("Reached maximum number of event devices");
143399a2dd95SBruce Richardson return NULL;
143499a2dd95SBruce Richardson }
143599a2dd95SBruce Richardson
143699a2dd95SBruce Richardson eventdev = &rte_eventdevs[dev_id];
143799a2dd95SBruce Richardson
143899a2dd95SBruce Richardson if (eventdev->data == NULL) {
143999a2dd95SBruce Richardson struct rte_eventdev_data *eventdev_data = NULL;
144099a2dd95SBruce Richardson
14419c67fcbfSPavan Nikhilesh int retval =
14429c67fcbfSPavan Nikhilesh eventdev_data_alloc(dev_id, &eventdev_data, socket_id);
144399a2dd95SBruce Richardson
144499a2dd95SBruce Richardson if (retval < 0 || eventdev_data == NULL)
144599a2dd95SBruce Richardson return NULL;
144699a2dd95SBruce Richardson
144799a2dd95SBruce Richardson eventdev->data = eventdev_data;
144899a2dd95SBruce Richardson
144999a2dd95SBruce Richardson if (rte_eal_process_type() == RTE_PROC_PRIMARY) {
145099a2dd95SBruce Richardson
145199a2dd95SBruce Richardson strlcpy(eventdev->data->name, name,
145299a2dd95SBruce Richardson RTE_EVENTDEV_NAME_MAX_LEN);
145399a2dd95SBruce Richardson
145499a2dd95SBruce Richardson eventdev->data->dev_id = dev_id;
145599a2dd95SBruce Richardson eventdev->data->socket_id = socket_id;
145699a2dd95SBruce Richardson eventdev->data->dev_started = 0;
145799a2dd95SBruce Richardson }
145899a2dd95SBruce Richardson
145999a2dd95SBruce Richardson eventdev->attached = RTE_EVENTDEV_ATTACHED;
146099a2dd95SBruce Richardson eventdev_globals.nb_devs++;
146199a2dd95SBruce Richardson }
146299a2dd95SBruce Richardson
146399a2dd95SBruce Richardson return eventdev;
146499a2dd95SBruce Richardson }
146599a2dd95SBruce Richardson
146699a2dd95SBruce Richardson int
rte_event_pmd_release(struct rte_eventdev * eventdev)146799a2dd95SBruce Richardson rte_event_pmd_release(struct rte_eventdev *eventdev)
146899a2dd95SBruce Richardson {
146999a2dd95SBruce Richardson int ret;
147099a2dd95SBruce Richardson char mz_name[RTE_EVENTDEV_NAME_MAX_LEN];
147199a2dd95SBruce Richardson const struct rte_memzone *mz;
147299a2dd95SBruce Richardson
147399a2dd95SBruce Richardson if (eventdev == NULL)
147499a2dd95SBruce Richardson return -EINVAL;
147599a2dd95SBruce Richardson
1476d35e6132SPavan Nikhilesh event_dev_fp_ops_reset(rte_event_fp_ops + eventdev->data->dev_id);
147799a2dd95SBruce Richardson eventdev->attached = RTE_EVENTDEV_DETACHED;
147899a2dd95SBruce Richardson eventdev_globals.nb_devs--;
147999a2dd95SBruce Richardson
148099a2dd95SBruce Richardson if (rte_eal_process_type() == RTE_PROC_PRIMARY) {
148199a2dd95SBruce Richardson rte_free(eventdev->data->dev_private);
148299a2dd95SBruce Richardson
148399a2dd95SBruce Richardson /* Generate memzone name */
148499a2dd95SBruce Richardson ret = snprintf(mz_name, sizeof(mz_name), "rte_eventdev_data_%u",
148599a2dd95SBruce Richardson eventdev->data->dev_id);
148699a2dd95SBruce Richardson if (ret >= (int)sizeof(mz_name))
148799a2dd95SBruce Richardson return -EINVAL;
148899a2dd95SBruce Richardson
148999a2dd95SBruce Richardson mz = rte_memzone_lookup(mz_name);
149099a2dd95SBruce Richardson if (mz == NULL)
149199a2dd95SBruce Richardson return -ENOMEM;
149299a2dd95SBruce Richardson
149399a2dd95SBruce Richardson ret = rte_memzone_free(mz);
149499a2dd95SBruce Richardson if (ret)
149599a2dd95SBruce Richardson return ret;
149699a2dd95SBruce Richardson }
149799a2dd95SBruce Richardson
149899a2dd95SBruce Richardson eventdev->data = NULL;
149999a2dd95SBruce Richardson return 0;
150099a2dd95SBruce Richardson }
150199a2dd95SBruce Richardson
1502d35e6132SPavan Nikhilesh void
event_dev_probing_finish(struct rte_eventdev * eventdev)1503d35e6132SPavan Nikhilesh event_dev_probing_finish(struct rte_eventdev *eventdev)
1504d35e6132SPavan Nikhilesh {
1505d35e6132SPavan Nikhilesh if (eventdev == NULL)
1506d35e6132SPavan Nikhilesh return;
1507d35e6132SPavan Nikhilesh
1508d35e6132SPavan Nikhilesh event_dev_fp_ops_set(rte_event_fp_ops + eventdev->data->dev_id,
1509d35e6132SPavan Nikhilesh eventdev);
1510d35e6132SPavan Nikhilesh }
151199a2dd95SBruce Richardson
151299a2dd95SBruce Richardson static int
handle_dev_list(const char * cmd __rte_unused,const char * params __rte_unused,struct rte_tel_data * d)151399a2dd95SBruce Richardson handle_dev_list(const char *cmd __rte_unused,
151499a2dd95SBruce Richardson const char *params __rte_unused,
151599a2dd95SBruce Richardson struct rte_tel_data *d)
151699a2dd95SBruce Richardson {
151799a2dd95SBruce Richardson uint8_t dev_id;
151899a2dd95SBruce Richardson int ndev = rte_event_dev_count();
151999a2dd95SBruce Richardson
152099a2dd95SBruce Richardson if (ndev < 1)
152199a2dd95SBruce Richardson return -1;
152299a2dd95SBruce Richardson
152399a2dd95SBruce Richardson rte_tel_data_start_array(d, RTE_TEL_INT_VAL);
152499a2dd95SBruce Richardson for (dev_id = 0; dev_id < RTE_EVENT_MAX_DEVS; dev_id++) {
152599a2dd95SBruce Richardson if (rte_eventdevs[dev_id].attached ==
152699a2dd95SBruce Richardson RTE_EVENTDEV_ATTACHED)
152799a2dd95SBruce Richardson rte_tel_data_add_array_int(d, dev_id);
152899a2dd95SBruce Richardson }
152999a2dd95SBruce Richardson
153099a2dd95SBruce Richardson return 0;
153199a2dd95SBruce Richardson }
153299a2dd95SBruce Richardson
153399a2dd95SBruce Richardson static int
handle_port_list(const char * cmd __rte_unused,const char * params,struct rte_tel_data * d)153499a2dd95SBruce Richardson handle_port_list(const char *cmd __rte_unused,
153599a2dd95SBruce Richardson const char *params,
153699a2dd95SBruce Richardson struct rte_tel_data *d)
153799a2dd95SBruce Richardson {
153899a2dd95SBruce Richardson int i;
153999a2dd95SBruce Richardson uint8_t dev_id;
154099a2dd95SBruce Richardson struct rte_eventdev *dev;
154199a2dd95SBruce Richardson char *end_param;
154299a2dd95SBruce Richardson
154399a2dd95SBruce Richardson if (params == NULL || strlen(params) == 0 || !isdigit(*params))
154499a2dd95SBruce Richardson return -1;
154599a2dd95SBruce Richardson
154699a2dd95SBruce Richardson dev_id = strtoul(params, &end_param, 10);
154799a2dd95SBruce Richardson if (*end_param != '\0')
154899a2dd95SBruce Richardson RTE_EDEV_LOG_DEBUG(
154999a2dd95SBruce Richardson "Extra parameters passed to eventdev telemetry command, ignoring");
155099a2dd95SBruce Richardson
155199a2dd95SBruce Richardson RTE_EVENTDEV_VALID_DEVID_OR_ERR_RET(dev_id, -EINVAL);
155299a2dd95SBruce Richardson dev = &rte_eventdevs[dev_id];
155399a2dd95SBruce Richardson
155499a2dd95SBruce Richardson rte_tel_data_start_array(d, RTE_TEL_INT_VAL);
155599a2dd95SBruce Richardson for (i = 0; i < dev->data->nb_ports; i++)
155699a2dd95SBruce Richardson rte_tel_data_add_array_int(d, i);
155799a2dd95SBruce Richardson
155899a2dd95SBruce Richardson return 0;
155999a2dd95SBruce Richardson }
156099a2dd95SBruce Richardson
156199a2dd95SBruce Richardson static int
handle_queue_list(const char * cmd __rte_unused,const char * params,struct rte_tel_data * d)156299a2dd95SBruce Richardson handle_queue_list(const char *cmd __rte_unused,
156399a2dd95SBruce Richardson const char *params,
156499a2dd95SBruce Richardson struct rte_tel_data *d)
156599a2dd95SBruce Richardson {
156699a2dd95SBruce Richardson int i;
156799a2dd95SBruce Richardson uint8_t dev_id;
156899a2dd95SBruce Richardson struct rte_eventdev *dev;
156999a2dd95SBruce Richardson char *end_param;
157099a2dd95SBruce Richardson
157199a2dd95SBruce Richardson if (params == NULL || strlen(params) == 0 || !isdigit(*params))
157299a2dd95SBruce Richardson return -1;
157399a2dd95SBruce Richardson
157499a2dd95SBruce Richardson dev_id = strtoul(params, &end_param, 10);
157599a2dd95SBruce Richardson if (*end_param != '\0')
157699a2dd95SBruce Richardson RTE_EDEV_LOG_DEBUG(
157799a2dd95SBruce Richardson "Extra parameters passed to eventdev telemetry command, ignoring");
157899a2dd95SBruce Richardson
157999a2dd95SBruce Richardson RTE_EVENTDEV_VALID_DEVID_OR_ERR_RET(dev_id, -EINVAL);
158099a2dd95SBruce Richardson dev = &rte_eventdevs[dev_id];
158199a2dd95SBruce Richardson
158299a2dd95SBruce Richardson rte_tel_data_start_array(d, RTE_TEL_INT_VAL);
158399a2dd95SBruce Richardson for (i = 0; i < dev->data->nb_queues; i++)
158499a2dd95SBruce Richardson rte_tel_data_add_array_int(d, i);
158599a2dd95SBruce Richardson
158699a2dd95SBruce Richardson return 0;
158799a2dd95SBruce Richardson }
158899a2dd95SBruce Richardson
158999a2dd95SBruce Richardson static int
handle_queue_links(const char * cmd __rte_unused,const char * params,struct rte_tel_data * d)159099a2dd95SBruce Richardson handle_queue_links(const char *cmd __rte_unused,
159199a2dd95SBruce Richardson const char *params,
159299a2dd95SBruce Richardson struct rte_tel_data *d)
159399a2dd95SBruce Richardson {
159499a2dd95SBruce Richardson int i, ret, port_id = 0;
159599a2dd95SBruce Richardson char *end_param;
159699a2dd95SBruce Richardson uint8_t dev_id;
159799a2dd95SBruce Richardson uint8_t queues[RTE_EVENT_MAX_QUEUES_PER_DEV];
159899a2dd95SBruce Richardson uint8_t priorities[RTE_EVENT_MAX_QUEUES_PER_DEV];
159999a2dd95SBruce Richardson const char *p_param;
160099a2dd95SBruce Richardson
160199a2dd95SBruce Richardson if (params == NULL || strlen(params) == 0 || !isdigit(*params))
160299a2dd95SBruce Richardson return -1;
160399a2dd95SBruce Richardson
160499a2dd95SBruce Richardson /* Get dev ID from parameter string */
160599a2dd95SBruce Richardson dev_id = strtoul(params, &end_param, 10);
160699a2dd95SBruce Richardson RTE_EVENTDEV_VALID_DEVID_OR_ERR_RET(dev_id, -EINVAL);
160799a2dd95SBruce Richardson
160899a2dd95SBruce Richardson p_param = strtok(end_param, ",");
160999a2dd95SBruce Richardson if (p_param == NULL || strlen(p_param) == 0 || !isdigit(*p_param))
161099a2dd95SBruce Richardson return -1;
161199a2dd95SBruce Richardson
161299a2dd95SBruce Richardson port_id = strtoul(p_param, &end_param, 10);
161399a2dd95SBruce Richardson p_param = strtok(NULL, "\0");
161499a2dd95SBruce Richardson if (p_param != NULL)
161599a2dd95SBruce Richardson RTE_EDEV_LOG_DEBUG(
161699a2dd95SBruce Richardson "Extra parameters passed to eventdev telemetry command, ignoring");
161799a2dd95SBruce Richardson
161899a2dd95SBruce Richardson ret = rte_event_port_links_get(dev_id, port_id, queues, priorities);
161999a2dd95SBruce Richardson if (ret < 0)
162099a2dd95SBruce Richardson return -1;
162199a2dd95SBruce Richardson
162299a2dd95SBruce Richardson rte_tel_data_start_dict(d);
162399a2dd95SBruce Richardson for (i = 0; i < ret; i++) {
162499a2dd95SBruce Richardson char qid_name[32];
162599a2dd95SBruce Richardson
162699a2dd95SBruce Richardson snprintf(qid_name, 31, "qid_%u", queues[i]);
162799a2dd95SBruce Richardson rte_tel_data_add_dict_u64(d, qid_name, priorities[i]);
162899a2dd95SBruce Richardson }
162999a2dd95SBruce Richardson
163099a2dd95SBruce Richardson return 0;
163199a2dd95SBruce Richardson }
163299a2dd95SBruce Richardson
163399a2dd95SBruce Richardson static int
eventdev_build_telemetry_data(int dev_id,enum rte_event_dev_xstats_mode mode,int port_queue_id,struct rte_tel_data * d)163499a2dd95SBruce Richardson eventdev_build_telemetry_data(int dev_id,
163599a2dd95SBruce Richardson enum rte_event_dev_xstats_mode mode,
163699a2dd95SBruce Richardson int port_queue_id,
163799a2dd95SBruce Richardson struct rte_tel_data *d)
163899a2dd95SBruce Richardson {
163999a2dd95SBruce Richardson struct rte_event_dev_xstats_name *xstat_names;
164099a2dd95SBruce Richardson unsigned int *ids;
164199a2dd95SBruce Richardson uint64_t *values;
164299a2dd95SBruce Richardson int i, ret, num_xstats;
164399a2dd95SBruce Richardson
164499a2dd95SBruce Richardson num_xstats = rte_event_dev_xstats_names_get(dev_id,
164599a2dd95SBruce Richardson mode,
164699a2dd95SBruce Richardson port_queue_id,
164799a2dd95SBruce Richardson NULL,
164899a2dd95SBruce Richardson NULL,
164999a2dd95SBruce Richardson 0);
165099a2dd95SBruce Richardson
165199a2dd95SBruce Richardson if (num_xstats < 0)
165299a2dd95SBruce Richardson return -1;
165399a2dd95SBruce Richardson
165499a2dd95SBruce Richardson /* use one malloc for names */
165599a2dd95SBruce Richardson xstat_names = malloc((sizeof(struct rte_event_dev_xstats_name))
165699a2dd95SBruce Richardson * num_xstats);
165799a2dd95SBruce Richardson if (xstat_names == NULL)
165899a2dd95SBruce Richardson return -1;
165999a2dd95SBruce Richardson
166099a2dd95SBruce Richardson ids = malloc((sizeof(unsigned int)) * num_xstats);
166199a2dd95SBruce Richardson if (ids == NULL) {
166299a2dd95SBruce Richardson free(xstat_names);
166399a2dd95SBruce Richardson return -1;
166499a2dd95SBruce Richardson }
166599a2dd95SBruce Richardson
166699a2dd95SBruce Richardson values = malloc((sizeof(uint64_t)) * num_xstats);
166799a2dd95SBruce Richardson if (values == NULL) {
166899a2dd95SBruce Richardson free(xstat_names);
166999a2dd95SBruce Richardson free(ids);
167099a2dd95SBruce Richardson return -1;
167199a2dd95SBruce Richardson }
167299a2dd95SBruce Richardson
167399a2dd95SBruce Richardson ret = rte_event_dev_xstats_names_get(dev_id, mode, port_queue_id,
167499a2dd95SBruce Richardson xstat_names, ids, num_xstats);
167599a2dd95SBruce Richardson if (ret < 0 || ret > num_xstats) {
167699a2dd95SBruce Richardson free(xstat_names);
167799a2dd95SBruce Richardson free(ids);
167899a2dd95SBruce Richardson free(values);
167999a2dd95SBruce Richardson return -1;
168099a2dd95SBruce Richardson }
168199a2dd95SBruce Richardson
168299a2dd95SBruce Richardson ret = rte_event_dev_xstats_get(dev_id, mode, port_queue_id,
168399a2dd95SBruce Richardson ids, values, num_xstats);
168499a2dd95SBruce Richardson if (ret < 0 || ret > num_xstats) {
168599a2dd95SBruce Richardson free(xstat_names);
168699a2dd95SBruce Richardson free(ids);
168799a2dd95SBruce Richardson free(values);
168899a2dd95SBruce Richardson return -1;
168999a2dd95SBruce Richardson }
169099a2dd95SBruce Richardson
169199a2dd95SBruce Richardson rte_tel_data_start_dict(d);
169299a2dd95SBruce Richardson for (i = 0; i < num_xstats; i++)
169399a2dd95SBruce Richardson rte_tel_data_add_dict_u64(d, xstat_names[i].name,
169499a2dd95SBruce Richardson values[i]);
169599a2dd95SBruce Richardson
169699a2dd95SBruce Richardson free(xstat_names);
169799a2dd95SBruce Richardson free(ids);
169899a2dd95SBruce Richardson free(values);
169999a2dd95SBruce Richardson return 0;
170099a2dd95SBruce Richardson }
170199a2dd95SBruce Richardson
170299a2dd95SBruce Richardson static int
handle_dev_xstats(const char * cmd __rte_unused,const char * params,struct rte_tel_data * d)170399a2dd95SBruce Richardson handle_dev_xstats(const char *cmd __rte_unused,
170499a2dd95SBruce Richardson const char *params,
170599a2dd95SBruce Richardson struct rte_tel_data *d)
170699a2dd95SBruce Richardson {
170799a2dd95SBruce Richardson int dev_id;
170899a2dd95SBruce Richardson enum rte_event_dev_xstats_mode mode;
170999a2dd95SBruce Richardson char *end_param;
171099a2dd95SBruce Richardson
171199a2dd95SBruce Richardson if (params == NULL || strlen(params) == 0 || !isdigit(*params))
171299a2dd95SBruce Richardson return -1;
171399a2dd95SBruce Richardson
171499a2dd95SBruce Richardson /* Get dev ID from parameter string */
171599a2dd95SBruce Richardson dev_id = strtoul(params, &end_param, 10);
171699a2dd95SBruce Richardson if (*end_param != '\0')
171799a2dd95SBruce Richardson RTE_EDEV_LOG_DEBUG(
171899a2dd95SBruce Richardson "Extra parameters passed to eventdev telemetry command, ignoring");
171999a2dd95SBruce Richardson
172099a2dd95SBruce Richardson RTE_EVENTDEV_VALID_DEVID_OR_ERR_RET(dev_id, -EINVAL);
172199a2dd95SBruce Richardson
172299a2dd95SBruce Richardson mode = RTE_EVENT_DEV_XSTATS_DEVICE;
172399a2dd95SBruce Richardson return eventdev_build_telemetry_data(dev_id, mode, 0, d);
172499a2dd95SBruce Richardson }
172599a2dd95SBruce Richardson
172699a2dd95SBruce Richardson static int
handle_port_xstats(const char * cmd __rte_unused,const char * params,struct rte_tel_data * d)172799a2dd95SBruce Richardson handle_port_xstats(const char *cmd __rte_unused,
172899a2dd95SBruce Richardson const char *params,
172999a2dd95SBruce Richardson struct rte_tel_data *d)
173099a2dd95SBruce Richardson {
173199a2dd95SBruce Richardson int dev_id;
173299a2dd95SBruce Richardson int port_queue_id = 0;
173399a2dd95SBruce Richardson enum rte_event_dev_xstats_mode mode;
173499a2dd95SBruce Richardson char *end_param;
173599a2dd95SBruce Richardson const char *p_param;
173699a2dd95SBruce Richardson
173799a2dd95SBruce Richardson if (params == NULL || strlen(params) == 0 || !isdigit(*params))
173899a2dd95SBruce Richardson return -1;
173999a2dd95SBruce Richardson
174099a2dd95SBruce Richardson /* Get dev ID from parameter string */
174199a2dd95SBruce Richardson dev_id = strtoul(params, &end_param, 10);
174299a2dd95SBruce Richardson RTE_EVENTDEV_VALID_DEVID_OR_ERR_RET(dev_id, -EINVAL);
174399a2dd95SBruce Richardson
174499a2dd95SBruce Richardson p_param = strtok(end_param, ",");
174599a2dd95SBruce Richardson mode = RTE_EVENT_DEV_XSTATS_PORT;
174699a2dd95SBruce Richardson
174799a2dd95SBruce Richardson if (p_param == NULL || strlen(p_param) == 0 || !isdigit(*p_param))
174899a2dd95SBruce Richardson return -1;
174999a2dd95SBruce Richardson
175099a2dd95SBruce Richardson port_queue_id = strtoul(p_param, &end_param, 10);
175199a2dd95SBruce Richardson
175299a2dd95SBruce Richardson p_param = strtok(NULL, "\0");
175399a2dd95SBruce Richardson if (p_param != NULL)
175499a2dd95SBruce Richardson RTE_EDEV_LOG_DEBUG(
175599a2dd95SBruce Richardson "Extra parameters passed to eventdev telemetry command, ignoring");
175699a2dd95SBruce Richardson
175799a2dd95SBruce Richardson return eventdev_build_telemetry_data(dev_id, mode, port_queue_id, d);
175899a2dd95SBruce Richardson }
175999a2dd95SBruce Richardson
176099a2dd95SBruce Richardson static int
handle_queue_xstats(const char * cmd __rte_unused,const char * params,struct rte_tel_data * d)176199a2dd95SBruce Richardson handle_queue_xstats(const char *cmd __rte_unused,
176299a2dd95SBruce Richardson const char *params,
176399a2dd95SBruce Richardson struct rte_tel_data *d)
176499a2dd95SBruce Richardson {
176599a2dd95SBruce Richardson int dev_id;
176699a2dd95SBruce Richardson int port_queue_id = 0;
176799a2dd95SBruce Richardson enum rte_event_dev_xstats_mode mode;
176899a2dd95SBruce Richardson char *end_param;
176999a2dd95SBruce Richardson const char *p_param;
177099a2dd95SBruce Richardson
177199a2dd95SBruce Richardson if (params == NULL || strlen(params) == 0 || !isdigit(*params))
177299a2dd95SBruce Richardson return -1;
177399a2dd95SBruce Richardson
177499a2dd95SBruce Richardson /* Get dev ID from parameter string */
177599a2dd95SBruce Richardson dev_id = strtoul(params, &end_param, 10);
177699a2dd95SBruce Richardson RTE_EVENTDEV_VALID_DEVID_OR_ERR_RET(dev_id, -EINVAL);
177799a2dd95SBruce Richardson
177899a2dd95SBruce Richardson p_param = strtok(end_param, ",");
177999a2dd95SBruce Richardson mode = RTE_EVENT_DEV_XSTATS_QUEUE;
178099a2dd95SBruce Richardson
178199a2dd95SBruce Richardson if (p_param == NULL || strlen(p_param) == 0 || !isdigit(*p_param))
178299a2dd95SBruce Richardson return -1;
178399a2dd95SBruce Richardson
178499a2dd95SBruce Richardson port_queue_id = strtoul(p_param, &end_param, 10);
178599a2dd95SBruce Richardson
178699a2dd95SBruce Richardson p_param = strtok(NULL, "\0");
178799a2dd95SBruce Richardson if (p_param != NULL)
178899a2dd95SBruce Richardson RTE_EDEV_LOG_DEBUG(
178999a2dd95SBruce Richardson "Extra parameters passed to eventdev telemetry command, ignoring");
179099a2dd95SBruce Richardson
179199a2dd95SBruce Richardson return eventdev_build_telemetry_data(dev_id, mode, port_queue_id, d);
179299a2dd95SBruce Richardson }
179399a2dd95SBruce Richardson
RTE_INIT(eventdev_init_telemetry)179499a2dd95SBruce Richardson RTE_INIT(eventdev_init_telemetry)
179599a2dd95SBruce Richardson {
179699a2dd95SBruce Richardson rte_telemetry_register_cmd("/eventdev/dev_list", handle_dev_list,
179799a2dd95SBruce Richardson "Returns list of available eventdevs. Takes no parameters");
179899a2dd95SBruce Richardson rte_telemetry_register_cmd("/eventdev/port_list", handle_port_list,
179999a2dd95SBruce Richardson "Returns list of available ports. Parameter: DevID");
180099a2dd95SBruce Richardson rte_telemetry_register_cmd("/eventdev/queue_list", handle_queue_list,
180199a2dd95SBruce Richardson "Returns list of available queues. Parameter: DevID");
180299a2dd95SBruce Richardson
180399a2dd95SBruce Richardson rte_telemetry_register_cmd("/eventdev/dev_xstats", handle_dev_xstats,
180499a2dd95SBruce Richardson "Returns stats for an eventdev. Parameter: DevID");
180599a2dd95SBruce Richardson rte_telemetry_register_cmd("/eventdev/port_xstats", handle_port_xstats,
180699a2dd95SBruce Richardson "Returns stats for an eventdev port. Params: DevID,PortID");
180799a2dd95SBruce Richardson rte_telemetry_register_cmd("/eventdev/queue_xstats",
180899a2dd95SBruce Richardson handle_queue_xstats,
180999a2dd95SBruce Richardson "Returns stats for an eventdev queue. Params: DevID,QueueID");
181099a2dd95SBruce Richardson rte_telemetry_register_cmd("/eventdev/queue_links", handle_queue_links,
181199a2dd95SBruce Richardson "Returns links for an eventdev port. Params: DevID,QueueID");
181299a2dd95SBruce Richardson }
1813