Commit 0e299b03 authored by Junliang Yan's avatar Junliang Yan Committed by V8 LUCI CQ

ppc: Unify Memory Operation 4

Change-Id: I57e46d779e8336b4a456b2a0932a0a6126fcb873
Reviewed-on: https://chromium-review.googlesource.com/c/v8/v8/+/2937256
Commit-Queue: Junliang Yan <junyan@redhat.com>
Commit-Queue: Milad Fa <mfarazma@redhat.com>
Auto-Submit: Junliang Yan <junyan@redhat.com>
Reviewed-by: 's avatarMilad Fa <mfarazma@redhat.com>
Cr-Commit-Position: refs/heads/master@{#74940}
parent 1caa8968
...@@ -2785,46 +2785,21 @@ void TurboAssembler::StoreU32(Register src, const MemOperand& mem, ...@@ -2785,46 +2785,21 @@ void TurboAssembler::StoreU32(Register src, const MemOperand& mem,
void TurboAssembler::LoadS16(Register dst, const MemOperand& mem, void TurboAssembler::LoadS16(Register dst, const MemOperand& mem,
Register scratch) { Register scratch) {
int offset = mem.offset(); GenerateMemoryOperation(dst, mem, lha, lhax);
if (!is_int16(offset)) {
DCHECK(scratch != no_reg);
mov(scratch, Operand(offset));
lhax(dst, MemOperand(mem.ra(), scratch));
} else {
lha(dst, mem);
}
} }
// Variable length depending on whether offset fits into immediate field // Variable length depending on whether offset fits into immediate field
// MemOperand currently only supports d-form // MemOperand currently only supports d-form
void TurboAssembler::LoadU16(Register dst, const MemOperand& mem, void TurboAssembler::LoadU16(Register dst, const MemOperand& mem,
Register scratch) { Register scratch) {
Register base = mem.ra(); GenerateMemoryOperation(dst, mem, lhz, lhzx);
int offset = mem.offset();
if (!is_int16(offset)) {
DCHECK_NE(scratch, no_reg);
mov(scratch, Operand(offset));
lhzx(dst, MemOperand(base, scratch));
} else {
lhz(dst, mem);
}
} }
// Variable length depending on whether offset fits into immediate field // Variable length depending on whether offset fits into immediate field
// MemOperand current only supports d-form // MemOperand current only supports d-form
void TurboAssembler::StoreU16(Register src, const MemOperand& mem, void TurboAssembler::StoreU16(Register src, const MemOperand& mem,
Register scratch) { Register scratch) {
Register base = mem.ra(); GenerateMemoryOperation(src, mem, sth, sthx);
int offset = mem.offset();
if (!is_int16(offset)) {
LoadIntLiteral(scratch, offset);
sthx(src, MemOperand(base, scratch));
} else {
sth(src, mem);
}
} }
// Variable length depending on whether offset fits into immediate field // Variable length depending on whether offset fits into immediate field
......
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