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

ppc: Unify Memory Operation 5

Change-Id: I363e9ecdcecacca34e87086506a9cc4ab8a19d91
Reviewed-on: https://chromium-review.googlesource.com/c/v8/v8/+/2944594Reviewed-by: 's avatarMilad Fa <mfarazma@redhat.com>
Commit-Queue: Junliang Yan <junyan@redhat.com>
Commit-Queue: Milad Fa <mfarazma@redhat.com>
Auto-Submit: Junliang Yan <junyan@redhat.com>
Cr-Commit-Position: refs/heads/master@{#74996}
parent 8ab75a56
...@@ -2742,7 +2742,6 @@ void MacroAssembler::AndSmiLiteral(Register dst, Register src, Smi smi, ...@@ -2742,7 +2742,6 @@ void MacroAssembler::AndSmiLiteral(Register dst, Register src, Smi smi,
} \ } \
} }
// Load a "pointer" sized value from the memory location
void TurboAssembler::LoadU64(Register dst, const MemOperand& mem, void TurboAssembler::LoadU64(Register dst, const MemOperand& mem,
Register scratch) { Register scratch) {
GenerateMemoryOperationWithAlign(dst, mem, ld, ldx); GenerateMemoryOperationWithAlign(dst, mem, ld, ldx);
...@@ -2753,7 +2752,6 @@ void TurboAssembler::LoadU64WithUpdate(Register dst, const MemOperand& mem, ...@@ -2753,7 +2752,6 @@ void TurboAssembler::LoadU64WithUpdate(Register dst, const MemOperand& mem,
GenerateMemoryOperation(dst, mem, ldu, ldux); GenerateMemoryOperation(dst, mem, ldu, ldux);
} }
// Store a "pointer" sized value to the memory location
void TurboAssembler::StoreU64(Register src, const MemOperand& mem, void TurboAssembler::StoreU64(Register src, const MemOperand& mem,
Register scratch) { Register scratch) {
GenerateMemoryOperationWithAlign(src, mem, std, stdx); GenerateMemoryOperationWithAlign(src, mem, std, stdx);
...@@ -2769,15 +2767,11 @@ void TurboAssembler::LoadS32(Register dst, const MemOperand& mem, ...@@ -2769,15 +2767,11 @@ void TurboAssembler::LoadS32(Register dst, const MemOperand& mem,
GenerateMemoryOperationWithAlign(dst, mem, lwa, lwax); GenerateMemoryOperationWithAlign(dst, mem, lwa, lwax);
} }
// Variable length depending on whether offset fits into immediate field
// MemOperand currently only supports d-form
void TurboAssembler::LoadU32(Register dst, const MemOperand& mem, void TurboAssembler::LoadU32(Register dst, const MemOperand& mem,
Register scratch) { Register scratch) {
GenerateMemoryOperation(dst, mem, lwz, lwzx); GenerateMemoryOperation(dst, mem, lwz, lwzx);
} }
// Variable length depending on whether offset fits into immediate field
// MemOperand current only supports d-form
void TurboAssembler::StoreU32(Register src, const MemOperand& mem, void TurboAssembler::StoreU32(Register src, const MemOperand& mem,
Register scratch) { Register scratch) {
GenerateMemoryOperation(src, mem, stw, stwx); GenerateMemoryOperation(src, mem, stw, stwx);
...@@ -2788,48 +2782,24 @@ void TurboAssembler::LoadS16(Register dst, const MemOperand& mem, ...@@ -2788,48 +2782,24 @@ void TurboAssembler::LoadS16(Register dst, const MemOperand& mem,
GenerateMemoryOperation(dst, mem, lha, lhax); GenerateMemoryOperation(dst, mem, lha, lhax);
} }
// Variable length depending on whether offset fits into immediate field
// 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) {
GenerateMemoryOperation(dst, mem, lhz, lhzx); GenerateMemoryOperation(dst, mem, lhz, lhzx);
} }
// Variable length depending on whether offset fits into immediate field
// 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) {
GenerateMemoryOperation(src, mem, sth, sthx); GenerateMemoryOperation(src, mem, sth, sthx);
} }
// Variable length depending on whether offset fits into immediate field
// MemOperand currently only supports d-form
void TurboAssembler::LoadU8(Register dst, const MemOperand& mem, void TurboAssembler::LoadU8(Register dst, const MemOperand& mem,
Register scratch) { Register scratch) {
Register base = mem.ra(); GenerateMemoryOperation(dst, mem, lbz, lbzx);
int offset = mem.offset();
if (!is_int16(offset)) {
mov(scratch, Operand(offset));
lbzx(dst, MemOperand(base, scratch));
} else {
lbz(dst, mem);
}
} }
// Variable length depending on whether offset fits into immediate field
// MemOperand current only supports d-form
void TurboAssembler::StoreU8(Register src, const MemOperand& mem, void TurboAssembler::StoreU8(Register src, const MemOperand& mem,
Register scratch) { Register scratch) {
Register base = mem.ra(); GenerateMemoryOperation(src, mem, stb, stbx);
int offset = mem.offset();
if (!is_int16(offset)) {
LoadIntLiteral(scratch, offset);
stbx(src, MemOperand(base, scratch));
} else {
stb(src, mem);
}
} }
void TurboAssembler::LoadDouble(DoubleRegister dst, const MemOperand& mem, void TurboAssembler::LoadDouble(DoubleRegister dst, const MemOperand& mem,
......
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