summaryrefslogtreecommitdiffstats
path: root/vlib
diff options
context:
space:
mode:
authorBud Grise <griseb@cisco.com>2016-02-19 12:10:33 -0500
committerGerrit Code Review <gerrit@fd.io>2016-02-26 21:01:17 +0000
commitd56a6f59e99b7adec6742cd25f0d84bacf594537 (patch)
tree868a86b3fd2554ed11744a457e18610de4ddcfd8 /vlib
parent060c6fc0b54c909db56856b4d3e3fa65265f5871 (diff)
Add packet tracing hint
This avoids checking the buffer flags bit if tracing is not enabled. Change-Id: I32e1a90b5fd10318254c611344488bc2a441c71e Signed-off-by: Todd Foggoa (tfoggoa) <tfoggoa@cisco.com>
Diffstat (limited to 'vlib')
-rw-r--r--vlib/vlib/trace.c4
-rw-r--r--vlib/vlib/trace.h3
2 files changed, 7 insertions, 0 deletions
diff --git a/vlib/vlib/trace.c b/vlib/vlib/trace.c
index b3008644e5d..4a611ee97b1 100644
--- a/vlib/vlib/trace.c
+++ b/vlib/vlib/trace.c
@@ -121,6 +121,8 @@ clear_trace_buffer (void)
tm = &this_vlib_main->trace_main;
mainheap = clib_mem_set_heap (this_vlib_main->heap_base);
+ tm->trace_active_hint = 0;
+
for (i = 0; i < vec_len (tm->trace_buffer_pool); i++)
if (! pool_is_free_index (tm->trace_buffer_pool, i))
vec_free (tm->trace_buffer_pool[i]);
@@ -369,6 +371,8 @@ cli_add_trace_buffer (vlib_main_t * vm,
void *oldheap;
tm = &this_vlib_main->trace_main;
+ tm->trace_active_hint = 1;
+
oldheap = clib_mem_set_heap (this_vlib_main->heap_base);
vec_validate (tm->nodes, node_index);
diff --git a/vlib/vlib/trace.h b/vlib/vlib/trace.h
index 50e51638fdb..fe5d7377861 100644
--- a/vlib/vlib/trace.h
+++ b/vlib/vlib/trace.h
@@ -76,6 +76,9 @@ typedef struct {
#define FILTER_FLAG_EXCLUDE 2
u32 filter_count;
+ /* set on trace add, cleared on clear trace */
+ u32 trace_active_hint;
+
/* Per node trace counts. */
vlib_trace_node_t * nodes;
} vlib_trace_main_t;