46 (
u32) sizeof (t->
h) );
51 LISP_GPE_INPUT_NEXT_DROP,
52 LISP_GPE_INPUT_NEXT_IP4_INPUT,
53 LISP_GPE_INPUT_NEXT_IP6_INPUT,
54 LISP_GPE_INPUT_NEXT_L2_INPUT,
55 LISP_GPE_INPUT_NEXT_DROP
66 else if ((lgh->
flags & LISP_GPE_FLAGS_P) == 0)
70 return LISP_GPE_INPUT_NEXT_IP4_INPUT;
72 return LISP_GPE_INPUT_NEXT_IP6_INPUT;
74 return LISP_GPE_INPUT_NEXT_DROP;
77 return LISP_GPE_INPUT_NEXT_DROP;
83 if (LISP_GPE_INPUT_NEXT_IP4_INPUT == next_index
84 || LISP_GPE_INPUT_NEXT_IP6_INPUT == next_index)
86 else if (LISP_GPE_INPUT_NEXT_L2_INPUT == next_index)
88 clib_warning (
"next_index not associated to an interface!");
94 u32 sw_if_index,
u32 * last_sw_if_index,
u32 * n_packets,
112 cpu_index, *last_sw_if_index,
113 *n_packets, *n_bytes);
115 *last_sw_if_index = sw_if_index;
125 u32 n_left_from, next_index, *from, *to_next, cpu_index;
126 u32 n_bytes = 0, n_packets = 0, last_sw_if_index = ~0, drops = 0;
135 while (n_left_from > 0)
141 while (n_left_from >= 4 && n_left_to_next >= 2)
145 ip4_udp_lisp_gpe_header_t *iul4_0, *iul4_1;
146 ip6_udp_lisp_gpe_header_t *iul6_0, *iul6_1;
148 u32 next0, next1, error0, error1;
231 clib_net_to_host_u32 (lh0->
iid));
233 clib_net_to_host_u32 (lh1->
iid));
244 &last_sw_if_index, &n_packets, &n_bytes);
250 next0 = LISP_GPE_INPUT_NEXT_DROP;
251 error0 = LISP_GPE_ERROR_NO_TUNNEL;
259 &last_sw_if_index, &n_packets, &n_bytes);
265 next1 = LISP_GPE_INPUT_NEXT_DROP;
266 error1 = LISP_GPE_ERROR_NO_TUNNEL;
292 n_left_to_next, bi0, bi1, next0,
296 while (n_left_from > 0 && n_left_to_next > 0)
301 ip4_udp_lisp_gpe_header_t *iul4_0;
302 ip6_udp_lisp_gpe_header_t *iul6_0;
364 clib_net_to_host_u32 (lh0->
iid));
373 &last_sw_if_index, &n_packets, &n_bytes);
379 next0 = LISP_GPE_INPUT_NEXT_DROP;
380 error0 = LISP_GPE_ERROR_NO_TUNNEL;
397 n_left_to_next, bi0, next0);
405 &n_packets, &n_bytes);
407 LISP_GPE_ERROR_NO_TUNNEL, drops);
426 #define lisp_gpe_error(n,s) s, 428 #undef lisp_gpe_error 434 .name =
"lisp-gpe-ip4-input",
436 .vector_size =
sizeof (
u32),
439 #define _(s,n) [LISP_GPE_INPUT_NEXT_##s] = n, 456 .name =
"lisp-gpe-ip6-input",
458 .vector_size =
sizeof (
u32),
461 #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
#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)
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)