Commit 5211824c authored by hpayer@chromium.org's avatar hpayer@chromium.org

Re-evaluate marking bits of a descriptor array when it gets replaced.

BUG=340254
R=verwaest@chromium.org

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

git-svn-id: http://v8.googlecode.com/svn/branches/bleeding_edge@19546 ce2b1a6d-e550-0410-aec6-3dcde31c8c00
parent e7e93cd4
...@@ -2579,6 +2579,7 @@ void Map::DeprecateTarget(Name* key, DescriptorArray* new_descriptors) { ...@@ -2579,6 +2579,7 @@ void Map::DeprecateTarget(Name* key, DescriptorArray* new_descriptors) {
DescriptorArray* to_replace = instance_descriptors(); DescriptorArray* to_replace = instance_descriptors();
Map* current = this; Map* current = this;
GetHeap()->incremental_marking()->RecordWrites(to_replace);
while (current->instance_descriptors() == to_replace) { while (current->instance_descriptors() == to_replace) {
current->SetEnumLength(kInvalidEnumCacheSentinel); current->SetEnumLength(kInvalidEnumCacheSentinel);
current->set_instance_descriptors(new_descriptors); current->set_instance_descriptors(new_descriptors);
...@@ -6814,6 +6815,8 @@ MaybeObject* Map::ShareDescriptor(DescriptorArray* descriptors, ...@@ -6814,6 +6815,8 @@ MaybeObject* Map::ShareDescriptor(DescriptorArray* descriptors,
Map* map; Map* map;
// Replace descriptors by new_descriptors in all maps that share it. // Replace descriptors by new_descriptors in all maps that share it.
GetHeap()->incremental_marking()->RecordWrites(descriptors);
for (Object* current = GetBackPointer(); for (Object* current = GetBackPointer();
!current->IsUndefined(); !current->IsUndefined();
current = map->GetBackPointer()) { current = map->GetBackPointer()) {
......
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