Commit 0fcd8916 authored by bmeurer@chromium.org's avatar bmeurer@chromium.org

Fix invalid attributes when generalizing because of incompatible map change.

BUG=382143
LOG=y
TEST=mjsunit/regress/regress-382143
R=verwaest@chromium.org

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

git-svn-id: https://v8.googlecode.com/svn/branches/bleeding_edge@21743 ce2b1a6d-e550-0410-aec6-3dcde31c8c00
parent 6ccf6f8b
...@@ -2416,6 +2416,18 @@ Handle<Map> Map::CopyGeneralizeAllRepresentations(Handle<Map> map, ...@@ -2416,6 +2416,18 @@ Handle<Map> Map::CopyGeneralizeAllRepresentations(Handle<Map> map,
} }
// static
Handle<Map> Map::CopyGeneralizeAllRepresentations(Handle<Map> map,
int modify_index,
StoreMode store_mode,
const char* reason) {
PropertyDetails details =
map->instance_descriptors()->GetDetails(modify_index);
return CopyGeneralizeAllRepresentations(map, modify_index, store_mode,
details.attributes(), reason);
}
void Map::DeprecateTransitionTree() { void Map::DeprecateTransitionTree() {
if (is_deprecated()) return; if (is_deprecated()) return;
if (HasTransitionArray()) { if (HasTransitionArray()) {
...@@ -2661,8 +2673,8 @@ Handle<Map> Map::GeneralizeRepresentation(Handle<Map> old_map, ...@@ -2661,8 +2673,8 @@ Handle<Map> Map::GeneralizeRepresentation(Handle<Map> old_map,
// Check the state of the root map. // Check the state of the root map.
Handle<Map> root_map(old_map->FindRootMap(), isolate); Handle<Map> root_map(old_map->FindRootMap(), isolate);
if (!old_map->EquivalentToForTransition(*root_map)) { if (!old_map->EquivalentToForTransition(*root_map)) {
return CopyGeneralizeAllRepresentations(old_map, modify_index, store_mode, return CopyGeneralizeAllRepresentations(
old_details.attributes(), "not equivalent"); old_map, modify_index, store_mode, "not equivalent");
} }
int root_nof = root_map->NumberOfOwnDescriptors(); int root_nof = root_map->NumberOfOwnDescriptors();
if (modify_index < root_nof) { if (modify_index < root_nof) {
...@@ -2671,8 +2683,8 @@ Handle<Map> Map::GeneralizeRepresentation(Handle<Map> old_map, ...@@ -2671,8 +2683,8 @@ Handle<Map> Map::GeneralizeRepresentation(Handle<Map> old_map,
(old_details.type() == FIELD && (old_details.type() == FIELD &&
(!new_field_type->NowIs(old_descriptors->GetFieldType(modify_index)) || (!new_field_type->NowIs(old_descriptors->GetFieldType(modify_index)) ||
!new_representation.fits_into(old_details.representation())))) { !new_representation.fits_into(old_details.representation())))) {
return CopyGeneralizeAllRepresentations(old_map, modify_index, store_mode, return CopyGeneralizeAllRepresentations(
old_details.attributes(), "root modification"); old_map, modify_index, store_mode, "root modification");
} }
} }
...@@ -2694,8 +2706,7 @@ Handle<Map> Map::GeneralizeRepresentation(Handle<Map> old_map, ...@@ -2694,8 +2706,7 @@ Handle<Map> Map::GeneralizeRepresentation(Handle<Map> old_map,
(tmp_type != old_type || (tmp_type != old_type ||
tmp_descriptors->GetValue(i) != old_descriptors->GetValue(i)))) { tmp_descriptors->GetValue(i) != old_descriptors->GetValue(i)))) {
return CopyGeneralizeAllRepresentations( return CopyGeneralizeAllRepresentations(
old_map, modify_index, store_mode, old_map, modify_index, store_mode, "incompatible");
old_details.attributes(), "incompatible");
} }
Representation old_representation = old_details.representation(); Representation old_representation = old_details.representation();
Representation tmp_representation = tmp_details.representation(); Representation tmp_representation = tmp_details.representation();
...@@ -2759,8 +2770,7 @@ Handle<Map> Map::GeneralizeRepresentation(Handle<Map> old_map, ...@@ -2759,8 +2770,7 @@ Handle<Map> Map::GeneralizeRepresentation(Handle<Map> old_map,
(tmp_details.type() != old_details.type() || (tmp_details.type() != old_details.type() ||
tmp_descriptors->GetValue(i) != old_descriptors->GetValue(i)))) { tmp_descriptors->GetValue(i) != old_descriptors->GetValue(i)))) {
return CopyGeneralizeAllRepresentations( return CopyGeneralizeAllRepresentations(
old_map, modify_index, store_mode, old_map, modify_index, store_mode, "incompatible");
old_details.attributes(), "incompatible");
} }
target_map = tmp_map; target_map = tmp_map;
} }
...@@ -2803,6 +2813,7 @@ Handle<Map> Map::GeneralizeRepresentation(Handle<Map> old_map, ...@@ -2803,6 +2813,7 @@ Handle<Map> Map::GeneralizeRepresentation(Handle<Map> old_map,
target_details = target_details.CopyWithRepresentation( target_details = target_details.CopyWithRepresentation(
new_representation.generalize(target_details.representation())); new_representation.generalize(target_details.representation()));
} }
ASSERT_EQ(old_details.attributes(), target_details.attributes());
if (old_details.type() == FIELD || if (old_details.type() == FIELD ||
target_details.type() == FIELD || target_details.type() == FIELD ||
(modify_index == i && store_mode == FORCE_FIELD) || (modify_index == i && store_mode == FORCE_FIELD) ||
......
...@@ -6367,6 +6367,11 @@ class Map: public HeapObject { ...@@ -6367,6 +6367,11 @@ class Map: public HeapObject {
StoreMode store_mode, StoreMode store_mode,
PropertyAttributes attributes, PropertyAttributes attributes,
const char* reason); const char* reason);
static Handle<Map> CopyGeneralizeAllRepresentations(
Handle<Map> map,
int modify_index,
StoreMode store_mode,
const char* reason);
static Handle<Map> Normalize(Handle<Map> map, PropertyNormalizationMode mode); static Handle<Map> Normalize(Handle<Map> map, PropertyNormalizationMode mode);
......
// Copyright 2013 the V8 project authors. All rights reserved.
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
function A() {
Object.defineProperty(this, "x", { set: function () {}, get: function () {}});
this.a = function () { return 1; }
}
function B() {
A.apply( this );
this.a = function () { return 2; }
}
var b = new B();
assertTrue(Object.getOwnPropertyDescriptor(b, "a").enumerable);
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