| Index: src/ia32/assembler-ia32-inl.h
|
| diff --git a/src/ia32/assembler-ia32-inl.h b/src/ia32/assembler-ia32-inl.h
|
| index 32ed3d81f17adf588d1f465984817df48a9ac944..913e1c1aaa8381c3700291ce772335e117dd4e20 100644
|
| --- a/src/ia32/assembler-ia32-inl.h
|
| +++ b/src/ia32/assembler-ia32-inl.h
|
| @@ -53,34 +53,35 @@ static const int kNoCodeAgeSequenceLength = 5;
|
|
|
|
|
| // The modes possibly affected by apply must be in kApplyMask.
|
| -void RelocInfo::apply(intptr_t delta) {
|
| +void RelocInfo::apply(intptr_t delta, ICacheFlushMode icache_flush_mode) {
|
| + bool flush_icache = icache_flush_mode != SKIP_ICACHE_FLUSH;
|
| if (IsRuntimeEntry(rmode_) || IsCodeTarget(rmode_)) {
|
| int32_t* p = reinterpret_cast<int32_t*>(pc_);
|
| *p -= delta; // Relocate entry.
|
| - CPU::FlushICache(p, sizeof(uint32_t));
|
| + if (flush_icache) CPU::FlushICache(p, sizeof(uint32_t));
|
| } else if (rmode_ == CODE_AGE_SEQUENCE) {
|
| if (*pc_ == kCallOpcode) {
|
| int32_t* p = reinterpret_cast<int32_t*>(pc_ + 1);
|
| *p -= delta; // Relocate entry.
|
| - CPU::FlushICache(p, sizeof(uint32_t));
|
| + if (flush_icache) CPU::FlushICache(p, sizeof(uint32_t));
|
| }
|
| } else if (rmode_ == JS_RETURN && IsPatchedReturnSequence()) {
|
| // Special handling of js_return when a break point is set (call
|
| // instruction has been inserted).
|
| int32_t* p = reinterpret_cast<int32_t*>(pc_ + 1);
|
| *p -= delta; // Relocate entry.
|
| - CPU::FlushICache(p, sizeof(uint32_t));
|
| + if (flush_icache) CPU::FlushICache(p, sizeof(uint32_t));
|
| } else if (rmode_ == DEBUG_BREAK_SLOT && IsPatchedDebugBreakSlotSequence()) {
|
| // Special handling of a debug break slot when a break point is set (call
|
| // instruction has been inserted).
|
| int32_t* p = reinterpret_cast<int32_t*>(pc_ + 1);
|
| *p -= delta; // Relocate entry.
|
| - CPU::FlushICache(p, sizeof(uint32_t));
|
| + if (flush_icache) CPU::FlushICache(p, sizeof(uint32_t));
|
| } else if (IsInternalReference(rmode_)) {
|
| // absolute code pointer inside code object moves with the code object.
|
| int32_t* p = reinterpret_cast<int32_t*>(pc_);
|
| *p += delta; // Relocate entry.
|
| - CPU::FlushICache(p, sizeof(uint32_t));
|
| + if (flush_icache) CPU::FlushICache(p, sizeof(uint32_t));
|
| }
|
| }
|
|
|
| @@ -110,10 +111,13 @@ int RelocInfo::target_address_size() {
|
| }
|
|
|
|
|
| -void RelocInfo::set_target_address(Address target, WriteBarrierMode mode) {
|
| - Assembler::set_target_address_at(pc_, host_, target);
|
| +void RelocInfo::set_target_address(Address target,
|
| + WriteBarrierMode write_barrier_mode,
|
| + ICacheFlushMode icache_flush_mode) {
|
| + Assembler::set_target_address_at(pc_, host_, target, icache_flush_mode);
|
| ASSERT(IsCodeTarget(rmode_) || IsRuntimeEntry(rmode_));
|
| - if (mode == UPDATE_WRITE_BARRIER && host() != NULL && IsCodeTarget(rmode_)) {
|
| + if (write_barrier_mode == UPDATE_WRITE_BARRIER && host() != NULL &&
|
| + IsCodeTarget(rmode_)) {
|
| Object* target_code = Code::GetCodeFromTargetAddress(target);
|
| host()->GetHeap()->incremental_marking()->RecordWriteIntoCode(
|
| host(), this, HeapObject::cast(target_code));
|
| @@ -133,12 +137,16 @@ Handle<Object> RelocInfo::target_object_handle(Assembler* origin) {
|
| }
|
|
|
|
|
| -void RelocInfo::set_target_object(Object* target, WriteBarrierMode mode) {
|
| +void RelocInfo::set_target_object(Object* target,
|
| + WriteBarrierMode write_barrier_mode,
|
| + ICacheFlushMode icache_flush_mode) {
|
| ASSERT(IsCodeTarget(rmode_) || rmode_ == EMBEDDED_OBJECT);
|
| ASSERT(!target->IsConsString());
|
| Memory::Object_at(pc_) = target;
|
| - CPU::FlushICache(pc_, sizeof(Address));
|
| - if (mode == UPDATE_WRITE_BARRIER &&
|
| + if (icache_flush_mode != SKIP_ICACHE_FLUSH) {
|
| + CPU::FlushICache(pc_, sizeof(Address));
|
| + }
|
| + if (write_barrier_mode == UPDATE_WRITE_BARRIER &&
|
| host() != NULL &&
|
| target->IsHeapObject()) {
|
| host()->GetHeap()->incremental_marking()->RecordWrite(
|
| @@ -160,9 +168,12 @@ Address RelocInfo::target_runtime_entry(Assembler* origin) {
|
|
|
|
|
| void RelocInfo::set_target_runtime_entry(Address target,
|
| - WriteBarrierMode mode) {
|
| + WriteBarrierMode write_barrier_mode,
|
| + ICacheFlushMode icache_flush_mode) {
|
| ASSERT(IsRuntimeEntry(rmode_));
|
| - if (target_address() != target) set_target_address(target, mode);
|
| + if (target_address() != target) {
|
| + set_target_address(target, write_barrier_mode, icache_flush_mode);
|
| + }
|
| }
|
|
|
|
|
| @@ -179,12 +190,16 @@ Cell* RelocInfo::target_cell() {
|
| }
|
|
|
|
|
| -void RelocInfo::set_target_cell(Cell* cell, WriteBarrierMode mode) {
|
| +void RelocInfo::set_target_cell(Cell* cell,
|
| + WriteBarrierMode write_barrier_mode,
|
| + ICacheFlushMode icache_flush_mode) {
|
| ASSERT(rmode_ == RelocInfo::CELL);
|
| Address address = cell->address() + Cell::kValueOffset;
|
| Memory::Address_at(pc_) = address;
|
| - CPU::FlushICache(pc_, sizeof(Address));
|
| - if (mode == UPDATE_WRITE_BARRIER && host() != NULL) {
|
| + if (icache_flush_mode != SKIP_ICACHE_FLUSH) {
|
| + CPU::FlushICache(pc_, sizeof(Address));
|
| + }
|
| + if (write_barrier_mode == UPDATE_WRITE_BARRIER && host() != NULL) {
|
| // TODO(1550) We are passing NULL as a slot because cell can never be on
|
| // evacuation candidate.
|
| host()->GetHeap()->incremental_marking()->RecordWrite(
|
| @@ -208,10 +223,12 @@ Code* RelocInfo::code_age_stub() {
|
| }
|
|
|
|
|
| -void RelocInfo::set_code_age_stub(Code* stub) {
|
| +void RelocInfo::set_code_age_stub(Code* stub,
|
| + ICacheFlushMode icache_flush_mode) {
|
| ASSERT(*pc_ == kCallOpcode);
|
| ASSERT(rmode_ == RelocInfo::CODE_AGE_SEQUENCE);
|
| - Assembler::set_target_address_at(pc_ + 1, host_, stub->instruction_start());
|
| + Assembler::set_target_address_at(pc_ + 1, host_, stub->instruction_start(),
|
| + icache_flush_mode);
|
| }
|
|
|
|
|
| @@ -451,10 +468,13 @@ Address Assembler::target_address_at(Address pc,
|
|
|
| void Assembler::set_target_address_at(Address pc,
|
| ConstantPoolArray* constant_pool,
|
| - Address target) {
|
| + Address target,
|
| + ICacheFlushMode icache_flush_mode) {
|
| int32_t* p = reinterpret_cast<int32_t*>(pc);
|
| *p = target - (pc + sizeof(int32_t));
|
| - CPU::FlushICache(p, sizeof(int32_t));
|
| + if (icache_flush_mode != SKIP_ICACHE_FLUSH) {
|
| + CPU::FlushICache(p, sizeof(int32_t));
|
| + }
|
| }
|
|
|
|
|
|
|