node/deps/v8/test/mjsunit/compiler/regress-crbug-1227677.js
Michaël Zasso 50930a0fa0
deps: update V8 to 9.3.345.16
PR-URL: https://github.com/nodejs/node/pull/39469
Reviewed-By: Jiawen Geng <technicalcute@gmail.com>
Reviewed-By: James M Snell <jasnell@gmail.com>
Reviewed-By: Colin Ihrig <cjihrig@gmail.com>
2021-08-30 21:02:51 +02:00

196 lines
4.1 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: --allow-natives-syntax --interrupt-budget=1024
(function() {
async function foo() {
for (let j = 0; j < 1; j++) {
const x = 2n * 3n;
for (let k = 0; k < 4; k++) {
function unused() {}
x >> 5n;
for (let i = 0; i < 100; i++) ;
for (let i = 0; i == 6; i++) await 7;
}
}
}
%PrepareFunctionForOptimization(foo);
foo();
foo();
%OptimizeFunctionOnNextCall(foo);
foo();
})();
(function() {
async function foo() {
for (let j = 0; j < 1; j++) {
const x = 2n * 3n;
for (let k = 0; k < 4; k++) {
function unused() {}
x << 5n;
for (let i = 0; i < 100; i++) ;
for (let i = 0; i == 6; i++) await 7;
}
}
}
%PrepareFunctionForOptimization(foo);
foo();
foo();
%OptimizeFunctionOnNextCall(foo);
foo();
})();
(function() {
async function foo() {
for (let j = 0; j < 1; j++) {
const x = 2n * 3n;
for (let k = 0; k < 4; k++) {
function unused() {}
x / 5n;
for (let i = 0; i < 100; i++) ;
for (let i = 0; i == 6; i++) await 7;
}
}
}
%PrepareFunctionForOptimization(foo);
foo();
foo();
%OptimizeFunctionOnNextCall(foo);
foo();
})();
(function() {
async function foo() {
for (let j = 0; j < 1; j++) {
const x = 2n * 3n;
for (let k = 0; k < 4; k++) {
function unused() {}
x % 5n;
for (let i = 0; i < 100; i++) ;
for (let i = 0; i == 6; i++) await 7;
}
}
}
%PrepareFunctionForOptimization(foo);
foo();
foo();
%OptimizeFunctionOnNextCall(foo);
foo();
})();
(function() {
async function foo() {
for (let j = 0; j < 1; j++) {
const x = 2n * 3n;
for (let k = 0; k < 4; k++) {
function unused() {}
x * 5n;
for (let i = 0; i < 100; i++) ;
for (let i = 0; i == 6; i++) await 7;
}
}
}
%PrepareFunctionForOptimization(foo);
foo();
foo();
%OptimizeFunctionOnNextCall(foo);
foo();
})();
(function() {
async function foo() {
for (let j = 0; j < 1; j++) {
const x = 2n * 3n;
for (let k = 0; k < 4; k++) {
function unused() {}
x ^ 5n;
for (let i = 0; i < 100; i++) ;
for (let i = 0; i == 6; i++) await 7;
}
}
}
%PrepareFunctionForOptimization(foo);
foo();
foo();
%OptimizeFunctionOnNextCall(foo);
foo();
})();
(function() {
async function foo() {
for (let j = 0; j < 1; j++) {
const x = 2n * 3n;
for (let k = 0; k < 4; k++) {
function unused() {}
x & 5n;
for (let i = 0; i < 100; i++) ;
for (let i = 0; i == 6; i++) await 7;
}
}
}
%PrepareFunctionForOptimization(foo);
foo();
foo();
%OptimizeFunctionOnNextCall(foo);
foo();
})();
(function() {
async function foo() {
for (let j = 0; j < 1; j++) {
const x = 2n * 3n;
for (let k = 0; k < 4; k++) {
function unused() {}
x | 5n;
for (let i = 0; i < 100; i++) ;
for (let i = 0; i == 6; i++) await 7;
}
}
}
%PrepareFunctionForOptimization(foo);
foo();
foo();
%OptimizeFunctionOnNextCall(foo);
foo();
})();
(function() {
async function foo() {
for (let j = 0; j < 1; j++) {
const x = 2n * 3n;
for (let k = 0; k < 4; k++) {
function unused() {}
x + 5n;
for (let i = 0; i < 100; i++) ;
for (let i = 0; i == 6; i++) await 7;
}
}
}
%PrepareFunctionForOptimization(foo);
foo();
foo();
%OptimizeFunctionOnNextCall(foo);
foo();
})();
(function() {
async function foo() {
for (let j = 0; j < 1; j++) {
const x = 2n * 3n;
for (let k = 0; k < 4; k++) {
function unused() {}
x < 5n;
for (let i = 0; i < 100; i++) ;
for (let i = 0; i == 6; i++) await 7;
}
}
}
%PrepareFunctionForOptimization(foo);
foo();
foo();
%OptimizeFunctionOnNextCall(foo);
foo();
})();