Index: src/compiler/ia32/code-generator-ia32.cc |
diff --git a/src/compiler/ia32/code-generator-ia32.cc b/src/compiler/ia32/code-generator-ia32.cc |
index 316333ba89aa481830499c5e0b3df95c6d5c4308..5525fdcc54ee10aa27e7fa0b4efd983a523d397f 100644 |
--- a/src/compiler/ia32/code-generator-ia32.cc |
+++ b/src/compiler/ia32/code-generator-ia32.cc |
@@ -1093,8 +1093,13 @@ void CodeGenerator::AssemblePrologue() { |
osr_pc_offset_ = __ pc_offset(); |
// TODO(titzer): cannot address target function == local #-1 |
__ mov(edi, Operand(ebp, JavaScriptFrameConstants::kFunctionOffset)); |
- DCHECK(stack_slots >= frame()->GetOsrStackSlotCount()); |
- stack_slots -= frame()->GetOsrStackSlotCount(); |
+ int osr_stack_slot_count = frame()->GetOsrStackSlotCount(); |
+ DCHECK(stack_slots >= osr_stack_slot_count); |
+ stack_slots -= osr_stack_slot_count; |
+ |
+ // Full-code javascript functions have a type feedback vector in the frame. |
+ // Shift any locals down one slot, and adjust the stack pointer. |
+ __ AdaptUnoptimizedFrameForOsrEntry(osr_stack_slot_count, ebx, eax); |
} |
if (stack_slots > 0) { |