X-Git-Url: https://gerrit.fd.io/r/gitweb?a=blobdiff_plain;f=src%2Fvpp%2Fstats%2Fstat_segment.h;h=28e9ca3f778e619ae4ba6e63910a5c65ea0ba725;hb=refs%2Fchanges%2F46%2F26546%2F4;hp=4167695a94cd059c2ecd6ac4ad0f489d27d775d6;hpb=fe269f3c6f350444a17e4829311ac64dd0175641;p=vpp.git diff --git a/src/vpp/stats/stat_segment.h b/src/vpp/stats/stat_segment.h index 4167695a94c..28e9ca3f778 100644 --- a/src/vpp/stats/stat_segment.h +++ b/src/vpp/stats/stat_segment.h @@ -16,14 +16,15 @@ #ifndef included_stat_segment_h #define included_stat_segment_h -#include #include #include -#include +#include typedef enum { STAT_COUNTER_VECTOR_RATE = 0, + STAT_COUNTER_NUM_WORKER_THREADS, + STAT_COUNTER_VECTOR_RATE_PER_WORKER, STAT_COUNTER_INPUT_RATE, STAT_COUNTER_LAST_UPDATE, STAT_COUNTER_LAST_STATS_CLEAR, @@ -34,48 +35,36 @@ typedef enum STAT_COUNTER_NODE_SUSPENDS, STAT_COUNTER_INTERFACE_NAMES, STAT_COUNTER_NODE_NAMES, + STAT_COUNTER_MEM_STATSEG_TOTAL, + STAT_COUNTER_MEM_STATSEG_USED, STAT_COUNTERS } stat_segment_counter_t; -#define foreach_stat_segment_counter_name \ - _(VECTOR_RATE, SCALAR_INDEX, vector_rate, /sys) \ - _(INPUT_RATE, SCALAR_INDEX, input_rate, /sys) \ - _(LAST_UPDATE, SCALAR_INDEX, last_update, /sys) \ - _(LAST_STATS_CLEAR, SCALAR_INDEX, last_stats_clear, /sys) \ - _(HEARTBEAT, SCALAR_INDEX, heartbeat, /sys) \ - _(NODE_CLOCKS, COUNTER_VECTOR_SIMPLE, clocks, /sys/node) \ - _(NODE_VECTORS, COUNTER_VECTOR_SIMPLE, vectors, /sys/node) \ - _(NODE_CALLS, COUNTER_VECTOR_SIMPLE, calls, /sys/node) \ - _(NODE_SUSPENDS, COUNTER_VECTOR_SIMPLE, suspends, /sys/node) \ +#define foreach_stat_segment_counter_name \ + _(VECTOR_RATE, SCALAR_INDEX, vector_rate, /sys) \ + _(VECTOR_RATE_PER_WORKER, COUNTER_VECTOR_SIMPLE, \ + vector_rate_per_worker, /sys) \ + _(NUM_WORKER_THREADS, SCALAR_INDEX, num_worker_threads, /sys) \ + _(INPUT_RATE, SCALAR_INDEX, input_rate, /sys) \ + _(LAST_UPDATE, SCALAR_INDEX, last_update, /sys) \ + _(LAST_STATS_CLEAR, SCALAR_INDEX, last_stats_clear, /sys) \ + _(HEARTBEAT, SCALAR_INDEX, heartbeat, /sys) \ + _(NODE_CLOCKS, COUNTER_VECTOR_SIMPLE, clocks, /sys/node) \ + _(NODE_VECTORS, COUNTER_VECTOR_SIMPLE, vectors, /sys/node) \ + _(NODE_CALLS, COUNTER_VECTOR_SIMPLE, calls, /sys/node) \ + _(NODE_SUSPENDS, COUNTER_VECTOR_SIMPLE, suspends, /sys/node) \ _(INTERFACE_NAMES, NAME_VECTOR, names, /if) \ - _(NODE_NAMES, NAME_VECTOR, names, /sys/node) - -typedef struct -{ - stat_directory_type_t type; - union { - uint64_t offset; - uint64_t index; - uint64_t value; - }; - uint64_t offset_vector; - char name[128]; // TODO change this to pointer to "somewhere" -} stat_segment_directory_entry_t; + _(NODE_NAMES, NAME_VECTOR, names, /sys/node) \ + _(MEM_STATSEG_TOTAL, SCALAR_INDEX, total, /mem/statseg) \ + _(MEM_STATSEG_USED, SCALAR_INDEX, used, /mem/statseg) /* Default stat segment 32m */ #define STAT_SEGMENT_DEFAULT_SIZE (32<<20) -/* - * Shared header first in the shared memory segment. - */ -typedef struct -{ - atomic_int_fast64_t epoch; - atomic_int_fast64_t in_progress; - atomic_int_fast64_t directory_offset; - atomic_int_fast64_t error_offset; - atomic_int_fast64_t stats_offset; -} stat_segment_shared_header_t; +/* Shared segment memory layout version */ +#define STAT_SEGMENT_VERSION 1 + +#define STAT_SEGMENT_INDEX_INVALID UINT32_MAX static inline uint64_t stat_segment_offset (void *start, void *data) @@ -83,12 +72,6 @@ stat_segment_offset (void *start, void *data) return (char *) data - (char *) start; } -static inline void * -stat_segment_pointer (void *start, uint64_t offset) -{ - return ((char *) start + offset); -} - typedef void (*stat_segment_update_fn)(stat_segment_directory_entry_t * e, u32 i); typedef struct { @@ -105,9 +88,13 @@ typedef struct /* statistics segment */ uword *directory_vector_by_name; stat_segment_directory_entry_t *directory_vector; + u64 *error_vector; u8 **interfaces; u8 **nodes; + /* Update interval */ + f64 update_interval; + clib_spinlock_t *stat_segment_lockp; clib_socket_t *socket; u8 *socket_name; @@ -125,5 +112,10 @@ extern stat_segment_main_t stat_segment_main; clib_error_t * stat_segment_register_gauge (u8 *names, stat_segment_update_fn update_fn, u32 index); +clib_error_t * +stat_segment_register_state_counter(u8 *name, u32 *index); +clib_error_t * +stat_segment_deregister_state_counter(u32 index); +void stat_segment_set_state_counter (u32 index, u64 value); #endif