| 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/dart_api_state.h" |
| 8 #include "vm/isolate.h" | 9 #include "vm/isolate.h" |
| 9 #include "vm/object.h" | 10 #include "vm/object.h" |
| 10 #include "vm/stack_frame.h" | 11 #include "vm/stack_frame.h" |
| 11 #include "vm/verifier.h" | 12 #include "vm/verifier.h" |
| 12 #include "vm/visitor.h" | 13 #include "vm/visitor.h" |
| 13 | 14 |
| 14 namespace dart { | 15 namespace dart { |
| 15 | 16 |
| 16 enum { | 17 enum { |
| 17 kForwardingMask = 3, | 18 kForwardingMask = 3, |
| (...skipping 105 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 123 } | 124 } |
| 124 | 125 |
| 125 Scavenger* scavenger_; | 126 Scavenger* scavenger_; |
| 126 Heap* heap_; | 127 Heap* heap_; |
| 127 Heap* vm_heap_; | 128 Heap* vm_heap_; |
| 128 | 129 |
| 129 DISALLOW_COPY_AND_ASSIGN(ScavengerVisitor); | 130 DISALLOW_COPY_AND_ASSIGN(ScavengerVisitor); |
| 130 }; | 131 }; |
| 131 | 132 |
| 132 | 133 |
| 133 class ScavengerWeakVisitor : public ObjectPointerVisitor { | 134 class ScavengerWeakVisitor : public HandleVisitor { |
| 134 public: | 135 public: |
| 135 explicit ScavengerWeakVisitor(Scavenger* scavenger) : scavenger_(scavenger) { | 136 explicit ScavengerWeakVisitor(Scavenger* scavenger) : scavenger_(scavenger) { |
| 136 } | 137 } |
| 137 | 138 |
| 138 void VisitPointers(RawObject** first, RawObject** last) { | 139 void VisitHandle(uword* addr) { |
| 139 for (RawObject** current = first; current <= last; current++) { | 140 WeakPersistentHandle* handle = |
| 140 RawObject* raw_obj = *current; | 141 reinterpret_cast<WeakPersistentHandle*>(addr); |
| 141 ASSERT(raw_obj->IsHeapObject()); | 142 RawObject* raw_obj = handle->raw(); |
| 142 uword raw_addr = RawObject::ToAddr(raw_obj); | 143 uword raw_addr = RawObject::ToAddr(raw_obj); |
| 143 if (scavenger_->from_->Contains(raw_addr)) { | 144 if (scavenger_->from_->Contains(raw_addr)) { |
| 144 uword header = *reinterpret_cast<uword*>(raw_addr); | 145 uword header = *reinterpret_cast<uword*>(raw_addr); |
| 145 if (IsForwarding(header)) { | 146 if (IsForwarding(header)) { |
| 146 *current = RawObject::FromAddr(ForwardedAddr(header)); | 147 handle->set_raw(RawObject::FromAddr(ForwardedAddr(header))); |
| 147 } else { | 148 } else { |
| 148 *current = Object::null(); | 149 handle->Finalize(); |
| 149 } | |
| 150 } | 150 } |
| 151 } | 151 } |
| 152 } | 152 } |
| 153 | 153 |
| 154 private: | 154 private: |
| 155 Scavenger* scavenger_; | 155 Scavenger* scavenger_; |
| 156 | 156 |
| 157 DISALLOW_COPY_AND_ASSIGN(ScavengerWeakVisitor); | 157 DISALLOW_COPY_AND_ASSIGN(ScavengerWeakVisitor); |
| 158 }; | 158 }; |
| 159 | 159 |
| (...skipping 57 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 217 // moment. | 217 // moment. |
| 218 survivor_end_ = top_; | 218 survivor_end_ = top_; |
| 219 | 219 |
| 220 #if defined(DEBUG) | 220 #if defined(DEBUG) |
| 221 memset(from_->pointer(), 0xf3, from_->size()); | 221 memset(from_->pointer(), 0xf3, from_->size()); |
| 222 #endif // defined(DEBUG) | 222 #endif // defined(DEBUG) |
| 223 } | 223 } |
| 224 | 224 |
| 225 | 225 |
| 226 void Scavenger::IterateRoots(Isolate* isolate, ObjectPointerVisitor* visitor) { | 226 void Scavenger::IterateRoots(Isolate* isolate, ObjectPointerVisitor* visitor) { |
| 227 isolate->VisitStrongObjectPointers(visitor, | 227 isolate->VisitObjectPointers(visitor, |
| 228 StackFrameIterator::kDontValidateFrames); | 228 StackFrameIterator::kDontValidateFrames); |
| 229 heap_->IterateOldPointers(visitor); | 229 heap_->IterateOldPointers(visitor); |
| 230 } | 230 } |
| 231 | 231 |
| 232 | 232 |
| 233 void Scavenger::IterateWeakRoots(Isolate* isolate, | 233 void Scavenger::IterateWeakRoots(Isolate* isolate, HandleVisitor* visitor) { |
| 234 ObjectPointerVisitor* visitor) { | 234 isolate->VisitWeakPersistentHandles(visitor); |
| 235 isolate->VisitWeakObjectPointers(visitor); | |
| 236 } | 235 } |
| 237 | 236 |
| 238 | 237 |
| 239 void Scavenger::ProcessToSpace(ObjectPointerVisitor* visitor) { | 238 void Scavenger::ProcessToSpace(ObjectPointerVisitor* visitor) { |
| 240 uword resolved_top = FirstObjectStart(); | 239 uword resolved_top = FirstObjectStart(); |
| 241 // Iterate until all work has been drained. | 240 // Iterate until all work has been drained. |
| 242 while ((resolved_top < top_) || PromotedStackHasMore()) { | 241 while ((resolved_top < top_) || PromotedStackHasMore()) { |
| 243 while (resolved_top < top_) { | 242 while (resolved_top < top_) { |
| 244 RawObject* raw_obj = RawObject::FromAddr(resolved_top); | 243 RawObject* raw_obj = RawObject::FromAddr(resolved_top); |
| 245 resolved_top += raw_obj->VisitPointers(visitor); | 244 resolved_top += raw_obj->VisitPointers(visitor); |
| (...skipping 52 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 298 OS::PrintErr(" done.\n"); | 297 OS::PrintErr(" done.\n"); |
| 299 } | 298 } |
| 300 | 299 |
| 301 count_++; | 300 count_++; |
| 302 // Done scavenging. Reset the marker. | 301 // Done scavenging. Reset the marker. |
| 303 ASSERT(scavenging_); | 302 ASSERT(scavenging_); |
| 304 scavenging_ = false; | 303 scavenging_ = false; |
| 305 } | 304 } |
| 306 | 305 |
| 307 } // namespace dart | 306 } // namespace dart |
| OLD | NEW |