Index: src/arm/assembler-arm.cc |
diff --git a/src/arm/assembler-arm.cc b/src/arm/assembler-arm.cc |
index a511db6f2cfcd850434544a62f5c39689750d96f..d66949cdc083e6ea3702a8a8b61fdf30aa1d87eb 100644 |
--- a/src/arm/assembler-arm.cc |
+++ b/src/arm/assembler-arm.cc |
@@ -249,6 +249,11 @@ uint32_t RelocInfo::wasm_memory_size_reference() { |
return reinterpret_cast<uint32_t>(Assembler::target_address_at(pc_, host_)); |
} |
+Address RelocInfo::wasm_global_reference() { |
+ DCHECK(IsWasmGlobalReference(rmode_)); |
+ return Assembler::target_address_at(pc_, host_); |
+} |
+ |
void RelocInfo::update_wasm_memory_reference( |
Address old_base, Address new_base, uint32_t old_size, uint32_t new_size, |
ICacheFlushMode icache_flush_mode) { |
@@ -276,6 +281,17 @@ void RelocInfo::update_wasm_memory_reference( |
} |
} |
+void RelocInfo::update_wasm_global_reference( |
+ Address old_base, Address new_base, ICacheFlushMode icache_flush_mode) { |
+ DCHECK(IsWasmGlobalReference(rmode_)); |
+ Address updated_reference; |
+ DCHECK(old_base <= wasm_global_reference()); |
+ updated_reference = new_base + (wasm_global_reference() - old_base); |
+ DCHECK(new_base <= updated_reference); |
+ Assembler::set_target_address_at(isolate_, pc_, host_, updated_reference, |
+ icache_flush_mode); |
+} |
+ |
// ----------------------------------------------------------------------------- |
// Implementation of Operand and MemOperand |
// See assembler-arm-inl.h for inlined constructors |