FD.io VPP
v20.01-48-g3e0dafb74
Vector Packet Processing
trace.h
Go to the documentation of this file.
1
/*
2
* Copyright (c) 2015 Cisco and/or its affiliates.
3
* Licensed under the Apache License, Version 2.0 (the "License");
4
* you may not use this file except in compliance with the License.
5
* You may obtain a copy of the License at:
6
*
7
* http://www.apache.org/licenses/LICENSE-2.0
8
*
9
* Unless required by applicable law or agreed to in writing, software
10
* distributed under the License is distributed on an "AS IS" BASIS,
11
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
12
* See the License for the specific language governing permissions and
13
* limitations under the License.
14
*/
15
/*
16
* trace.h: VLIB trace buffer.
17
*
18
* Copyright (c) 2008 Eliot Dresselhaus
19
*
20
* Permission is hereby granted, free of charge, to any person obtaining
21
* a copy of this software and associated documentation files (the
22
* "Software"), to deal in the Software without restriction, including
23
* without limitation the rights to use, copy, modify, merge, publish,
24
* distribute, sublicense, and/or sell copies of the Software, and to
25
* permit persons to whom the Software is furnished to do so, subject to
26
* the following conditions:
27
*
28
* The above copyright notice and this permission notice shall be
29
* included in all copies or substantial portions of the Software.
30
*
31
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
32
* EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
33
* MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
34
* NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE
35
* LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION
36
* OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION
37
* WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
38
*/
39
40
#ifndef included_vlib_trace_h
41
#define included_vlib_trace_h
42
43
#include <
vppinfra/pool.h
>
44
45
typedef
struct
46
{
47
/* CPU time stamp trace was made. */
48
u64
time
;
49
50
/* Node which generated this trace. */
51
u32
node_index
;
52
53
/* Number of data words in this trace. */
54
u32
n_data
;
55
56
/* Trace data follows. */
57
u8
data
[0];
58
}
vlib_trace_header_t
;
59
60
typedef
struct
61
{
62
/* Current number of traces in buffer. */
63
u32
count
;
64
65
/* Max. number of traces to be added to buffer. */
66
u32
limit
;
67
}
vlib_trace_node_t
;
68
69
/* Callback type for post-processing the vlib trace buffer */
70
struct
vlib_main_t
;
71
struct
vlib_trace_main_t
;
72
typedef
void (
vlib_trace_buffer_callback_t
) (
struct
vlib_main_t
*,
73
struct
vlib_trace_main_t
*);
74
75
/* Callback type for alternate handling of vlib_add_trace internals */
76
struct
vlib_node_runtime_t
;
77
struct
vlib_buffer_t
;
78
typedef
void
*(
vlib_add_trace_callback_t
) (
struct
vlib_main_t
*,
79
struct
vlib_node_runtime_t
* r,
80
struct
vlib_buffer_t
* b,
81
u32
n_data_bytes);
82
83
typedef
struct
84
{
85
/* Pool of trace buffers. */
86
vlib_trace_header_t
**
trace_buffer_pool
;
87
88
u32
last_main_loop_count
;
89
u32
filter_node_index
;
90
u32
filter_flag
;
91
#define FILTER_FLAG_NONE 0
92
#define FILTER_FLAG_INCLUDE 1
93
#define FILTER_FLAG_EXCLUDE 2
94
u32
filter_count
;
95
96
/* set on trace add, cleared on clear trace */
97
u32
trace_enable
;
98
99
/* Per node trace counts. */
100
vlib_trace_node_t
*
nodes
;
101
102
/* verbosity */
103
int
verbose
;
104
105
/* a callback to enable customized consumption of the trace buffer content */
106
vlib_trace_buffer_callback_t
*
trace_buffer_callback
;
107
108
/* a callback to enable customized addition of a new trace */
109
vlib_add_trace_callback_t
*
add_trace_callback
;
110
111
}
vlib_trace_main_t
;
112
113
format_function_t
format_vlib_trace
;
114
115
#endif
/* included_vlib_trace_h */
116
117
/*
118
* fd.io coding-style-patch-verification: ON
119
*
120
* Local Variables:
121
* eval: (c-set-style "gnu")
122
* End:
123
*/
vlib_trace_main_t::filter_flag
u32 filter_flag
Definition:
trace.h:90
vlib_trace_main_t::nodes
vlib_trace_node_t * nodes
Definition:
trace.h:100
u64
unsigned long u64
Definition:
types.h:89
pool.h
Fixed length block allocator.
vlib_trace_main_t::trace_buffer_callback
vlib_trace_buffer_callback_t * trace_buffer_callback
Definition:
trace.h:106
vlib_trace_main_t
Definition:
trace.h:83
vlib_trace_header_t
Definition:
trace.h:45
vlib_trace_header_t::n_data
u32 n_data
Definition:
trace.h:54
u8
unsigned char u8
Definition:
types.h:56
vlib_trace_main_t::filter_node_index
u32 filter_node_index
Definition:
trace.h:89
format_function_t
u8 *() format_function_t(u8 *s, va_list *args)
Definition:
format.h:48
vlib_node_runtime_t
Definition:
node.h:464
vlib_trace_main_t::trace_buffer_pool
vlib_trace_header_t ** trace_buffer_pool
Definition:
trace.h:86
vlib_trace_main_t::last_main_loop_count
u32 last_main_loop_count
Definition:
trace.h:88
vlib_trace_node_t::count
u32 count
Definition:
trace.h:63
vlib_trace_main_t::trace_enable
u32 trace_enable
Definition:
trace.h:97
vlib_trace_node_t
Definition:
trace.h:60
vlib_trace_buffer_callback_t
void() vlib_trace_buffer_callback_t(struct vlib_main_t *, struct vlib_trace_main_t *)
Definition:
trace.h:72
u32
unsigned int u32
Definition:
types.h:88
vlib_trace_node_t::limit
u32 limit
Definition:
trace.h:66
format_vlib_trace
format_function_t format_vlib_trace
Definition:
trace.h:113
vlib_trace_main_t::add_trace_callback
vlib_add_trace_callback_t * add_trace_callback
Definition:
trace.h:109
vlib_trace_main_t::verbose
int verbose
Definition:
trace.h:103
vlib_trace_main_t::filter_count
u32 filter_count
Definition:
trace.h:94
vlib_add_trace_callback_t
void *() vlib_add_trace_callback_t(struct vlib_main_t *, struct vlib_node_runtime_t *r, struct vlib_buffer_t *b, u32 n_data_bytes)
Definition:
trace.h:78
data
u8 data[128]
Definition:
ipsec_types.api:87
vlib_trace_header_t::node_index
u32 node_index
Definition:
trace.h:51
vlib_trace_header_t::time
u64 time
Definition:
trace.h:48
vlib_main_t
Definition:
main.h:83
vlib_buffer_t
VLIB buffer representation.
Definition:
buffer.h:102
src
vlib
trace.h
Generated on Wed Sep 9 2020 00:04:21 for FD.io VPP by
1.8.13