X-Git-Url: https://gerrit.fd.io/r/gitweb?a=blobdiff_plain;f=src%2Fvnet%2Fspan%2Fnode.c;h=a70dac769c8f5e60bb6460d8098e650f1f89edac;hb=a79271fad186e806060e73131d9128bd9d7ea6a4;hp=67f1d6e42bbaf0f373c76e05da6e4ac28fd5f0bd;hpb=55333d76c6501e78ed234a81301e844edc1863b2;p=vpp.git diff --git a/src/vnet/span/node.c b/src/vnet/span/node.c index 67f1d6e42bb..a70dac769c8 100644 --- a/src/vnet/span/node.c +++ b/src/vnet/span/node.c @@ -25,10 +25,8 @@ #include #include -vlib_node_registration_t span_node; - /* packet trace format function */ -u8 * +static u8 * format_span_trace (u8 * s, va_list * args) { CLIB_UNUSED (vlib_main_t * vm) = va_arg (*args, vlib_main_t *); @@ -136,7 +134,6 @@ span_node_inline_fn (vlib_main_t * vm, vlib_node_runtime_t * node, span_main_t *sm = &span_main; vnet_main_t *vnm = &vnet_main; u32 n_left_from, *from, *to_next; - u32 n_span_packets = 0; u32 next_index; u32 sw_if_index; static __thread vlib_frame_t **mirror_frames = 0; @@ -267,36 +264,32 @@ span_node_inline_fn (vlib_main_t * vm, vlib_node_runtime_t * node, vnet_put_frame_to_sw_interface (vnm, sw_if_index, f); mirror_frames[sw_if_index] = 0; } - vlib_node_increment_counter (vm, span_node.index, SPAN_ERROR_HITS, - n_span_packets); return frame->n_vectors; } -static uword -span_device_input_node_fn (vlib_main_t * vm, vlib_node_runtime_t * node, - vlib_frame_t * frame) +VLIB_NODE_FN (span_input_node) (vlib_main_t * vm, vlib_node_runtime_t * node, + vlib_frame_t * frame) { return span_node_inline_fn (vm, node, frame, VLIB_RX, SPAN_FEAT_DEVICE); } -static uword -span_device_output_node_fn (vlib_main_t * vm, vlib_node_runtime_t * node, - vlib_frame_t * frame) +VLIB_NODE_FN (span_output_node) (vlib_main_t * vm, vlib_node_runtime_t * node, + vlib_frame_t * frame) { return span_node_inline_fn (vm, node, frame, VLIB_TX, SPAN_FEAT_DEVICE); } -static uword -span_l2_input_node_fn (vlib_main_t * vm, vlib_node_runtime_t * node, - vlib_frame_t * frame) +VLIB_NODE_FN (span_l2_input_node) (vlib_main_t * vm, + vlib_node_runtime_t * node, + vlib_frame_t * frame) { return span_node_inline_fn (vm, node, frame, VLIB_RX, SPAN_FEAT_L2); } -static uword -span_l2_output_node_fn (vlib_main_t * vm, vlib_node_runtime_t * node, - vlib_frame_t * frame) +VLIB_NODE_FN (span_l2_output_node) (vlib_main_t * vm, + vlib_node_runtime_t * node, + vlib_frame_t * frame) { return span_node_inline_fn (vm, node, frame, VLIB_TX, SPAN_FEAT_L2); } @@ -315,36 +308,25 @@ span_l2_output_node_fn (vlib_main_t * vm, vlib_node_runtime_t * node, /* *INDENT-OFF* */ VLIB_REGISTER_NODE (span_input_node) = { span_node_defs, - .function = span_device_input_node_fn, .name = "span-input", }; -VLIB_NODE_FUNCTION_MULTIARCH (span_input_node, span_device_input_node_fn) - VLIB_REGISTER_NODE (span_output_node) = { span_node_defs, - .function = span_device_output_node_fn, .name = "span-output", }; -VLIB_NODE_FUNCTION_MULTIARCH (span_output_node, span_device_output_node_fn) - VLIB_REGISTER_NODE (span_l2_input_node) = { span_node_defs, - .function = span_l2_input_node_fn, .name = "span-l2-input", }; -VLIB_NODE_FUNCTION_MULTIARCH (span_l2_input_node, span_l2_input_node_fn) - VLIB_REGISTER_NODE (span_l2_output_node) = { span_node_defs, - .function = span_l2_output_node_fn, .name = "span-l2-output", }; -VLIB_NODE_FUNCTION_MULTIARCH (span_l2_output_node, span_l2_output_node_fn) - +#ifndef CLIB_MARCH_VARIANT clib_error_t *span_init (vlib_main_t * vm) { span_main_t *sm = &span_main; @@ -369,6 +351,7 @@ clib_error_t *span_init (vlib_main_t * vm) VLIB_INIT_FUNCTION (span_init); /* *INDENT-ON* */ +#endif /* CLIB_MARCH_VARIANT */ #undef span_node_defs /*