Index: base/allocator/allocated_type_tcmalloc.cc |
diff --git a/base/allocator/allocated_type_tcmalloc.cc b/base/allocator/allocated_type_tcmalloc.cc |
new file mode 100644 |
index 0000000000000000000000000000000000000000..0e13a2d20698df55c779f47053eda99e9d05eb49 |
--- /dev/null |
+++ b/base/allocator/allocated_type_tcmalloc.cc |
@@ -0,0 +1,39 @@ |
+// Copyright (c) 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. |
+ |
+#include "allocated_type.h" |
+#include "allocated_type_tcmalloc.h" |
+#include "base/atomicops.h" |
+#include <gperftools/allocated_type_map.h> |
+#include <gperftools/heap-profiler.h> |
+ |
+volatile Atomic32 do_not_intercept = 0; |
jar (doing other things)
2012/08/02 23:38:30
It is not clear why you are using atomics.
When d
Dai Mikurube (NOT FULLTIME)
2012/08/03 10:01:50
The reason why I use Atomic is they may be called
jar (doing other things)
2012/08/04 01:13:47
Please use a positive name, rather than a negative
jar (doing other things)
2012/08/04 01:13:47
re: atomics
If this is accessed on multiple threa
Dai Mikurube (NOT FULLTIME)
2012/08/07 10:39:18
re: atomics
Yes, it is acceptable for now.
The al
Dai Mikurube (NOT FULLTIME)
2012/08/07 10:39:18
re: name
Ok, your suggestion is so reasonable. Bu
|
+ |
+void SuspendAllocatedTypeIntercept() { |
+ base::subtle::NoBarrier_AtomicIncrement(&do_not_intercept, 1); |
jar (doing other things)
2012/08/02 23:38:30
Given the name of the function, I suspect you shou
Dai Mikurube (NOT FULLTIME)
2012/08/03 10:01:50
I agree with that ResumeAllocatedTypeIntercept bef
|
+} |
+ |
+void ResumeAllocatedTypeIntercept() { |
+ base::subtle::NoBarrier_AtomicIncrement(&do_not_intercept, -1); |
+} |
+ |
+void* __op_new_intercept__( |
+ void* ptr, size_t size, const std::type_info& type) { |
jar (doing other things)
2012/08/02 23:38:30
nit: wrap to match the indent of the paren, and pu
Dai Mikurube (NOT FULLTIME)
2012/08/03 10:01:50
Done.
|
+ if (do_not_intercept == 0) { |
jar (doing other things)
2012/08/02 23:38:30
You should not access an atomic directly. Use NoB
Dai Mikurube (NOT FULLTIME)
2012/08/03 10:01:50
Done.
|
+ if (IsHeapProfilerRunning()) { |
+ InsertAllocatedType(ptr, size, type); |
+ } |
+ } |
+ return ptr; |
+} |
+ |
+void* __op_delete_intercept__( |
+ void* ptr, size_t size, const std::type_info &type) { |
jar (doing other things)
2012/08/02 23:38:30
nit: wrap to match paren indent.
Dai Mikurube (NOT FULLTIME)
2012/08/03 10:01:50
Done.
|
+ if (do_not_intercept == 0) { |
+ if (IsHeapProfilerRunning()) { |
+ EraseAllocatedType(ptr); |
+ } |
+ } |
+ return ptr; |
+} |