Commit b544277a authored by George Wort's avatar George Wort Committed by Commit Bot

[liftoff][arm] Implement stack access

This adds stack access functionality for the arm32 port of Liftoff.

Bug: v8:6600
Change-Id: I163ab133efc63045f37d1387fd5f32be333bc501
Reviewed-on: https://chromium-review.googlesource.com/c/1346333
Commit-Queue: Clemens Hammacher <clemensh@chromium.org>
Reviewed-by: 's avatarClemens Hammacher <clemensh@chromium.org>
Cr-Commit-Position: refs/heads/master@{#57729}
parent 7d6beb3f
...@@ -361,7 +361,10 @@ void LiftoffAssembler::LoadCallerFrameSlot(LiftoffRegister dst, ...@@ -361,7 +361,10 @@ void LiftoffAssembler::LoadCallerFrameSlot(LiftoffRegister dst,
void LiftoffAssembler::MoveStackValue(uint32_t dst_index, uint32_t src_index, void LiftoffAssembler::MoveStackValue(uint32_t dst_index, uint32_t src_index,
ValueType type) { ValueType type) {
BAILOUT("MoveStackValue"); DCHECK_NE(dst_index, src_index);
LiftoffRegister reg = GetUnusedRegister(kGpReg);
Fill(reg, src_index, type);
Spill(dst_index, reg, type);
} }
void LiftoffAssembler::Move(Register dst, Register src, ValueType type) { void LiftoffAssembler::Move(Register dst, Register src, ValueType type) {
...@@ -377,20 +380,83 @@ void LiftoffAssembler::Move(DoubleRegister dst, DoubleRegister src, ...@@ -377,20 +380,83 @@ void LiftoffAssembler::Move(DoubleRegister dst, DoubleRegister src,
void LiftoffAssembler::Spill(uint32_t index, LiftoffRegister reg, void LiftoffAssembler::Spill(uint32_t index, LiftoffRegister reg,
ValueType type) { ValueType type) {
BAILOUT("Spill register"); RecordUsedSpillSlot(index);
MemOperand dst = liftoff::GetStackSlot(index);
switch (type) {
case kWasmI32:
str(reg.gp(), dst);
break;
case kWasmI64:
str(reg.low_gp(), dst);
str(reg.high_gp(), liftoff::GetHalfStackSlot(index, kHighWord));
break;
case kWasmF32:
BAILOUT("Spill Register f32");
break;
case kWasmF64:
vstr(reg.fp(), dst);
break;
default:
UNREACHABLE();
}
} }
void LiftoffAssembler::Spill(uint32_t index, WasmValue value) { void LiftoffAssembler::Spill(uint32_t index, WasmValue value) {
BAILOUT("Spill value"); RecordUsedSpillSlot(index);
MemOperand dst = liftoff::GetStackSlot(index);
UseScratchRegisterScope temps(this);
Register src = no_reg;
// The scratch register will be required by str if multiple instructions
// are required to encode the offset, and so we cannot use it in that case.
if (!ImmediateFitsAddrMode2Instruction(dst.offset())) {
src = GetUnusedRegister(kGpReg).gp();
} else {
src = temps.Acquire();
}
switch (value.type()) {
case kWasmI32:
mov(src, Operand(value.to_i32()));
str(src, dst);
break;
case kWasmI64: {
int32_t low_word = value.to_i64();
mov(src, Operand(low_word));
str(src, dst);
int32_t high_word = value.to_i64() >> 32;
mov(src, Operand(high_word));
str(src, liftoff::GetHalfStackSlot(index, kHighWord));
break;
}
default:
// We do not track f32 and f64 constants, hence they are unreachable.
UNREACHABLE();
}
} }
void LiftoffAssembler::Fill(LiftoffRegister reg, uint32_t index, void LiftoffAssembler::Fill(LiftoffRegister reg, uint32_t index,
ValueType type) { ValueType type) {
BAILOUT("Fill"); MemOperand src = liftoff::GetStackSlot(index);
switch (type) {
case kWasmI32:
ldr(reg.gp(), src);
break;
case kWasmI64:
ldr(reg.low_gp(), src);
ldr(reg.high_gp(), liftoff::GetHalfStackSlot(index, kHighWord));
break;
case kWasmF32:
BAILOUT("Fill Register");
break;
case kWasmF64:
vldr(reg.fp(), src);
break;
default:
UNREACHABLE();
}
} }
void LiftoffAssembler::FillI64Half(Register, uint32_t half_index) { void LiftoffAssembler::FillI64Half(Register reg, uint32_t half_index) {
BAILOUT("FillI64Half"); ldr(reg, liftoff::GetHalfStackSlot(half_index));
} }
#define UNIMPLEMENTED_GP_BINOP(name) \ #define UNIMPLEMENTED_GP_BINOP(name) \
...@@ -709,11 +775,12 @@ void LiftoffAssembler::CallRuntimeStub(WasmCode::RuntimeStubId sid) { ...@@ -709,11 +775,12 @@ void LiftoffAssembler::CallRuntimeStub(WasmCode::RuntimeStubId sid) {
} }
void LiftoffAssembler::AllocateStackSlot(Register addr, uint32_t size) { void LiftoffAssembler::AllocateStackSlot(Register addr, uint32_t size) {
BAILOUT("AllocateStackSlot"); sub(sp, sp, Operand(size));
mov(addr, sp);
} }
void LiftoffAssembler::DeallocateStackSlot(uint32_t size) { void LiftoffAssembler::DeallocateStackSlot(uint32_t size) {
BAILOUT("DeallocateStackSlot"); add(sp, sp, Operand(size));
} }
void LiftoffStackSlots::Construct() { void LiftoffStackSlots::Construct() {
......
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