c437ecdf21
(at least hoping to). Bug: v8:12486, v8:13354 Change-Id: I5bd9fedde5369b5644a4e9ab36e103902ee5b2b9 Reviewed-on: https://chromium-review.googlesource.com/c/v8/v8/+/3964273 Commit-Queue: Nico Hartmann <nicohartmann@chromium.org> Reviewed-by: Darius Mercadier <dmercadier@chromium.org> Cr-Commit-Position: refs/heads/main@{#83802}
40 lines
1.1 KiB
JavaScript
40 lines
1.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 --turbofan --no-always-turbofan
|
|
|
|
|
|
function f(x) {
|
|
return BigInt.asIntN(3, x);
|
|
}
|
|
|
|
%PrepareFunctionForOptimization(f);
|
|
assertEquals(-1n, f(7n));
|
|
assertEquals(1n, f(9n));
|
|
%OptimizeFunctionOnNextCall(f);
|
|
assertEquals(-1n, f(7n));
|
|
assertEquals(1n, f(9n));
|
|
assertOptimized(f);
|
|
|
|
// BigInt.asIntN throws TypeError for non-BigInt arguments.
|
|
assertThrows(() => f(2), TypeError);
|
|
if(%Is64Bit()) {
|
|
// On 64 bit architectures TurboFan optimizes BigInt.asIntN to native code
|
|
// that deoptimizes on non-BigInt arguments.
|
|
assertUnoptimized(f);
|
|
|
|
// The next time the function is optimized, speculation should be disabled
|
|
// so the builtin call is kept, which won't deoptimize again.
|
|
%PrepareFunctionForOptimization(f);
|
|
assertEquals(-1n, f(7n));
|
|
assertEquals(1n, f(9n));
|
|
%OptimizeFunctionOnNextCall(f);
|
|
}
|
|
assertEquals(-1n, f(7n));
|
|
assertOptimized(f);
|
|
|
|
// Re-optimized still throws but does not deopt-loop.
|
|
assertThrows(() => f(2), TypeError);
|
|
assertOptimized(f);
|