| Index: test/mjsunit/compiler/osr-maze1.js | 
| diff --git a/test/mjsunit/compiler/osr-maze1.js b/test/mjsunit/compiler/osr-maze1.js | 
| new file mode 100644 | 
| index 0000000000000000000000000000000000000000..87d85c8d8624bdd4c44d2a8c406b831a30439962 | 
| --- /dev/null | 
| +++ b/test/mjsunit/compiler/osr-maze1.js | 
| @@ -0,0 +1,52 @@ | 
| +// 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 --turbo-deoptimization | 
| + | 
| +function bar(goal) { | 
| +  var count = 0; | 
| +  var sum = 11; | 
| +  var i = 35; | 
| +  while (i-- > 33) { | 
| +    if (count++ == goal) %OptimizeOsr(); | 
| +    sum = sum + i; | 
| +  } | 
| +  while (i-- > 31) { | 
| +    if (count++ == goal) %OptimizeOsr(); | 
| +    j = 9; | 
| +    while (j-- > 7) { | 
| +      if (count++ == goal) %OptimizeOsr(); | 
| +      sum = sum + j * 3; | 
| +    } | 
| +    while (j-- > 5) { | 
| +      if (count++ == goal) %OptimizeOsr(); | 
| +      sum = sum + j * 5; | 
| +    } | 
| +  } | 
| +  while (i-- > 29) { | 
| +    if (count++ == goal) %OptimizeOsr(); | 
| +    while (j-- > 3) { | 
| +      var k = 10; | 
| +      if (count++ == goal) %OptimizeOsr(); | 
| +      while (k-- > 8) { | 
| +        if (count++ == goal) %OptimizeOsr(); | 
| +        sum = sum + k * 11; | 
| +      } | 
| +    } | 
| +    while (j-- > 1) { | 
| +      if (count++ == goal) %OptimizeOsr(); | 
| +      while (k-- > 6) { | 
| +        if (count++ == goal) %OptimizeOsr(); | 
| +        sum = sum + j * 13; | 
| +      } | 
| +    } | 
| +  } | 
| +  print(count); | 
| +  return sum; | 
| +} | 
| + | 
| +for (var i = 0; i < 13; i++) { | 
| +  %DeoptimizeFunction(bar); | 
| +  assertEquals(348, bar(i)); | 
| +} | 
|  |