| Index: src/mips/macro-assembler-mips.cc
|
| diff --git a/src/mips/macro-assembler-mips.cc b/src/mips/macro-assembler-mips.cc
|
| index 52d8a4c3579f68f3bed2501ac4d5ac1bb9468006..c434c31148c38d30671ab6f13f881a2e45a15e68 100644
|
| --- a/src/mips/macro-assembler-mips.cc
|
| +++ b/src/mips/macro-assembler-mips.cc
|
| @@ -35,6 +35,7 @@
|
| #include "codegen.h"
|
| #include "cpu-profiler.h"
|
| #include "debug.h"
|
| +#include "isolate-inl.h"
|
| #include "runtime.h"
|
|
|
| namespace v8 {
|
| @@ -82,19 +83,6 @@ void MacroAssembler::StoreRoot(Register source,
|
| }
|
|
|
|
|
| -void MacroAssembler::LoadHeapObject(Register result,
|
| - Handle<HeapObject> object) {
|
| - AllowDeferredHandleDereference using_raw_address;
|
| - if (isolate()->heap()->InNewSpace(*object)) {
|
| - Handle<Cell> cell = isolate()->factory()->NewCell(object);
|
| - li(result, Operand(cell));
|
| - lw(result, FieldMemOperand(result, Cell::kValueOffset));
|
| - } else {
|
| - li(result, Operand(object));
|
| - }
|
| -}
|
| -
|
| -
|
| // Push and pop all registers that can hold pointers.
|
| void MacroAssembler::PushSafepointRegisters() {
|
| // Safepoints expect a block of kNumSafepointRegisters values on the
|
| @@ -767,6 +755,23 @@ void MacroAssembler::Ror(Register rd, Register rs, const Operand& rt) {
|
|
|
| //------------Pseudo-instructions-------------
|
|
|
| +void MacroAssembler::li(Register dst, Handle<Object> value, LiFlags mode) {
|
| + AllowDeferredHandleDereference smi_check;
|
| + if (value->IsSmi()) {
|
| + li(dst, Operand(value), mode);
|
| + } else {
|
| + ASSERT(value->IsHeapObject());
|
| + if (isolate()->heap()->InNewSpace(*value)) {
|
| + Handle<Cell> cell = isolate()->factory()->NewCell(value);
|
| + li(dst, Operand(cell));
|
| + lw(dst, FieldMemOperand(dst, Cell::kValueOffset));
|
| + } else {
|
| + li(dst, Operand(value));
|
| + }
|
| + }
|
| +}
|
| +
|
| +
|
| void MacroAssembler::li(Register rd, Operand j, LiFlags mode) {
|
| ASSERT(!j.is_reg());
|
| BlockTrampolinePoolScope block_trampoline_pool(this);
|
| @@ -3696,7 +3701,7 @@ void MacroAssembler::InvokeFunction(Handle<JSFunction> function,
|
| ASSERT(flag == JUMP_FUNCTION || has_frame());
|
|
|
| // Get the function and setup the context.
|
| - LoadHeapObject(a1, function);
|
| + li(a1, function);
|
| lw(cp, FieldMemOperand(a1, JSFunction::kContextOffset));
|
|
|
| // We call indirectly through the code field in the function to
|
| @@ -4596,19 +4601,19 @@ void MacroAssembler::Prologue(PrologueFrameMode frame_mode) {
|
| this, kNoCodeAgeSequenceLength * Assembler::kInstrSize);
|
| // The following three instructions must remain together and unmodified
|
| // for code aging to work properly.
|
| - if (FLAG_optimize_for_size && FLAG_age_code) {
|
| + if (isolate()->IsCodePreAgingActive()) {
|
| // Pre-age the code.
|
| Code* stub = Code::GetPreAgedCodeAgeStub(isolate());
|
| nop(Assembler::CODE_AGE_MARKER_NOP);
|
| // Save the function's original return address
|
| - // (it will be clobbered by Call(t9))
|
| + // (it will be clobbered by Call(t9)).
|
| mov(at, ra);
|
| - // Load the stub address to t9 and call it
|
| + // Load the stub address to t9 and call it.
|
| li(t9,
|
| Operand(reinterpret_cast<uint32_t>(stub->instruction_start())));
|
| Call(t9);
|
| - // Record the stub address in the empty space for GetCodeAgeAndParity()
|
| - dd(reinterpret_cast<uint32_t>(stub->instruction_start()));
|
| + // Record the stub address in the empty space for GetCodeAgeAndParity().
|
| + emit_code_stub_address(stub);
|
| } else {
|
| Push(ra, fp, cp, a1);
|
| nop(Assembler::CODE_AGE_SEQUENCE_NOP);
|
|
|