OLD | NEW |
1 // Copyright 2015 the V8 project authors. All rights reserved. | 1 // Copyright 2015 the V8 project 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 #ifndef V8_PROFILER_SAMPLING_HEAP_PROFILER_H_ | 5 #ifndef V8_PROFILER_SAMPLING_HEAP_PROFILER_H_ |
6 #define V8_PROFILER_SAMPLING_HEAP_PROFILER_H_ | 6 #define V8_PROFILER_SAMPLING_HEAP_PROFILER_H_ |
7 | 7 |
8 #include <deque> | 8 #include <deque> |
9 #include <map> | 9 #include <map> |
10 #include <set> | 10 #include <set> |
(...skipping 62 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
73 public: | 73 public: |
74 AllocationNode(AllocationNode* parent, const char* name, int script_id, | 74 AllocationNode(AllocationNode* parent, const char* name, int script_id, |
75 int start_position) | 75 int start_position) |
76 : parent_(parent), | 76 : parent_(parent), |
77 script_id_(script_id), | 77 script_id_(script_id), |
78 script_position_(start_position), | 78 script_position_(start_position), |
79 name_(name), | 79 name_(name), |
80 pinned_(false) {} | 80 pinned_(false) {} |
81 ~AllocationNode() { | 81 ~AllocationNode() { |
82 for (auto child : children_) { | 82 for (auto child : children_) { |
83 delete child; | 83 delete child.second; |
84 } | 84 } |
85 } | 85 } |
86 | 86 |
87 private: | 87 private: |
| 88 typedef uint64_t FunctionId; |
| 89 static FunctionId function_id(int script_id, int start_position, |
| 90 const char* name) { |
| 91 // script_id == kNoScriptId case: |
| 92 // Use function name pointer as an id. Names derived from VM state |
| 93 // must not collide with the builtin names. The least significant bit |
| 94 // of the id is set to 1. |
| 95 if (script_id == v8::UnboundScript::kNoScriptId) { |
| 96 return reinterpret_cast<intptr_t>(name) | 1; |
| 97 } |
| 98 // script_id != kNoScriptId case: |
| 99 // Use script_id, start_position pair to uniquelly identify the node. |
| 100 // The least significant bit of the id is set to 0. |
| 101 DCHECK(static_cast<unsigned>(start_position) < (1u << 31)); |
| 102 return (static_cast<uint64_t>(script_id) << 32) + (start_position << 1); |
| 103 } |
| 104 AllocationNode* FindOrAddChildNode(const char* name, int script_id, |
| 105 int start_position); |
| 106 // TODO(alph): make use of unordered_map's here. Pay attention to |
| 107 // iterator invalidation during TranslateAllocationNode. |
88 std::map<size_t, unsigned int> allocations_; | 108 std::map<size_t, unsigned int> allocations_; |
89 std::vector<AllocationNode*> children_; | 109 std::map<FunctionId, AllocationNode*> children_; |
90 AllocationNode* const parent_; | 110 AllocationNode* const parent_; |
91 const int script_id_; | 111 const int script_id_; |
92 const int script_position_; | 112 const int script_position_; |
93 const char* const name_; | 113 const char* const name_; |
94 bool pinned_; | 114 bool pinned_; |
95 | 115 |
96 friend class SamplingHeapProfiler; | 116 friend class SamplingHeapProfiler; |
97 | 117 |
98 DISALLOW_COPY_AND_ASSIGN(AllocationNode); | 118 DISALLOW_COPY_AND_ASSIGN(AllocationNode); |
99 }; | 119 }; |
(...skipping 11 matching lines...) Expand all Loading... |
111 // AllocationProfile::Node. The newly created AllocationProfile::Node is added | 131 // AllocationProfile::Node. The newly created AllocationProfile::Node is added |
112 // to the provided AllocationProfile *profile*. Line numbers, column numbers, | 132 // to the provided AllocationProfile *profile*. Line numbers, column numbers, |
113 // and script names are resolved using *scripts* which maps all currently | 133 // and script names are resolved using *scripts* which maps all currently |
114 // loaded scripts keyed by their script id. | 134 // loaded scripts keyed by their script id. |
115 v8::AllocationProfile::Node* TranslateAllocationNode( | 135 v8::AllocationProfile::Node* TranslateAllocationNode( |
116 AllocationProfile* profile, SamplingHeapProfiler::AllocationNode* node, | 136 AllocationProfile* profile, SamplingHeapProfiler::AllocationNode* node, |
117 const std::map<int, Handle<Script>>& scripts); | 137 const std::map<int, Handle<Script>>& scripts); |
118 v8::AllocationProfile::Allocation ScaleSample(size_t size, | 138 v8::AllocationProfile::Allocation ScaleSample(size_t size, |
119 unsigned int count); | 139 unsigned int count); |
120 AllocationNode* AddStack(); | 140 AllocationNode* AddStack(); |
121 AllocationNode* FindOrAddChildNode(AllocationNode* parent, const char* name, | |
122 int script_id, int start_position); | |
123 | 141 |
124 Isolate* const isolate_; | 142 Isolate* const isolate_; |
125 Heap* const heap_; | 143 Heap* const heap_; |
126 base::SmartPointer<SamplingAllocationObserver> new_space_observer_; | 144 base::SmartPointer<SamplingAllocationObserver> new_space_observer_; |
127 base::SmartPointer<SamplingAllocationObserver> other_spaces_observer_; | 145 base::SmartPointer<SamplingAllocationObserver> other_spaces_observer_; |
128 StringsStorage* const names_; | 146 StringsStorage* const names_; |
129 AllocationNode profile_root_; | 147 AllocationNode profile_root_; |
130 std::set<Sample*> samples_; | 148 std::set<Sample*> samples_; |
131 const int stack_depth_; | 149 const int stack_depth_; |
132 const uint64_t rate_; | 150 const uint64_t rate_; |
(...skipping 29 matching lines...) Expand all Loading... |
162 SamplingHeapProfiler* const profiler_; | 180 SamplingHeapProfiler* const profiler_; |
163 Heap* const heap_; | 181 Heap* const heap_; |
164 base::RandomNumberGenerator* const random_; | 182 base::RandomNumberGenerator* const random_; |
165 uint64_t const rate_; | 183 uint64_t const rate_; |
166 }; | 184 }; |
167 | 185 |
168 } // namespace internal | 186 } // namespace internal |
169 } // namespace v8 | 187 } // namespace v8 |
170 | 188 |
171 #endif // V8_PROFILER_SAMPLING_HEAP_PROFILER_H_ | 189 #endif // V8_PROFILER_SAMPLING_HEAP_PROFILER_H_ |
OLD | NEW |