vlib: refactor trajectory trace debug feature
trajectory trace has been broken for a while because we used to save the buffer trajectory in a vector pointed to in opaque2. This does not work well when opaque2 is copied (eg. because of a clone) as 2 buffers end up sharing the same vector. This dedicates a full cacheline in the buffer metadata instead when trajectory is compiled in. No dynamic allocation, no sharing, no tears. Type: refactor Change-Id: I6a028ca1b48d38f393a36979e5e452c2dd48ad3f Signed-off-by: Benoît Ganne <bganne@cisco.com>
This commit is contained in:

committed by
Damjan Marion

parent
c8983241b9
commit
f89bbbe300
@@ -233,9 +233,6 @@ mrvl_pp2_device_input_inline (vlib_main_t * vm, vlib_node_runtime_t * node,
|
||||
clib_memcpy_fast (vnet_buffer (b1)->sw_if_index, sw_if_index,
|
||||
sizeof (sw_if_index));
|
||||
|
||||
VLIB_BUFFER_TRACE_TRAJECTORY_INIT (b0);
|
||||
VLIB_BUFFER_TRACE_TRAJECTORY_INIT (b1);
|
||||
|
||||
if (PREDICT_FALSE (n_trace > 0))
|
||||
{
|
||||
mrvl_pp2_input_trace (vm, node, next0, b0, &n_trace, ppif, d);
|
||||
@@ -277,8 +274,6 @@ mrvl_pp2_device_input_inline (vlib_main_t * vm, vlib_node_runtime_t * node,
|
||||
clib_memcpy_fast (vnet_buffer (b0)->sw_if_index, sw_if_index,
|
||||
sizeof (sw_if_index));
|
||||
|
||||
VLIB_BUFFER_TRACE_TRAJECTORY_INIT (b0);
|
||||
|
||||
if (PREDICT_FALSE (n_trace > 0))
|
||||
mrvl_pp2_input_trace (vm, node, next0, b0, &n_trace, ppif, d);
|
||||
|
||||
|
Reference in New Issue
Block a user