xref: /aosp_15_r20/external/cronet/base/trace_event/trace_event.h (revision 6777b5387eb2ff775bb5750e3f5d96f37fb7352b)
1*6777b538SAndroid Build Coastguard Worker // Copyright 2012 The Chromium Authors
2*6777b538SAndroid Build Coastguard Worker // Use of this source code is governed by a BSD-style license that can be
3*6777b538SAndroid Build Coastguard Worker // found in the LICENSE file.
4*6777b538SAndroid Build Coastguard Worker 
5*6777b538SAndroid Build Coastguard Worker #ifndef BASE_TRACE_EVENT_TRACE_EVENT_H_
6*6777b538SAndroid Build Coastguard Worker #define BASE_TRACE_EVENT_TRACE_EVENT_H_
7*6777b538SAndroid Build Coastguard Worker 
8*6777b538SAndroid Build Coastguard Worker // This header file defines implementation details of how the trace macros in
9*6777b538SAndroid Build Coastguard Worker // trace_event_common.h collect and store trace events. Anything not
10*6777b538SAndroid Build Coastguard Worker // implementation-specific should go in trace_event_common.h instead of here.
11*6777b538SAndroid Build Coastguard Worker 
12*6777b538SAndroid Build Coastguard Worker #include <stddef.h>
13*6777b538SAndroid Build Coastguard Worker #include <stdint.h>
14*6777b538SAndroid Build Coastguard Worker 
15*6777b538SAndroid Build Coastguard Worker #include <memory>
16*6777b538SAndroid Build Coastguard Worker #include <utility>
17*6777b538SAndroid Build Coastguard Worker 
18*6777b538SAndroid Build Coastguard Worker #include "base/atomicops.h"
19*6777b538SAndroid Build Coastguard Worker #include "base/base_export.h"
20*6777b538SAndroid Build Coastguard Worker #include "base/threading/platform_thread.h"
21*6777b538SAndroid Build Coastguard Worker #include "base/time/time.h"
22*6777b538SAndroid Build Coastguard Worker #include "base/time/time_override.h"
23*6777b538SAndroid Build Coastguard Worker #include "base/trace_event/builtin_categories.h"
24*6777b538SAndroid Build Coastguard Worker #include "base/trace_event/common/trace_event_common.h"
25*6777b538SAndroid Build Coastguard Worker #include "base/trace_event/trace_arguments.h"
26*6777b538SAndroid Build Coastguard Worker #include "base/trace_event/trace_category.h"
27*6777b538SAndroid Build Coastguard Worker #include "base/trace_event/trace_log.h"
28*6777b538SAndroid Build Coastguard Worker #include "base/trace_event/traced_value_support.h"
29*6777b538SAndroid Build Coastguard Worker #include "base/tracing_buildflags.h"
30*6777b538SAndroid Build Coastguard Worker 
31*6777b538SAndroid Build Coastguard Worker #if !BUILDFLAG(USE_PERFETTO_CLIENT_LIBRARY)
32*6777b538SAndroid Build Coastguard Worker 
33*6777b538SAndroid Build Coastguard Worker // By default, const char* argument values are assumed to have long-lived scope
34*6777b538SAndroid Build Coastguard Worker // and will not be copied. Use this macro to force a const char* to be copied.
35*6777b538SAndroid Build Coastguard Worker #define TRACE_STR_COPY(str) ::base::trace_event::TraceStringWithCopy(str)
36*6777b538SAndroid Build Coastguard Worker 
37*6777b538SAndroid Build Coastguard Worker // By default, trace IDs are eventually converted to a single 64-bit number. Use
38*6777b538SAndroid Build Coastguard Worker // this macro to add a scope string. For example,
39*6777b538SAndroid Build Coastguard Worker //
40*6777b538SAndroid Build Coastguard Worker // TRACE_EVENT_NESTABLE_ASYNC_BEGIN0(
41*6777b538SAndroid Build Coastguard Worker //     "network", "ResourceLoad",
42*6777b538SAndroid Build Coastguard Worker //     TRACE_ID_WITH_SCOPE("BlinkResourceID", resourceID));
43*6777b538SAndroid Build Coastguard Worker #define TRACE_ID_WITH_SCOPE(scope, ...) \
44*6777b538SAndroid Build Coastguard Worker   trace_event_internal::TraceID::WithScope(scope, ##__VA_ARGS__)
45*6777b538SAndroid Build Coastguard Worker 
46*6777b538SAndroid Build Coastguard Worker // Use this for ids that are unique across processes. This allows different
47*6777b538SAndroid Build Coastguard Worker // processes to use the same id to refer to the same event.
48*6777b538SAndroid Build Coastguard Worker #define TRACE_ID_GLOBAL(id) trace_event_internal::TraceID::GlobalId(id)
49*6777b538SAndroid Build Coastguard Worker 
50*6777b538SAndroid Build Coastguard Worker // Use this for ids that are unique within a single process. This allows
51*6777b538SAndroid Build Coastguard Worker // different processes to use the same id to refer to different events.
52*6777b538SAndroid Build Coastguard Worker #define TRACE_ID_LOCAL(id) trace_event_internal::TraceID::LocalId(id)
53*6777b538SAndroid Build Coastguard Worker 
54*6777b538SAndroid Build Coastguard Worker #define TRACE_EVENT_API_CURRENT_THREAD_ID base::PlatformThread::CurrentId()
55*6777b538SAndroid Build Coastguard Worker 
56*6777b538SAndroid Build Coastguard Worker #define INTERNAL_TRACE_EVENT_CATEGORY_GROUP_ENABLED_FOR_RECORDING_MODE() \
57*6777b538SAndroid Build Coastguard Worker   UNLIKELY(*INTERNAL_TRACE_EVENT_UID(category_group_enabled) &           \
58*6777b538SAndroid Build Coastguard Worker            (base::trace_event::TraceCategory::ENABLED_FOR_RECORDING |    \
59*6777b538SAndroid Build Coastguard Worker             base::trace_event::TraceCategory::ENABLED_FOR_ETW_EXPORT))
60*6777b538SAndroid Build Coastguard Worker 
61*6777b538SAndroid Build Coastguard Worker #define INTERNAL_TRACE_EVENT_CATEGORY_GROUP_ENABLED()                  \
62*6777b538SAndroid Build Coastguard Worker   UNLIKELY(*INTERNAL_TRACE_EVENT_UID(category_group_enabled) &         \
63*6777b538SAndroid Build Coastguard Worker            (base::trace_event::TraceCategory::ENABLED_FOR_RECORDING |  \
64*6777b538SAndroid Build Coastguard Worker             base::trace_event::TraceCategory::ENABLED_FOR_ETW_EXPORT | \
65*6777b538SAndroid Build Coastguard Worker             base::trace_event::TraceCategory::ENABLED_FOR_FILTERING))
66*6777b538SAndroid Build Coastguard Worker 
67*6777b538SAndroid Build Coastguard Worker ////////////////////////////////////////////////////////////////////////////////
68*6777b538SAndroid Build Coastguard Worker // Implementation specific tracing API definitions.
69*6777b538SAndroid Build Coastguard Worker 
70*6777b538SAndroid Build Coastguard Worker // Get a pointer to the enabled state of the given trace category. Only
71*6777b538SAndroid Build Coastguard Worker // long-lived literal strings should be given as the category group. The
72*6777b538SAndroid Build Coastguard Worker // returned pointer can be held permanently in a local static for example. If
73*6777b538SAndroid Build Coastguard Worker // the unsigned char is non-zero, tracing is enabled. If tracing is enabled,
74*6777b538SAndroid Build Coastguard Worker // TRACE_EVENT_API_ADD_TRACE_EVENT can be called. It's OK if tracing is disabled
75*6777b538SAndroid Build Coastguard Worker // between the load of the tracing state and the call to
76*6777b538SAndroid Build Coastguard Worker // TRACE_EVENT_API_ADD_TRACE_EVENT, because this flag only provides an early out
77*6777b538SAndroid Build Coastguard Worker // for best performance when tracing is disabled.
78*6777b538SAndroid Build Coastguard Worker // const unsigned char*
79*6777b538SAndroid Build Coastguard Worker //     TRACE_EVENT_API_GET_CATEGORY_GROUP_ENABLED(const char* category_group)
80*6777b538SAndroid Build Coastguard Worker #define TRACE_EVENT_API_GET_CATEGORY_GROUP_ENABLED \
81*6777b538SAndroid Build Coastguard Worker     base::trace_event::TraceLog::GetCategoryGroupEnabled
82*6777b538SAndroid Build Coastguard Worker 
83*6777b538SAndroid Build Coastguard Worker // Get the number of times traces have been recorded. This is used to implement
84*6777b538SAndroid Build Coastguard Worker // the TRACE_EVENT_IS_NEW_TRACE facility.
85*6777b538SAndroid Build Coastguard Worker // unsigned int TRACE_EVENT_API_GET_NUM_TRACES_RECORDED()
86*6777b538SAndroid Build Coastguard Worker #define TRACE_EVENT_API_GET_NUM_TRACES_RECORDED \
87*6777b538SAndroid Build Coastguard Worker   trace_event_internal::GetNumTracesRecorded
88*6777b538SAndroid Build Coastguard Worker 
89*6777b538SAndroid Build Coastguard Worker #endif  // !BUILDFLAG(USE_PERFETTO_CLIENT_LIBRARY)
90*6777b538SAndroid Build Coastguard Worker 
91*6777b538SAndroid Build Coastguard Worker // Legacy TRACE_EVENT_API entrypoints. Do not use from new code.
92*6777b538SAndroid Build Coastguard Worker 
93*6777b538SAndroid Build Coastguard Worker // Add a trace event to the platform tracing system.
94*6777b538SAndroid Build Coastguard Worker // base::trace_event::TraceEventHandle TRACE_EVENT_API_ADD_TRACE_EVENT(
95*6777b538SAndroid Build Coastguard Worker //                    char phase,
96*6777b538SAndroid Build Coastguard Worker //                    const unsigned char* category_group_enabled,
97*6777b538SAndroid Build Coastguard Worker //                    const char* name,
98*6777b538SAndroid Build Coastguard Worker //                    const char* scope,
99*6777b538SAndroid Build Coastguard Worker //                    uint64_t id,
100*6777b538SAndroid Build Coastguard Worker //                    base::trace_event::TraceArguments* args,
101*6777b538SAndroid Build Coastguard Worker //                    unsigned int flags)
102*6777b538SAndroid Build Coastguard Worker #define TRACE_EVENT_API_ADD_TRACE_EVENT trace_event_internal::AddTraceEvent
103*6777b538SAndroid Build Coastguard Worker 
104*6777b538SAndroid Build Coastguard Worker // Add a trace event to the platform tracing system.
105*6777b538SAndroid Build Coastguard Worker // base::trace_event::TraceEventHandle
106*6777b538SAndroid Build Coastguard Worker // TRACE_EVENT_API_ADD_TRACE_EVENT_WITH_BIND_ID(
107*6777b538SAndroid Build Coastguard Worker //                    char phase,
108*6777b538SAndroid Build Coastguard Worker //                    const unsigned char* category_group_enabled,
109*6777b538SAndroid Build Coastguard Worker //                    const char* name,
110*6777b538SAndroid Build Coastguard Worker //                    const char* scope,
111*6777b538SAndroid Build Coastguard Worker //                    uint64_t id,
112*6777b538SAndroid Build Coastguard Worker //                    uint64_t bind_id,
113*6777b538SAndroid Build Coastguard Worker //                    base::trace_event::TraceArguments* args,
114*6777b538SAndroid Build Coastguard Worker //                    unsigned int flags)
115*6777b538SAndroid Build Coastguard Worker #define TRACE_EVENT_API_ADD_TRACE_EVENT_WITH_BIND_ID \
116*6777b538SAndroid Build Coastguard Worker   trace_event_internal::AddTraceEventWithBindId
117*6777b538SAndroid Build Coastguard Worker 
118*6777b538SAndroid Build Coastguard Worker // Add a trace event to the platform tracing system overriding the pid.
119*6777b538SAndroid Build Coastguard Worker // The resulting event will have tid = pid == (process_id passed here).
120*6777b538SAndroid Build Coastguard Worker // base::trace_event::TraceEventHandle
121*6777b538SAndroid Build Coastguard Worker // TRACE_EVENT_API_ADD_TRACE_EVENT_WITH_PROCESS_ID(
122*6777b538SAndroid Build Coastguard Worker //                    char phase,
123*6777b538SAndroid Build Coastguard Worker //                    const unsigned char* category_group_enabled,
124*6777b538SAndroid Build Coastguard Worker //                    const char* name,
125*6777b538SAndroid Build Coastguard Worker //                    const char* scope,
126*6777b538SAndroid Build Coastguard Worker //                    uint64_t id,
127*6777b538SAndroid Build Coastguard Worker //                    base::ProcessId process_id,
128*6777b538SAndroid Build Coastguard Worker //                    base::trace_event::TraceArguments* args,
129*6777b538SAndroid Build Coastguard Worker //                    unsigned int flags)
130*6777b538SAndroid Build Coastguard Worker #define TRACE_EVENT_API_ADD_TRACE_EVENT_WITH_PROCESS_ID \
131*6777b538SAndroid Build Coastguard Worker   trace_event_internal::AddTraceEventWithProcessId
132*6777b538SAndroid Build Coastguard Worker 
133*6777b538SAndroid Build Coastguard Worker // Add a trace event to the platform tracing system.
134*6777b538SAndroid Build Coastguard Worker // base::trace_event::TraceEventHandle
135*6777b538SAndroid Build Coastguard Worker // TRACE_EVENT_API_ADD_TRACE_EVENT_WITH_THREAD_ID_AND_TIMESTAMP(
136*6777b538SAndroid Build Coastguard Worker //                    char phase,
137*6777b538SAndroid Build Coastguard Worker //                    const unsigned char* category_group_enabled,
138*6777b538SAndroid Build Coastguard Worker //                    const char* name,
139*6777b538SAndroid Build Coastguard Worker //                    const char* scope,
140*6777b538SAndroid Build Coastguard Worker //                    uint64_t id,
141*6777b538SAndroid Build Coastguard Worker //                    uint64_t bind_id,
142*6777b538SAndroid Build Coastguard Worker //                    base::PlatformThreadId thread_id,
143*6777b538SAndroid Build Coastguard Worker //                    const TimeTicks& timestamp,
144*6777b538SAndroid Build Coastguard Worker //                    base::trace_event::TraceArguments* args,
145*6777b538SAndroid Build Coastguard Worker //                    unsigned int flags)
146*6777b538SAndroid Build Coastguard Worker #define TRACE_EVENT_API_ADD_TRACE_EVENT_WITH_THREAD_ID_AND_TIMESTAMP \
147*6777b538SAndroid Build Coastguard Worker   trace_event_internal::AddTraceEventWithThreadIdAndTimestamp
148*6777b538SAndroid Build Coastguard Worker 
149*6777b538SAndroid Build Coastguard Worker // Set the duration field of a COMPLETE trace event.
150*6777b538SAndroid Build Coastguard Worker // void TRACE_EVENT_API_UPDATE_TRACE_EVENT_DURATION(
151*6777b538SAndroid Build Coastguard Worker //     const unsigned char* category_group_enabled,
152*6777b538SAndroid Build Coastguard Worker //     const char* name,
153*6777b538SAndroid Build Coastguard Worker //     base::trace_event::TraceEventHandle id)
154*6777b538SAndroid Build Coastguard Worker #define TRACE_EVENT_API_UPDATE_TRACE_EVENT_DURATION \
155*6777b538SAndroid Build Coastguard Worker   trace_event_internal::UpdateTraceEventDuration
156*6777b538SAndroid Build Coastguard Worker 
157*6777b538SAndroid Build Coastguard Worker // Adds a metadata event to the trace log. The |AppendValueAsTraceFormat| method
158*6777b538SAndroid Build Coastguard Worker // on the convertable value will be called at flush time.
159*6777b538SAndroid Build Coastguard Worker // TRACE_EVENT_API_ADD_METADATA_EVENT(
160*6777b538SAndroid Build Coastguard Worker //     const unsigned char* category_group_enabled,
161*6777b538SAndroid Build Coastguard Worker //     const char* event_name,
162*6777b538SAndroid Build Coastguard Worker //     const char* arg_name,
163*6777b538SAndroid Build Coastguard Worker //     std::unique_ptr<ConvertableToTraceFormat> arg_value)
164*6777b538SAndroid Build Coastguard Worker #define TRACE_EVENT_API_ADD_METADATA_EVENT \
165*6777b538SAndroid Build Coastguard Worker     trace_event_internal::AddMetadataEvent
166*6777b538SAndroid Build Coastguard Worker 
167*6777b538SAndroid Build Coastguard Worker // Defines atomic operations used internally by the tracing system.
168*6777b538SAndroid Build Coastguard Worker // Acquire/release barriers are important here: crbug.com/1330114#c8.
169*6777b538SAndroid Build Coastguard Worker #define TRACE_EVENT_API_ATOMIC_WORD base::subtle::AtomicWord
170*6777b538SAndroid Build Coastguard Worker #define TRACE_EVENT_API_ATOMIC_LOAD(var) base::subtle::Acquire_Load(&(var))
171*6777b538SAndroid Build Coastguard Worker #define TRACE_EVENT_API_ATOMIC_STORE(var, value) \
172*6777b538SAndroid Build Coastguard Worker   base::subtle::Release_Store(&(var), (value))
173*6777b538SAndroid Build Coastguard Worker 
174*6777b538SAndroid Build Coastguard Worker // Defines visibility for classes in trace_event.h
175*6777b538SAndroid Build Coastguard Worker #define TRACE_EVENT_API_CLASS_EXPORT BASE_EXPORT
176*6777b538SAndroid Build Coastguard Worker 
177*6777b538SAndroid Build Coastguard Worker ////////////////////////////////////////////////////////////////////////////////
178*6777b538SAndroid Build Coastguard Worker 
179*6777b538SAndroid Build Coastguard Worker // Implementation detail: trace event macros create temporary variables
180*6777b538SAndroid Build Coastguard Worker // to keep instrumentation overhead low. These macros give each temporary
181*6777b538SAndroid Build Coastguard Worker // variable a unique name based on the line number to prevent name collisions.
182*6777b538SAndroid Build Coastguard Worker #if !BUILDFLAG(USE_PERFETTO_CLIENT_LIBRARY)
183*6777b538SAndroid Build Coastguard Worker #define INTERNAL_TRACE_EVENT_UID3(a, b) trace_event_unique_##a##b
184*6777b538SAndroid Build Coastguard Worker #define INTERNAL_TRACE_EVENT_UID2(a, b) INTERNAL_TRACE_EVENT_UID3(a, b)
185*6777b538SAndroid Build Coastguard Worker #define INTERNAL_TRACE_EVENT_UID(name_prefix) \
186*6777b538SAndroid Build Coastguard Worker     INTERNAL_TRACE_EVENT_UID2(name_prefix, __LINE__)
187*6777b538SAndroid Build Coastguard Worker 
188*6777b538SAndroid Build Coastguard Worker // Implementation detail: internal macro to create static category.
189*6777b538SAndroid Build Coastguard Worker // No barriers are needed, because this code is designed to operate safely
190*6777b538SAndroid Build Coastguard Worker // even when the unsigned char* points to garbage data (which may be the case
191*6777b538SAndroid Build Coastguard Worker // on processors without cache coherency).
192*6777b538SAndroid Build Coastguard Worker #define INTERNAL_TRACE_EVENT_GET_CATEGORY_INFO_CUSTOM_VARIABLES(    \
193*6777b538SAndroid Build Coastguard Worker     category_group, atomic, category_group_enabled)                 \
194*6777b538SAndroid Build Coastguard Worker   category_group_enabled = reinterpret_cast<const unsigned char*>(  \
195*6777b538SAndroid Build Coastguard Worker       TRACE_EVENT_API_ATOMIC_LOAD(atomic));                         \
196*6777b538SAndroid Build Coastguard Worker   if (UNLIKELY(!category_group_enabled)) {                          \
197*6777b538SAndroid Build Coastguard Worker     category_group_enabled =                                        \
198*6777b538SAndroid Build Coastguard Worker         TRACE_EVENT_API_GET_CATEGORY_GROUP_ENABLED(category_group); \
199*6777b538SAndroid Build Coastguard Worker     TRACE_EVENT_API_ATOMIC_STORE(                                   \
200*6777b538SAndroid Build Coastguard Worker         atomic, reinterpret_cast<TRACE_EVENT_API_ATOMIC_WORD>(      \
201*6777b538SAndroid Build Coastguard Worker                     category_group_enabled));                       \
202*6777b538SAndroid Build Coastguard Worker   }
203*6777b538SAndroid Build Coastguard Worker 
204*6777b538SAndroid Build Coastguard Worker #define INTERNAL_TRACE_EVENT_GET_CATEGORY_INFO_MAYBE_AT_COMPILE_TIME(        \
205*6777b538SAndroid Build Coastguard Worker     category_group, k_category_group_enabled, category_group_enabled)        \
206*6777b538SAndroid Build Coastguard Worker   if (k_category_group_enabled) {                                            \
207*6777b538SAndroid Build Coastguard Worker     category_group_enabled = k_category_group_enabled;                       \
208*6777b538SAndroid Build Coastguard Worker   } else {                                                                   \
209*6777b538SAndroid Build Coastguard Worker     static TRACE_EVENT_API_ATOMIC_WORD INTERNAL_TRACE_EVENT_UID(atomic) = 0; \
210*6777b538SAndroid Build Coastguard Worker     INTERNAL_TRACE_EVENT_GET_CATEGORY_INFO_CUSTOM_VARIABLES(                 \
211*6777b538SAndroid Build Coastguard Worker         category_group, INTERNAL_TRACE_EVENT_UID(atomic),                    \
212*6777b538SAndroid Build Coastguard Worker         category_group_enabled);                                             \
213*6777b538SAndroid Build Coastguard Worker   }
214*6777b538SAndroid Build Coastguard Worker 
215*6777b538SAndroid Build Coastguard Worker #define INTERNAL_TRACE_EVENT_GET_CATEGORY_INFO(category_group)                 \
216*6777b538SAndroid Build Coastguard Worker   static_assert(                                                               \
217*6777b538SAndroid Build Coastguard Worker       base::trace_event::BuiltinCategories::IsAllowedCategory(category_group), \
218*6777b538SAndroid Build Coastguard Worker       "Unknown tracing category is used. Please register your "                \
219*6777b538SAndroid Build Coastguard Worker       "category in base/trace_event/builtin_categories.h");                    \
220*6777b538SAndroid Build Coastguard Worker   constexpr const unsigned char* INTERNAL_TRACE_EVENT_UID(                     \
221*6777b538SAndroid Build Coastguard Worker       k_category_group_enabled) =                                              \
222*6777b538SAndroid Build Coastguard Worker       base::trace_event::TraceLog::GetBuiltinCategoryEnabled(category_group);  \
223*6777b538SAndroid Build Coastguard Worker   const unsigned char* INTERNAL_TRACE_EVENT_UID(category_group_enabled);       \
224*6777b538SAndroid Build Coastguard Worker   INTERNAL_TRACE_EVENT_GET_CATEGORY_INFO_MAYBE_AT_COMPILE_TIME(                \
225*6777b538SAndroid Build Coastguard Worker       category_group, INTERNAL_TRACE_EVENT_UID(k_category_group_enabled),      \
226*6777b538SAndroid Build Coastguard Worker       INTERNAL_TRACE_EVENT_UID(category_group_enabled));
227*6777b538SAndroid Build Coastguard Worker 
228*6777b538SAndroid Build Coastguard Worker // Implementation detail: internal macro to return unoverridden
229*6777b538SAndroid Build Coastguard Worker // base::TimeTicks::Now(). This is important because in headless VirtualTime can
230*6777b538SAndroid Build Coastguard Worker // override base:TimeTicks::Now().
231*6777b538SAndroid Build Coastguard Worker #define INTERNAL_TRACE_TIME_TICKS_NOW() \
232*6777b538SAndroid Build Coastguard Worker   base::subtle::TimeTicksNowIgnoringOverride()
233*6777b538SAndroid Build Coastguard Worker 
234*6777b538SAndroid Build Coastguard Worker // Implementation detail: internal macro to return unoverridden
235*6777b538SAndroid Build Coastguard Worker // base::Time::Now(). This is important because in headless VirtualTime can
236*6777b538SAndroid Build Coastguard Worker // override base:TimeTicks::Now().
237*6777b538SAndroid Build Coastguard Worker #define INTERNAL_TRACE_TIME_NOW() base::subtle::TimeNowIgnoringOverride()
238*6777b538SAndroid Build Coastguard Worker 
239*6777b538SAndroid Build Coastguard Worker // Implementation detail: internal macro to create static category and add
240*6777b538SAndroid Build Coastguard Worker // event if the category is enabled.
241*6777b538SAndroid Build Coastguard Worker #define INTERNAL_TRACE_EVENT_ADD(phase, category_group, name, flags, ...)  \
242*6777b538SAndroid Build Coastguard Worker   do {                                                                     \
243*6777b538SAndroid Build Coastguard Worker     INTERNAL_TRACE_EVENT_GET_CATEGORY_INFO(category_group);                \
244*6777b538SAndroid Build Coastguard Worker     if (INTERNAL_TRACE_EVENT_CATEGORY_GROUP_ENABLED()) {                   \
245*6777b538SAndroid Build Coastguard Worker       trace_event_internal::AddTraceEvent(                                 \
246*6777b538SAndroid Build Coastguard Worker           phase, INTERNAL_TRACE_EVENT_UID(category_group_enabled), name,   \
247*6777b538SAndroid Build Coastguard Worker           trace_event_internal::kGlobalScope, trace_event_internal::kNoId, \
248*6777b538SAndroid Build Coastguard Worker           flags, trace_event_internal::kNoId, ##__VA_ARGS__);              \
249*6777b538SAndroid Build Coastguard Worker     }                                                                      \
250*6777b538SAndroid Build Coastguard Worker   } while (0)
251*6777b538SAndroid Build Coastguard Worker 
252*6777b538SAndroid Build Coastguard Worker // Implementation detail: internal macro to create static category and add begin
253*6777b538SAndroid Build Coastguard Worker // event if the category is enabled. Also adds the end event when the scope
254*6777b538SAndroid Build Coastguard Worker // ends.
255*6777b538SAndroid Build Coastguard Worker #define INTERNAL_TRACE_EVENT_ADD_SCOPED(category_group, name, ...)           \
256*6777b538SAndroid Build Coastguard Worker   INTERNAL_TRACE_EVENT_GET_CATEGORY_INFO(category_group);                    \
257*6777b538SAndroid Build Coastguard Worker   trace_event_internal::ScopedTracer INTERNAL_TRACE_EVENT_UID(tracer);       \
258*6777b538SAndroid Build Coastguard Worker   if (INTERNAL_TRACE_EVENT_CATEGORY_GROUP_ENABLED()) {                       \
259*6777b538SAndroid Build Coastguard Worker     base::trace_event::TraceEventHandle INTERNAL_TRACE_EVENT_UID(h) =        \
260*6777b538SAndroid Build Coastguard Worker         trace_event_internal::AddTraceEvent(                                 \
261*6777b538SAndroid Build Coastguard Worker             TRACE_EVENT_PHASE_COMPLETE,                                      \
262*6777b538SAndroid Build Coastguard Worker             INTERNAL_TRACE_EVENT_UID(category_group_enabled), name,          \
263*6777b538SAndroid Build Coastguard Worker             trace_event_internal::kGlobalScope, trace_event_internal::kNoId, \
264*6777b538SAndroid Build Coastguard Worker             TRACE_EVENT_FLAG_NONE, trace_event_internal::kNoId,              \
265*6777b538SAndroid Build Coastguard Worker             ##__VA_ARGS__);                                                  \
266*6777b538SAndroid Build Coastguard Worker     INTERNAL_TRACE_EVENT_UID(tracer).Initialize(                             \
267*6777b538SAndroid Build Coastguard Worker         INTERNAL_TRACE_EVENT_UID(category_group_enabled), name,              \
268*6777b538SAndroid Build Coastguard Worker         INTERNAL_TRACE_EVENT_UID(h));                                        \
269*6777b538SAndroid Build Coastguard Worker   }
270*6777b538SAndroid Build Coastguard Worker 
271*6777b538SAndroid Build Coastguard Worker #define INTERNAL_TRACE_EVENT_ADD_SCOPED_WITH_FLAGS(category_group, name,     \
272*6777b538SAndroid Build Coastguard Worker                                                    flags, ...)               \
273*6777b538SAndroid Build Coastguard Worker   INTERNAL_TRACE_EVENT_GET_CATEGORY_INFO(category_group);                    \
274*6777b538SAndroid Build Coastguard Worker   trace_event_internal::ScopedTracer INTERNAL_TRACE_EVENT_UID(tracer);       \
275*6777b538SAndroid Build Coastguard Worker   if (INTERNAL_TRACE_EVENT_CATEGORY_GROUP_ENABLED()) {                       \
276*6777b538SAndroid Build Coastguard Worker     base::trace_event::TraceEventHandle INTERNAL_TRACE_EVENT_UID(h) =        \
277*6777b538SAndroid Build Coastguard Worker         trace_event_internal::AddTraceEvent(                                 \
278*6777b538SAndroid Build Coastguard Worker             TRACE_EVENT_PHASE_COMPLETE,                                      \
279*6777b538SAndroid Build Coastguard Worker             INTERNAL_TRACE_EVENT_UID(category_group_enabled), name,          \
280*6777b538SAndroid Build Coastguard Worker             trace_event_internal::kGlobalScope, trace_event_internal::kNoId, \
281*6777b538SAndroid Build Coastguard Worker             flags, trace_event_internal::kNoId, ##__VA_ARGS__);              \
282*6777b538SAndroid Build Coastguard Worker     INTERNAL_TRACE_EVENT_UID(tracer).Initialize(                             \
283*6777b538SAndroid Build Coastguard Worker         INTERNAL_TRACE_EVENT_UID(category_group_enabled), name,              \
284*6777b538SAndroid Build Coastguard Worker         INTERNAL_TRACE_EVENT_UID(h));                                        \
285*6777b538SAndroid Build Coastguard Worker   }
286*6777b538SAndroid Build Coastguard Worker 
287*6777b538SAndroid Build Coastguard Worker #define INTERNAL_TRACE_EVENT_ADD_SCOPED_WITH_FLOW(category_group, name,      \
288*6777b538SAndroid Build Coastguard Worker                                                   bind_id, flow_flags, ...)  \
289*6777b538SAndroid Build Coastguard Worker   INTERNAL_TRACE_EVENT_GET_CATEGORY_INFO(category_group);                    \
290*6777b538SAndroid Build Coastguard Worker   trace_event_internal::ScopedTracer INTERNAL_TRACE_EVENT_UID(tracer);       \
291*6777b538SAndroid Build Coastguard Worker   if (INTERNAL_TRACE_EVENT_CATEGORY_GROUP_ENABLED()) {                       \
292*6777b538SAndroid Build Coastguard Worker     trace_event_internal::TraceID trace_event_bind_id((bind_id));            \
293*6777b538SAndroid Build Coastguard Worker     unsigned int trace_event_flags =                                         \
294*6777b538SAndroid Build Coastguard Worker         flow_flags | trace_event_bind_id.id_flags();                         \
295*6777b538SAndroid Build Coastguard Worker     base::trace_event::TraceEventHandle INTERNAL_TRACE_EVENT_UID(h) =        \
296*6777b538SAndroid Build Coastguard Worker         trace_event_internal::AddTraceEvent(                                 \
297*6777b538SAndroid Build Coastguard Worker             TRACE_EVENT_PHASE_COMPLETE,                                      \
298*6777b538SAndroid Build Coastguard Worker             INTERNAL_TRACE_EVENT_UID(category_group_enabled), name,          \
299*6777b538SAndroid Build Coastguard Worker             trace_event_internal::kGlobalScope, trace_event_internal::kNoId, \
300*6777b538SAndroid Build Coastguard Worker             trace_event_flags, trace_event_bind_id.raw_id(), ##__VA_ARGS__); \
301*6777b538SAndroid Build Coastguard Worker     INTERNAL_TRACE_EVENT_UID(tracer).Initialize(                             \
302*6777b538SAndroid Build Coastguard Worker         INTERNAL_TRACE_EVENT_UID(category_group_enabled), name,              \
303*6777b538SAndroid Build Coastguard Worker         INTERNAL_TRACE_EVENT_UID(h));                                        \
304*6777b538SAndroid Build Coastguard Worker   }
305*6777b538SAndroid Build Coastguard Worker 
306*6777b538SAndroid Build Coastguard Worker // Implementation detail: internal macro to create static category and add
307*6777b538SAndroid Build Coastguard Worker // event if the category is enabled.
308*6777b538SAndroid Build Coastguard Worker #define INTERNAL_TRACE_EVENT_ADD_WITH_ID(phase, category_group, name, id, \
309*6777b538SAndroid Build Coastguard Worker                                          flags, ...)                      \
310*6777b538SAndroid Build Coastguard Worker   do {                                                                    \
311*6777b538SAndroid Build Coastguard Worker     INTERNAL_TRACE_EVENT_GET_CATEGORY_INFO(category_group);               \
312*6777b538SAndroid Build Coastguard Worker     if (INTERNAL_TRACE_EVENT_CATEGORY_GROUP_ENABLED()) {                  \
313*6777b538SAndroid Build Coastguard Worker       trace_event_internal::TraceID trace_event_trace_id((id));           \
314*6777b538SAndroid Build Coastguard Worker       unsigned int trace_event_flags =                                    \
315*6777b538SAndroid Build Coastguard Worker           flags | trace_event_trace_id.id_flags();                        \
316*6777b538SAndroid Build Coastguard Worker       trace_event_internal::AddTraceEvent(                                \
317*6777b538SAndroid Build Coastguard Worker           phase, INTERNAL_TRACE_EVENT_UID(category_group_enabled), name,  \
318*6777b538SAndroid Build Coastguard Worker           trace_event_trace_id.scope(), trace_event_trace_id.raw_id(),    \
319*6777b538SAndroid Build Coastguard Worker           trace_event_flags, trace_event_internal::kNoId, ##__VA_ARGS__); \
320*6777b538SAndroid Build Coastguard Worker     }                                                                     \
321*6777b538SAndroid Build Coastguard Worker   } while (0)
322*6777b538SAndroid Build Coastguard Worker 
323*6777b538SAndroid Build Coastguard Worker // Implementation detail: internal macro to create static category and add
324*6777b538SAndroid Build Coastguard Worker // event if the category is enabled.
325*6777b538SAndroid Build Coastguard Worker #define INTERNAL_TRACE_EVENT_ADD_WITH_TIMESTAMP(phase, category_group, name, \
326*6777b538SAndroid Build Coastguard Worker                                                 timestamp, flags, ...)       \
327*6777b538SAndroid Build Coastguard Worker   do {                                                                       \
328*6777b538SAndroid Build Coastguard Worker     INTERNAL_TRACE_EVENT_GET_CATEGORY_INFO(category_group);                  \
329*6777b538SAndroid Build Coastguard Worker     if (INTERNAL_TRACE_EVENT_CATEGORY_GROUP_ENABLED()) {                     \
330*6777b538SAndroid Build Coastguard Worker       trace_event_internal::AddTraceEventWithThreadIdAndTimestamp(           \
331*6777b538SAndroid Build Coastguard Worker           phase, INTERNAL_TRACE_EVENT_UID(category_group_enabled), name,     \
332*6777b538SAndroid Build Coastguard Worker           trace_event_internal::kGlobalScope, trace_event_internal::kNoId,   \
333*6777b538SAndroid Build Coastguard Worker           TRACE_EVENT_API_CURRENT_THREAD_ID, timestamp,                      \
334*6777b538SAndroid Build Coastguard Worker           flags | TRACE_EVENT_FLAG_EXPLICIT_TIMESTAMP,                       \
335*6777b538SAndroid Build Coastguard Worker           trace_event_internal::kNoId, ##__VA_ARGS__);                       \
336*6777b538SAndroid Build Coastguard Worker     }                                                                        \
337*6777b538SAndroid Build Coastguard Worker   } while (0)
338*6777b538SAndroid Build Coastguard Worker 
339*6777b538SAndroid Build Coastguard Worker // Implementation detail: internal macro to create static category and add
340*6777b538SAndroid Build Coastguard Worker // event if the category is enabled.
341*6777b538SAndroid Build Coastguard Worker #define INTERNAL_TRACE_EVENT_ADD_WITH_ID_TID_AND_TIMESTAMP(              \
342*6777b538SAndroid Build Coastguard Worker     phase, category_group, name, id, thread_id, timestamp, flags, ...)   \
343*6777b538SAndroid Build Coastguard Worker   do {                                                                   \
344*6777b538SAndroid Build Coastguard Worker     INTERNAL_TRACE_EVENT_GET_CATEGORY_INFO(category_group);              \
345*6777b538SAndroid Build Coastguard Worker     if (INTERNAL_TRACE_EVENT_CATEGORY_GROUP_ENABLED()) {                 \
346*6777b538SAndroid Build Coastguard Worker       trace_event_internal::TraceID trace_event_trace_id((id));          \
347*6777b538SAndroid Build Coastguard Worker       unsigned int trace_event_flags =                                   \
348*6777b538SAndroid Build Coastguard Worker           flags | trace_event_trace_id.id_flags();                       \
349*6777b538SAndroid Build Coastguard Worker       trace_event_internal::AddTraceEventWithThreadIdAndTimestamp(       \
350*6777b538SAndroid Build Coastguard Worker           phase, INTERNAL_TRACE_EVENT_UID(category_group_enabled), name, \
351*6777b538SAndroid Build Coastguard Worker           trace_event_trace_id.scope(), trace_event_trace_id.raw_id(),   \
352*6777b538SAndroid Build Coastguard Worker           thread_id, timestamp,                                          \
353*6777b538SAndroid Build Coastguard Worker           trace_event_flags | TRACE_EVENT_FLAG_EXPLICIT_TIMESTAMP,       \
354*6777b538SAndroid Build Coastguard Worker           trace_event_internal::kNoId, ##__VA_ARGS__);                   \
355*6777b538SAndroid Build Coastguard Worker     }                                                                    \
356*6777b538SAndroid Build Coastguard Worker   } while (0)
357*6777b538SAndroid Build Coastguard Worker 
358*6777b538SAndroid Build Coastguard Worker // Implementation detail: internal macro to create static category and add
359*6777b538SAndroid Build Coastguard Worker // event if the category is enabled.
360*6777b538SAndroid Build Coastguard Worker #define INTERNAL_TRACE_EVENT_ADD_WITH_ID_TID_AND_TIMESTAMPS(                 \
361*6777b538SAndroid Build Coastguard Worker     phase, category_group, name, id, thread_id, timestamp, thread_timestamp, \
362*6777b538SAndroid Build Coastguard Worker     flags)                                                                   \
363*6777b538SAndroid Build Coastguard Worker   do {                                                                       \
364*6777b538SAndroid Build Coastguard Worker     INTERNAL_TRACE_EVENT_GET_CATEGORY_INFO(category_group);                  \
365*6777b538SAndroid Build Coastguard Worker     if (INTERNAL_TRACE_EVENT_CATEGORY_GROUP_ENABLED()) {                     \
366*6777b538SAndroid Build Coastguard Worker       trace_event_internal::TraceID trace_event_trace_id((id));              \
367*6777b538SAndroid Build Coastguard Worker       unsigned int trace_event_flags =                                       \
368*6777b538SAndroid Build Coastguard Worker           flags | trace_event_trace_id.id_flags();                           \
369*6777b538SAndroid Build Coastguard Worker       const unsigned char* uid_category_group_enabled =                      \
370*6777b538SAndroid Build Coastguard Worker           INTERNAL_TRACE_EVENT_UID(category_group_enabled);                  \
371*6777b538SAndroid Build Coastguard Worker       trace_event_internal::AddTraceEventWithThreadIdAndTimestamps(          \
372*6777b538SAndroid Build Coastguard Worker           phase, uid_category_group_enabled, name,                           \
373*6777b538SAndroid Build Coastguard Worker           trace_event_trace_id.scope(), trace_event_trace_id.raw_id(),       \
374*6777b538SAndroid Build Coastguard Worker           thread_id, timestamp, thread_timestamp,                            \
375*6777b538SAndroid Build Coastguard Worker           trace_event_flags | TRACE_EVENT_FLAG_EXPLICIT_TIMESTAMP);          \
376*6777b538SAndroid Build Coastguard Worker     }                                                                        \
377*6777b538SAndroid Build Coastguard Worker   } while (0)
378*6777b538SAndroid Build Coastguard Worker 
379*6777b538SAndroid Build Coastguard Worker // Implementation detail: internal macro to create static category and add
380*6777b538SAndroid Build Coastguard Worker // metadata event if the category is enabled.
381*6777b538SAndroid Build Coastguard Worker #define INTERNAL_TRACE_EVENT_METADATA_ADD(category_group, name, ...) \
382*6777b538SAndroid Build Coastguard Worker   do {                                                               \
383*6777b538SAndroid Build Coastguard Worker     INTERNAL_TRACE_EVENT_GET_CATEGORY_INFO(category_group);          \
384*6777b538SAndroid Build Coastguard Worker     if (INTERNAL_TRACE_EVENT_CATEGORY_GROUP_ENABLED()) {             \
385*6777b538SAndroid Build Coastguard Worker       TRACE_EVENT_API_ADD_METADATA_EVENT(                            \
386*6777b538SAndroid Build Coastguard Worker           INTERNAL_TRACE_EVENT_UID(category_group_enabled), name,    \
387*6777b538SAndroid Build Coastguard Worker           ##__VA_ARGS__);                                            \
388*6777b538SAndroid Build Coastguard Worker     }                                                                \
389*6777b538SAndroid Build Coastguard Worker   } while (0)
390*6777b538SAndroid Build Coastguard Worker #endif  // BUILDFLAG(USE_PERFETTO_CLIENT_LIBRARY)
391*6777b538SAndroid Build Coastguard Worker 
392*6777b538SAndroid Build Coastguard Worker namespace trace_event_internal {
393*6777b538SAndroid Build Coastguard Worker 
394*6777b538SAndroid Build Coastguard Worker // Specify these values when the corresponding argument of AddTraceEvent is not
395*6777b538SAndroid Build Coastguard Worker // used.
396*6777b538SAndroid Build Coastguard Worker const int kZeroNumArgs = 0;
397*6777b538SAndroid Build Coastguard Worker const std::nullptr_t kGlobalScope = nullptr;
398*6777b538SAndroid Build Coastguard Worker const uint64_t kNoId = 0;
399*6777b538SAndroid Build Coastguard Worker 
400*6777b538SAndroid Build Coastguard Worker // TraceID encapsulates an ID that can either be an integer or pointer.
401*6777b538SAndroid Build Coastguard Worker class BASE_EXPORT TraceID {
402*6777b538SAndroid Build Coastguard Worker  public:
403*6777b538SAndroid Build Coastguard Worker   // Can be combined with WithScope.
404*6777b538SAndroid Build Coastguard Worker   class LocalId {
405*6777b538SAndroid Build Coastguard Worker    public:
LocalId(const void * raw_id)406*6777b538SAndroid Build Coastguard Worker     explicit LocalId(const void* raw_id)
407*6777b538SAndroid Build Coastguard Worker         : raw_id_(static_cast<uint64_t>(reinterpret_cast<uintptr_t>(raw_id))) {}
LocalId(uint64_t raw_id)408*6777b538SAndroid Build Coastguard Worker     explicit LocalId(uint64_t raw_id) : raw_id_(raw_id) {}
raw_id()409*6777b538SAndroid Build Coastguard Worker     uint64_t raw_id() const { return raw_id_; }
410*6777b538SAndroid Build Coastguard Worker 
411*6777b538SAndroid Build Coastguard Worker    private:
412*6777b538SAndroid Build Coastguard Worker     uint64_t raw_id_;
413*6777b538SAndroid Build Coastguard Worker   };
414*6777b538SAndroid Build Coastguard Worker 
415*6777b538SAndroid Build Coastguard Worker   // Can be combined with WithScope.
416*6777b538SAndroid Build Coastguard Worker   class GlobalId {
417*6777b538SAndroid Build Coastguard Worker    public:
GlobalId(uint64_t raw_id)418*6777b538SAndroid Build Coastguard Worker     explicit GlobalId(uint64_t raw_id) : raw_id_(raw_id) {}
raw_id()419*6777b538SAndroid Build Coastguard Worker     uint64_t raw_id() const { return raw_id_; }
420*6777b538SAndroid Build Coastguard Worker 
421*6777b538SAndroid Build Coastguard Worker    private:
422*6777b538SAndroid Build Coastguard Worker     uint64_t raw_id_;
423*6777b538SAndroid Build Coastguard Worker   };
424*6777b538SAndroid Build Coastguard Worker 
425*6777b538SAndroid Build Coastguard Worker   class WithScope {
426*6777b538SAndroid Build Coastguard Worker    public:
WithScope(const char * scope,uint64_t raw_id)427*6777b538SAndroid Build Coastguard Worker     WithScope(const char* scope, uint64_t raw_id)
428*6777b538SAndroid Build Coastguard Worker         : scope_(scope), raw_id_(raw_id) {}
WithScope(const char * scope,LocalId local_id)429*6777b538SAndroid Build Coastguard Worker     WithScope(const char* scope, LocalId local_id)
430*6777b538SAndroid Build Coastguard Worker         : scope_(scope), raw_id_(local_id.raw_id()) {
431*6777b538SAndroid Build Coastguard Worker       id_flags_ = TRACE_EVENT_FLAG_HAS_LOCAL_ID;
432*6777b538SAndroid Build Coastguard Worker     }
WithScope(const char * scope,GlobalId global_id)433*6777b538SAndroid Build Coastguard Worker     WithScope(const char* scope, GlobalId global_id)
434*6777b538SAndroid Build Coastguard Worker         : scope_(scope), raw_id_(global_id.raw_id()) {
435*6777b538SAndroid Build Coastguard Worker       id_flags_ = TRACE_EVENT_FLAG_HAS_GLOBAL_ID;
436*6777b538SAndroid Build Coastguard Worker     }
raw_id()437*6777b538SAndroid Build Coastguard Worker     uint64_t raw_id() const { return raw_id_; }
scope()438*6777b538SAndroid Build Coastguard Worker     const char* scope() const { return scope_; }
id_flags()439*6777b538SAndroid Build Coastguard Worker     unsigned int id_flags() const { return id_flags_; }
440*6777b538SAndroid Build Coastguard Worker 
441*6777b538SAndroid Build Coastguard Worker    private:
442*6777b538SAndroid Build Coastguard Worker     const char* scope_ = nullptr;
443*6777b538SAndroid Build Coastguard Worker     uint64_t raw_id_;
444*6777b538SAndroid Build Coastguard Worker     unsigned int id_flags_ = TRACE_EVENT_FLAG_HAS_ID;
445*6777b538SAndroid Build Coastguard Worker   };
446*6777b538SAndroid Build Coastguard Worker 
TraceID(const void * raw_id)447*6777b538SAndroid Build Coastguard Worker   explicit TraceID(const void* raw_id)
448*6777b538SAndroid Build Coastguard Worker       : raw_id_(static_cast<uint64_t>(reinterpret_cast<uintptr_t>(raw_id))) {
449*6777b538SAndroid Build Coastguard Worker     id_flags_ = TRACE_EVENT_FLAG_HAS_LOCAL_ID;
450*6777b538SAndroid Build Coastguard Worker   }
TraceID(unsigned long long raw_id)451*6777b538SAndroid Build Coastguard Worker   explicit TraceID(unsigned long long raw_id)
452*6777b538SAndroid Build Coastguard Worker       : raw_id_(static_cast<uint64_t>(raw_id)) {}
TraceID(unsigned long raw_id)453*6777b538SAndroid Build Coastguard Worker   explicit TraceID(unsigned long raw_id)
454*6777b538SAndroid Build Coastguard Worker       : raw_id_(static_cast<uint64_t>(raw_id)) {}
TraceID(unsigned int raw_id)455*6777b538SAndroid Build Coastguard Worker   explicit TraceID(unsigned int raw_id)
456*6777b538SAndroid Build Coastguard Worker       : raw_id_(static_cast<uint64_t>(raw_id)) {}
TraceID(unsigned short raw_id)457*6777b538SAndroid Build Coastguard Worker   explicit TraceID(unsigned short raw_id)
458*6777b538SAndroid Build Coastguard Worker       : raw_id_(static_cast<uint64_t>(raw_id)) {}
TraceID(unsigned char raw_id)459*6777b538SAndroid Build Coastguard Worker   explicit TraceID(unsigned char raw_id)
460*6777b538SAndroid Build Coastguard Worker       : raw_id_(static_cast<uint64_t>(raw_id)) {}
TraceID(long long raw_id)461*6777b538SAndroid Build Coastguard Worker   explicit TraceID(long long raw_id) : raw_id_(static_cast<uint64_t>(raw_id)) {}
TraceID(long raw_id)462*6777b538SAndroid Build Coastguard Worker   explicit TraceID(long raw_id) : raw_id_(static_cast<uint64_t>(raw_id)) {}
TraceID(int raw_id)463*6777b538SAndroid Build Coastguard Worker   explicit TraceID(int raw_id) : raw_id_(static_cast<uint64_t>(raw_id)) {}
TraceID(short raw_id)464*6777b538SAndroid Build Coastguard Worker   explicit TraceID(short raw_id) : raw_id_(static_cast<uint64_t>(raw_id)) {}
TraceID(signed char raw_id)465*6777b538SAndroid Build Coastguard Worker   explicit TraceID(signed char raw_id)
466*6777b538SAndroid Build Coastguard Worker       : raw_id_(static_cast<uint64_t>(raw_id)) {}
TraceID(LocalId raw_id)467*6777b538SAndroid Build Coastguard Worker   explicit TraceID(LocalId raw_id) : raw_id_(raw_id.raw_id()) {
468*6777b538SAndroid Build Coastguard Worker     id_flags_ = TRACE_EVENT_FLAG_HAS_LOCAL_ID;
469*6777b538SAndroid Build Coastguard Worker   }
TraceID(GlobalId raw_id)470*6777b538SAndroid Build Coastguard Worker   explicit TraceID(GlobalId raw_id) : raw_id_(raw_id.raw_id()) {
471*6777b538SAndroid Build Coastguard Worker     id_flags_ = TRACE_EVENT_FLAG_HAS_GLOBAL_ID;
472*6777b538SAndroid Build Coastguard Worker   }
TraceID(WithScope scoped_id)473*6777b538SAndroid Build Coastguard Worker   explicit TraceID(WithScope scoped_id)
474*6777b538SAndroid Build Coastguard Worker       : scope_(scoped_id.scope()),
475*6777b538SAndroid Build Coastguard Worker         raw_id_(scoped_id.raw_id()),
476*6777b538SAndroid Build Coastguard Worker         id_flags_(scoped_id.id_flags()) {}
477*6777b538SAndroid Build Coastguard Worker 
raw_id()478*6777b538SAndroid Build Coastguard Worker   uint64_t raw_id() const { return raw_id_; }
scope()479*6777b538SAndroid Build Coastguard Worker   const char* scope() const { return scope_; }
id_flags()480*6777b538SAndroid Build Coastguard Worker   unsigned int id_flags() const { return id_flags_; }
481*6777b538SAndroid Build Coastguard Worker 
482*6777b538SAndroid Build Coastguard Worker  private:
483*6777b538SAndroid Build Coastguard Worker   const char* scope_ = nullptr;
484*6777b538SAndroid Build Coastguard Worker   uint64_t raw_id_;
485*6777b538SAndroid Build Coastguard Worker   unsigned int id_flags_ = TRACE_EVENT_FLAG_HAS_ID;
486*6777b538SAndroid Build Coastguard Worker };
487*6777b538SAndroid Build Coastguard Worker 
488*6777b538SAndroid Build Coastguard Worker // These functions all internally call
489*6777b538SAndroid Build Coastguard Worker // base::trace_event::TraceLog::GetInstance() then call the method with the same
490*6777b538SAndroid Build Coastguard Worker // name on it. This is used to reduce the generated machine code at each
491*6777b538SAndroid Build Coastguard Worker // TRACE_EVENTXXX macro call.
492*6777b538SAndroid Build Coastguard Worker 
493*6777b538SAndroid Build Coastguard Worker base::trace_event::TraceEventHandle BASE_EXPORT
494*6777b538SAndroid Build Coastguard Worker AddTraceEvent(char phase,
495*6777b538SAndroid Build Coastguard Worker               const unsigned char* category_group_enabled,
496*6777b538SAndroid Build Coastguard Worker               const char* name,
497*6777b538SAndroid Build Coastguard Worker               const char* scope,
498*6777b538SAndroid Build Coastguard Worker               uint64_t id,
499*6777b538SAndroid Build Coastguard Worker               base::trace_event::TraceArguments* args,
500*6777b538SAndroid Build Coastguard Worker               unsigned int flags);
501*6777b538SAndroid Build Coastguard Worker 
502*6777b538SAndroid Build Coastguard Worker base::trace_event::TraceEventHandle BASE_EXPORT
503*6777b538SAndroid Build Coastguard Worker AddTraceEventWithBindId(char phase,
504*6777b538SAndroid Build Coastguard Worker                         const unsigned char* category_group_enabled,
505*6777b538SAndroid Build Coastguard Worker                         const char* name,
506*6777b538SAndroid Build Coastguard Worker                         const char* scope,
507*6777b538SAndroid Build Coastguard Worker                         uint64_t id,
508*6777b538SAndroid Build Coastguard Worker                         uint64_t bind_id,
509*6777b538SAndroid Build Coastguard Worker                         base::trace_event::TraceArguments* args,
510*6777b538SAndroid Build Coastguard Worker                         unsigned int flags);
511*6777b538SAndroid Build Coastguard Worker 
512*6777b538SAndroid Build Coastguard Worker base::trace_event::TraceEventHandle BASE_EXPORT
513*6777b538SAndroid Build Coastguard Worker AddTraceEventWithProcessId(char phase,
514*6777b538SAndroid Build Coastguard Worker                            const unsigned char* category_group_enabled,
515*6777b538SAndroid Build Coastguard Worker                            const char* name,
516*6777b538SAndroid Build Coastguard Worker                            const char* scope,
517*6777b538SAndroid Build Coastguard Worker                            uint64_t id,
518*6777b538SAndroid Build Coastguard Worker                            base::ProcessId process_id,
519*6777b538SAndroid Build Coastguard Worker                            base::trace_event::TraceArguments* args,
520*6777b538SAndroid Build Coastguard Worker                            unsigned int flags);
521*6777b538SAndroid Build Coastguard Worker 
522*6777b538SAndroid Build Coastguard Worker base::trace_event::TraceEventHandle BASE_EXPORT
523*6777b538SAndroid Build Coastguard Worker AddTraceEventWithThreadIdAndTimestamp(
524*6777b538SAndroid Build Coastguard Worker     char phase,
525*6777b538SAndroid Build Coastguard Worker     const unsigned char* category_group_enabled,
526*6777b538SAndroid Build Coastguard Worker     const char* name,
527*6777b538SAndroid Build Coastguard Worker     const char* scope,
528*6777b538SAndroid Build Coastguard Worker     uint64_t id,
529*6777b538SAndroid Build Coastguard Worker     base::PlatformThreadId thread_id,
530*6777b538SAndroid Build Coastguard Worker     const base::TimeTicks& timestamp,
531*6777b538SAndroid Build Coastguard Worker     base::trace_event::TraceArguments* args,
532*6777b538SAndroid Build Coastguard Worker     unsigned int flags);
533*6777b538SAndroid Build Coastguard Worker 
534*6777b538SAndroid Build Coastguard Worker base::trace_event::TraceEventHandle BASE_EXPORT
535*6777b538SAndroid Build Coastguard Worker AddTraceEventWithThreadIdAndTimestamp(
536*6777b538SAndroid Build Coastguard Worker     char phase,
537*6777b538SAndroid Build Coastguard Worker     const unsigned char* category_group_enabled,
538*6777b538SAndroid Build Coastguard Worker     const char* name,
539*6777b538SAndroid Build Coastguard Worker     const char* scope,
540*6777b538SAndroid Build Coastguard Worker     uint64_t id,
541*6777b538SAndroid Build Coastguard Worker     uint64_t bind_id,
542*6777b538SAndroid Build Coastguard Worker     base::PlatformThreadId thread_id,
543*6777b538SAndroid Build Coastguard Worker     const base::TimeTicks& timestamp,
544*6777b538SAndroid Build Coastguard Worker     base::trace_event::TraceArguments* args,
545*6777b538SAndroid Build Coastguard Worker     unsigned int flags);
546*6777b538SAndroid Build Coastguard Worker 
547*6777b538SAndroid Build Coastguard Worker base::trace_event::TraceEventHandle BASE_EXPORT
548*6777b538SAndroid Build Coastguard Worker AddTraceEventWithThreadIdAndTimestamps(
549*6777b538SAndroid Build Coastguard Worker     char phase,
550*6777b538SAndroid Build Coastguard Worker     const unsigned char* category_group_enabled,
551*6777b538SAndroid Build Coastguard Worker     const char* name,
552*6777b538SAndroid Build Coastguard Worker     const char* scope,
553*6777b538SAndroid Build Coastguard Worker     uint64_t id,
554*6777b538SAndroid Build Coastguard Worker     base::PlatformThreadId thread_id,
555*6777b538SAndroid Build Coastguard Worker     const base::TimeTicks& timestamp,
556*6777b538SAndroid Build Coastguard Worker     const base::ThreadTicks& thread_timestamp,
557*6777b538SAndroid Build Coastguard Worker     unsigned int flags);
558*6777b538SAndroid Build Coastguard Worker 
559*6777b538SAndroid Build Coastguard Worker void BASE_EXPORT AddMetadataEvent(const unsigned char* category_group_enabled,
560*6777b538SAndroid Build Coastguard Worker                                   const char* name,
561*6777b538SAndroid Build Coastguard Worker                                   base::trace_event::TraceArguments* args,
562*6777b538SAndroid Build Coastguard Worker                                   unsigned int flags);
563*6777b538SAndroid Build Coastguard Worker 
564*6777b538SAndroid Build Coastguard Worker int BASE_EXPORT GetNumTracesRecorded();
565*6777b538SAndroid Build Coastguard Worker 
566*6777b538SAndroid Build Coastguard Worker void BASE_EXPORT
567*6777b538SAndroid Build Coastguard Worker UpdateTraceEventDuration(const unsigned char* category_group_enabled,
568*6777b538SAndroid Build Coastguard Worker                          const char* name,
569*6777b538SAndroid Build Coastguard Worker                          base::trace_event::TraceEventHandle handle);
570*6777b538SAndroid Build Coastguard Worker 
571*6777b538SAndroid Build Coastguard Worker void BASE_EXPORT
572*6777b538SAndroid Build Coastguard Worker UpdateTraceEventDurationExplicit(const unsigned char* category_group_enabled,
573*6777b538SAndroid Build Coastguard Worker                                  const char* name,
574*6777b538SAndroid Build Coastguard Worker                                  base::trace_event::TraceEventHandle handle,
575*6777b538SAndroid Build Coastguard Worker                                  base::PlatformThreadId thread_id,
576*6777b538SAndroid Build Coastguard Worker                                  bool explicit_timestamps,
577*6777b538SAndroid Build Coastguard Worker                                  const base::TimeTicks& now,
578*6777b538SAndroid Build Coastguard Worker                                  const base::ThreadTicks& thread_now);
579*6777b538SAndroid Build Coastguard Worker 
580*6777b538SAndroid Build Coastguard Worker // These AddTraceEvent and AddTraceEventWithThreadIdAndTimestamp template
581*6777b538SAndroid Build Coastguard Worker // functions are defined here instead of in the macro, because the arg_values
582*6777b538SAndroid Build Coastguard Worker // could be temporary objects, such as `std::string`. In order to store
583*6777b538SAndroid Build Coastguard Worker // pointers to the internal c_str and pass through to the tracing API,
584*6777b538SAndroid Build Coastguard Worker // the arg_values must live throughout these procedures.
585*6777b538SAndroid Build Coastguard Worker 
586*6777b538SAndroid Build Coastguard Worker template <class ARG1_TYPE>
587*6777b538SAndroid Build Coastguard Worker inline base::trace_event::TraceEventHandle
AddTraceEventWithThreadIdAndTimestamp(char phase,const unsigned char * category_group_enabled,const char * name,const char * scope,uint64_t id,base::PlatformThreadId thread_id,const base::TimeTicks & timestamp,unsigned int flags,uint64_t bind_id,const char * arg1_name,ARG1_TYPE && arg1_val)588*6777b538SAndroid Build Coastguard Worker AddTraceEventWithThreadIdAndTimestamp(
589*6777b538SAndroid Build Coastguard Worker     char phase,
590*6777b538SAndroid Build Coastguard Worker     const unsigned char* category_group_enabled,
591*6777b538SAndroid Build Coastguard Worker     const char* name,
592*6777b538SAndroid Build Coastguard Worker     const char* scope,
593*6777b538SAndroid Build Coastguard Worker     uint64_t id,
594*6777b538SAndroid Build Coastguard Worker     base::PlatformThreadId thread_id,
595*6777b538SAndroid Build Coastguard Worker     const base::TimeTicks& timestamp,
596*6777b538SAndroid Build Coastguard Worker     unsigned int flags,
597*6777b538SAndroid Build Coastguard Worker     uint64_t bind_id,
598*6777b538SAndroid Build Coastguard Worker     const char* arg1_name,
599*6777b538SAndroid Build Coastguard Worker     ARG1_TYPE&& arg1_val) {
600*6777b538SAndroid Build Coastguard Worker   base::trace_event::TraceArguments args(arg1_name,
601*6777b538SAndroid Build Coastguard Worker                                          std::forward<ARG1_TYPE>(arg1_val));
602*6777b538SAndroid Build Coastguard Worker   return TRACE_EVENT_API_ADD_TRACE_EVENT_WITH_THREAD_ID_AND_TIMESTAMP(
603*6777b538SAndroid Build Coastguard Worker       phase, category_group_enabled, name, scope, id, bind_id, thread_id,
604*6777b538SAndroid Build Coastguard Worker       timestamp, &args, flags);
605*6777b538SAndroid Build Coastguard Worker }
606*6777b538SAndroid Build Coastguard Worker 
607*6777b538SAndroid Build Coastguard Worker template <class ARG1_TYPE, class ARG2_TYPE>
608*6777b538SAndroid Build Coastguard Worker inline base::trace_event::TraceEventHandle
AddTraceEventWithThreadIdAndTimestamp(char phase,const unsigned char * category_group_enabled,const char * name,const char * scope,uint64_t id,base::PlatformThreadId thread_id,const base::TimeTicks & timestamp,unsigned int flags,uint64_t bind_id,const char * arg1_name,ARG1_TYPE && arg1_val,const char * arg2_name,ARG2_TYPE && arg2_val)609*6777b538SAndroid Build Coastguard Worker AddTraceEventWithThreadIdAndTimestamp(
610*6777b538SAndroid Build Coastguard Worker     char phase,
611*6777b538SAndroid Build Coastguard Worker     const unsigned char* category_group_enabled,
612*6777b538SAndroid Build Coastguard Worker     const char* name,
613*6777b538SAndroid Build Coastguard Worker     const char* scope,
614*6777b538SAndroid Build Coastguard Worker     uint64_t id,
615*6777b538SAndroid Build Coastguard Worker     base::PlatformThreadId thread_id,
616*6777b538SAndroid Build Coastguard Worker     const base::TimeTicks& timestamp,
617*6777b538SAndroid Build Coastguard Worker     unsigned int flags,
618*6777b538SAndroid Build Coastguard Worker     uint64_t bind_id,
619*6777b538SAndroid Build Coastguard Worker     const char* arg1_name,
620*6777b538SAndroid Build Coastguard Worker     ARG1_TYPE&& arg1_val,
621*6777b538SAndroid Build Coastguard Worker     const char* arg2_name,
622*6777b538SAndroid Build Coastguard Worker     ARG2_TYPE&& arg2_val) {
623*6777b538SAndroid Build Coastguard Worker   base::trace_event::TraceArguments args(
624*6777b538SAndroid Build Coastguard Worker       arg1_name, std::forward<ARG1_TYPE>(arg1_val), arg2_name,
625*6777b538SAndroid Build Coastguard Worker       std::forward<ARG2_TYPE>(arg2_val));
626*6777b538SAndroid Build Coastguard Worker   return TRACE_EVENT_API_ADD_TRACE_EVENT_WITH_THREAD_ID_AND_TIMESTAMP(
627*6777b538SAndroid Build Coastguard Worker       phase, category_group_enabled, name, scope, id, bind_id, thread_id,
628*6777b538SAndroid Build Coastguard Worker       timestamp, &args, flags);
629*6777b538SAndroid Build Coastguard Worker }
630*6777b538SAndroid Build Coastguard Worker 
631*6777b538SAndroid Build Coastguard Worker inline base::trace_event::TraceEventHandle
AddTraceEventWithThreadIdAndTimestamp(char phase,const unsigned char * category_group_enabled,const char * name,const char * scope,uint64_t id,base::PlatformThreadId thread_id,const base::TimeTicks & timestamp,unsigned int flags,uint64_t bind_id)632*6777b538SAndroid Build Coastguard Worker AddTraceEventWithThreadIdAndTimestamp(
633*6777b538SAndroid Build Coastguard Worker     char phase,
634*6777b538SAndroid Build Coastguard Worker     const unsigned char* category_group_enabled,
635*6777b538SAndroid Build Coastguard Worker     const char* name,
636*6777b538SAndroid Build Coastguard Worker     const char* scope,
637*6777b538SAndroid Build Coastguard Worker     uint64_t id,
638*6777b538SAndroid Build Coastguard Worker     base::PlatformThreadId thread_id,
639*6777b538SAndroid Build Coastguard Worker     const base::TimeTicks& timestamp,
640*6777b538SAndroid Build Coastguard Worker     unsigned int flags,
641*6777b538SAndroid Build Coastguard Worker     uint64_t bind_id) {
642*6777b538SAndroid Build Coastguard Worker   return TRACE_EVENT_API_ADD_TRACE_EVENT_WITH_THREAD_ID_AND_TIMESTAMP(
643*6777b538SAndroid Build Coastguard Worker       phase, category_group_enabled, name, scope, id, bind_id, thread_id,
644*6777b538SAndroid Build Coastguard Worker       timestamp, nullptr, flags);
645*6777b538SAndroid Build Coastguard Worker }
646*6777b538SAndroid Build Coastguard Worker 
AddTraceEvent(char phase,const unsigned char * category_group_enabled,const char * name,const char * scope,uint64_t id,unsigned int flags,uint64_t bind_id)647*6777b538SAndroid Build Coastguard Worker inline base::trace_event::TraceEventHandle AddTraceEvent(
648*6777b538SAndroid Build Coastguard Worker     char phase,
649*6777b538SAndroid Build Coastguard Worker     const unsigned char* category_group_enabled,
650*6777b538SAndroid Build Coastguard Worker     const char* name,
651*6777b538SAndroid Build Coastguard Worker     const char* scope,
652*6777b538SAndroid Build Coastguard Worker     uint64_t id,
653*6777b538SAndroid Build Coastguard Worker     unsigned int flags,
654*6777b538SAndroid Build Coastguard Worker     uint64_t bind_id) {
655*6777b538SAndroid Build Coastguard Worker   return AddTraceEventWithThreadIdAndTimestamp(
656*6777b538SAndroid Build Coastguard Worker       phase, category_group_enabled, name, scope, id,
657*6777b538SAndroid Build Coastguard Worker       TRACE_EVENT_API_CURRENT_THREAD_ID, TRACE_TIME_TICKS_NOW(), flags,
658*6777b538SAndroid Build Coastguard Worker       bind_id);
659*6777b538SAndroid Build Coastguard Worker }
660*6777b538SAndroid Build Coastguard Worker 
661*6777b538SAndroid Build Coastguard Worker template <class ARG1_TYPE>
AddTraceEvent(char phase,const unsigned char * category_group_enabled,const char * name,const char * scope,uint64_t id,unsigned int flags,uint64_t bind_id,const char * arg1_name,ARG1_TYPE && arg1_val)662*6777b538SAndroid Build Coastguard Worker inline base::trace_event::TraceEventHandle AddTraceEvent(
663*6777b538SAndroid Build Coastguard Worker     char phase,
664*6777b538SAndroid Build Coastguard Worker     const unsigned char* category_group_enabled,
665*6777b538SAndroid Build Coastguard Worker     const char* name,
666*6777b538SAndroid Build Coastguard Worker     const char* scope,
667*6777b538SAndroid Build Coastguard Worker     uint64_t id,
668*6777b538SAndroid Build Coastguard Worker     unsigned int flags,
669*6777b538SAndroid Build Coastguard Worker     uint64_t bind_id,
670*6777b538SAndroid Build Coastguard Worker     const char* arg1_name,
671*6777b538SAndroid Build Coastguard Worker     ARG1_TYPE&& arg1_val) {
672*6777b538SAndroid Build Coastguard Worker   return AddTraceEventWithThreadIdAndTimestamp(
673*6777b538SAndroid Build Coastguard Worker       phase, category_group_enabled, name, scope, id,
674*6777b538SAndroid Build Coastguard Worker       TRACE_EVENT_API_CURRENT_THREAD_ID, TRACE_TIME_TICKS_NOW(), flags, bind_id,
675*6777b538SAndroid Build Coastguard Worker       arg1_name, std::forward<ARG1_TYPE>(arg1_val));
676*6777b538SAndroid Build Coastguard Worker }
677*6777b538SAndroid Build Coastguard Worker 
678*6777b538SAndroid Build Coastguard Worker template <class ARG1_TYPE, class ARG2_TYPE>
AddTraceEvent(char phase,const unsigned char * category_group_enabled,const char * name,const char * scope,uint64_t id,unsigned int flags,uint64_t bind_id,const char * arg1_name,ARG1_TYPE && arg1_val,const char * arg2_name,ARG2_TYPE && arg2_val)679*6777b538SAndroid Build Coastguard Worker inline base::trace_event::TraceEventHandle AddTraceEvent(
680*6777b538SAndroid Build Coastguard Worker     char phase,
681*6777b538SAndroid Build Coastguard Worker     const unsigned char* category_group_enabled,
682*6777b538SAndroid Build Coastguard Worker     const char* name,
683*6777b538SAndroid Build Coastguard Worker     const char* scope,
684*6777b538SAndroid Build Coastguard Worker     uint64_t id,
685*6777b538SAndroid Build Coastguard Worker     unsigned int flags,
686*6777b538SAndroid Build Coastguard Worker     uint64_t bind_id,
687*6777b538SAndroid Build Coastguard Worker     const char* arg1_name,
688*6777b538SAndroid Build Coastguard Worker     ARG1_TYPE&& arg1_val,
689*6777b538SAndroid Build Coastguard Worker     const char* arg2_name,
690*6777b538SAndroid Build Coastguard Worker     ARG2_TYPE&& arg2_val) {
691*6777b538SAndroid Build Coastguard Worker   return AddTraceEventWithThreadIdAndTimestamp(
692*6777b538SAndroid Build Coastguard Worker       phase, category_group_enabled, name, scope, id,
693*6777b538SAndroid Build Coastguard Worker       TRACE_EVENT_API_CURRENT_THREAD_ID, TRACE_TIME_TICKS_NOW(), flags, bind_id,
694*6777b538SAndroid Build Coastguard Worker       arg1_name, std::forward<ARG1_TYPE>(arg1_val), arg2_name,
695*6777b538SAndroid Build Coastguard Worker       std::forward<ARG2_TYPE>(arg2_val));
696*6777b538SAndroid Build Coastguard Worker }
697*6777b538SAndroid Build Coastguard Worker 
698*6777b538SAndroid Build Coastguard Worker template <class ARG1_TYPE>
AddMetadataEvent(const unsigned char * category_group_enabled,const char * event_name,const char * arg_name,ARG1_TYPE && arg_val)699*6777b538SAndroid Build Coastguard Worker void AddMetadataEvent(const unsigned char* category_group_enabled,
700*6777b538SAndroid Build Coastguard Worker                       const char* event_name,
701*6777b538SAndroid Build Coastguard Worker                       const char* arg_name,
702*6777b538SAndroid Build Coastguard Worker                       ARG1_TYPE&& arg_val) {
703*6777b538SAndroid Build Coastguard Worker   base::trace_event::TraceArguments args(arg_name,
704*6777b538SAndroid Build Coastguard Worker                                          std::forward<ARG1_TYPE>(arg_val));
705*6777b538SAndroid Build Coastguard Worker   trace_event_internal::AddMetadataEvent(category_group_enabled, event_name,
706*6777b538SAndroid Build Coastguard Worker                                          &args, TRACE_EVENT_FLAG_NONE);
707*6777b538SAndroid Build Coastguard Worker }
708*6777b538SAndroid Build Coastguard Worker 
709*6777b538SAndroid Build Coastguard Worker #if !BUILDFLAG(USE_PERFETTO_CLIENT_LIBRARY)
710*6777b538SAndroid Build Coastguard Worker 
711*6777b538SAndroid Build Coastguard Worker // Used by TRACE_EVENTx macros. Do not use directly.
712*6777b538SAndroid Build Coastguard Worker class TRACE_EVENT_API_CLASS_EXPORT ScopedTracer {
713*6777b538SAndroid Build Coastguard Worker  public:
714*6777b538SAndroid Build Coastguard Worker   ScopedTracer() = default;
715*6777b538SAndroid Build Coastguard Worker 
~ScopedTracer()716*6777b538SAndroid Build Coastguard Worker   ~ScopedTracer() {
717*6777b538SAndroid Build Coastguard Worker     if (category_group_enabled_ && *category_group_enabled_) {
718*6777b538SAndroid Build Coastguard Worker       TRACE_EVENT_API_UPDATE_TRACE_EVENT_DURATION(category_group_enabled_,
719*6777b538SAndroid Build Coastguard Worker                                                   name_, event_handle_);
720*6777b538SAndroid Build Coastguard Worker     }
721*6777b538SAndroid Build Coastguard Worker   }
722*6777b538SAndroid Build Coastguard Worker 
Initialize(const unsigned char * category_group_enabled,const char * name,base::trace_event::TraceEventHandle event_handle)723*6777b538SAndroid Build Coastguard Worker   void Initialize(const unsigned char* category_group_enabled,
724*6777b538SAndroid Build Coastguard Worker                   const char* name,
725*6777b538SAndroid Build Coastguard Worker                   base::trace_event::TraceEventHandle event_handle) {
726*6777b538SAndroid Build Coastguard Worker     category_group_enabled_ = category_group_enabled;
727*6777b538SAndroid Build Coastguard Worker     name_ = name;
728*6777b538SAndroid Build Coastguard Worker     event_handle_ = event_handle;
729*6777b538SAndroid Build Coastguard Worker   }
730*6777b538SAndroid Build Coastguard Worker 
731*6777b538SAndroid Build Coastguard Worker  private:
732*6777b538SAndroid Build Coastguard Worker   // NOTE: Only initialize the first member to reduce generated code size,
733*6777b538SAndroid Build Coastguard Worker   // since there is no point in initializing the other members if Initialize()
734*6777b538SAndroid Build Coastguard Worker   // is never called.
735*6777b538SAndroid Build Coastguard Worker   const unsigned char* category_group_enabled_ = nullptr;
736*6777b538SAndroid Build Coastguard Worker   const char* name_;
737*6777b538SAndroid Build Coastguard Worker   base::trace_event::TraceEventHandle event_handle_;
738*6777b538SAndroid Build Coastguard Worker };
739*6777b538SAndroid Build Coastguard Worker 
740*6777b538SAndroid Build Coastguard Worker // Used by TRACE_EVENT_BINARY_EFFICIENTx macro. Do not use directly.
741*6777b538SAndroid Build Coastguard Worker class TRACE_EVENT_API_CLASS_EXPORT ScopedTraceBinaryEfficient {
742*6777b538SAndroid Build Coastguard Worker  public:
743*6777b538SAndroid Build Coastguard Worker   ScopedTraceBinaryEfficient(const char* category_group, const char* name);
744*6777b538SAndroid Build Coastguard Worker   ~ScopedTraceBinaryEfficient();
745*6777b538SAndroid Build Coastguard Worker 
746*6777b538SAndroid Build Coastguard Worker  private:
747*6777b538SAndroid Build Coastguard Worker   const unsigned char* category_group_enabled_;
748*6777b538SAndroid Build Coastguard Worker   const char* name_;
749*6777b538SAndroid Build Coastguard Worker   base::trace_event::TraceEventHandle event_handle_;
750*6777b538SAndroid Build Coastguard Worker };
751*6777b538SAndroid Build Coastguard Worker 
752*6777b538SAndroid Build Coastguard Worker // This macro generates less code then TRACE_EVENT0 but is also
753*6777b538SAndroid Build Coastguard Worker // slower to execute when tracing is off. It should generally only be
754*6777b538SAndroid Build Coastguard Worker // used with code that is seldom executed or conditionally executed
755*6777b538SAndroid Build Coastguard Worker // when debugging.
756*6777b538SAndroid Build Coastguard Worker // For now the category_group must be "gpu".
757*6777b538SAndroid Build Coastguard Worker #define TRACE_EVENT_BINARY_EFFICIENT0(category_group, name) \
758*6777b538SAndroid Build Coastguard Worker     trace_event_internal::ScopedTraceBinaryEfficient \
759*6777b538SAndroid Build Coastguard Worker         INTERNAL_TRACE_EVENT_UID(scoped_trace)(category_group, name);
760*6777b538SAndroid Build Coastguard Worker 
761*6777b538SAndroid Build Coastguard Worker #endif  // !BUILDFLAG(USE_PERFETTO_CLIENT_LIBRARY)
762*6777b538SAndroid Build Coastguard Worker 
763*6777b538SAndroid Build Coastguard Worker }  // namespace trace_event_internal
764*6777b538SAndroid Build Coastguard Worker 
765*6777b538SAndroid Build Coastguard Worker namespace base {
766*6777b538SAndroid Build Coastguard Worker namespace trace_event {
767*6777b538SAndroid Build Coastguard Worker 
768*6777b538SAndroid Build Coastguard Worker template <typename IDType, const char* category>
769*6777b538SAndroid Build Coastguard Worker class TraceScopedTrackableObject {
770*6777b538SAndroid Build Coastguard Worker  public:
TraceScopedTrackableObject(const char * name,IDType id)771*6777b538SAndroid Build Coastguard Worker   TraceScopedTrackableObject(const char* name, IDType id)
772*6777b538SAndroid Build Coastguard Worker       : name_(name), id_(id) {
773*6777b538SAndroid Build Coastguard Worker     TRACE_EVENT_OBJECT_CREATED_WITH_ID(category, name_, id_);
774*6777b538SAndroid Build Coastguard Worker   }
775*6777b538SAndroid Build Coastguard Worker   TraceScopedTrackableObject(const TraceScopedTrackableObject&) = delete;
776*6777b538SAndroid Build Coastguard Worker   TraceScopedTrackableObject& operator=(const TraceScopedTrackableObject&) =
777*6777b538SAndroid Build Coastguard Worker       delete;
778*6777b538SAndroid Build Coastguard Worker 
snapshot(ArgType snapshot)779*6777b538SAndroid Build Coastguard Worker   template <typename ArgType> void snapshot(ArgType snapshot) {
780*6777b538SAndroid Build Coastguard Worker     TRACE_EVENT_OBJECT_SNAPSHOT_WITH_ID(category, name_, id_, snapshot);
781*6777b538SAndroid Build Coastguard Worker   }
782*6777b538SAndroid Build Coastguard Worker 
~TraceScopedTrackableObject()783*6777b538SAndroid Build Coastguard Worker   ~TraceScopedTrackableObject() {
784*6777b538SAndroid Build Coastguard Worker     TRACE_EVENT_OBJECT_DELETED_WITH_ID(category, name_, id_);
785*6777b538SAndroid Build Coastguard Worker   }
786*6777b538SAndroid Build Coastguard Worker 
787*6777b538SAndroid Build Coastguard Worker  private:
788*6777b538SAndroid Build Coastguard Worker   const char* name_;
789*6777b538SAndroid Build Coastguard Worker   IDType id_;
790*6777b538SAndroid Build Coastguard Worker };
791*6777b538SAndroid Build Coastguard Worker 
792*6777b538SAndroid Build Coastguard Worker }  // namespace trace_event
793*6777b538SAndroid Build Coastguard Worker }  // namespace base
794*6777b538SAndroid Build Coastguard Worker 
795*6777b538SAndroid Build Coastguard Worker #endif  // BASE_TRACE_EVENT_TRACE_EVENT_H_
796