Commit a1616e6f authored by Andreas Haas's avatar Andreas Haas Committed by Commit Bot

[wasm][liftoff][arm] Record correct offset in StoreTaggedPointer

The write barrier for storing a reference to an object requires the
destination offset as a parameter. The existing code only passed the
immediate offset, however, not the offset provided through a register.
With this CL, the correct offset is provided.

R=thibaudm@chromium.org

Bug: v8:7581
Change-Id: Ia2a1d90d822988a3ef0c27ce8227f28f0226c937
Reviewed-on: https://chromium-review.googlesource.com/c/v8/v8/+/2639766Reviewed-by: 's avatarThibaud Michaud <thibaudm@chromium.org>
Commit-Queue: Andreas Haas <ahaas@chromium.org>
Cr-Commit-Position: refs/heads/master@{#72194}
parent 14ad529b
...@@ -703,13 +703,17 @@ void LiftoffAssembler::StoreTaggedPointer(Register dst_addr, ...@@ -703,13 +703,17 @@ void LiftoffAssembler::StoreTaggedPointer(Register dst_addr,
LiftoffRegister src, LiftoffRegister src,
LiftoffRegList pinned) { LiftoffRegList pinned) {
STATIC_ASSERT(kTaggedSize == kInt32Size); STATIC_ASSERT(kTaggedSize == kInt32Size);
{ Register actual_offset_reg = offset_reg;
// Store the value. if (offset_reg != no_reg && offset_imm != 0) {
UseScratchRegisterScope temps(this); if (cache_state()->is_used(LiftoffRegister(offset_reg))) {
MemOperand dst_op = actual_offset_reg = GetUnusedRegister(kGpReg, pinned).gp();
liftoff::GetMemOp(this, &temps, dst_addr, offset_reg, offset_imm); }
str(src.gp(), dst_op); add(actual_offset_reg, offset_reg, Operand(offset_imm));
} }
MemOperand dst_op = actual_offset_reg == no_reg
? MemOperand(dst_addr, offset_imm)
: MemOperand(dst_addr, actual_offset_reg);
str(src.gp(), dst_op);
// The write barrier. // The write barrier.
Label write_barrier; Label write_barrier;
Label exit; Label exit;
...@@ -720,8 +724,11 @@ void LiftoffAssembler::StoreTaggedPointer(Register dst_addr, ...@@ -720,8 +724,11 @@ void LiftoffAssembler::StoreTaggedPointer(Register dst_addr,
JumpIfSmi(src.gp(), &exit); JumpIfSmi(src.gp(), &exit);
CheckPageFlag(src.gp(), MemoryChunk::kPointersToHereAreInterestingMask, eq, CheckPageFlag(src.gp(), MemoryChunk::kPointersToHereAreInterestingMask, eq,
&exit); &exit);
CallRecordWriteStub(dst_addr, Operand(offset_imm), EMIT_REMEMBERED_SET, CallRecordWriteStub(dst_addr,
kSaveFPRegs, wasm::WasmCode::kRecordWrite); actual_offset_reg == no_reg ? Operand(offset_imm)
: Operand(actual_offset_reg),
EMIT_REMEMBERED_SET, kSaveFPRegs,
wasm::WasmCode::kRecordWrite);
bind(&exit); bind(&exit);
} }
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment