]> git.proxmox.com Git - mirror_frr.git/blame - lib/libfrr_trace.h
Merge pull request #12798 from donaldsharp/rib_match_multicast
[mirror_frr.git] / lib / libfrr_trace.h
CommitLineData
acddc0ed 1// SPDX-License-Identifier: GPL-2.0-or-later
0cbcadcc
QY
2/* Tracing
3 *
4 * Copyright (C) 2020 NVIDIA Corporation
5 * Quentin Young
0cbcadcc
QY
6 */
7
912d45a1
QY
8#if !defined(_LIBFRR_TRACE_H_) || defined(TRACEPOINT_HEADER_MULTI_READ)
9#define _LIBFRR_TRACE_H_
0cbcadcc 10
c7bb4f00 11#include "trace.h"
0cbcadcc
QY
12
13#ifdef HAVE_LTTNG
14
15#undef TRACEPOINT_PROVIDER
16#define TRACEPOINT_PROVIDER frr_libfrr
17
18#undef TRACEPOINT_INCLUDE
912d45a1 19#define TRACEPOINT_INCLUDE "./libfrr_trace.h"
0cbcadcc 20
0cbcadcc 21#include <lttng/tracepoint.h>
abf96a87
QY
22
23#include "hash.h"
24#include "thread.h"
d92658f4
QY
25#include "memory.h"
26#include "linklist.h"
a72255a3 27#include "table.h"
abf96a87
QY
28
29/* clang-format off */
30
31TRACEPOINT_EVENT(
32 frr_libfrr,
33 hash_get,
34 TP_ARGS(struct hash *, hash, void *, data),
35 TP_FIELDS(
36 ctf_string(name, hash->name ? hash->name : "(unnamed)")
37 ctf_integer(unsigned int, index_size, hash->size)
38 ctf_integer(unsigned long, item_count, hash->count)
39 ctf_integer_hex(intptr_t, data_ptr, data)
40 )
41)
42
43TRACEPOINT_LOGLEVEL(frr_libfrr, hash_get, TRACE_INFO)
44
67a485d1
QY
45TRACEPOINT_EVENT(
46 frr_libfrr,
47 hash_insert,
48 TP_ARGS(struct hash *, hash, void *, data, unsigned int, key),
49 TP_FIELDS(
50 ctf_string(name, hash->name ? hash->name : "(unnamed)")
51 ctf_integer(unsigned int, key, hash->size)
52 ctf_integer(unsigned int, index_size, hash->size)
53 ctf_integer(unsigned long, item_count, hash->count)
54 ctf_integer_hex(intptr_t, data_ptr, data)
55 )
56)
57
58TRACEPOINT_LOGLEVEL(frr_libfrr, hash_insert, TRACE_INFO)
59
abf96a87
QY
60TRACEPOINT_EVENT(
61 frr_libfrr,
62 hash_release,
63 TP_ARGS(struct hash *, hash, void *, data, void *, released_item),
64 TP_FIELDS(
65 ctf_string(name, hash->name ? hash->name : "(unnamed)")
66 ctf_integer(unsigned int, index_size, hash->size)
67 ctf_integer(unsigned long, item_count, hash->count)
68 ctf_integer_hex(intptr_t, data_ptr, data)
69 ctf_integer_hex(intptr_t, released_item, data)
70 )
71)
72
73TRACEPOINT_LOGLEVEL(frr_libfrr, hash_release, TRACE_INFO)
74
75#define THREAD_SCHEDULE_ARGS \
76 TP_ARGS(struct thread_master *, master, const char *, funcname, \
77 const char *, schedfrom, int, fromln, struct thread **, \
78 thread_ptr, int, fd, int, val, void *, arg, long, time)
79
80TRACEPOINT_EVENT_CLASS(
81 frr_libfrr,
82 thread_operation,
83 THREAD_SCHEDULE_ARGS,
84 TP_FIELDS(
85 ctf_string(threadmaster_name, master->name)
86 ctf_string(function_name, funcname ? funcname : "(unknown function)")
87 ctf_string(scheduled_from, schedfrom ? schedfrom : "(unknown file)")
88 ctf_integer(int, scheduled_on_line, fromln)
89 ctf_integer_hex(intptr_t, thread_addr, thread_ptr ? *thread_ptr : NULL)
90 ctf_integer(int, file_descriptor, fd)
91 ctf_integer(int, event_value, val)
92 ctf_integer_hex(intptr_t, argument_ptr, arg)
93 ctf_integer(long, timer, time)
94 )
95)
96
97#define THREAD_OPERATION_TRACEPOINT_INSTANCE(name) \
98 TRACEPOINT_EVENT_INSTANCE(frr_libfrr, thread_operation, name, \
99 THREAD_SCHEDULE_ARGS) \
100 TRACEPOINT_LOGLEVEL(frr_libfrr, name, TRACE_INFO)
101
102THREAD_OPERATION_TRACEPOINT_INSTANCE(schedule_timer)
103THREAD_OPERATION_TRACEPOINT_INSTANCE(schedule_event)
104THREAD_OPERATION_TRACEPOINT_INSTANCE(schedule_read)
105THREAD_OPERATION_TRACEPOINT_INSTANCE(schedule_write)
106THREAD_OPERATION_TRACEPOINT_INSTANCE(thread_cancel)
107THREAD_OPERATION_TRACEPOINT_INSTANCE(thread_cancel_async)
108THREAD_OPERATION_TRACEPOINT_INSTANCE(thread_call)
109
87879a5e
QY
110TRACEPOINT_EVENT(
111 frr_libfrr,
112 frr_pthread_run,
113 TP_ARGS(
114 char *, name
115 ),
116 TP_FIELDS(
117 ctf_string(frr_pthread_name, name)
118 )
119)
120
121TRACEPOINT_EVENT(
122 frr_libfrr,
123 frr_pthread_stop,
124 TP_ARGS(
125 char *, name
126 ),
127 TP_FIELDS(
128 ctf_string(frr_pthread_name, name)
129 )
130)
131
d92658f4
QY
132TRACEPOINT_EVENT(
133 frr_libfrr,
134 memalloc,
135 TP_ARGS(
136 struct memtype *, mt, void *, ptr, size_t, size
137 ),
138 TP_FIELDS(
139 ctf_string(memtype, mt->name)
140 ctf_integer(size_t, size, size)
141 ctf_integer_hex(intptr_t, ptr, ptr)
142 )
143)
144
145TRACEPOINT_EVENT(
146 frr_libfrr,
147 memfree,
148 TP_ARGS(
149 struct memtype *, mt, void *, ptr
150 ),
151 TP_FIELDS(
152 ctf_string(memtype, mt->name)
153 ctf_integer_hex(intptr_t, ptr, ptr)
154 )
155)
156
157TRACEPOINT_EVENT(
158 frr_libfrr,
159 list_add,
160 TP_ARGS(
161 struct list *, list, const void *, ptr
162 ),
163 TP_FIELDS(
164 ctf_integer_hex(intptr_t, list, list)
165 ctf_integer(unsigned int, count, list->count)
166 ctf_integer_hex(intptr_t, ptr, ptr)
167 )
168)
169
170TRACEPOINT_EVENT(
171 frr_libfrr,
172 list_remove,
173 TP_ARGS(
174 struct list *, list, const void *, ptr
175 ),
176 TP_FIELDS(
177 ctf_integer_hex(intptr_t, list, list)
178 ctf_integer(unsigned int, count, list->count)
179 ctf_integer_hex(intptr_t, ptr, ptr)
180 )
181)
182
183TRACEPOINT_EVENT(
184 frr_libfrr,
185 list_delete_node,
186 TP_ARGS(
187 struct list *, list, const void *, node
188 ),
189 TP_FIELDS(
190 ctf_integer_hex(intptr_t, list, list)
191 ctf_integer(unsigned int, count, list->count)
192 ctf_integer_hex(intptr_t, node, node)
193 )
194)
195
196TRACEPOINT_EVENT(
197 frr_libfrr,
198 list_sort,
199 TP_ARGS(
200 struct list *, list
201 ),
202 TP_FIELDS(
203 ctf_integer_hex(intptr_t, list, list)
204 ctf_integer(unsigned int, count, list->count)
205 )
206)
207
a72255a3
QY
208TRACEPOINT_EVENT(
209 frr_libfrr,
210 route_node_get,
211 TP_ARGS(
212 struct route_table *, table, char *, prefix
213 ),
214 TP_FIELDS(
215 ctf_integer_hex(intptr_t, table, table)
216 ctf_string(prefix, prefix)
217 )
218)
219
abf96a87
QY
220/* clang-format on */
221
0cbcadcc 222#include <lttng/tracepoint-event.h>
1bd1ebaa 223#include <lttng/tracelog.h>
0cbcadcc 224
0cbcadcc
QY
225#endif /* HAVE_LTTNG */
226
c7bb4f00 227#endif /* _LIBFRR_TRACE_H_ */