Fix missing slot recording in transition compaction.
authormstarzinger@chromium.org <mstarzinger@chromium.org@ce2b1a6d-e550-0410-aec6-3dcde31c8c00>
Tue, 26 Jun 2012 11:25:28 +0000 (11:25 +0000)
committermstarzinger@chromium.org <mstarzinger@chromium.org@ce2b1a6d-e550-0410-aec6-3dcde31c8c00>
Tue, 26 Jun 2012 11:25:28 +0000 (11:25 +0000)
R=verwaest@chromium.org
TEST=cctest/test-api/Threading2

Review URL: https://chromiumcodereview.appspot.com/10658033

git-svn-id: http://v8.googlecode.com/svn/branches/bleeding_edge@11930 ce2b1a6d-e550-0410-aec6-3dcde31c8c00

src/objects.cc

index 5ec05aa..5748317 100644 (file)
@@ -7444,6 +7444,9 @@ static bool ClearNonLiveTransitionsFromDescriptor(Heap* heap,
 }
 
 
+// TODO(mstarzinger): This method should be moved into MarkCompactCollector,
+// because it cannot be called from outside the GC and we already have methods
+// depending on the transitions layout in the GC anyways.
 void Map::ClearNonLiveTransitions(Heap* heap) {
   Object* array = *RawField(this, Map::kInstanceDescriptorsOrBitField3Offset);
   // If there are no descriptors to be cleared, return.
@@ -7457,9 +7460,18 @@ void Map::ClearNonLiveTransitions(Heap* heap) {
   for (int i = 0; i < d->number_of_descriptors(); ++i) {
     if (!ClearNonLiveTransitionsFromDescriptor(heap, d, i)) {
       if (i != descriptor_index) {
-        d->SetKeyUnchecked(heap, descriptor_index, d->GetKey(i));
+        String* key = d->GetKey(i);
+        Object* value = d->GetValue(i);
+        d->SetKeyUnchecked(heap, descriptor_index, key);
         d->SetDetailsUnchecked(descriptor_index, d->GetDetails(i).AsSmi());
-        d->SetValueUnchecked(heap, descriptor_index, d->GetValue(i));
+        d->SetValueUnchecked(heap, descriptor_index, value);
+        MarkCompactCollector* collector = heap->mark_compact_collector();
+        Object** key_slot = d->GetKeySlot(descriptor_index);
+        collector->RecordSlot(key_slot, key_slot, key);
+        if (value->IsHeapObject()) {
+          Object** value_slot = d->GetValueSlot(descriptor_index);
+          collector->RecordSlot(value_slot, value_slot, value);
+        }
       }
       descriptor_index++;
     }