Index: src/x64/assembler-x64-inl.h |
diff --git a/src/x64/assembler-x64-inl.h b/src/x64/assembler-x64-inl.h |
index 073fcbe8e944902ac096b63f91b976bd3acd1ea0..d487d83e7b3cdad653269b63f7d410542686be6a 100644 |
--- a/src/x64/assembler-x64-inl.h |
+++ b/src/x64/assembler-x64-inl.h |
@@ -205,12 +205,15 @@ void Assembler::emit_optional_rex_32(const Operand& op) { |
} |
-Address Assembler::target_address_at(Address pc) { |
+Address Assembler::target_address_at(Address pc, |
+ ConstantPoolArray* constant_pool) { |
return Memory::int32_at(pc) + pc + 4; |
} |
-void Assembler::set_target_address_at(Address pc, Address target) { |
+void Assembler::set_target_address_at(Address pc, |
+ ConstantPoolArray* constant_pool, |
+ Address target) { |
Memory::int32_at(pc) = static_cast<int32_t>(target - pc - 4); |
CPU::FlushICache(pc, sizeof(int32_t)); |
} |
@@ -255,7 +258,7 @@ void RelocInfo::apply(intptr_t delta) { |
Address RelocInfo::target_address() { |
ASSERT(IsCodeTarget(rmode_) || IsRuntimeEntry(rmode_)); |
- return Assembler::target_address_at(pc_); |
+ return Assembler::target_address_at(pc_, host_); |
} |
@@ -278,7 +281,7 @@ int RelocInfo::target_address_size() { |
void RelocInfo::set_target_address(Address target, WriteBarrierMode mode) { |
ASSERT(IsCodeTarget(rmode_) || IsRuntimeEntry(rmode_)); |
- Assembler::set_target_address_at(pc_, target); |
+ Assembler::set_target_address_at(pc_, host_, target); |
if (mode == UPDATE_WRITE_BARRIER && host() != NULL && IsCodeTarget(rmode_)) { |
Object* target_code = Code::GetCodeFromTargetAddress(target); |
host()->GetHeap()->incremental_marking()->RecordWriteIntoCode( |
@@ -369,7 +372,7 @@ void RelocInfo::WipeOut() { |
Memory::Address_at(pc_) = NULL; |
} else if (IsCodeTarget(rmode_) || IsRuntimeEntry(rmode_)) { |
// Effectively write zero into the relocation. |
- Assembler::set_target_address_at(pc_, pc_ + sizeof(int32_t)); |
+ Assembler::set_target_address_at(pc_, host_, pc_ + sizeof(int32_t)); |
} else { |
UNREACHABLE(); |
} |
@@ -408,14 +411,14 @@ Code* RelocInfo::code_age_stub() { |
ASSERT(rmode_ == RelocInfo::CODE_AGE_SEQUENCE); |
ASSERT(*pc_ == kCallOpcode); |
return Code::GetCodeFromTargetAddress( |
- Assembler::target_address_at(pc_ + 1)); |
+ Assembler::target_address_at(pc_ + 1, host_)); |
} |
void RelocInfo::set_code_age_stub(Code* stub) { |
ASSERT(*pc_ == kCallOpcode); |
ASSERT(rmode_ == RelocInfo::CODE_AGE_SEQUENCE); |
- Assembler::set_target_address_at(pc_ + 1, stub->instruction_start()); |
+ Assembler::set_target_address_at(pc_ + 1, host_, stub->instruction_start()); |
} |