Chromium Code Reviews| 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 "skia_memory_dump_provider.h" | 5 #include "skia_memory_dump_provider.h" |
| 6 | 6 |
| 7 #include "base/memory/discardable_shared_memory.h" | |
| 8 #include "base/trace_event/malloc_dump_provider.h" | |
| 7 #include "base/trace_event/memory_allocator_dump.h" | 9 #include "base/trace_event/memory_allocator_dump.h" |
| 8 #include "base/trace_event/memory_dump_manager.h" | 10 #include "base/trace_event/memory_dump_manager.h" |
| 9 #include "base/trace_event/process_memory_dump.h" | 11 #include "base/trace_event/process_memory_dump.h" |
| 10 #include "third_party/skia/include/core/SkGraphics.h" | 12 #include "third_party/skia/include/core/SkGraphics.h" |
| 11 #include "third_party/skia/src/core/SkResourceCache.h" | 13 #include "third_party/skia/src/core/SkResourceCache.h" |
| 12 | 14 |
| 13 namespace skia { | 15 namespace skia { |
| 14 | 16 |
| 15 // static | 17 // static |
| 16 SkiaMemoryDumpProvider* SkiaMemoryDumpProvider::GetInstance() { | 18 SkiaMemoryDumpProvider* SkiaMemoryDumpProvider::GetInstance() { |
| 17 return Singleton<SkiaMemoryDumpProvider, | 19 return Singleton<SkiaMemoryDumpProvider, |
| 18 LeakySingletonTraits<SkiaMemoryDumpProvider>>::get(); | 20 LeakySingletonTraits<SkiaMemoryDumpProvider>>::get(); |
| 19 } | 21 } |
| 20 | 22 |
| 21 SkiaMemoryDumpProvider::SkiaMemoryDumpProvider() {} | 23 SkiaMemoryDumpProvider::SkiaMemoryDumpProvider() {} |
| 22 | 24 |
| 23 SkiaMemoryDumpProvider::~SkiaMemoryDumpProvider() {} | 25 SkiaMemoryDumpProvider::~SkiaMemoryDumpProvider() {} |
| 24 | 26 |
| 25 bool SkiaMemoryDumpProvider::OnMemoryDump( | 27 bool SkiaMemoryDumpProvider::OnMemoryDump( |
| 26 base::trace_event::ProcessMemoryDump* process_memory_dump) { | 28 base::trace_event::ProcessMemoryDump* process_memory_dump) { |
| 27 auto font_mad = | 29 auto font_mad = |
| 28 process_memory_dump->CreateAllocatorDump("skia/sk_font_cache"); | 30 process_memory_dump->CreateAllocatorDump("skia/sk_font_cache"); |
| 29 font_mad->AddScalar("size", "bytes", SkGraphics::GetFontCacheUsed()); | 31 font_mad->AddScalar(base::trace_event::MemoryAllocatorDump::kNameSize, |
| 30 font_mad->AddScalar("count", "objects", SkGraphics::GetFontCacheCountUsed()); | 32 base::trace_event::MemoryAllocatorDump::kUnitsBytes, |
| 33 SkGraphics::GetFontCacheUsed()); | |
| 34 font_mad->AddScalar(base::trace_event::MemoryAllocatorDump::kNameObjectsCount, | |
| 35 base::trace_event::MemoryAllocatorDump::kUnitsObjects, | |
| 36 SkGraphics::GetFontCacheCountUsed()); | |
| 31 | 37 |
| 38 const size_t skia_resource_cache_size = SkResourceCache::GetTotalBytesUsed(); | |
| 32 auto resource_mad = | 39 auto resource_mad = |
| 33 process_memory_dump->CreateAllocatorDump("skia/sk_resource_cache"); | 40 process_memory_dump->CreateAllocatorDump("skia/sk_resource_cache"); |
| 34 resource_mad->AddScalar("size", "bytes", | 41 resource_mad->AddScalar(base::trace_event::MemoryAllocatorDump::kNameSize, |
| 35 SkResourceCache::GetTotalBytesUsed()); | 42 base::trace_event::MemoryAllocatorDump::kUnitsBytes, |
| 36 // TODO(ssid): crbug.com/503168. Add sub-allocation edges from discardable or | 43 skia_resource_cache_size); |
| 37 // malloc memory dumps to avoid double counting. | 44 const char* source_name = |
| 38 | 45 SkResourceCache::GetDiscardableFactory() |
| 46 ? base::DiscardableSharedMemory::kAllocatedObjectsDumpName | |
|
petrcermak
2015/07/29 16:39:00
Maybe rename the constant to "kAllocatedObjects" t
ssid
2015/07/29 16:57:37
Added dumpName since This is not really a dumpProv
| |
| 47 : base::trace_event::MallocDumpProvider::kAllocatedObjects; | |
| 48 process_memory_dump->AddSuballocation(resource_mad->guid(), source_name); | |
| 39 return true; | 49 return true; |
|
petrcermak
2015/07/29 16:38:59
nit: I'd keep a blank line in front of the return
ssid
2015/07/29 16:57:37
Done.
| |
| 40 } | 50 } |
| 41 | 51 |
| 42 } // namespace skia | 52 } // namespace skia |
| OLD | NEW |