199a2dd95SBruce Richardson /* SPDX-License-Identifier: BSD-3-Clause
299a2dd95SBruce Richardson * Copyright(c) 2016 Cavium, Inc
399a2dd95SBruce Richardson */
499a2dd95SBruce Richardson
508966fe7STyler Retzlaff #include <stdalign.h>
699a2dd95SBruce Richardson #include <ctype.h>
799a2dd95SBruce Richardson #include <stdio.h>
899a2dd95SBruce Richardson #include <stdlib.h>
999a2dd95SBruce Richardson #include <string.h>
1099a2dd95SBruce Richardson #include <errno.h>
1199a2dd95SBruce Richardson #include <stdint.h>
1299a2dd95SBruce Richardson #include <inttypes.h>
1399a2dd95SBruce Richardson
1499a2dd95SBruce Richardson #include <rte_string_fns.h>
1599a2dd95SBruce Richardson #include <rte_log.h>
161acb7f54SDavid Marchand #include <dev_driver.h>
1799a2dd95SBruce Richardson #include <rte_memzone.h>
1899a2dd95SBruce Richardson #include <rte_eal.h>
1999a2dd95SBruce Richardson #include <rte_common.h>
2099a2dd95SBruce Richardson #include <rte_malloc.h>
2199a2dd95SBruce Richardson #include <rte_errno.h>
22f9bdee26SKonstantin Ananyev #include <ethdev_driver.h>
2399a2dd95SBruce Richardson #include <rte_cryptodev.h>
24d3aa3cd5SAmit Prakash Shukla #include <rte_dmadev.h>
25af668035SAkhil Goyal #include <cryptodev_pmd.h>
2699a2dd95SBruce Richardson #include <rte_telemetry.h>
2799a2dd95SBruce Richardson
2899a2dd95SBruce Richardson #include "rte_eventdev.h"
2999a2dd95SBruce Richardson #include "eventdev_pmd.h"
30f26f2ca6SPavan Nikhilesh #include "eventdev_trace.h"
3199a2dd95SBruce Richardson
32e792ec08SStephen Hemminger RTE_LOG_REGISTER_DEFAULT(rte_event_logtype, INFO);
33e792ec08SStephen Hemminger
3499a2dd95SBruce Richardson static struct rte_eventdev rte_event_devices[RTE_EVENT_MAX_DEVS];
3599a2dd95SBruce Richardson
3699a2dd95SBruce Richardson struct rte_eventdev *rte_eventdevs = rte_event_devices;
3799a2dd95SBruce Richardson
3899a2dd95SBruce Richardson static struct rte_eventdev_global eventdev_globals = {
3999a2dd95SBruce Richardson .nb_devs = 0
4099a2dd95SBruce Richardson };
4199a2dd95SBruce Richardson
42d35e6132SPavan Nikhilesh /* Public fastpath APIs. */
43d35e6132SPavan Nikhilesh struct rte_event_fp_ops rte_event_fp_ops[RTE_EVENT_MAX_DEVS];
44d35e6132SPavan Nikhilesh
4599a2dd95SBruce Richardson /* Event dev north bound API implementation */
4699a2dd95SBruce Richardson
4799a2dd95SBruce Richardson uint8_t
rte_event_dev_count(void)4899a2dd95SBruce Richardson rte_event_dev_count(void)
4999a2dd95SBruce Richardson {
5099a2dd95SBruce Richardson return eventdev_globals.nb_devs;
5199a2dd95SBruce Richardson }
5299a2dd95SBruce Richardson
5399a2dd95SBruce Richardson int
rte_event_dev_get_dev_id(const char * name)5499a2dd95SBruce Richardson rte_event_dev_get_dev_id(const char *name)
5599a2dd95SBruce Richardson {
5699a2dd95SBruce Richardson int i;
5799a2dd95SBruce Richardson uint8_t cmp;
5899a2dd95SBruce Richardson
5999a2dd95SBruce Richardson if (!name)
6099a2dd95SBruce Richardson return -EINVAL;
6199a2dd95SBruce Richardson
6299a2dd95SBruce Richardson for (i = 0; i < eventdev_globals.nb_devs; i++) {
6399a2dd95SBruce Richardson cmp = (strncmp(rte_event_devices[i].data->name, name,
6499a2dd95SBruce Richardson RTE_EVENTDEV_NAME_MAX_LEN) == 0) ||
6599a2dd95SBruce Richardson (rte_event_devices[i].dev ? (strncmp(
6699a2dd95SBruce Richardson rte_event_devices[i].dev->driver->name, name,
6799a2dd95SBruce Richardson RTE_EVENTDEV_NAME_MAX_LEN) == 0) : 0);
6899a2dd95SBruce Richardson if (cmp && (rte_event_devices[i].attached ==
697f2d9df6SAmit Prakash Shukla RTE_EVENTDEV_ATTACHED)) {
707f2d9df6SAmit Prakash Shukla rte_eventdev_trace_get_dev_id(name, i);
7199a2dd95SBruce Richardson return i;
7299a2dd95SBruce Richardson }
737f2d9df6SAmit Prakash Shukla }
7499a2dd95SBruce Richardson return -ENODEV;
7599a2dd95SBruce Richardson }
7699a2dd95SBruce Richardson
7799a2dd95SBruce Richardson int
rte_event_dev_socket_id(uint8_t dev_id)7899a2dd95SBruce Richardson rte_event_dev_socket_id(uint8_t dev_id)
7999a2dd95SBruce Richardson {
8099a2dd95SBruce Richardson struct rte_eventdev *dev;
8199a2dd95SBruce Richardson
8299a2dd95SBruce Richardson RTE_EVENTDEV_VALID_DEVID_OR_ERR_RET(dev_id, -EINVAL);
8399a2dd95SBruce Richardson dev = &rte_eventdevs[dev_id];
8499a2dd95SBruce Richardson
857f2d9df6SAmit Prakash Shukla rte_eventdev_trace_socket_id(dev_id, dev, dev->data->socket_id);
867f2d9df6SAmit Prakash Shukla
8799a2dd95SBruce Richardson return dev->data->socket_id;
8899a2dd95SBruce Richardson }
8999a2dd95SBruce Richardson
9099a2dd95SBruce Richardson int
rte_event_dev_info_get(uint8_t dev_id,struct rte_event_dev_info * dev_info)9199a2dd95SBruce Richardson rte_event_dev_info_get(uint8_t dev_id, struct rte_event_dev_info *dev_info)
9299a2dd95SBruce Richardson {
9399a2dd95SBruce Richardson struct rte_eventdev *dev;
9499a2dd95SBruce Richardson
9599a2dd95SBruce Richardson RTE_EVENTDEV_VALID_DEVID_OR_ERR_RET(dev_id, -EINVAL);
9699a2dd95SBruce Richardson dev = &rte_eventdevs[dev_id];
9799a2dd95SBruce Richardson
9899a2dd95SBruce Richardson if (dev_info == NULL)
9999a2dd95SBruce Richardson return -EINVAL;
10099a2dd95SBruce Richardson
10199a2dd95SBruce Richardson memset(dev_info, 0, sizeof(struct rte_event_dev_info));
10299a2dd95SBruce Richardson
1038f1d23ecSDavid Marchand if (*dev->dev_ops->dev_infos_get == NULL)
1048f1d23ecSDavid Marchand return -ENOTSUP;
10599a2dd95SBruce Richardson (*dev->dev_ops->dev_infos_get)(dev, dev_info);
10699a2dd95SBruce Richardson
10799a2dd95SBruce Richardson dev_info->dequeue_timeout_ns = dev->data->dev_conf.dequeue_timeout_ns;
10899a2dd95SBruce Richardson
10999a2dd95SBruce Richardson dev_info->dev = dev->dev;
110cbbba8b8SBruce Richardson if (dev->dev != NULL && dev->dev->driver != NULL)
111cbbba8b8SBruce Richardson dev_info->driver_name = dev->dev->driver->name;
1127f2d9df6SAmit Prakash Shukla
1137f2d9df6SAmit Prakash Shukla rte_eventdev_trace_info_get(dev_id, dev_info, dev_info->dev);
1147f2d9df6SAmit Prakash Shukla
11599a2dd95SBruce Richardson return 0;
11699a2dd95SBruce Richardson }
11799a2dd95SBruce Richardson
11899a2dd95SBruce Richardson int
rte_event_eth_rx_adapter_caps_get(uint8_t dev_id,uint16_t eth_port_id,uint32_t * caps)11999a2dd95SBruce Richardson rte_event_eth_rx_adapter_caps_get(uint8_t dev_id, uint16_t eth_port_id,
12099a2dd95SBruce Richardson uint32_t *caps)
12199a2dd95SBruce Richardson {
12299a2dd95SBruce Richardson struct rte_eventdev *dev;
12399a2dd95SBruce Richardson
1247f2d9df6SAmit Prakash Shukla rte_eventdev_trace_eth_rx_adapter_caps_get(dev_id, eth_port_id);
1257f2d9df6SAmit Prakash Shukla
12699a2dd95SBruce Richardson RTE_EVENTDEV_VALID_DEVID_OR_ERR_RET(dev_id, -EINVAL);
12799a2dd95SBruce Richardson RTE_ETH_VALID_PORTID_OR_ERR_RET(eth_port_id, -EINVAL);
12899a2dd95SBruce Richardson
12999a2dd95SBruce Richardson dev = &rte_eventdevs[dev_id];
13099a2dd95SBruce Richardson
13199a2dd95SBruce Richardson if (caps == NULL)
13299a2dd95SBruce Richardson return -EINVAL;
13399a2dd95SBruce Richardson
13499a2dd95SBruce Richardson if (dev->dev_ops->eth_rx_adapter_caps_get == NULL)
13599a2dd95SBruce Richardson *caps = RTE_EVENT_ETH_RX_ADAPTER_SW_CAP;
13699a2dd95SBruce Richardson else
13799a2dd95SBruce Richardson *caps = 0;
13899a2dd95SBruce Richardson
13999a2dd95SBruce Richardson return dev->dev_ops->eth_rx_adapter_caps_get ?
14099a2dd95SBruce Richardson (*dev->dev_ops->eth_rx_adapter_caps_get)(dev,
14199a2dd95SBruce Richardson &rte_eth_devices[eth_port_id],
14299a2dd95SBruce Richardson caps)
14399a2dd95SBruce Richardson : 0;
14499a2dd95SBruce Richardson }
14599a2dd95SBruce Richardson
14699a2dd95SBruce Richardson int
rte_event_timer_adapter_caps_get(uint8_t dev_id,uint32_t * caps)14799a2dd95SBruce Richardson rte_event_timer_adapter_caps_get(uint8_t dev_id, uint32_t *caps)
14899a2dd95SBruce Richardson {
14999a2dd95SBruce Richardson struct rte_eventdev *dev;
15053548ad3SPavan Nikhilesh const struct event_timer_adapter_ops *ops;
15199a2dd95SBruce Richardson
1527f2d9df6SAmit Prakash Shukla rte_eventdev_trace_timer_adapter_caps_get(dev_id);
1537f2d9df6SAmit Prakash Shukla
15499a2dd95SBruce Richardson RTE_EVENTDEV_VALID_DEVID_OR_ERR_RET(dev_id, -EINVAL);
15599a2dd95SBruce Richardson
15699a2dd95SBruce Richardson dev = &rte_eventdevs[dev_id];
15799a2dd95SBruce Richardson
15899a2dd95SBruce Richardson if (caps == NULL)
15999a2dd95SBruce Richardson return -EINVAL;
1603d9d8adfSNaga Harish K S V
1613d9d8adfSNaga Harish K S V if (dev->dev_ops->timer_adapter_caps_get == NULL)
1623d9d8adfSNaga Harish K S V *caps = RTE_EVENT_TIMER_ADAPTER_SW_CAP;
1633d9d8adfSNaga Harish K S V else
16499a2dd95SBruce Richardson *caps = 0;
16599a2dd95SBruce Richardson
16699a2dd95SBruce Richardson return dev->dev_ops->timer_adapter_caps_get ?
16799a2dd95SBruce Richardson (*dev->dev_ops->timer_adapter_caps_get)(dev,
16899a2dd95SBruce Richardson 0,
16999a2dd95SBruce Richardson caps,
17099a2dd95SBruce Richardson &ops)
17199a2dd95SBruce Richardson : 0;
17299a2dd95SBruce Richardson }
17399a2dd95SBruce Richardson
17499a2dd95SBruce Richardson int
rte_event_crypto_adapter_caps_get(uint8_t dev_id,uint8_t cdev_id,uint32_t * caps)17599a2dd95SBruce Richardson rte_event_crypto_adapter_caps_get(uint8_t dev_id, uint8_t cdev_id,
17699a2dd95SBruce Richardson uint32_t *caps)
17799a2dd95SBruce Richardson {
17899a2dd95SBruce Richardson struct rte_eventdev *dev;
17999a2dd95SBruce Richardson struct rte_cryptodev *cdev;
18099a2dd95SBruce Richardson
18199a2dd95SBruce Richardson RTE_EVENTDEV_VALID_DEVID_OR_ERR_RET(dev_id, -EINVAL);
182e74abd48SAkhil Goyal if (!rte_cryptodev_is_valid_dev(cdev_id))
18399a2dd95SBruce Richardson return -EINVAL;
18499a2dd95SBruce Richardson
18599a2dd95SBruce Richardson dev = &rte_eventdevs[dev_id];
18699a2dd95SBruce Richardson cdev = rte_cryptodev_pmd_get_dev(cdev_id);
18799a2dd95SBruce Richardson
1887f2d9df6SAmit Prakash Shukla rte_eventdev_trace_crypto_adapter_caps_get(dev_id, dev, cdev_id, cdev);
1897f2d9df6SAmit Prakash Shukla
19099a2dd95SBruce Richardson if (caps == NULL)
19199a2dd95SBruce Richardson return -EINVAL;
1926b946657SGanapati Kundapura
1936b946657SGanapati Kundapura if (dev->dev_ops->crypto_adapter_caps_get == NULL)
1946b946657SGanapati Kundapura *caps = RTE_EVENT_CRYPTO_ADAPTER_SW_CAP;
1956b946657SGanapati Kundapura else
19699a2dd95SBruce Richardson *caps = 0;
19799a2dd95SBruce Richardson
19899a2dd95SBruce Richardson return dev->dev_ops->crypto_adapter_caps_get ?
19999a2dd95SBruce Richardson (*dev->dev_ops->crypto_adapter_caps_get)
2006b946657SGanapati Kundapura (dev, cdev, caps) : 0;
20199a2dd95SBruce Richardson }
20299a2dd95SBruce Richardson
20399a2dd95SBruce Richardson int
rte_event_eth_tx_adapter_caps_get(uint8_t dev_id,uint16_t eth_port_id,uint32_t * caps)20499a2dd95SBruce Richardson rte_event_eth_tx_adapter_caps_get(uint8_t dev_id, uint16_t eth_port_id,
20599a2dd95SBruce Richardson uint32_t *caps)
20699a2dd95SBruce Richardson {
20799a2dd95SBruce Richardson struct rte_eventdev *dev;
20899a2dd95SBruce Richardson struct rte_eth_dev *eth_dev;
20999a2dd95SBruce Richardson
21099a2dd95SBruce Richardson RTE_EVENTDEV_VALID_DEVID_OR_ERR_RET(dev_id, -EINVAL);
21199a2dd95SBruce Richardson RTE_ETH_VALID_PORTID_OR_ERR_RET(eth_port_id, -EINVAL);
21299a2dd95SBruce Richardson
21399a2dd95SBruce Richardson dev = &rte_eventdevs[dev_id];
21499a2dd95SBruce Richardson eth_dev = &rte_eth_devices[eth_port_id];
21599a2dd95SBruce Richardson
2167f2d9df6SAmit Prakash Shukla rte_eventdev_trace_eth_tx_adapter_caps_get(dev_id, dev, eth_port_id, eth_dev);
2177f2d9df6SAmit Prakash Shukla
21899a2dd95SBruce Richardson if (caps == NULL)
21999a2dd95SBruce Richardson return -EINVAL;
22099a2dd95SBruce Richardson
22199a2dd95SBruce Richardson if (dev->dev_ops->eth_tx_adapter_caps_get == NULL)
22299a2dd95SBruce Richardson *caps = RTE_EVENT_ETH_TX_ADAPTER_CAP_EVENT_VECTOR;
22399a2dd95SBruce Richardson else
22499a2dd95SBruce Richardson *caps = 0;
22599a2dd95SBruce Richardson
22699a2dd95SBruce Richardson return dev->dev_ops->eth_tx_adapter_caps_get ?
22799a2dd95SBruce Richardson (*dev->dev_ops->eth_tx_adapter_caps_get)(dev,
22899a2dd95SBruce Richardson eth_dev,
22999a2dd95SBruce Richardson caps)
23099a2dd95SBruce Richardson : 0;
23199a2dd95SBruce Richardson }
23299a2dd95SBruce Richardson
233d3aa3cd5SAmit Prakash Shukla int
rte_event_dma_adapter_caps_get(uint8_t dev_id,uint8_t dma_dev_id,uint32_t * caps)234d3aa3cd5SAmit Prakash Shukla rte_event_dma_adapter_caps_get(uint8_t dev_id, uint8_t dma_dev_id, uint32_t *caps)
235d3aa3cd5SAmit Prakash Shukla {
236d3aa3cd5SAmit Prakash Shukla struct rte_eventdev *dev;
237d3aa3cd5SAmit Prakash Shukla
238d3aa3cd5SAmit Prakash Shukla RTE_EVENTDEV_VALID_DEVID_OR_ERR_RET(dev_id, -EINVAL);
239d3aa3cd5SAmit Prakash Shukla if (!rte_dma_is_valid(dma_dev_id))
240d3aa3cd5SAmit Prakash Shukla return -EINVAL;
241d3aa3cd5SAmit Prakash Shukla
242d3aa3cd5SAmit Prakash Shukla dev = &rte_eventdevs[dev_id];
243d3aa3cd5SAmit Prakash Shukla
244d3aa3cd5SAmit Prakash Shukla if (caps == NULL)
245d3aa3cd5SAmit Prakash Shukla return -EINVAL;
246d3aa3cd5SAmit Prakash Shukla
247d3aa3cd5SAmit Prakash Shukla *caps = 0;
248d3aa3cd5SAmit Prakash Shukla
249d3aa3cd5SAmit Prakash Shukla if (dev->dev_ops->dma_adapter_caps_get)
250d3aa3cd5SAmit Prakash Shukla return (*dev->dev_ops->dma_adapter_caps_get)(dev, dma_dev_id, caps);
251d3aa3cd5SAmit Prakash Shukla
252d3aa3cd5SAmit Prakash Shukla return 0;
253d3aa3cd5SAmit Prakash Shukla }
254d3aa3cd5SAmit Prakash Shukla
25599a2dd95SBruce Richardson static inline int
event_dev_queue_config(struct rte_eventdev * dev,uint8_t nb_queues)2569c67fcbfSPavan Nikhilesh event_dev_queue_config(struct rte_eventdev *dev, uint8_t nb_queues)
25799a2dd95SBruce Richardson {
25899a2dd95SBruce Richardson uint8_t old_nb_queues = dev->data->nb_queues;
25999a2dd95SBruce Richardson struct rte_event_queue_conf *queues_cfg;
26099a2dd95SBruce Richardson unsigned int i;
26199a2dd95SBruce Richardson
26299a2dd95SBruce Richardson RTE_EDEV_LOG_DEBUG("Setup %d queues on device %u", nb_queues,
26399a2dd95SBruce Richardson dev->data->dev_id);
26499a2dd95SBruce Richardson
2659c67fcbfSPavan Nikhilesh if (nb_queues != 0) {
2669c67fcbfSPavan Nikhilesh queues_cfg = dev->data->queues_cfg;
2678f1d23ecSDavid Marchand if (*dev->dev_ops->queue_release == NULL)
2688f1d23ecSDavid Marchand return -ENOTSUP;
26999a2dd95SBruce Richardson
27099a2dd95SBruce Richardson for (i = nb_queues; i < old_nb_queues; i++)
27199a2dd95SBruce Richardson (*dev->dev_ops->queue_release)(dev, i);
27299a2dd95SBruce Richardson
27399a2dd95SBruce Richardson
27499a2dd95SBruce Richardson if (nb_queues > old_nb_queues) {
27599a2dd95SBruce Richardson uint8_t new_qs = nb_queues - old_nb_queues;
27699a2dd95SBruce Richardson
27799a2dd95SBruce Richardson memset(queues_cfg + old_nb_queues, 0,
27899a2dd95SBruce Richardson sizeof(queues_cfg[0]) * new_qs);
27999a2dd95SBruce Richardson }
2809c67fcbfSPavan Nikhilesh } else {
2818f1d23ecSDavid Marchand if (*dev->dev_ops->queue_release == NULL)
2828f1d23ecSDavid Marchand return -ENOTSUP;
28399a2dd95SBruce Richardson
28499a2dd95SBruce Richardson for (i = nb_queues; i < old_nb_queues; i++)
28599a2dd95SBruce Richardson (*dev->dev_ops->queue_release)(dev, i);
28699a2dd95SBruce Richardson }
28799a2dd95SBruce Richardson
28899a2dd95SBruce Richardson dev->data->nb_queues = nb_queues;
28999a2dd95SBruce Richardson return 0;
29099a2dd95SBruce Richardson }
29199a2dd95SBruce Richardson
29299a2dd95SBruce Richardson #define EVENT_QUEUE_SERVICE_PRIORITY_INVALID (0xdead)
29399a2dd95SBruce Richardson
29499a2dd95SBruce Richardson static inline int
event_dev_port_config(struct rte_eventdev * dev,uint8_t nb_ports)2959c67fcbfSPavan Nikhilesh event_dev_port_config(struct rte_eventdev *dev, uint8_t nb_ports)
29699a2dd95SBruce Richardson {
29799a2dd95SBruce Richardson uint8_t old_nb_ports = dev->data->nb_ports;
29899a2dd95SBruce Richardson void **ports;
29999a2dd95SBruce Richardson uint16_t *links_map;
30099a2dd95SBruce Richardson struct rte_event_port_conf *ports_cfg;
301d007a7f3SPavan Nikhilesh unsigned int i, j;
30299a2dd95SBruce Richardson
30399a2dd95SBruce Richardson RTE_EDEV_LOG_DEBUG("Setup %d ports on device %u", nb_ports,
30499a2dd95SBruce Richardson dev->data->dev_id);
30599a2dd95SBruce Richardson
3069c67fcbfSPavan Nikhilesh if (nb_ports != 0) { /* re-config */
3078f1d23ecSDavid Marchand if (*dev->dev_ops->port_release == NULL)
3088f1d23ecSDavid Marchand return -ENOTSUP;
30999a2dd95SBruce Richardson
31099a2dd95SBruce Richardson ports = dev->data->ports;
31199a2dd95SBruce Richardson ports_cfg = dev->data->ports_cfg;
31299a2dd95SBruce Richardson
31399a2dd95SBruce Richardson for (i = nb_ports; i < old_nb_ports; i++)
31499a2dd95SBruce Richardson (*dev->dev_ops->port_release)(ports[i]);
31599a2dd95SBruce Richardson
31699a2dd95SBruce Richardson if (nb_ports > old_nb_ports) {
31799a2dd95SBruce Richardson uint8_t new_ps = nb_ports - old_nb_ports;
31899a2dd95SBruce Richardson unsigned int old_links_map_end =
31999a2dd95SBruce Richardson old_nb_ports * RTE_EVENT_MAX_QUEUES_PER_DEV;
32099a2dd95SBruce Richardson unsigned int links_map_end =
32199a2dd95SBruce Richardson nb_ports * RTE_EVENT_MAX_QUEUES_PER_DEV;
32299a2dd95SBruce Richardson
32399a2dd95SBruce Richardson memset(ports + old_nb_ports, 0,
32499a2dd95SBruce Richardson sizeof(ports[0]) * new_ps);
32599a2dd95SBruce Richardson memset(ports_cfg + old_nb_ports, 0,
32699a2dd95SBruce Richardson sizeof(ports_cfg[0]) * new_ps);
327d007a7f3SPavan Nikhilesh for (i = 0; i < RTE_EVENT_MAX_PROFILES_PER_PORT; i++) {
328d007a7f3SPavan Nikhilesh links_map = dev->data->links_map[i];
329d007a7f3SPavan Nikhilesh for (j = old_links_map_end; j < links_map_end; j++)
330d007a7f3SPavan Nikhilesh links_map[j] = EVENT_QUEUE_SERVICE_PRIORITY_INVALID;
331d007a7f3SPavan Nikhilesh }
33299a2dd95SBruce Richardson }
3339c67fcbfSPavan Nikhilesh } else {
3348f1d23ecSDavid Marchand if (*dev->dev_ops->port_release == NULL)
3358f1d23ecSDavid Marchand return -ENOTSUP;
33699a2dd95SBruce Richardson
33799a2dd95SBruce Richardson ports = dev->data->ports;
3389c67fcbfSPavan Nikhilesh for (i = nb_ports; i < old_nb_ports; i++) {
33999a2dd95SBruce Richardson (*dev->dev_ops->port_release)(ports[i]);
3409c67fcbfSPavan Nikhilesh ports[i] = NULL;
3419c67fcbfSPavan Nikhilesh }
34299a2dd95SBruce Richardson }
34399a2dd95SBruce Richardson
34499a2dd95SBruce Richardson dev->data->nb_ports = nb_ports;
34599a2dd95SBruce Richardson return 0;
34699a2dd95SBruce Richardson }
34799a2dd95SBruce Richardson
34899a2dd95SBruce Richardson int
rte_event_dev_configure(uint8_t dev_id,const struct rte_event_dev_config * dev_conf)34999a2dd95SBruce Richardson rte_event_dev_configure(uint8_t dev_id,
35099a2dd95SBruce Richardson const struct rte_event_dev_config *dev_conf)
35199a2dd95SBruce Richardson {
35299a2dd95SBruce Richardson struct rte_event_dev_info info;
353d35e6132SPavan Nikhilesh struct rte_eventdev *dev;
35499a2dd95SBruce Richardson int diag;
35599a2dd95SBruce Richardson
35699a2dd95SBruce Richardson RTE_EVENTDEV_VALID_DEVID_OR_ERR_RET(dev_id, -EINVAL);
35799a2dd95SBruce Richardson dev = &rte_eventdevs[dev_id];
35899a2dd95SBruce Richardson
3598f1d23ecSDavid Marchand if (*dev->dev_ops->dev_infos_get == NULL)
3608f1d23ecSDavid Marchand return -ENOTSUP;
3618f1d23ecSDavid Marchand if (*dev->dev_ops->dev_configure == NULL)
3628f1d23ecSDavid Marchand return -ENOTSUP;
36399a2dd95SBruce Richardson
36499a2dd95SBruce Richardson if (dev->data->dev_started) {
36599a2dd95SBruce Richardson RTE_EDEV_LOG_ERR(
36699a2dd95SBruce Richardson "device %d must be stopped to allow configuration", dev_id);
36799a2dd95SBruce Richardson return -EBUSY;
36899a2dd95SBruce Richardson }
36999a2dd95SBruce Richardson
37099a2dd95SBruce Richardson if (dev_conf == NULL)
37199a2dd95SBruce Richardson return -EINVAL;
37299a2dd95SBruce Richardson
37399a2dd95SBruce Richardson (*dev->dev_ops->dev_infos_get)(dev, &info);
37499a2dd95SBruce Richardson
37599a2dd95SBruce Richardson /* Check dequeue_timeout_ns value is in limit */
37699a2dd95SBruce Richardson if (!(dev_conf->event_dev_cfg & RTE_EVENT_DEV_CFG_PER_DEQUEUE_TIMEOUT)) {
37799a2dd95SBruce Richardson if (dev_conf->dequeue_timeout_ns &&
37899a2dd95SBruce Richardson (dev_conf->dequeue_timeout_ns < info.min_dequeue_timeout_ns
37999a2dd95SBruce Richardson || dev_conf->dequeue_timeout_ns >
38099a2dd95SBruce Richardson info.max_dequeue_timeout_ns)) {
38199a2dd95SBruce Richardson RTE_EDEV_LOG_ERR("dev%d invalid dequeue_timeout_ns=%d"
38299a2dd95SBruce Richardson " min_dequeue_timeout_ns=%d max_dequeue_timeout_ns=%d",
38399a2dd95SBruce Richardson dev_id, dev_conf->dequeue_timeout_ns,
38499a2dd95SBruce Richardson info.min_dequeue_timeout_ns,
38599a2dd95SBruce Richardson info.max_dequeue_timeout_ns);
38699a2dd95SBruce Richardson return -EINVAL;
38799a2dd95SBruce Richardson }
38899a2dd95SBruce Richardson }
38999a2dd95SBruce Richardson
39099a2dd95SBruce Richardson /* Check nb_events_limit is in limit */
39199a2dd95SBruce Richardson if (dev_conf->nb_events_limit > info.max_num_events) {
39299a2dd95SBruce Richardson RTE_EDEV_LOG_ERR("dev%d nb_events_limit=%d > max_num_events=%d",
39399a2dd95SBruce Richardson dev_id, dev_conf->nb_events_limit, info.max_num_events);
39499a2dd95SBruce Richardson return -EINVAL;
39599a2dd95SBruce Richardson }
39699a2dd95SBruce Richardson
39799a2dd95SBruce Richardson /* Check nb_event_queues is in limit */
39899a2dd95SBruce Richardson if (!dev_conf->nb_event_queues) {
39999a2dd95SBruce Richardson RTE_EDEV_LOG_ERR("dev%d nb_event_queues cannot be zero",
40099a2dd95SBruce Richardson dev_id);
40199a2dd95SBruce Richardson return -EINVAL;
40299a2dd95SBruce Richardson }
40399a2dd95SBruce Richardson if (dev_conf->nb_event_queues > info.max_event_queues +
40499a2dd95SBruce Richardson info.max_single_link_event_port_queue_pairs) {
40599a2dd95SBruce Richardson RTE_EDEV_LOG_ERR("%d nb_event_queues=%d > max_event_queues=%d + max_single_link_event_port_queue_pairs=%d",
40699a2dd95SBruce Richardson dev_id, dev_conf->nb_event_queues,
40799a2dd95SBruce Richardson info.max_event_queues,
40899a2dd95SBruce Richardson info.max_single_link_event_port_queue_pairs);
40999a2dd95SBruce Richardson return -EINVAL;
41099a2dd95SBruce Richardson }
41199a2dd95SBruce Richardson if (dev_conf->nb_event_queues -
41299a2dd95SBruce Richardson dev_conf->nb_single_link_event_port_queues >
41399a2dd95SBruce Richardson info.max_event_queues) {
41499a2dd95SBruce Richardson RTE_EDEV_LOG_ERR("id%d nb_event_queues=%d - nb_single_link_event_port_queues=%d > max_event_queues=%d",
41599a2dd95SBruce Richardson dev_id, dev_conf->nb_event_queues,
41699a2dd95SBruce Richardson dev_conf->nb_single_link_event_port_queues,
41799a2dd95SBruce Richardson info.max_event_queues);
41899a2dd95SBruce Richardson return -EINVAL;
41999a2dd95SBruce Richardson }
42099a2dd95SBruce Richardson if (dev_conf->nb_single_link_event_port_queues >
42199a2dd95SBruce Richardson dev_conf->nb_event_queues) {
42299a2dd95SBruce Richardson RTE_EDEV_LOG_ERR("dev%d nb_single_link_event_port_queues=%d > nb_event_queues=%d",
42399a2dd95SBruce Richardson dev_id,
42499a2dd95SBruce Richardson dev_conf->nb_single_link_event_port_queues,
42599a2dd95SBruce Richardson dev_conf->nb_event_queues);
42699a2dd95SBruce Richardson return -EINVAL;
42799a2dd95SBruce Richardson }
42899a2dd95SBruce Richardson
42999a2dd95SBruce Richardson /* Check nb_event_ports is in limit */
43099a2dd95SBruce Richardson if (!dev_conf->nb_event_ports) {
43199a2dd95SBruce Richardson RTE_EDEV_LOG_ERR("dev%d nb_event_ports cannot be zero", dev_id);
43299a2dd95SBruce Richardson return -EINVAL;
43399a2dd95SBruce Richardson }
43499a2dd95SBruce Richardson if (dev_conf->nb_event_ports > info.max_event_ports +
43599a2dd95SBruce Richardson info.max_single_link_event_port_queue_pairs) {
43699a2dd95SBruce Richardson RTE_EDEV_LOG_ERR("id%d nb_event_ports=%d > max_event_ports=%d + max_single_link_event_port_queue_pairs=%d",
43799a2dd95SBruce Richardson dev_id, dev_conf->nb_event_ports,
43899a2dd95SBruce Richardson info.max_event_ports,
43999a2dd95SBruce Richardson info.max_single_link_event_port_queue_pairs);
44099a2dd95SBruce Richardson return -EINVAL;
44199a2dd95SBruce Richardson }
44299a2dd95SBruce Richardson if (dev_conf->nb_event_ports -
44399a2dd95SBruce Richardson dev_conf->nb_single_link_event_port_queues
44499a2dd95SBruce Richardson > info.max_event_ports) {
44599a2dd95SBruce Richardson RTE_EDEV_LOG_ERR("id%d nb_event_ports=%d - nb_single_link_event_port_queues=%d > max_event_ports=%d",
44699a2dd95SBruce Richardson dev_id, dev_conf->nb_event_ports,
44799a2dd95SBruce Richardson dev_conf->nb_single_link_event_port_queues,
44899a2dd95SBruce Richardson info.max_event_ports);
44999a2dd95SBruce Richardson return -EINVAL;
45099a2dd95SBruce Richardson }
45199a2dd95SBruce Richardson
45299a2dd95SBruce Richardson if (dev_conf->nb_single_link_event_port_queues >
45399a2dd95SBruce Richardson dev_conf->nb_event_ports) {
45499a2dd95SBruce Richardson RTE_EDEV_LOG_ERR(
45599a2dd95SBruce Richardson "dev%d nb_single_link_event_port_queues=%d > nb_event_ports=%d",
45699a2dd95SBruce Richardson dev_id,
45799a2dd95SBruce Richardson dev_conf->nb_single_link_event_port_queues,
45899a2dd95SBruce Richardson dev_conf->nb_event_ports);
45999a2dd95SBruce Richardson return -EINVAL;
46099a2dd95SBruce Richardson }
46199a2dd95SBruce Richardson
46299a2dd95SBruce Richardson /* Check nb_event_queue_flows is in limit */
46399a2dd95SBruce Richardson if (!dev_conf->nb_event_queue_flows) {
46499a2dd95SBruce Richardson RTE_EDEV_LOG_ERR("dev%d nb_flows cannot be zero", dev_id);
46599a2dd95SBruce Richardson return -EINVAL;
46699a2dd95SBruce Richardson }
46799a2dd95SBruce Richardson if (dev_conf->nb_event_queue_flows > info.max_event_queue_flows) {
46899a2dd95SBruce Richardson RTE_EDEV_LOG_ERR("dev%d nb_flows=%x > max_flows=%x",
46999a2dd95SBruce Richardson dev_id, dev_conf->nb_event_queue_flows,
47099a2dd95SBruce Richardson info.max_event_queue_flows);
47199a2dd95SBruce Richardson return -EINVAL;
47299a2dd95SBruce Richardson }
47399a2dd95SBruce Richardson
47499a2dd95SBruce Richardson /* Check nb_event_port_dequeue_depth is in limit */
47599a2dd95SBruce Richardson if (!dev_conf->nb_event_port_dequeue_depth) {
47699a2dd95SBruce Richardson RTE_EDEV_LOG_ERR("dev%d nb_dequeue_depth cannot be zero",
47799a2dd95SBruce Richardson dev_id);
47899a2dd95SBruce Richardson return -EINVAL;
47999a2dd95SBruce Richardson }
48099a2dd95SBruce Richardson if ((info.event_dev_cap & RTE_EVENT_DEV_CAP_BURST_MODE) &&
48199a2dd95SBruce Richardson (dev_conf->nb_event_port_dequeue_depth >
48299a2dd95SBruce Richardson info.max_event_port_dequeue_depth)) {
48399a2dd95SBruce Richardson RTE_EDEV_LOG_ERR("dev%d nb_dq_depth=%d > max_dq_depth=%d",
48499a2dd95SBruce Richardson dev_id, dev_conf->nb_event_port_dequeue_depth,
48599a2dd95SBruce Richardson info.max_event_port_dequeue_depth);
48699a2dd95SBruce Richardson return -EINVAL;
48799a2dd95SBruce Richardson }
48899a2dd95SBruce Richardson
48999a2dd95SBruce Richardson /* Check nb_event_port_enqueue_depth is in limit */
49099a2dd95SBruce Richardson if (!dev_conf->nb_event_port_enqueue_depth) {
49199a2dd95SBruce Richardson RTE_EDEV_LOG_ERR("dev%d nb_enqueue_depth cannot be zero",
49299a2dd95SBruce Richardson dev_id);
49399a2dd95SBruce Richardson return -EINVAL;
49499a2dd95SBruce Richardson }
49599a2dd95SBruce Richardson if ((info.event_dev_cap & RTE_EVENT_DEV_CAP_BURST_MODE) &&
49699a2dd95SBruce Richardson (dev_conf->nb_event_port_enqueue_depth >
49799a2dd95SBruce Richardson info.max_event_port_enqueue_depth)) {
49899a2dd95SBruce Richardson RTE_EDEV_LOG_ERR("dev%d nb_enq_depth=%d > max_enq_depth=%d",
49999a2dd95SBruce Richardson dev_id, dev_conf->nb_event_port_enqueue_depth,
50099a2dd95SBruce Richardson info.max_event_port_enqueue_depth);
50199a2dd95SBruce Richardson return -EINVAL;
50299a2dd95SBruce Richardson }
50399a2dd95SBruce Richardson
50499a2dd95SBruce Richardson /* Copy the dev_conf parameter into the dev structure */
50599a2dd95SBruce Richardson memcpy(&dev->data->dev_conf, dev_conf, sizeof(dev->data->dev_conf));
50699a2dd95SBruce Richardson
50799a2dd95SBruce Richardson /* Setup new number of queues and reconfigure device. */
5089c67fcbfSPavan Nikhilesh diag = event_dev_queue_config(dev, dev_conf->nb_event_queues);
50999a2dd95SBruce Richardson if (diag != 0) {
5109c67fcbfSPavan Nikhilesh RTE_EDEV_LOG_ERR("dev%d event_dev_queue_config = %d", dev_id,
5119c67fcbfSPavan Nikhilesh diag);
51299a2dd95SBruce Richardson return diag;
51399a2dd95SBruce Richardson }
51499a2dd95SBruce Richardson
51599a2dd95SBruce Richardson /* Setup new number of ports and reconfigure device. */
5169c67fcbfSPavan Nikhilesh diag = event_dev_port_config(dev, dev_conf->nb_event_ports);
51799a2dd95SBruce Richardson if (diag != 0) {
5189c67fcbfSPavan Nikhilesh event_dev_queue_config(dev, 0);
5199c67fcbfSPavan Nikhilesh RTE_EDEV_LOG_ERR("dev%d event_dev_port_config = %d", dev_id,
5209c67fcbfSPavan Nikhilesh diag);
52199a2dd95SBruce Richardson return diag;
52299a2dd95SBruce Richardson }
52399a2dd95SBruce Richardson
524d35e6132SPavan Nikhilesh event_dev_fp_ops_reset(rte_event_fp_ops + dev_id);
525d35e6132SPavan Nikhilesh
52699a2dd95SBruce Richardson /* Configure the device */
52799a2dd95SBruce Richardson diag = (*dev->dev_ops->dev_configure)(dev);
52899a2dd95SBruce Richardson if (diag != 0) {
52999a2dd95SBruce Richardson RTE_EDEV_LOG_ERR("dev%d dev_configure = %d", dev_id, diag);
530d35e6132SPavan Nikhilesh event_dev_fp_ops_reset(rte_event_fp_ops + dev_id);
5319c67fcbfSPavan Nikhilesh event_dev_queue_config(dev, 0);
5329c67fcbfSPavan Nikhilesh event_dev_port_config(dev, 0);
53399a2dd95SBruce Richardson }
53499a2dd95SBruce Richardson
53599a2dd95SBruce Richardson dev->data->event_dev_cap = info.event_dev_cap;
53699a2dd95SBruce Richardson rte_eventdev_trace_configure(dev_id, dev_conf, diag);
53799a2dd95SBruce Richardson return diag;
53899a2dd95SBruce Richardson }
53999a2dd95SBruce Richardson
54099a2dd95SBruce Richardson static inline int
is_valid_queue(struct rte_eventdev * dev,uint8_t queue_id)54199a2dd95SBruce Richardson is_valid_queue(struct rte_eventdev *dev, uint8_t queue_id)
54299a2dd95SBruce Richardson {
54399a2dd95SBruce Richardson if (queue_id < dev->data->nb_queues && queue_id <
54499a2dd95SBruce Richardson RTE_EVENT_MAX_QUEUES_PER_DEV)
54599a2dd95SBruce Richardson return 1;
54699a2dd95SBruce Richardson else
54799a2dd95SBruce Richardson return 0;
54899a2dd95SBruce Richardson }
54999a2dd95SBruce Richardson
55099a2dd95SBruce Richardson int
rte_event_queue_default_conf_get(uint8_t dev_id,uint8_t queue_id,struct rte_event_queue_conf * queue_conf)55199a2dd95SBruce Richardson rte_event_queue_default_conf_get(uint8_t dev_id, uint8_t queue_id,
55299a2dd95SBruce Richardson struct rte_event_queue_conf *queue_conf)
55399a2dd95SBruce Richardson {
55499a2dd95SBruce Richardson struct rte_eventdev *dev;
55599a2dd95SBruce Richardson
55699a2dd95SBruce Richardson RTE_EVENTDEV_VALID_DEVID_OR_ERR_RET(dev_id, -EINVAL);
55799a2dd95SBruce Richardson dev = &rte_eventdevs[dev_id];
55899a2dd95SBruce Richardson
55999a2dd95SBruce Richardson if (queue_conf == NULL)
56099a2dd95SBruce Richardson return -EINVAL;
56199a2dd95SBruce Richardson
56299a2dd95SBruce Richardson if (!is_valid_queue(dev, queue_id)) {
56399a2dd95SBruce Richardson RTE_EDEV_LOG_ERR("Invalid queue_id=%" PRIu8, queue_id);
56499a2dd95SBruce Richardson return -EINVAL;
56599a2dd95SBruce Richardson }
56699a2dd95SBruce Richardson
5678f1d23ecSDavid Marchand if (*dev->dev_ops->queue_def_conf == NULL)
5688f1d23ecSDavid Marchand return -ENOTSUP;
56999a2dd95SBruce Richardson memset(queue_conf, 0, sizeof(struct rte_event_queue_conf));
57099a2dd95SBruce Richardson (*dev->dev_ops->queue_def_conf)(dev, queue_id, queue_conf);
5717f2d9df6SAmit Prakash Shukla
5727f2d9df6SAmit Prakash Shukla rte_eventdev_trace_queue_default_conf_get(dev_id, dev, queue_id, queue_conf);
5737f2d9df6SAmit Prakash Shukla
57499a2dd95SBruce Richardson return 0;
57599a2dd95SBruce Richardson }
57699a2dd95SBruce Richardson
57799a2dd95SBruce Richardson static inline int
is_valid_atomic_queue_conf(const struct rte_event_queue_conf * queue_conf)57899a2dd95SBruce Richardson is_valid_atomic_queue_conf(const struct rte_event_queue_conf *queue_conf)
57999a2dd95SBruce Richardson {
58099a2dd95SBruce Richardson if (queue_conf &&
58199a2dd95SBruce Richardson !(queue_conf->event_queue_cfg &
58299a2dd95SBruce Richardson RTE_EVENT_QUEUE_CFG_SINGLE_LINK) &&
58399a2dd95SBruce Richardson ((queue_conf->event_queue_cfg &
58499a2dd95SBruce Richardson RTE_EVENT_QUEUE_CFG_ALL_TYPES) ||
58599a2dd95SBruce Richardson (queue_conf->schedule_type
58699a2dd95SBruce Richardson == RTE_SCHED_TYPE_ATOMIC)
58799a2dd95SBruce Richardson ))
58899a2dd95SBruce Richardson return 1;
58999a2dd95SBruce Richardson else
59099a2dd95SBruce Richardson return 0;
59199a2dd95SBruce Richardson }
59299a2dd95SBruce Richardson
59399a2dd95SBruce Richardson static inline int
is_valid_ordered_queue_conf(const struct rte_event_queue_conf * queue_conf)59499a2dd95SBruce Richardson is_valid_ordered_queue_conf(const struct rte_event_queue_conf *queue_conf)
59599a2dd95SBruce Richardson {
59699a2dd95SBruce Richardson if (queue_conf &&
59799a2dd95SBruce Richardson !(queue_conf->event_queue_cfg &
59899a2dd95SBruce Richardson RTE_EVENT_QUEUE_CFG_SINGLE_LINK) &&
59999a2dd95SBruce Richardson ((queue_conf->event_queue_cfg &
60099a2dd95SBruce Richardson RTE_EVENT_QUEUE_CFG_ALL_TYPES) ||
60199a2dd95SBruce Richardson (queue_conf->schedule_type
60299a2dd95SBruce Richardson == RTE_SCHED_TYPE_ORDERED)
60399a2dd95SBruce Richardson ))
60499a2dd95SBruce Richardson return 1;
60599a2dd95SBruce Richardson else
60699a2dd95SBruce Richardson return 0;
60799a2dd95SBruce Richardson }
60899a2dd95SBruce Richardson
60999a2dd95SBruce Richardson
61099a2dd95SBruce Richardson int
rte_event_queue_setup(uint8_t dev_id,uint8_t queue_id,const struct rte_event_queue_conf * queue_conf)61199a2dd95SBruce Richardson rte_event_queue_setup(uint8_t dev_id, uint8_t queue_id,
61299a2dd95SBruce Richardson const struct rte_event_queue_conf *queue_conf)
61399a2dd95SBruce Richardson {
61499a2dd95SBruce Richardson struct rte_eventdev *dev;
61599a2dd95SBruce Richardson struct rte_event_queue_conf def_conf;
61699a2dd95SBruce Richardson
61799a2dd95SBruce Richardson RTE_EVENTDEV_VALID_DEVID_OR_ERR_RET(dev_id, -EINVAL);
61899a2dd95SBruce Richardson dev = &rte_eventdevs[dev_id];
61999a2dd95SBruce Richardson
62099a2dd95SBruce Richardson if (!is_valid_queue(dev, queue_id)) {
62199a2dd95SBruce Richardson RTE_EDEV_LOG_ERR("Invalid queue_id=%" PRIu8, queue_id);
62299a2dd95SBruce Richardson return -EINVAL;
62399a2dd95SBruce Richardson }
62499a2dd95SBruce Richardson
62599a2dd95SBruce Richardson /* Check nb_atomic_flows limit */
62699a2dd95SBruce Richardson if (is_valid_atomic_queue_conf(queue_conf)) {
62799a2dd95SBruce Richardson if (queue_conf->nb_atomic_flows == 0 ||
62899a2dd95SBruce Richardson queue_conf->nb_atomic_flows >
62999a2dd95SBruce Richardson dev->data->dev_conf.nb_event_queue_flows) {
63099a2dd95SBruce Richardson RTE_EDEV_LOG_ERR(
63199a2dd95SBruce Richardson "dev%d queue%d Invalid nb_atomic_flows=%d max_flows=%d",
63299a2dd95SBruce Richardson dev_id, queue_id, queue_conf->nb_atomic_flows,
63399a2dd95SBruce Richardson dev->data->dev_conf.nb_event_queue_flows);
63499a2dd95SBruce Richardson return -EINVAL;
63599a2dd95SBruce Richardson }
63699a2dd95SBruce Richardson }
63799a2dd95SBruce Richardson
63899a2dd95SBruce Richardson /* Check nb_atomic_order_sequences limit */
63999a2dd95SBruce Richardson if (is_valid_ordered_queue_conf(queue_conf)) {
64099a2dd95SBruce Richardson if (queue_conf->nb_atomic_order_sequences == 0 ||
64199a2dd95SBruce Richardson queue_conf->nb_atomic_order_sequences >
64299a2dd95SBruce Richardson dev->data->dev_conf.nb_event_queue_flows) {
64399a2dd95SBruce Richardson RTE_EDEV_LOG_ERR(
64499a2dd95SBruce Richardson "dev%d queue%d Invalid nb_atomic_order_seq=%d max_flows=%d",
64599a2dd95SBruce Richardson dev_id, queue_id, queue_conf->nb_atomic_order_sequences,
64699a2dd95SBruce Richardson dev->data->dev_conf.nb_event_queue_flows);
64799a2dd95SBruce Richardson return -EINVAL;
64899a2dd95SBruce Richardson }
64999a2dd95SBruce Richardson }
65099a2dd95SBruce Richardson
65199a2dd95SBruce Richardson if (dev->data->dev_started) {
65299a2dd95SBruce Richardson RTE_EDEV_LOG_ERR(
65399a2dd95SBruce Richardson "device %d must be stopped to allow queue setup", dev_id);
65499a2dd95SBruce Richardson return -EBUSY;
65599a2dd95SBruce Richardson }
65699a2dd95SBruce Richardson
6578f1d23ecSDavid Marchand if (*dev->dev_ops->queue_setup == NULL)
6588f1d23ecSDavid Marchand return -ENOTSUP;
65999a2dd95SBruce Richardson
66099a2dd95SBruce Richardson if (queue_conf == NULL) {
6618f1d23ecSDavid Marchand if (*dev->dev_ops->queue_def_conf == NULL)
6628f1d23ecSDavid Marchand return -ENOTSUP;
66399a2dd95SBruce Richardson (*dev->dev_ops->queue_def_conf)(dev, queue_id, &def_conf);
66499a2dd95SBruce Richardson queue_conf = &def_conf;
66599a2dd95SBruce Richardson }
66699a2dd95SBruce Richardson
66799a2dd95SBruce Richardson dev->data->queues_cfg[queue_id] = *queue_conf;
66899a2dd95SBruce Richardson rte_eventdev_trace_queue_setup(dev_id, queue_id, queue_conf);
66999a2dd95SBruce Richardson return (*dev->dev_ops->queue_setup)(dev, queue_id, queue_conf);
67099a2dd95SBruce Richardson }
67199a2dd95SBruce Richardson
67299a2dd95SBruce Richardson static inline int
is_valid_port(struct rte_eventdev * dev,uint8_t port_id)67399a2dd95SBruce Richardson is_valid_port(struct rte_eventdev *dev, uint8_t port_id)
67499a2dd95SBruce Richardson {
67599a2dd95SBruce Richardson if (port_id < dev->data->nb_ports)
67699a2dd95SBruce Richardson return 1;
67799a2dd95SBruce Richardson else
67899a2dd95SBruce Richardson return 0;
67999a2dd95SBruce Richardson }
68099a2dd95SBruce Richardson
68199a2dd95SBruce Richardson int
rte_event_port_default_conf_get(uint8_t dev_id,uint8_t port_id,struct rte_event_port_conf * port_conf)68299a2dd95SBruce Richardson rte_event_port_default_conf_get(uint8_t dev_id, uint8_t port_id,
68399a2dd95SBruce Richardson struct rte_event_port_conf *port_conf)
68499a2dd95SBruce Richardson {
68599a2dd95SBruce Richardson struct rte_eventdev *dev;
68699a2dd95SBruce Richardson
68799a2dd95SBruce Richardson RTE_EVENTDEV_VALID_DEVID_OR_ERR_RET(dev_id, -EINVAL);
68899a2dd95SBruce Richardson dev = &rte_eventdevs[dev_id];
68999a2dd95SBruce Richardson
69099a2dd95SBruce Richardson if (port_conf == NULL)
69199a2dd95SBruce Richardson return -EINVAL;
69299a2dd95SBruce Richardson
69399a2dd95SBruce Richardson if (!is_valid_port(dev, port_id)) {
69499a2dd95SBruce Richardson RTE_EDEV_LOG_ERR("Invalid port_id=%" PRIu8, port_id);
69599a2dd95SBruce Richardson return -EINVAL;
69699a2dd95SBruce Richardson }
69799a2dd95SBruce Richardson
6988f1d23ecSDavid Marchand if (*dev->dev_ops->port_def_conf == NULL)
6998f1d23ecSDavid Marchand return -ENOTSUP;
70099a2dd95SBruce Richardson memset(port_conf, 0, sizeof(struct rte_event_port_conf));
70199a2dd95SBruce Richardson (*dev->dev_ops->port_def_conf)(dev, port_id, port_conf);
7027f2d9df6SAmit Prakash Shukla
7037f2d9df6SAmit Prakash Shukla rte_eventdev_trace_port_default_conf_get(dev_id, dev, port_id, port_conf);
7047f2d9df6SAmit Prakash Shukla
70599a2dd95SBruce Richardson return 0;
70699a2dd95SBruce Richardson }
70799a2dd95SBruce Richardson
70899a2dd95SBruce Richardson int
rte_event_port_setup(uint8_t dev_id,uint8_t port_id,const struct rte_event_port_conf * port_conf)70999a2dd95SBruce Richardson rte_event_port_setup(uint8_t dev_id, uint8_t port_id,
71099a2dd95SBruce Richardson const struct rte_event_port_conf *port_conf)
71199a2dd95SBruce Richardson {
71299a2dd95SBruce Richardson struct rte_eventdev *dev;
71399a2dd95SBruce Richardson struct rte_event_port_conf def_conf;
71499a2dd95SBruce Richardson int diag;
71599a2dd95SBruce Richardson
71699a2dd95SBruce Richardson RTE_EVENTDEV_VALID_DEVID_OR_ERR_RET(dev_id, -EINVAL);
71799a2dd95SBruce Richardson dev = &rte_eventdevs[dev_id];
71899a2dd95SBruce Richardson
71999a2dd95SBruce Richardson if (!is_valid_port(dev, port_id)) {
72099a2dd95SBruce Richardson RTE_EDEV_LOG_ERR("Invalid port_id=%" PRIu8, port_id);
72199a2dd95SBruce Richardson return -EINVAL;
72299a2dd95SBruce Richardson }
72399a2dd95SBruce Richardson
72499a2dd95SBruce Richardson /* Check new_event_threshold limit */
72599a2dd95SBruce Richardson if ((port_conf && !port_conf->new_event_threshold) ||
72699a2dd95SBruce Richardson (port_conf && port_conf->new_event_threshold >
72799a2dd95SBruce Richardson dev->data->dev_conf.nb_events_limit)) {
72899a2dd95SBruce Richardson RTE_EDEV_LOG_ERR(
72999a2dd95SBruce Richardson "dev%d port%d Invalid event_threshold=%d nb_events_limit=%d",
73099a2dd95SBruce Richardson dev_id, port_id, port_conf->new_event_threshold,
73199a2dd95SBruce Richardson dev->data->dev_conf.nb_events_limit);
73299a2dd95SBruce Richardson return -EINVAL;
73399a2dd95SBruce Richardson }
73499a2dd95SBruce Richardson
73599a2dd95SBruce Richardson /* Check dequeue_depth limit */
73699a2dd95SBruce Richardson if ((port_conf && !port_conf->dequeue_depth) ||
73799a2dd95SBruce Richardson (port_conf && port_conf->dequeue_depth >
73899a2dd95SBruce Richardson dev->data->dev_conf.nb_event_port_dequeue_depth)) {
73999a2dd95SBruce Richardson RTE_EDEV_LOG_ERR(
74099a2dd95SBruce Richardson "dev%d port%d Invalid dequeue depth=%d max_dequeue_depth=%d",
74199a2dd95SBruce Richardson dev_id, port_id, port_conf->dequeue_depth,
74299a2dd95SBruce Richardson dev->data->dev_conf.nb_event_port_dequeue_depth);
74399a2dd95SBruce Richardson return -EINVAL;
74499a2dd95SBruce Richardson }
74599a2dd95SBruce Richardson
74699a2dd95SBruce Richardson /* Check enqueue_depth limit */
74799a2dd95SBruce Richardson if ((port_conf && !port_conf->enqueue_depth) ||
74899a2dd95SBruce Richardson (port_conf && port_conf->enqueue_depth >
74999a2dd95SBruce Richardson dev->data->dev_conf.nb_event_port_enqueue_depth)) {
75099a2dd95SBruce Richardson RTE_EDEV_LOG_ERR(
75199a2dd95SBruce Richardson "dev%d port%d Invalid enqueue depth=%d max_enqueue_depth=%d",
75299a2dd95SBruce Richardson dev_id, port_id, port_conf->enqueue_depth,
75399a2dd95SBruce Richardson dev->data->dev_conf.nb_event_port_enqueue_depth);
75499a2dd95SBruce Richardson return -EINVAL;
75599a2dd95SBruce Richardson }
75699a2dd95SBruce Richardson
75799a2dd95SBruce Richardson if (port_conf &&
75899a2dd95SBruce Richardson (port_conf->event_port_cfg & RTE_EVENT_PORT_CFG_DISABLE_IMPL_REL) &&
75999a2dd95SBruce Richardson !(dev->data->event_dev_cap &
76099a2dd95SBruce Richardson RTE_EVENT_DEV_CAP_IMPLICIT_RELEASE_DISABLE)) {
76199a2dd95SBruce Richardson RTE_EDEV_LOG_ERR(
76299a2dd95SBruce Richardson "dev%d port%d Implicit release disable not supported",
76399a2dd95SBruce Richardson dev_id, port_id);
76499a2dd95SBruce Richardson return -EINVAL;
76599a2dd95SBruce Richardson }
76699a2dd95SBruce Richardson
76799a2dd95SBruce Richardson if (dev->data->dev_started) {
76899a2dd95SBruce Richardson RTE_EDEV_LOG_ERR(
76999a2dd95SBruce Richardson "device %d must be stopped to allow port setup", dev_id);
77099a2dd95SBruce Richardson return -EBUSY;
77199a2dd95SBruce Richardson }
77299a2dd95SBruce Richardson
7738f1d23ecSDavid Marchand if (*dev->dev_ops->port_setup == NULL)
7748f1d23ecSDavid Marchand return -ENOTSUP;
77599a2dd95SBruce Richardson
77699a2dd95SBruce Richardson if (port_conf == NULL) {
7778f1d23ecSDavid Marchand if (*dev->dev_ops->port_def_conf == NULL)
7788f1d23ecSDavid Marchand return -ENOTSUP;
77999a2dd95SBruce Richardson (*dev->dev_ops->port_def_conf)(dev, port_id, &def_conf);
78099a2dd95SBruce Richardson port_conf = &def_conf;
78199a2dd95SBruce Richardson }
78299a2dd95SBruce Richardson
78399a2dd95SBruce Richardson dev->data->ports_cfg[port_id] = *port_conf;
78499a2dd95SBruce Richardson
78599a2dd95SBruce Richardson diag = (*dev->dev_ops->port_setup)(dev, port_id, port_conf);
78699a2dd95SBruce Richardson
78799a2dd95SBruce Richardson /* Unlink all the queues from this port(default state after setup) */
78899a2dd95SBruce Richardson if (!diag)
78999a2dd95SBruce Richardson diag = rte_event_port_unlink(dev_id, port_id, NULL, 0);
79099a2dd95SBruce Richardson
79199a2dd95SBruce Richardson rte_eventdev_trace_port_setup(dev_id, port_id, port_conf, diag);
79299a2dd95SBruce Richardson if (diag < 0)
79399a2dd95SBruce Richardson return diag;
79499a2dd95SBruce Richardson
79599a2dd95SBruce Richardson return 0;
79699a2dd95SBruce Richardson }
79799a2dd95SBruce Richardson
7981ff23ce6SPavan Nikhilesh void
rte_event_port_quiesce(uint8_t dev_id,uint8_t port_id,rte_eventdev_port_flush_t release_cb,void * args)7991ff23ce6SPavan Nikhilesh rte_event_port_quiesce(uint8_t dev_id, uint8_t port_id,
8001ff23ce6SPavan Nikhilesh rte_eventdev_port_flush_t release_cb, void *args)
8011ff23ce6SPavan Nikhilesh {
8021ff23ce6SPavan Nikhilesh struct rte_eventdev *dev;
8031ff23ce6SPavan Nikhilesh
8041ff23ce6SPavan Nikhilesh RTE_EVENTDEV_VALID_DEVID_OR_RET(dev_id);
8051ff23ce6SPavan Nikhilesh dev = &rte_eventdevs[dev_id];
8061ff23ce6SPavan Nikhilesh
8077f2d9df6SAmit Prakash Shukla rte_eventdev_trace_port_quiesce(dev_id, dev, port_id, args);
8087f2d9df6SAmit Prakash Shukla
8091ff23ce6SPavan Nikhilesh if (!is_valid_port(dev, port_id)) {
8101ff23ce6SPavan Nikhilesh RTE_EDEV_LOG_ERR("Invalid port_id=%" PRIu8, port_id);
8111ff23ce6SPavan Nikhilesh return;
8121ff23ce6SPavan Nikhilesh }
8131ff23ce6SPavan Nikhilesh
8141ff23ce6SPavan Nikhilesh if (dev->dev_ops->port_quiesce)
8151ff23ce6SPavan Nikhilesh (*dev->dev_ops->port_quiesce)(dev, dev->data->ports[port_id],
8161ff23ce6SPavan Nikhilesh release_cb, args);
8171ff23ce6SPavan Nikhilesh }
8181ff23ce6SPavan Nikhilesh
81999a2dd95SBruce Richardson int
rte_event_dev_attr_get(uint8_t dev_id,uint32_t attr_id,uint32_t * attr_value)82099a2dd95SBruce Richardson rte_event_dev_attr_get(uint8_t dev_id, uint32_t attr_id,
82199a2dd95SBruce Richardson uint32_t *attr_value)
82299a2dd95SBruce Richardson {
82399a2dd95SBruce Richardson struct rte_eventdev *dev;
82499a2dd95SBruce Richardson
82599a2dd95SBruce Richardson if (!attr_value)
82699a2dd95SBruce Richardson return -EINVAL;
82799a2dd95SBruce Richardson RTE_EVENTDEV_VALID_DEVID_OR_ERR_RET(dev_id, -EINVAL);
82899a2dd95SBruce Richardson dev = &rte_eventdevs[dev_id];
82999a2dd95SBruce Richardson
83099a2dd95SBruce Richardson switch (attr_id) {
83199a2dd95SBruce Richardson case RTE_EVENT_DEV_ATTR_PORT_COUNT:
83299a2dd95SBruce Richardson *attr_value = dev->data->nb_ports;
83399a2dd95SBruce Richardson break;
83499a2dd95SBruce Richardson case RTE_EVENT_DEV_ATTR_QUEUE_COUNT:
83599a2dd95SBruce Richardson *attr_value = dev->data->nb_queues;
83699a2dd95SBruce Richardson break;
83799a2dd95SBruce Richardson case RTE_EVENT_DEV_ATTR_STARTED:
83899a2dd95SBruce Richardson *attr_value = dev->data->dev_started;
83999a2dd95SBruce Richardson break;
84099a2dd95SBruce Richardson default:
84199a2dd95SBruce Richardson return -EINVAL;
84299a2dd95SBruce Richardson }
84399a2dd95SBruce Richardson
8447f2d9df6SAmit Prakash Shukla rte_eventdev_trace_attr_get(dev_id, dev, attr_id, *attr_value);
8457f2d9df6SAmit Prakash Shukla
84699a2dd95SBruce Richardson return 0;
84799a2dd95SBruce Richardson }
84899a2dd95SBruce Richardson
84999a2dd95SBruce Richardson int
rte_event_port_attr_get(uint8_t dev_id,uint8_t port_id,uint32_t attr_id,uint32_t * attr_value)85099a2dd95SBruce Richardson rte_event_port_attr_get(uint8_t dev_id, uint8_t port_id, uint32_t attr_id,
85199a2dd95SBruce Richardson uint32_t *attr_value)
85299a2dd95SBruce Richardson {
85399a2dd95SBruce Richardson struct rte_eventdev *dev;
85499a2dd95SBruce Richardson
85599a2dd95SBruce Richardson if (!attr_value)
85699a2dd95SBruce Richardson return -EINVAL;
85799a2dd95SBruce Richardson
85899a2dd95SBruce Richardson RTE_EVENTDEV_VALID_DEVID_OR_ERR_RET(dev_id, -EINVAL);
85999a2dd95SBruce Richardson dev = &rte_eventdevs[dev_id];
86099a2dd95SBruce Richardson if (!is_valid_port(dev, port_id)) {
86199a2dd95SBruce Richardson RTE_EDEV_LOG_ERR("Invalid port_id=%" PRIu8, port_id);
86299a2dd95SBruce Richardson return -EINVAL;
86399a2dd95SBruce Richardson }
86499a2dd95SBruce Richardson
86599a2dd95SBruce Richardson switch (attr_id) {
86699a2dd95SBruce Richardson case RTE_EVENT_PORT_ATTR_ENQ_DEPTH:
86799a2dd95SBruce Richardson *attr_value = dev->data->ports_cfg[port_id].enqueue_depth;
86899a2dd95SBruce Richardson break;
86999a2dd95SBruce Richardson case RTE_EVENT_PORT_ATTR_DEQ_DEPTH:
87099a2dd95SBruce Richardson *attr_value = dev->data->ports_cfg[port_id].dequeue_depth;
87199a2dd95SBruce Richardson break;
87299a2dd95SBruce Richardson case RTE_EVENT_PORT_ATTR_NEW_EVENT_THRESHOLD:
87399a2dd95SBruce Richardson *attr_value = dev->data->ports_cfg[port_id].new_event_threshold;
87499a2dd95SBruce Richardson break;
87599a2dd95SBruce Richardson case RTE_EVENT_PORT_ATTR_IMPLICIT_RELEASE_DISABLE:
87699a2dd95SBruce Richardson {
87799a2dd95SBruce Richardson uint32_t config;
87899a2dd95SBruce Richardson
87999a2dd95SBruce Richardson config = dev->data->ports_cfg[port_id].event_port_cfg;
88099a2dd95SBruce Richardson *attr_value = !!(config & RTE_EVENT_PORT_CFG_DISABLE_IMPL_REL);
88199a2dd95SBruce Richardson break;
88299a2dd95SBruce Richardson }
88399a2dd95SBruce Richardson default:
88499a2dd95SBruce Richardson return -EINVAL;
88599a2dd95SBruce Richardson };
8867f2d9df6SAmit Prakash Shukla
8877f2d9df6SAmit Prakash Shukla rte_eventdev_trace_port_attr_get(dev_id, dev, port_id, attr_id, *attr_value);
8887f2d9df6SAmit Prakash Shukla
88999a2dd95SBruce Richardson return 0;
89099a2dd95SBruce Richardson }
89199a2dd95SBruce Richardson
89299a2dd95SBruce Richardson int
rte_event_queue_attr_get(uint8_t dev_id,uint8_t queue_id,uint32_t attr_id,uint32_t * attr_value)89399a2dd95SBruce Richardson rte_event_queue_attr_get(uint8_t dev_id, uint8_t queue_id, uint32_t attr_id,
89499a2dd95SBruce Richardson uint32_t *attr_value)
89599a2dd95SBruce Richardson {
89699a2dd95SBruce Richardson struct rte_event_queue_conf *conf;
89799a2dd95SBruce Richardson struct rte_eventdev *dev;
89899a2dd95SBruce Richardson
89999a2dd95SBruce Richardson if (!attr_value)
90099a2dd95SBruce Richardson return -EINVAL;
90199a2dd95SBruce Richardson
90299a2dd95SBruce Richardson RTE_EVENTDEV_VALID_DEVID_OR_ERR_RET(dev_id, -EINVAL);
90399a2dd95SBruce Richardson dev = &rte_eventdevs[dev_id];
90499a2dd95SBruce Richardson if (!is_valid_queue(dev, queue_id)) {
90599a2dd95SBruce Richardson RTE_EDEV_LOG_ERR("Invalid queue_id=%" PRIu8, queue_id);
90699a2dd95SBruce Richardson return -EINVAL;
90799a2dd95SBruce Richardson }
90899a2dd95SBruce Richardson
90999a2dd95SBruce Richardson conf = &dev->data->queues_cfg[queue_id];
91099a2dd95SBruce Richardson
91199a2dd95SBruce Richardson switch (attr_id) {
91299a2dd95SBruce Richardson case RTE_EVENT_QUEUE_ATTR_PRIORITY:
91399a2dd95SBruce Richardson *attr_value = RTE_EVENT_DEV_PRIORITY_NORMAL;
91499a2dd95SBruce Richardson if (dev->data->event_dev_cap & RTE_EVENT_DEV_CAP_QUEUE_QOS)
91599a2dd95SBruce Richardson *attr_value = conf->priority;
91699a2dd95SBruce Richardson break;
91799a2dd95SBruce Richardson case RTE_EVENT_QUEUE_ATTR_NB_ATOMIC_FLOWS:
91899a2dd95SBruce Richardson *attr_value = conf->nb_atomic_flows;
91999a2dd95SBruce Richardson break;
92099a2dd95SBruce Richardson case RTE_EVENT_QUEUE_ATTR_NB_ATOMIC_ORDER_SEQUENCES:
92199a2dd95SBruce Richardson *attr_value = conf->nb_atomic_order_sequences;
92299a2dd95SBruce Richardson break;
92399a2dd95SBruce Richardson case RTE_EVENT_QUEUE_ATTR_EVENT_QUEUE_CFG:
92499a2dd95SBruce Richardson *attr_value = conf->event_queue_cfg;
92599a2dd95SBruce Richardson break;
92699a2dd95SBruce Richardson case RTE_EVENT_QUEUE_ATTR_SCHEDULE_TYPE:
92799a2dd95SBruce Richardson if (conf->event_queue_cfg & RTE_EVENT_QUEUE_CFG_ALL_TYPES)
92899a2dd95SBruce Richardson return -EOVERFLOW;
92999a2dd95SBruce Richardson
93099a2dd95SBruce Richardson *attr_value = conf->schedule_type;
93199a2dd95SBruce Richardson break;
93244516e6bSShijith Thotton case RTE_EVENT_QUEUE_ATTR_WEIGHT:
93344516e6bSShijith Thotton *attr_value = RTE_EVENT_QUEUE_WEIGHT_LOWEST;
9342f279a1bSShijith Thotton if (dev->data->event_dev_cap & RTE_EVENT_DEV_CAP_QUEUE_QOS)
9352f279a1bSShijith Thotton *attr_value = conf->weight;
93644516e6bSShijith Thotton break;
93744516e6bSShijith Thotton case RTE_EVENT_QUEUE_ATTR_AFFINITY:
93844516e6bSShijith Thotton *attr_value = RTE_EVENT_QUEUE_AFFINITY_LOWEST;
9392f279a1bSShijith Thotton if (dev->data->event_dev_cap & RTE_EVENT_DEV_CAP_QUEUE_QOS)
9402f279a1bSShijith Thotton *attr_value = conf->affinity;
94144516e6bSShijith Thotton break;
94299a2dd95SBruce Richardson default:
94399a2dd95SBruce Richardson return -EINVAL;
94499a2dd95SBruce Richardson };
9457f2d9df6SAmit Prakash Shukla
9467f2d9df6SAmit Prakash Shukla rte_eventdev_trace_queue_attr_get(dev_id, dev, queue_id, attr_id, *attr_value);
9477f2d9df6SAmit Prakash Shukla
94899a2dd95SBruce Richardson return 0;
94999a2dd95SBruce Richardson }
95099a2dd95SBruce Richardson
95199a2dd95SBruce Richardson int
rte_event_queue_attr_set(uint8_t dev_id,uint8_t queue_id,uint32_t attr_id,uint64_t attr_value)95297b914f4SShijith Thotton rte_event_queue_attr_set(uint8_t dev_id, uint8_t queue_id, uint32_t attr_id,
95397b914f4SShijith Thotton uint64_t attr_value)
95497b914f4SShijith Thotton {
95597b914f4SShijith Thotton struct rte_eventdev *dev;
95697b914f4SShijith Thotton
9577f2d9df6SAmit Prakash Shukla rte_eventdev_trace_queue_attr_set(dev_id, queue_id, attr_id, attr_value);
9587f2d9df6SAmit Prakash Shukla
95997b914f4SShijith Thotton RTE_EVENTDEV_VALID_DEVID_OR_ERR_RET(dev_id, -EINVAL);
96097b914f4SShijith Thotton dev = &rte_eventdevs[dev_id];
96197b914f4SShijith Thotton if (!is_valid_queue(dev, queue_id)) {
96297b914f4SShijith Thotton RTE_EDEV_LOG_ERR("Invalid queue_id=%" PRIu8, queue_id);
96397b914f4SShijith Thotton return -EINVAL;
96497b914f4SShijith Thotton }
96597b914f4SShijith Thotton
96697b914f4SShijith Thotton if (!(dev->data->event_dev_cap &
96797b914f4SShijith Thotton RTE_EVENT_DEV_CAP_RUNTIME_QUEUE_ATTR)) {
96897b914f4SShijith Thotton RTE_EDEV_LOG_ERR(
96997b914f4SShijith Thotton "Device %" PRIu8 "does not support changing queue attributes at runtime",
97097b914f4SShijith Thotton dev_id);
97197b914f4SShijith Thotton return -ENOTSUP;
97297b914f4SShijith Thotton }
97397b914f4SShijith Thotton
9748f1d23ecSDavid Marchand if (*dev->dev_ops->queue_attr_set == NULL)
9758f1d23ecSDavid Marchand return -ENOTSUP;
97697b914f4SShijith Thotton return (*dev->dev_ops->queue_attr_set)(dev, queue_id, attr_id,
97797b914f4SShijith Thotton attr_value);
97897b914f4SShijith Thotton }
97997b914f4SShijith Thotton
98097b914f4SShijith 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)98199a2dd95SBruce Richardson rte_event_port_link(uint8_t dev_id, uint8_t port_id,
98299a2dd95SBruce Richardson const uint8_t queues[], const uint8_t priorities[],
98399a2dd95SBruce Richardson uint16_t nb_links)
98499a2dd95SBruce Richardson {
985d007a7f3SPavan Nikhilesh return rte_event_port_profile_links_set(dev_id, port_id, queues, priorities, nb_links, 0);
986d007a7f3SPavan Nikhilesh }
987d007a7f3SPavan Nikhilesh
988d007a7f3SPavan Nikhilesh int
rte_event_port_profile_links_set(uint8_t dev_id,uint8_t port_id,const uint8_t queues[],const uint8_t priorities[],uint16_t nb_links,uint8_t profile_id)989d007a7f3SPavan Nikhilesh rte_event_port_profile_links_set(uint8_t dev_id, uint8_t port_id, const uint8_t queues[],
990d007a7f3SPavan Nikhilesh const uint8_t priorities[], uint16_t nb_links, uint8_t profile_id)
991d007a7f3SPavan Nikhilesh {
99299a2dd95SBruce Richardson uint8_t priorities_list[RTE_EVENT_MAX_QUEUES_PER_DEV];
993d007a7f3SPavan Nikhilesh uint8_t queues_list[RTE_EVENT_MAX_QUEUES_PER_DEV];
994d007a7f3SPavan Nikhilesh struct rte_event_dev_info info;
995d007a7f3SPavan Nikhilesh struct rte_eventdev *dev;
99699a2dd95SBruce Richardson uint16_t *links_map;
99799a2dd95SBruce Richardson int i, diag;
99899a2dd95SBruce Richardson
99999a2dd95SBruce Richardson RTE_EVENTDEV_VALID_DEVID_OR_ERRNO_RET(dev_id, EINVAL, 0);
100099a2dd95SBruce Richardson dev = &rte_eventdevs[dev_id];
100199a2dd95SBruce Richardson
1002d007a7f3SPavan Nikhilesh if (*dev->dev_ops->dev_infos_get == NULL)
1003d007a7f3SPavan Nikhilesh return -ENOTSUP;
1004d007a7f3SPavan Nikhilesh
1005d007a7f3SPavan Nikhilesh (*dev->dev_ops->dev_infos_get)(dev, &info);
1006d007a7f3SPavan Nikhilesh if (profile_id >= RTE_EVENT_MAX_PROFILES_PER_PORT ||
1007d007a7f3SPavan Nikhilesh profile_id >= info.max_profiles_per_port) {
1008d007a7f3SPavan Nikhilesh RTE_EDEV_LOG_ERR("Invalid profile_id=%" PRIu8, profile_id);
1009d007a7f3SPavan Nikhilesh return -EINVAL;
1010d007a7f3SPavan Nikhilesh }
1011d007a7f3SPavan Nikhilesh
101299a2dd95SBruce Richardson if (*dev->dev_ops->port_link == NULL) {
1013ae282b06SDavid Marchand RTE_EDEV_LOG_ERR("Function not supported");
101499a2dd95SBruce Richardson rte_errno = ENOTSUP;
101599a2dd95SBruce Richardson return 0;
101699a2dd95SBruce Richardson }
101799a2dd95SBruce Richardson
1018d007a7f3SPavan Nikhilesh if (profile_id && *dev->dev_ops->port_link_profile == NULL) {
1019ae282b06SDavid Marchand RTE_EDEV_LOG_ERR("Function not supported");
1020d007a7f3SPavan Nikhilesh rte_errno = ENOTSUP;
1021d007a7f3SPavan Nikhilesh return 0;
1022d007a7f3SPavan Nikhilesh }
1023d007a7f3SPavan Nikhilesh
102499a2dd95SBruce Richardson if (!is_valid_port(dev, port_id)) {
102599a2dd95SBruce Richardson RTE_EDEV_LOG_ERR("Invalid port_id=%" PRIu8, port_id);
102699a2dd95SBruce Richardson rte_errno = EINVAL;
102799a2dd95SBruce Richardson return 0;
102899a2dd95SBruce Richardson }
102999a2dd95SBruce Richardson
103099a2dd95SBruce Richardson if (queues == NULL) {
103199a2dd95SBruce Richardson for (i = 0; i < dev->data->nb_queues; i++)
103299a2dd95SBruce Richardson queues_list[i] = i;
103399a2dd95SBruce Richardson
103499a2dd95SBruce Richardson queues = queues_list;
103599a2dd95SBruce Richardson nb_links = dev->data->nb_queues;
103699a2dd95SBruce Richardson }
103799a2dd95SBruce Richardson
103899a2dd95SBruce Richardson if (priorities == NULL) {
103999a2dd95SBruce Richardson for (i = 0; i < nb_links; i++)
104099a2dd95SBruce Richardson priorities_list[i] = RTE_EVENT_DEV_PRIORITY_NORMAL;
104199a2dd95SBruce Richardson
104299a2dd95SBruce Richardson priorities = priorities_list;
104399a2dd95SBruce Richardson }
104499a2dd95SBruce Richardson
104599a2dd95SBruce Richardson for (i = 0; i < nb_links; i++)
104699a2dd95SBruce Richardson if (queues[i] >= dev->data->nb_queues) {
104799a2dd95SBruce Richardson rte_errno = EINVAL;
104899a2dd95SBruce Richardson return 0;
104999a2dd95SBruce Richardson }
105099a2dd95SBruce Richardson
1051d007a7f3SPavan Nikhilesh if (profile_id)
1052d007a7f3SPavan Nikhilesh diag = (*dev->dev_ops->port_link_profile)(dev, dev->data->ports[port_id], queues,
1053d007a7f3SPavan Nikhilesh priorities, nb_links, profile_id);
1054d007a7f3SPavan Nikhilesh else
1055d007a7f3SPavan Nikhilesh diag = (*dev->dev_ops->port_link)(dev, dev->data->ports[port_id], queues,
1056d007a7f3SPavan Nikhilesh priorities, nb_links);
105799a2dd95SBruce Richardson if (diag < 0)
105899a2dd95SBruce Richardson return diag;
105999a2dd95SBruce Richardson
1060d007a7f3SPavan Nikhilesh links_map = dev->data->links_map[profile_id];
106199a2dd95SBruce Richardson /* Point links_map to this port specific area */
106299a2dd95SBruce Richardson links_map += (port_id * RTE_EVENT_MAX_QUEUES_PER_DEV);
106399a2dd95SBruce Richardson for (i = 0; i < diag; i++)
106499a2dd95SBruce Richardson links_map[queues[i]] = (uint8_t)priorities[i];
106599a2dd95SBruce Richardson
1066d007a7f3SPavan Nikhilesh rte_eventdev_trace_port_profile_links_set(dev_id, port_id, nb_links, profile_id, diag);
106799a2dd95SBruce Richardson return diag;
106899a2dd95SBruce Richardson }
106999a2dd95SBruce Richardson
107099a2dd95SBruce Richardson int
rte_event_port_unlink(uint8_t dev_id,uint8_t port_id,uint8_t queues[],uint16_t nb_unlinks)107199a2dd95SBruce Richardson rte_event_port_unlink(uint8_t dev_id, uint8_t port_id,
107299a2dd95SBruce Richardson uint8_t queues[], uint16_t nb_unlinks)
107399a2dd95SBruce Richardson {
1074d007a7f3SPavan Nikhilesh return rte_event_port_profile_unlink(dev_id, port_id, queues, nb_unlinks, 0);
1075d007a7f3SPavan Nikhilesh }
1076d007a7f3SPavan Nikhilesh
1077d007a7f3SPavan Nikhilesh int
rte_event_port_profile_unlink(uint8_t dev_id,uint8_t port_id,uint8_t queues[],uint16_t nb_unlinks,uint8_t profile_id)1078d007a7f3SPavan Nikhilesh rte_event_port_profile_unlink(uint8_t dev_id, uint8_t port_id, uint8_t queues[],
1079d007a7f3SPavan Nikhilesh uint16_t nb_unlinks, uint8_t profile_id)
1080d007a7f3SPavan Nikhilesh {
108199a2dd95SBruce Richardson uint8_t all_queues[RTE_EVENT_MAX_QUEUES_PER_DEV];
1082d007a7f3SPavan Nikhilesh struct rte_event_dev_info info;
1083d007a7f3SPavan Nikhilesh struct rte_eventdev *dev;
108499a2dd95SBruce Richardson uint16_t *links_map;
1085d007a7f3SPavan Nikhilesh int i, diag, j;
108699a2dd95SBruce Richardson
108799a2dd95SBruce Richardson RTE_EVENTDEV_VALID_DEVID_OR_ERRNO_RET(dev_id, EINVAL, 0);
108899a2dd95SBruce Richardson dev = &rte_eventdevs[dev_id];
108999a2dd95SBruce Richardson
1090d007a7f3SPavan Nikhilesh if (*dev->dev_ops->dev_infos_get == NULL)
1091d007a7f3SPavan Nikhilesh return -ENOTSUP;
1092d007a7f3SPavan Nikhilesh
1093d007a7f3SPavan Nikhilesh (*dev->dev_ops->dev_infos_get)(dev, &info);
1094d007a7f3SPavan Nikhilesh if (profile_id >= RTE_EVENT_MAX_PROFILES_PER_PORT ||
1095d007a7f3SPavan Nikhilesh profile_id >= info.max_profiles_per_port) {
1096d007a7f3SPavan Nikhilesh RTE_EDEV_LOG_ERR("Invalid profile_id=%" PRIu8, profile_id);
1097d007a7f3SPavan Nikhilesh return -EINVAL;
1098d007a7f3SPavan Nikhilesh }
1099d007a7f3SPavan Nikhilesh
110099a2dd95SBruce Richardson if (*dev->dev_ops->port_unlink == NULL) {
110199a2dd95SBruce Richardson RTE_EDEV_LOG_ERR("Function not supported");
110299a2dd95SBruce Richardson rte_errno = ENOTSUP;
110399a2dd95SBruce Richardson return 0;
110499a2dd95SBruce Richardson }
110599a2dd95SBruce Richardson
1106d007a7f3SPavan Nikhilesh if (profile_id && *dev->dev_ops->port_unlink_profile == NULL) {
1107d007a7f3SPavan Nikhilesh RTE_EDEV_LOG_ERR("Function not supported");
1108d007a7f3SPavan Nikhilesh rte_errno = ENOTSUP;
1109d007a7f3SPavan Nikhilesh return 0;
1110d007a7f3SPavan Nikhilesh }
1111d007a7f3SPavan Nikhilesh
111299a2dd95SBruce Richardson if (!is_valid_port(dev, port_id)) {
111399a2dd95SBruce Richardson RTE_EDEV_LOG_ERR("Invalid port_id=%" PRIu8, port_id);
111499a2dd95SBruce Richardson rte_errno = EINVAL;
111599a2dd95SBruce Richardson return 0;
111699a2dd95SBruce Richardson }
111799a2dd95SBruce Richardson
1118d007a7f3SPavan Nikhilesh links_map = dev->data->links_map[profile_id];
111999a2dd95SBruce Richardson /* Point links_map to this port specific area */
112099a2dd95SBruce Richardson links_map += (port_id * RTE_EVENT_MAX_QUEUES_PER_DEV);
112199a2dd95SBruce Richardson
112299a2dd95SBruce Richardson if (queues == NULL) {
112399a2dd95SBruce Richardson j = 0;
112499a2dd95SBruce Richardson for (i = 0; i < dev->data->nb_queues; i++) {
112599a2dd95SBruce Richardson if (links_map[i] !=
112699a2dd95SBruce Richardson EVENT_QUEUE_SERVICE_PRIORITY_INVALID) {
112799a2dd95SBruce Richardson all_queues[j] = i;
112899a2dd95SBruce Richardson j++;
112999a2dd95SBruce Richardson }
113099a2dd95SBruce Richardson }
113199a2dd95SBruce Richardson queues = all_queues;
113299a2dd95SBruce Richardson } else {
113399a2dd95SBruce Richardson for (j = 0; j < nb_unlinks; j++) {
113499a2dd95SBruce Richardson if (links_map[queues[j]] ==
113599a2dd95SBruce Richardson EVENT_QUEUE_SERVICE_PRIORITY_INVALID)
113699a2dd95SBruce Richardson break;
113799a2dd95SBruce Richardson }
113899a2dd95SBruce Richardson }
113999a2dd95SBruce Richardson
114099a2dd95SBruce Richardson nb_unlinks = j;
114199a2dd95SBruce Richardson for (i = 0; i < nb_unlinks; i++)
114299a2dd95SBruce Richardson if (queues[i] >= dev->data->nb_queues) {
114399a2dd95SBruce Richardson rte_errno = EINVAL;
114499a2dd95SBruce Richardson return 0;
114599a2dd95SBruce Richardson }
114699a2dd95SBruce Richardson
1147d007a7f3SPavan Nikhilesh if (profile_id)
1148d007a7f3SPavan Nikhilesh diag = (*dev->dev_ops->port_unlink_profile)(dev, dev->data->ports[port_id], queues,
1149d007a7f3SPavan Nikhilesh nb_unlinks, profile_id);
1150d007a7f3SPavan Nikhilesh else
1151d007a7f3SPavan Nikhilesh diag = (*dev->dev_ops->port_unlink)(dev, dev->data->ports[port_id], queues,
1152d007a7f3SPavan Nikhilesh nb_unlinks);
115399a2dd95SBruce Richardson if (diag < 0)
115499a2dd95SBruce Richardson return diag;
115599a2dd95SBruce Richardson
115699a2dd95SBruce Richardson for (i = 0; i < diag; i++)
115799a2dd95SBruce Richardson links_map[queues[i]] = EVENT_QUEUE_SERVICE_PRIORITY_INVALID;
115899a2dd95SBruce Richardson
1159d007a7f3SPavan Nikhilesh rte_eventdev_trace_port_profile_unlink(dev_id, port_id, nb_unlinks, profile_id, diag);
116099a2dd95SBruce Richardson return diag;
116199a2dd95SBruce Richardson }
116299a2dd95SBruce Richardson
116399a2dd95SBruce Richardson int
rte_event_port_unlinks_in_progress(uint8_t dev_id,uint8_t port_id)116499a2dd95SBruce Richardson rte_event_port_unlinks_in_progress(uint8_t dev_id, uint8_t port_id)
116599a2dd95SBruce Richardson {
116699a2dd95SBruce Richardson struct rte_eventdev *dev;
116799a2dd95SBruce Richardson
11687f2d9df6SAmit Prakash Shukla rte_eventdev_trace_port_unlinks_in_progress(dev_id, port_id);
11697f2d9df6SAmit Prakash Shukla
117099a2dd95SBruce Richardson RTE_EVENTDEV_VALID_DEVID_OR_ERR_RET(dev_id, -EINVAL);
117199a2dd95SBruce Richardson dev = &rte_eventdevs[dev_id];
117299a2dd95SBruce Richardson if (!is_valid_port(dev, port_id)) {
117399a2dd95SBruce Richardson RTE_EDEV_LOG_ERR("Invalid port_id=%" PRIu8, port_id);
117499a2dd95SBruce Richardson return -EINVAL;
117599a2dd95SBruce Richardson }
117699a2dd95SBruce Richardson
117799a2dd95SBruce Richardson /* Return 0 if the PMD does not implement unlinks in progress.
117899a2dd95SBruce Richardson * This allows PMDs which handle unlink synchronously to not implement
117999a2dd95SBruce Richardson * this function at all.
118099a2dd95SBruce Richardson */
11818f1d23ecSDavid Marchand if (*dev->dev_ops->port_unlinks_in_progress == NULL)
11828f1d23ecSDavid Marchand return 0;
118399a2dd95SBruce Richardson
118499a2dd95SBruce Richardson return (*dev->dev_ops->port_unlinks_in_progress)(dev,
118599a2dd95SBruce Richardson dev->data->ports[port_id]);
118699a2dd95SBruce Richardson }
118799a2dd95SBruce Richardson
118899a2dd95SBruce Richardson int
rte_event_port_links_get(uint8_t dev_id,uint8_t port_id,uint8_t queues[],uint8_t priorities[])118999a2dd95SBruce Richardson rte_event_port_links_get(uint8_t dev_id, uint8_t port_id,
119099a2dd95SBruce Richardson uint8_t queues[], uint8_t priorities[])
119199a2dd95SBruce Richardson {
119299a2dd95SBruce Richardson struct rte_eventdev *dev;
119399a2dd95SBruce Richardson uint16_t *links_map;
119499a2dd95SBruce Richardson int i, count = 0;
119599a2dd95SBruce Richardson
119699a2dd95SBruce Richardson RTE_EVENTDEV_VALID_DEVID_OR_ERR_RET(dev_id, -EINVAL);
119799a2dd95SBruce Richardson dev = &rte_eventdevs[dev_id];
119899a2dd95SBruce Richardson if (!is_valid_port(dev, port_id)) {
119999a2dd95SBruce Richardson RTE_EDEV_LOG_ERR("Invalid port_id=%" PRIu8, port_id);
120099a2dd95SBruce Richardson return -EINVAL;
120199a2dd95SBruce Richardson }
120299a2dd95SBruce Richardson
1203d007a7f3SPavan Nikhilesh /* Use the default profile_id. */
1204d007a7f3SPavan Nikhilesh links_map = dev->data->links_map[0];
120599a2dd95SBruce Richardson /* Point links_map to this port specific area */
120699a2dd95SBruce Richardson links_map += (port_id * RTE_EVENT_MAX_QUEUES_PER_DEV);
120799a2dd95SBruce Richardson for (i = 0; i < dev->data->nb_queues; i++) {
120899a2dd95SBruce Richardson if (links_map[i] != EVENT_QUEUE_SERVICE_PRIORITY_INVALID) {
120999a2dd95SBruce Richardson queues[count] = i;
121099a2dd95SBruce Richardson priorities[count] = (uint8_t)links_map[i];
121199a2dd95SBruce Richardson ++count;
121299a2dd95SBruce Richardson }
121399a2dd95SBruce Richardson }
12147f2d9df6SAmit Prakash Shukla
12157f2d9df6SAmit Prakash Shukla rte_eventdev_trace_port_links_get(dev_id, port_id, count);
12167f2d9df6SAmit Prakash Shukla
121799a2dd95SBruce Richardson return count;
121899a2dd95SBruce Richardson }
121999a2dd95SBruce Richardson
122099a2dd95SBruce Richardson int
rte_event_port_profile_links_get(uint8_t dev_id,uint8_t port_id,uint8_t queues[],uint8_t priorities[],uint8_t profile_id)1221d007a7f3SPavan Nikhilesh rte_event_port_profile_links_get(uint8_t dev_id, uint8_t port_id, uint8_t queues[],
1222d007a7f3SPavan Nikhilesh uint8_t priorities[], uint8_t profile_id)
1223d007a7f3SPavan Nikhilesh {
1224d007a7f3SPavan Nikhilesh struct rte_event_dev_info info;
1225d007a7f3SPavan Nikhilesh struct rte_eventdev *dev;
1226d007a7f3SPavan Nikhilesh uint16_t *links_map;
1227d007a7f3SPavan Nikhilesh int i, count = 0;
1228d007a7f3SPavan Nikhilesh
1229d007a7f3SPavan Nikhilesh RTE_EVENTDEV_VALID_DEVID_OR_ERR_RET(dev_id, -EINVAL);
1230d007a7f3SPavan Nikhilesh
1231d007a7f3SPavan Nikhilesh dev = &rte_eventdevs[dev_id];
1232d007a7f3SPavan Nikhilesh if (*dev->dev_ops->dev_infos_get == NULL)
1233d007a7f3SPavan Nikhilesh return -ENOTSUP;
1234d007a7f3SPavan Nikhilesh
1235d007a7f3SPavan Nikhilesh (*dev->dev_ops->dev_infos_get)(dev, &info);
1236d007a7f3SPavan Nikhilesh if (profile_id >= RTE_EVENT_MAX_PROFILES_PER_PORT ||
1237d007a7f3SPavan Nikhilesh profile_id >= info.max_profiles_per_port) {
1238d007a7f3SPavan Nikhilesh RTE_EDEV_LOG_ERR("Invalid profile_id=%" PRIu8, profile_id);
1239d007a7f3SPavan Nikhilesh return -EINVAL;
1240d007a7f3SPavan Nikhilesh }
1241d007a7f3SPavan Nikhilesh
1242d007a7f3SPavan Nikhilesh if (!is_valid_port(dev, port_id)) {
1243d007a7f3SPavan Nikhilesh RTE_EDEV_LOG_ERR("Invalid port_id=%" PRIu8, port_id);
1244d007a7f3SPavan Nikhilesh return -EINVAL;
1245d007a7f3SPavan Nikhilesh }
1246d007a7f3SPavan Nikhilesh
1247d007a7f3SPavan Nikhilesh links_map = dev->data->links_map[profile_id];
1248d007a7f3SPavan Nikhilesh /* Point links_map to this port specific area */
1249d007a7f3SPavan Nikhilesh links_map += (port_id * RTE_EVENT_MAX_QUEUES_PER_DEV);
1250d007a7f3SPavan Nikhilesh for (i = 0; i < dev->data->nb_queues; i++) {
1251d007a7f3SPavan Nikhilesh if (links_map[i] != EVENT_QUEUE_SERVICE_PRIORITY_INVALID) {
1252d007a7f3SPavan Nikhilesh queues[count] = i;
1253d007a7f3SPavan Nikhilesh priorities[count] = (uint8_t)links_map[i];
1254d007a7f3SPavan Nikhilesh ++count;
1255d007a7f3SPavan Nikhilesh }
1256d007a7f3SPavan Nikhilesh }
1257d007a7f3SPavan Nikhilesh
1258d007a7f3SPavan Nikhilesh rte_eventdev_trace_port_profile_links_get(dev_id, port_id, profile_id, count);
1259d007a7f3SPavan Nikhilesh
1260d007a7f3SPavan Nikhilesh return count;
1261d007a7f3SPavan Nikhilesh }
1262d007a7f3SPavan Nikhilesh
1263d007a7f3SPavan Nikhilesh int
rte_event_dequeue_timeout_ticks(uint8_t dev_id,uint64_t ns,uint64_t * timeout_ticks)126499a2dd95SBruce Richardson rte_event_dequeue_timeout_ticks(uint8_t dev_id, uint64_t ns,
126599a2dd95SBruce Richardson uint64_t *timeout_ticks)
126699a2dd95SBruce Richardson {
126799a2dd95SBruce Richardson struct rte_eventdev *dev;
126899a2dd95SBruce Richardson
12697f2d9df6SAmit Prakash Shukla rte_eventdev_trace_dequeue_timeout_ticks(dev_id, ns, timeout_ticks);
12707f2d9df6SAmit Prakash Shukla
127199a2dd95SBruce Richardson RTE_EVENTDEV_VALID_DEVID_OR_ERR_RET(dev_id, -EINVAL);
127299a2dd95SBruce Richardson dev = &rte_eventdevs[dev_id];
12738f1d23ecSDavid Marchand if (*dev->dev_ops->timeout_ticks == NULL)
12748f1d23ecSDavid Marchand return -ENOTSUP;
127599a2dd95SBruce Richardson
127699a2dd95SBruce Richardson if (timeout_ticks == NULL)
127799a2dd95SBruce Richardson return -EINVAL;
127899a2dd95SBruce Richardson
127999a2dd95SBruce Richardson return (*dev->dev_ops->timeout_ticks)(dev, ns, timeout_ticks);
128099a2dd95SBruce Richardson }
128199a2dd95SBruce Richardson
128299a2dd95SBruce Richardson int
rte_event_dev_service_id_get(uint8_t dev_id,uint32_t * service_id)128399a2dd95SBruce Richardson rte_event_dev_service_id_get(uint8_t dev_id, uint32_t *service_id)
128499a2dd95SBruce Richardson {
128599a2dd95SBruce Richardson struct rte_eventdev *dev;
128699a2dd95SBruce Richardson
128799a2dd95SBruce Richardson RTE_EVENTDEV_VALID_DEVID_OR_ERR_RET(dev_id, -EINVAL);
128899a2dd95SBruce Richardson dev = &rte_eventdevs[dev_id];
128999a2dd95SBruce Richardson
129099a2dd95SBruce Richardson if (service_id == NULL)
129199a2dd95SBruce Richardson return -EINVAL;
129299a2dd95SBruce Richardson
129399a2dd95SBruce Richardson if (dev->data->service_inited)
129499a2dd95SBruce Richardson *service_id = dev->data->service_id;
129599a2dd95SBruce Richardson
12967f2d9df6SAmit Prakash Shukla rte_eventdev_trace_service_id_get(dev_id, *service_id);
12977f2d9df6SAmit Prakash Shukla
129899a2dd95SBruce Richardson return dev->data->service_inited ? 0 : -ESRCH;
129999a2dd95SBruce Richardson }
130099a2dd95SBruce Richardson
130199a2dd95SBruce Richardson int
rte_event_dev_dump(uint8_t dev_id,FILE * f)130299a2dd95SBruce Richardson rte_event_dev_dump(uint8_t dev_id, FILE *f)
130399a2dd95SBruce Richardson {
130499a2dd95SBruce Richardson struct rte_eventdev *dev;
130599a2dd95SBruce Richardson
130699a2dd95SBruce Richardson RTE_EVENTDEV_VALID_DEVID_OR_ERR_RET(dev_id, -EINVAL);
130799a2dd95SBruce Richardson dev = &rte_eventdevs[dev_id];
13088f1d23ecSDavid Marchand if (*dev->dev_ops->dump == NULL)
13098f1d23ecSDavid Marchand return -ENOTSUP;
131099a2dd95SBruce Richardson if (f == NULL)
131199a2dd95SBruce Richardson return -EINVAL;
131299a2dd95SBruce Richardson
131399a2dd95SBruce Richardson (*dev->dev_ops->dump)(dev, f);
131499a2dd95SBruce Richardson return 0;
131599a2dd95SBruce Richardson
131699a2dd95SBruce Richardson }
131799a2dd95SBruce Richardson
131899a2dd95SBruce Richardson static int
xstats_get_count(uint8_t dev_id,enum rte_event_dev_xstats_mode mode,uint8_t queue_port_id)131999a2dd95SBruce Richardson xstats_get_count(uint8_t dev_id, enum rte_event_dev_xstats_mode mode,
132099a2dd95SBruce Richardson uint8_t queue_port_id)
132199a2dd95SBruce Richardson {
132299a2dd95SBruce Richardson struct rte_eventdev *dev = &rte_eventdevs[dev_id];
132399a2dd95SBruce Richardson if (dev->dev_ops->xstats_get_names != NULL)
132499a2dd95SBruce Richardson return (*dev->dev_ops->xstats_get_names)(dev, mode,
132599a2dd95SBruce Richardson queue_port_id,
132699a2dd95SBruce Richardson NULL, NULL, 0);
132799a2dd95SBruce Richardson return 0;
132899a2dd95SBruce Richardson }
132999a2dd95SBruce Richardson
133099a2dd95SBruce 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,uint64_t * ids,unsigned int size)133199a2dd95SBruce Richardson rte_event_dev_xstats_names_get(uint8_t dev_id,
133299a2dd95SBruce Richardson enum rte_event_dev_xstats_mode mode, uint8_t queue_port_id,
133399a2dd95SBruce Richardson struct rte_event_dev_xstats_name *xstats_names,
13341bdfe4d7SPavan Nikhilesh uint64_t *ids, unsigned int size)
133599a2dd95SBruce Richardson {
133699a2dd95SBruce Richardson RTE_EVENTDEV_VALID_DEVID_OR_ERR_RET(dev_id, -ENODEV);
133799a2dd95SBruce Richardson const int cnt_expected_entries = xstats_get_count(dev_id, mode,
133899a2dd95SBruce Richardson queue_port_id);
133999a2dd95SBruce Richardson if (xstats_names == NULL || cnt_expected_entries < 0 ||
134099a2dd95SBruce Richardson (int)size < cnt_expected_entries)
134199a2dd95SBruce Richardson return cnt_expected_entries;
134299a2dd95SBruce Richardson
134399a2dd95SBruce Richardson /* dev_id checked above */
134499a2dd95SBruce Richardson const struct rte_eventdev *dev = &rte_eventdevs[dev_id];
134599a2dd95SBruce Richardson
134699a2dd95SBruce Richardson if (dev->dev_ops->xstats_get_names != NULL)
134799a2dd95SBruce Richardson return (*dev->dev_ops->xstats_get_names)(dev, mode,
134899a2dd95SBruce Richardson queue_port_id, xstats_names, ids, size);
134999a2dd95SBruce Richardson
135099a2dd95SBruce Richardson return -ENOTSUP;
135199a2dd95SBruce Richardson }
135299a2dd95SBruce Richardson
135399a2dd95SBruce Richardson /* retrieve eventdev extended statistics */
135499a2dd95SBruce Richardson int
rte_event_dev_xstats_get(uint8_t dev_id,enum rte_event_dev_xstats_mode mode,uint8_t queue_port_id,const uint64_t ids[],uint64_t values[],unsigned int n)135599a2dd95SBruce Richardson rte_event_dev_xstats_get(uint8_t dev_id, enum rte_event_dev_xstats_mode mode,
13561bdfe4d7SPavan Nikhilesh uint8_t queue_port_id, const uint64_t ids[],
135799a2dd95SBruce Richardson uint64_t values[], unsigned int n)
135899a2dd95SBruce Richardson {
135999a2dd95SBruce Richardson RTE_EVENTDEV_VALID_DEVID_OR_ERR_RET(dev_id, -ENODEV);
136099a2dd95SBruce Richardson const struct rte_eventdev *dev = &rte_eventdevs[dev_id];
136199a2dd95SBruce Richardson
136299a2dd95SBruce Richardson /* implemented by the driver */
136399a2dd95SBruce Richardson if (dev->dev_ops->xstats_get != NULL)
136499a2dd95SBruce Richardson return (*dev->dev_ops->xstats_get)(dev, mode, queue_port_id,
136599a2dd95SBruce Richardson ids, values, n);
136699a2dd95SBruce Richardson return -ENOTSUP;
136799a2dd95SBruce Richardson }
136899a2dd95SBruce Richardson
136999a2dd95SBruce Richardson uint64_t
rte_event_dev_xstats_by_name_get(uint8_t dev_id,const char * name,uint64_t * id)137099a2dd95SBruce Richardson rte_event_dev_xstats_by_name_get(uint8_t dev_id, const char *name,
13711bdfe4d7SPavan Nikhilesh uint64_t *id)
137299a2dd95SBruce Richardson {
137399a2dd95SBruce Richardson RTE_EVENTDEV_VALID_DEVID_OR_ERR_RET(dev_id, 0);
137499a2dd95SBruce Richardson const struct rte_eventdev *dev = &rte_eventdevs[dev_id];
13751bdfe4d7SPavan Nikhilesh uint64_t temp = -1;
137699a2dd95SBruce Richardson
137799a2dd95SBruce Richardson if (id != NULL)
137899a2dd95SBruce Richardson *id = (unsigned int)-1;
137999a2dd95SBruce Richardson else
138099a2dd95SBruce Richardson id = &temp; /* ensure driver never gets a NULL value */
138199a2dd95SBruce Richardson
138299a2dd95SBruce Richardson /* implemented by driver */
138399a2dd95SBruce Richardson if (dev->dev_ops->xstats_get_by_name != NULL)
138499a2dd95SBruce Richardson return (*dev->dev_ops->xstats_get_by_name)(dev, name, id);
138599a2dd95SBruce Richardson return -ENOTSUP;
138699a2dd95SBruce Richardson }
138799a2dd95SBruce Richardson
rte_event_dev_xstats_reset(uint8_t dev_id,enum rte_event_dev_xstats_mode mode,int16_t queue_port_id,const uint64_t ids[],uint32_t nb_ids)138899a2dd95SBruce Richardson int rte_event_dev_xstats_reset(uint8_t dev_id,
138999a2dd95SBruce Richardson enum rte_event_dev_xstats_mode mode, int16_t queue_port_id,
13901bdfe4d7SPavan Nikhilesh const uint64_t ids[], uint32_t nb_ids)
139199a2dd95SBruce Richardson {
139299a2dd95SBruce Richardson RTE_EVENTDEV_VALID_DEVID_OR_ERR_RET(dev_id, -EINVAL);
139399a2dd95SBruce Richardson struct rte_eventdev *dev = &rte_eventdevs[dev_id];
139499a2dd95SBruce Richardson
139599a2dd95SBruce Richardson if (dev->dev_ops->xstats_reset != NULL)
139699a2dd95SBruce Richardson return (*dev->dev_ops->xstats_reset)(dev, mode, queue_port_id,
139799a2dd95SBruce Richardson ids, nb_ids);
139899a2dd95SBruce Richardson return -ENOTSUP;
139999a2dd95SBruce Richardson }
140099a2dd95SBruce Richardson
140199a2dd95SBruce Richardson int rte_event_pmd_selftest_seqn_dynfield_offset = -1;
140299a2dd95SBruce Richardson
rte_event_dev_selftest(uint8_t dev_id)140399a2dd95SBruce Richardson int rte_event_dev_selftest(uint8_t dev_id)
140499a2dd95SBruce Richardson {
140599a2dd95SBruce Richardson RTE_EVENTDEV_VALID_DEVID_OR_ERR_RET(dev_id, -EINVAL);
140699a2dd95SBruce Richardson static const struct rte_mbuf_dynfield test_seqn_dynfield_desc = {
140799a2dd95SBruce Richardson .name = "rte_event_pmd_selftest_seqn_dynfield",
140899a2dd95SBruce Richardson .size = sizeof(rte_event_pmd_selftest_seqn_t),
140908966fe7STyler Retzlaff .align = alignof(rte_event_pmd_selftest_seqn_t),
141099a2dd95SBruce Richardson };
141199a2dd95SBruce Richardson struct rte_eventdev *dev = &rte_eventdevs[dev_id];
141299a2dd95SBruce Richardson
141399a2dd95SBruce Richardson if (dev->dev_ops->dev_selftest != NULL) {
141499a2dd95SBruce Richardson rte_event_pmd_selftest_seqn_dynfield_offset =
141599a2dd95SBruce Richardson rte_mbuf_dynfield_register(&test_seqn_dynfield_desc);
141699a2dd95SBruce Richardson if (rte_event_pmd_selftest_seqn_dynfield_offset < 0)
141799a2dd95SBruce Richardson return -ENOMEM;
141899a2dd95SBruce Richardson return (*dev->dev_ops->dev_selftest)();
141999a2dd95SBruce Richardson }
142099a2dd95SBruce Richardson return -ENOTSUP;
142199a2dd95SBruce Richardson }
142299a2dd95SBruce Richardson
142399a2dd95SBruce 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)142499a2dd95SBruce Richardson rte_event_vector_pool_create(const char *name, unsigned int n,
142599a2dd95SBruce Richardson unsigned int cache_size, uint16_t nb_elem,
142699a2dd95SBruce Richardson int socket_id)
142799a2dd95SBruce Richardson {
142899a2dd95SBruce Richardson const char *mp_ops_name;
142999a2dd95SBruce Richardson struct rte_mempool *mp;
143099a2dd95SBruce Richardson unsigned int elt_sz;
143199a2dd95SBruce Richardson int ret;
143299a2dd95SBruce Richardson
143399a2dd95SBruce Richardson if (!nb_elem) {
1434c07da8e3SDavid Marchand RTE_EDEV_LOG_ERR("Invalid number of elements=%d requested",
1435c07da8e3SDavid Marchand nb_elem);
143699a2dd95SBruce Richardson rte_errno = EINVAL;
143799a2dd95SBruce Richardson return NULL;
143899a2dd95SBruce Richardson }
143999a2dd95SBruce Richardson
144099a2dd95SBruce Richardson elt_sz =
144199a2dd95SBruce Richardson sizeof(struct rte_event_vector) + (nb_elem * sizeof(uintptr_t));
144299a2dd95SBruce Richardson mp = rte_mempool_create_empty(name, n, elt_sz, cache_size, 0, socket_id,
144399a2dd95SBruce Richardson 0);
144499a2dd95SBruce Richardson if (mp == NULL)
144599a2dd95SBruce Richardson return NULL;
144699a2dd95SBruce Richardson
144799a2dd95SBruce Richardson mp_ops_name = rte_mbuf_best_mempool_ops();
144899a2dd95SBruce Richardson ret = rte_mempool_set_ops_byname(mp, mp_ops_name, NULL);
144999a2dd95SBruce Richardson if (ret != 0) {
1450c07da8e3SDavid Marchand RTE_EDEV_LOG_ERR("error setting mempool handler");
145199a2dd95SBruce Richardson goto err;
145299a2dd95SBruce Richardson }
145399a2dd95SBruce Richardson
145499a2dd95SBruce Richardson ret = rte_mempool_populate_default(mp);
145599a2dd95SBruce Richardson if (ret < 0)
145699a2dd95SBruce Richardson goto err;
145799a2dd95SBruce Richardson
14587f2d9df6SAmit Prakash Shukla rte_eventdev_trace_vector_pool_create(mp, mp->name, mp->socket_id,
14597f2d9df6SAmit Prakash Shukla mp->size, mp->cache_size, mp->elt_size);
14607f2d9df6SAmit Prakash Shukla
146199a2dd95SBruce Richardson return mp;
146299a2dd95SBruce Richardson err:
146399a2dd95SBruce Richardson rte_mempool_free(mp);
146499a2dd95SBruce Richardson rte_errno = -ret;
146599a2dd95SBruce Richardson return NULL;
146699a2dd95SBruce Richardson }
146799a2dd95SBruce Richardson
146899a2dd95SBruce Richardson int
rte_event_dev_start(uint8_t dev_id)146999a2dd95SBruce Richardson rte_event_dev_start(uint8_t dev_id)
147099a2dd95SBruce Richardson {
147199a2dd95SBruce Richardson struct rte_eventdev *dev;
147299a2dd95SBruce Richardson int diag;
147399a2dd95SBruce Richardson
147499a2dd95SBruce Richardson RTE_EDEV_LOG_DEBUG("Start dev_id=%" PRIu8, dev_id);
147599a2dd95SBruce Richardson
147699a2dd95SBruce Richardson RTE_EVENTDEV_VALID_DEVID_OR_ERR_RET(dev_id, -EINVAL);
147799a2dd95SBruce Richardson dev = &rte_eventdevs[dev_id];
14788f1d23ecSDavid Marchand if (*dev->dev_ops->dev_start == NULL)
14798f1d23ecSDavid Marchand return -ENOTSUP;
148099a2dd95SBruce Richardson
148199a2dd95SBruce Richardson if (dev->data->dev_started != 0) {
148299a2dd95SBruce Richardson RTE_EDEV_LOG_ERR("Device with dev_id=%" PRIu8 "already started",
148399a2dd95SBruce Richardson dev_id);
148499a2dd95SBruce Richardson return 0;
148599a2dd95SBruce Richardson }
148699a2dd95SBruce Richardson
148799a2dd95SBruce Richardson diag = (*dev->dev_ops->dev_start)(dev);
148899a2dd95SBruce Richardson rte_eventdev_trace_start(dev_id, diag);
148999a2dd95SBruce Richardson if (diag == 0)
149099a2dd95SBruce Richardson dev->data->dev_started = 1;
149199a2dd95SBruce Richardson else
149299a2dd95SBruce Richardson return diag;
149399a2dd95SBruce Richardson
1494d35e6132SPavan Nikhilesh event_dev_fp_ops_set(rte_event_fp_ops + dev_id, dev);
1495d35e6132SPavan Nikhilesh
149699a2dd95SBruce Richardson return 0;
149799a2dd95SBruce Richardson }
149899a2dd95SBruce Richardson
149999a2dd95SBruce Richardson int
rte_event_dev_stop_flush_callback_register(uint8_t dev_id,rte_eventdev_stop_flush_t callback,void * userdata)150099a2dd95SBruce Richardson rte_event_dev_stop_flush_callback_register(uint8_t dev_id,
1501d986276fSPavan Nikhilesh rte_eventdev_stop_flush_t callback,
1502d986276fSPavan Nikhilesh void *userdata)
150399a2dd95SBruce Richardson {
150499a2dd95SBruce Richardson struct rte_eventdev *dev;
150599a2dd95SBruce Richardson
150699a2dd95SBruce Richardson RTE_EDEV_LOG_DEBUG("Stop flush register dev_id=%" PRIu8, dev_id);
150799a2dd95SBruce Richardson
15087f2d9df6SAmit Prakash Shukla rte_eventdev_trace_stop_flush_callback_register(dev_id, callback, userdata);
15097f2d9df6SAmit Prakash Shukla
151099a2dd95SBruce Richardson RTE_EVENTDEV_VALID_DEVID_OR_ERR_RET(dev_id, -EINVAL);
151199a2dd95SBruce Richardson dev = &rte_eventdevs[dev_id];
151299a2dd95SBruce Richardson
151399a2dd95SBruce Richardson dev->dev_ops->dev_stop_flush = callback;
151499a2dd95SBruce Richardson dev->data->dev_stop_flush_arg = userdata;
151599a2dd95SBruce Richardson
151699a2dd95SBruce Richardson return 0;
151799a2dd95SBruce Richardson }
151899a2dd95SBruce Richardson
151999a2dd95SBruce Richardson void
rte_event_dev_stop(uint8_t dev_id)152099a2dd95SBruce Richardson rte_event_dev_stop(uint8_t dev_id)
152199a2dd95SBruce Richardson {
152299a2dd95SBruce Richardson struct rte_eventdev *dev;
152399a2dd95SBruce Richardson
152499a2dd95SBruce Richardson RTE_EDEV_LOG_DEBUG("Stop dev_id=%" PRIu8, dev_id);
152599a2dd95SBruce Richardson
152699a2dd95SBruce Richardson RTE_EVENTDEV_VALID_DEVID_OR_RET(dev_id);
152799a2dd95SBruce Richardson dev = &rte_eventdevs[dev_id];
15288f1d23ecSDavid Marchand if (*dev->dev_ops->dev_stop == NULL)
15298f1d23ecSDavid Marchand return;
153099a2dd95SBruce Richardson
153199a2dd95SBruce Richardson if (dev->data->dev_started == 0) {
153299a2dd95SBruce Richardson RTE_EDEV_LOG_ERR("Device with dev_id=%" PRIu8 "already stopped",
153399a2dd95SBruce Richardson dev_id);
153499a2dd95SBruce Richardson return;
153599a2dd95SBruce Richardson }
153699a2dd95SBruce Richardson
153799a2dd95SBruce Richardson dev->data->dev_started = 0;
153899a2dd95SBruce Richardson (*dev->dev_ops->dev_stop)(dev);
153999a2dd95SBruce Richardson rte_eventdev_trace_stop(dev_id);
1540d35e6132SPavan Nikhilesh event_dev_fp_ops_reset(rte_event_fp_ops + dev_id);
154199a2dd95SBruce Richardson }
154299a2dd95SBruce Richardson
154399a2dd95SBruce Richardson int
rte_event_dev_close(uint8_t dev_id)154499a2dd95SBruce Richardson rte_event_dev_close(uint8_t dev_id)
154599a2dd95SBruce Richardson {
154699a2dd95SBruce Richardson struct rte_eventdev *dev;
154799a2dd95SBruce Richardson
154899a2dd95SBruce Richardson RTE_EVENTDEV_VALID_DEVID_OR_ERR_RET(dev_id, -EINVAL);
154999a2dd95SBruce Richardson dev = &rte_eventdevs[dev_id];
15508f1d23ecSDavid Marchand if (*dev->dev_ops->dev_close == NULL)
15518f1d23ecSDavid Marchand return -ENOTSUP;
155299a2dd95SBruce Richardson
155399a2dd95SBruce Richardson /* Device must be stopped before it can be closed */
155499a2dd95SBruce Richardson if (dev->data->dev_started == 1) {
155599a2dd95SBruce Richardson RTE_EDEV_LOG_ERR("Device %u must be stopped before closing",
155699a2dd95SBruce Richardson dev_id);
155799a2dd95SBruce Richardson return -EBUSY;
155899a2dd95SBruce Richardson }
155999a2dd95SBruce Richardson
1560d35e6132SPavan Nikhilesh event_dev_fp_ops_reset(rte_event_fp_ops + dev_id);
156199a2dd95SBruce Richardson rte_eventdev_trace_close(dev_id);
156299a2dd95SBruce Richardson return (*dev->dev_ops->dev_close)(dev);
156399a2dd95SBruce Richardson }
156499a2dd95SBruce Richardson
156599a2dd95SBruce Richardson static inline int
eventdev_data_alloc(uint8_t dev_id,struct rte_eventdev_data ** data,int socket_id)15669c67fcbfSPavan Nikhilesh eventdev_data_alloc(uint8_t dev_id, struct rte_eventdev_data **data,
156799a2dd95SBruce Richardson int socket_id)
156899a2dd95SBruce Richardson {
156999a2dd95SBruce Richardson char mz_name[RTE_EVENTDEV_NAME_MAX_LEN];
157099a2dd95SBruce Richardson const struct rte_memzone *mz;
1571d007a7f3SPavan Nikhilesh int i, n;
157299a2dd95SBruce Richardson
157399a2dd95SBruce Richardson /* Generate memzone name */
157499a2dd95SBruce Richardson n = snprintf(mz_name, sizeof(mz_name), "rte_eventdev_data_%u", dev_id);
157599a2dd95SBruce Richardson if (n >= (int)sizeof(mz_name))
157699a2dd95SBruce Richardson return -EINVAL;
157799a2dd95SBruce Richardson
157899a2dd95SBruce Richardson if (rte_eal_process_type() == RTE_PROC_PRIMARY) {
157999a2dd95SBruce Richardson mz = rte_memzone_reserve(mz_name,
158099a2dd95SBruce Richardson sizeof(struct rte_eventdev_data),
158199a2dd95SBruce Richardson socket_id, 0);
158299a2dd95SBruce Richardson } else
158399a2dd95SBruce Richardson mz = rte_memzone_lookup(mz_name);
158499a2dd95SBruce Richardson
158599a2dd95SBruce Richardson if (mz == NULL)
158699a2dd95SBruce Richardson return -ENOMEM;
158799a2dd95SBruce Richardson
158899a2dd95SBruce Richardson *data = mz->addr;
15899c67fcbfSPavan Nikhilesh if (rte_eal_process_type() == RTE_PROC_PRIMARY) {
159099a2dd95SBruce Richardson memset(*data, 0, sizeof(struct rte_eventdev_data));
1591d007a7f3SPavan Nikhilesh for (i = 0; i < RTE_EVENT_MAX_PROFILES_PER_PORT; i++)
1592d007a7f3SPavan Nikhilesh for (n = 0; n < RTE_EVENT_MAX_PORTS_PER_DEV * RTE_EVENT_MAX_QUEUES_PER_DEV;
15939c67fcbfSPavan Nikhilesh n++)
1594d007a7f3SPavan Nikhilesh (*data)->links_map[i][n] = EVENT_QUEUE_SERVICE_PRIORITY_INVALID;
15959c67fcbfSPavan Nikhilesh }
159699a2dd95SBruce Richardson
159799a2dd95SBruce Richardson return 0;
159899a2dd95SBruce Richardson }
159999a2dd95SBruce Richardson
160099a2dd95SBruce Richardson static inline uint8_t
eventdev_find_free_device_index(void)16019c67fcbfSPavan Nikhilesh eventdev_find_free_device_index(void)
160299a2dd95SBruce Richardson {
160399a2dd95SBruce Richardson uint8_t dev_id;
160499a2dd95SBruce Richardson
160599a2dd95SBruce Richardson for (dev_id = 0; dev_id < RTE_EVENT_MAX_DEVS; dev_id++) {
160699a2dd95SBruce Richardson if (rte_eventdevs[dev_id].attached ==
160799a2dd95SBruce Richardson RTE_EVENTDEV_DETACHED)
160899a2dd95SBruce Richardson return dev_id;
160999a2dd95SBruce Richardson }
161099a2dd95SBruce Richardson return RTE_EVENT_MAX_DEVS;
161199a2dd95SBruce Richardson }
161299a2dd95SBruce Richardson
161399a2dd95SBruce Richardson struct rte_eventdev *
rte_event_pmd_allocate(const char * name,int socket_id)161499a2dd95SBruce Richardson rte_event_pmd_allocate(const char *name, int socket_id)
161599a2dd95SBruce Richardson {
161699a2dd95SBruce Richardson struct rte_eventdev *eventdev;
161799a2dd95SBruce Richardson uint8_t dev_id;
161899a2dd95SBruce Richardson
161999a2dd95SBruce Richardson if (rte_event_pmd_get_named_dev(name) != NULL) {
162099a2dd95SBruce Richardson RTE_EDEV_LOG_ERR("Event device with name %s already "
162199a2dd95SBruce Richardson "allocated!", name);
162299a2dd95SBruce Richardson return NULL;
162399a2dd95SBruce Richardson }
162499a2dd95SBruce Richardson
16259c67fcbfSPavan Nikhilesh dev_id = eventdev_find_free_device_index();
162699a2dd95SBruce Richardson if (dev_id == RTE_EVENT_MAX_DEVS) {
162799a2dd95SBruce Richardson RTE_EDEV_LOG_ERR("Reached maximum number of event devices");
162899a2dd95SBruce Richardson return NULL;
162999a2dd95SBruce Richardson }
163099a2dd95SBruce Richardson
163199a2dd95SBruce Richardson eventdev = &rte_eventdevs[dev_id];
163299a2dd95SBruce Richardson
163399a2dd95SBruce Richardson if (eventdev->data == NULL) {
163499a2dd95SBruce Richardson struct rte_eventdev_data *eventdev_data = NULL;
163599a2dd95SBruce Richardson
16369c67fcbfSPavan Nikhilesh int retval =
16379c67fcbfSPavan Nikhilesh eventdev_data_alloc(dev_id, &eventdev_data, socket_id);
163899a2dd95SBruce Richardson
163999a2dd95SBruce Richardson if (retval < 0 || eventdev_data == NULL)
164099a2dd95SBruce Richardson return NULL;
164199a2dd95SBruce Richardson
164299a2dd95SBruce Richardson eventdev->data = eventdev_data;
164399a2dd95SBruce Richardson
164499a2dd95SBruce Richardson if (rte_eal_process_type() == RTE_PROC_PRIMARY) {
164599a2dd95SBruce Richardson
164699a2dd95SBruce Richardson strlcpy(eventdev->data->name, name,
164799a2dd95SBruce Richardson RTE_EVENTDEV_NAME_MAX_LEN);
164899a2dd95SBruce Richardson
164999a2dd95SBruce Richardson eventdev->data->dev_id = dev_id;
165099a2dd95SBruce Richardson eventdev->data->socket_id = socket_id;
165199a2dd95SBruce Richardson eventdev->data->dev_started = 0;
165299a2dd95SBruce Richardson }
165399a2dd95SBruce Richardson
165499a2dd95SBruce Richardson eventdev->attached = RTE_EVENTDEV_ATTACHED;
165599a2dd95SBruce Richardson eventdev_globals.nb_devs++;
165699a2dd95SBruce Richardson }
165799a2dd95SBruce Richardson
165899a2dd95SBruce Richardson return eventdev;
165999a2dd95SBruce Richardson }
166099a2dd95SBruce Richardson
166199a2dd95SBruce Richardson int
rte_event_pmd_release(struct rte_eventdev * eventdev)166299a2dd95SBruce Richardson rte_event_pmd_release(struct rte_eventdev *eventdev)
166399a2dd95SBruce Richardson {
166499a2dd95SBruce Richardson int ret;
166599a2dd95SBruce Richardson char mz_name[RTE_EVENTDEV_NAME_MAX_LEN];
166699a2dd95SBruce Richardson const struct rte_memzone *mz;
166799a2dd95SBruce Richardson
166899a2dd95SBruce Richardson if (eventdev == NULL)
166999a2dd95SBruce Richardson return -EINVAL;
167099a2dd95SBruce Richardson
1671d35e6132SPavan Nikhilesh event_dev_fp_ops_reset(rte_event_fp_ops + eventdev->data->dev_id);
167299a2dd95SBruce Richardson eventdev->attached = RTE_EVENTDEV_DETACHED;
167399a2dd95SBruce Richardson eventdev_globals.nb_devs--;
167499a2dd95SBruce Richardson
167599a2dd95SBruce Richardson if (rte_eal_process_type() == RTE_PROC_PRIMARY) {
167699a2dd95SBruce Richardson rte_free(eventdev->data->dev_private);
167799a2dd95SBruce Richardson
167899a2dd95SBruce Richardson /* Generate memzone name */
167999a2dd95SBruce Richardson ret = snprintf(mz_name, sizeof(mz_name), "rte_eventdev_data_%u",
168099a2dd95SBruce Richardson eventdev->data->dev_id);
168199a2dd95SBruce Richardson if (ret >= (int)sizeof(mz_name))
168299a2dd95SBruce Richardson return -EINVAL;
168399a2dd95SBruce Richardson
168499a2dd95SBruce Richardson mz = rte_memzone_lookup(mz_name);
168599a2dd95SBruce Richardson if (mz == NULL)
168699a2dd95SBruce Richardson return -ENOMEM;
168799a2dd95SBruce Richardson
168899a2dd95SBruce Richardson ret = rte_memzone_free(mz);
168999a2dd95SBruce Richardson if (ret)
169099a2dd95SBruce Richardson return ret;
169199a2dd95SBruce Richardson }
169299a2dd95SBruce Richardson
169399a2dd95SBruce Richardson eventdev->data = NULL;
169499a2dd95SBruce Richardson return 0;
169599a2dd95SBruce Richardson }
169699a2dd95SBruce Richardson
1697d35e6132SPavan Nikhilesh void
event_dev_probing_finish(struct rte_eventdev * eventdev)1698d35e6132SPavan Nikhilesh event_dev_probing_finish(struct rte_eventdev *eventdev)
1699d35e6132SPavan Nikhilesh {
1700d35e6132SPavan Nikhilesh if (eventdev == NULL)
1701d35e6132SPavan Nikhilesh return;
1702d35e6132SPavan Nikhilesh
1703d35e6132SPavan Nikhilesh event_dev_fp_ops_set(rte_event_fp_ops + eventdev->data->dev_id,
1704d35e6132SPavan Nikhilesh eventdev);
1705d35e6132SPavan Nikhilesh }
170699a2dd95SBruce Richardson
170799a2dd95SBruce Richardson static int
handle_dev_list(const char * cmd __rte_unused,const char * params __rte_unused,struct rte_tel_data * d)170899a2dd95SBruce Richardson handle_dev_list(const char *cmd __rte_unused,
170999a2dd95SBruce Richardson const char *params __rte_unused,
171099a2dd95SBruce Richardson struct rte_tel_data *d)
171199a2dd95SBruce Richardson {
171299a2dd95SBruce Richardson uint8_t dev_id;
171399a2dd95SBruce Richardson int ndev = rte_event_dev_count();
171499a2dd95SBruce Richardson
171599a2dd95SBruce Richardson if (ndev < 1)
171699a2dd95SBruce Richardson return -1;
171799a2dd95SBruce Richardson
171899a2dd95SBruce Richardson rte_tel_data_start_array(d, RTE_TEL_INT_VAL);
171999a2dd95SBruce Richardson for (dev_id = 0; dev_id < RTE_EVENT_MAX_DEVS; dev_id++) {
172099a2dd95SBruce Richardson if (rte_eventdevs[dev_id].attached ==
172199a2dd95SBruce Richardson RTE_EVENTDEV_ATTACHED)
172299a2dd95SBruce Richardson rte_tel_data_add_array_int(d, dev_id);
172399a2dd95SBruce Richardson }
172499a2dd95SBruce Richardson
172599a2dd95SBruce Richardson return 0;
172699a2dd95SBruce Richardson }
172799a2dd95SBruce Richardson
172899a2dd95SBruce Richardson static int
handle_port_list(const char * cmd __rte_unused,const char * params,struct rte_tel_data * d)172999a2dd95SBruce Richardson handle_port_list(const char *cmd __rte_unused,
173099a2dd95SBruce Richardson const char *params,
173199a2dd95SBruce Richardson struct rte_tel_data *d)
173299a2dd95SBruce Richardson {
173399a2dd95SBruce Richardson int i;
173499a2dd95SBruce Richardson uint8_t dev_id;
173599a2dd95SBruce Richardson struct rte_eventdev *dev;
173699a2dd95SBruce Richardson char *end_param;
173799a2dd95SBruce Richardson
173899a2dd95SBruce Richardson if (params == NULL || strlen(params) == 0 || !isdigit(*params))
173999a2dd95SBruce Richardson return -1;
174099a2dd95SBruce Richardson
174199a2dd95SBruce Richardson dev_id = strtoul(params, &end_param, 10);
174299a2dd95SBruce Richardson if (*end_param != '\0')
174399a2dd95SBruce Richardson RTE_EDEV_LOG_DEBUG(
174499a2dd95SBruce Richardson "Extra parameters passed to eventdev telemetry command, ignoring");
174599a2dd95SBruce Richardson
174699a2dd95SBruce Richardson RTE_EVENTDEV_VALID_DEVID_OR_ERR_RET(dev_id, -EINVAL);
174799a2dd95SBruce Richardson dev = &rte_eventdevs[dev_id];
174899a2dd95SBruce Richardson
174999a2dd95SBruce Richardson rte_tel_data_start_array(d, RTE_TEL_INT_VAL);
175099a2dd95SBruce Richardson for (i = 0; i < dev->data->nb_ports; i++)
175199a2dd95SBruce Richardson rte_tel_data_add_array_int(d, i);
175299a2dd95SBruce Richardson
175399a2dd95SBruce Richardson return 0;
175499a2dd95SBruce Richardson }
175599a2dd95SBruce Richardson
175699a2dd95SBruce Richardson static int
handle_queue_list(const char * cmd __rte_unused,const char * params,struct rte_tel_data * d)175799a2dd95SBruce Richardson handle_queue_list(const char *cmd __rte_unused,
175899a2dd95SBruce Richardson const char *params,
175999a2dd95SBruce Richardson struct rte_tel_data *d)
176099a2dd95SBruce Richardson {
176199a2dd95SBruce Richardson int i;
176299a2dd95SBruce Richardson uint8_t dev_id;
176399a2dd95SBruce Richardson struct rte_eventdev *dev;
176499a2dd95SBruce Richardson char *end_param;
176599a2dd95SBruce Richardson
176699a2dd95SBruce Richardson if (params == NULL || strlen(params) == 0 || !isdigit(*params))
176799a2dd95SBruce Richardson return -1;
176899a2dd95SBruce Richardson
176999a2dd95SBruce Richardson dev_id = strtoul(params, &end_param, 10);
177099a2dd95SBruce Richardson if (*end_param != '\0')
177199a2dd95SBruce Richardson RTE_EDEV_LOG_DEBUG(
177299a2dd95SBruce Richardson "Extra parameters passed to eventdev telemetry command, ignoring");
177399a2dd95SBruce Richardson
177499a2dd95SBruce Richardson RTE_EVENTDEV_VALID_DEVID_OR_ERR_RET(dev_id, -EINVAL);
177599a2dd95SBruce Richardson dev = &rte_eventdevs[dev_id];
177699a2dd95SBruce Richardson
177799a2dd95SBruce Richardson rte_tel_data_start_array(d, RTE_TEL_INT_VAL);
177899a2dd95SBruce Richardson for (i = 0; i < dev->data->nb_queues; i++)
177999a2dd95SBruce Richardson rte_tel_data_add_array_int(d, i);
178099a2dd95SBruce Richardson
178199a2dd95SBruce Richardson return 0;
178299a2dd95SBruce Richardson }
178399a2dd95SBruce Richardson
178499a2dd95SBruce Richardson static int
handle_queue_links(const char * cmd __rte_unused,const char * params,struct rte_tel_data * d)178599a2dd95SBruce Richardson handle_queue_links(const char *cmd __rte_unused,
178699a2dd95SBruce Richardson const char *params,
178799a2dd95SBruce Richardson struct rte_tel_data *d)
178899a2dd95SBruce Richardson {
178999a2dd95SBruce Richardson int i, ret, port_id = 0;
179099a2dd95SBruce Richardson char *end_param;
179199a2dd95SBruce Richardson uint8_t dev_id;
179299a2dd95SBruce Richardson uint8_t queues[RTE_EVENT_MAX_QUEUES_PER_DEV];
179399a2dd95SBruce Richardson uint8_t priorities[RTE_EVENT_MAX_QUEUES_PER_DEV];
179499a2dd95SBruce Richardson const char *p_param;
179599a2dd95SBruce Richardson
179699a2dd95SBruce Richardson if (params == NULL || strlen(params) == 0 || !isdigit(*params))
179799a2dd95SBruce Richardson return -1;
179899a2dd95SBruce Richardson
179999a2dd95SBruce Richardson /* Get dev ID from parameter string */
180099a2dd95SBruce Richardson dev_id = strtoul(params, &end_param, 10);
180199a2dd95SBruce Richardson RTE_EVENTDEV_VALID_DEVID_OR_ERR_RET(dev_id, -EINVAL);
180299a2dd95SBruce Richardson
180399a2dd95SBruce Richardson p_param = strtok(end_param, ",");
180499a2dd95SBruce Richardson if (p_param == NULL || strlen(p_param) == 0 || !isdigit(*p_param))
180599a2dd95SBruce Richardson return -1;
180699a2dd95SBruce Richardson
180799a2dd95SBruce Richardson port_id = strtoul(p_param, &end_param, 10);
180899a2dd95SBruce Richardson p_param = strtok(NULL, "\0");
180999a2dd95SBruce Richardson if (p_param != NULL)
181099a2dd95SBruce Richardson RTE_EDEV_LOG_DEBUG(
181199a2dd95SBruce Richardson "Extra parameters passed to eventdev telemetry command, ignoring");
181299a2dd95SBruce Richardson
181399a2dd95SBruce Richardson ret = rte_event_port_links_get(dev_id, port_id, queues, priorities);
181499a2dd95SBruce Richardson if (ret < 0)
181599a2dd95SBruce Richardson return -1;
181699a2dd95SBruce Richardson
181799a2dd95SBruce Richardson rte_tel_data_start_dict(d);
181899a2dd95SBruce Richardson for (i = 0; i < ret; i++) {
181999a2dd95SBruce Richardson char qid_name[32];
182099a2dd95SBruce Richardson
182199a2dd95SBruce Richardson snprintf(qid_name, 31, "qid_%u", queues[i]);
1822af0785a2SBruce Richardson rte_tel_data_add_dict_uint(d, qid_name, priorities[i]);
182399a2dd95SBruce Richardson }
182499a2dd95SBruce Richardson
182599a2dd95SBruce Richardson return 0;
182699a2dd95SBruce Richardson }
182799a2dd95SBruce Richardson
182899a2dd95SBruce 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)182999a2dd95SBruce Richardson eventdev_build_telemetry_data(int dev_id,
183099a2dd95SBruce Richardson enum rte_event_dev_xstats_mode mode,
183199a2dd95SBruce Richardson int port_queue_id,
183299a2dd95SBruce Richardson struct rte_tel_data *d)
183399a2dd95SBruce Richardson {
183499a2dd95SBruce Richardson struct rte_event_dev_xstats_name *xstat_names;
18351bdfe4d7SPavan Nikhilesh uint64_t *ids;
183699a2dd95SBruce Richardson uint64_t *values;
183799a2dd95SBruce Richardson int i, ret, num_xstats;
183899a2dd95SBruce Richardson
183999a2dd95SBruce Richardson num_xstats = rte_event_dev_xstats_names_get(dev_id,
184099a2dd95SBruce Richardson mode,
184199a2dd95SBruce Richardson port_queue_id,
184299a2dd95SBruce Richardson NULL,
184399a2dd95SBruce Richardson NULL,
184499a2dd95SBruce Richardson 0);
184599a2dd95SBruce Richardson
184699a2dd95SBruce Richardson if (num_xstats < 0)
184799a2dd95SBruce Richardson return -1;
184899a2dd95SBruce Richardson
184999a2dd95SBruce Richardson /* use one malloc for names */
185099a2dd95SBruce Richardson xstat_names = malloc((sizeof(struct rte_event_dev_xstats_name))
185199a2dd95SBruce Richardson * num_xstats);
185299a2dd95SBruce Richardson if (xstat_names == NULL)
185399a2dd95SBruce Richardson return -1;
185499a2dd95SBruce Richardson
1855e0fb0051SAbdullah Sevincer ids = malloc((sizeof(uint64_t)) * num_xstats);
185699a2dd95SBruce Richardson if (ids == NULL) {
185799a2dd95SBruce Richardson free(xstat_names);
185899a2dd95SBruce Richardson return -1;
185999a2dd95SBruce Richardson }
186099a2dd95SBruce Richardson
186199a2dd95SBruce Richardson values = malloc((sizeof(uint64_t)) * num_xstats);
186299a2dd95SBruce Richardson if (values == NULL) {
186399a2dd95SBruce Richardson free(xstat_names);
186499a2dd95SBruce Richardson free(ids);
186599a2dd95SBruce Richardson return -1;
186699a2dd95SBruce Richardson }
186799a2dd95SBruce Richardson
186899a2dd95SBruce Richardson ret = rte_event_dev_xstats_names_get(dev_id, mode, port_queue_id,
186999a2dd95SBruce Richardson xstat_names, ids, num_xstats);
187099a2dd95SBruce Richardson if (ret < 0 || ret > num_xstats) {
187199a2dd95SBruce Richardson free(xstat_names);
187299a2dd95SBruce Richardson free(ids);
187399a2dd95SBruce Richardson free(values);
187499a2dd95SBruce Richardson return -1;
187599a2dd95SBruce Richardson }
187699a2dd95SBruce Richardson
187799a2dd95SBruce Richardson ret = rte_event_dev_xstats_get(dev_id, mode, port_queue_id,
187899a2dd95SBruce Richardson ids, values, num_xstats);
187999a2dd95SBruce Richardson if (ret < 0 || ret > num_xstats) {
188099a2dd95SBruce Richardson free(xstat_names);
188199a2dd95SBruce Richardson free(ids);
188299a2dd95SBruce Richardson free(values);
188399a2dd95SBruce Richardson return -1;
188499a2dd95SBruce Richardson }
188599a2dd95SBruce Richardson
188699a2dd95SBruce Richardson rte_tel_data_start_dict(d);
188799a2dd95SBruce Richardson for (i = 0; i < num_xstats; i++)
1888af0785a2SBruce Richardson rte_tel_data_add_dict_uint(d, xstat_names[i].name, values[i]);
188999a2dd95SBruce Richardson
189099a2dd95SBruce Richardson free(xstat_names);
189199a2dd95SBruce Richardson free(ids);
189299a2dd95SBruce Richardson free(values);
189399a2dd95SBruce Richardson return 0;
189499a2dd95SBruce Richardson }
189599a2dd95SBruce Richardson
189699a2dd95SBruce Richardson static int
handle_dev_xstats(const char * cmd __rte_unused,const char * params,struct rte_tel_data * d)189799a2dd95SBruce Richardson handle_dev_xstats(const char *cmd __rte_unused,
189899a2dd95SBruce Richardson const char *params,
189999a2dd95SBruce Richardson struct rte_tel_data *d)
190099a2dd95SBruce Richardson {
190199a2dd95SBruce Richardson int dev_id;
190299a2dd95SBruce Richardson enum rte_event_dev_xstats_mode mode;
190399a2dd95SBruce Richardson char *end_param;
190499a2dd95SBruce Richardson
190599a2dd95SBruce Richardson if (params == NULL || strlen(params) == 0 || !isdigit(*params))
190699a2dd95SBruce Richardson return -1;
190799a2dd95SBruce Richardson
190899a2dd95SBruce Richardson /* Get dev ID from parameter string */
190999a2dd95SBruce Richardson dev_id = strtoul(params, &end_param, 10);
191099a2dd95SBruce Richardson if (*end_param != '\0')
191199a2dd95SBruce Richardson RTE_EDEV_LOG_DEBUG(
191299a2dd95SBruce Richardson "Extra parameters passed to eventdev telemetry command, ignoring");
191399a2dd95SBruce Richardson
191499a2dd95SBruce Richardson RTE_EVENTDEV_VALID_DEVID_OR_ERR_RET(dev_id, -EINVAL);
191599a2dd95SBruce Richardson
191699a2dd95SBruce Richardson mode = RTE_EVENT_DEV_XSTATS_DEVICE;
191799a2dd95SBruce Richardson return eventdev_build_telemetry_data(dev_id, mode, 0, d);
191899a2dd95SBruce Richardson }
191999a2dd95SBruce Richardson
192099a2dd95SBruce Richardson static int
handle_port_xstats(const char * cmd __rte_unused,const char * params,struct rte_tel_data * d)192199a2dd95SBruce Richardson handle_port_xstats(const char *cmd __rte_unused,
192299a2dd95SBruce Richardson const char *params,
192399a2dd95SBruce Richardson struct rte_tel_data *d)
192499a2dd95SBruce Richardson {
192599a2dd95SBruce Richardson int dev_id;
192699a2dd95SBruce Richardson int port_queue_id = 0;
192799a2dd95SBruce Richardson enum rte_event_dev_xstats_mode mode;
192899a2dd95SBruce Richardson char *end_param;
192999a2dd95SBruce Richardson const char *p_param;
193099a2dd95SBruce Richardson
193199a2dd95SBruce Richardson if (params == NULL || strlen(params) == 0 || !isdigit(*params))
193299a2dd95SBruce Richardson return -1;
193399a2dd95SBruce Richardson
193499a2dd95SBruce Richardson /* Get dev ID from parameter string */
193599a2dd95SBruce Richardson dev_id = strtoul(params, &end_param, 10);
193699a2dd95SBruce Richardson RTE_EVENTDEV_VALID_DEVID_OR_ERR_RET(dev_id, -EINVAL);
193799a2dd95SBruce Richardson
193899a2dd95SBruce Richardson p_param = strtok(end_param, ",");
193999a2dd95SBruce Richardson mode = RTE_EVENT_DEV_XSTATS_PORT;
194099a2dd95SBruce Richardson
194199a2dd95SBruce Richardson if (p_param == NULL || strlen(p_param) == 0 || !isdigit(*p_param))
194299a2dd95SBruce Richardson return -1;
194399a2dd95SBruce Richardson
194499a2dd95SBruce Richardson port_queue_id = strtoul(p_param, &end_param, 10);
194599a2dd95SBruce Richardson
194699a2dd95SBruce Richardson p_param = strtok(NULL, "\0");
194799a2dd95SBruce Richardson if (p_param != NULL)
194899a2dd95SBruce Richardson RTE_EDEV_LOG_DEBUG(
194999a2dd95SBruce Richardson "Extra parameters passed to eventdev telemetry command, ignoring");
195099a2dd95SBruce Richardson
195199a2dd95SBruce Richardson return eventdev_build_telemetry_data(dev_id, mode, port_queue_id, d);
195299a2dd95SBruce Richardson }
195399a2dd95SBruce Richardson
195499a2dd95SBruce Richardson static int
handle_queue_xstats(const char * cmd __rte_unused,const char * params,struct rte_tel_data * d)195599a2dd95SBruce Richardson handle_queue_xstats(const char *cmd __rte_unused,
195699a2dd95SBruce Richardson const char *params,
195799a2dd95SBruce Richardson struct rte_tel_data *d)
195899a2dd95SBruce Richardson {
195999a2dd95SBruce Richardson int dev_id;
196099a2dd95SBruce Richardson int port_queue_id = 0;
196199a2dd95SBruce Richardson enum rte_event_dev_xstats_mode mode;
196299a2dd95SBruce Richardson char *end_param;
196399a2dd95SBruce Richardson const char *p_param;
196499a2dd95SBruce Richardson
196599a2dd95SBruce Richardson if (params == NULL || strlen(params) == 0 || !isdigit(*params))
196699a2dd95SBruce Richardson return -1;
196799a2dd95SBruce Richardson
196899a2dd95SBruce Richardson /* Get dev ID from parameter string */
196999a2dd95SBruce Richardson dev_id = strtoul(params, &end_param, 10);
197099a2dd95SBruce Richardson RTE_EVENTDEV_VALID_DEVID_OR_ERR_RET(dev_id, -EINVAL);
197199a2dd95SBruce Richardson
197299a2dd95SBruce Richardson p_param = strtok(end_param, ",");
197399a2dd95SBruce Richardson mode = RTE_EVENT_DEV_XSTATS_QUEUE;
197499a2dd95SBruce Richardson
197599a2dd95SBruce Richardson if (p_param == NULL || strlen(p_param) == 0 || !isdigit(*p_param))
197699a2dd95SBruce Richardson return -1;
197799a2dd95SBruce Richardson
197899a2dd95SBruce Richardson port_queue_id = strtoul(p_param, &end_param, 10);
197999a2dd95SBruce Richardson
198099a2dd95SBruce Richardson p_param = strtok(NULL, "\0");
198199a2dd95SBruce Richardson if (p_param != NULL)
198299a2dd95SBruce Richardson RTE_EDEV_LOG_DEBUG(
198399a2dd95SBruce Richardson "Extra parameters passed to eventdev telemetry command, ignoring");
198499a2dd95SBruce Richardson
198599a2dd95SBruce Richardson return eventdev_build_telemetry_data(dev_id, mode, port_queue_id, d);
198699a2dd95SBruce Richardson }
198799a2dd95SBruce Richardson
1988a3b7b476SChengwen Feng static int
handle_dev_dump(const char * cmd __rte_unused,const char * params,struct rte_tel_data * d)1989a3b7b476SChengwen Feng handle_dev_dump(const char *cmd __rte_unused,
1990a3b7b476SChengwen Feng const char *params,
1991a3b7b476SChengwen Feng struct rte_tel_data *d)
1992a3b7b476SChengwen Feng {
1993a3b7b476SChengwen Feng char *buf, *end_param;
1994a3b7b476SChengwen Feng int dev_id, ret;
1995a3b7b476SChengwen Feng FILE *f;
1996a3b7b476SChengwen Feng
1997a3b7b476SChengwen Feng if (params == NULL || strlen(params) == 0 || !isdigit(*params))
1998a3b7b476SChengwen Feng return -1;
1999a3b7b476SChengwen Feng
2000a3b7b476SChengwen Feng /* Get dev ID from parameter string */
2001a3b7b476SChengwen Feng dev_id = strtoul(params, &end_param, 10);
2002a3b7b476SChengwen Feng if (*end_param != '\0')
2003a3b7b476SChengwen Feng RTE_EDEV_LOG_DEBUG(
2004a3b7b476SChengwen Feng "Extra parameters passed to eventdev telemetry command, ignoring");
2005a3b7b476SChengwen Feng
2006a3b7b476SChengwen Feng RTE_EVENTDEV_VALID_DEVID_OR_ERR_RET(dev_id, -EINVAL);
2007a3b7b476SChengwen Feng
2008*09fbda36SFerruh Yigit buf = calloc(RTE_TEL_MAX_SINGLE_STRING_LEN, sizeof(char));
2009a3b7b476SChengwen Feng if (buf == NULL)
2010a3b7b476SChengwen Feng return -ENOMEM;
2011a3b7b476SChengwen Feng
2012a3b7b476SChengwen Feng f = fmemopen(buf, RTE_TEL_MAX_SINGLE_STRING_LEN - 1, "w+");
2013a3b7b476SChengwen Feng if (f == NULL) {
2014a3b7b476SChengwen Feng free(buf);
2015a3b7b476SChengwen Feng return -EINVAL;
2016a3b7b476SChengwen Feng }
2017a3b7b476SChengwen Feng
2018a3b7b476SChengwen Feng ret = rte_event_dev_dump(dev_id, f);
2019a3b7b476SChengwen Feng fclose(f);
2020a3b7b476SChengwen Feng if (ret == 0) {
2021a3b7b476SChengwen Feng rte_tel_data_start_dict(d);
2022a3b7b476SChengwen Feng rte_tel_data_string(d, buf);
2023a3b7b476SChengwen Feng }
2024a3b7b476SChengwen Feng
2025a3b7b476SChengwen Feng free(buf);
2026a3b7b476SChengwen Feng return ret;
2027a3b7b476SChengwen Feng }
2028a3b7b476SChengwen Feng
RTE_INIT(eventdev_init_telemetry)202999a2dd95SBruce Richardson RTE_INIT(eventdev_init_telemetry)
203099a2dd95SBruce Richardson {
203199a2dd95SBruce Richardson rte_telemetry_register_cmd("/eventdev/dev_list", handle_dev_list,
203299a2dd95SBruce Richardson "Returns list of available eventdevs. Takes no parameters");
203399a2dd95SBruce Richardson rte_telemetry_register_cmd("/eventdev/port_list", handle_port_list,
203499a2dd95SBruce Richardson "Returns list of available ports. Parameter: DevID");
203599a2dd95SBruce Richardson rte_telemetry_register_cmd("/eventdev/queue_list", handle_queue_list,
203699a2dd95SBruce Richardson "Returns list of available queues. Parameter: DevID");
203799a2dd95SBruce Richardson
203899a2dd95SBruce Richardson rte_telemetry_register_cmd("/eventdev/dev_xstats", handle_dev_xstats,
203999a2dd95SBruce Richardson "Returns stats for an eventdev. Parameter: DevID");
204099a2dd95SBruce Richardson rte_telemetry_register_cmd("/eventdev/port_xstats", handle_port_xstats,
204199a2dd95SBruce Richardson "Returns stats for an eventdev port. Params: DevID,PortID");
204299a2dd95SBruce Richardson rte_telemetry_register_cmd("/eventdev/queue_xstats",
204399a2dd95SBruce Richardson handle_queue_xstats,
204499a2dd95SBruce Richardson "Returns stats for an eventdev queue. Params: DevID,QueueID");
2045a3b7b476SChengwen Feng rte_telemetry_register_cmd("/eventdev/dev_dump", handle_dev_dump,
2046a3b7b476SChengwen Feng "Returns dump information for an eventdev. Parameter: DevID");
204799a2dd95SBruce Richardson rte_telemetry_register_cmd("/eventdev/queue_links", handle_queue_links,
204899a2dd95SBruce Richardson "Returns links for an eventdev port. Params: DevID,QueueID");
204999a2dd95SBruce Richardson }
2050