| Index: src/objects.cc
|
| diff --git a/src/objects.cc b/src/objects.cc
|
| index 03e6994a42b87b5e5abefd722decd437889f3cc7..67e32a63ac4bb1db49d6702eac5a2b793ab67575 100644
|
| --- a/src/objects.cc
|
| +++ b/src/objects.cc
|
| @@ -2571,7 +2571,7 @@ Handle<Map> Map::ReconfigureProperty(Handle<Map> old_map, int modify_index,
|
|
|
| ElementsKind from_kind = root_map->elements_kind();
|
| ElementsKind to_kind = old_map->elements_kind();
|
| - if (from_kind != to_kind &&
|
| + if (from_kind != to_kind && to_kind != DICTIONARY_ELEMENTS &&
|
| !(IsTransitionableFastElementsKind(from_kind) &&
|
| IsMoreGeneralElementsKindTransition(from_kind, to_kind))) {
|
| return CopyGeneralizeAllRepresentations(old_map, modify_index, store_mode,
|
| @@ -3035,6 +3035,15 @@ MaybeHandle<Map> Map::TryUpdate(Handle<Map> old_map) {
|
| // Check the state of the root map.
|
| Map* root_map = old_map->FindRootMap();
|
| if (!old_map->EquivalentToForTransition(root_map)) return MaybeHandle<Map>();
|
| +
|
| + ElementsKind from_kind = root_map->elements_kind();
|
| + ElementsKind to_kind = old_map->elements_kind();
|
| + if (from_kind != to_kind) {
|
| + // Try to follow existing elements kind transitions.
|
| + root_map = root_map->LookupElementsTransitionMap(to_kind);
|
| + if (root_map == NULL) return MaybeHandle<Map>();
|
| + // From here on, use the map with correct elements kind as root map.
|
| + }
|
| int root_nof = root_map->NumberOfOwnDescriptors();
|
|
|
| int old_nof = old_map->NumberOfOwnDescriptors();
|
|
|