OLD | NEW |
1 // Copyright (c) 2012, the Dart project authors. Please see the AUTHORS file | 1 // Copyright (c) 2012, the Dart project authors. Please see the AUTHORS file |
2 // for details. All rights reserved. Use of this source code is governed by a | 2 // for details. All rights reserved. Use of this source code is governed by a |
3 // BSD-style license that can be found in the LICENSE file. | 3 // BSD-style license that can be found in the LICENSE file. |
4 | 4 |
5 #ifndef RUNTIME_VM_SCAVENGER_H_ | 5 #ifndef RUNTIME_VM_SCAVENGER_H_ |
6 #define RUNTIME_VM_SCAVENGER_H_ | 6 #define RUNTIME_VM_SCAVENGER_H_ |
7 | 7 |
8 #include "platform/assert.h" | 8 #include "platform/assert.h" |
9 #include "platform/utils.h" | 9 #include "platform/utils.h" |
10 #include "vm/dart.h" | 10 #include "vm/dart.h" |
(...skipping 80 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
91 | 91 |
92 // Fraction of promotion candidates that survived and was thereby promoted. | 92 // Fraction of promotion candidates that survived and was thereby promoted. |
93 // Returns zero if there were no promotion candidates. | 93 // Returns zero if there were no promotion candidates. |
94 double PromoCandidatesSuccessFraction() const { | 94 double PromoCandidatesSuccessFraction() const { |
95 return promo_candidates_in_words_ > 0 | 95 return promo_candidates_in_words_ > 0 |
96 ? promoted_in_words_ / | 96 ? promoted_in_words_ / |
97 static_cast<double>(promo_candidates_in_words_) | 97 static_cast<double>(promo_candidates_in_words_) |
98 : 0.0; | 98 : 0.0; |
99 } | 99 } |
100 | 100 |
| 101 intptr_t UsedBeforeInWords() const { return before_.used_in_words; } |
| 102 |
101 int64_t DurationMicros() const { return end_micros_ - start_micros_; } | 103 int64_t DurationMicros() const { return end_micros_ - start_micros_; } |
102 | 104 |
103 private: | 105 private: |
104 int64_t start_micros_; | 106 int64_t start_micros_; |
105 int64_t end_micros_; | 107 int64_t end_micros_; |
106 SpaceUsage before_; | 108 SpaceUsage before_; |
107 SpaceUsage after_; | 109 SpaceUsage after_; |
108 intptr_t promo_candidates_in_words_; | 110 intptr_t promo_candidates_in_words_; |
109 intptr_t promoted_in_words_; | 111 intptr_t promoted_in_words_; |
110 }; | 112 }; |
(...skipping 104 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
215 return usage; | 217 return usage; |
216 } | 218 } |
217 | 219 |
218 void VisitObjects(ObjectVisitor* visitor) const; | 220 void VisitObjects(ObjectVisitor* visitor) const; |
219 void VisitObjectPointers(ObjectPointerVisitor* visitor) const; | 221 void VisitObjectPointers(ObjectPointerVisitor* visitor) const; |
220 | 222 |
221 void AddRegionsToObjectSet(ObjectSet* set) const; | 223 void AddRegionsToObjectSet(ObjectSet* set) const; |
222 | 224 |
223 void WriteProtect(bool read_only); | 225 void WriteProtect(bool read_only); |
224 | 226 |
| 227 bool ShouldPerformIdleScavenge(int64_t deadline); |
| 228 |
225 void AddGCTime(int64_t micros) { gc_time_micros_ += micros; } | 229 void AddGCTime(int64_t micros) { gc_time_micros_ += micros; } |
226 | 230 |
227 int64_t gc_time_micros() const { return gc_time_micros_; } | 231 int64_t gc_time_micros() const { return gc_time_micros_; } |
228 | 232 |
229 void IncrementCollections() { collections_++; } | 233 void IncrementCollections() { collections_++; } |
230 | 234 |
231 intptr_t collections() const { return collections_; } | 235 intptr_t collections() const { return collections_; } |
232 | 236 |
233 #ifndef PRODUCT | 237 #ifndef PRODUCT |
234 void PrintToJSONObject(JSONObject* object) const; | 238 void PrintToJSONObject(JSONObject* object) const; |
(...skipping 89 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
324 uword object_alignment_; | 328 uword object_alignment_; |
325 | 329 |
326 // Keep track whether a scavenge is currently running. | 330 // Keep track whether a scavenge is currently running. |
327 bool scavenging_; | 331 bool scavenging_; |
328 | 332 |
329 // Keep track of pending weak properties discovered while scagenging. | 333 // Keep track of pending weak properties discovered while scagenging. |
330 RawWeakProperty* delayed_weak_properties_; | 334 RawWeakProperty* delayed_weak_properties_; |
331 | 335 |
332 int64_t gc_time_micros_; | 336 int64_t gc_time_micros_; |
333 intptr_t collections_; | 337 intptr_t collections_; |
334 static const int kStatsHistoryCapacity = 2; | 338 static const int kStatsHistoryCapacity = 4; |
335 RingBuffer<ScavengeStats, kStatsHistoryCapacity> stats_history_; | 339 RingBuffer<ScavengeStats, kStatsHistoryCapacity> stats_history_; |
336 | 340 |
| 341 intptr_t scavenge_words_per_micro_; |
| 342 intptr_t idle_scavenge_threshold_in_words_; |
| 343 |
337 // The total size of external data associated with objects in this scavenger. | 344 // The total size of external data associated with objects in this scavenger. |
338 intptr_t external_size_; | 345 intptr_t external_size_; |
339 | 346 |
340 bool failed_to_promote_; | 347 bool failed_to_promote_; |
341 | 348 |
342 // Protects new space during the allocation of new TLABs | 349 // Protects new space during the allocation of new TLABs |
343 Mutex* space_lock_; | 350 Mutex* space_lock_; |
344 friend class ScavengerVisitor; | 351 friend class ScavengerVisitor; |
345 friend class ScavengerWeakVisitor; | 352 friend class ScavengerWeakVisitor; |
346 | 353 |
347 DISALLOW_COPY_AND_ASSIGN(Scavenger); | 354 DISALLOW_COPY_AND_ASSIGN(Scavenger); |
348 }; | 355 }; |
349 | 356 |
350 } // namespace dart | 357 } // namespace dart |
351 | 358 |
352 #endif // RUNTIME_VM_SCAVENGER_H_ | 359 #endif // RUNTIME_VM_SCAVENGER_H_ |
OLD | NEW |