Chromium Code Reviews| 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..0054253286546831e1df8b6dbc9afef2c6f049dc 100644 |
| --- a/src/compiler/x64/instruction-selector-x64.cc |
| +++ b/src/compiler/x64/instruction-selector-x64.cc |
| @@ -2274,36 +2274,78 @@ 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 SIMD_SHIFT_OPCODES(V) \ |
| + V(Int32x4ShiftLeftByScalar) \ |
| + V(Int32x4ShiftRightByScalar) \ |
| + V(Uint32x4ShiftRightByScalar) |
| + |
| +#define VISIT_SIMD_BINOP(Opcode) \ |
|
bbudge
2017/02/28 19:34:39
nit: Elsewhere, we follow the general ordering:
Ty
gdeepti
2017/03/13 20:37:52
Done.
|
| + 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_SHIFT(Opcode) \ |
| + void InstructionSelector::Visit##Opcode(Node* node) { \ |
| + X64OperandGenerator g(this); \ |
| + int32_t value = OpParameter<int32_t>(node); \ |
| + Emit(kX64##Opcode, g.DefineSameAsFirst(node), \ |
| + g.UseRegister(node->InputAt(0)), g.UseImmediate(value)); \ |
| + } |
| +SIMD_SHIFT_OPCODES(VISIT_SIMD_SHIFT) |
| +#undef VISIT_SIMD_SHIFT |
| + |
| +#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) { |