Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(457)

Side by Side Diff: base/trace_event/memory_profiler_heap_dump_writer.cc

Issue 1419633004: [Tracing] Introduce HeapDumpWriter helper class (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: Address primiano comments Created 5 years, 1 month ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch
OLDNEW
(Empty)
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
3 // found in the LICENSE file.
4
5 #include "base/trace_event/memory_profiler_heap_dump_writer.h"
6
7 #include <numeric>
8
9 #include "base/format_macros.h"
10 #include "base/strings/stringprintf.h"
11 #include "base/trace_event/memory_profiler_allocation_register.h"
12
13 namespace base {
14 namespace trace_event {
15
16 namespace {
17
18 template <typename T>
19 bool PairSizeGt(const std::pair<T, size_t>& lhs,
20 const std::pair<T, size_t>& rhs) {
21 return lhs.second > rhs.second;
22 }
23
24 template <typename T>
25 size_t PairSizeAdd(size_t acc, const std::pair<T, size_t>& rhs) {
26 return acc + rhs.second;
27 }
28
29 } // namespace
30
31 HeapDumpWriter::HeapDumpWriter(StackFrameDeduplicator* stack_frame_deduplicator)
32 : traced_value_(new TracedValue()),
33 stack_frame_deduplicator_(stack_frame_deduplicator) {}
34
35 HeapDumpWriter::~HeapDumpWriter() {}
36
37 void HeapDumpWriter::InsertAllocation(const AllocationContext& context,
38 size_t size) {
39 bytes_by_backtrace_[context.backtrace] += size;
40 }
41
42 scoped_refptr<TracedValue> HeapDumpWriter::WriteHeapDump() {
43 // Sort the backtraces by size in descending order.
44 std::vector<std::pair<Backtrace, size_t>> sorted_by_backtrace;
45
46 std::copy(bytes_by_backtrace_.begin(), bytes_by_backtrace_.end(),
47 std::back_inserter(sorted_by_backtrace));
48 std::sort(sorted_by_backtrace.begin(), sorted_by_backtrace.end(),
49 PairSizeGt<Backtrace>);
50
51 traced_value_->BeginArray("entries");
52
53 // The global size, no column specified.
54 {
55 size_t total_size =
56 std::accumulate(sorted_by_backtrace.begin(), sorted_by_backtrace.end(),
57 size_t(0), PairSizeAdd<Backtrace>);
58 traced_value_->BeginDictionary();
59 WriteSize(total_size);
60 traced_value_->EndDictionary();
61 }
62
63 // Size per backtrace.
64 for (auto it = sorted_by_backtrace.begin();
65 it != sorted_by_backtrace.end(); it++) {
66 traced_value_->BeginDictionary();
67 // Insert a forward reference to the backtrace that will be written to the
68 // |stackFrames| dictionary later on.
69 WriteStackFrameIndex(stack_frame_deduplicator_->Insert(it->first));
70 WriteSize(it->second);
71 traced_value_->EndDictionary();
72 }
73
74 traced_value_->EndArray(); // "entries"
75
76 return traced_value_;
77 }
78
79 void HeapDumpWriter::WriteStackFrameIndex(int index) {
80 if (index == -1) {
81 // An empty backtrace (which will have index -1) is represented by the empty
82 // string, because there is no leaf frame to reference in |stackFrames|.
83 traced_value_->SetString("bt", "");
84 } else {
85 // Format index of the leaf frame as a string, because |stackFrames| is a
86 // dictionary, not an array.
87 SStringPrintf(&buffer_, "%i", index);
88 traced_value_->SetString("bt", buffer_);
89 }
90 }
91
92 void HeapDumpWriter::WriteSize(size_t size) {
93 // Format size as hexadecimal string into |buffer_|.
94 SStringPrintf(&buffer_, "%" PRIx64, static_cast<uint64_t>(size));
95 traced_value_->SetString("size", buffer_);
96 }
97
98 } // namespace trace_event
99 } // namespace base
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698