OLD | NEW |
1 // Copyright 2012 the V8 project authors. All rights reserved. | 1 // Copyright 2012 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 #include "src/heap/incremental-marking.h" | 5 #include "src/heap/incremental-marking.h" |
6 | 6 |
7 #include "src/code-stubs.h" | 7 #include "src/code-stubs.h" |
8 #include "src/compilation-cache.h" | 8 #include "src/compilation-cache.h" |
9 #include "src/conversions.h" | 9 #include "src/conversions.h" |
10 #include "src/heap/concurrent-marking.h" | 10 #include "src/heap/concurrent-marking.h" |
(...skipping 533 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
544 | 544 |
545 heap_->CompletelyClearInstanceofCache(); | 545 heap_->CompletelyClearInstanceofCache(); |
546 heap_->isolate()->compilation_cache()->MarkCompactPrologue(); | 546 heap_->isolate()->compilation_cache()->MarkCompactPrologue(); |
547 | 547 |
548 // Mark strong roots grey. | 548 // Mark strong roots grey. |
549 IncrementalMarkingRootMarkingVisitor visitor(this); | 549 IncrementalMarkingRootMarkingVisitor visitor(this); |
550 heap_->IterateStrongRoots(&visitor, VISIT_ONLY_STRONG); | 550 heap_->IterateStrongRoots(&visitor, VISIT_ONLY_STRONG); |
551 | 551 |
552 if (FLAG_concurrent_marking) { | 552 if (FLAG_concurrent_marking) { |
553 ConcurrentMarking* concurrent_marking = heap_->concurrent_marking(); | 553 ConcurrentMarking* concurrent_marking = heap_->concurrent_marking(); |
554 marking_deque()->Iterate([concurrent_marking](HeapObject* obj) { | |
555 concurrent_marking->AddRoot(obj); | |
556 }); | |
557 concurrent_marking->StartTask(); | 554 concurrent_marking->StartTask(); |
558 } | 555 } |
559 | 556 |
560 // Ready to start incremental marking. | 557 // Ready to start incremental marking. |
561 if (FLAG_trace_incremental_marking) { | 558 if (FLAG_trace_incremental_marking) { |
562 heap()->isolate()->PrintWithTimestamp("[IncrementalMarking] Running\n"); | 559 heap()->isolate()->PrintWithTimestamp("[IncrementalMarking] Running\n"); |
563 } | 560 } |
564 } | 561 } |
565 | 562 |
566 void IncrementalMarking::StartBlackAllocation() { | 563 void IncrementalMarking::StartBlackAllocation() { |
(...skipping 599 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
1166 idle_marking_delay_counter_++; | 1163 idle_marking_delay_counter_++; |
1167 } | 1164 } |
1168 | 1165 |
1169 | 1166 |
1170 void IncrementalMarking::ClearIdleMarkingDelayCounter() { | 1167 void IncrementalMarking::ClearIdleMarkingDelayCounter() { |
1171 idle_marking_delay_counter_ = 0; | 1168 idle_marking_delay_counter_ = 0; |
1172 } | 1169 } |
1173 | 1170 |
1174 } // namespace internal | 1171 } // namespace internal |
1175 } // namespace v8 | 1172 } // namespace v8 |
OLD | NEW |