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

ppc: [liftoff] fix Float copysign operation

Change-Id: Icdef3916993e14e39ef9da70af128b9fde2d3b60
Reviewed-on: https://chromium-review.googlesource.com/c/v8/v8/+/3158323Reviewed-by: 's avatarMilad Fa <mfarazma@redhat.com>
Commit-Queue: Junliang Yan <junyan@redhat.com>
Cr-Commit-Position: refs/heads/main@{#76797}
parent de46367d
...@@ -3056,6 +3056,11 @@ void TurboAssembler::DivF32(DoubleRegister dst, DoubleRegister lhs, ...@@ -3056,6 +3056,11 @@ void TurboAssembler::DivF32(DoubleRegister dst, DoubleRegister lhs,
frsp(dst, dst, r); frsp(dst, dst, r);
} }
void TurboAssembler::CopySignF64(DoubleRegister dst, DoubleRegister lhs,
DoubleRegister rhs, RCBit r) {
fcpsgn(dst, rhs, lhs, r);
}
void MacroAssembler::CmpSmiLiteral(Register src1, Smi smi, Register scratch, void MacroAssembler::CmpSmiLiteral(Register src1, Smi smi, Register scratch,
CRegister cr) { CRegister cr) {
#if defined(V8_COMPRESS_POINTERS) || defined(V8_31BIT_SMIS_ON_64BIT_ARCH) #if defined(V8_COMPRESS_POINTERS) || defined(V8_31BIT_SMIS_ON_64BIT_ARCH)
......
...@@ -279,6 +279,8 @@ class V8_EXPORT_PRIVATE TurboAssembler : public TurboAssemblerBase { ...@@ -279,6 +279,8 @@ class V8_EXPORT_PRIVATE TurboAssembler : public TurboAssemblerBase {
RCBit r = LeaveRC); RCBit r = LeaveRC);
void DivF32(DoubleRegister dst, DoubleRegister lhs, DoubleRegister rhs, void DivF32(DoubleRegister dst, DoubleRegister lhs, DoubleRegister rhs,
RCBit r = LeaveRC); RCBit r = LeaveRC);
void CopySignF64(DoubleRegister dst, DoubleRegister lhs, DoubleRegister rhs,
RCBit r = LeaveRC);
void Push(Register src) { push(src); } void Push(Register src) { push(src); }
// Push a handle. // Push a handle.
......
...@@ -3688,7 +3688,7 @@ void Simulator::ExecuteGeneric(Instruction* instr) { ...@@ -3688,7 +3688,7 @@ void Simulator::ExecuteGeneric(Instruction* instr) {
int fra = instr->RAValue(); int fra = instr->RAValue();
double frb_val = get_double_from_d_register(frb); double frb_val = get_double_from_d_register(frb);
double fra_val = get_double_from_d_register(fra); double fra_val = get_double_from_d_register(fra);
double frt_val = std::copysign(fra_val, frb_val); double frt_val = std::copysign(frb_val, fra_val);
set_d_register_from_double(frt, frt_val); set_d_register_from_double(frt, frt_val);
return; return;
} }
......
...@@ -842,10 +842,10 @@ UNOP_LIST(EMIT_UNOP_FUNCTION) ...@@ -842,10 +842,10 @@ UNOP_LIST(EMIT_UNOP_FUNCTION)
// V(name, instr, dtype, stype1, stype2, dcast, scast1, scast2, rcast, // V(name, instr, dtype, stype1, stype2, dcast, scast1, scast2, rcast,
// return_val, return_type) // return_val, return_type)
#define BINOP_LIST(V) \ #define BINOP_LIST(V) \
V(f32_copysign, fcpsgn, DoubleRegister, DoubleRegister, DoubleRegister, , , \ V(f32_copysign, CopySignF64, DoubleRegister, DoubleRegister, DoubleRegister, \
, ROUND_F64_TO_F32, , void) \ , , , ROUND_F64_TO_F32, , void) \
V(f64_copysign, fcpsgn, DoubleRegister, DoubleRegister, DoubleRegister, , , \ V(f64_copysign, CopySignF64, DoubleRegister, DoubleRegister, DoubleRegister, \
, USE, , void) \ , , , USE, , void) \
V(f32_min, MinF64, DoubleRegister, DoubleRegister, DoubleRegister, , , , \ V(f32_min, MinF64, DoubleRegister, DoubleRegister, DoubleRegister, , , , \
USE, , void) \ USE, , void) \
V(f32_max, MaxF64, DoubleRegister, DoubleRegister, DoubleRegister, , , , \ V(f32_max, MaxF64, DoubleRegister, DoubleRegister, DoubleRegister, , , , \
......
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