1*c8dee2aaSAndroid Build Coastguard Worker /* 2*c8dee2aaSAndroid Build Coastguard Worker * Copyright 2017 Google Inc. 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 ChromeTracingTracer_DEFINED 9*c8dee2aaSAndroid Build Coastguard Worker #define ChromeTracingTracer_DEFINED 10*c8dee2aaSAndroid Build Coastguard Worker 11*c8dee2aaSAndroid Build Coastguard Worker #include "include/core/SkString.h" 12*c8dee2aaSAndroid Build Coastguard Worker #include "include/utils/SkEventTracer.h" 13*c8dee2aaSAndroid Build Coastguard Worker #include "src/base/SkSpinlock.h" 14*c8dee2aaSAndroid Build Coastguard Worker #include "src/core/SkTHash.h" 15*c8dee2aaSAndroid Build Coastguard Worker #include "tools/trace/EventTracingPriv.h" 16*c8dee2aaSAndroid Build Coastguard Worker 17*c8dee2aaSAndroid Build Coastguard Worker class SkJSONWriter; 18*c8dee2aaSAndroid Build Coastguard Worker 19*c8dee2aaSAndroid Build Coastguard Worker /** 20*c8dee2aaSAndroid Build Coastguard Worker * A SkEventTracer implementation that logs events to JSON for viewing with chrome://tracing. 21*c8dee2aaSAndroid Build Coastguard Worker */ 22*c8dee2aaSAndroid Build Coastguard Worker class ChromeTracingTracer : public SkEventTracer { 23*c8dee2aaSAndroid Build Coastguard Worker public: 24*c8dee2aaSAndroid Build Coastguard Worker ChromeTracingTracer(const char* filename); 25*c8dee2aaSAndroid Build Coastguard Worker ~ChromeTracingTracer() override; 26*c8dee2aaSAndroid Build Coastguard Worker 27*c8dee2aaSAndroid Build Coastguard Worker SkEventTracer::Handle addTraceEvent(char phase, 28*c8dee2aaSAndroid Build Coastguard Worker const uint8_t* categoryEnabledFlag, 29*c8dee2aaSAndroid Build Coastguard Worker const char* name, 30*c8dee2aaSAndroid Build Coastguard Worker uint64_t id, 31*c8dee2aaSAndroid Build Coastguard Worker int numArgs, 32*c8dee2aaSAndroid Build Coastguard Worker const char** argNames, 33*c8dee2aaSAndroid Build Coastguard Worker const uint8_t* argTypes, 34*c8dee2aaSAndroid Build Coastguard Worker const uint64_t* argValues, 35*c8dee2aaSAndroid Build Coastguard Worker uint8_t flags) override; 36*c8dee2aaSAndroid Build Coastguard Worker 37*c8dee2aaSAndroid Build Coastguard Worker void updateTraceEventDuration(const uint8_t* categoryEnabledFlag, 38*c8dee2aaSAndroid Build Coastguard Worker const char* name, 39*c8dee2aaSAndroid Build Coastguard Worker SkEventTracer::Handle handle) override; 40*c8dee2aaSAndroid Build Coastguard Worker getCategoryGroupEnabled(const char * name)41*c8dee2aaSAndroid Build Coastguard Worker const uint8_t* getCategoryGroupEnabled(const char* name) override { 42*c8dee2aaSAndroid Build Coastguard Worker return fCategories.getCategoryGroupEnabled(name); 43*c8dee2aaSAndroid Build Coastguard Worker } 44*c8dee2aaSAndroid Build Coastguard Worker getCategoryGroupName(const uint8_t * categoryEnabledFlag)45*c8dee2aaSAndroid Build Coastguard Worker const char* getCategoryGroupName(const uint8_t* categoryEnabledFlag) override { 46*c8dee2aaSAndroid Build Coastguard Worker return fCategories.getCategoryGroupName(categoryEnabledFlag); 47*c8dee2aaSAndroid Build Coastguard Worker } 48*c8dee2aaSAndroid Build Coastguard Worker 49*c8dee2aaSAndroid Build Coastguard Worker // The Chrome tracer does not yet support splitting up trace output into sections. newTracingSection(const char * name)50*c8dee2aaSAndroid Build Coastguard Worker void newTracingSection(const char* name) override {} 51*c8dee2aaSAndroid Build Coastguard Worker 52*c8dee2aaSAndroid Build Coastguard Worker private: 53*c8dee2aaSAndroid Build Coastguard Worker void flush(); 54*c8dee2aaSAndroid Build Coastguard Worker 55*c8dee2aaSAndroid Build Coastguard Worker enum { 56*c8dee2aaSAndroid Build Coastguard Worker // Events are variable size, but most commonly 48 bytes, assuming 64-bit pointers and 57*c8dee2aaSAndroid Build Coastguard Worker // reasonable packing. This is a first guess at a number that balances memory usage vs. 58*c8dee2aaSAndroid Build Coastguard Worker // time overhead of allocating blocks. 59*c8dee2aaSAndroid Build Coastguard Worker kBlockSize = 512 * 1024, 60*c8dee2aaSAndroid Build Coastguard Worker }; 61*c8dee2aaSAndroid Build Coastguard Worker 62*c8dee2aaSAndroid Build Coastguard Worker typedef std::unique_ptr<uint8_t[]> BlockPtr; 63*c8dee2aaSAndroid Build Coastguard Worker struct TraceEventBlock { 64*c8dee2aaSAndroid Build Coastguard Worker BlockPtr fBlock; 65*c8dee2aaSAndroid Build Coastguard Worker int fEventsInBlock; 66*c8dee2aaSAndroid Build Coastguard Worker }; 67*c8dee2aaSAndroid Build Coastguard Worker 68*c8dee2aaSAndroid Build Coastguard Worker void createBlock(); 69*c8dee2aaSAndroid Build Coastguard Worker 70*c8dee2aaSAndroid Build Coastguard Worker Handle appendEvent(const void* data, size_t size); 71*c8dee2aaSAndroid Build Coastguard Worker 72*c8dee2aaSAndroid Build Coastguard Worker SkString fFilename; 73*c8dee2aaSAndroid Build Coastguard Worker SkSpinlock fMutex; 74*c8dee2aaSAndroid Build Coastguard Worker SkEventTracingCategories fCategories; 75*c8dee2aaSAndroid Build Coastguard Worker 76*c8dee2aaSAndroid Build Coastguard Worker TraceEventBlock fCurBlock; 77*c8dee2aaSAndroid Build Coastguard Worker size_t fCurBlockUsed; 78*c8dee2aaSAndroid Build Coastguard Worker 79*c8dee2aaSAndroid Build Coastguard Worker skia_private::TArray<TraceEventBlock> fBlocks; 80*c8dee2aaSAndroid Build Coastguard Worker }; 81*c8dee2aaSAndroid Build Coastguard Worker 82*c8dee2aaSAndroid Build Coastguard Worker #endif 83