diff options
author | Filip Tehlar <ftehlar@cisco.com> | 2019-02-28 04:36:10 -0800 |
---|---|---|
committer | Damjan Marion <dmarion@me.com> | 2019-03-04 11:17:15 +0000 |
commit | b806d0e1d767d61b40169685ea6fb9aa4bf595bf (patch) | |
tree | d8978aa7626f957aeb80f8601974c138d50f9592 | |
parent | 4689da0c6104435f86fab19e6bb4d1342ce4dcaf (diff) |
stats: fix crash on early init
Change-Id: I911b5070f544c3556ad1ca584d42689c00cc38f3
Signed-off-by: Filip Tehlar <ftehlar@cisco.com>
-rw-r--r-- | src/vlib/buffer.c | 22 |
1 files changed, 18 insertions, 4 deletions
diff --git a/src/vlib/buffer.c b/src/vlib/buffer.c index 7581d9cdd48..9312e8c0e47 100644 --- a/src/vlib/buffer.c +++ b/src/vlib/buffer.c @@ -63,6 +63,17 @@ STATIC_ASSERT_OFFSET_OF (vlib_buffer_t, template_end, 64); u16 __vlib_buffer_external_hdr_size = 0; +static void +buffer_gauges_update_cached_fn (stat_segment_directory_entry_t * e, + u32 index); + +static void +buffer_gauges_update_available_fn (stat_segment_directory_entry_t * e, + u32 index); + +static void +buffer_gauges_update_used_fn (stat_segment_directory_entry_t * e, u32 index); + uword vlib_buffer_length_in_chain_slow_path (vlib_main_t * vm, vlib_buffer_t * b_first) @@ -716,11 +727,15 @@ buffer_get_cached (vlib_buffer_pool_t * bp) u32 cached = 0; vlib_buffer_pool_thread_t *bpt; + clib_spinlock_lock (&bp->lock); + /* *INDENT-OFF* */ vec_foreach (bpt, bp->threads) cached += vec_len (bpt->cached_buffers); /* *INDENT-ON* */ + clib_spinlock_unlock (&bp->lock); + return cached; } @@ -808,21 +823,20 @@ vlib_buffer_main_init (struct vlib_main_t * vm) vec_foreach (bp, bm->buffer_pools) { - name = format (0, "/buffer/cached/%s%c", bp->name, 0); + name = format (0, "/buffer-pools/%s/cached%c", bp->name, 0); stat_segment_register_gauge (name, buffer_gauges_update_cached_fn, bp - bm->buffer_pools); vec_free (name); - name = format (0, "/buffer/used/%s%c", bp->name, 0); + name = format (0, "/buffer-pools/%s/used%c", bp->name, 0); stat_segment_register_gauge (name, buffer_gauges_update_used_fn, bp - bm->buffer_pools); vec_free (name); - name = format (0, "/buffer/available/%s%c", bp->name, 0); + name = format (0, "/buffer-pools/%s/available%c", bp->name, 0); stat_segment_register_gauge (name, buffer_gauges_update_available_fn, bp - bm->buffer_pools); vec_free (name); } - done: vec_free (bmp); return err; |