Index: test/mjsunit/regress/regress-4800.js |
diff --git a/test/mjsunit/regress/regress-4800.js b/test/mjsunit/regress/regress-4800.js |
new file mode 100644 |
index 0000000000000000000000000000000000000000..af7cbc0b8f42d953cb44e9b72f84ecbd79cea8ec |
--- /dev/null |
+++ b/test/mjsunit/regress/regress-4800.js |
@@ -0,0 +1,76 @@ |
+// 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); |