129 for (index = first_nf_index; index < first_nf_index +
139 "%s next index %d owns enqueue rights to %s\n",
141 index - first_nf_index,
143 fformat (stderr,
" nf index %d nf->frame %p\n",
169 fformat (stderr,
"node runtime index %d name %s\n", index,
182 else if (verbose == 1)
186 fformat (stderr,
"verbose not 0 or 1\n");
190 vlib_cli_show_errors.
function (vm, &input, 0 );
203 else if (verbose == 1)
205 else if (verbose == 2)
209 fformat (stderr,
"verbose not 0 - 2\n");
213 vlib_cli_show_session_command.
function (vm, &input, 0 );
223 return dt < 0 ? -1 : (dt > 0 ? +1 : 0);
244 fmt =
"------------------- Start of thread %d %s -------------------\n";
247 tm = &this_vlib_main->trace_main;
259 s =
format (s,
"No packets in trace buffer\n");
266 for (i = 0; i <
vec_len (traces); i++)
270 fformat (stderr,
"Limiting display to %d packets." 271 " To display more specify max.", max);
275 s =
format (s,
"Packet %d\n%U\n\n", i + 1,
306 "vgb(bi) returns vlib_get_buffer(vlib_get_main(), bi)");
313 vlib_cli_output (vm,
"gdb_validate_buffer(b) check vlib_buffer b sanity");
314 vlib_cli_output (vm,
"debug_hex_bytes (ptr, n_bytes) dumps n_bytes in hex");
316 vlib_cli_output (vm,
"vlib_runtime_index_to_node_name (index) prints NN");
324 .short_help =
"Describe functions which can be called from gdb",
376 fformat (stderr,
"gdb_validate_buffer(): %v", s);
379 fformat (stderr,
"gdb_validate_buffer(): no error found\n");
void vlib_runtime_index_to_node_name(u32 index)
GDB callable function: vlib_runtime_index_to_node_name.
u32 next_frame_index
Start of next frames for this node.
#define pool_foreach(VAR, POOL)
Iterate through pool.
#define CLIB_LOG2_CACHE_LINE_BYTES
u32 vbi(vlib_buffer_t *b)
#define vec_add1(V, E)
Add 1 element to end of vector (unspecified alignment).
vlib_buffer_main_t * buffer_main
void vlib_dump_frame_ownership(void)
GDB callable function: vlib_dump_frame_ownership.
vlib_main_t ** vlib_mains
vlib_buffer_t * vgb(u32 bi)
vnet_buffer_opaque_t * vb(void *vb_arg)
void gdb_show_session(int verbose)
vlib_trace_header_t ** trace_buffer_pool
void debug_hex_bytes(u8 *s, u32 n)
GDB callable function: debug_hex_bytes - return formatted hex string.
#define VLIB_INIT_FUNCTION(x)
description fragment has unexpected format
#define vec_elt_at_index(v, i)
Get vector value at index i checking that i is in bounds.
vlib_node_runtime_t * nodes_by_type[VLIB_N_NODE_TYPE]
pool_header_t * ph(void *p)
GDB callable function: ph - call pool_header - get pool header.
static pool_header_t * pool_header(void *v)
Get pool header from user pool pointer.
vlib_worker_thread_t * vlib_worker_threads
vlib_cli_command_t vlib_cli_show_errors
(constructor) VLIB_CLI_COMMAND (vlib_cli_show_errors)
vlib_cli_command_function_t * function
format_function_t format_vlib_trace
vlib_cli_command_t vlib_cli_show_session_command
(constructor) VLIB_CLI_COMMAND (vlib_cli_show_session_command)
static clib_error_t * show_gdb_command_fn(vlib_main_t *vm, unformat_input_t *input, vlib_cli_command_t *cmd)
GDB callable function: show_gdb_command_fn - show gdb.
u32 node_index
Node index.
#define foreach_vlib_main(body)
vec_header_t * pvh(void *p)
GDB callable function: pvh - Return vector header of vector.
sll srl srl sll sra u16x4 i
#define vec_free(V)
Free vector's memory (no header).
#define pool_is_free_index(P, I)
Use free bitmap to query whether given index is free.
vnet_buffer_opaque2_t * vb2(void *vb_arg)
#define VLIB_CLI_COMMAND(x,...)
clib_error_t * gdb_func_init(vlib_main_t *vm)
void vlib_cli_output(vlib_main_t *vm, char *fmt,...)
int gdb_validate_buffer(vlib_buffer_t *b)
int pifi(void *p, u32 index)
GDB callable function: pifi - call pool_is_free_index - is passed index free?
uword pe(void *v)
GDB callable function: pe - call pool_elts - number of elements in a pool.
static uword pointer_to_uword(const void *p)
static vlib_main_t * vlib_get_main(void)
u32 vl(void *p)
GDB callable function: vl - Return vector length of vector.
static int trace_cmp(void *a1, void *a2)
#define vec_len(v)
Number of elements in vector (rvalue-only, NULL tolerant)
vlib_node_main_t node_main
VLIB buffer representation.
vlib_next_frame_t * next_frames
#define vec_sort_with_function(vec, f)
Sort a vector using the supplied element comparison function.
u8 * vlib_validate_buffers(vlib_main_t *vm, u32 *buffers, uword next_buffer_stride, uword n_buffers, vlib_buffer_known_state_t known_state, uword follow_buffer_next)
#define vec_foreach(var, vec)
Vector iterator.
static vlib_buffer_t * vlib_get_buffer(vlib_main_t *vm, u32 buffer_index)
Translate buffer index into buffer pointer.
void trace_apply_filter(vlib_main_t *vm)
void gdb_show_errors(int verbose)
static uword pool_elts(void *v)
Number of active elements in a pool.