2016-12-23 16:30:57 +01:00
|
|
|
// Copyright 2016 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.
|
|
|
|
|
2017-10-18 15:03:02 -07:00
|
|
|
// Flags: --allow-natives-syntax --turbo-filter=f
|
2016-12-23 16:30:57 +01:00
|
|
|
|
2019-08-16 11:32:46 +02:00
|
|
|
function f(x) {
|
|
|
|
return x + 23;
|
|
|
|
};
|
|
|
|
%PrepareFunctionForOptimization(f);
|
|
|
|
function g(x) {
|
|
|
|
return f(x) + 42;
|
|
|
|
};
|
|
|
|
%PrepareFunctionForOptimization(g);
|
2016-12-23 16:30:57 +01:00
|
|
|
assertEquals(23, f(0));
|
|
|
|
assertEquals(24, f(1));
|
|
|
|
assertEquals(67, g(2));
|
|
|
|
assertEquals(68, g(3));
|
|
|
|
|
|
|
|
// Optimize {g} with Crankshaft, causing {f} to be inlined.
|
|
|
|
%OptimizeFunctionOnNextCall(g);
|
|
|
|
assertEquals(65, g(0));
|
|
|
|
|
|
|
|
// Optimize {f} with Turbofan, after it has been inlined.
|
|
|
|
%OptimizeFunctionOnNextCall(f);
|
|
|
|
assertEquals(23, f(0));
|