bbc89774a6
This mostly reverts commit c503b80595
but fixes
an issue where literals would always be pretenured on first instantiation.
As a cleanup we pass in a PretenureFlag instead of using the FeedbackVector as
indicator.
Bug: v8:6211
Change-Id: Id328552620e33f5083519bcba1e24396d162d516
Reviewed-on: https://chromium-review.googlesource.com/555670
Reviewed-by: Igor Sheludko <ishell@chromium.org>
Reviewed-by: Camillo Bruni <cbruni@chromium.org>
Commit-Queue: Camillo Bruni <cbruni@chromium.org>
Cr-Commit-Position: refs/heads/master@{#46342}
44 lines
1.3 KiB
JavaScript
44 lines
1.3 KiB
JavaScript
// Copyright 2015 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.
|
|
|
|
// Flags: --allow-natives-syntax --no-always-opt
|
|
|
|
function literals_sharing_test(warmup, optimize) {
|
|
function closure() {
|
|
// Ensure small array literals start in specific element kind mode.
|
|
assertTrue(%HasFastSmiElements([]));
|
|
assertTrue(%HasFastSmiElements([1]));
|
|
assertTrue(%HasFastSmiElements([1,2]));
|
|
assertTrue(%HasFastDoubleElements([1.1]));
|
|
assertTrue(%HasFastDoubleElements([1.1,2]));
|
|
|
|
var a = [1, 2, 3];
|
|
if (warmup) {
|
|
// Transition elements kind during warmup...
|
|
assertTrue(%HasFastSmiElements(a));
|
|
assertEquals(4, a.push(1.3));
|
|
}
|
|
// ... and ensure that the information about transitioning is
|
|
// propagated to the next closure.
|
|
assertTrue(%HasFastDoubleElements(a));
|
|
};
|
|
if (optimize) %OptimizeFunctionOnNextCall(closure);
|
|
closure();
|
|
}
|
|
|
|
|
|
function test() {
|
|
for (var i = 0; i < 3; i++) {
|
|
// We only start tracking allocation information with the second
|
|
// instantiation.
|
|
var warmup = i < 2;
|
|
print("iter: " + i + ", warmup: "+ warmup);
|
|
literals_sharing_test(warmup, false);
|
|
}
|
|
print("iter: " + i + ", opt: true");
|
|
literals_sharing_test(warmup, true);
|
|
}
|
|
|
|
test();
|