2019-06-25 11:12:58 +00:00
|
|
|
/* SPDX-License-Identifier: BSD-3-Clause
|
|
|
|
* Copyright(c) 2017 Intel Corporation
|
2017-04-21 10:43:26 +00:00
|
|
|
*/
|
|
|
|
|
2018-05-15 09:49:22 +00:00
|
|
|
#ifndef _RTE_BITRATE_H_
|
|
|
|
#define _RTE_BITRATE_H_
|
|
|
|
|
|
|
|
#include <stdint.h>
|
2017-04-21 10:43:26 +00:00
|
|
|
|
|
|
|
#ifdef __cplusplus
|
|
|
|
extern "C" {
|
|
|
|
#endif
|
|
|
|
|
2018-05-15 09:49:22 +00:00
|
|
|
/**
|
|
|
|
* Bitrate statistics data structure.
|
|
|
|
* This data structure is intentionally opaque.
|
|
|
|
*/
|
|
|
|
struct rte_stats_bitrates;
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Allocate a bitrate statistics structure
|
|
|
|
*
|
|
|
|
* @return
|
|
|
|
* - Pointer to structure on success
|
|
|
|
* - NULL on error (zmalloc failure)
|
|
|
|
*/
|
|
|
|
struct rte_stats_bitrates *rte_stats_bitrate_create(void);
|
|
|
|
|
2021-02-05 08:48:47 +00:00
|
|
|
/**
|
|
|
|
* Free bitrate statistics structure
|
|
|
|
*
|
|
|
|
* @param bitrate_data
|
|
|
|
* Pointer allocated by rte_stats_bitrate_create()
|
2023-09-13 12:21:49 +00:00
|
|
|
* If bitrate_data is NULL, no operation is performed.
|
2021-02-05 08:48:47 +00:00
|
|
|
*/
|
|
|
|
void rte_stats_bitrate_free(struct rte_stats_bitrates *bitrate_data);
|
2017-04-21 10:43:26 +00:00
|
|
|
|
|
|
|
/**
|
2018-05-15 09:49:22 +00:00
|
|
|
* Register bitrate statistics with the metric library.
|
|
|
|
*
|
|
|
|
* @param bitrate_data
|
2021-02-05 08:48:47 +00:00
|
|
|
* Pointer allocated by rte_stats_bitrate_create()
|
2018-05-15 09:49:22 +00:00
|
|
|
*
|
|
|
|
* @return
|
|
|
|
* Zero on success
|
|
|
|
* Negative on error
|
2017-04-21 10:43:26 +00:00
|
|
|
*/
|
2018-05-15 09:49:22 +00:00
|
|
|
int rte_stats_bitrate_reg(struct rte_stats_bitrates *bitrate_data);
|
2017-04-21 10:43:26 +00:00
|
|
|
|
|
|
|
|
2018-05-15 09:49:22 +00:00
|
|
|
/**
|
|
|
|
* Calculate statistics for current time window. The period with which
|
|
|
|
* this function is called should be the intended sampling window width.
|
|
|
|
*
|
|
|
|
* @param bitrate_data
|
|
|
|
* Bitrate statistics data pointer
|
|
|
|
*
|
|
|
|
* @param port_id
|
|
|
|
* Port id to calculate statistics for
|
|
|
|
*
|
|
|
|
* @return
|
|
|
|
* - Zero on success
|
|
|
|
* - Negative value on error
|
|
|
|
*/
|
|
|
|
int rte_stats_bitrate_calc(struct rte_stats_bitrates *bitrate_data,
|
|
|
|
uint16_t port_id);
|
|
|
|
|
2017-04-21 10:43:26 +00:00
|
|
|
#ifdef __cplusplus
|
|
|
|
}
|
|
|
|
#endif
|
|
|
|
|
2018-05-15 09:49:22 +00:00
|
|
|
#endif /* _RTE_BITRATE_H_ */
|