1LTTNG_UST_TRACEF(3) LTTng Manual LTTNG_UST_TRACEF(3)
2
3
4
6 lttng_ust_tracef, lttng_ust_vtracef - LTTng-UST printf(3)-like
7 interface
8
10 #include <lttng/tracef.h>
11
12 #define lttng_ust_tracef(fmt, ...)
13 #define lttng_ust_vtracef(fmt, ap)
14
15 Link with:
16
17 • -llttng-ust
18
19 • If you define _LGPL_SOURCE before including <lttng/tracef.h>
20 (directly or indirectly): -llttng-ust-common
21
23 The LTTng-UST lttng_ust_tracef() and lttng_ust_vtracef() API allows you
24 to trace your application with the help of simple printf(3)-like and
25 vprintf(3)-like macros.
26
27 The fmt argument is passed directly as the fmt parameter of
28 vasprintf(3), as well as:
29
30 For lttng_ust_tracef()
31 The optional parameters following fmt.
32
33 For lttng_ust_vtracef()
34 The ap parameter as the ap parameter of vasprintf(3) (va_list
35 type).
36
37 To use lttng_ust_tracef() or lttng_ust_vtracef(), include
38 <lttng/tracef.h> where you need it, and link your application with
39 liblttng-ust and liblttng-ust-common. See the EXAMPLE section below for
40 a complete usage example.
41
42 Once your application is instrumented with lttng_ust_tracef() and/or
43 lttng_ust_vtracef() calls and ready to run, use lttng-enable-event(1)
44 to enable the lttng_ust_tracef:* event.
45
46 The lttng_ust_tracef() and lttng_ust_vtracef() events contain a single
47 field, named msg, which is the formatted string output.
48
49 If you need to attach a specific log level to a
50 lttng_ust_tracef()/lttng_ust_vtracef() call, use lttng_ust_tracelog(3)
51 and lttng_ust_vtracelog(3) instead.
52
53 See also the LIMITATIONS section below for important limitations to
54 consider when using lttng_ust_tracef() or lttng_ust_vtracef().
55
57 Here’s a usage example of lttng_ust_tracef():
58
59 #include <stdlib.h>
60 #include <lttng/tracef.h>
61
62 int main(void)
63 {
64 int i;
65
66 for (i = 0; i < 25; i++) {
67 lttng_ust_tracef("my message: %s, this integer: %d",
68 "a message", i);
69 }
70
71 return EXIT_SUCCESS;
72 }
73
74 This C source file, saved as app.c, can be compiled into a program like
75 this:
76
77 $ cc -o app app.c -llttng-ust -llttng-ust-common
78
79 You can create an LTTng tracing session, enable the lttng_ust_tracef()
80 events, and start the created tracing session like this:
81
82 $ lttng create my-session
83 $ lttng enable-event --userspace 'lttng_ust_tracef:*'
84 $ lttng start
85
86 Next, start the program to be traced:
87
88 $ ./app
89
90 Finally, stop the tracing session, and inspect the recorded events:
91
92 $ lttng stop
93 $ lttng view
94
96 The lttng_ust_tracef() and lttng_ust_vtracef() utility macros were
97 developed to make user space tracing super simple, albeit with notable
98 disadvantages compared to custom, full-fledged tracepoint providers:
99
100 • All generated events have the same provider/event names.
101
102 • There’s no static type checking.
103
104 • The only event field with user data you actually get, named msg, is
105 a string potentially containing the values you passed to the macro
106 using your own format. This also means that you cannot use
107 filtering using a custom expression at run time because there are
108 no isolated fields.
109
110 • Since lttng_ust_tracef() and lttng_ust_vtracef() use C standard
111 library’s vasprintf(3) function in the background to format the
112 strings at run time, their expected performance is lower than using
113 custom tracepoint providers with typed fields, which do not require
114 a conversion to a string.
115
116 • Generally, a string containing the textual representation of the
117 user data fields is not as compact as binary fields in the
118 resulting trace.
119
120 Thus, lttng_ust_tracef()/lttng_ust_vtracef() are useful for quick
121 prototyping and debugging, but should not be considered for any
122 permanent/serious application instrumentation.
123
124 lttng_ust_vtracef() does not have a STAP_PROBEV() call, because
125 STAP_PROBEV() does not support va_list. If you need it, you should emit
126 this call yourself.
127
128 See lttng-ust(3) to learn more about custom tracepoint providers.
129
131 If you encounter any issue or usability problem, please report it on
132 the LTTng bug tracker <https://bugs.lttng.org/projects/lttng-ust>.
133
135 • LTTng project website <http://lttng.org>
136
137 • LTTng documentation <http://lttng.org/docs>
138
139 • Git repositories <http://git.lttng.org>
140
141 • GitHub organization <http://github.com/lttng>
142
143 • Continuous integration <http://ci.lttng.org/>
144
145 • Mailing list <http://lists.lttng.org> for support and development:
146 lttng-dev@lists.lttng.org
147
148 • IRC channel <irc://irc.oftc.net/lttng>: #lttng on irc.oftc.net
149
151 This macro is part of the LTTng-UST project.
152
153 This macro is distributed under the GNU Lesser General Public License,
154 version 2.1 <http://www.gnu.org/licenses/old-
155 licenses/lgpl-2.1.en.html>. See the for more details.
156
158 Thanks to Ericsson for funding this work, providing real-life use
159 cases, and testing.
160
161 Special thanks to Michel Dagenais and the DORSAL laboratory
162 <http://www.dorsal.polymtl.ca/> at École Polytechnique de Montréal for
163 the LTTng journey.
164
166 LTTng-UST was originally written by Mathieu Desnoyers, with additional
167 contributions from various other people. It is currently maintained by
168 Mathieu Desnoyers <mailto:mathieu.desnoyers@efficios.com>.
169
171 lttng_ust_tracelog(3), lttng_ust_vtracelog(3), lttng-ust(3), lttng(1),
172 printf(3)
173
174
175
176LTTng 2.13.5 09/30/2022 LTTNG_UST_TRACEF(3)