[ia32][wasm] Add F32x4 Add/Sub/Mul/Min/Max
Bug: Change-Id: I75de89ca895ef5a408a1d958b75dbc79d07e007a Reviewed-on: https://chromium-review.googlesource.com/856096 Reviewed-by: Bill Budge <bbudge@chromium.org> Reviewed-by: Benedikt Meurer <bmeurer@chromium.org> Commit-Queue: Jing Bao <jing.bao@intel.com> Cr-Commit-Position: refs/heads/master@{#50468}
This commit is contained in:
parent
1300f51ff6
commit
058f166bd4
@ -1660,6 +1660,61 @@ CodeGenerator::CodeGenResult CodeGenerator::AssembleArchInstruction(
|
||||
i.InputOperand(2), i.InputInt8(1) << 4);
|
||||
break;
|
||||
}
|
||||
case kSSEF32x4Add: {
|
||||
DCHECK_EQ(i.OutputSimd128Register(), i.InputSimd128Register(0));
|
||||
__ addps(i.OutputSimd128Register(), i.InputOperand(1));
|
||||
break;
|
||||
}
|
||||
case kAVXF32x4Add: {
|
||||
CpuFeatureScope avx_scope(tasm(), AVX);
|
||||
__ vaddps(i.OutputSimd128Register(), i.InputSimd128Register(0),
|
||||
i.InputOperand(1));
|
||||
break;
|
||||
}
|
||||
case kSSEF32x4Sub: {
|
||||
DCHECK_EQ(i.OutputSimd128Register(), i.InputSimd128Register(0));
|
||||
__ subps(i.OutputSimd128Register(), i.InputOperand(1));
|
||||
break;
|
||||
}
|
||||
case kAVXF32x4Sub: {
|
||||
CpuFeatureScope avx_scope(tasm(), AVX);
|
||||
__ vsubps(i.OutputSimd128Register(), i.InputSimd128Register(0),
|
||||
i.InputOperand(1));
|
||||
break;
|
||||
}
|
||||
case kSSEF32x4Mul: {
|
||||
DCHECK_EQ(i.OutputSimd128Register(), i.InputSimd128Register(0));
|
||||
__ mulps(i.OutputSimd128Register(), i.InputOperand(1));
|
||||
break;
|
||||
}
|
||||
case kAVXF32x4Mul: {
|
||||
CpuFeatureScope avx_scope(tasm(), AVX);
|
||||
__ vmulps(i.OutputSimd128Register(), i.InputSimd128Register(0),
|
||||
i.InputOperand(1));
|
||||
break;
|
||||
}
|
||||
case kSSEF32x4Min: {
|
||||
DCHECK_EQ(i.OutputSimd128Register(), i.InputSimd128Register(0));
|
||||
__ minps(i.OutputSimd128Register(), i.InputOperand(1));
|
||||
break;
|
||||
}
|
||||
case kAVXF32x4Min: {
|
||||
CpuFeatureScope avx_scope(tasm(), AVX);
|
||||
__ vminps(i.OutputSimd128Register(), i.InputSimd128Register(0),
|
||||
i.InputOperand(1));
|
||||
break;
|
||||
}
|
||||
case kSSEF32x4Max: {
|
||||
DCHECK_EQ(i.OutputSimd128Register(), i.InputSimd128Register(0));
|
||||
__ maxps(i.OutputSimd128Register(), i.InputOperand(1));
|
||||
break;
|
||||
}
|
||||
case kAVXF32x4Max: {
|
||||
CpuFeatureScope avx_scope(tasm(), AVX);
|
||||
__ vmaxps(i.OutputSimd128Register(), i.InputSimd128Register(0),
|
||||
i.InputOperand(1));
|
||||
break;
|
||||
}
|
||||
case kSSEF32x4Eq: {
|
||||
DCHECK_EQ(i.OutputSimd128Register(), i.InputSimd128Register(0));
|
||||
__ cmpeqps(i.OutputSimd128Register(), i.InputOperand(1));
|
||||
|
@ -120,6 +120,16 @@ namespace compiler {
|
||||
V(AVXF32x4ExtractLane) \
|
||||
V(SSEF32x4ReplaceLane) \
|
||||
V(AVXF32x4ReplaceLane) \
|
||||
V(SSEF32x4Add) \
|
||||
V(AVXF32x4Add) \
|
||||
V(SSEF32x4Sub) \
|
||||
V(AVXF32x4Sub) \
|
||||
V(SSEF32x4Mul) \
|
||||
V(AVXF32x4Mul) \
|
||||
V(SSEF32x4Min) \
|
||||
V(AVXF32x4Min) \
|
||||
V(SSEF32x4Max) \
|
||||
V(AVXF32x4Max) \
|
||||
V(SSEF32x4Eq) \
|
||||
V(AVXF32x4Eq) \
|
||||
V(SSEF32x4Ne) \
|
||||
|
@ -103,6 +103,16 @@ int InstructionScheduler::GetTargetInstructionFlags(
|
||||
case kAVXF32x4ExtractLane:
|
||||
case kSSEF32x4ReplaceLane:
|
||||
case kAVXF32x4ReplaceLane:
|
||||
case kSSEF32x4Add:
|
||||
case kAVXF32x4Add:
|
||||
case kSSEF32x4Sub:
|
||||
case kAVXF32x4Sub:
|
||||
case kSSEF32x4Mul:
|
||||
case kAVXF32x4Mul:
|
||||
case kSSEF32x4Min:
|
||||
case kAVXF32x4Min:
|
||||
case kSSEF32x4Max:
|
||||
case kAVXF32x4Max:
|
||||
case kSSEF32x4Eq:
|
||||
case kAVXF32x4Eq:
|
||||
case kSSEF32x4Ne:
|
||||
|
@ -1789,6 +1789,11 @@ VISIT_ATOMIC_BINOP(Xor)
|
||||
V(I8x16)
|
||||
|
||||
#define SIMD_BINOP_LIST(V) \
|
||||
V(F32x4Add) \
|
||||
V(F32x4Sub) \
|
||||
V(F32x4Mul) \
|
||||
V(F32x4Min) \
|
||||
V(F32x4Max) \
|
||||
V(F32x4Eq) \
|
||||
V(F32x4Ne) \
|
||||
V(F32x4Lt) \
|
||||
|
@ -2114,8 +2114,6 @@ void InstructionSelector::VisitF32x4Neg(Node* node) { UNIMPLEMENTED(); }
|
||||
void InstructionSelector::VisitF32x4RecipSqrtApprox(Node* node) {
|
||||
UNIMPLEMENTED();
|
||||
}
|
||||
|
||||
void InstructionSelector::VisitF32x4Add(Node* node) { UNIMPLEMENTED(); }
|
||||
#endif // !V8_TARGET_ARCH_ARM && !V8_TARGET_ARCH_ARM64 && !V8_TARGET_ARCH_MIPS
|
||||
// && !V8_TARGET_ARCH_MIPS64 && !V8_TARGET_ARCH_X64
|
||||
|
||||
@ -2127,14 +2125,6 @@ void InstructionSelector::VisitF32x4AddHoriz(Node* node) { UNIMPLEMENTED(); }
|
||||
|
||||
#if !V8_TARGET_ARCH_ARM && !V8_TARGET_ARCH_ARM64 && !V8_TARGET_ARCH_MIPS && \
|
||||
!V8_TARGET_ARCH_MIPS64 && !V8_TARGET_ARCH_X64
|
||||
void InstructionSelector::VisitF32x4Sub(Node* node) { UNIMPLEMENTED(); }
|
||||
|
||||
void InstructionSelector::VisitF32x4Mul(Node* node) { UNIMPLEMENTED(); }
|
||||
|
||||
void InstructionSelector::VisitF32x4Max(Node* node) { UNIMPLEMENTED(); }
|
||||
|
||||
void InstructionSelector::VisitF32x4Min(Node* node) { UNIMPLEMENTED(); }
|
||||
|
||||
void InstructionSelector::VisitF32x4RecipApprox(Node* node) { UNIMPLEMENTED(); }
|
||||
#endif // !V8_TARGET_ARCH_ARM && !V8_TARGET_ARCH_ARM64 && !V8_TARGET_ARCH_MIPS
|
||||
// && !V8_TARGET_ARCH_MIPS64 && !V8_TARGET_ARCH_X64
|
||||
|
@ -517,6 +517,8 @@ WASM_SIMD_COMPILED_TEST(F32x4RecipSqrtApprox) {
|
||||
RunF32x4UnOpTest(lower_simd, kExprF32x4RecipSqrtApprox, RecipSqrt,
|
||||
kApproxError);
|
||||
}
|
||||
#endif // V8_TARGET_ARCH_ARM || V8_TARGET_ARCH_ARM64 || V8_TARGET_ARCH_MIPS ||
|
||||
// V8_TARGET_ARCH_MIPS64 || V8_TARGET_ARCH_X64
|
||||
|
||||
void RunF32x4BinOpTest(LowerSimd lower_simd, WasmOpcode simd_op,
|
||||
FloatBinOp expected_op) {
|
||||
@ -552,8 +554,6 @@ WASM_SIMD_TEST(F32x4_Min) {
|
||||
WASM_SIMD_TEST(F32x4_Max) {
|
||||
RunF32x4BinOpTest(lower_simd, kExprF32x4Max, JSMax);
|
||||
}
|
||||
#endif // V8_TARGET_ARCH_ARM || V8_TARGET_ARCH_ARM64 || V8_TARGET_ARCH_MIPS ||
|
||||
// V8_TARGET_ARCH_MIPS64 || V8_TARGET_ARCH_X64
|
||||
|
||||
void RunF32x4CompareOpTest(LowerSimd lower_simd, WasmOpcode simd_op,
|
||||
FloatCompareOp expected_op) {
|
||||
|
Loading…
Reference in New Issue
Block a user