47 u32 next_buffer_stride,
50 u32 drop_error_node,
u32 drop_error_code)
52 u32 n_left_this_frame, n_buffers_left, *args, n_args_left;
57 n_buffers_left = n_buffers;
58 while (n_buffers_left > 0)
62 n_left_this_frame =
clib_min (n_buffers_left, n_args_left);
63 n_buffers_left -= n_left_this_frame;
64 n_args_left -= n_left_this_frame;
66 while (n_left_this_frame >= 4)
68 u32 bi0, bi1, bi2, bi3;
71 args[0] = bi0 = buffers[0];
72 args[1] = bi1 = buffers[1];
73 args[2] = bi2 = buffers[2];
74 args[3] = bi3 = buffers[3];
81 b0->
error = drop_error;
82 b1->
error = drop_error;
83 b2->
error = drop_error;
84 b3->
error = drop_error;
88 n_left_this_frame -= 4;
91 while (n_left_this_frame >= 1)
96 args[0] = bi0 = buffers[0];
99 b0->
error = drop_error;
103 n_left_this_frame -= 1;
113 __attribute__ ((weak));
116 u64 * notused3,
u64 notused4)
130 u32 node_index,
u32 n_errors,
char *error_strings[])
156 error_strings, n_errors * sizeof (error_strings[0]));
170 n_errors * sizeof (em->
counters[0]));
173 0, n_errors * sizeof (em->
counters[0]));
180 for (i = 0; i < n_errors; i++)
182 error_name =
format (0,
"/err/%v/%s%c", n->
name, error_strings[i], 0);
198 for (i = 0; i < n_errors; i++)
201 n->
name, error_strings[i]);
219 if (
unformat (input,
"verbose %d", &verbose))
221 else if (
unformat (input,
"verbose"))
235 em = &this_vlib_main->error_main;
241 for (ni = 0; ni <
vec_len (this_vlib_main->node_main.nodes); ni++)
244 for (code = 0; code < n->
n_errors; code++)
252 if (c == 0 && verbose < 2)
273 for (code = 0; code < n->
n_errors; code++)
292 .path =
"show errors",
293 .short_help =
"Show error counts",
300 .path =
"show node counters",
301 .short_help =
"Show node counters",
315 em = &this_vlib_main->error_main;
326 .path =
"clear errors",
327 .short_help =
"Clear error counters",
334 .path =
"clear node counters",
335 .short_help =
"Clear node counters",
#define vec_validate(V, I)
Make sure vector is long enough for given index (no header, unspecified alignment) ...
void vlib_stats_register_error_index(void *, u8 *, u64 *, u64)
void * vlib_stats_push_heap(void *)
static clib_error_t * show_errors(vlib_main_t *vm, unformat_input_t *input, vlib_cli_command_t *cmd)
clib_memset(h->entries, 0, sizeof(h->entries[0])*entries)
char * format
Format string.
#define clib_memcpy(d, s, n)
void vlib_register_errors(vlib_main_t *vm, u32 node_index, u32 n_errors, char *error_strings[])
u64 * counters_last_clear
void vlib_stats_pop_heap2(void *, u32, void *)
#define vec_elt_at_index(v, i)
Get vector value at index i checking that i is in bounds.
elog_event_type_t * error_elog_event_types
vlib_error_t error
Error code for buffers to be enqueued to error handler.
vlib_worker_thread_t * vlib_worker_threads
static vlib_error_t vlib_error_set(u32 node_index, u32 code)
vlib_error_main_t error_main
uword vlib_error_drop_buffers(vlib_main_t *vm, vlib_node_runtime_t *node, u32 *buffers, u32 next_buffer_stride, u32 n_buffers, u32 next_index, u32 drop_error_node, u32 drop_error_code)
#define foreach_vlib_main(body)
#define VLIB_ELOG_MAIN_LOOP
#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).
char ** error_strings_heap
static_always_inline uword vlib_get_thread_index(void)
#define vec_free(V)
Free vector's memory (no header).
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 VLIB_CLI_COMMAND(x,...)
void heap_dealloc(void *v, uword handle)
#define heap_alloc(v, size, handle)
static clib_error_t * clear_error_counters(vlib_main_t *vm, unformat_input_t *input, vlib_cli_command_t *cmd)
#define vec_len(v)
Number of elements in vector (rvalue-only, NULL tolerant)
vlib_node_main_t node_main
VLIB buffer representation.
static vlib_node_t * vlib_get_node(vlib_main_t *vm, u32 i)
Get vlib node by index.
void vlib_cli_output(vlib_main_t *vm, char *fmt,...)
static vlib_buffer_t * vlib_get_buffer(vlib_main_t *vm, u32 buffer_index)
Translate buffer index into buffer pointer.