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

// Flags: --allow-natives-syntax

function f(x, len) {
  var distraction = [];
  var result = new Array(25);

  // Create a bunch of double values with long live ranges.
  var d0 = x + 0.5;
  var d1 = x + 1.5;
  var d2 = x + 2.5;
  var d3 = x + 3.5;
  var d4 = x + 4.5;
  var d5 = x + 5.5;
  var d6 = x + 6.5;
  var d7 = x + 7.5;
  var d8 = x + 8.5;
  var d9 = x + 9.5;
  var d10 = x + 10.5;
  var d11 = x + 11.5;
  var d12 = x + 12.5;
  var d13 = x + 13.5;
  var d14 = x + 14.5;
  var d15 = x + 15.5;
  var d16 = x + 16.5;
  var d17 = x + 17.5;
  var d18 = x + 18.5;
  var d19 = x + 19.5;
  var d20 = x + 20.5;
  var d21 = x + 21.5;
  var d22 = x + 22.5;
  var d23 = x + 23.5;
  var d24 = x + 24.5;

  // Trigger a stub failure when the array grows too big.
  distraction[len] = 0;

  // Write the long-lived doubles to memory and verify them.
  result[0] = d0;
  result[1] = d1;
  result[2] = d2;
  result[3] = d3;
  result[4] = d4;
  result[5] = d5;
  result[6] = d6;
  result[7] = d7;
  result[8] = d8;
  result[9] = d9;
  result[10] = d10;
  result[11] = d11;
  result[12] = d12;
  result[13] = d13;
  result[14] = d14;
  result[15] = d15;
  result[16] = d16;
  result[17] = d17;
  result[18] = d18;
  result[19] = d19;
  result[20] = d20;
  result[21] = d21;
  result[22] = d22;
  result[23] = d23;
  result[24] = d24;

  for (var i = 0; i < result.length; i++) {
    assertEquals(x + i + 0.5, result[i]);
  }
}

f(0, 10);
f(0, 10);
%OptimizeFunctionOnNextCall(f);
f(0, 80000);