skia2/tools/trace/ChromeTracingTracer.h
Mike Klein eb678fcc1f de-Sk tools/trace
Kept it on SkDebugfTracer, which seemed to parse as "SkDebugf, Tracer".

Change-Id: I3e43fe101798ca5ffe14324e3c29f2dd41a6bd0f
Reviewed-on: https://skia-review.googlesource.com/c/skia/+/202317
Commit-Queue: Mike Klein <mtklein@google.com>
Reviewed-by: Brian Osman <brianosman@google.com>
2019-03-20 18:27:27 +00:00

80 lines
2.4 KiB
C++

/*
* Copyright 2017 Google Inc.
*
* Use of this source code is governed by a BSD-style license that can be
* found in the LICENSE file.
*/
#ifndef ChromeTracingTracer_DEFINED
#define ChromeTracingTracer_DEFINED
#include "EventTracingPriv.h"
#include "SkEventTracer.h"
#include "SkSpinlock.h"
#include "SkString.h"
#include "SkTHash.h"
class SkJSONWriter;
/**
* A SkEventTracer implementation that logs events to JSON for viewing with chrome://tracing.
*/
class ChromeTracingTracer : public SkEventTracer {
public:
ChromeTracingTracer(const char* filename);
~ChromeTracingTracer() override;
SkEventTracer::Handle addTraceEvent(char phase,
const uint8_t* categoryEnabledFlag,
const char* name,
uint64_t id,
int numArgs,
const char** argNames,
const uint8_t* argTypes,
const uint64_t* argValues,
uint8_t flags) override;
void updateTraceEventDuration(const uint8_t* categoryEnabledFlag,
const char* name,
SkEventTracer::Handle handle) override;
const uint8_t* getCategoryGroupEnabled(const char* name) override {
return fCategories.getCategoryGroupEnabled(name);
}
const char* getCategoryGroupName(const uint8_t* categoryEnabledFlag) override {
return fCategories.getCategoryGroupName(categoryEnabledFlag);
}
private:
void flush();
enum {
// Events are variable size, but most commonly 48 bytes, assuming 64-bit pointers and
// reasonable packing. This is a first guess at a number that balances memory usage vs.
// time overhead of allocating blocks.
kBlockSize = 512 * 1024,
};
typedef std::unique_ptr<uint8_t[]> BlockPtr;
struct TraceEventBlock {
BlockPtr fBlock;
int fEventsInBlock;
};
void createBlock();
Handle appendEvent(const void* data, size_t size);
SkString fFilename;
SkSpinlock fMutex;
SkEventTracingCategories fCategories;
TraceEventBlock fCurBlock;
size_t fCurBlockUsed;
SkTArray<TraceEventBlock> fBlocks;
};
#endif