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

ppc: [liftoff] implement count leading/trailing zeros

Change-Id: Ib10b00443fe1d46ccb75bd93ec0c855919bb563d
Reviewed-on: https://chromium-review.googlesource.com/c/v8/v8/+/3058295Reviewed-by: 's avatarMilad Fa <mfarazma@redhat.com>
Commit-Queue: Junliang Yan <junyan@redhat.com>
Cr-Commit-Position: refs/heads/master@{#75964}
parent dc49fe06
...@@ -3573,6 +3573,24 @@ void TurboAssembler::Popcnt32(Register dst, Register src) { popcntw(dst, src); } ...@@ -3573,6 +3573,24 @@ void TurboAssembler::Popcnt32(Register dst, Register src) { popcntw(dst, src); }
void TurboAssembler::Popcnt64(Register dst, Register src) { popcntd(dst, src); } void TurboAssembler::Popcnt64(Register dst, Register src) { popcntd(dst, src); }
void TurboAssembler::CountLeadingZerosU32(Register dst, Register src, RCBit r) {
cntlzw(dst, src, r);
}
void TurboAssembler::CountLeadingZerosU64(Register dst, Register src, RCBit r) {
cntlzd(dst, src, r);
}
void TurboAssembler::CountTrailingZerosU32(Register dst, Register src,
RCBit r) {
cnttzw(dst, src, r);
}
void TurboAssembler::CountTrailingZerosU64(Register dst, Register src,
RCBit r) {
cnttzd(dst, src, r);
}
} // namespace internal } // namespace internal
} // namespace v8 } // namespace v8
......
...@@ -238,6 +238,11 @@ class V8_EXPORT_PRIVATE TurboAssembler : public TurboAssemblerBase { ...@@ -238,6 +238,11 @@ class V8_EXPORT_PRIVATE TurboAssembler : public TurboAssemblerBase {
void ShiftRightS32(Register dst, Register src, Register value, void ShiftRightS32(Register dst, Register src, Register value,
RCBit r = LeaveRC); RCBit r = LeaveRC);
void CountLeadingZerosU32(Register dst, Register src, RCBit r = LeaveRC);
void CountLeadingZerosU64(Register dst, Register src, RCBit r = LeaveRC);
void CountTrailingZerosU32(Register dst, Register src, RCBit r = LeaveRC);
void CountTrailingZerosU64(Register dst, Register src, RCBit r = LeaveRC);
void AddF64(DoubleRegister dst, DoubleRegister lhs, DoubleRegister rhs, void AddF64(DoubleRegister dst, DoubleRegister lhs, DoubleRegister rhs,
RCBit r = LeaveRC); RCBit r = LeaveRC);
void SubF64(DoubleRegister dst, DoubleRegister lhs, DoubleRegister rhs, void SubF64(DoubleRegister dst, DoubleRegister lhs, DoubleRegister rhs,
......
...@@ -784,8 +784,6 @@ void LiftoffAssembler::FillStackSlotsWithZero(int start, int size) { ...@@ -784,8 +784,6 @@ void LiftoffAssembler::FillStackSlotsWithZero(int start, int size) {
bailout(kUnsupportedArchitecture, "i64 shiftop: " #name); \ bailout(kUnsupportedArchitecture, "i64 shiftop: " #name); \
} }
UNIMPLEMENTED_GP_UNOP(i32_clz)
UNIMPLEMENTED_GP_UNOP(i32_ctz)
UNIMPLEMENTED_FP_BINOP(f32_copysign) UNIMPLEMENTED_FP_BINOP(f32_copysign)
UNIMPLEMENTED_FP_UNOP(f32_abs) UNIMPLEMENTED_FP_UNOP(f32_abs)
UNIMPLEMENTED_FP_UNOP(f32_neg) UNIMPLEMENTED_FP_UNOP(f32_neg)
...@@ -825,9 +823,15 @@ UNIMPLEMENTED_FP_UNOP(f64_sqrt) ...@@ -825,9 +823,15 @@ UNIMPLEMENTED_FP_UNOP(f64_sqrt)
#define LFR_TO_REG(reg) reg.gp() #define LFR_TO_REG(reg) reg.gp()
// V(name, instr, dtype, stype, dcast, scast, rcast, return_val, return_type) // V(name, instr, dtype, stype, dcast, scast, rcast, return_val, return_type)
#define UNOP_LIST(V) \ #define UNOP_LIST(V) \
V(i32_popcnt, Popcnt32, Register, Register, , , USE, true, bool) \ V(i32_clz, CountLeadingZerosU32, Register, Register, , , USE, , void) \
V(i64_popcnt, Popcnt64, LiftoffRegister, LiftoffRegister, LFR_TO_REG, \ V(i32_ctz, CountTrailingZerosU32, Register, Register, , , USE, , void) \
V(i64_clz, CountLeadingZerosU64, LiftoffRegister, LiftoffRegister, \
LFR_TO_REG, LFR_TO_REG, USE, , void) \
V(i64_ctz, CountTrailingZerosU64, LiftoffRegister, LiftoffRegister, \
LFR_TO_REG, LFR_TO_REG, USE, , void) \
V(i32_popcnt, Popcnt32, Register, Register, , , USE, true, bool) \
V(i64_popcnt, Popcnt64, LiftoffRegister, LiftoffRegister, LFR_TO_REG, \
LFR_TO_REG, USE, true, bool) LFR_TO_REG, USE, true, bool)
#define EMIT_UNOP_FUNCTION(name, instr, dtype, stype, dcast, scast, rcast, \ #define EMIT_UNOP_FUNCTION(name, instr, dtype, stype, dcast, scast, rcast, \
...@@ -996,14 +1000,6 @@ bool LiftoffAssembler::emit_i64_remu(LiftoffRegister dst, LiftoffRegister lhs, ...@@ -996,14 +1000,6 @@ bool LiftoffAssembler::emit_i64_remu(LiftoffRegister dst, LiftoffRegister lhs,
return true; return true;
} }
void LiftoffAssembler::emit_i64_clz(LiftoffRegister dst, LiftoffRegister src) {
bailout(kUnsupportedArchitecture, "i64_clz");
}
void LiftoffAssembler::emit_i64_ctz(LiftoffRegister dst, LiftoffRegister src) {
bailout(kUnsupportedArchitecture, "i64_ctz");
}
void LiftoffAssembler::emit_u32_to_intptr(Register dst, Register src) { void LiftoffAssembler::emit_u32_to_intptr(Register dst, Register src) {
#ifdef V8_TARGET_ARCH_PPC64 #ifdef V8_TARGET_ARCH_PPC64
bailout(kUnsupportedArchitecture, "emit_u32_to_intptr"); bailout(kUnsupportedArchitecture, "emit_u32_to_intptr");
......
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