45 #define foreach_hdlc_input_next \ 46 _ (PUNT, "error-punt") \ 47 _ (DROP, "error-drop") 50 #define _(s,n) HDLC_INPUT_NEXT_##s, 85 u32 n_left_from, next_index, i_next, * from, * to_next;
100 while (n_left_from > 0)
105 to_next, n_left_to_next);
107 while (n_left_from >= 4 && n_left_to_next >= 2)
112 u32 i0, i1, len0, len1, protocol0, protocol1, enqueue_code;
147 len0 =
sizeof (h0[0]);
148 len1 =
sizeof (h1[0]);
150 len0 += protocol0 == clib_host_to_net_u16 (HDLC_PROTOCOL_osi);
151 len1 += protocol1 == clib_host_to_net_u16 (HDLC_PROTOCOL_osi);
165 enqueue_code = (i0 != i_next) + 2*(i1 != i_next);
169 switch (enqueue_code)
204 while (n_left_from > 0 && n_left_to_next > 0)
209 u32 i0, len0, protocol0;
225 len0 =
sizeof (h0[0]);
226 len0 += protocol0 == clib_host_to_net_u16 (HDLC_PROTOCOL_osi);
245 to_next, n_left_to_next);
260 #define hdlc_error(n,s) s, 267 .name =
"hdlc-input",
269 .vector_size =
sizeof (
u32),
273 .n_errors = HDLC_N_ERROR,
278 #define _(s,n) [HDLC_INPUT_NEXT_##s] = n, #define vec_validate(V, I)
Make sure vector is long enough for given index (no header, unspecified alignment) ...
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.
static hdlc_protocol_info_t * hdlc_get_protocol_info(hdlc_main_t *em, hdlc_protocol_t protocol)
sll srl srl sll sra u16x4 i
vlib_node_registration_t hdlc_input_node
(constructor) VLIB_REGISTER_NODE (hdlc_input_node)
static void vlib_set_next_frame_buffer(vlib_main_t *vm, vlib_node_runtime_t *node, u32 next_index, u32 buffer_index)
static uword hdlc_input(vlib_main_t *vm, vlib_node_runtime_t *node, vlib_frame_t *from_frame)
static char * hdlc_error_strings[]
format_function_t format_hdlc_header_with_length
#define clib_error_report(e)
static uword vlib_node_add_next(vlib_main_t *vm, uword node, uword next_node)
static void hdlc_setup_node(vlib_main_t *vm, u32 node_index)
i16 current_data
signed offset in data[], pre_data[] that we are currently processing.
#define VLIB_INIT_FUNCTION(x)
#define sparse_vec_validate(v, i)
static clib_error_t * hdlc_init(vlib_main_t *vm)
static void sparse_vec_index2(void *v, u32 si0, u32 si1, u32 *i0_return, u32 *i1_return)
#define vlib_call_init_function(vm, x)
u16 current_length
Nbytes between current data and the end of this buffer.
static void * vlib_node_get_runtime_data(vlib_main_t *vm, u32 node_index)
Get node runtime private data by node index.
#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.
unformat_function_t unformat_hdlc_header
#define foreach_hdlc_input_next
#define CLIB_PREFETCH(addr, size, type)
static u8 * format_hdlc_input_trace(u8 *s, va_list *va)
static uword sparse_vec_index(void *v, uword sparse_index)
#define VLIB_NODE_FLAG_TRACE
#define vec_elt(v, i)
Get vector value at index i.
void vlib_trace_frame_buffers_only(vlib_main_t *vm, vlib_node_runtime_t *node, u32 *buffers, uword n_buffers, uword next_buffer_stride, uword n_buffer_data_bytes_in_trace)
void hdlc_register_input_protocol(vlib_main_t *vm, hdlc_protocol_t protocol, u32 node_index)
static clib_error_t * hdlc_input_init(vlib_main_t *vm)
#define vec_len(v)
Number of elements in vector (rvalue-only, NULL tolerant)
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,...)
format_function_t format_hdlc_header
static void * sparse_vec_new(uword elt_bytes, uword sparse_index_bits)
uword runtime_data[(128-1 *sizeof(vlib_node_function_t *)-1 *sizeof(vlib_error_t *)-11 *sizeof(u32)-5 *sizeof(u16))/sizeof(uword)]
static vlib_buffer_t * vlib_get_buffer(vlib_main_t *vm, u32 buffer_index)
Translate buffer index into buffer pointer.
#define SPARSE_VEC_INVALID_INDEX