aboutsummaryrefslogtreecommitdiffhomepage
diff options
context:
space:
mode:
-rw-r--r--gn/gn_to_bp.py3
-rw-r--r--src/core/SkATrace.h30
-rw-r--r--src/gpu/gl/builders/GrGLProgramBuilder.cpp2
3 files changed, 35 insertions, 0 deletions
diff --git a/gn/gn_to_bp.py b/gn/gn_to_bp.py
index 58a8dd563c..487bdffd1e 100644
--- a/gn/gn_to_bp.py
+++ b/gn/gn_to_bp.py
@@ -33,6 +33,7 @@ tool_shared_libs = [
'libft2',
'libdng_sdk',
'libpiex',
+ 'libcutils',
]
# The ordering here is important: libsfntly needs to come after libskia.
@@ -57,6 +58,7 @@ cc_library {
"-U_FORTIFY_SOURCE",
"-D_FORTIFY_SOURCE=1",
"-DSKIA_IMPLEMENTATION=1",
+ "-DATRACE_TAG=ATRACE_TAG_VIEW",
],
export_include_dirs: [
@@ -129,6 +131,7 @@ cc_library {
"libpng",
"libvulkan",
"libz",
+ "libcutils",
],
static_libs: [
"libarect",
diff --git a/src/core/SkATrace.h b/src/core/SkATrace.h
index f870c5a57b..f2282f78c1 100644
--- a/src/core/SkATrace.h
+++ b/src/core/SkATrace.h
@@ -50,5 +50,35 @@ private:
bool (*fIsEnabled)(void);
};
+
+#ifdef SK_BUILD_FOR_ANDROID_FRAMEWORK
+
+ #include <utils/Trace.h>
+ #define ATRACE_ANDROID_FRAMEWORK(fmt, ...) SkAndroidTraceUtil __trace = \
+ (SkAndroidTraceUtil::atraceFormatBegin(fmt, ##__VA_ARGS__), SkAndroidTraceUtil())
+
+ class SkAndroidTraceUtil {
+ public:
+ ~SkAndroidTraceUtil() { ATRACE_END(); }
+
+ static void atraceFormatBegin(const char* fmt, ...) {
+ if (CC_LIKELY(!ATRACE_ENABLED())) return;
+
+ const int BUFFER_SIZE = 256;
+ va_list ap;
+ char buf[BUFFER_SIZE];
+
+ va_start(ap, fmt);
+ vsnprintf(buf, BUFFER_SIZE, fmt, ap);
+ va_end(ap);
+
+ ATRACE_BEGIN(buf);
+ }
+ };
+
+#else
+ #define ATRACE_ANDROID_FRAMEWORK(fmt, ...)
+#endif // SK_BUILD_FOR_ANDROID_FRAMEWORK
+
#endif
diff --git a/src/gpu/gl/builders/GrGLProgramBuilder.cpp b/src/gpu/gl/builders/GrGLProgramBuilder.cpp
index 4f1909eecf..9ddfa80baf 100644
--- a/src/gpu/gl/builders/GrGLProgramBuilder.cpp
+++ b/src/gpu/gl/builders/GrGLProgramBuilder.cpp
@@ -15,6 +15,7 @@
#include "GrSwizzle.h"
#include "GrTexture.h"
#include "SkAutoMalloc.h"
+#include "SkATrace.h"
#include "SkTraceEvent.h"
#include "gl/GrGLGpu.h"
#include "gl/GrGLProgram.h"
@@ -32,6 +33,7 @@ GrGLProgram* GrGLProgramBuilder::CreateProgram(const GrPipeline& pipeline,
const GrPrimitiveProcessor& primProc,
GrProgramDesc* desc,
GrGLGpu* gpu) {
+ ATRACE_ANDROID_FRAMEWORK("Shader Compile");
GrAutoLocaleSetter als("C");
// create a builder. This will be handed off to effects so they can use it to add