| // Copyright 2017 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 --opt |
| |
| (function test() { |
| function foo(a) { a.push(a.length = 2); } |
| |
| %PrepareFunctionForOptimization(foo); |
| foo([1]); |
| foo([1]); |
| %OptimizeFunctionOnNextCall(foo); |
| foo([1]); |
| %PrepareFunctionForOptimization(foo); |
| %OptimizeFunctionOnNextCall(foo); |
| foo([1]); |
| assertOptimized(foo); |
| })(); |
| |
| (function testElementTypeCheckSmi() { |
| function foo(a) { a.push('a'); } |
| |
| %PrepareFunctionForOptimization(foo); |
| foo([1]); |
| foo([1]); |
| %OptimizeFunctionOnNextCall(foo); |
| foo([1]); |
| %PrepareFunctionForOptimization(foo); |
| %OptimizeFunctionOnNextCall(foo); |
| foo([1]); |
| assertOptimized(foo); |
| })(); |
| |
| (function testElementTypeCheckDouble() { |
| function foo(a) { a.push('a'); } |
| |
| %PrepareFunctionForOptimization(foo); |
| foo([0.3413312]); |
| foo([0.3413312]); |
| %OptimizeFunctionOnNextCall(foo); |
| foo([0.3413312]); |
| %PrepareFunctionForOptimization(foo); |
| %OptimizeFunctionOnNextCall(foo); |
| foo([0.3413312]); |
| assertOptimized(foo); |
| })(); |
| (function test() { |
| function bar(a) { a.x = 2 }; |
| %NeverOptimizeFunction(bar); |
| function foo(a) { a.push(bar(a)); } |
| |
| %PrepareFunctionForOptimization(foo); |
| foo(["1"]); |
| foo(["1"]); |
| %OptimizeFunctionOnNextCall(foo); |
| foo(["1"]); |
| %PrepareFunctionForOptimization(foo); |
| %OptimizeFunctionOnNextCall(foo); |
| foo(["1"]); |
| assertOptimized(foo); |
| })(); |
| |
| (function test() { |
| function foo(a) { a.push(a.length = 2); } |
| |
| %PrepareFunctionForOptimization(foo); |
| foo([0.34234]); |
| foo([0.34234]); |
| %OptimizeFunctionOnNextCall(foo); |
| foo([0.34234]); |
| %PrepareFunctionForOptimization(foo); |
| %OptimizeFunctionOnNextCall(foo); |
| foo([0.34234]); |
| assertOptimized(foo); |
| })(); |
| |
| (function test() { |
| const N = 128 * 1024; |
| |
| function foo(a) { a.push(1); } |
| |
| %PrepareFunctionForOptimization(foo); |
| foo(new Array(N)); |
| foo(new Array(N)); |
| %OptimizeFunctionOnNextCall(foo); |
| foo(new Array(N)); |
| %PrepareFunctionForOptimization(foo); |
| %OptimizeFunctionOnNextCall(foo); |
| foo(new Array(N)); |
| assertOptimized(foo); |
| })(); |
| |
| (function test() { |
| // Conservative arrays lengths in slow and fast mode. |
| const kFastModeLength = 1024; |
| const kSlowModeLength = 512 * 1024; |
| function mkArray(length) { |
| let a = [0.1]; |
| a.length = length; |
| return a; |
| } |
| function foo(a) { a.push(0.23441233123); } |
| |
| |
| // 1. Optimize foo to handle fast mode arrays. |
| %PrepareFunctionForOptimization(foo); |
| foo(mkArray(kFastModeLength)); |
| foo(mkArray(kFastModeLength)); |
| %OptimizeFunctionOnNextCall(foo); |
| foo(mkArray(kFastModeLength)); |
| assertOptimized(foo); |
| |
| // Prepare foo to be re-optimized, ensuring it's bytecode / feedback vector |
| // doesn't get flushed after deoptimization. |
| %PrepareFunctionForOptimization(foo); |
| |
| // 2. Given a slow mode array, foo will deopt. |
| foo(mkArray(kSlowModeLength)); |
| |
| // 3. Optimize foo again. |
| %OptimizeFunctionOnNextCall(foo); |
| foo(mkArray(kSlowModeLength)); |
| // 4. It should stay optimized. |
| assertOptimized(foo); |
| })(); |