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/strings/stringprintf.h" | |
| 7 #include "base/trace_event/memory_allocator_dump.h" | 8 #include "base/trace_event/memory_allocator_dump.h" |
| 8 #include "base/trace_event/memory_dump_manager.h" | 9 #include "base/trace_event/memory_dump_manager.h" |
| 9 #include "base/trace_event/process_memory_dump.h" | 10 #include "base/trace_event/process_memory_dump.h" |
| 10 #include "third_party/skia/include/core/SkGraphics.h" | 11 #include "third_party/skia/include/core/SkGraphics.h" |
| 12 #include "third_party/skia/include/core/SkGlyphCacheStats.h" | |
|
petrcermak
2015/07/28 19:40:29
nit: I think this should come before the include o
ssid
2015/07/28 20:19:11
I would expect upload to give me error. Fixed it,
| |
| 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 |
| 17 namespace { | |
| 18 | |
| 19 const char kFontCacheDumpName[] = "skia/sk_font_cache"; | |
| 20 | |
| 21 class SkiaGlyphCacheDumper : public SkGlyphCacheStatsDumper { | |
| 22 public: | |
| 23 SkiaGlyphCacheDumper( | |
| 24 base::trace_event::ProcessMemoryDump* process_memory_dump); | |
| 25 | |
| 26 // SkGlyphCacheStatsDumper implementation: | |
| 27 void DumpStats(const char* uniqueName, const size_t memoryUsed) override; | |
| 28 | |
| 29 private: | |
| 30 base::trace_event::ProcessMemoryDump* process_memory_dump_; | |
| 31 }; | |
| 32 | |
| 33 SkiaGlyphCacheDumper::SkiaGlyphCacheDumper( | |
| 34 base::trace_event::ProcessMemoryDump* process_memory_dump) | |
| 35 : process_memory_dump_(process_memory_dump) {} | |
| 36 | |
| 37 void SkiaGlyphCacheDumper::DumpStats(const char* uniqueName, | |
| 38 const size_t memoryUsed) { | |
| 39 auto cache_mad = process_memory_dump_->CreateAllocatorDump( | |
| 40 base::StringPrintf("%s/%s", kFontCacheDumpName, uniqueName)); | |
| 41 | |
| 42 cache_mad->AddScalar(base::trace_event::MemoryAllocatorDump::kNameSize, | |
|
petrcermak
2015/07/28 19:40:29
nit: I'd find this more readable if both calls had
ssid
2015/07/28 20:19:11
Hm, it was git cl format. I don't want to touch th
| |
| 43 base::trace_event::MemoryAllocatorDump::kUnitsBytes, | |
| 44 memoryUsed); | |
| 45 cache_mad->AddScalar( | |
| 46 base::trace_event::MemoryAllocatorDump::kNameObjectsCount, | |
| 47 base::trace_event::MemoryAllocatorDump::kUnitsObjects, 1u); | |
| 48 } | |
| 49 | |
| 50 } // namespace | |
| 51 | |
| 15 // static | 52 // static |
| 16 SkiaMemoryDumpProvider* SkiaMemoryDumpProvider::GetInstance() { | 53 SkiaMemoryDumpProvider* SkiaMemoryDumpProvider::GetInstance() { |
| 17 return Singleton<SkiaMemoryDumpProvider, | 54 return Singleton<SkiaMemoryDumpProvider, |
| 18 LeakySingletonTraits<SkiaMemoryDumpProvider>>::get(); | 55 LeakySingletonTraits<SkiaMemoryDumpProvider>>::get(); |
| 19 } | 56 } |
| 20 | 57 |
| 21 SkiaMemoryDumpProvider::SkiaMemoryDumpProvider() {} | 58 SkiaMemoryDumpProvider::SkiaMemoryDumpProvider() {} |
| 22 | 59 |
| 23 SkiaMemoryDumpProvider::~SkiaMemoryDumpProvider() {} | 60 SkiaMemoryDumpProvider::~SkiaMemoryDumpProvider() {} |
| 24 | 61 |
| 25 bool SkiaMemoryDumpProvider::OnMemoryDump( | 62 bool SkiaMemoryDumpProvider::OnMemoryDump( |
| 26 base::trace_event::ProcessMemoryDump* process_memory_dump) { | 63 base::trace_event::ProcessMemoryDump* process_memory_dump) { |
| 27 auto font_mad = | 64 auto font_mad = process_memory_dump->CreateAllocatorDump(kFontCacheDumpName); |
| 28 process_memory_dump->CreateAllocatorDump("skia/sk_font_cache"); | 65 font_mad->AddScalar(base::trace_event::MemoryAllocatorDump::kNameSize, |
| 29 font_mad->AddScalar("size", "bytes", SkGraphics::GetFontCacheUsed()); | 66 base::trace_event::MemoryAllocatorDump::kUnitsBytes, |
| 30 font_mad->AddScalar("count", "objects", SkGraphics::GetFontCacheCountUsed()); | 67 SkGraphics::GetFontCacheUsed()); |
| 68 font_mad->AddScalar(base::trace_event::MemoryAllocatorDump::kNameObjectsCount, | |
| 69 base::trace_event::MemoryAllocatorDump::kUnitsObjects, | |
| 70 SkGraphics::GetFontCacheCountUsed()); | |
| 71 | |
| 72 SkiaGlyphCacheDumper dumper(process_memory_dump); | |
| 73 DumpSkGlyphCacheStats(&dumper); | |
| 31 | 74 |
| 32 auto resource_mad = | 75 auto resource_mad = |
| 33 process_memory_dump->CreateAllocatorDump("skia/sk_resource_cache"); | 76 process_memory_dump->CreateAllocatorDump("skia/sk_resource_cache"); |
|
petrcermak
2015/07/28 19:40:29
nit: I'd factor this dump name out into a constant
ssid
2015/07/28 20:19:11
Done.
| |
| 34 resource_mad->AddScalar("size", "bytes", | 77 resource_mad->AddScalar(base::trace_event::MemoryAllocatorDump::kNameSize, |
| 78 base::trace_event::MemoryAllocatorDump::kUnitsBytes, | |
| 35 SkResourceCache::GetTotalBytesUsed()); | 79 SkResourceCache::GetTotalBytesUsed()); |
| 36 // TODO(ssid): crbug.com/503168. Add sub-allocation edges from discardable or | 80 // TODO(ssid): crbug.com/503168. Add sub-allocation edges from discardable or |
| 37 // malloc memory dumps to avoid double counting. | 81 // malloc memory dumps to avoid double counting. |
| 38 | 82 |
| 39 return true; | 83 return true; |
| 40 } | 84 } |
| 41 | 85 |
| 42 } // namespace skia | 86 } // namespace skia |
| OLD | NEW |