Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(276)

Unified Diff: src/gpu/GrTracing.h

Issue 184443003: Add Gpu Tracing to Ganesh (Closed) Base URL: https://skia.googlesource.com/skia.git@master
Patch Set: Added files Created 6 years, 9 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
Index: src/gpu/GrTracing.h
diff --git a/src/gpu/GrTracing.h b/src/gpu/GrTracing.h
new file mode 100644
index 0000000000000000000000000000000000000000..de5bfd0414a3a77ce1ec2b530219ab46e2ebc107
--- /dev/null
+++ b/src/gpu/GrTracing.h
@@ -0,0 +1,100 @@
+/*
+ * Copyright 2014 Google Inc.
+ *
+ * Use of this source code is governed by a BSD-style license that can be
+ * found in the LICENSE file.
+ */
+
+#ifndef GrTracing_DEFINED
+#define GrTracing_DEFINED
+
+#include "SkTraceEvent.h"
+
+class GrGpuTraceMarker {
+public:
+ GrGpuTraceMarker(const char* marker, int idCounter) : fMarker(marker), fID(idCounter) {}
+
+ bool operator<(const GrGpuTraceMarker& rhs) const {
+ return this->fMarker < rhs.fMarker || (this->fMarker == rhs.fMarker && this->fID < rhs.fID);
+ }
+
+ bool operator==(const GrGpuTraceMarker& rhs) const {
+ return (this->fID == rhs.fID && this->fMarker == rhs.fMarker);
+ }
+
+ const char* fMarker;
+ int fID;
+};
+
+template<typename T>
+class SkTDArray;
+
+class GrTraceMarkerSet {
+public:
+ GrTraceMarkerSet() {}
+
+ GrTraceMarkerSet(const GrTraceMarkerSet& other);
+
+ // Adds marker to the set.
+ void add(const GrGpuTraceMarker& marker);
+ // Adds all markers from one set into this set.
+ void addSet(const GrTraceMarkerSet& markerSet);
+
+ void remove(const GrGpuTraceMarker& marker);
+
+ int count() const;
+
+ // First sorts fMarkerArray and returns a string of the format
+ // MarkerName1(#,#,...)%MarkerName2(#,#,...):... where MarkerName is the
+ // marker string used in the TraceMarker and the (#,#,..) is a list of instance
+ // id's for the the given marker string
+ SkString toString() const;
+
+ class Iter;
+
+ Iter begin() const;
+
+ Iter end() const;
+
+private:
+ mutable SkTDArray<GrGpuTraceMarker> fMarkerArray;
+};
+
+class GrDrawTarget;
+
+/**
+ * Marker generation class used for adding and removing markers around code blocks
+ */
+class GrGpuTraceMarkerGenerator : public ::SkNoncopyable {
+public:
+ GrGpuTraceMarkerGenerator(const char* marker_str, int* marker_counter, GrDrawTarget* target);
bsalomon 2014/03/20 16:32:53 I think these should be inlinable. Otherwise we ad
+ ~GrGpuTraceMarkerGenerator();
+
+private:
+ GrDrawTarget* fTarget;
+ GrGpuTraceMarker fTraceMarker;
+};
+
+////////// macros to place around the internal draw calls //////////////////
bsalomon 2014/03/20 16:32:53 Can we use the /** style comments?
+// GR_CREATE_TRACE_MARKER will place begin and end trace markers for both
+// cpu and gpu (if gpu tracing enabled) for the current scope.
+// marker is of type const char* and target is of type GrDrawTarget*
+
+#define GR_CREATE_TRACE_MARKER(marker_str, target) \
bsalomon 2014/03/20 16:32:53 If we want to do tracing in SkGpuDevice.cpp we'll
+ static const char* static_str = marker_str; \
+ static int marker_counter = 0; \
bsalomon 2014/03/20 16:32:53 I think these statics need some mangling to make s
+ GR_CREATE_GPU_TRACE_MARKER(static_str, target, marker_counter) \
+ TRACE_EVENT1(TRACE_DISABLED_BY_DEFAULT("skia.gpu"), static_str, \
+ "id", marker_counter) \
+ sk_atomic_inc(&marker_counter); \
+
+#define GR_CREATE_GPU_TRACE_MARKER(marker_str, target, marker_counter) \
+ GrGpuTraceMarkerGenerator SK_MACRO_APPEND_LINE(TMG)(static_str, \
+ &marker_counter, \
+ target); \
+
+////////////////////////////////////////////////////////////////////////////
+
+
+#endif
+

Powered by Google App Engine
This is Rietveld 408576698