f-stack/dpdk/lib/librte_eventdev/rte_event_eth_tx_adapter.h

463 lines
14 KiB
C

/* SPDX-License-Identifier: BSD-3-Clause
* Copyright(c) 2018 Intel Corporation.
*/
#ifndef _RTE_EVENT_ETH_TX_ADAPTER_
#define _RTE_EVENT_ETH_TX_ADAPTER_
/**
* @file
*
* RTE Event Ethernet Tx Adapter
*
* The event ethernet Tx adapter provides configuration and data path APIs
* for the ethernet transmit stage of an event driven packet processing
* application. These APIs abstract the implementation of the transmit stage
* and allow the application to use eventdev PMD support or a common
* implementation.
*
* In the common implementation, the application enqueues mbufs to the adapter
* which runs as a rte_service function. The service function dequeues events
* from its event port and transmits the mbufs referenced by these events.
*
* The ethernet Tx event adapter APIs are:
*
* - rte_event_eth_tx_adapter_create()
* - rte_event_eth_tx_adapter_create_ext()
* - rte_event_eth_tx_adapter_free()
* - rte_event_eth_tx_adapter_start()
* - rte_event_eth_tx_adapter_stop()
* - rte_event_eth_tx_adapter_queue_add()
* - rte_event_eth_tx_adapter_queue_del()
* - rte_event_eth_tx_adapter_stats_get()
* - rte_event_eth_tx_adapter_stats_reset()
* - rte_event_eth_tx_adapter_enqueue()
* - rte_event_eth_tx_adapter_event_port_get()
* - rte_event_eth_tx_adapter_service_id_get()
*
* The application creates the adapter using
* rte_event_eth_tx_adapter_create() or rte_event_eth_tx_adapter_create_ext().
*
* The adapter will use the common implementation when the eventdev PMD
* does not have the #RTE_EVENT_ETH_TX_ADAPTER_CAP_INTERNAL_PORT capability.
* The common implementation uses an event port that is created using the port
* configuration parameter passed to rte_event_eth_tx_adapter_create(). The
* application can get the port identifier using
* rte_event_eth_tx_adapter_event_port_get() and must link an event queue to
* this port.
*
* If the eventdev PMD has the #RTE_EVENT_ETH_TX_ADAPTER_CAP_INTERNAL_PORT
* flags set, Tx adapter events should be enqueued using the
* rte_event_eth_tx_adapter_enqueue() function, else the application should
* use rte_event_enqueue_burst().
*
* Transmit queues can be added and deleted from the adapter using
* rte_event_eth_tx_adapter_queue_add()/del() APIs respectively.
*
* The application can start and stop the adapter using the
* rte_event_eth_tx_adapter_start/stop() calls.
*
* The common adapter implementation uses an EAL service function as described
* before and its execution is controlled using the rte_service APIs. The
* rte_event_eth_tx_adapter_service_id_get()
* function can be used to retrieve the adapter's service function ID.
*
* The ethernet port and transmit queue index to transmit the mbuf on are
* specified using the mbuf port and the higher 16 bits of
* struct rte_mbuf::hash::sched:hi. The application should use the
* rte_event_eth_tx_adapter_txq_set() and rte_event_eth_tx_adapter_txq_get()
* functions to access the transmit queue index since it is expected that the
* transmit queue will be eventually defined within struct rte_mbuf and using
* these macros will help with minimizing application impact due to
* a change in how the transmit queue index is specified.
*/
#ifdef __cplusplus
extern "C" {
#endif
#include <stdint.h>
#include <rte_mbuf.h>
#include "rte_eventdev.h"
/**
* @warning
* @b EXPERIMENTAL: this API may change without prior notice
*
* Adapter configuration structure
*
* @see rte_event_eth_tx_adapter_create_ext
* @see rte_event_eth_tx_adapter_conf_cb
*/
struct rte_event_eth_tx_adapter_conf {
uint8_t event_port_id;
/**< Event port identifier, the adapter service function dequeues mbuf
* events from this port.
* @see RTE_EVENT_ETH_RX_ADAPTER_CAP_INTERNAL_PORT
*/
uint32_t max_nb_tx;
/**< The adapter can return early if it has processed at least
* max_nb_tx mbufs. This isn't treated as a requirement; batching may
* cause the adapter to process more than max_nb_tx mbufs.
*/
};
/**
* @warning
* @b EXPERIMENTAL: this API may change without prior notice
*
* Function type used for adapter configuration callback. The callback is
* used to fill in members of the struct rte_event_eth_tx_adapter_conf, this
* callback is invoked when creating a RTE service function based
* adapter implementation.
*
* @param id
* Adapter identifier.
* @param dev_id
* Event device identifier.
* @param [out] conf
* Structure that needs to be populated by this callback.
* @param arg
* Argument to the callback. This is the same as the conf_arg passed to the
* rte_event_eth_tx_adapter_create_ext().
*
* @return
* - 0: Success
* - <0: Error code on failure
*/
typedef int (*rte_event_eth_tx_adapter_conf_cb) (uint8_t id, uint8_t dev_id,
struct rte_event_eth_tx_adapter_conf *conf,
void *arg);
/**
* @warning
* @b EXPERIMENTAL: this API may change without prior notice
*
* A structure used to retrieve statistics for an ethernet Tx adapter instance.
*/
struct rte_event_eth_tx_adapter_stats {
uint64_t tx_retry;
/**< Number of transmit retries */
uint64_t tx_packets;
/**< Number of packets transmitted */
uint64_t tx_dropped;
/**< Number of packets dropped */
};
/**
* @warning
* @b EXPERIMENTAL: this API may change without prior notice
*
* Create a new ethernet Tx adapter with the specified identifier.
*
* @param id
* The identifier of the ethernet Tx adapter.
* @param dev_id
* The event device identifier.
* @param port_config
* Event port configuration, the adapter uses this configuration to
* create an event port if needed.
* @return
* - 0: Success
* - <0: Error code on failure
*/
int __rte_experimental
rte_event_eth_tx_adapter_create(uint8_t id, uint8_t dev_id,
struct rte_event_port_conf *port_config);
/**
* @warning
* @b EXPERIMENTAL: this API may change without prior notice
*
* Create a new ethernet Tx adapter with the specified identifier.
*
* @param id
* The identifier of the ethernet Tx adapter.
* @param dev_id
* The event device identifier.
* @param conf_cb
* Callback function that initializes members of the
* struct rte_event_eth_tx_adapter_conf struct passed into
* it.
* @param conf_arg
* Argument that is passed to the conf_cb function.
* @return
* - 0: Success
* - <0: Error code on failure
*/
int __rte_experimental
rte_event_eth_tx_adapter_create_ext(uint8_t id, uint8_t dev_id,
rte_event_eth_tx_adapter_conf_cb conf_cb,
void *conf_arg);
/**
* @warning
* @b EXPERIMENTAL: this API may change without prior notice
*
* Free an ethernet Tx adapter
*
* @param id
* Adapter identifier.
* @return
* - 0: Success
* - <0: Error code on failure, If the adapter still has Tx queues
* added to it, the function returns -EBUSY.
*/
int __rte_experimental
rte_event_eth_tx_adapter_free(uint8_t id);
/**
* @warning
* @b EXPERIMENTAL: this API may change without prior notice
*
* Start ethernet Tx adapter
*
* @param id
* Adapter identifier.
* @return
* - 0: Success, Adapter started correctly.
* - <0: Error code on failure.
*/
int __rte_experimental
rte_event_eth_tx_adapter_start(uint8_t id);
/**
* @warning
* @b EXPERIMENTAL: this API may change without prior notice
*
* Stop ethernet Tx adapter
*
* @param id
* Adapter identifier.
* @return
* - 0: Success.
* - <0: Error code on failure.
*/
int __rte_experimental
rte_event_eth_tx_adapter_stop(uint8_t id);
/**
* @warning
* @b EXPERIMENTAL: this API may change without prior notice
*
* Add a Tx queue to the adapter.
* A queue value of -1 is used to indicate all
* queues within the device.
*
* @param id
* Adapter identifier.
* @param eth_dev_id
* Ethernet Port Identifier.
* @param queue
* Tx queue index.
* @return
* - 0: Success, Queues added successfully.
* - <0: Error code on failure.
*/
int __rte_experimental
rte_event_eth_tx_adapter_queue_add(uint8_t id,
uint16_t eth_dev_id,
int32_t queue);
/**
* @warning
* @b EXPERIMENTAL: this API may change without prior notice
*
* Delete a Tx queue from the adapter.
* A queue value of -1 is used to indicate all
* queues within the device, that have been added to this
* adapter.
*
* @param id
* Adapter identifier.
* @param eth_dev_id
* Ethernet Port Identifier.
* @param queue
* Tx queue index.
* @return
* - 0: Success, Queues deleted successfully.
* - <0: Error code on failure.
*/
int __rte_experimental
rte_event_eth_tx_adapter_queue_del(uint8_t id,
uint16_t eth_dev_id,
int32_t queue);
/**
* @warning
* @b EXPERIMENTAL: this API may change without prior notice
*
* Set Tx queue in the mbuf. This queue is used by the adapter
* to transmit the mbuf.
*
* @param pkt
* Pointer to the mbuf.
* @param queue
* Tx queue index.
*/
static __rte_always_inline void __rte_experimental
rte_event_eth_tx_adapter_txq_set(struct rte_mbuf *pkt, uint16_t queue)
{
uint16_t *p = (uint16_t *)&pkt->hash.sched.hi;
p[1] = queue;
}
/**
* @warning
* @b EXPERIMENTAL: this API may change without prior notice
*
* Retrieve Tx queue from the mbuf.
*
* @param pkt
* Pointer to the mbuf.
* @return
* Tx queue identifier.
*
* @see rte_event_eth_tx_adapter_txq_set()
*/
static __rte_always_inline uint16_t __rte_experimental
rte_event_eth_tx_adapter_txq_get(struct rte_mbuf *pkt)
{
uint16_t *p = (uint16_t *)&pkt->hash.sched.hi;
return p[1];
}
/**
* @warning
* @b EXPERIMENTAL: this API may change without prior notice
*
* Retrieve the adapter event port. The adapter creates an event port if
* the #RTE_EVENT_ETH_TX_ADAPTER_CAP_INTERNAL_PORT is not set in the
* ethernet Tx capabilities of the event device.
*
* @param id
* Adapter Identifier.
* @param[out] event_port_id
* Event port pointer.
* @return
* - 0: Success.
* - <0: Error code on failure.
*/
int __rte_experimental
rte_event_eth_tx_adapter_event_port_get(uint8_t id, uint8_t *event_port_id);
/**
* Enqueue a burst of events objects or an event object supplied in *rte_event*
* structure on an event device designated by its *dev_id* through the event
* port specified by *port_id*. This function is supported if the eventdev PMD
* has the #RTE_EVENT_ETH_TX_ADAPTER_CAP_INTERNAL_PORT capability flag set.
*
* The *nb_events* parameter is the number of event objects to enqueue which are
* supplied in the *ev* array of *rte_event* structure.
*
* The rte_event_eth_tx_adapter_enqueue() function returns the number of
* events objects it actually enqueued. A return value equal to *nb_events*
* means that all event objects have been enqueued.
*
* @param dev_id
* The identifier of the device.
* @param port_id
* The identifier of the event port.
* @param ev
* Points to an array of *nb_events* objects of type *rte_event* structure
* which contain the event object enqueue operations to be processed.
* @param nb_events
* The number of event objects to enqueue, typically number of
* rte_event_port_enqueue_depth() available for this port.
*
* @return
* The number of event objects actually enqueued on the event device. The
* return value can be less than the value of the *nb_events* parameter when
* the event devices queue is full or if invalid parameters are specified in a
* *rte_event*. If the return value is less than *nb_events*, the remaining
* events at the end of ev[] are not consumed and the caller has to take care
* of them, and rte_errno is set accordingly. Possible errno values include:
* - -EINVAL The port ID is invalid, device ID is invalid, an event's queue
* ID is invalid, or an event's sched type doesn't match the
* capabilities of the destination queue.
* - -ENOSPC The event port was backpressured and unable to enqueue
* one or more events. This error code is only applicable to
* closed systems.
*/
static inline uint16_t __rte_experimental
rte_event_eth_tx_adapter_enqueue(uint8_t dev_id,
uint8_t port_id,
struct rte_event ev[],
uint16_t nb_events)
{
const struct rte_eventdev *dev = &rte_eventdevs[dev_id];
#ifdef RTE_LIBRTE_EVENTDEV_DEBUG
if (dev_id >= RTE_EVENT_MAX_DEVS ||
!rte_eventdevs[dev_id].attached) {
rte_errno = -EINVAL;
return 0;
}
if (port_id >= dev->data->nb_ports) {
rte_errno = -EINVAL;
return 0;
}
#endif
return dev->txa_enqueue(dev->data->ports[port_id], ev, nb_events);
}
/**
* @warning
* @b EXPERIMENTAL: this API may change without prior notice
*
* Retrieve statistics for an adapter
*
* @param id
* Adapter identifier.
* @param [out] stats
* A pointer to structure used to retrieve statistics for an adapter.
* @return
* - 0: Success, statistics retrieved successfully.
* - <0: Error code on failure.
*/
int __rte_experimental
rte_event_eth_tx_adapter_stats_get(uint8_t id,
struct rte_event_eth_tx_adapter_stats *stats);
/**
* @warning
* @b EXPERIMENTAL: this API may change without prior notice
*
* Reset statistics for an adapter.
*
* @param id
* Adapter identifier.
* @return
* - 0: Success, statistics reset successfully.
* - <0: Error code on failure.
*/
int __rte_experimental
rte_event_eth_tx_adapter_stats_reset(uint8_t id);
/**
* @warning
* @b EXPERIMENTAL: this API may change without prior notice
*
* Retrieve the service ID of an adapter. If the adapter doesn't use
* a rte_service function, this function returns -ESRCH.
*
* @param id
* Adapter identifier.
* @param [out] service_id
* A pointer to a uint32_t, to be filled in with the service id.
* @return
* - 0: Success
* - <0: Error code on failure, if the adapter doesn't use a rte_service
* function, this function returns -ESRCH.
*/
int __rte_experimental
rte_event_eth_tx_adapter_service_id_get(uint8_t id, uint32_t *service_id);
#ifdef __cplusplus
}
#endif
#endif /* _RTE_EVENT_ETH_TX_ADAPTER_ */