Index: src/mips/lithium-codegen-mips.cc |
diff --git a/src/mips/lithium-codegen-mips.cc b/src/mips/lithium-codegen-mips.cc |
index 38b0ff5274d4c44cda241072aa8e7a7ab05a54be..5e6b7cea62ac631abd7694690527a46f6e510c7c 100644 |
--- a/src/mips/lithium-codegen-mips.cc |
+++ b/src/mips/lithium-codegen-mips.cc |
@@ -98,24 +98,6 @@ void LChunkBuilder::Abort(BailoutReason reason) { |
} |
-void LCodeGen::Comment(const char* format, ...) { |
- if (!FLAG_code_comments) return; |
- char buffer[4 * KB]; |
- StringBuilder builder(buffer, ARRAY_SIZE(buffer)); |
- va_list arguments; |
- va_start(arguments, format); |
- builder.AddFormattedList(format, arguments); |
- va_end(arguments); |
- |
- // Copy the string before recording it in the assembler to avoid |
- // issues when the stack allocated buffer goes out of scope. |
- size_t length = builder.position(); |
- Vector<char> copy = Vector<char>::New(length + 1); |
- OS::MemCopy(copy.start(), builder.Finalize(), copy.length()); |
- masm()->RecordComment(copy.start()); |
-} |
- |
- |
bool LCodeGen::GeneratePrologue() { |
ASSERT(is_generating()); |
@@ -265,37 +247,6 @@ void LCodeGen::GenerateOsrPrologue() { |
} |
-bool LCodeGen::GenerateBody() { |
- ASSERT(is_generating()); |
- bool emit_instructions = true; |
- for (current_instruction_ = 0; |
- !is_aborted() && current_instruction_ < instructions_->length(); |
- current_instruction_++) { |
- LInstruction* instr = instructions_->at(current_instruction_); |
- |
- // Don't emit code for basic blocks with a replacement. |
- if (instr->IsLabel()) { |
- emit_instructions = !LLabel::cast(instr)->HasReplacement(); |
- } |
- if (!emit_instructions) continue; |
- |
- if (FLAG_code_comments && instr->HasInterestingComment(this)) { |
- Comment(";;; <@%d,#%d> %s", |
- current_instruction_, |
- instr->hydrogen_value()->id(), |
- instr->Mnemonic()); |
- } |
- |
- RecordAndUpdatePosition(instr->position()); |
- |
- instr->CompileToNative(this); |
- } |
- EnsureSpaceForLazyDeopt(); |
- last_lazy_deopt_pc_ = masm()->pc_offset(); |
- return !is_aborted(); |
-} |
- |
- |
bool LCodeGen::GenerateDeferredCode() { |
ASSERT(is_generating()); |
if (deferred_.length() > 0) { |
@@ -703,7 +654,7 @@ void LCodeGen::CallCodeGeneric(Handle<Code> code, |
RelocInfo::Mode mode, |
LInstruction* instr, |
SafepointMode safepoint_mode) { |
- EnsureSpaceForLazyDeopt(); |
+ EnsureSpaceForLazyDeopt(Deoptimizer::patch_size()); |
ASSERT(instr != NULL); |
LPointerMap* pointers = instr->pointer_map(); |
RecordPosition(pointers->position()); |
@@ -2011,13 +1962,6 @@ void LCodeGen::DoArithmeticT(LArithmeticT* instr) { |
} |
-int LCodeGen::GetNextEmittedBlock() const { |
- for (int i = current_block_ + 1; i < graph()->blocks()->length(); ++i) { |
- if (!chunk_->GetLabel(i)->HasReplacement()) return i; |
- } |
- return -1; |
-} |
- |
template<class InstrType> |
void LCodeGen::EmitBranch(InstrType instr, |
Condition condition, |
@@ -5635,14 +5579,13 @@ void LCodeGen::EmitIsConstructCall(Register temp1, Register temp2) { |
} |
-void LCodeGen::EnsureSpaceForLazyDeopt() { |
+void LCodeGen::EnsureSpaceForLazyDeopt(int space_needed) { |
if (info()->IsStub()) return; |
// Ensure that we have enough space after the previous lazy-bailout |
// instruction for patching the code here. |
int current_pc = masm()->pc_offset(); |
- int patch_size = Deoptimizer::patch_size(); |
- if (current_pc < last_lazy_deopt_pc_ + patch_size) { |
- int padding_size = last_lazy_deopt_pc_ + patch_size - current_pc; |
+ if (current_pc < last_lazy_deopt_pc_ + space_needed) { |
+ int padding_size = last_lazy_deopt_pc_ + space_needed - current_pc; |
ASSERT_EQ(0, padding_size % Assembler::kInstrSize); |
while (padding_size > 0) { |
__ nop(); |
@@ -5653,7 +5596,7 @@ void LCodeGen::EnsureSpaceForLazyDeopt() { |
void LCodeGen::DoLazyBailout(LLazyBailout* instr) { |
- EnsureSpaceForLazyDeopt(); |
+ EnsureSpaceForLazyDeopt(Deoptimizer::patch_size()); |
last_lazy_deopt_pc_ = masm()->pc_offset(); |
ASSERT(instr->HasEnvironment()); |
LEnvironment* env = instr->environment(); |
@@ -5721,7 +5664,7 @@ void LCodeGen::DoStackCheck(LStackCheck* instr) { |
CallCode(isolate()->builtins()->StackCheck(), |
RelocInfo::CODE_TARGET, |
instr); |
- EnsureSpaceForLazyDeopt(); |
+ EnsureSpaceForLazyDeopt(Deoptimizer::patch_size()); |
last_lazy_deopt_pc_ = masm()->pc_offset(); |
__ bind(&done); |
RegisterEnvironmentForDeoptimization(env, Safepoint::kLazyDeopt); |
@@ -5733,7 +5676,7 @@ void LCodeGen::DoStackCheck(LStackCheck* instr) { |
new(zone()) DeferredStackCheck(this, instr); |
__ LoadRoot(at, Heap::kStackLimitRootIndex); |
__ Branch(deferred_stack_check->entry(), lo, sp, Operand(at)); |
- EnsureSpaceForLazyDeopt(); |
+ EnsureSpaceForLazyDeopt(Deoptimizer::patch_size()); |
last_lazy_deopt_pc_ = masm()->pc_offset(); |
__ bind(instr->done_label()); |
deferred_stack_check->SetExit(instr->done_label()); |