v8/test/mjsunit/baseline/batch-compilation.js
Leszek Swirski 6d1d1fbd8b Reland "[sparkplug] Trigger compilation when a FBV exists"
This is a reland of 3296de2f65
It includes pthier@'s fix of overzealous OSR

Original change's description:
> [sparkplug] Trigger compilation when a FBV exists
>
> We were gating baseline compilation on FBV allocation, but in some
> cases, the feedback vector may be allocated eagerly (notably, if we are
> logging function events). Instead, unconditionally try baseline
> compilation after ensuring the feedback vector exists.
>
> Bug: v8:11420
> Change-Id: I1264a1d541a74d4eccb5caf65c360ac23836a1a8
> Reviewed-on: https://chromium-review.googlesource.com/c/v8/v8/+/2953161
> Auto-Submit: Leszek Swirski <leszeks@chromium.org>
> Commit-Queue: Patrick Thier <pthier@chromium.org>
> Reviewed-by: Patrick Thier <pthier@chromium.org>
> Cr-Commit-Position: refs/heads/master@{#75242}

Bug: v8:11420
Change-Id: Ia6864856926d6760bbe6c89ee010fa62cf23b6ca
Reviewed-on: https://chromium-review.googlesource.com/c/v8/v8/+/2976660
Auto-Submit: Leszek Swirski <leszeks@chromium.org>
Commit-Queue: Patrick Thier <pthier@chromium.org>
Reviewed-by: Patrick Thier <pthier@chromium.org>
Cr-Commit-Position: refs/heads/master@{#75319}
2021-06-23 07:42:33 +00:00

74 lines
2.0 KiB
JavaScript

// Copyright 2021 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: --sparkplug --no-always-sparkplug --sparkplug-filter="test*"
// Flags: --allow-natives-syntax --expose-gc --no-always-opt
// Flags: --baseline-batch-compilation --baseline-batch-compilation-threshold=200
// Flags: --scale-factor-for-feedback-allocation=4
// Flags to drive Fuzzers into the right direction
// TODO(v8:11853): Remove these flags once fuzzers handle flag implications
// better.
// Flags: --lazy-feedback-allocation --no-stress-concurrent-inlining
// Basic test
(function() {
// Bytecode length 24 -> estimated instruction size 120 - 168.
function test1 (a,b) {
return (a + b + 11) * 42 / a % b;
}
// Bytecode length 24 -> estimated instruction size 120 - 168.
function test2 (a,b) {
return (a + b + 11) * 42 / a % b;
}
%NeverOptimizeFunction(test1);
// Trigger bytecode budget interrupt for test1.
for (let i=0; i<5; ++i) {
test1(i,4711);
}
// Shouldn't be compiled because of batch compilation.
assertFalse(isBaseline(test1));
%NeverOptimizeFunction(test2);
// Trigger bytecode budget interrupt for test2.
for (let i=0; i<5; ++i) {
test2(i,4711);
}
// Call test1 again so baseline code gets installed on the function.
test1(1,2);
// Both functions should be compiled with baseline now.
assertTrue(isBaseline(test1));
assertTrue(isBaseline(test2));
})();
// Test function weak handle.
(function() {
function test_weak (a,b) {
return (a + b + 11) * 42 / a % b;
}
function test2 (a,b) {
return (a + b + 11) * 42 / a % b;
}
%NeverOptimizeFunction(test_weak);
for (let i=0; i<5; ++i) {
test_weak(i,4711);
}
gc(); // GC should cause the handle to test_weak to be freed.
%NeverOptimizeFunction(test2);
// Trigger bytecode budget interrupt for test2.
for (let i=0; i<5; ++i) {
test2(i,4711);
}
assertTrue(isBaseline(test2));
})();