mirror of
https://github.com/nodejs/node.git
synced 2025-05-15 16:01:52 +00:00

PR-URL: https://github.com/nodejs/node/pull/45579 Reviewed-By: Michaël Zasso <targos@protonmail.com> Reviewed-By: James M Snell <jasnell@gmail.com>
98 lines
3.0 KiB
JavaScript
98 lines
3.0 KiB
JavaScript
// Copyright 2022 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 --turbofan --no-always-turbofan
|
|
|
|
(function OptimizeAndTestNegativeLimit() {
|
|
function f(x, y) {
|
|
return x + y;
|
|
}
|
|
%PrepareFunctionForOptimization(f);
|
|
assertEquals(1n, f(0n, 1n));
|
|
assertEquals(5n, f(2n, 3n));
|
|
%OptimizeFunctionOnNextCall(f);
|
|
assertEquals(-(2n ** 63n), f(-(2n ** 63n), 0n));
|
|
assertOptimized(f);
|
|
// Re-prepare the function before the first deopt to ensure type feedback is
|
|
// not cleared by an umtimely gc.
|
|
%PrepareFunctionForOptimization(f);
|
|
assertOptimized(f);
|
|
// CheckBigInt64 should trigger deopt on INT_MIN - 1.
|
|
assertEquals(-(2n ** 63n) - 1n, f(-(2n ** 63n) - 1n, 0n));
|
|
if (%Is64Bit()) {
|
|
assertUnoptimized(f);
|
|
|
|
assertEquals(1n, f(0n, 1n));
|
|
assertEquals(5n, f(2n, 3n));
|
|
%OptimizeFunctionOnNextCall(f);
|
|
assertEquals(-(2n ** 63n), f(-(2n ** 63n), 0n));
|
|
assertOptimized(f);
|
|
// Ensure there is no deopt loop.
|
|
assertEquals(-(2n ** 63n) - 1n, f(-(2n ** 63n) - 1n, 0n));
|
|
assertOptimized(f);
|
|
}
|
|
})();
|
|
|
|
(function OptimizeAndTestPositiveLimit() {
|
|
function f(x, y) {
|
|
return x + y;
|
|
}
|
|
%PrepareFunctionForOptimization(f);
|
|
assertEquals(1n, f(0n, 1n));
|
|
assertEquals(5n, f(2n, 3n));
|
|
%OptimizeFunctionOnNextCall(f);
|
|
assertEquals(2n ** 63n - 1n, f(2n ** 63n - 1n, 0n));
|
|
assertOptimized(f);
|
|
// Re-prepare the function before the first deopt to ensure type feedback is
|
|
// not cleared by an untimely gc.
|
|
%PrepareFunctionForOptimization(f);
|
|
assertOptimized(f);
|
|
// CheckBigInt64 should trigger deopt on INT_MAX + 1.
|
|
assertEquals(2n ** 63n, f(2n ** 63n, 0n));
|
|
if (%Is64Bit()) {
|
|
assertUnoptimized(f);
|
|
|
|
assertEquals(1n, f(0n, 1n));
|
|
assertEquals(5n, f(2n, 3n));
|
|
%OptimizeFunctionOnNextCall(f);
|
|
assertEquals(2n ** 63n - 1n, f(2n ** 63n - 1n, 0n));
|
|
assertOptimized(f);
|
|
// Ensure there is no deopt loop.
|
|
assertEquals(2n ** 63n, f(2n ** 63n, 0n));
|
|
assertOptimized(f);
|
|
}
|
|
})();
|
|
|
|
(function OptimizeAndTestOverflow() {
|
|
function f(x, y) {
|
|
return x + y;
|
|
}
|
|
%PrepareFunctionForOptimization(f);
|
|
assertEquals(1n, f(0n, 1n));
|
|
assertEquals(5n, f(2n, 3n));
|
|
%OptimizeFunctionOnNextCall(f);
|
|
assertEquals(9n, f(4n, 5n));
|
|
assertOptimized(f);
|
|
assertEquals(-(2n ** 63n), f(-(2n ** 62n), -(2n ** 62n)));
|
|
assertOptimized(f);
|
|
// Re-prepare the function before the first deopt to ensure type feedback is
|
|
// not cleared by an umtimely gc.
|
|
%PrepareFunctionForOptimization(f);
|
|
assertOptimized(f);
|
|
// CheckedInt64Add will trigger deopt due to overflow.
|
|
assertEquals(-(2n ** 63n) - 1n, f(-(2n ** 62n + 1n), -(2n ** 62n)));
|
|
if (%Is64Bit()) {
|
|
assertUnoptimized(f);
|
|
|
|
assertEquals(1n, f(0n, 1n));
|
|
assertEquals(5n, f(2n, 3n));
|
|
%OptimizeFunctionOnNextCall(f);
|
|
assertEquals(9n, f(4n, 5n));
|
|
assertOptimized(f);
|
|
// Ensure there is no deopt loop.
|
|
assertEquals(-(2n ** 63n) - 1n, f(-(2n ** 62n + 1n), -(2n ** 62n)));
|
|
assertOptimized(f);
|
|
}
|
|
})();
|