50 (
u32) sizeof (t->
h) );
55 LISP_GPE_INPUT_NEXT_DROP,
56 LISP_GPE_INPUT_NEXT_IP4_INPUT,
57 LISP_GPE_INPUT_NEXT_IP6_INPUT,
58 LISP_GPE_INPUT_NEXT_L2_INPUT,
59 LISP_GPE_INPUT_NEXT_DROP
70 else if ((lgh->
flags & LISP_GPE_FLAGS_P) == 0)
74 return LISP_GPE_INPUT_NEXT_IP4_INPUT;
76 return LISP_GPE_INPUT_NEXT_IP6_INPUT;
78 return LISP_GPE_INPUT_NEXT_DROP;
81 return LISP_GPE_INPUT_NEXT_DROP;
87 if (LISP_GPE_INPUT_NEXT_IP4_INPUT == next_index
88 || LISP_GPE_INPUT_NEXT_IP6_INPUT == next_index)
90 else if (LISP_GPE_INPUT_NEXT_L2_INPUT == next_index)
92 clib_warning (
"next_index not associated to an interface!");
98 u32 sw_if_index,
u32 * last_sw_if_index,
u32 * n_packets,
116 cpu_index, *last_sw_if_index,
117 *n_packets, *n_bytes);
119 *last_sw_if_index = sw_if_index;
144 u32 n_left_from, next_index, *from, *to_next, cpu_index;
145 u32 n_bytes = 0, n_packets = 0, last_sw_if_index = ~0, drops = 0;
154 while (n_left_from > 0)
160 while (n_left_from >= 4 && n_left_to_next >= 2)
164 ip4_udp_lisp_gpe_header_t *iul4_0, *iul4_1;
165 ip6_udp_lisp_gpe_header_t *iul6_0, *iul6_1;
167 u32 next0, next1, error0, error1;
250 clib_net_to_host_u32 (lh0->
iid));
252 clib_net_to_host_u32 (lh1->
iid));
263 &last_sw_if_index, &n_packets, &n_bytes);
269 next0 = LISP_GPE_INPUT_NEXT_DROP;
270 error0 = LISP_GPE_ERROR_NO_TUNNEL;
278 &last_sw_if_index, &n_packets, &n_bytes);
284 next1 = LISP_GPE_INPUT_NEXT_DROP;
285 error1 = LISP_GPE_ERROR_NO_TUNNEL;
311 n_left_to_next, bi0, bi1, next0,
315 while (n_left_from > 0 && n_left_to_next > 0)
320 ip4_udp_lisp_gpe_header_t *iul4_0;
321 ip6_udp_lisp_gpe_header_t *iul6_0;
384 clib_net_to_host_u32 (lh0->
iid << 8));
393 &last_sw_if_index, &n_packets, &n_bytes);
399 next0 = LISP_GPE_INPUT_NEXT_DROP;
400 error0 = LISP_GPE_ERROR_NO_TUNNEL;
417 n_left_to_next, bi0, next0);
425 &n_packets, &n_bytes);
427 LISP_GPE_ERROR_NO_TUNNEL, drops);
446 #define lisp_gpe_error(n,s) s, 448 #undef lisp_gpe_error 454 .name =
"lisp-gpe-ip4-input",
456 .vector_size =
sizeof (
u32),
459 #define _(s,n) [LISP_GPE_INPUT_NEXT_##s] = n, 476 .name =
"lisp-gpe-ip6-input",
478 .vector_size =
sizeof (
u32),
481 #define _(s,n) [LISP_GPE_INPUT_NEXT_##s] = n, void vlib_put_next_frame(vlib_main_t *vm, vlib_node_runtime_t *r, u32 next_index, u32 n_vectors_left)
Release pointer to next frame vector data.
#define foreach_lisp_gpe_ip_input_next
vlib_node_registration_t lisp_gpe_ip4_input_node
(constructor) VLIB_REGISTER_NODE (lisp_gpe_ip4_input_node)
vnet_interface_main_t interface_main
static tunnel_lookup_t * next_index_to_iface(lisp_gpe_main_t *lgm, u32 next_index)
static uword lisp_gpe_ip4_input(vlib_main_t *vm, vlib_node_runtime_t *node, vlib_frame_t *from_frame)
static_always_inline void incr_decap_stats(vnet_main_t *vnm, u32 cpu_index, u32 length, u32 sw_if_index, u32 *last_sw_if_index, u32 *n_packets, u32 *n_bytes)
static uword vlib_buffer_length_in_chain(vlib_main_t *vm, vlib_buffer_t *b)
Get length in bytes of the buffer chain.
static lisp_gpe_main_t * vnet_lisp_gpe_get_main()
#define static_always_inline
static uword lisp_gpe_ip6_input(vlib_main_t *vm, vlib_node_runtime_t *node, vlib_frame_t *from_frame)
static void * vlib_buffer_get_current(vlib_buffer_t *b)
Get pointer to current data to process.
vlib_combined_counter_main_t * combined_sw_if_counters
#define clib_warning(format, args...)
u8 * format_lisp_gpe_header_with_length(u8 *s, va_list *args)
static char * lisp_gpe_ip4_input_error_strings[]
vlib_node_registration_t lisp_gpe_ip6_input_node
(constructor) VLIB_REGISTER_NODE (lisp_gpe_ip6_input_node)
uword os_get_cpu_number(void)
#define vlib_validate_buffer_enqueue_x2(vm, node, next_index, to_next, n_left_to_next, bi0, bi1, next0, next1)
Finish enqueueing two buffers forward in the graph.
#define vlib_validate_buffer_enqueue_x1(vm, node, next_index, to_next, n_left_to_next, bi0, next0)
Finish enqueueing one buffer forward in the graph.
#define vlib_get_next_frame(vm, node, next_index, vectors, n_vectors_left)
Get pointer to next frame vector data by (vlib_node_runtime_t, next_index).
vlib_error_t error
Error code for buffers to be enqueued to error handler.
static void vlib_node_increment_counter(vlib_main_t *vm, u32 node_index, u32 counter_index, u64 increment)
uword * sw_if_index_by_vni
lookup decap tunnel termination sw_if_index by vni and vice versa
#define CLIB_PREFETCH(addr, size, type)
tunnel_lookup_t l2_ifaces
static void vlib_buffer_advance(vlib_buffer_t *b, word l)
Advance current data pointer by the supplied (signed!) amount.
static uword lisp_gpe_input_inline(vlib_main_t *vm, vlib_node_runtime_t *node, vlib_frame_t *from_frame, u8 is_v4)
LISP-GPE decap dispatcher.
static void vlib_increment_combined_counter(vlib_combined_counter_main_t *cm, u32 cpu_index, u32 index, u32 packet_increment, u32 byte_increment)
Increment a combined counter.
#define VLIB_BUFFER_IS_TRACED
static void * vlib_add_trace(vlib_main_t *vm, vlib_node_runtime_t *r, vlib_buffer_t *b, u32 n_data_bytes)
static u32 next_proto_to_next_index[LISP_GPE_NEXT_PROTOS]
tunnel_lookup_t l3_ifaces
static void * vlib_frame_vector_args(vlib_frame_t *f)
Get pointer to frame vector data.
#define vlib_prefetch_buffer_header(b, type)
Prefetch buffer metadata.
#define VLIB_REGISTER_NODE(x,...)
static u32 next_protocol_to_next_index(lisp_gpe_header_t *lgh, u8 *next_header)
#define CLIB_CACHE_LINE_BYTES
u32 flags
buffer flags: VLIB_BUFFER_IS_TRACED: trace this buffer.
static vlib_buffer_t * vlib_get_buffer(vlib_main_t *vm, u32 buffer_index)
Translate buffer index into buffer pointer.
static u8 * format_lisp_gpe_rx_trace(u8 *s, va_list *args)