Commit 23bf71d7 authored by hpayer's avatar hpayer Committed by Commit bot

Use proper write barriers instead of RecordWrites when copying object elements.

This CL brings us one step closer to untangle the runtime-gc dependency, i.e. RecordWrites should not be called from the runtime.

BUG=

Review URL: https://codereview.chromium.org/1456533002

Cr-Commit-Position: refs/heads/master@{#32074}
parent 30d6a4de
...@@ -136,20 +136,14 @@ void CopyObjectToObjectElements(FixedArrayBase* from_base, ...@@ -136,20 +136,14 @@ void CopyObjectToObjectElements(FixedArrayBase* from_base,
FixedArray* to = FixedArray::cast(to_base); FixedArray* to = FixedArray::cast(to_base);
DCHECK(IsFastSmiOrObjectElementsKind(from_kind)); DCHECK(IsFastSmiOrObjectElementsKind(from_kind));
DCHECK(IsFastSmiOrObjectElementsKind(to_kind)); DCHECK(IsFastSmiOrObjectElementsKind(to_kind));
Address to_address = to->address() + FixedArray::kHeaderSize;
Address from_address = from->address() + FixedArray::kHeaderSize; WriteBarrierMode write_barrier_mode =
CopyWords(reinterpret_cast<Object**>(to_address) + to_start, (IsFastObjectElementsKind(from_kind) && IsFastObjectElementsKind(to_kind))
reinterpret_cast<Object**>(from_address) + from_start, ? UPDATE_WRITE_BARRIER
static_cast<size_t>(copy_size)); : SKIP_WRITE_BARRIER;
if (IsFastObjectElementsKind(from_kind) && for (int i = 0; i < copy_size; i++) {
IsFastObjectElementsKind(to_kind)) { Object* value = from->get(from_start + i);
Heap* heap = from->GetHeap(); to->set(to_start + i, value, write_barrier_mode);
if (!heap->InNewSpace(to)) {
heap->RecordWrites(to->address(),
to->OffsetOfElementAt(to_start),
copy_size);
}
heap->incremental_marking()->RecordWrites(to);
} }
} }
...@@ -160,7 +154,6 @@ static void CopyDictionaryToObjectElements( ...@@ -160,7 +154,6 @@ static void CopyDictionaryToObjectElements(
DisallowHeapAllocation no_allocation; DisallowHeapAllocation no_allocation;
SeededNumberDictionary* from = SeededNumberDictionary::cast(from_base); SeededNumberDictionary* from = SeededNumberDictionary::cast(from_base);
int copy_size = raw_copy_size; int copy_size = raw_copy_size;
Heap* heap = from->GetHeap();
if (raw_copy_size < 0) { if (raw_copy_size < 0) {
DCHECK(raw_copy_size == ElementsAccessor::kCopyToEnd || DCHECK(raw_copy_size == ElementsAccessor::kCopyToEnd ||
raw_copy_size == ElementsAccessor::kCopyToEndAndInitializeToHole); raw_copy_size == ElementsAccessor::kCopyToEndAndInitializeToHole);
...@@ -183,24 +176,19 @@ static void CopyDictionaryToObjectElements( ...@@ -183,24 +176,19 @@ static void CopyDictionaryToObjectElements(
if (to_start + copy_size > to_length) { if (to_start + copy_size > to_length) {
copy_size = to_length - to_start; copy_size = to_length - to_start;
} }
WriteBarrierMode write_barrier_mode = IsFastObjectElementsKind(to_kind)
? UPDATE_WRITE_BARRIER
: SKIP_WRITE_BARRIER;
for (int i = 0; i < copy_size; i++) { for (int i = 0; i < copy_size; i++) {
int entry = from->FindEntry(i + from_start); int entry = from->FindEntry(i + from_start);
if (entry != SeededNumberDictionary::kNotFound) { if (entry != SeededNumberDictionary::kNotFound) {
Object* value = from->ValueAt(entry); Object* value = from->ValueAt(entry);
DCHECK(!value->IsTheHole()); DCHECK(!value->IsTheHole());
to->set(i + to_start, value, SKIP_WRITE_BARRIER); to->set(i + to_start, value, write_barrier_mode);
} else { } else {
to->set_the_hole(i + to_start); to->set_the_hole(i + to_start);
} }
} }
if (IsFastObjectElementsKind(to_kind)) {
if (!heap->InNewSpace(to)) {
heap->RecordWrites(to->address(),
to->OffsetOfElementAt(to_start),
copy_size);
}
heap->incremental_marking()->RecordWrites(to);
}
} }
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment