| 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. | 
|  |