osr-for-let.js 1.56 KB
Newer Older
1 2 3 4
// Copyright 2015 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.

5
// Flags: --allow-natives-syntax --use-osr
6 7 8 9

"use strict";

function test(expected, func) {
10
  %PrepareFunctionForOptimization(func);
11
  assertEquals(expected, func());
12
  %PrepareFunctionForOptimization(func);
13
  assertEquals(expected, func());
14
  %PrepareFunctionForOptimization(func);
15 16 17 18 19 20 21 22 23 24 25 26 27 28 29
  assertEquals(expected, func());
}

function bar() {
  var result;
  {
    let sum = 0;
    for (let i = 0; i < 90; i++) {
      sum += i;
      if (i == 45) %OptimizeOsr();
    }
    result = sum;
  }
  return result;
}
30
%PrepareFunctionForOptimization(bar);
31 32 33 34 35 36

test(4005, bar);

function baz() {
  let sum = 0;
  for (let i = 0; i < 2; i++) {
37
    %PrepareFunctionForOptimization(baz);
38 39 40 41 42 43 44 45 46 47 48
    sum = 2;
    %OptimizeOsr();
  }
  return sum;
}

test(2, baz);

function qux() {
  var result = 0;
  for (let i = 0; i < 2; i++) {
49
    %PrepareFunctionForOptimization(qux);
50 51 52 53 54 55 56 57 58 59 60 61
    result = i;
    %OptimizeOsr();
  }
  return result;
}

test(1, qux);

function nux() {
  var result = 0;
  for (let i = 0; i < 2; i++) {
    {
62
      %PrepareFunctionForOptimization(nux);
63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87
      let sum = i;
      %OptimizeOsr();
      result = sum;
    }
  }
  return result;
}

test(1, nux);

function blo() {
  var result;
  {
    let sum = 0;
    for (let i = 0; i < 90; i++) {
      sum += i;
      if (i == 45) %OptimizeOsr();
    }
    result = ret;
    function ret() {
      return sum;
    }
  }
  return result;
}
88
%PrepareFunctionForOptimization(blo);
89 90

test(4005, blo());