OLD | NEW |
1 // Copyright 2015 The Chromium Authors. All rights reserved. | 1 // Copyright 2015 The Chromium Authors. All rights reserved. |
2 // Use of this source code is governed by a BSD-style license that can be | 2 // Use of this source code is governed by a BSD-style license that can be |
3 // found in the LICENSE file. | 3 // found in the LICENSE file. |
4 | 4 |
5 #include "base/trace_event/trace_event_memory_overhead.h" | 5 #include "base/trace_event/trace_event_memory_overhead.h" |
6 | 6 |
7 #include <algorithm> | 7 #include <algorithm> |
8 | 8 |
9 #include "base/bits.h" | 9 #include "base/bits.h" |
10 #include "base/memory/ref_counted_memory.h" | 10 #include "base/memory/ref_counted_memory.h" |
(...skipping 104 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
115 | 115 |
116 void TraceEventMemoryOverhead::AddSelf() { | 116 void TraceEventMemoryOverhead::AddSelf() { |
117 size_t estimated_size = sizeof(*this); | 117 size_t estimated_size = sizeof(*this); |
118 // If the SmallMap did overflow its static capacity, its elements will be | 118 // If the SmallMap did overflow its static capacity, its elements will be |
119 // allocated on the heap and have to be accounted separately. | 119 // allocated on the heap and have to be accounted separately. |
120 if (allocated_objects_.UsingFullMap()) | 120 if (allocated_objects_.UsingFullMap()) |
121 estimated_size += sizeof(map_type::value_type) * allocated_objects_.size(); | 121 estimated_size += sizeof(map_type::value_type) * allocated_objects_.size(); |
122 Add("TraceEventMemoryOverhead", estimated_size); | 122 Add("TraceEventMemoryOverhead", estimated_size); |
123 } | 123 } |
124 | 124 |
| 125 size_t TraceEventMemoryOverhead::GetCount(const char* object_type) const { |
| 126 const auto& it = allocated_objects_.find(object_type); |
| 127 if (it == allocated_objects_.end()) |
| 128 return 0u; |
| 129 return it->second.count; |
| 130 } |
| 131 |
125 void TraceEventMemoryOverhead::Update(const TraceEventMemoryOverhead& other) { | 132 void TraceEventMemoryOverhead::Update(const TraceEventMemoryOverhead& other) { |
126 for (const auto& it : other.allocated_objects_) { | 133 for (const auto& it : other.allocated_objects_) { |
127 AddOrCreateInternal(it.first, it.second.count, | 134 AddOrCreateInternal(it.first, it.second.count, |
128 it.second.allocated_size_in_bytes, | 135 it.second.allocated_size_in_bytes, |
129 it.second.resident_size_in_bytes); | 136 it.second.resident_size_in_bytes); |
130 } | 137 } |
131 } | 138 } |
132 | 139 |
133 void TraceEventMemoryOverhead::DumpInto(const char* base_name, | 140 void TraceEventMemoryOverhead::DumpInto(const char* base_name, |
134 ProcessMemoryDump* pmd) const { | 141 ProcessMemoryDump* pmd) const { |
135 for (const auto& it : allocated_objects_) { | 142 for (const auto& it : allocated_objects_) { |
136 std::string dump_name = StringPrintf("%s/%s", base_name, it.first); | 143 std::string dump_name = StringPrintf("%s/%s", base_name, it.first); |
137 MemoryAllocatorDump* mad = pmd->CreateAllocatorDump(dump_name); | 144 MemoryAllocatorDump* mad = pmd->CreateAllocatorDump(dump_name); |
138 mad->AddScalar(MemoryAllocatorDump::kNameSize, | 145 mad->AddScalar(MemoryAllocatorDump::kNameSize, |
139 MemoryAllocatorDump::kUnitsBytes, | 146 MemoryAllocatorDump::kUnitsBytes, |
140 it.second.allocated_size_in_bytes); | 147 it.second.allocated_size_in_bytes); |
141 mad->AddScalar("resident_size", MemoryAllocatorDump::kUnitsBytes, | 148 mad->AddScalar("resident_size", MemoryAllocatorDump::kUnitsBytes, |
142 it.second.resident_size_in_bytes); | 149 it.second.resident_size_in_bytes); |
143 mad->AddScalar(MemoryAllocatorDump::kNameObjectsCount, | 150 mad->AddScalar(MemoryAllocatorDump::kNameObjectsCount, |
144 MemoryAllocatorDump::kUnitsObjects, it.second.count); | 151 MemoryAllocatorDump::kUnitsObjects, it.second.count); |
145 } | 152 } |
146 } | 153 } |
147 | 154 |
148 } // namespace trace_event | 155 } // namespace trace_event |
149 } // namespace base | 156 } // namespace base |
OLD | NEW |