f5b4a9aa02
This commit addresses the following errors: In file included from build/include/rte_latencystats.h:43:0, from /tmp/check-includes.sh.6580.c:1: build/include/rte_metrics.h:91:2: error: unknown type name 'uint16_t' [...] In file included from /tmp/check-includes.sh.6580.c:1:0: build/include/rte_latencystats.h:66:19: error: expected declaration specifiers or '...' before '*' token [...] Fixes: 5cd3cac9ed22 ("latency: added new library for latency stats") Signed-off-by: Adrien Mazarguil <adrien.mazarguil@6wind.com>
157 lines
5.3 KiB
C
157 lines
5.3 KiB
C
/*-
|
|
* BSD LICENSE
|
|
*
|
|
* Copyright(c) 2017 Intel Corporation. All rights reserved.
|
|
*
|
|
* Redistribution and use in source and binary forms, with or without
|
|
* modification, are permitted provided that the following conditions
|
|
* are met:
|
|
*
|
|
* * Redistributions of source code must retain the above copyright
|
|
* notice, this list of conditions and the following disclaimer.
|
|
* * Redistributions in binary form must reproduce the above copyright
|
|
* notice, this list of conditions and the following disclaimer in
|
|
* the documentation and/or other materials provided with the
|
|
* distribution.
|
|
* * Neither the name of Intel Corporation nor the names of its
|
|
* contributors may be used to endorse or promote products derived
|
|
* from this software without specific prior written permission.
|
|
*
|
|
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
|
|
* "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
|
|
* LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
|
|
* A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
|
|
* OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
|
|
* SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
|
|
* LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
|
|
* DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
|
|
* THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
|
|
* (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
|
|
* OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
|
*/
|
|
|
|
#ifndef _RTE_LATENCYSTATS_H_
|
|
#define _RTE_LATENCYSTATS_H_
|
|
|
|
/**
|
|
* @file
|
|
* RTE latency stats
|
|
*
|
|
* library to provide application and flow based latency stats.
|
|
*/
|
|
|
|
#include <stdint.h>
|
|
#include <rte_metrics.h>
|
|
#include <rte_mbuf.h>
|
|
|
|
#ifdef __cplusplus
|
|
extern "C" {
|
|
#endif
|
|
|
|
/**
|
|
* Note: This function pointer is for future flow based latency stats
|
|
* implementation.
|
|
*
|
|
* Function type used for identifting 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.
|
|
*
|
|
* @param pkt
|
|
* Packet that has to be identified with its flow types.
|
|
* @param user_param
|
|
* The arbitrary user parameter passed in by the application when
|
|
* the callback was originally configured.
|
|
* @return
|
|
* The flow_mask, representing the multiple flow types of a packet.
|
|
*/
|
|
typedef uint16_t (*rte_latency_stats_flow_type_fn)(struct rte_mbuf *pkt,
|
|
void *user_param);
|
|
|
|
/**
|
|
* Registers Rx/Tx callbacks for each active port, queue.
|
|
*
|
|
* @param samp_intvl
|
|
* Sampling time period in nano seconds, at which packet
|
|
* should be marked with time stamp.
|
|
* @param 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.
|
|
* @return
|
|
* -1 : On error
|
|
* -ENOMEM: On error
|
|
* 0 : On success
|
|
*/
|
|
int rte_latencystats_init(uint64_t samp_intvl,
|
|
rte_latency_stats_flow_type_fn user_cb);
|
|
|
|
/**
|
|
* Calculates the latency and jitter values internally, exposing the updated
|
|
* values via *rte_latencystats_get* or the rte_metrics API.
|
|
* @return:
|
|
* 0 : on Success
|
|
* < 0 : Error in updating values.
|
|
*/
|
|
int32_t rte_latencystats_update(void);
|
|
|
|
/**
|
|
* Removes registered Rx/Tx callbacks for each active port, queue.
|
|
*
|
|
* @return
|
|
* -1: On error
|
|
* 0: On success
|
|
*/
|
|
int rte_latencystats_uninit(void);
|
|
|
|
/**
|
|
* Retrieve names of latency statistics
|
|
*
|
|
* @param names
|
|
* Block of memory to insert names into. Must be at least size in capacity.
|
|
* If set to NULL, function returns required capacity.
|
|
* @param size
|
|
* Capacity of latency stats names (number of names).
|
|
* @return
|
|
* - 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_names(struct rte_metric_name *names,
|
|
uint16_t size);
|
|
|
|
/**
|
|
* Retrieve latency statistics.
|
|
*
|
|
* @param 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.
|
|
* @param size
|
|
* The size of the stats table, which should be large enough to store
|
|
* all the latency stats.
|
|
* @return
|
|
* - 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.
|
|
*/
|
|
int rte_latencystats_get(struct rte_metric_value *values,
|
|
uint16_t size);
|
|
|
|
#ifdef __cplusplus
|
|
}
|
|
#endif
|
|
|
|
#endif /* _RTE_LATENCYSTATS_H_ */
|