Provided by: dpdk-doc_24.11.2-2_all bug

NAME

       rte_latencystats.h

SYNOPSIS

       #include <stdint.h>
       #include <rte_metrics.h>
       #include <rte_mbuf.h>

   Typedefs
       typedef uint16_t(* rte_latency_stats_flow_type_fn) (struct rte_mbuf *pkt, void *user_param)

   Functions
       int rte_latencystats_init (uint64_t samp_intvl, rte_latency_stats_flow_type_fn user_cb)
       int32_t rte_latencystats_update (void)
       int rte_latencystats_uninit (void)
       int rte_latencystats_get_names (struct rte_metric_name *names, uint16_t size)
       int rte_latencystats_get (struct rte_metric_value *values, uint16_t size)

Detailed Description

       RTE latency stats

       library to provide application and flow based latency stats.

       Definition in file rte_latencystats.h.

Typedef Documentation

   typedef uint16_t(* rte_latency_stats_flow_type_fn) (struct rte_mbuf *pkt, void *user_param)
       Note: This function pointer is for future flow based latency stats implementation.

       Function type used for identifying flow types of a Rx packet.

       The callback function is called on Rx for each packet. This function is used for flow based latency
       calculations.

       Parameters
           pkt Packet that has to be identified with its flow types.
           user_param The arbitrary user parameter passed in by the application when the callback was originally
           configured.

       Returns
           The flow_mask, representing the multiple flow types of a packet.

       Definition at line 40 of file rte_latencystats.h.

Function Documentation

   int rte_latencystats_init (uint64_t samp_intvl, rte_latency_stats_flow_type_fn user_cb)
       Registers Rx/Tx callbacks for each active port, queue.

       Parameters
           samp_intvl Sampling time period in nano seconds, at which packet should be marked with time stamp.
           user_cb Note: This param is for future flow based latency stats implementation. User callback to be
           called to get flow types of a packet. Used for flow based latency calculation. If the value is NULL,
           global stats will be calculated, else flow based latency stats will be calculated. For now just pass
           on the NULL value to this param.

       Returns
           -1 : On error -ENOMEM: On error 0 : On success

   int32_t rte_latencystats_update (void)
       Calculates the latency and jitter values internally, exposing the updated values via rte_latencystats_get
       or the rte_metrics API.

       Returns
           : 0 : on Success < 0 : Error in updating values.

   int rte_latencystats_uninit (void)
       Removes registered Rx/Tx callbacks for each active port, queue.

       Returns
           -1: On error 0: On success

   int rte_latencystats_get_names (struct rte_metric_name * names, uint16_t size)
       Retrieve names of latency statistics

       Parameters
           names Block of memory to insert names into. Must be at least size in capacity. If set to NULL,
           function returns required capacity.
           size Capacity of latency stats names (number of names).

       Returns

           • positive value lower or equal to size: success. The return value is the number of entries filled in
             the stats table.

           • positive  value  higher than size: error, the given statistics table is too small. The return value
             corresponds to the size that should be given to succeed. The entries in the table are not valid and
             shall not be used by the caller.

   int rte_latencystats_get (struct rte_metric_value * values, uint16_t size)
       Retrieve latency statistics.

       Parameters
           values A pointer to a table  of  structure  of  type  rte_metric_value  to  be  filled  with  latency
           statistics ids and values. This parameter can be set to NULL if size is 0.
           size The size of the stats table, which should be large enough to store all the latency stats.

       Returns

           • positive value lower or equal to size: success. The return value is the number of entries filled in
             the stats table.

           • positive  value  higher than size: error, the given statistics table is too small. The return value
             corresponds to the size that should be given to succeed. The entries in the table are not valid and
             shall not be used by the caller. -ENOMEM: On failure.

Author

       Generated automatically by Doxygen for DPDK from the source code.

DPDK                                             Version 24.11.2                           rte_latencystats.h(3)