blob: 7a9ca2ee80cbe355608d28757b63de32c3f38109 [file] [log] [blame]
Brian Osman53136aa2017-07-20 15:43:35 -04001/*
2 * Copyright 2017 Google Inc.
3 *
4 * Use of this source code is governed by a BSD-style license that can be
5 * found in the LICENSE file.
6 */
7
8#include "SkEventTracingPriv.h"
9
10#include "SkATrace.h"
Brian Osman53136aa2017-07-20 15:43:35 -040011#include "SkChromeTracingTracer.h"
Brian Osman65e4c612017-07-21 11:06:24 -040012#include "SkCommandLineFlags.h"
Brian Osman53136aa2017-07-20 15:43:35 -040013#include "SkDebugfTracer.h"
Brian Osman65e4c612017-07-21 11:06:24 -040014#include "SkEventTracer.h"
Brian Osman39c08ac2017-07-26 09:36:09 -040015#include "SkTraceEvent.h"
Brian Osman53136aa2017-07-20 15:43:35 -040016
17DEFINE_string(trace, "",
18 "Log trace events in one of several modes:\n"
19 " debugf : Show events using SkDebugf\n"
20 " atrace : Send events to Android ATrace\n"
21 " <filename> : Any other string is interpreted as a filename. Writes\n"
22 " trace events to specified file as JSON, for viewing\n"
23 " with chrome://tracing");
24
Mike Klein3bf00422017-07-24 14:27:18 -040025void initializeEventTracingForTools(const char* traceFlag) {
26 if (!traceFlag) {
27 if (FLAGS_trace.isEmpty()) {
28 return;
29 }
30 traceFlag = FLAGS_trace[0];
Brian Osman53136aa2017-07-20 15:43:35 -040031 }
32
Brian Osman53136aa2017-07-20 15:43:35 -040033 SkEventTracer* eventTracer = nullptr;
34 if (0 == strcmp(traceFlag, "atrace")) {
35 eventTracer = new SkATrace();
36 } else if (0 == strcmp(traceFlag, "debugf")) {
37 eventTracer = new SkDebugfTracer();
38 } else {
Brian Osman53136aa2017-07-20 15:43:35 -040039 eventTracer = new SkChromeTracingTracer(traceFlag);
40 }
41
42 SkAssertResult(SkEventTracer::SetInstance(eventTracer));
43}
Brian Osman65e4c612017-07-21 11:06:24 -040044
Brian Osman39c08ac2017-07-26 09:36:09 -040045uint8_t* SkEventTracingCategories::getCategoryGroupEnabled(const char* name) {
46 static_assert(0 == offsetof(CategoryState, fEnabled), "CategoryState");
47
48 // We ignore the "disabled-by-default-" prefix in our internal tools
49 if (SkStrStartsWith(name, TRACE_CATEGORY_PREFIX)) {
50 name += strlen(TRACE_CATEGORY_PREFIX);
51 }
52
53 // Chrome's implementation of this API does a two-phase lookup (once without a lock, then again
54 // with a lock. But the tracing macros avoid calling these functions more than once per site,
55 // so just do something simple (and easier to reason about):
Brian Osman65e4c612017-07-21 11:06:24 -040056 SkAutoMutexAcquire lock(&fMutex);
57 for (int i = 0; i < fNumCategories; ++i) {
58 if (0 == strcmp(name, fCategories[i].fName)) {
59 return reinterpret_cast<uint8_t*>(&fCategories[i]);
60 }
61 }
62
63 if (fNumCategories >= kMaxCategories) {
64 SkDEBUGFAIL("Exhausted event tracing categories. Increase kMaxCategories.");
65 return reinterpret_cast<uint8_t*>(&fCategories[0]);
66 }
67
68 fCategories[fNumCategories].fEnabled =
69 SkEventTracer::kEnabledForRecording_CategoryGroupEnabledFlags;
70 fCategories[fNumCategories].fName = name;
71 return reinterpret_cast<uint8_t*>(&fCategories[fNumCategories++]);
72}
73
Brian Osman39c08ac2017-07-26 09:36:09 -040074const char* SkEventTracingCategories::getCategoryGroupName(const uint8_t* categoryEnabledFlag) {
Brian Osman65e4c612017-07-21 11:06:24 -040075 if (categoryEnabledFlag) {
76 return reinterpret_cast<const CategoryState*>(categoryEnabledFlag)->fName;
77 }
78 return nullptr;
79}