Go to the source code of this file.
|
static u8 * | format_nsh_output_trace (u8 *s, va_list *args) |
|
static uword | nsh_output_inline (vlib_main_t *vm, vlib_node_runtime_t *node, vlib_frame_t *from_frame, int is_midchain) |
|
static uword | nsh_eth_output (vlib_main_t *vm, vlib_node_runtime_t *node, vlib_frame_t *from_frame) |
|
static uword | nsh_midchain (vlib_main_t *vm, vlib_node_runtime_t *node, vlib_frame_t *from_frame) |
|
| VNET_FEATURE_INIT (nsh_interface_output, static) |
|
| VNET_FEATURE_ARC_INIT (nsh_eth_output, static) |
|
| VNET_FEATURE_INIT (nsh_eth_tx_drop, static) |
|
static uword | nsh_adj_incomplete (vlib_main_t *vm, vlib_node_runtime_t *node, vlib_frame_t *from_frame) |
| Graph node for incomplete NSH adjacency. More...
|
|
static u8 * | format_nsh_adj_incomplete_trace (u8 *s, va_list *args) |
|
#define foreach_nsh_adj_incomplete_next |
Value:_(
IP6,
"ip6-discover-neighbor")
Next index values from the NSH incomplete adj node.
Definition at line 397 of file nsh_output.c.
#define foreach_nsh_output_next |
Value:_(INTERFACE, "interface-output" )
Definition at line 32 of file nsh_output.c.
A struct to hold tracing information for the NSH label imposition node.
Enumerator |
---|
NSH_ADJ_INCOMPLETE_N_NEXT |
|
Definition at line 402 of file nsh_output.c.
Enumerator |
---|
NSH_MIDCHAIN_NEXT_DROP |
|
Definition at line 321 of file nsh_output.c.
Enumerator |
---|
NSH_OUTPUT_N_NEXT |
|
Definition at line 36 of file nsh_output.c.
static u8* format_nsh_adj_incomplete_trace |
( |
u8 * |
s, |
|
|
va_list * |
args |
|
) |
| |
|
static |
static u8* format_nsh_output_trace |
( |
u8 * |
s, |
|
|
va_list * |
args |
|
) |
| |
|
static |
Graph node for incomplete NSH adjacency.
This node will push traffic to either the v4-arp or v6-nd node based on the next-hop proto of the adj. We pay a cost for this 'routing' node, but an incomplete adj is the exception case.
Definition at line 427 of file nsh_output.c.
VNET_FEATURE_INIT |
( |
nsh_interface_output |
, |
|
|
static |
|
|
) |
| |
VNET_FEATURE_INIT |
( |
nsh_eth_tx_drop |
, |
|
|
static |
|
|
) |
| |
Initial value:= {
.name = "nsh-adj-incomplete",
.vector_size =
sizeof (
u32),
.next_nodes = {
#define _(s,n)
},
}
static u8 * format_nsh_adj_incomplete_trace(u8 *s, va_list *args)
static uword nsh_adj_incomplete(vlib_main_t *vm, vlib_node_runtime_t *node, vlib_frame_t *from_frame)
Graph node for incomplete NSH adjacency.
#define foreach_nsh_adj_incomplete_next
Next index values from the NSH incomplete adj node.
(constructor) VLIB_REGISTER_NODE (nsh_adj_incomplete_node)
Definition at line 505 of file nsh_output.c.
Initial value:= {
.name = "nsh-eth-output",
.vector_size =
sizeof (
u32),
.next_nodes = {
#define _(s,n)
},
}
static uword nsh_eth_output(vlib_main_t *vm, vlib_node_runtime_t *node, vlib_frame_t *from_frame)
static u8 * format_nsh_output_trace(u8 *s, va_list *args)
#define foreach_nsh_output_next
(constructor) VLIB_REGISTER_NODE (nsh_eth_output_node)
Definition at line 334 of file nsh_output.c.
Initial value:= {
.name = "nsh-midchain",
.vector_size =
sizeof (
u32),
.n_next_nodes = 1,
.next_nodes = {
},
}
static u8 * format_nsh_output_trace(u8 *s, va_list *args)
static uword nsh_midchain(vlib_main_t *vm, vlib_node_runtime_t *node, vlib_frame_t *from_frame)
(constructor) VLIB_REGISTER_NODE (nsh_midchain_node)
Definition at line 359 of file nsh_output.c.