Commit 3f064b53 authored by Zhao Jiazhong's avatar Zhao Jiazhong Committed by Commit Bot

[mips][wasm-simd][liftoff] Implement S8x16Shuffle

Port df2ab0f0
https://crrev.com/c/2219688

Change-Id: I5183d883a8bc34723efadde4782301f205273bb6
Reviewed-on: https://chromium-review.googlesource.com/c/v8/v8/+/2233436Reviewed-by: 's avatarClemens Backes <clemensb@chromium.org>
Commit-Queue: Zhao Jiazhong <zhaojiazhong-hf@loongson.cn>
Cr-Commit-Position: refs/heads/master@{#68224}
parent ccba3aa8
...@@ -1574,6 +1574,13 @@ void LiftoffAssembler::LoadTransform(LiftoffRegister dst, Register src_addr, ...@@ -1574,6 +1574,13 @@ void LiftoffAssembler::LoadTransform(LiftoffRegister dst, Register src_addr,
bailout(kSimd, "load extend and load splat unimplemented"); bailout(kSimd, "load extend and load splat unimplemented");
} }
void LiftoffAssembler::emit_s8x16_shuffle(LiftoffRegister dst,
LiftoffRegister lhs,
LiftoffRegister rhs,
const uint8_t shuffle[16]) {
bailout(kSimd, "emit_s8x16_shuffle");
}
void LiftoffAssembler::emit_s8x16_swizzle(LiftoffRegister dst, void LiftoffAssembler::emit_s8x16_swizzle(LiftoffRegister dst,
LiftoffRegister lhs, LiftoffRegister lhs,
LiftoffRegister rhs) { LiftoffRegister rhs) {
......
...@@ -1459,6 +1459,38 @@ void LiftoffAssembler::LoadTransform(LiftoffRegister dst, Register src_addr, ...@@ -1459,6 +1459,38 @@ void LiftoffAssembler::LoadTransform(LiftoffRegister dst, Register src_addr,
} }
} }
void LiftoffAssembler::emit_s8x16_shuffle(LiftoffRegister dst,
LiftoffRegister lhs,
LiftoffRegister rhs,
const uint8_t shuffle[16]) {
MSARegister dst_msa = dst.fp().toW();
MSARegister lhs_msa = lhs.fp().toW();
MSARegister rhs_msa = rhs.fp().toW();
uint64_t control_hi = 0;
uint64_t control_low = 0;
for (int i = 7; i >= 0; i--) {
control_hi <<= 8;
control_hi |= shuffle[i + 8];
control_low <<= 8;
control_low |= shuffle[i];
}
if (dst_msa == lhs_msa) {
move_v(kSimd128ScratchReg, lhs_msa);
lhs_msa = kSimd128ScratchReg;
} else if (dst_msa == rhs_msa) {
move_v(kSimd128ScratchReg, rhs_msa);
rhs_msa = kSimd128ScratchReg;
}
li(kScratchReg, control_low);
insert_d(dst_msa, 0, kScratchReg);
li(kScratchReg, control_hi);
insert_d(dst_msa, 1, kScratchReg);
vshf_b(dst_msa, rhs_msa, lhs_msa);
}
void LiftoffAssembler::emit_s8x16_swizzle(LiftoffRegister dst, void LiftoffAssembler::emit_s8x16_swizzle(LiftoffRegister dst,
LiftoffRegister lhs, LiftoffRegister lhs,
LiftoffRegister rhs) { LiftoffRegister rhs) {
......
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