| Index: src/compiler/x64/instruction-selector-x64.cc
|
| diff --git a/src/compiler/x64/instruction-selector-x64.cc b/src/compiler/x64/instruction-selector-x64.cc
|
| index 44eadb1ee78670f2199d4152ebb7a6cdd588c723..4306168a34354d7ca7cdef96b59261eeab464fc3 100644
|
| --- a/src/compiler/x64/instruction-selector-x64.cc
|
| +++ b/src/compiler/x64/instruction-selector-x64.cc
|
| @@ -2274,36 +2274,63 @@ void InstructionSelector::VisitAtomicStore(Node* node) {
|
| Emit(code, 0, static_cast<InstructionOperand*>(nullptr), input_count, inputs);
|
| }
|
|
|
| -void InstructionSelector::VisitInt32x4Splat(Node* node) {
|
| +#define SIMD_TYPES(V) V(Int32x4)
|
| +
|
| +#define SIMD_BINOP_LIST(V) \
|
| + V(Int32x4Add) \
|
| + V(Int32x4Sub) \
|
| + V(Int32x4Mul) \
|
| + V(Int32x4Min) \
|
| + V(Int32x4Max) \
|
| + V(Int32x4Equal) \
|
| + V(Int32x4NotEqual) \
|
| + V(Uint32x4Min) \
|
| + V(Uint32x4Max)
|
| +
|
| +#define VISIT_SIMD_BINOP(Opcode) \
|
| + void InstructionSelector::Visit##Opcode(Node* node) { \
|
| + X64OperandGenerator g(this); \
|
| + Emit(kX64##Opcode, g.DefineSameAsFirst(node), \
|
| + g.UseRegister(node->InputAt(0)), g.UseRegister(node->InputAt(1))); \
|
| + }
|
| +SIMD_BINOP_LIST(VISIT_SIMD_BINOP)
|
| +#undef VISIT_SIMD_BINOP
|
| +
|
| +#define VISIT_SIMD_SPLAT(Type) \
|
| + void InstructionSelector::Visit##Type##Splat(Node* node) { \
|
| + X64OperandGenerator g(this); \
|
| + Emit(kX64##Type##Splat, g.DefineAsRegister(node), \
|
| + g.Use(node->InputAt(0))); \
|
| + }
|
| +SIMD_TYPES(VISIT_SIMD_SPLAT)
|
| +#undef VISIT_SIMD_SPLAT
|
| +
|
| +#define VISIT_SIMD_EXTRACT_LANE(Type) \
|
| + void InstructionSelector::Visit##Type##ExtractLane(Node* node) { \
|
| + X64OperandGenerator g(this); \
|
| + int32_t lane = OpParameter<int32_t>(node); \
|
| + Emit(kX64##Type##ExtractLane, g.DefineAsRegister(node), \
|
| + g.UseRegister(node->InputAt(0)), g.UseImmediate(lane)); \
|
| + }
|
| +SIMD_TYPES(VISIT_SIMD_EXTRACT_LANE)
|
| +#undef VISIT_SIMD_EXTRACT_LANE
|
| +
|
| +#define VISIT_SIMD_REPLACE_LANE(Type) \
|
| + void InstructionSelector::Visit##Type##ReplaceLane(Node* node) { \
|
| + X64OperandGenerator g(this); \
|
| + int32_t lane = OpParameter<int32_t>(node); \
|
| + Emit(kX64##Type##ReplaceLane, g.DefineSameAsFirst(node), \
|
| + g.UseRegister(node->InputAt(0)), g.UseImmediate(lane), \
|
| + g.Use(node->InputAt(1))); \
|
| + }
|
| +SIMD_TYPES(VISIT_SIMD_REPLACE_LANE)
|
| +#undef VISIT_SIMD_REPLACE_LANE
|
| +
|
| +void InstructionSelector::VisitSimd32x4Select(Node* node) {
|
| X64OperandGenerator g(this);
|
| - Emit(kX64Int32x4Splat, g.DefineAsRegister(node), g.Use(node->InputAt(0)));
|
| -}
|
| -
|
| -void InstructionSelector::VisitInt32x4ExtractLane(Node* node) {
|
| - X64OperandGenerator g(this);
|
| - int32_t lane = OpParameter<int32_t>(node);
|
| - Emit(kX64Int32x4ExtractLane, g.DefineAsRegister(node),
|
| - g.UseRegister(node->InputAt(0)), g.UseImmediate(lane));
|
| -}
|
| -
|
| -void InstructionSelector::VisitInt32x4ReplaceLane(Node* node) {
|
| - X64OperandGenerator g(this);
|
| - int32_t lane = OpParameter<int32_t>(node);
|
| - Emit(kX64Int32x4ReplaceLane, g.DefineSameAsFirst(node),
|
| - g.UseRegister(node->InputAt(0)), g.UseImmediate(lane),
|
| - g.Use(node->InputAt(1)));
|
| -}
|
| -
|
| -void InstructionSelector::VisitInt32x4Add(Node* node) {
|
| - X64OperandGenerator g(this);
|
| - Emit(kX64Int32x4Add, g.DefineSameAsFirst(node),
|
| - g.UseRegister(node->InputAt(0)), g.UseRegister(node->InputAt(1)));
|
| -}
|
| -
|
| -void InstructionSelector::VisitInt32x4Sub(Node* node) {
|
| - X64OperandGenerator g(this);
|
| - Emit(kX64Int32x4Sub, g.DefineSameAsFirst(node),
|
| - g.UseRegister(node->InputAt(0)), g.UseRegister(node->InputAt(1)));
|
| + Emit(kX64Simd32x4Select, g.DefineSameAsFirst(node),
|
| + g.UseRegister(node->InputAt(0)), g.UseRegister(node->InputAt(1)),
|
| + g.UseRegister(node->InputAt(2)));
|
| }
|
|
|
| void InstructionSelector::VisitSimd128Zero(Node* node) {
|
|
|