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

Unified Diff: base/allocator/type_profiler.h

Issue 10411047: Type profiler by intercepting 'new' and 'delete' expressions. (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: fix IsAvailable Created 8 years, 3 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: base/allocator/type_profiler.h
diff --git a/base/allocator/type_profiler.h b/base/allocator/type_profiler.h
new file mode 100644
index 0000000000000000000000000000000000000000..e76405bcd07d511ed7344a583b64888c3da07d25
--- /dev/null
+++ b/base/allocator/type_profiler.h
@@ -0,0 +1,53 @@
+// Copyright 2012 The Chromium Authors. All rights reserved.
+// Use of this source code is governed by a BSD-style license that can be
+// found in the LICENSE file.
+
+#ifndef BASE_ALLOCATOR_TYPE_PROFILER_H_
+#define BASE_ALLOCATOR_TYPE_PROFILER_H_
+
+#if defined(TYPE_PROFILING)
+
+#include <cstddef>
+#include <typeinfo>
+
+namespace base {
+namespace type_profiler {
+
+typedef void* InterceptFunction(void*, size_t, const std::type_info&);
+
+void* NopIntercept(void* ptr, size_t size, const std::type_info& type);
jar (doing other things) 2012/09/06 19:31:43 Why isn't this private to type_profiler.cc? Is it
Dai Mikurube (NOT FULLTIME) 2012/09/07 08:06:45 Removed from type_profiler.h, and moved it to anon
+
+class InterceptFunctions {
+ public:
+ // It must be called only once in a process while it is in single-thread.
+ // For now, ContentMainRunnerImpl::Initialize is the only supposed caller
+ // of this function except for single-threaded unit tests.
+ static bool SetFunctions(InterceptFunction* new_intercept,
+ InterceptFunction* delete_intercept);
+
+ private:
+ friend class TypeProfilerTest;
+
+ // This function is not thread safe. Use it only when SetInterceptFunctions()
+ // is called in a single-thread such as type_profiler_unittests.
+ static bool IsAvailable();
+};
+
+} // namespace type_profiler
+} // namespace base
+
+// These functions wrap all 'new' and 'delete' expressions.
+// They are called by a modified version of Clang checked-in
+// at deps/third_party/llvm-allocated-type.
+
+void* __op_new_intercept__(void* ptr,
jar (doing other things) 2012/09/06 19:31:43 If these are not called by any code (test code?),
Dai Mikurube (NOT FULLTIME) 2012/09/07 08:06:45 They don't look "called" lexically in source files
jar (doing other things) 2012/09/10 16:33:33 Does the compiler trigger on the *declaration* of
Dai Mikurube (NOT FULLTIME) 2012/09/11 00:57:58 *Declaration" triggers. Calling "__op*" is insert
Dai Mikurube (NOT FULLTIME) 2012/09/11 08:19:28 Finally, we could modify Clang to declare required
+ size_t size,
+ const std::type_info& type);
+
+void* __op_delete_intercept__(void* ptr,
+ size_t size,
+ const std::type_info& type);
+
+#endif // defined(TYPE_PROFILING)
+
+#endif // BASE_ALLOCATOR_TYPE_PROFILER_H_

Powered by Google App Engine
This is Rietveld 408576698