f-stack/dpdk/lib/bitratestats/rte_bitrate.h

74 lines
1.5 KiB
C
Raw Normal View History

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
*/
#ifndef _RTE_BITRATE_H_
#define _RTE_BITRATE_H_
#include <stdint.h>
2017-04-21 10:43:26 +00:00
#ifdef __cplusplus
extern "C" {
#endif
/**
* 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
/**
* 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()
*
* @return
* Zero on success
* Negative on error
2017-04-21 10:43:26 +00:00
*/
int rte_stats_bitrate_reg(struct rte_stats_bitrates *bitrate_data);
2017-04-21 10:43:26 +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
#endif /* _RTE_BITRATE_H_ */