OLD | NEW |
---|---|
1 /* | 1 /* |
2 * Copyright 2013 Google Inc. | 2 * Copyright 2013 Google Inc. |
3 * | 3 * |
4 * Use of this source code is governed by a BSD-style license that can be | 4 * Use of this source code is governed by a BSD-style license that can be |
5 * found in the LICENSE file. | 5 * found in the LICENSE file. |
6 */ | 6 */ |
7 | 7 |
8 #include "SkChecksum.h" | 8 #include "SkChecksum.h" |
9 #include "SkMessageBus.h" | 9 #include "SkMessageBus.h" |
10 #include "SkMipMap.h" | 10 #include "SkMipMap.h" |
(...skipping 657 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
668 SkDebugf("RC: %12s bytes %9lu discardable %p\n", | 668 SkDebugf("RC: %12s bytes %9lu discardable %p\n", |
669 rec.getCategory(), rec.bytesUsed(), rec.diagnostic_only_getDiscarda ble()); | 669 rec.getCategory(), rec.bytesUsed(), rec.diagnostic_only_getDiscarda ble()); |
670 } | 670 } |
671 | 671 |
672 void SkResourceCache::TestDumpMemoryStatistics() { | 672 void SkResourceCache::TestDumpMemoryStatistics() { |
673 VisitAll(dump_visitor, nullptr); | 673 VisitAll(dump_visitor, nullptr); |
674 } | 674 } |
675 | 675 |
676 static void sk_trace_dump_visitor(const SkResourceCache::Rec& rec, void* context ) { | 676 static void sk_trace_dump_visitor(const SkResourceCache::Rec& rec, void* context ) { |
677 SkTraceMemoryDump* dump = static_cast<SkTraceMemoryDump*>(context); | 677 SkTraceMemoryDump* dump = static_cast<SkTraceMemoryDump*>(context); |
678 SkString dump_name = SkStringPrintf("skia/sk_resource_cache/%s_%p", rec.getC ategory(), &rec); | 678 SkString dumpName = SkStringPrintf("skia/sk_resource_cache/%s_%p", rec.getCa tegory(), &rec); |
679 SkDiscardableMemory* discardable = rec.diagnostic_only_getDiscardable(); | 679 SkDiscardableMemory* discardable = rec.diagnostic_only_getDiscardable(); |
680 if (discardable) { | 680 if (discardable) { |
681 dump->setDiscardableMemoryBacking(dump_name.c_str(), *discardable); | 681 dump->setDiscardableMemoryBacking(dumpName.c_str(), *discardable); |
682 } else { | 682 } else { |
683 dump->dumpNumericValue(dump_name.c_str(), "size", "bytes", rec.bytesUsed ()); | 683 dump->dumpNumericValue(dumpName.c_str(), "size", "bytes", rec.bytesUsed( )); |
684 dump->setMemoryBacking(dump_name.c_str(), "malloc", nullptr); | 684 dump->setMemoryBacking(dumpName.c_str(), "malloc", nullptr); |
685 } | 685 } |
686 } | 686 } |
687 | 687 |
688 void SkResourceCache::DumpMemoryStatistics(SkTraceMemoryDump* dump) { | 688 void SkResourceCache::DumpMemoryStatistics(SkTraceMemoryDump* dump) { |
689 VisitAll(sk_trace_dump_visitor, dump); | 689 // Since resource could be backed by malloc or discardable, the cache always dumps detailed |
690 // stats to be accurate. | |
691 if (dump->getRequestedDetails() | SkTraceMemoryDump::kMemoryTotals | | |
692 SkTraceMemoryDump::kDiscardableDetails | SkTraceMemoryDump::kMallocD etails) { | |
Primiano Tucci (use gerrit)
2015/09/11 17:39:53
This flag check seems wrong. I think you meant her
ssid
2015/09/21 14:24:14
Fixed this to &
| |
693 VisitAll(sk_trace_dump_visitor, dump); | |
694 } | |
690 } | 695 } |
OLD | NEW |