c6a16c10dd
With bytecode flushing and lazy feedback allocation, we need to call %PrepareForOptimization before we call %OptimizeFunctionOnNextCall, ideally after declaring the function. Bug: v8:8801, v8:8394, v8:9183 Change-Id: I3fb257282a30f6526a376a3afdedb44786320d34 Reviewed-on: https://chromium-review.googlesource.com/c/v8/v8/+/1648255 Commit-Queue: Mathias Bynens <mathias@chromium.org> Reviewed-by: Maya Lekova <mslekova@chromium.org> Reviewed-by: Mythri Alle <mythria@chromium.org> Cr-Commit-Position: refs/heads/master@{#62119}
46 lines
1.3 KiB
JavaScript
46 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(%HasSmiElements([]));
|
|
assertTrue(%HasSmiElements([1]));
|
|
assertTrue(%HasSmiElements([1, 2]));
|
|
assertTrue(%HasDoubleElements([1.1]));
|
|
assertTrue(%HasDoubleElements([1.1, 2]));
|
|
|
|
var a = [1, 2, 3];
|
|
if (warmup) {
|
|
// Transition elements kind during warmup...
|
|
assertTrue(%HasSmiElements(a));
|
|
assertEquals(4, a.push(1.3));
|
|
}
|
|
// ... and ensure that the information about transitioning is
|
|
// propagated to the next closure.
|
|
assertTrue(%HasDoubleElements(a));
|
|
};
|
|
%PrepareFunctionForOptimization(closure);
|
|
;
|
|
%EnsureFeedbackVectorForFunction(closure);
|
|
if (optimize) %OptimizeFunctionOnNextCall(closure);
|
|
closure();
|
|
}
|
|
|
|
|
|
function test() {
|
|
var warmup = true;
|
|
for (var i = 0; i < 3; i++) {
|
|
print('iter: ' + i + ', warmup: ' + warmup);
|
|
literals_sharing_test(warmup, false);
|
|
warmup = false;
|
|
}
|
|
print("iter: " + i + ", opt: true");
|
|
literals_sharing_test(warmup, true);
|
|
}
|
|
|
|
test();
|