| Index: src/objects.cc
|
| diff --git a/src/objects.cc b/src/objects.cc
|
| index bb10a9b1c203b08793c58c5a0c2c936c0a8b9599..4e3ccb4ca79ca8fb57d00eb549d42f0682ee4548 100644
|
| --- a/src/objects.cc
|
| +++ b/src/objects.cc
|
| @@ -11936,15 +11936,9 @@ MUST_USE_RESULT static MaybeHandle<Object> EndPerformSplice(
|
| MaybeHandle<Object> JSArray::SetElementsLength(
|
| Handle<JSArray> array,
|
| Handle<Object> new_length_handle) {
|
| - if (array->HasFastElements()) {
|
| - // If the new array won't fit in a some non-trivial fraction of the max old
|
| - // space size, then force it to go dictionary mode.
|
| - int max_fast_array_size = static_cast<int>(
|
| - (array->GetHeap()->MaxOldGenerationSize() / kDoubleSize) / 4);
|
| - if (new_length_handle->IsNumber() &&
|
| - NumberToInt32(*new_length_handle) >= max_fast_array_size) {
|
| - NormalizeElements(array);
|
| - }
|
| + if (array->HasFastElements() &&
|
| + SetElementsLengthWouldNormalize(array->GetHeap(), new_length_handle)) {
|
| + NormalizeElements(array);
|
| }
|
|
|
| // We should never end in here with a pixel or external array.
|
|
|