199a2dd95SBruce Richardson /* SPDX-License-Identifier: BSD-3-Clause 299a2dd95SBruce Richardson * Copyright(c) 2016 Cavium, Inc 399a2dd95SBruce Richardson */ 499a2dd95SBruce Richardson 5*08966fe7STyler 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 4899a2dd95SBruce Richardson rte_event_dev_count(void) 4999a2dd95SBruce Richardson { 5099a2dd95SBruce Richardson return eventdev_globals.nb_devs; 5199a2dd95SBruce Richardson } 5299a2dd95SBruce Richardson 5399a2dd95SBruce Richardson int 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 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 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 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 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 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 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 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 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 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 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 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 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 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 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 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 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 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 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 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 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 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 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 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 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 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 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 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 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 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 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 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 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 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 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 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 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 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 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 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), 1409*08966fe7STyler 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 * 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 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 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 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 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 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 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 * 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 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 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 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 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 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 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 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 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 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 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 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 2008a3b7b476SChengwen Feng buf = calloc(sizeof(char), RTE_TEL_MAX_SINGLE_STRING_LEN); 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 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