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 #include "src/heap/scavenger.h" | 5 #include "src/heap/scavenger.h" |
6 | 6 |
7 #include "src/contexts.h" | 7 #include "src/contexts.h" |
8 #include "src/heap/heap.h" | 8 #include "src/heap/heap.h" |
9 #include "src/heap/objects-visiting-inl.h" | 9 #include "src/heap/objects-visiting-inl.h" |
10 #include "src/heap/scavenger-inl.h" | 10 #include "src/heap/scavenger-inl.h" |
(...skipping 277 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
288 | 288 |
289 static inline void EvacuateJSArrayBuffer(Map* map, HeapObject** slot, | 289 static inline void EvacuateJSArrayBuffer(Map* map, HeapObject** slot, |
290 HeapObject* object) { | 290 HeapObject* object) { |
291 ObjectEvacuationStrategy<POINTER_OBJECT>::Visit(map, slot, object); | 291 ObjectEvacuationStrategy<POINTER_OBJECT>::Visit(map, slot, object); |
292 | 292 |
293 Heap* heap = map->GetHeap(); | 293 Heap* heap = map->GetHeap(); |
294 MapWord map_word = object->map_word(); | 294 MapWord map_word = object->map_word(); |
295 DCHECK(map_word.IsForwardingAddress()); | 295 DCHECK(map_word.IsForwardingAddress()); |
296 HeapObject* target = map_word.ToForwardingAddress(); | 296 HeapObject* target = map_word.ToForwardingAddress(); |
297 if (!heap->InNewSpace(target)) { | 297 if (!heap->InNewSpace(target)) { |
298 heap->array_buffer_tracker()->Promote(JSArrayBuffer::cast(target)); | 298 heap->array_buffer_tracker()->Promote( |
| 299 JSArrayBuffer::cast(target), |
| 300 reinterpret_cast<JSArrayBuffer*>(object)); |
| 301 } else { |
| 302 heap->array_buffer_tracker()->SemiSpaceCopy( |
| 303 JSArrayBuffer::cast(target), |
| 304 reinterpret_cast<JSArrayBuffer*>(object)); |
299 } | 305 } |
300 } | 306 } |
301 | 307 |
302 | 308 |
303 static inline void EvacuateByteArray(Map* map, HeapObject** slot, | 309 static inline void EvacuateByteArray(Map* map, HeapObject** slot, |
304 HeapObject* object) { | 310 HeapObject* object) { |
305 int object_size = reinterpret_cast<ByteArray*>(object)->ByteArraySize(); | 311 int object_size = reinterpret_cast<ByteArray*>(object)->ByteArraySize(); |
306 EvacuateObject<DATA_OBJECT, kWordAligned>(map, slot, object, object_size); | 312 EvacuateObject<DATA_OBJECT, kWordAligned>(map, slot, object, object_size); |
307 } | 313 } |
308 | 314 |
(...skipping 156 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
465 | 471 |
466 void ScavengeVisitor::ScavengePointer(Object** p) { | 472 void ScavengeVisitor::ScavengePointer(Object** p) { |
467 Object* object = *p; | 473 Object* object = *p; |
468 if (!heap_->InNewSpace(object)) return; | 474 if (!heap_->InNewSpace(object)) return; |
469 Scavenger::ScavengeObject(reinterpret_cast<HeapObject**>(p), | 475 Scavenger::ScavengeObject(reinterpret_cast<HeapObject**>(p), |
470 reinterpret_cast<HeapObject*>(object)); | 476 reinterpret_cast<HeapObject*>(object)); |
471 } | 477 } |
472 | 478 |
473 } // namespace internal | 479 } // namespace internal |
474 } // namespace v8 | 480 } // namespace v8 |
OLD | NEW |