2022-05-23 10:45:09 +00:00
|
|
|
// 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.
|
|
|
|
|
2022-07-13 08:58:44 +00:00
|
|
|
// Flags: --allow-natives-syntax --maglev --no-stress-opt --no-always-turbofan
|
2022-05-23 10:45:09 +00:00
|
|
|
|
|
|
|
function foo(x,y) {
|
|
|
|
if (x < y) {
|
|
|
|
return 42;
|
|
|
|
}
|
|
|
|
return 24;
|
|
|
|
}
|
|
|
|
|
|
|
|
%PrepareFunctionForOptimization(foo);
|
|
|
|
assertEquals(42, foo(1,2));
|
|
|
|
assertEquals(24, foo(6,2));
|
|
|
|
%OptimizeMaglevOnNextCall(foo);
|
|
|
|
assertEquals(42, foo(1,2));
|
|
|
|
assertEquals(24, foo(6,2));
|
2022-07-13 08:58:44 +00:00
|
|
|
assertTrue(isMaglevved(foo));
|
|
|
|
assertEquals(42, foo(1.1, 2.2));
|
|
|
|
assertEquals(24, foo(6.6, 2.2));
|
|
|
|
assertUnoptimized(foo);
|
2022-05-23 10:45:09 +00:00
|
|
|
|
|
|
|
|
|
|
|
function bar(x,y) {
|
|
|
|
if (!(x >= y)) {
|
|
|
|
return 42;
|
|
|
|
}
|
|
|
|
return 24;
|
|
|
|
}
|
|
|
|
|
|
|
|
%PrepareFunctionForOptimization(bar);
|
|
|
|
assertEquals(42, bar(1,2));
|
|
|
|
assertEquals(24, bar(6,2));
|
|
|
|
%OptimizeMaglevOnNextCall(bar);
|
|
|
|
assertEquals(42, bar(1,2));
|
|
|
|
assertEquals(24, bar(6,2));
|
2022-07-13 08:58:44 +00:00
|
|
|
assertTrue(isMaglevved(bar));
|
|
|
|
assertEquals(42, bar(1.1, 2.2));
|
|
|
|
assertEquals(24, bar(6.6, 2.2));
|
|
|
|
assertUnoptimized(bar);
|