| OLD | NEW |
| 1 // Copyright (c) 2011, the Dart project authors. Please see the AUTHORS file | 1 // Copyright (c) 2011, 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 #include "vm/scavenger.h" | 5 #include "vm/scavenger.h" |
| 6 | 6 |
| 7 #include "vm/dart.h" | 7 #include "vm/dart.h" |
| 8 #include "vm/isolate.h" |
| 8 #include "vm/object.h" | 9 #include "vm/object.h" |
| 9 #include "vm/stack_frame.h" | 10 #include "vm/stack_frame.h" |
| 10 #include "vm/verifier.h" | 11 #include "vm/verifier.h" |
| 11 #include "vm/visitor.h" | 12 #include "vm/visitor.h" |
| 12 | 13 |
| 13 namespace dart { | 14 namespace dart { |
| 14 | 15 |
| 15 class ScavengerVisitor : public ObjectPointerVisitor { | 16 class ScavengerVisitor : public ObjectPointerVisitor { |
| 16 public: | 17 public: |
| 17 explicit ScavengerVisitor(Scavenger* scavenger) | 18 explicit ScavengerVisitor(Scavenger* scavenger) |
| (...skipping 140 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 158 } | 159 } |
| 159 | 160 |
| 160 | 161 |
| 161 void Scavenger::Epilogue() { | 162 void Scavenger::Epilogue() { |
| 162 #if defined(DEBUG) | 163 #if defined(DEBUG) |
| 163 memset(from_->pointer(), 0xf3, from_->size()); | 164 memset(from_->pointer(), 0xf3, from_->size()); |
| 164 #endif // defined(DEBUG) | 165 #endif // defined(DEBUG) |
| 165 } | 166 } |
| 166 | 167 |
| 167 | 168 |
| 168 void Scavenger::IterateRoots(ObjectPointerVisitor* visitor) { | 169 void Scavenger::IterateRoots(Isolate* isolate, ObjectPointerVisitor* visitor) { |
| 169 Isolate::Current()->VisitObjectPointers( | 170 isolate->VisitObjectPointers(visitor, |
| 170 visitor, StackFrameIterator::kDontValidateFrames); | 171 StackFrameIterator::kDontValidateFrames); |
| 171 heap_->IterateOldPointers(visitor); | 172 heap_->IterateOldPointers(visitor); |
| 172 } | 173 } |
| 173 | 174 |
| 174 | 175 |
| 175 void Scavenger::ProcessToSpace(ObjectPointerVisitor* visitor) { | 176 void Scavenger::ProcessToSpace(ObjectPointerVisitor* visitor) { |
| 176 uword resolved_top = FirstObjectStart(); | 177 uword resolved_top = FirstObjectStart(); |
| 177 // Iterate until all work has been drained. | 178 // Iterate until all work has been drained. |
| 178 while (resolved_top < top_) { | 179 while (resolved_top < top_) { |
| 179 RawObject* raw_obj = RawObject::FromAddr(resolved_top); | 180 RawObject* raw_obj = RawObject::FromAddr(resolved_top); |
| 180 resolved_top += raw_obj->VisitPointers(visitor); | 181 resolved_top += raw_obj->VisitPointers(visitor); |
| 181 } | 182 } |
| 182 } | 183 } |
| 183 | 184 |
| 184 | 185 |
| 185 void Scavenger::VisitObjectPointers(ObjectPointerVisitor* visitor) const { | 186 void Scavenger::VisitObjectPointers(ObjectPointerVisitor* visitor) const { |
| 186 uword cur = FirstObjectStart(); | 187 uword cur = FirstObjectStart(); |
| 187 while (cur < top_) { | 188 while (cur < top_) { |
| 188 RawObject* raw_obj = RawObject::FromAddr(cur); | 189 RawObject* raw_obj = RawObject::FromAddr(cur); |
| 189 cur += raw_obj->VisitPointers(visitor); | 190 cur += raw_obj->VisitPointers(visitor); |
| 190 } | 191 } |
| 191 } | 192 } |
| 192 | 193 |
| 193 | 194 |
| 194 void Scavenger::Scavenge() { | 195 void Scavenger::Scavenge() { |
| 195 // Scavenging is not reentrant. Make sure that is the case. | 196 // Scavenging is not reentrant. Make sure that is the case. |
| 196 ASSERT(!scavenging_); | 197 ASSERT(!scavenging_); |
| 197 scavenging_ = true; | 198 scavenging_ = true; |
| 198 NoHandleScope no_handles; | 199 Isolate* isolate = Isolate::Current(); |
| 200 NoHandleScope no_handles(isolate); |
| 199 | 201 |
| 200 Timer timer(FLAG_verbose_gc, "Scavenge"); | 202 Timer timer(FLAG_verbose_gc, "Scavenge"); |
| 201 timer.Start(); | 203 timer.Start(); |
| 202 // Setup the visitor and run a scavenge. | 204 // Setup the visitor and run a scavenge. |
| 203 ScavengerVisitor visitor(this); | 205 ScavengerVisitor visitor(this); |
| 204 Prologue(); | 206 Prologue(); |
| 205 IterateRoots(&visitor); | 207 IterateRoots(isolate, &visitor); |
| 206 ProcessToSpace(&visitor); | 208 ProcessToSpace(&visitor); |
| 207 Epilogue(); | 209 Epilogue(); |
| 208 timer.Stop(); | 210 timer.Stop(); |
| 209 if (FLAG_verbose_gc) { | 211 if (FLAG_verbose_gc) { |
| 210 OS::PrintErr("Scavenge[%d]: %dus\n", count_, timer.TotalElapsedTime()); | 212 OS::PrintErr("Scavenge[%d]: %dus\n", count_, timer.TotalElapsedTime()); |
| 211 } | 213 } |
| 212 | 214 |
| 213 count_++; | 215 count_++; |
| 214 // Done scavenging. Reset the marker. | 216 // Done scavenging. Reset the marker. |
| 215 ASSERT(scavenging_); | 217 ASSERT(scavenging_); |
| 216 scavenging_ = false; | 218 scavenging_ = false; |
| 217 } | 219 } |
| 218 | 220 |
| 219 } // namespace dart | 221 } // namespace dart |
| OLD | NEW |