// 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.

// Flags: --allow-natives-syntax --use-osr

function bar(goal) {
  var count = 0;
  var sum = 11;
  var i = 35;
  %PrepareFunctionForOptimization(bar);
  while (i-- > 33) {
    if (count++ == goal) %OptimizeOsr();
    sum = sum + i;
  }
  %PrepareFunctionForOptimization(bar);
  while (i-- > 31) {
    if (count++ == goal) %OptimizeOsr();
    j = 9;
    %PrepareFunctionForOptimization(bar);
    while (j-- > 7) {
      if (count++ == goal) %OptimizeOsr();
      sum = sum + j * 3;
    }
    %PrepareFunctionForOptimization(bar);
    while (j-- > 5) {
      if (count++ == goal) %OptimizeOsr();
      sum = sum + j * 5;
    }
  }
  while (i-- > 29) {
    %PrepareFunctionForOptimization(bar);
    if (count++ == goal) %OptimizeOsr();
    while (j-- > 3) {
      var k = 10;
      %PrepareFunctionForOptimization(bar);
      if (count++ == goal) %OptimizeOsr();
      while (k-- > 8) {
        %PrepareFunctionForOptimization(bar);
        if (count++ == goal) %OptimizeOsr();
        sum = sum + k * 11;
      }
    }
    while (j-- > 1) {
      %PrepareFunctionForOptimization(bar);
      if (count++ == goal) %OptimizeOsr();
      while (k-- > 6) {
        %PrepareFunctionForOptimization(bar);
        if (count++ == goal) %OptimizeOsr();
        sum = sum + j * 13;
      }
    }
  }
  return sum;
}
%PrepareFunctionForOptimization(bar);

for (var i = 0; i < 13; i++) {
  %DeoptimizeFunction(bar);
  assertEquals(348, bar(i));
}