rte_event_timer_adapter.h(3) | DPDK | rte_event_timer_adapter.h(3) |
NAME¶
rte_event_timer_adapter.h
SYNOPSIS¶
#include 'rte_eventdev.h'
#include 'rte_eventdev_trace_fp.h'
Data Structures¶
struct rte_event_timer_adapter_conf
struct rte_event_timer_adapter_stats
struct rte_event_timer_adapter_info
struct rte_event_timer
Macros¶
#define RTE_EVENT_TIMER_ADAPTER_F_ADJUST_RES (1ULL <<
0)
#define RTE_EVENT_TIMER_ADAPTER_F_SP_PUT (1ULL << 1)
#define RTE_EVENT_TIMER_ADAPTER_F_PERIODIC (1ULL << 2)
Typedefs¶
typedef int(*
rte_event_timer_adapter_port_conf_cb_t) (uint16_t id, uint8_t
event_dev_id, uint8_t *event_port_id, void *conf_arg)
Enumerations¶
enum rte_event_timer_adapter_clk_src {
RTE_EVENT_TIMER_ADAPTER_CPU_CLK,
RTE_EVENT_TIMER_ADAPTER_EXT_CLK0,
RTE_EVENT_TIMER_ADAPTER_EXT_CLK1,
RTE_EVENT_TIMER_ADAPTER_EXT_CLK2,
RTE_EVENT_TIMER_ADAPTER_EXT_CLK3 }
enum rte_event_timer_state { RTE_EVENT_TIMER_NOT_ARMED = 0,
RTE_EVENT_TIMER_ARMED = 1, RTE_EVENT_TIMER_CANCELED = 2,
RTE_EVENT_TIMER_ERROR = -1, RTE_EVENT_TIMER_ERROR_TOOEARLY =
-2, RTE_EVENT_TIMER_ERROR_TOOLATE = -3 }
Functions¶
struct rte_event_timer_adapter *
rte_event_timer_adapter_create (const struct
rte_event_timer_adapter_conf *conf)
struct rte_event_timer_adapter * rte_event_timer_adapter_create_ext
(const struct rte_event_timer_adapter_conf *conf,
rte_event_timer_adapter_port_conf_cb_t conf_cb, void *conf_arg)
int rte_event_timer_adapter_get_info (const struct
rte_event_timer_adapter *adapter, struct rte_event_timer_adapter_info
*adapter_info)
int rte_event_timer_adapter_start (const struct rte_event_timer_adapter
*adapter)
int rte_event_timer_adapter_stop (const struct rte_event_timer_adapter
*adapter)
struct rte_event_timer_adapter * rte_event_timer_adapter_lookup
(uint16_t adapter_id)
int rte_event_timer_adapter_free (struct rte_event_timer_adapter
*adapter)
int rte_event_timer_adapter_service_id_get (struct
rte_event_timer_adapter *adapter, uint32_t *service_id)
int rte_event_timer_adapter_stats_get (struct rte_event_timer_adapter
*adapter, struct rte_event_timer_adapter_stats *stats)
int rte_event_timer_adapter_stats_reset (struct rte_event_timer_adapter
*adapter)
static uint16_t rte_event_timer_arm_burst (const struct
rte_event_timer_adapter *adapter, struct rte_event_timer **evtims,
uint16_t nb_evtims)
static uint16_t rte_event_timer_arm_tmo_tick_burst (const struct
rte_event_timer_adapter *adapter, struct rte_event_timer **evtims,
const uint64_t timeout_ticks, const uint16_t nb_evtims)
static uint16_t rte_event_timer_cancel_burst (const struct
rte_event_timer_adapter *adapter, struct rte_event_timer **evtims,
uint16_t nb_evtims)
__rte_experimental int rte_event_timer_remaining_ticks_get (const
struct rte_event_timer_adapter *adapter, const struct rte_event_timer
*evtim, uint64_t *ticks_remaining)
Detailed Description¶
RTE Event Timer Adapter
An event timer adapter has the following abstract working model:
timer_tick_ns
+
+-------+ |
| | |
+-------+ bkt 0 +----v---+
| | | |
| +-------+ |
+---+---+ +---+---+ +---+---+---+---+
| | | | | | | | |
| bkt n | | bkt 1 |<-> t0| t1| t2| tn|
| | | | | | | | |
+---+---+ +---+---+ +---+---+---+---+
| Timer adapter |
+---+---+ +---+---+
| | | |
| bkt 4 | | bkt 2 |<--- Current bucket
| | | |
+---+---+ +---+---+
| +-------+ |
| | | |
+------+ bkt 3 +-------+
| |
+-------+
- It has a virtual monotonically increasing 64-bit timer adapter clock based on enum rte_event_timer_adapter_clk_src clock source. The clock source could be a CPU clock, or a platform dependent external clock.
- The application creates a timer adapter instance with given the clock source, the total number of event timers, and a resolution(expressed in ns) to traverse between the buckets.
- Each timer adapter may have 0 to n buckets based on the configured max timeout(max_tmo_ns) and resolution(timer_tick_ns). Upon starting the timer adapter, the adapter starts ticking at timer_tick_ns resolution.
- The application arms an event timer that will expire timer_tick_ns from now.
- The application can cancel an armed timer and no timer expiry event will be generated.
- If a timer expires then the library injects the timer expiry event in the designated event queue.
- The timer expiry event will be received through rte_event_dequeue_burst.
- The application frees the timer adapter instance.
Multiple timer adapters can be created with a varying level of resolution for various expiry use cases that run in parallel.
Before using the timer adapter, the application has to create and configure an event device along with the event port. Based on the event device capability it might require creating an additional event port to be used by the timer adapter.
The application creates the event timer adapter using the rte_event_timer_adapter_create(). The event device id is passed to this function, inside this function the event device capability is checked, and if an in-built port is absent the application uses the default function to create a new producer port.
The application may also use the function rte_event_timer_adapter_create_ext() to have granular control over producer port creation in a case where the in-built port is absent.
After creating the timer adapter, the application has to start it using rte_event_timer_adapter_start(). The buckets are traversed from 0 to n; when the adapter ticks, the next bucket is visited. Each time, the list per bucket is processed, and timer expiry events are sent to the designated event queue.
The application can arm one or more event timers using the rte_event_timer_arm_burst(). The timeout_ticks represents the number of timer_tick_ns after which the timer has to expire. The timeout at which the timers expire can be grouped or be independent of each event timer instance. rte_event_timer_arm_tmo_tick_burst() addresses the former case and rte_event_timer_arm_burst() addresses the latter case.
The application can cancel the timers from expiring using the rte_event_timer_cancel_burst().
On the secondary process, rte_event_timer_adapter_lookup() can be used to get the timer adapter pointer from its id and use it to invoke fastpath operations such as arm and cancel.
Some of the use cases of event timer adapter are Beacon Timers, Generic SW Timeout, Wireless MAC Scheduling, 3G Frame Protocols, Packet Scheduling, Protocol Retransmission Timers, Supervision Timers. All these use cases require high resolution and low time drift.
Definition in file rte_event_timer_adapter.h.
Macro Definition Documentation¶
#define RTE_EVENT_TIMER_ADAPTER_F_ADJUST_RES (1ULL << 0)¶
The event timer adapter implementation may have constraints on the resolution (timer_tick_ns) and maximum timer expiry timeout(max_tmo_ns) based on the given timer adapter or system. If this flag is set, the implementation adjusts the resolution and maximum timeout to the best possible configuration. On successful timer adapter creation, the application can get the configured resolution and max timeout with rte_event_timer_adapter_get_info().
See also
struct rte_event_timer_adapter_info::max_tmo_ns
Definition at line 145 of file rte_event_timer_adapter.h.
#define RTE_EVENT_TIMER_ADAPTER_F_SP_PUT (1ULL << 1)¶
rte_event_timer_arm_burst() API to be used in single producer mode.
See also
Definition at line 150 of file rte_event_timer_adapter.h.
#define RTE_EVENT_TIMER_ADAPTER_F_PERIODIC (1ULL << 2)¶
Flag to configure an event timer adapter in periodic mode; non-periodic mode is the default. A timer will fire once or periodically until the timer is cancelled based on the adapter mode.
See also
Definition at line 158 of file rte_event_timer_adapter.h.
Typedef Documentation¶
typedef int(* rte_event_timer_adapter_port_conf_cb_t) (uint16_t id, uint8_t event_dev_id, uint8_t *event_port_id, void *conf_arg)¶
Callback function type for producer port creation.
Definition at line 205 of file rte_event_timer_adapter.h.
Enumeration Type Documentation¶
enum rte_event_timer_adapter_clk_src¶
Timer adapter clock source
Enumerator
- RTE_EVENT_TIMER_ADAPTER_CPU_CLK
- Use CPU clock as the clock source.
- RTE_EVENT_TIMER_ADAPTER_EXT_CLK0
- Platform dependent external clock source 0.
- RTE_EVENT_TIMER_ADAPTER_EXT_CLK1
- Platform dependent external clock source 1.
- RTE_EVENT_TIMER_ADAPTER_EXT_CLK2
- Platform dependent external clock source 2.
- RTE_EVENT_TIMER_ADAPTER_EXT_CLK3
- Platform dependent external clock source 3.
Definition at line 121 of file rte_event_timer_adapter.h.
enum rte_event_timer_state¶
Event timer state.
Enumerator
- RTE_EVENT_TIMER_NOT_ARMED
- Event timer not armed.
- RTE_EVENT_TIMER_ARMED
- Event timer successfully armed.
- RTE_EVENT_TIMER_CANCELED
- Event timer successfully canceled.
- RTE_EVENT_TIMER_ERROR
- Generic event timer error.
- RTE_EVENT_TIMER_ERROR_TOOEARLY
- Event timer timeout tick value is too small for the adapter to handle, given its configured resolution.
- RTE_EVENT_TIMER_ERROR_TOOLATE
- Event timer timeout tick is greater than the maximum timeout.
Definition at line 455 of file rte_event_timer_adapter.h.
Function Documentation¶
struct rte_event_timer_adapter* rte_event_timer_adapter_create (const struct rte_event_timer_adapter_conf * conf)¶
Create an event timer adapter.
This function must be invoked first before any other function in the API.
When this API is used for creating adapter instance, rte_event_dev_config::nb_event_ports is automatically incremented, and the event device is reconfigured with additional event port during service initialization. This event device reconfigure logic also increments the rte_event_dev_config::nb_single_link_event_port_queues parameter if the adapter event port config is of type RTE_EVENT_PORT_CFG_SINGLE_LINK.
Application no longer needs to account for rte_event_dev_config::nb_event_ports and rte_event_dev_config::nb_single_link_event_port_queues parameters required for Timer adapter in event device configuration when the adapter is created with this API.
Parameters
Returns
- ERANGE: timer_tick_ns is not in supported range.
- ENOMEM: unable to allocate sufficient memory for adapter instances
- EINVAL: invalid event device identifier specified in config
- ENOSPC: maximum number of adapters already created
- EIO: event device reconfiguration and restart error. The adapter reconfigures the event device with an additional port by default if it is required to use a service to manage timers. If the device had been started before this call, this error code indicates an error in restart following an error in reconfiguration, i.e., a combination of the two error codes.
struct rte_event_timer_adapter* rte_event_timer_adapter_create_ext (const struct rte_event_timer_adapter_conf * conf, rte_event_timer_adapter_port_conf_cb_t conf_cb, void * conf_arg)¶
Create a timer adapter with the supplied callback.
This function can be used to have a more granular control over the timer adapter creation. If a built-in port is absent, then the function uses the callback provided to create and get the port id to be used as a producer port.
Parameters
conf_cb The port config callback function.
conf_arg Opaque pointer to the argument for the callback function
Returns
- ERANGE: timer_tick_ns is not in supported range.
- ENOMEM: unable to allocate sufficient memory for adapter instances
- EINVAL: invalid event device identifier specified in config
- ENOSPC: maximum number of adapters already created
int rte_event_timer_adapter_get_info (const struct rte_event_timer_adapter * adapter, struct rte_event_timer_adapter_info * adapter_info)¶
Retrieve the contextual information of an event timer adapter.
Parameters
adapter_info A pointer to a structure of type rte_event_timer_adapter_info to be filled with the contextual information of the adapter.
Returns
- 0: Success, driver updates the contextual information of the timer adapter
- <0: Error code returned by the driver info get function.
- -EINVAL: adapter identifier invalid
See also
int rte_event_timer_adapter_start (const struct rte_event_timer_adapter * adapter)¶
Start a timer adapter.
The adapter start step is the last one and consists of setting the timer adapter to start accepting the timers and schedules to event queues.
On success, all basic functions exported by the API (timer arm, timer cancel and so on) can be invoked.
Parameters
Returns
- 0: Success, adapter started.
- <0: Error code returned by the driver start function.
- -EINVAL if adapter identifier invalid
- -ENOENT if software adapter but no service core mapped
- -ENOTSUP if software adapter and more than one service core mapped
- -EALREADY if adapter has already been started
Note
int rte_event_timer_adapter_stop (const struct rte_event_timer_adapter * adapter)¶
Stop an event timer adapter.
The adapter can be restarted with a call to rte_event_timer_adapter_start().
Parameters
Returns
- 0: Success, adapter stopped.
- <0: Error code returned by the driver stop function.
- -EINVAL if adapter identifier invalid
struct rte_event_timer_adapter* rte_event_timer_adapter_lookup (uint16_t adapter_id)¶
Lookup an event timer adapter using its identifier.
If an event timer adapter was created in another process with the same identifier, this function will locate its state and set up access to it so that it can be used in this process.
Parameters
Returns
- •
- ENOENT - requested entry not available to return.
int rte_event_timer_adapter_free (struct rte_event_timer_adapter * adapter)¶
Free an event timer adapter.
Destroy an event timer adapter, freeing all resources.
Before invoking this function, the application must wait for all the armed timers to expire or cancel the outstanding armed timers.
Parameters
Returns
- 0: Successfully freed the event timer adapter resources.
- <0: Failed to free the event timer adapter resources.
- -EAGAIN: adapter is busy; timers outstanding
- -EBUSY: stop hasn't been called for this adapter yet
- -EINVAL: adapter id invalid, or adapter invalid
int rte_event_timer_adapter_service_id_get (struct rte_event_timer_adapter * adapter, uint32_t * service_id)¶
Retrieve the service ID of the event timer adapter. If the adapter doesn't use an rte_service function, this function returns -ESRCH.
Parameters
service_id A pointer to a uint32_t, to be filled in with the service id.
Returns
- 0: Success
- <0: Error code on failure
- -ESRCH: the adapter does not require a service to operate
int rte_event_timer_adapter_stats_get (struct rte_event_timer_adapter * adapter, struct rte_event_timer_adapter_stats * stats)¶
Retrieve statistics for an event timer adapter instance.
Parameters
stats A pointer to a structure to fill with statistics.
Returns
- 0: Successfully retrieved.
- <0: Failure; error code returned.
int rte_event_timer_adapter_stats_reset (struct rte_event_timer_adapter * adapter)¶
Reset statistics for an event timer adapter instance.
Parameters
Returns
- 0: Successfully reset;
- <0: Failure; error code returned.
static uint16_t rte_event_timer_arm_burst (const struct rte_event_timer_adapter * adapter, struct rte_event_timer ** evtims, uint16_t nb_evtims) [inline], [static]¶
Arm a burst of event timers with separate expiration timeout tick for each event timer.
Before calling this function, the application allocates struct rte_event_timer objects from mempool or huge page backed application buffers of desired size. On successful allocation, application updates the struct rte_event_timer` attributes such as expiry event attributes, timeout ticks from now. This function submits the event timer arm requests to the event timer adapter and on expiry, the events will be injected to designated event queue. Timer expiry events will be generated once or periodically until cancellation based on the adapter mode.
Parameters
evtims Pointer to an array of objects of type rte_event_timer structure.
nb_evtims Number of event timers in the supplied array.
Returns
- EINVAL Invalid timer adapter, expiry event queue ID is invalid, or an expiry event's sched type doesn't match the capabilities of the destination event queue.
- EAGAIN Specified timer adapter is not running
- EALREADY A timer was encountered that was already armed
See also
Definition at line 598 of file rte_event_timer_adapter.h.
static uint16_t rte_event_timer_arm_tmo_tick_burst (const struct rte_event_timer_adapter * adapter, struct rte_event_timer ** evtims, const uint64_t timeout_ticks, const uint16_t nb_evtims) [inline], [static]¶
Arm a burst of event timers with same expiration timeout tick.
Provides the same functionality as rte_event_timer_arm_burst(), except that application can use this API when all the event timers have the same timeout expiration tick. This specialized function can provide the additional hint to the adapter implementation and optimize if possible.
Parameters
evtims Points to an array of objects of type rte_event_timer structure.
timeout_ticks The number of ticks in which the timers should expire.
nb_evtims Number of event timers in the supplied array.
Returns
- EINVAL Invalid timer adapter, expiry event queue ID is invalid, or an expiry event's sched type doesn't match the capabilities of the destination event queue.
- EAGAIN Specified event timer adapter is not running
- EALREADY A timer was encountered that was already armed
Definition at line 641 of file rte_event_timer_adapter.h.
static uint16_t rte_event_timer_cancel_burst (const struct rte_event_timer_adapter * adapter, struct rte_event_timer ** evtims, uint16_t nb_evtims) [inline], [static]¶
Cancel a burst of event timers from being scheduled to the event device.
Parameters
evtims Points to an array of objects of type rte_event_timer structure
nb_evtims Number of event timer instances in the supplied array.
Returns
- EINVAL Invalid timer adapter identifier
- EAGAIN Specified timer adapter is not running
- EALREADY A timer was encountered that was already canceled
Definition at line 678 of file rte_event_timer_adapter.h.
__rte_experimental int rte_event_timer_remaining_ticks_get (const struct rte_event_timer_adapter * adapter, const struct rte_event_timer * evtim, uint64_t * ticks_remaining)¶
Get the number of ticks remaining until event timer expiry.
Parameters
evtim A pointer to an rte_event_timer structure
ticks_remaining Pointer to variable into which to write the number of ticks remaining until event timer expiry
Returns
- 0: Success
- -EINVAL Invalid timer adapter identifier or the event timer is not in the armed state or ticks_remaining is NULL
- -ENOTSUP The timer adapter implementation does not support this API.
Author¶
Generated automatically by Doxygen for DPDK from the source code.
Fri Dec 15 2023 | Version 23.11.0 |