xref: /aosp_15_r20/external/mesa3d/src/util/perf/u_perfetto.cc (revision 6104692788411f58d303aa86923a9ff6ecaded22)
1*61046927SAndroid Build Coastguard Worker /*
2*61046927SAndroid Build Coastguard Worker  * Copyright © 2021 Google, Inc.
3*61046927SAndroid Build Coastguard Worker  *
4*61046927SAndroid Build Coastguard Worker  * Permission is hereby granted, free of charge, to any person obtaining a
5*61046927SAndroid Build Coastguard Worker  * copy of this software and associated documentation files (the "Software"),
6*61046927SAndroid Build Coastguard Worker  * to deal in the Software without restriction, including without limitation
7*61046927SAndroid Build Coastguard Worker  * the rights to use, copy, modify, merge, publish, distribute, sublicense,
8*61046927SAndroid Build Coastguard Worker  * and/or sell copies of the Software, and to permit persons to whom the
9*61046927SAndroid Build Coastguard Worker  * Software is furnished to do so, subject to the following conditions:
10*61046927SAndroid Build Coastguard Worker  *
11*61046927SAndroid Build Coastguard Worker  * The above copyright notice and this permission notice (including the next
12*61046927SAndroid Build Coastguard Worker  * paragraph) shall be included in all copies or substantial portions of the
13*61046927SAndroid Build Coastguard Worker  * Software.
14*61046927SAndroid Build Coastguard Worker  *
15*61046927SAndroid Build Coastguard Worker  * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
16*61046927SAndroid Build Coastguard Worker  * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
17*61046927SAndroid Build Coastguard Worker  * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.  IN NO EVENT SHALL
18*61046927SAndroid Build Coastguard Worker  * THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
19*61046927SAndroid Build Coastguard Worker  * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
20*61046927SAndroid Build Coastguard Worker  * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
21*61046927SAndroid Build Coastguard Worker  * SOFTWARE.
22*61046927SAndroid Build Coastguard Worker  */
23*61046927SAndroid Build Coastguard Worker 
24*61046927SAndroid Build Coastguard Worker #include "u_perfetto.h"
25*61046927SAndroid Build Coastguard Worker 
26*61046927SAndroid Build Coastguard Worker #include <perfetto.h>
27*61046927SAndroid Build Coastguard Worker 
28*61046927SAndroid Build Coastguard Worker #include "c11/threads.h"
29*61046927SAndroid Build Coastguard Worker #include "util/macros.h"
30*61046927SAndroid Build Coastguard Worker 
31*61046927SAndroid Build Coastguard Worker /* perfetto requires string literals */
32*61046927SAndroid Build Coastguard Worker #define UTIL_PERFETTO_CATEGORY_DEFAULT_STR "mesa.default"
33*61046927SAndroid Build Coastguard Worker 
34*61046927SAndroid Build Coastguard Worker PERFETTO_DEFINE_CATEGORIES(
35*61046927SAndroid Build Coastguard Worker    perfetto::Category(UTIL_PERFETTO_CATEGORY_DEFAULT_STR)
36*61046927SAndroid Build Coastguard Worker       .SetDescription("Mesa default events"));
37*61046927SAndroid Build Coastguard Worker 
38*61046927SAndroid Build Coastguard Worker PERFETTO_TRACK_EVENT_STATIC_STORAGE();
39*61046927SAndroid Build Coastguard Worker 
40*61046927SAndroid Build Coastguard Worker int util_perfetto_tracing_state;
41*61046927SAndroid Build Coastguard Worker 
42*61046927SAndroid Build Coastguard Worker static uint64_t util_perfetto_unique_id = 1;
43*61046927SAndroid Build Coastguard Worker 
44*61046927SAndroid Build Coastguard Worker static void
util_perfetto_update_tracing_state(void)45*61046927SAndroid Build Coastguard Worker util_perfetto_update_tracing_state(void)
46*61046927SAndroid Build Coastguard Worker {
47*61046927SAndroid Build Coastguard Worker    p_atomic_set(&util_perfetto_tracing_state,
48*61046927SAndroid Build Coastguard Worker                 TRACE_EVENT_CATEGORY_ENABLED(UTIL_PERFETTO_CATEGORY_DEFAULT_STR));
49*61046927SAndroid Build Coastguard Worker }
50*61046927SAndroid Build Coastguard Worker 
51*61046927SAndroid Build Coastguard Worker void
util_perfetto_trace_begin(const char * name)52*61046927SAndroid Build Coastguard Worker util_perfetto_trace_begin(const char *name)
53*61046927SAndroid Build Coastguard Worker {
54*61046927SAndroid Build Coastguard Worker    TRACE_EVENT_BEGIN(
55*61046927SAndroid Build Coastguard Worker       UTIL_PERFETTO_CATEGORY_DEFAULT_STR, nullptr,
56*61046927SAndroid Build Coastguard Worker       [&](perfetto::EventContext ctx) { ctx.event()->set_name(name); });
57*61046927SAndroid Build Coastguard Worker }
58*61046927SAndroid Build Coastguard Worker 
59*61046927SAndroid Build Coastguard Worker void
util_perfetto_trace_end(void)60*61046927SAndroid Build Coastguard Worker util_perfetto_trace_end(void)
61*61046927SAndroid Build Coastguard Worker {
62*61046927SAndroid Build Coastguard Worker    TRACE_EVENT_END(UTIL_PERFETTO_CATEGORY_DEFAULT_STR);
63*61046927SAndroid Build Coastguard Worker 
64*61046927SAndroid Build Coastguard Worker    util_perfetto_update_tracing_state();
65*61046927SAndroid Build Coastguard Worker }
66*61046927SAndroid Build Coastguard Worker 
67*61046927SAndroid Build Coastguard Worker void
util_perfetto_trace_begin_flow(const char * fname,uint64_t id)68*61046927SAndroid Build Coastguard Worker util_perfetto_trace_begin_flow(const char *fname, uint64_t id)
69*61046927SAndroid Build Coastguard Worker {
70*61046927SAndroid Build Coastguard Worker    TRACE_EVENT_BEGIN(
71*61046927SAndroid Build Coastguard Worker       UTIL_PERFETTO_CATEGORY_DEFAULT_STR, nullptr, perfetto::Flow::ProcessScoped(id),
72*61046927SAndroid Build Coastguard Worker       [&](perfetto::EventContext ctx) { ctx.event()->set_name(fname); });
73*61046927SAndroid Build Coastguard Worker }
74*61046927SAndroid Build Coastguard Worker 
75*61046927SAndroid Build Coastguard Worker void
util_perfetto_trace_full_begin(const char * fname,uint64_t track_id,uint64_t id,uint64_t timestamp)76*61046927SAndroid Build Coastguard Worker util_perfetto_trace_full_begin(const char *fname, uint64_t track_id, uint64_t id, uint64_t timestamp)
77*61046927SAndroid Build Coastguard Worker {
78*61046927SAndroid Build Coastguard Worker    TRACE_EVENT_BEGIN(
79*61046927SAndroid Build Coastguard Worker       UTIL_PERFETTO_CATEGORY_DEFAULT_STR, nullptr, perfetto::Track(track_id),
80*61046927SAndroid Build Coastguard Worker       timestamp, perfetto::Flow::ProcessScoped(id),
81*61046927SAndroid Build Coastguard Worker       [&](perfetto::EventContext ctx) { ctx.event()->set_name(fname); });
82*61046927SAndroid Build Coastguard Worker }
83*61046927SAndroid Build Coastguard Worker 
84*61046927SAndroid Build Coastguard Worker uint64_t
util_perfetto_new_track(const char * name)85*61046927SAndroid Build Coastguard Worker util_perfetto_new_track(const char *name)
86*61046927SAndroid Build Coastguard Worker {
87*61046927SAndroid Build Coastguard Worker    uint64_t track_id = util_perfetto_next_id();
88*61046927SAndroid Build Coastguard Worker    auto track = perfetto::Track(track_id);
89*61046927SAndroid Build Coastguard Worker    auto desc = track.Serialize();
90*61046927SAndroid Build Coastguard Worker    desc.set_name(name);
91*61046927SAndroid Build Coastguard Worker    perfetto::TrackEvent::SetTrackDescriptor(track, desc);
92*61046927SAndroid Build Coastguard Worker    return track_id;
93*61046927SAndroid Build Coastguard Worker }
94*61046927SAndroid Build Coastguard Worker 
95*61046927SAndroid Build Coastguard Worker void
util_perfetto_trace_full_end(const char * name,uint64_t track_id,uint64_t timestamp)96*61046927SAndroid Build Coastguard Worker util_perfetto_trace_full_end(const char *name, uint64_t track_id, uint64_t timestamp)
97*61046927SAndroid Build Coastguard Worker {
98*61046927SAndroid Build Coastguard Worker    TRACE_EVENT_END(UTIL_PERFETTO_CATEGORY_DEFAULT_STR, perfetto::Track(track_id), timestamp);
99*61046927SAndroid Build Coastguard Worker 
100*61046927SAndroid Build Coastguard Worker    util_perfetto_update_tracing_state();
101*61046927SAndroid Build Coastguard Worker }
102*61046927SAndroid Build Coastguard Worker 
103*61046927SAndroid Build Coastguard Worker void
util_perfetto_counter_set(const char * name,double value)104*61046927SAndroid Build Coastguard Worker util_perfetto_counter_set(const char *name, double value)
105*61046927SAndroid Build Coastguard Worker {
106*61046927SAndroid Build Coastguard Worker    TRACE_COUNTER(UTIL_PERFETTO_CATEGORY_DEFAULT_STR,
107*61046927SAndroid Build Coastguard Worker                  perfetto::DynamicString(name), value);
108*61046927SAndroid Build Coastguard Worker }
109*61046927SAndroid Build Coastguard Worker 
110*61046927SAndroid Build Coastguard Worker uint64_t
util_perfetto_next_id(void)111*61046927SAndroid Build Coastguard Worker util_perfetto_next_id(void)
112*61046927SAndroid Build Coastguard Worker {
113*61046927SAndroid Build Coastguard Worker    return p_atomic_inc_return(&util_perfetto_unique_id);
114*61046927SAndroid Build Coastguard Worker }
115*61046927SAndroid Build Coastguard Worker 
116*61046927SAndroid Build Coastguard Worker class UtilPerfettoObserver : public perfetto::TrackEventSessionObserver {
117*61046927SAndroid Build Coastguard Worker  public:
UtilPerfettoObserver()118*61046927SAndroid Build Coastguard Worker    UtilPerfettoObserver() { perfetto::TrackEvent::AddSessionObserver(this); }
119*61046927SAndroid Build Coastguard Worker 
OnStart(const perfetto::DataSourceBase::StartArgs &)120*61046927SAndroid Build Coastguard Worker    void OnStart(const perfetto::DataSourceBase::StartArgs &) override
121*61046927SAndroid Build Coastguard Worker    {
122*61046927SAndroid Build Coastguard Worker       util_perfetto_update_tracing_state();
123*61046927SAndroid Build Coastguard Worker    }
124*61046927SAndroid Build Coastguard Worker 
125*61046927SAndroid Build Coastguard Worker    /* XXX There is no PostStop callback.  We have to call
126*61046927SAndroid Build Coastguard Worker     * util_perfetto_update_tracing_state occasionally to poll.
127*61046927SAndroid Build Coastguard Worker     */
128*61046927SAndroid Build Coastguard Worker };
129*61046927SAndroid Build Coastguard Worker 
130*61046927SAndroid Build Coastguard Worker static void
util_perfetto_fini(void)131*61046927SAndroid Build Coastguard Worker util_perfetto_fini(void)
132*61046927SAndroid Build Coastguard Worker {
133*61046927SAndroid Build Coastguard Worker    perfetto::Tracing::Shutdown();
134*61046927SAndroid Build Coastguard Worker }
135*61046927SAndroid Build Coastguard Worker 
136*61046927SAndroid Build Coastguard Worker static void
util_perfetto_init_once(void)137*61046927SAndroid Build Coastguard Worker util_perfetto_init_once(void)
138*61046927SAndroid Build Coastguard Worker {
139*61046927SAndroid Build Coastguard Worker    // Connects to the system tracing service
140*61046927SAndroid Build Coastguard Worker    perfetto::TracingInitArgs args;
141*61046927SAndroid Build Coastguard Worker    args.backends = perfetto::kSystemBackend;
142*61046927SAndroid Build Coastguard Worker    perfetto::Tracing::Initialize(args);
143*61046927SAndroid Build Coastguard Worker 
144*61046927SAndroid Build Coastguard Worker    static UtilPerfettoObserver observer;
145*61046927SAndroid Build Coastguard Worker    perfetto::TrackEvent::Register();
146*61046927SAndroid Build Coastguard Worker 
147*61046927SAndroid Build Coastguard Worker    atexit(&util_perfetto_fini);
148*61046927SAndroid Build Coastguard Worker }
149*61046927SAndroid Build Coastguard Worker 
150*61046927SAndroid Build Coastguard Worker static once_flag perfetto_once_flag = ONCE_FLAG_INIT;
151*61046927SAndroid Build Coastguard Worker 
152*61046927SAndroid Build Coastguard Worker void
util_perfetto_init(void)153*61046927SAndroid Build Coastguard Worker util_perfetto_init(void)
154*61046927SAndroid Build Coastguard Worker {
155*61046927SAndroid Build Coastguard Worker    call_once(&perfetto_once_flag, util_perfetto_init_once);
156*61046927SAndroid Build Coastguard Worker }
157