X-Git-Url: https://gerrit.fd.io/r/gitweb?a=blobdiff_plain;f=src%2Fvlib%2Fcounter.c;h=5c3350fceecbf67d4eb81262b5edf5fe75b45172;hb=58492a83722caf1c49977d73abf931418ce1f8f2;hp=62f4bd66ddc687b6773cfdcd94527e5cc45260be;hpb=1bd01099a6512b6119bbf337b36222a6f0770d49;p=vpp.git diff --git a/src/vlib/counter.c b/src/vlib/counter.c index 62f4bd66ddc..5c3350fceec 100644 --- a/src/vlib/counter.c +++ b/src/vlib/counter.c @@ -74,15 +74,32 @@ vlib_clear_combined_counters (vlib_combined_counter_main_t * cm) } } +void *vlib_stats_push_heap (void) __attribute__ ((weak)); +void * +vlib_stats_push_heap (void) +{ + return 0; +}; + +void vlib_stats_pop_heap (void *, void *, int) __attribute__ ((weak)); +void +vlib_stats_pop_heap (void *notused, void *notused2, int type) +{ +}; + void vlib_validate_simple_counter (vlib_simple_counter_main_t * cm, u32 index) { vlib_thread_main_t *tm = vlib_get_thread_main (); int i; + void *oldheap = vlib_stats_push_heap (); vec_validate (cm->counters, tm->n_vlib_mains - 1); for (i = 0; i < tm->n_vlib_mains; i++) vec_validate_aligned (cm->counters[i], index, CLIB_CACHE_LINE_BYTES); + + vlib_stats_pop_heap (cm, oldheap, + 2 /* STAT_DIR_TYPE_COUNTER_VECTOR_SIMPLE */ ); } void @@ -90,10 +107,14 @@ vlib_validate_combined_counter (vlib_combined_counter_main_t * cm, u32 index) { vlib_thread_main_t *tm = vlib_get_thread_main (); int i; + void *oldheap = vlib_stats_push_heap (); vec_validate (cm->counters, tm->n_vlib_mains - 1); for (i = 0; i < tm->n_vlib_mains; i++) vec_validate_aligned (cm->counters[i], index, CLIB_CACHE_LINE_BYTES); + + vlib_stats_pop_heap (cm, oldheap, + 3 /*STAT_DIR_TYPE_COUNTER_VECTOR_COMBINED */ ); } u32