1*c8dee2aaSAndroid Build Coastguard Worker /* 2*c8dee2aaSAndroid Build Coastguard Worker * Copyright (C) 2014 Google Inc. All rights reserved. 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 SkEventTracer_DEFINED 9*c8dee2aaSAndroid Build Coastguard Worker #define SkEventTracer_DEFINED 10*c8dee2aaSAndroid Build Coastguard Worker 11*c8dee2aaSAndroid Build Coastguard Worker // The class in this header defines the interface between Skia's internal 12*c8dee2aaSAndroid Build Coastguard Worker // tracing macros and an external entity (e.g., Chrome) that will consume them. 13*c8dee2aaSAndroid Build Coastguard Worker // Such an entity should subclass SkEventTracer and provide an instance of 14*c8dee2aaSAndroid Build Coastguard Worker // that event to SkEventTracer::SetInstance. 15*c8dee2aaSAndroid Build Coastguard Worker 16*c8dee2aaSAndroid Build Coastguard Worker // If you're looking for the tracing macros to instrument Skia itself, those 17*c8dee2aaSAndroid Build Coastguard Worker // live in src/core/SkTraceEvent.h 18*c8dee2aaSAndroid Build Coastguard Worker 19*c8dee2aaSAndroid Build Coastguard Worker #include "include/core/SkTypes.h" 20*c8dee2aaSAndroid Build Coastguard Worker 21*c8dee2aaSAndroid Build Coastguard Worker #include <cstdint> 22*c8dee2aaSAndroid Build Coastguard Worker 23*c8dee2aaSAndroid Build Coastguard Worker class SK_API SkEventTracer { 24*c8dee2aaSAndroid Build Coastguard Worker public: 25*c8dee2aaSAndroid Build Coastguard Worker 26*c8dee2aaSAndroid Build Coastguard Worker typedef uint64_t Handle; 27*c8dee2aaSAndroid Build Coastguard Worker 28*c8dee2aaSAndroid Build Coastguard Worker /** 29*c8dee2aaSAndroid Build Coastguard Worker * If this is the first call to SetInstance or GetInstance then the passed instance is 30*c8dee2aaSAndroid Build Coastguard Worker * installed and true is returned. Otherwise, false is returned. In either case ownership of the 31*c8dee2aaSAndroid Build Coastguard Worker * tracer is transferred and it will be deleted when no longer needed. 32*c8dee2aaSAndroid Build Coastguard Worker * 33*c8dee2aaSAndroid Build Coastguard Worker * Not deleting the tracer on process exit should not cause problems as 34*c8dee2aaSAndroid Build Coastguard Worker * the whole heap is about to go away with the process. This can also 35*c8dee2aaSAndroid Build Coastguard Worker * improve performance by reducing the amount of work needed. 36*c8dee2aaSAndroid Build Coastguard Worker * 37*c8dee2aaSAndroid Build Coastguard Worker * @param leakTracer Do not delete tracer on process exit. 38*c8dee2aaSAndroid Build Coastguard Worker */ 39*c8dee2aaSAndroid Build Coastguard Worker static bool SetInstance(SkEventTracer*, bool leakTracer = false); 40*c8dee2aaSAndroid Build Coastguard Worker 41*c8dee2aaSAndroid Build Coastguard Worker /** 42*c8dee2aaSAndroid Build Coastguard Worker * Gets the event tracer. If this is the first call to SetInstance or GetIntance then a default 43*c8dee2aaSAndroid Build Coastguard Worker * event tracer is installed and returned. 44*c8dee2aaSAndroid Build Coastguard Worker */ 45*c8dee2aaSAndroid Build Coastguard Worker static SkEventTracer* GetInstance(); 46*c8dee2aaSAndroid Build Coastguard Worker 47*c8dee2aaSAndroid Build Coastguard Worker virtual ~SkEventTracer() = default; 48*c8dee2aaSAndroid Build Coastguard Worker 49*c8dee2aaSAndroid Build Coastguard Worker // The pointer returned from GetCategoryGroupEnabled() points to a 50*c8dee2aaSAndroid Build Coastguard Worker // value with zero or more of the following bits. Used in this class only. 51*c8dee2aaSAndroid Build Coastguard Worker // The TRACE_EVENT macros should only use the value as a bool. 52*c8dee2aaSAndroid Build Coastguard Worker // These values must be in sync with macro values in trace_event.h in chromium. 53*c8dee2aaSAndroid Build Coastguard Worker enum CategoryGroupEnabledFlags { 54*c8dee2aaSAndroid Build Coastguard Worker // Category group enabled for the recording mode. 55*c8dee2aaSAndroid Build Coastguard Worker kEnabledForRecording_CategoryGroupEnabledFlags = 1 << 0, 56*c8dee2aaSAndroid Build Coastguard Worker // Category group enabled for the monitoring mode. 57*c8dee2aaSAndroid Build Coastguard Worker kEnabledForMonitoring_CategoryGroupEnabledFlags = 1 << 1, 58*c8dee2aaSAndroid Build Coastguard Worker // Category group enabled by SetEventCallbackEnabled(). 59*c8dee2aaSAndroid Build Coastguard Worker kEnabledForEventCallback_CategoryGroupEnabledFlags = 1 << 2, 60*c8dee2aaSAndroid Build Coastguard Worker }; 61*c8dee2aaSAndroid Build Coastguard Worker 62*c8dee2aaSAndroid Build Coastguard Worker virtual const uint8_t* getCategoryGroupEnabled(const char* name) = 0; 63*c8dee2aaSAndroid Build Coastguard Worker virtual const char* getCategoryGroupName(const uint8_t* categoryEnabledFlag) = 0; 64*c8dee2aaSAndroid Build Coastguard Worker 65*c8dee2aaSAndroid Build Coastguard Worker virtual SkEventTracer::Handle 66*c8dee2aaSAndroid Build Coastguard Worker addTraceEvent(char phase, 67*c8dee2aaSAndroid Build Coastguard Worker const uint8_t* categoryEnabledFlag, 68*c8dee2aaSAndroid Build Coastguard Worker const char* name, 69*c8dee2aaSAndroid Build Coastguard Worker uint64_t id, 70*c8dee2aaSAndroid Build Coastguard Worker int32_t numArgs, 71*c8dee2aaSAndroid Build Coastguard Worker const char** argNames, 72*c8dee2aaSAndroid Build Coastguard Worker const uint8_t* argTypes, 73*c8dee2aaSAndroid Build Coastguard Worker const uint64_t* argValues, 74*c8dee2aaSAndroid Build Coastguard Worker uint8_t flags) = 0; 75*c8dee2aaSAndroid Build Coastguard Worker 76*c8dee2aaSAndroid Build Coastguard Worker virtual void 77*c8dee2aaSAndroid Build Coastguard Worker updateTraceEventDuration(const uint8_t* categoryEnabledFlag, 78*c8dee2aaSAndroid Build Coastguard Worker const char* name, 79*c8dee2aaSAndroid Build Coastguard Worker SkEventTracer::Handle handle) = 0; 80*c8dee2aaSAndroid Build Coastguard Worker 81*c8dee2aaSAndroid Build Coastguard Worker // Optional method that can be implemented to allow splitting up traces into different sections. newTracingSection(const char *)82*c8dee2aaSAndroid Build Coastguard Worker virtual void newTracingSection(const char*) {} 83*c8dee2aaSAndroid Build Coastguard Worker 84*c8dee2aaSAndroid Build Coastguard Worker protected: 85*c8dee2aaSAndroid Build Coastguard Worker SkEventTracer() = default; 86*c8dee2aaSAndroid Build Coastguard Worker SkEventTracer(const SkEventTracer&) = delete; 87*c8dee2aaSAndroid Build Coastguard Worker SkEventTracer& operator=(const SkEventTracer&) = delete; 88*c8dee2aaSAndroid Build Coastguard Worker }; 89*c8dee2aaSAndroid Build Coastguard Worker 90*c8dee2aaSAndroid Build Coastguard Worker #endif // SkEventTracer_DEFINED 91