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