[mips][wasm-simd][liftoff] Implement splat for i64x2, f64x2, i8x16
Port 9245e3b498
https://crrev.com/c/2049247
Change-Id: Ic2df706a4d5f7df8a2cdb4f53c4679cf96f0b8b8
Reviewed-on: https://chromium-review.googlesource.com/c/v8/v8/+/2086535
Reviewed-by: Clemens Backes <clemensb@chromium.org>
Reviewed-by: Zhi An Ng <zhin@chromium.org>
Commit-Queue: Clemens Backes <clemensb@chromium.org>
Cr-Commit-Position: refs/heads/master@{#66594}
This commit is contained in:
parent
f0bfa9ea1a
commit
6f2c7b1354
@ -1532,6 +1532,14 @@ void LiftoffAssembler::emit_f64_set_cond(Condition cond, Register dst,
|
||||
bind(&cont);
|
||||
}
|
||||
|
||||
void LiftoffAssembler::emit_f64x2_splat(LiftoffRegister dst,
|
||||
LiftoffRegister src) {
|
||||
// TODO(mips): Support this on loongson 3a4000. Currently, the main MIPS
|
||||
// CPU, Loongson 3a3000 does not support MSA(simd128), but the upcoming
|
||||
// 3a4000 support MSA.
|
||||
bailout(kSimd, "emit_f64x2_splat");
|
||||
}
|
||||
|
||||
void LiftoffAssembler::emit_f32x4_splat(LiftoffRegister dst,
|
||||
LiftoffRegister src) {
|
||||
// TODO(mips): Support this on loongson 3a4000. Currently, the main MIPS
|
||||
@ -1540,6 +1548,14 @@ void LiftoffAssembler::emit_f32x4_splat(LiftoffRegister dst,
|
||||
bailout(kSimd, "emit_f32x4_splat");
|
||||
}
|
||||
|
||||
void LiftoffAssembler::emit_i64x2_splat(LiftoffRegister dst,
|
||||
LiftoffRegister src) {
|
||||
// TODO(mips): Support this on loongson 3a4000. Currently, the main MIPS
|
||||
// CPU, Loongson 3a3000 does not support MSA(simd128), but the upcoming
|
||||
// 3a4000 support MSA.
|
||||
bailout(kSimd, "emit_i64x2_splat");
|
||||
}
|
||||
|
||||
void LiftoffAssembler::emit_i32x4_splat(LiftoffRegister dst,
|
||||
LiftoffRegister src) {
|
||||
// TODO(mips): Support this on loongson 3a4000. Currently, the main MIPS
|
||||
@ -1556,6 +1572,14 @@ void LiftoffAssembler::emit_i16x8_splat(LiftoffRegister dst,
|
||||
bailout(kSimd, "emit_i16x8_splat");
|
||||
}
|
||||
|
||||
void LiftoffAssembler::emit_i8x16_splat(LiftoffRegister dst,
|
||||
LiftoffRegister src) {
|
||||
// TODO(mips): Support this on loongson 3a4000. Currently, the main MIPS
|
||||
// CPU, Loongson 3a3000 does not support MSA(simd128), but the upcoming
|
||||
// 3a4000 support MSA.
|
||||
bailout(kSimd, "emit_i8x16_splat");
|
||||
}
|
||||
|
||||
void LiftoffAssembler::StackCheck(Label* ool_code, Register limit_address) {
|
||||
TurboAssembler::Ulw(limit_address, MemOperand(limit_address));
|
||||
TurboAssembler::Branch(ool_code, ule, sp, Operand(limit_address));
|
||||
|
@ -1324,6 +1324,14 @@ void LiftoffAssembler::emit_f64_set_cond(Condition cond, Register dst,
|
||||
bind(&cont);
|
||||
}
|
||||
|
||||
void LiftoffAssembler::emit_f64x2_splat(LiftoffRegister dst,
|
||||
LiftoffRegister src) {
|
||||
// TODO(mips): Support this on loongson 3a4000. Currently, the main MIPS
|
||||
// CPU, Loongson 3a3000 does not support MSA(simd128), but the upcoming
|
||||
// 3a4000 support MSA.
|
||||
bailout(kSimd, "emit_f64x2_splat");
|
||||
}
|
||||
|
||||
void LiftoffAssembler::emit_f32x4_splat(LiftoffRegister dst,
|
||||
LiftoffRegister src) {
|
||||
// TODO(mips): Support this on loongson 3a4000. Currently, the main MIPS
|
||||
@ -1332,6 +1340,14 @@ void LiftoffAssembler::emit_f32x4_splat(LiftoffRegister dst,
|
||||
bailout(kSimd, "emit_f32x4_splat");
|
||||
}
|
||||
|
||||
void LiftoffAssembler::emit_i64x2_splat(LiftoffRegister dst,
|
||||
LiftoffRegister src) {
|
||||
// TODO(mips): Support this on loongson 3a4000. Currently, the main MIPS
|
||||
// CPU, Loongson 3a3000 does not support MSA(simd128), but the upcoming
|
||||
// 3a4000 support MSA.
|
||||
bailout(kSimd, "emit_i64x2_splat");
|
||||
}
|
||||
|
||||
void LiftoffAssembler::emit_i32x4_splat(LiftoffRegister dst,
|
||||
LiftoffRegister src) {
|
||||
// TODO(mips): Support this on loongson 3a4000. Currently, the main MIPS
|
||||
@ -1348,6 +1364,14 @@ void LiftoffAssembler::emit_i16x8_splat(LiftoffRegister dst,
|
||||
bailout(kSimd, "emit_i16x8_splat");
|
||||
}
|
||||
|
||||
void LiftoffAssembler::emit_i8x16_splat(LiftoffRegister dst,
|
||||
LiftoffRegister src) {
|
||||
// TODO(mips): Support this on loongson 3a4000. Currently, the main MIPS
|
||||
// CPU, Loongson 3a3000 does not support MSA(simd128), but the upcoming
|
||||
// 3a4000 support MSA.
|
||||
bailout(kSimd, "emit_i8x16_splat");
|
||||
}
|
||||
|
||||
void LiftoffAssembler::StackCheck(Label* ool_code, Register limit_address) {
|
||||
TurboAssembler::Uld(limit_address, MemOperand(limit_address));
|
||||
TurboAssembler::Branch(ool_code, ule, sp, Operand(limit_address));
|
||||
|
Loading…
Reference in New Issue
Block a user