Index: src/compiler/mips64/code-generator-mips64.cc |
diff --git a/src/compiler/mips64/code-generator-mips64.cc b/src/compiler/mips64/code-generator-mips64.cc |
index c72d9789b846a0013d1eb91de4fca8180a957ace..670bd67435cb176bfdaf9c4c45235c918002c295 100644 |
--- a/src/compiler/mips64/code-generator-mips64.cc |
+++ b/src/compiler/mips64/code-generator-mips64.cc |
@@ -1428,21 +1428,23 @@ void CodeGenerator::AddNopForSmiCodeInlining() { |
void CodeGenerator::EnsureSpaceForLazyDeopt() { |
+ if (!info()->ShouldEnsureSpaceForLazyDeopt()) { |
+ return; |
+ } |
+ |
int space_needed = Deoptimizer::patch_size(); |
- if (!info()->IsStub()) { |
- // Ensure that we have enough space after the previous lazy-bailout |
- // instruction for patching the code here. |
- int current_pc = masm()->pc_offset(); |
- if (current_pc < last_lazy_deopt_pc_ + space_needed) { |
- // Block tramoline pool emission for duration of padding. |
- v8::internal::Assembler::BlockTrampolinePoolScope block_trampoline_pool( |
- masm()); |
- int padding_size = last_lazy_deopt_pc_ + space_needed - current_pc; |
- DCHECK_EQ(0, padding_size % v8::internal::Assembler::kInstrSize); |
- while (padding_size > 0) { |
- __ nop(); |
- padding_size -= v8::internal::Assembler::kInstrSize; |
- } |
+ // Ensure that we have enough space after the previous lazy-bailout |
+ // instruction for patching the code here. |
+ int current_pc = masm()->pc_offset(); |
+ if (current_pc < last_lazy_deopt_pc_ + space_needed) { |
+ // Block tramoline pool emission for duration of padding. |
+ v8::internal::Assembler::BlockTrampolinePoolScope block_trampoline_pool( |
+ masm()); |
+ int padding_size = last_lazy_deopt_pc_ + space_needed - current_pc; |
+ DCHECK_EQ(0, padding_size % v8::internal::Assembler::kInstrSize); |
+ while (padding_size > 0) { |
+ __ nop(); |
+ padding_size -= v8::internal::Assembler::kInstrSize; |
} |
} |
} |