1*c8dee2aaSAndroid Build Coastguard Worker /* 2*c8dee2aaSAndroid Build Coastguard Worker * Copyright 2022 Google LLC 3*c8dee2aaSAndroid Build Coastguard Worker * 4*c8dee2aaSAndroid Build Coastguard Worker * Use of this source code is governed by a BSD-style license that can be 5*c8dee2aaSAndroid Build Coastguard Worker * found in the LICENSE file. 6*c8dee2aaSAndroid Build Coastguard Worker */ 7*c8dee2aaSAndroid Build Coastguard Worker 8*c8dee2aaSAndroid Build Coastguard Worker #ifndef SkPerfettoTrace_DEFINED 9*c8dee2aaSAndroid Build Coastguard Worker #define SkPerfettoTrace_DEFINED 10*c8dee2aaSAndroid Build Coastguard Worker 11*c8dee2aaSAndroid Build Coastguard Worker #include "include/utils/SkEventTracer.h" 12*c8dee2aaSAndroid Build Coastguard Worker #include "tools/trace/EventTracingPriv.h" 13*c8dee2aaSAndroid Build Coastguard Worker #include "perfetto.h" 14*c8dee2aaSAndroid Build Coastguard Worker 15*c8dee2aaSAndroid Build Coastguard Worker PERFETTO_DEFINE_CATEGORIES(); 16*c8dee2aaSAndroid Build Coastguard Worker 17*c8dee2aaSAndroid Build Coastguard Worker /** 18*c8dee2aaSAndroid Build Coastguard Worker * This class is used to support Perfetto tracing. It hooks into the SkEventTracer system. 19*c8dee2aaSAndroid Build Coastguard Worker */ 20*c8dee2aaSAndroid Build Coastguard Worker class SkPerfettoTrace : public SkEventTracer { 21*c8dee2aaSAndroid Build Coastguard Worker public: 22*c8dee2aaSAndroid Build Coastguard Worker SkPerfettoTrace(); 23*c8dee2aaSAndroid Build Coastguard Worker ~SkPerfettoTrace() override; 24*c8dee2aaSAndroid Build Coastguard Worker 25*c8dee2aaSAndroid Build Coastguard Worker SkEventTracer::Handle addTraceEvent(char phase, 26*c8dee2aaSAndroid Build Coastguard Worker const uint8_t* categoryEnabledFlag, 27*c8dee2aaSAndroid Build Coastguard Worker const char* name, 28*c8dee2aaSAndroid Build Coastguard Worker uint64_t id, 29*c8dee2aaSAndroid Build Coastguard Worker int numArgs, 30*c8dee2aaSAndroid Build Coastguard Worker const char** argNames, 31*c8dee2aaSAndroid Build Coastguard Worker const uint8_t* argTypes, 32*c8dee2aaSAndroid Build Coastguard Worker const uint64_t* argValues, 33*c8dee2aaSAndroid Build Coastguard Worker uint8_t flags) override; 34*c8dee2aaSAndroid Build Coastguard Worker 35*c8dee2aaSAndroid Build Coastguard Worker 36*c8dee2aaSAndroid Build Coastguard Worker void updateTraceEventDuration(const uint8_t* categoryEnabledFlag, 37*c8dee2aaSAndroid Build Coastguard Worker const char* name, 38*c8dee2aaSAndroid Build Coastguard Worker SkEventTracer::Handle handle) override; 39*c8dee2aaSAndroid Build Coastguard Worker 40*c8dee2aaSAndroid Build Coastguard Worker const uint8_t* getCategoryGroupEnabled(const char* name) override; 41*c8dee2aaSAndroid Build Coastguard Worker 42*c8dee2aaSAndroid Build Coastguard Worker const char* getCategoryGroupName(const uint8_t* categoryEnabledFlag) override; 43*c8dee2aaSAndroid Build Coastguard Worker 44*c8dee2aaSAndroid Build Coastguard Worker void newTracingSection(const char* name) override; 45*c8dee2aaSAndroid Build Coastguard Worker 46*c8dee2aaSAndroid Build Coastguard Worker private: 47*c8dee2aaSAndroid Build Coastguard Worker SkPerfettoTrace(const SkPerfettoTrace&) = delete; 48*c8dee2aaSAndroid Build Coastguard Worker SkPerfettoTrace& operator=(const SkPerfettoTrace&) = delete; 49*c8dee2aaSAndroid Build Coastguard Worker SkEventTracingCategories fCategories; 50*c8dee2aaSAndroid Build Coastguard Worker std::unique_ptr<perfetto::TracingSession> tracingSession; 51*c8dee2aaSAndroid Build Coastguard Worker int fd{-1}; 52*c8dee2aaSAndroid Build Coastguard Worker 53*c8dee2aaSAndroid Build Coastguard Worker /** Store the perfetto trace file output path, name, and extension separately. This isolation 54*c8dee2aaSAndroid Build Coastguard Worker * of name components becomes useful when splitting traces up by sections, where we want to 55*c8dee2aaSAndroid Build Coastguard Worker * alter the base file name but keep the trace output path and file extension the same. 56*c8dee2aaSAndroid Build Coastguard Worker */ 57*c8dee2aaSAndroid Build Coastguard Worker std::string fOutputPath; 58*c8dee2aaSAndroid Build Coastguard Worker std::string fOutputFileExtension; 59*c8dee2aaSAndroid Build Coastguard Worker std::string fCurrentSessionFullOutputPath; 60*c8dee2aaSAndroid Build Coastguard Worker 61*c8dee2aaSAndroid Build Coastguard Worker void openNewTracingSession(const std::string& baseFileName); 62*c8dee2aaSAndroid Build Coastguard Worker void closeTracingSession(); 63*c8dee2aaSAndroid Build Coastguard Worker 64*c8dee2aaSAndroid Build Coastguard Worker /** Overloaded private methods to initiate a trace event with 0-2 arguments. Perfetto supports 65*c8dee2aaSAndroid Build Coastguard Worker * adding an arbitrary number of debug annotations or arguments, but the existing Skia trace 66*c8dee2aaSAndroid Build Coastguard Worker * structure only supports 0-2 so that is all we accommodate. 67*c8dee2aaSAndroid Build Coastguard Worker */ 68*c8dee2aaSAndroid Build Coastguard Worker void triggerTraceEvent(const uint8_t* categoryEnabledFlag, const char* eventName); 69*c8dee2aaSAndroid Build Coastguard Worker void triggerTraceEvent(const uint8_t* categoryEnabledFlag, const char* eventName, 70*c8dee2aaSAndroid Build Coastguard Worker const char* arg1Name, const uint8_t& arg1Type, const uint64_t& arg1Val); 71*c8dee2aaSAndroid Build Coastguard Worker void triggerTraceEvent(const uint8_t* categoryEnabledFlag, const char* eventName, 72*c8dee2aaSAndroid Build Coastguard Worker const char* arg1Name, const uint8_t& arg1Type, const uint64_t& arg1Val, 73*c8dee2aaSAndroid Build Coastguard Worker const char* arg2Name, const uint8_t& arg2Type, const uint64_t& arg2Val); 74*c8dee2aaSAndroid Build Coastguard Worker }; 75*c8dee2aaSAndroid Build Coastguard Worker 76*c8dee2aaSAndroid Build Coastguard Worker #endif 77