| Index: test/mjsunit/debug-step-turbofan.js | 
| diff --git a/test/mjsunit/debug-step-turbofan.js b/test/mjsunit/debug-step-turbofan.js | 
| new file mode 100644 | 
| index 0000000000000000000000000000000000000000..c8c346b2c7de1e4470ff961c4be2447045a050d2 | 
| --- /dev/null | 
| +++ b/test/mjsunit/debug-step-turbofan.js | 
| @@ -0,0 +1,57 @@ | 
| +// Copyright 2014 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: --turbo-filter=g --allow-natives-syntax | 
| + | 
| +// Test that Debug::PrepareForBreakPoints can deal with turbofan code (g) | 
| +// on the stack.  Without deoptimization support, we will not be able to | 
| +// replace optimized code for g by unoptimized code with debug break slots. | 
| +// This would cause stepping to fail (V8 issue 3660). | 
| + | 
| +function f(x) { | 
| +  g(x); | 
| +  var a = 0;              // Break 6 | 
| +  return a;               // Break 7 | 
| +}                         // Break 8 | 
| + | 
| +function g(x) { | 
| +  if (x) h(); | 
| +  var a = 0;              // Break 2 | 
| +  var b = 1;              // Break 3 | 
| +  return a + b;           // Break 4 | 
| +}                         // Break 5 | 
| + | 
| +function h() { | 
| +  debugger;               // Break 0 | 
| +}                         // Break 1 | 
| + | 
| +Debug = debug.Debug; | 
| +var exception = null; | 
| +var break_count = 0; | 
| + | 
| +function listener(event, exec_state, event_data, data) { | 
| +  if (event != Debug.DebugEvent.Break) return; | 
| +  try { | 
| +    exec_state.prepareStep(Debug.StepAction.StepNext, 1); | 
| +    print(exec_state.frame(0).sourceLineText()); | 
| +    var match = exec_state.frame(0).sourceLineText().match(/Break (\d)/); | 
| +    assertNotNull(match); | 
| +    assertEquals(break_count++, parseInt(match[1])); | 
| +  } catch (e) { | 
| +    print(e + e.stack); | 
| +    exception = e; | 
| +  } | 
| +} | 
| + | 
| +f(0); | 
| +f(0); | 
| +%OptimizeFunctionOnNextCall(g); | 
| + | 
| +Debug.setListener(listener); | 
| + | 
| +f(1); | 
| + | 
| +Debug.setListener(null);  // Break 9 | 
| +assertNull(exception); | 
| +assertEquals(10, break_count); | 
|  |