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>
This commit is contained in:
Bud Grise
2016-02-19 12:10:33 -05:00
committed by Gerrit Code Review
parent 060c6fc0b5
commit d56a6f59e9
3 changed files with 40 additions and 27 deletions

View File

@ -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);

View File

@ -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;

View File

@ -154,25 +154,28 @@ handoff_dispatch_node_fn (vlib_main_t * vm,
next0 = vnet_buffer(b0)->io_handoff.next_index;
next1 = vnet_buffer(b1)->io_handoff.next_index;
if (PREDICT_FALSE(b0->flags & VLIB_BUFFER_IS_TRACED))
if (PREDICT_FALSE(vm->trace_main.trace_active_hint))
{
vlib_trace_buffer (vm, node, next0, b0, /* follow_chain */ 0);
handoff_dispatch_trace_t *t =
vlib_add_trace (vm, node, b0, sizeof (*t));
sw_if_index0 = vnet_buffer(b0)->sw_if_index[VLIB_RX];
t->sw_if_index = sw_if_index0;
t->next_index = next0;
t->buffer_index = bi0;
}
if (PREDICT_FALSE(b1->flags & VLIB_BUFFER_IS_TRACED))
{
vlib_trace_buffer (vm, node, next1, b1, /* follow_chain */ 0);
handoff_dispatch_trace_t *t =
vlib_add_trace (vm, node, b1, sizeof (*t));
sw_if_index1 = vnet_buffer(b1)->sw_if_index[VLIB_RX];
t->sw_if_index = sw_if_index1;
t->next_index = next1;
t->buffer_index = bi1;
if (PREDICT_FALSE(b0->flags & VLIB_BUFFER_IS_TRACED))
{
vlib_trace_buffer (vm, node, next0, b0, /* follow_chain */ 0);
handoff_dispatch_trace_t *t =
vlib_add_trace (vm, node, b0, sizeof (*t));
sw_if_index0 = vnet_buffer(b0)->sw_if_index[VLIB_RX];
t->sw_if_index = sw_if_index0;
t->next_index = next0;
t->buffer_index = bi0;
}
if (PREDICT_FALSE(b1->flags & VLIB_BUFFER_IS_TRACED))
{
vlib_trace_buffer (vm, node, next1, b1, /* follow_chain */ 0);
handoff_dispatch_trace_t *t =
vlib_add_trace (vm, node, b1, sizeof (*t));
sw_if_index1 = vnet_buffer(b1)->sw_if_index[VLIB_RX];
t->sw_if_index = sw_if_index1;
t->next_index = next1;
t->buffer_index = bi1;
}
}
/* verify speculative enqueues, maybe switch current next frame */
@ -200,16 +203,19 @@ handoff_dispatch_node_fn (vlib_main_t * vm,
next0 = vnet_buffer(b0)->io_handoff.next_index;
if (PREDICT_FALSE(b0->flags & VLIB_BUFFER_IS_TRACED))
if (PREDICT_FALSE(vm->trace_main.trace_active_hint))
{
vlib_trace_buffer (vm, node, next0, b0, /* follow_chain */ 0);
handoff_dispatch_trace_t *t =
vlib_add_trace (vm, node, b0, sizeof (*t));
sw_if_index0 = vnet_buffer(b0)->sw_if_index[VLIB_RX];
t->sw_if_index = sw_if_index0;
t->next_index = next0;
t->buffer_index = bi0;
}
if (PREDICT_FALSE(b0->flags & VLIB_BUFFER_IS_TRACED))
{
vlib_trace_buffer (vm, node, next0, b0, /* follow_chain */ 0);
handoff_dispatch_trace_t *t =
vlib_add_trace (vm, node, b0, sizeof (*t));
sw_if_index0 = vnet_buffer(b0)->sw_if_index[VLIB_RX];
t->sw_if_index = sw_if_index0;
t->next_index = next0;
t->buffer_index = bi0;
}
}
/* verify speculative enqueue, maybe switch current next frame */
vlib_validate_buffer_enqueue_x1 (vm, node, next_index,