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)); |
+ } |
} |