X-Git-Url: https://gerrit.fd.io/r/gitweb?a=blobdiff_plain;f=src%2Fvpp%2Fstats%2Fstats.h;h=fd1ab271f78af00901d18d3785f04d7b9ba9691a;hb=048a4e5a000017d0d632ebf02dcc23d9bf9ccf72;hp=dd679a65db5df62cbac9b3c170480fbdc8dede11;hpb=e86a8edd3c14fb41ace2a12efd17bc7772bf623f;p=vpp.git diff --git a/src/vpp/stats/stats.h b/src/vpp/stats/stats.h index dd679a65db5..fd1ab271f78 100644 --- a/src/vpp/stats/stats.h +++ b/src/vpp/stats/stats.h @@ -27,6 +27,7 @@ #include #include #include +#include typedef struct { @@ -51,30 +52,6 @@ typedef CLIB_PACKED (struct }) ip4_route_t; /* *INDENT-ON* */ -/* see interface.api */ -typedef struct -{ - u32 sw_if_index; - u64 drop; - u64 punt; - u64 rx_ip4; - u64 rx_ip6; - u64 rx_no_buffer; - u64 rx_miss; - u64 rx_error; - u64 tx_error; - u64 rx_mpls; -} vnet_simple_counter_t; - -typedef struct -{ - u32 sw_if_index; - u64 rx_packets; /**< packet counter */ - u64 rx_bytes; /**< byte counter */ - u64 tx_packets; /**< packet counter */ - u64 tx_bytes; /**< byte counter */ -} vnet_combined_counter_t; - typedef struct { ip6_address_t address; @@ -181,6 +158,15 @@ typedef struct vpe_client_stats_registration_t **regs_tmp; vpe_client_registration_t **clients_tmp; + /* statistics segment */ + ssvm_private_t stat_segment; + uword *counter_vector_by_name; + clib_spinlock_t *stat_segment_lockp; + + /* Pointers to scalar stats maintained by the stat segment process */ + f64 *input_rate_ptr; + f64 *vector_rate_ptr; + /* convenience */ vlib_main_t *vlib_main; vnet_main_t *vnet_main; @@ -190,6 +176,25 @@ typedef struct extern stats_main_t stats_main; +#define STAT_SEGMENT_OPAQUE_LOCK 0 +#define STAT_SEGMENT_OPAQUE_DIR 1 +#define STAT_SEGMENT_OPAQUE_EPOCH 2 + +typedef enum +{ + STAT_DIR_TYPE_ILLEGAL = 0, + STAT_DIR_TYPE_SCALAR_POINTER, + STAT_DIR_TYPE_VECTOR_POINTER, + STAT_DIR_TYPE_COUNTER_VECTOR, + STAT_DIR_TYPE_ERROR_INDEX, +} stat_directory_type_t; + +typedef struct +{ + stat_directory_type_t type; + void *value; +} stat_segment_directory_entry_t; + #endif /* __included_stats_h__ */ /*