libosmocore
1.5.1
Osmocom core library
|
#include "config.h"
#include <osmocom/core/byteswap.h>
#include <osmocom/core/stats.h>
#include <unistd.h>
#include <string.h>
#include <stdint.h>
#include <errno.h>
#include <stdio.h>
#include <sys/types.h>
#include <inttypes.h>
#include <osmocom/core/utils.h>
#include <osmocom/core/logging.h>
#include <osmocom/core/rate_ctr.h>
#include <osmocom/core/stat_item.h>
#include <osmocom/core/select.h>
#include <osmocom/core/counter.h>
#include <osmocom/core/msgb.h>
Macros | |
#define | TRACE(probe) |
#define | TRACE_ENABLED(probe) (0) |
#define | STATS_DEFAULT_INTERVAL 5 /* secs */ |
#define | STATS_DEFAULT_BUFLEN 256 |
Functions | |
static | LLIST_HEAD (osmo_stats_reporter_list) |
static int | osmo_stats_reporter_log_send_counter (struct osmo_stats_reporter *srep, const struct rate_ctr_group *ctrg, const struct rate_ctr_desc *desc, int64_t value, int64_t delta) |
static int | osmo_stats_reporter_log_send_item (struct osmo_stats_reporter *srep, const struct osmo_stat_item_group *statg, const struct osmo_stat_item_desc *desc, int64_t value) |
static int | update_srep_config (struct osmo_stats_reporter *srep) |
static int | osmo_stats_timer_cb (struct osmo_fd *ofd, unsigned int what) |
static int | start_timer () |
struct osmo_stats_reporter * | osmo_stats_reporter_alloc (enum osmo_stats_reporter_type type, const char *name) |
void | osmo_stats_reporter_free (struct osmo_stats_reporter *srep) |
Destroy a given stats_reporter. More... | |
void | osmo_stats_init (void *ctx) |
Initilize the stats reporting module; call this once in your program. More... | |
struct osmo_stats_reporter * | osmo_stats_reporter_find (enum osmo_stats_reporter_type type, const char *name) |
Find a stats_reporter of given type and name. More... | |
int | osmo_stats_reporter_set_max_class (struct osmo_stats_reporter *srep, enum osmo_stats_class class_id) |
int | osmo_stats_set_interval (int interval) |
Set the reporting interval (common for all reporters) More... | |
int | osmo_stats_reporter_set_flush_period (struct osmo_stats_reporter *srep, unsigned int period) |
Set the regular flush period for a given stats_reporter. More... | |
int | osmo_stats_reporter_set_name_prefix (struct osmo_stats_reporter *srep, const char *prefix) |
Set the name prefix of a given stats_reporter. More... | |
int | osmo_stats_reporter_enable (struct osmo_stats_reporter *srep) |
Enable the given stats_reporter. More... | |
int | osmo_stats_reporter_disable (struct osmo_stats_reporter *srep) |
Disable the given stats_reporter. More... | |
struct osmo_stats_reporter * | osmo_stats_reporter_create_log (const char *name) |
Create a stats_reporter that logs via libosmocore logging. More... | |
static int | osmo_stats_reporter_log_send (struct osmo_stats_reporter *srep, const char *type, const char *name1, unsigned int index1, const char *name2, int value, const char *unit) |
static int | osmo_stats_reporter_check_config (struct osmo_stats_reporter *srep, unsigned int index, int class_id) |
static int | osmo_stats_reporter_send_counter (struct osmo_stats_reporter *srep, const struct rate_ctr_group *ctrg, const struct rate_ctr_desc *desc, int64_t value, int64_t delta) |
static int | rate_ctr_handler (struct rate_ctr_group *ctrg, struct rate_ctr *ctr, const struct rate_ctr_desc *desc, void *sctx_) |
static int | rate_ctr_group_handler (struct rate_ctr_group *ctrg, void *sctx_) |
static int | osmo_stats_reporter_send_item (struct osmo_stats_reporter *srep, const struct osmo_stat_item_group *statg, const struct osmo_stat_item_desc *desc, int32_t value) |
static int | osmo_stat_item_handler (struct osmo_stat_item_group *statg, struct osmo_stat_item *item, void *sctx_) |
static int | osmo_stat_item_group_handler (struct osmo_stat_item_group *statg, void *sctx_) |
static int | handle_counter (struct osmo_counter *counter, void *sctx_) |
static void | flush_all_reporters () |
int | osmo_stats_report () |
Variables | |
static void * | osmo_stats_ctx = NULL |
static int | is_initialised = 0 |
static int32_t | current_stat_item_index = 0 |
static struct osmo_stats_config | s_stats_config |
struct osmo_stats_config * | osmo_stats_config = &s_stats_config |
static struct osmo_fd | osmo_stats_timer = { .fd = -1 } |
|
static |
|
static |
References osmo_counter::description, rate_ctr_desc::description, osmo_stats_reporter::force_single_flush, llist_for_each_entry, osmo_counter::name, rate_ctr_desc::name, osmo_counter_difference(), osmo_stats_reporter_send_counter(), osmo_stats_reporter::running, and osmo_counter::value.
Referenced by osmo_stats_report().
|
static |
|
static |
References osmo_stat_item_for_each_item(), and osmo_stat_item_handler().
Referenced by osmo_stats_report().
|
static |
References osmo_stat_item_group_desc::class_id, current_stat_item_index, osmo_stat_item::desc, osmo_stat_item_group::desc, osmo_stats_reporter::force_single_flush, osmo_stat_item_group::idx, osmo_stats_reporter::list, llist_for_each_entry, osmo_stat_item_get_last(), osmo_stat_item_get_next(), osmo_stats_reporter_check_config(), osmo_stats_reporter_send_item(), and osmo_stats_reporter::running.
Referenced by osmo_stat_item_group_handler().
|
static |
References osmo_stats_reporter::max_class, OSMO_STATS_CLASS_GLOBAL, OSMO_STATS_CLASS_SUBSCRIBER, and OSMO_STATS_CLASS_UNKNOWN.
Referenced by osmo_stat_item_handler(), and rate_ctr_handler().
|
static |
References DLSTATS, LOGL_INFO, LOGP, and osmo_stats_reporter::name_prefix.
Referenced by osmo_stats_reporter_log_send_counter(), and osmo_stats_reporter_log_send_item().
|
static |
References rate_ctr_group::desc, rate_ctr_group_desc::group_name_prefix, rate_ctr_group::idx, rate_ctr_desc::name, and osmo_stats_reporter_log_send().
Referenced by osmo_stats_reporter_create_log().
|
static |
|
static |
References osmo_stats_reporter::send_counter.
Referenced by handle_counter(), and rate_ctr_handler().
|
static |
References osmo_stats_reporter::send_item.
Referenced by osmo_stat_item_handler().
|
static |
References DLSTATS, osmo_fd::fd, llist_empty(), LOGL_NOTICE, LOGP, OSMO_ASSERT, OSMO_FD_READ, and osmo_stats_report().
Referenced by start_timer().
|
static |
References rate_ctr_for_each_counter(), and rate_ctr_handler().
Referenced by osmo_stats_report().
|
static |
References rate_ctr_group_desc::class_id, rate_ctr::current, rate_ctr_group::desc, osmo_stats_reporter::force_single_flush, rate_ctr_group::idx, osmo_stats_reporter::list, llist_for_each_entry, osmo_stats_reporter_check_config(), osmo_stats_reporter_send_counter(), rate_ctr_difference(), and osmo_stats_reporter::running.
Referenced by rate_ctr_group_handler().
|
static |
References DLSTATS, osmo_fd::fd, osmo_stats_config::interval, is_initialised, LOGL_ERROR, LOGL_INFO, LOGP, osmo_stats_timer_cb(), osmo_timerfd_disable(), osmo_timerfd_schedule(), and osmo_timerfd_setup().
Referenced by osmo_stats_init(), and osmo_stats_set_interval().
|
static |