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

430 lines
13 KiB
C
Raw Normal View History

2019-06-25 11:12:58 +00:00
/* 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
2020-06-18 16:55:50 +00:00
* specified using the mbuf port struct rte_mbuf::hash::txadapter:txq.
* 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, using these macros will help with minimizing application
* impact due to a change in how the transmit queue index is specified.
2019-06-25 11:12:58 +00:00
*/
#ifdef __cplusplus
extern "C" {
#endif
#include <stdint.h>
#include <rte_mbuf.h>
#include "rte_eventdev.h"
/**
* 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.
*/
};
/**
* 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);
/**
* 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 */
};
/**
* 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
*/
2020-06-18 16:55:50 +00:00
int
2019-06-25 11:12:58 +00:00
rte_event_eth_tx_adapter_create(uint8_t id, uint8_t dev_id,
struct rte_event_port_conf *port_config);
/**
* 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
*/
2020-06-18 16:55:50 +00:00
int
2019-06-25 11:12:58 +00:00
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);
/**
* 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.
*/
2020-06-18 16:55:50 +00:00
int
2019-06-25 11:12:58 +00:00
rte_event_eth_tx_adapter_free(uint8_t id);
/**
* Start ethernet Tx adapter
*
* @param id
* Adapter identifier.
* @return
* - 0: Success, Adapter started correctly.
* - <0: Error code on failure.
*/
2020-06-18 16:55:50 +00:00
int
2019-06-25 11:12:58 +00:00
rte_event_eth_tx_adapter_start(uint8_t id);
/**
* Stop ethernet Tx adapter
*
* @param id
* Adapter identifier.
* @return
* - 0: Success.
* - <0: Error code on failure.
*/
2020-06-18 16:55:50 +00:00
int
2019-06-25 11:12:58 +00:00
rte_event_eth_tx_adapter_stop(uint8_t id);
/**
* 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.
*/
2020-06-18 16:55:50 +00:00
int
2019-06-25 11:12:58 +00:00
rte_event_eth_tx_adapter_queue_add(uint8_t id,
uint16_t eth_dev_id,
int32_t queue);
/**
* 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.
*/
2020-06-18 16:55:50 +00:00
int
2019-06-25 11:12:58 +00:00
rte_event_eth_tx_adapter_queue_del(uint8_t id,
uint16_t eth_dev_id,
int32_t queue);
/**
* 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.
*/
2020-06-18 16:55:50 +00:00
static __rte_always_inline void
2019-06-25 11:12:58 +00:00
rte_event_eth_tx_adapter_txq_set(struct rte_mbuf *pkt, uint16_t queue)
{
2020-06-18 16:55:50 +00:00
pkt->hash.txadapter.txq = queue;
2019-06-25 11:12:58 +00:00
}
/**
* Retrieve Tx queue from the mbuf.
*
* @param pkt
* Pointer to the mbuf.
* @return
* Tx queue identifier.
*
* @see rte_event_eth_tx_adapter_txq_set()
*/
2020-06-18 16:55:50 +00:00
static __rte_always_inline uint16_t
2019-06-25 11:12:58 +00:00
rte_event_eth_tx_adapter_txq_get(struct rte_mbuf *pkt)
{
2020-06-18 16:55:50 +00:00
return pkt->hash.txadapter.txq;
2019-06-25 11:12:58 +00:00
}
/**
* 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.
*/
2020-06-18 16:55:50 +00:00
int
2019-06-25 11:12:58 +00:00
rte_event_eth_tx_adapter_event_port_get(uint8_t id, uint8_t *event_port_id);
2020-06-18 16:55:50 +00:00
#define RTE_EVENT_ETH_TX_ADAPTER_ENQUEUE_SAME_DEST 0x1
/**< This flag is used when all the packets enqueued in the tx adapter are
* destined for the same Ethernet port & Tx queue.
*/
2019-06-25 11:12:58 +00:00
/**
* 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
2019-06-26 10:17:41 +00:00
* rte_event_port_attr_get(...RTE_EVENT_PORT_ATTR_ENQ_DEPTH...)
* available for this port.
2020-06-18 16:55:50 +00:00
* @param flags
* RTE_EVENT_ETH_TX_ADAPTER_ENQUEUE_ flags.
* #RTE_EVENT_ETH_TX_ADAPTER_ENQUEUE_SAME_DEST signifies that all the packets
* which are enqueued are destined for the same Ethernet port & Tx queue.
2019-06-25 11:12:58 +00:00
*
* @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:
2019-11-23 08:13:38 +00:00
* - EINVAL The port ID is invalid, device ID is invalid, an event's queue
2019-06-25 11:12:58 +00:00
* ID is invalid, or an event's sched type doesn't match the
* capabilities of the destination queue.
2019-11-23 08:13:38 +00:00
* - ENOSPC The event port was backpressured and unable to enqueue
2019-06-25 11:12:58 +00:00
* one or more events. This error code is only applicable to
* closed systems.
*/
2020-06-18 16:55:50 +00:00
static inline uint16_t
2019-06-25 11:12:58 +00:00
rte_event_eth_tx_adapter_enqueue(uint8_t dev_id,
uint8_t port_id,
struct rte_event ev[],
2020-06-18 16:55:50 +00:00
uint16_t nb_events,
const uint8_t flags)
2019-06-25 11:12:58 +00:00
{
2022-09-06 04:00:10 +00:00
const struct rte_event_fp_ops *fp_ops;
void *port;
2019-06-25 11:12:58 +00:00
2022-09-06 04:00:10 +00:00
fp_ops = &rte_event_fp_ops[dev_id];
port = fp_ops->data[port_id];
2019-06-25 11:12:58 +00:00
#ifdef RTE_LIBRTE_EVENTDEV_DEBUG
if (dev_id >= RTE_EVENT_MAX_DEVS ||
2022-09-06 04:00:10 +00:00
port_id >= RTE_EVENT_MAX_PORTS_PER_DEV) {
2019-11-23 08:13:38 +00:00
rte_errno = EINVAL;
2019-06-25 11:12:58 +00:00
return 0;
}
2022-09-06 04:00:10 +00:00
if (port == NULL) {
2019-11-23 08:13:38 +00:00
rte_errno = EINVAL;
2019-06-25 11:12:58 +00:00
return 0;
}
#endif
2021-02-05 08:48:47 +00:00
rte_eventdev_trace_eth_tx_adapter_enqueue(dev_id, port_id, ev,
nb_events, flags);
2020-06-18 16:55:50 +00:00
if (flags)
2022-09-06 04:00:10 +00:00
return fp_ops->txa_enqueue_same_dest(port, ev, nb_events);
2020-06-18 16:55:50 +00:00
else
2022-09-06 04:00:10 +00:00
return fp_ops->txa_enqueue(port, ev, nb_events);
2019-06-25 11:12:58 +00:00
}
/**
* 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.
*/
2020-06-18 16:55:50 +00:00
int
2019-06-25 11:12:58 +00:00
rte_event_eth_tx_adapter_stats_get(uint8_t id,
struct rte_event_eth_tx_adapter_stats *stats);
/**
* Reset statistics for an adapter.
*
* @param id
* Adapter identifier.
* @return
* - 0: Success, statistics reset successfully.
* - <0: Error code on failure.
*/
2020-06-18 16:55:50 +00:00
int
2019-06-25 11:12:58 +00:00
rte_event_eth_tx_adapter_stats_reset(uint8_t id);
/**
* 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.
*/
2020-06-18 16:55:50 +00:00
int
2019-06-25 11:12:58 +00:00
rte_event_eth_tx_adapter_service_id_get(uint8_t id, uint32_t *service_id);
#ifdef __cplusplus
}
#endif
#endif /* _RTE_EVENT_ETH_TX_ADAPTER_ */