1cb93a386Sopenharmony_ci/* 2cb93a386Sopenharmony_ci * Copyright 2016 Google Inc. 3cb93a386Sopenharmony_ci * 4cb93a386Sopenharmony_ci * Use of this source code is governed by a BSD-style license that can be 5cb93a386Sopenharmony_ci * found in the LICENSE file. 6cb93a386Sopenharmony_ci */ 7cb93a386Sopenharmony_ci 8cb93a386Sopenharmony_ci#ifndef SkATrace_DEFINED 9cb93a386Sopenharmony_ci#define SkATrace_DEFINED 10cb93a386Sopenharmony_ci 11cb93a386Sopenharmony_ci#include "include/utils/SkEventTracer.h" 12cb93a386Sopenharmony_ci 13cb93a386Sopenharmony_ci/** 14cb93a386Sopenharmony_ci * This class is used to support ATrace in android apps. It hooks into the SkEventTracer system. It 15cb93a386Sopenharmony_ci * currently supports the macros TRACE_EVENT*, TRACE_EVENT_INSTANT*, and TRACE_EVENT_BEGIN/END*. 16cb93a386Sopenharmony_ci * For versions of these calls that take additoinal args and value pairs we currently just drop them 17cb93a386Sopenharmony_ci * and report only the name. Since ATrace is a simple push and pop system (all traces are fully 18cb93a386Sopenharmony_ci * nested), if using BEGIN and END you should also make sure your calls are properly nested (i.e. if 19cb93a386Sopenharmony_ci * startA is before startB, then endB is before endA). 20cb93a386Sopenharmony_ci */ 21cb93a386Sopenharmony_ciclass SkATrace : public SkEventTracer { 22cb93a386Sopenharmony_cipublic: 23cb93a386Sopenharmony_ci SkATrace(); 24cb93a386Sopenharmony_ci 25cb93a386Sopenharmony_ci SkEventTracer::Handle addTraceEvent(char phase, 26cb93a386Sopenharmony_ci const uint8_t* categoryEnabledFlag, 27cb93a386Sopenharmony_ci const char* name, 28cb93a386Sopenharmony_ci uint64_t id, 29cb93a386Sopenharmony_ci int numArgs, 30cb93a386Sopenharmony_ci const char** argNames, 31cb93a386Sopenharmony_ci const uint8_t* argTypes, 32cb93a386Sopenharmony_ci const uint64_t* argValues, 33cb93a386Sopenharmony_ci uint8_t flags) override; 34cb93a386Sopenharmony_ci 35cb93a386Sopenharmony_ci 36cb93a386Sopenharmony_ci void updateTraceEventDuration(const uint8_t* categoryEnabledFlag, 37cb93a386Sopenharmony_ci const char* name, 38cb93a386Sopenharmony_ci SkEventTracer::Handle handle) override; 39cb93a386Sopenharmony_ci 40cb93a386Sopenharmony_ci const uint8_t* getCategoryGroupEnabled(const char* name) override; 41cb93a386Sopenharmony_ci 42cb93a386Sopenharmony_ci const char* getCategoryGroupName(const uint8_t* categoryEnabledFlag) override { 43cb93a386Sopenharmony_ci static const char* category = "skiaATrace"; 44cb93a386Sopenharmony_ci return category; 45cb93a386Sopenharmony_ci } 46cb93a386Sopenharmony_ci 47cb93a386Sopenharmony_ciprivate: 48cb93a386Sopenharmony_ci SkATrace(const SkATrace&) = delete; 49cb93a386Sopenharmony_ci SkATrace& operator=(const SkATrace&) = delete; 50cb93a386Sopenharmony_ci 51cb93a386Sopenharmony_ci void (*fBeginSection)(const char*); 52cb93a386Sopenharmony_ci void (*fEndSection)(void); 53cb93a386Sopenharmony_ci bool (*fIsEnabled)(void); 54cb93a386Sopenharmony_ci}; 55cb93a386Sopenharmony_ci 56cb93a386Sopenharmony_ci#endif 57