![]() |
FD.io VPP
v21.01.1
Vector Packet Processing
|
Include dependency graph for l2_output.c:Go to the source code of this file.
Data Structures | |
| struct | l2output_trace_t |
Macros | |
| #define | foreach_l2output_bad_intf_error _(DROP, "L2 output to interface not in L2 mode or deleted") |
Enumerations | |
| enum | l2output_bad_intf_error_t { L2OUTPUT_BAD_INTF_N_ERROR } |
Variables | |
| static char * | l2output_feat_names [] |
| l2output_main_t | l2output_main |
| static char * | l2output_error_strings [] |
| vlib_node_registration_t | l2output_node |
| (constructor) VLIB_REGISTER_NODE (l2output_node) More... | |
| static char * | l2output_bad_intf_error_strings [] |
| vlib_node_registration_t | l2output_bad_intf_node |
| (constructor) VLIB_REGISTER_NODE (l2output_bad_intf_node) More... | |
Definition at line 466 of file l2_output.c.
| Enumerator | |
|---|---|
| L2OUTPUT_BAD_INTF_N_ERROR | |
Definition at line 475 of file l2_output.c.
| VLIB_NODE_FN() l2output_bad_intf_node | ( | vlib_main_t * | vm, |
| vlib_node_runtime_t * | node, | ||
| vlib_frame_t * | frame | ||
| ) |
Output node for interfaces/tunnels which was in L2 mode but were changed to L3 mode or possibly deleted thereafter.
On changing forwarding mode of any tunnel/interface from L2 to L3, its entry in l2_output_main table next_nodes.output_node_index_vec[sw_if_index] MUST be set to the value of L2OUTPUT_NEXT_BAD_INTF. Thus, if there are stale entries in the L2FIB for this sw_if_index, l2-output will send packets for this sw_if_index to the l2-output-bad-intf node which just setup the proper drop reason before sending packets to the error-drop node to drop the packet. Then, stale L2FIB entries for deleted tunnels won't cause possible packet or memory corruption.
Definition at line 496 of file l2_output.c.
Here is the call graph for this function:| void l2output_create_output_node_mapping | ( | vlib_main_t * | vlib_main, |
| vnet_main_t * | vnet_main, | ||
| u32 | sw_if_index | ||
| ) |
Create a mapping in the next node mapping table for the given sw_if_index.
The next set of functions is for use by output feature graph nodes.
Definition at line 601 of file l2_output.c.
Here is the call graph for this function:
Here is the caller graph for this function:| char** l2output_get_feat_names | ( | void | ) |
|
static |
| void l2output_intf_bitmap_enable | ( | u32 | sw_if_index, |
| l2output_feat_masks_t | feature_bitmap, | ||
| u32 | enable | ||
| ) |
Enable (or disable) the feature in the bitmap for the given interface.
Definition at line 625 of file l2_output.c.
Here is the caller graph for this function:| l2_output_config_t* l2output_intf_config | ( | u32 | sw_if_index | ) |
Get a pointer to the config for the given interface.
Definition at line 615 of file l2_output.c.
Here is the caller graph for this function:| VLIB_NODE_FN() l2output_node | ( | vlib_main_t * | vm, |
| vlib_node_runtime_t * | node, | ||
| vlib_frame_t * | frame | ||
| ) |
| static_always_inline void l2output_process_batch | ( | vlib_main_t * | vm, |
| vlib_node_runtime_t * | node, | ||
| l2_output_config_t * | config, | ||
| vlib_buffer_t ** | b, | ||
| i16 * | cdo, | ||
| u16 * | next, | ||
| u32 | n_left, | ||
| int | l2_efp, | ||
| int | l2_vtr, | ||
| int | l2_pbb | ||
| ) |
Definition at line 266 of file l2_output.c.
Here is the call graph for this function:
Here is the caller graph for this function:| static_always_inline void l2output_process_batch_inline | ( | vlib_main_t * | vm, |
| vlib_node_runtime_t * | node, | ||
| l2_output_config_t * | config, | ||
| vlib_buffer_t ** | b, | ||
| i16 * | cdo, | ||
| u16 * | next, | ||
| u32 | n_left, | ||
| int | l2_efp, | ||
| int | l2_vtr, | ||
| int | l2_pbb, | ||
| int | shg_set, | ||
| int | update_feature_bitmap | ||
| ) |
Definition at line 134 of file l2_output.c.
Here is the call graph for this function:
Here is the caller graph for this function:| static_always_inline void l2output_set_buffer_error | ( | vlib_buffer_t ** | b, |
| u32 | n_left, | ||
| vlib_error_t | error | ||
| ) |
| static_always_inline void split_horizon_violation | ( | vlib_node_runtime_t * | node, |
| u8 | shg, | ||
| vlib_buffer_t * | b, | ||
| u16 * | next | ||
| ) |
Check for split horizon violations.
Return 0 if split horizon check passes, otherwise return non-zero. Packets should not be transmitted out an interface with the same split-horizon group as the input interface, except if the shg is 0 in which case the check always passes.
Definition at line 124 of file l2_output.c.
Here is the caller graph for this function:
|
static |
Definition at line 469 of file l2_output.c.
| vlib_node_registration_t l2output_bad_intf_node |
(constructor) VLIB_REGISTER_NODE (l2output_bad_intf_node)
Definition at line 552 of file l2_output.c.
|
static |
Definition at line 110 of file l2_output.c.
|
static |
Definition at line 31 of file l2_output.c.
| l2output_main_t l2output_main |
Definition at line 77 of file l2_output.c.
| vlib_node_registration_t l2output_node |
(constructor) VLIB_REGISTER_NODE (l2output_node)
Definition at line 446 of file l2_output.c.