| Index: src/compiler/instruction-selector.cc
|
| diff --git a/src/compiler/instruction-selector.cc b/src/compiler/instruction-selector.cc
|
| index 9e3163bebab3ec61301d31bb47a66f952b10419a..099802cf89a65c59514fed7d6533ab62cafdf60c 100644
|
| --- a/src/compiler/instruction-selector.cc
|
| +++ b/src/compiler/instruction-selector.cc
|
| @@ -1524,13 +1524,13 @@ void InstructionSelector::VisitNode(Node* node) {
|
| case IrOpcode::kF32x4Max:
|
| return MarkAsSimd128(node), VisitF32x4Max(node);
|
| case IrOpcode::kF32x4Eq:
|
| - return MarkAsSimd1x4(node), VisitF32x4Eq(node);
|
| + return MarkAsSimd128(node), VisitF32x4Eq(node);
|
| case IrOpcode::kF32x4Ne:
|
| - return MarkAsSimd1x4(node), VisitF32x4Ne(node);
|
| + return MarkAsSimd128(node), VisitF32x4Ne(node);
|
| case IrOpcode::kF32x4Lt:
|
| - return MarkAsSimd1x4(node), VisitF32x4Lt(node);
|
| + return MarkAsSimd128(node), VisitF32x4Lt(node);
|
| case IrOpcode::kF32x4Le:
|
| - return MarkAsSimd1x4(node), VisitF32x4Le(node);
|
| + return MarkAsSimd128(node), VisitF32x4Le(node);
|
| case IrOpcode::kI32x4Splat:
|
| return MarkAsSimd128(node), VisitI32x4Splat(node);
|
| case IrOpcode::kI32x4ExtractLane:
|
| @@ -1562,13 +1562,13 @@ void InstructionSelector::VisitNode(Node* node) {
|
| case IrOpcode::kI32x4MaxS:
|
| return MarkAsSimd128(node), VisitI32x4MaxS(node);
|
| case IrOpcode::kI32x4Eq:
|
| - return MarkAsSimd1x4(node), VisitI32x4Eq(node);
|
| + return MarkAsSimd128(node), VisitI32x4Eq(node);
|
| case IrOpcode::kI32x4Ne:
|
| - return MarkAsSimd1x4(node), VisitI32x4Ne(node);
|
| + return MarkAsSimd128(node), VisitI32x4Ne(node);
|
| case IrOpcode::kI32x4GtS:
|
| - return MarkAsSimd1x4(node), VisitI32x4GtS(node);
|
| + return MarkAsSimd128(node), VisitI32x4GtS(node);
|
| case IrOpcode::kI32x4GeS:
|
| - return MarkAsSimd1x4(node), VisitI32x4GeS(node);
|
| + return MarkAsSimd128(node), VisitI32x4GeS(node);
|
| case IrOpcode::kI32x4UConvertF32x4:
|
| return MarkAsSimd128(node), VisitI32x4UConvertF32x4(node);
|
| case IrOpcode::kI32x4UConvertI16x8Low:
|
| @@ -1582,9 +1582,9 @@ void InstructionSelector::VisitNode(Node* node) {
|
| case IrOpcode::kI32x4MaxU:
|
| return MarkAsSimd128(node), VisitI32x4MaxU(node);
|
| case IrOpcode::kI32x4GtU:
|
| - return MarkAsSimd1x4(node), VisitI32x4GtU(node);
|
| + return MarkAsSimd128(node), VisitI32x4GtU(node);
|
| case IrOpcode::kI32x4GeU:
|
| - return MarkAsSimd1x4(node), VisitI32x4GeU(node);
|
| + return MarkAsSimd128(node), VisitI32x4GeU(node);
|
| case IrOpcode::kI16x8Splat:
|
| return MarkAsSimd128(node), VisitI16x8Splat(node);
|
| case IrOpcode::kI16x8ExtractLane:
|
| @@ -1620,13 +1620,13 @@ void InstructionSelector::VisitNode(Node* node) {
|
| case IrOpcode::kI16x8MaxS:
|
| return MarkAsSimd128(node), VisitI16x8MaxS(node);
|
| case IrOpcode::kI16x8Eq:
|
| - return MarkAsSimd1x8(node), VisitI16x8Eq(node);
|
| + return MarkAsSimd128(node), VisitI16x8Eq(node);
|
| case IrOpcode::kI16x8Ne:
|
| - return MarkAsSimd1x8(node), VisitI16x8Ne(node);
|
| + return MarkAsSimd128(node), VisitI16x8Ne(node);
|
| case IrOpcode::kI16x8GtS:
|
| - return MarkAsSimd1x8(node), VisitI16x8GtS(node);
|
| + return MarkAsSimd128(node), VisitI16x8GtS(node);
|
| case IrOpcode::kI16x8GeS:
|
| - return MarkAsSimd1x8(node), VisitI16x8GeS(node);
|
| + return MarkAsSimd128(node), VisitI16x8GeS(node);
|
| case IrOpcode::kI16x8UConvertI8x16Low:
|
| return MarkAsSimd128(node), VisitI16x8UConvertI8x16Low(node);
|
| case IrOpcode::kI16x8UConvertI8x16High:
|
| @@ -1644,9 +1644,9 @@ void InstructionSelector::VisitNode(Node* node) {
|
| case IrOpcode::kI16x8MaxU:
|
| return MarkAsSimd128(node), VisitI16x8MaxU(node);
|
| case IrOpcode::kI16x8GtU:
|
| - return MarkAsSimd1x8(node), VisitI16x8GtU(node);
|
| + return MarkAsSimd128(node), VisitI16x8GtU(node);
|
| case IrOpcode::kI16x8GeU:
|
| - return MarkAsSimd1x8(node), VisitI16x8GeU(node);
|
| + return MarkAsSimd128(node), VisitI16x8GeU(node);
|
| case IrOpcode::kI8x16Splat:
|
| return MarkAsSimd128(node), VisitI8x16Splat(node);
|
| case IrOpcode::kI8x16ExtractLane:
|
| @@ -1676,13 +1676,13 @@ void InstructionSelector::VisitNode(Node* node) {
|
| case IrOpcode::kI8x16MaxS:
|
| return MarkAsSimd128(node), VisitI8x16MaxS(node);
|
| case IrOpcode::kI8x16Eq:
|
| - return MarkAsSimd1x16(node), VisitI8x16Eq(node);
|
| + return MarkAsSimd128(node), VisitI8x16Eq(node);
|
| case IrOpcode::kI8x16Ne:
|
| - return MarkAsSimd1x16(node), VisitI8x16Ne(node);
|
| + return MarkAsSimd128(node), VisitI8x16Ne(node);
|
| case IrOpcode::kI8x16GtS:
|
| - return MarkAsSimd1x16(node), VisitI8x16GtS(node);
|
| + return MarkAsSimd128(node), VisitI8x16GtS(node);
|
| case IrOpcode::kI8x16GeS:
|
| - return MarkAsSimd1x16(node), VisitI8x16GeS(node);
|
| + return MarkAsSimd128(node), VisitI8x16GeS(node);
|
| case IrOpcode::kI8x16ShrU:
|
| return MarkAsSimd128(node), VisitI8x16ShrU(node);
|
| case IrOpcode::kI8x16UConvertI16x8:
|
| @@ -1696,9 +1696,9 @@ void InstructionSelector::VisitNode(Node* node) {
|
| case IrOpcode::kI8x16MaxU:
|
| return MarkAsSimd128(node), VisitI8x16MaxU(node);
|
| case IrOpcode::kI8x16GtU:
|
| - return MarkAsSimd1x16(node), VisitI8x16GtU(node);
|
| + return MarkAsSimd128(node), VisitI8x16GtU(node);
|
| case IrOpcode::kI8x16GeU:
|
| - return MarkAsSimd1x16(node), VisitI16x8GeU(node);
|
| + return MarkAsSimd128(node), VisitI16x8GeU(node);
|
| case IrOpcode::kS128Zero:
|
| return MarkAsSimd128(node), VisitS128Zero(node);
|
| case IrOpcode::kS128And:
|
| @@ -1709,56 +1709,22 @@ void InstructionSelector::VisitNode(Node* node) {
|
| return MarkAsSimd128(node), VisitS128Xor(node);
|
| case IrOpcode::kS128Not:
|
| return MarkAsSimd128(node), VisitS128Not(node);
|
| + case IrOpcode::kS128Select:
|
| + return MarkAsSimd128(node), VisitS128Select(node);
|
| case IrOpcode::kS32x4Shuffle:
|
| return MarkAsSimd128(node), VisitS32x4Shuffle(node);
|
| - case IrOpcode::kS32x4Select:
|
| - return MarkAsSimd128(node), VisitS32x4Select(node);
|
| case IrOpcode::kS16x8Shuffle:
|
| return MarkAsSimd128(node), VisitS16x8Shuffle(node);
|
| - case IrOpcode::kS16x8Select:
|
| - return MarkAsSimd128(node), VisitS16x8Select(node);
|
| case IrOpcode::kS8x16Shuffle:
|
| return MarkAsSimd128(node), VisitS8x16Shuffle(node);
|
| - case IrOpcode::kS8x16Select:
|
| - return MarkAsSimd128(node), VisitS8x16Select(node);
|
| - case IrOpcode::kS1x4Zero:
|
| - return MarkAsSimd1x4(node), VisitS1x4Zero(node);
|
| - case IrOpcode::kS1x4And:
|
| - return MarkAsSimd1x4(node), VisitS1x4And(node);
|
| - case IrOpcode::kS1x4Or:
|
| - return MarkAsSimd1x4(node), VisitS1x4Or(node);
|
| - case IrOpcode::kS1x4Xor:
|
| - return MarkAsSimd1x4(node), VisitS1x4Xor(node);
|
| - case IrOpcode::kS1x4Not:
|
| - return MarkAsSimd1x4(node), VisitS1x4Not(node);
|
| case IrOpcode::kS1x4AnyTrue:
|
| return MarkAsWord32(node), VisitS1x4AnyTrue(node);
|
| case IrOpcode::kS1x4AllTrue:
|
| return MarkAsWord32(node), VisitS1x4AllTrue(node);
|
| - case IrOpcode::kS1x8Zero:
|
| - return MarkAsSimd1x8(node), VisitS1x8Zero(node);
|
| - case IrOpcode::kS1x8And:
|
| - return MarkAsSimd1x8(node), VisitS1x8And(node);
|
| - case IrOpcode::kS1x8Or:
|
| - return MarkAsSimd1x8(node), VisitS1x8Or(node);
|
| - case IrOpcode::kS1x8Xor:
|
| - return MarkAsSimd1x8(node), VisitS1x8Xor(node);
|
| - case IrOpcode::kS1x8Not:
|
| - return MarkAsSimd1x8(node), VisitS1x8Not(node);
|
| case IrOpcode::kS1x8AnyTrue:
|
| return MarkAsWord32(node), VisitS1x8AnyTrue(node);
|
| case IrOpcode::kS1x8AllTrue:
|
| return MarkAsWord32(node), VisitS1x8AllTrue(node);
|
| - case IrOpcode::kS1x16Zero:
|
| - return MarkAsSimd1x16(node), VisitS1x16Zero(node);
|
| - case IrOpcode::kS1x16And:
|
| - return MarkAsSimd1x16(node), VisitS1x16And(node);
|
| - case IrOpcode::kS1x16Or:
|
| - return MarkAsSimd1x16(node), VisitS1x16Or(node);
|
| - case IrOpcode::kS1x16Xor:
|
| - return MarkAsSimd1x16(node), VisitS1x16Xor(node);
|
| - case IrOpcode::kS1x16Not:
|
| - return MarkAsSimd1x16(node), VisitS1x16Not(node);
|
| case IrOpcode::kS1x16AnyTrue:
|
| return MarkAsWord32(node), VisitS1x16AnyTrue(node);
|
| case IrOpcode::kS1x16AllTrue:
|
| @@ -2412,18 +2378,12 @@ void InstructionSelector::VisitS128Not(Node* node) { UNIMPLEMENTED(); }
|
| #if !V8_TARGET_ARCH_X64 && !V8_TARGET_ARCH_ARM && !V8_TARGET_ARCH_MIPS && \
|
| !V8_TARGET_ARCH_MIPS64
|
| void InstructionSelector::VisitS128Zero(Node* node) { UNIMPLEMENTED(); }
|
| -
|
| -void InstructionSelector::VisitS1x4Zero(Node* node) { UNIMPLEMENTED(); }
|
| -
|
| -void InstructionSelector::VisitS1x8Zero(Node* node) { UNIMPLEMENTED(); }
|
| -
|
| -void InstructionSelector::VisitS1x16Zero(Node* node) { UNIMPLEMENTED(); }
|
| #endif // !V8_TARGET_ARCH_X64 && !V8_TARGET_ARCH_ARM && !V8_TARGET_ARCH_MIPS &&
|
| // !V8_TARGET_ARCH_MIPS64
|
|
|
| #if !V8_TARGET_ARCH_X64 && !V8_TARGET_ARCH_ARM && !V8_TARGET_ARCH_MIPS && \
|
| !V8_TARGET_ARCH_MIPS64
|
| -void InstructionSelector::VisitS32x4Select(Node* node) { UNIMPLEMENTED(); }
|
| +void InstructionSelector::VisitS128Select(Node* node) { UNIMPLEMENTED(); }
|
| #endif // !V8_TARGET_ARCH_X64 && !V8_TARGET_ARCH_ARM && !V8_TARGET_ARCH_MIPS &&
|
| // !V8_TARGET_ARCH_MIPS64
|
|
|
| @@ -2434,56 +2394,19 @@ void InstructionSelector::VisitS16x8Shuffle(Node* node) { UNIMPLEMENTED(); }
|
|
|
| #endif // !V8_TARGET_ARCH_ARM
|
|
|
| -#if !V8_TARGET_ARCH_X64 && !V8_TARGET_ARCH_ARM && !V8_TARGET_ARCH_MIPS && \
|
| - !V8_TARGET_ARCH_MIPS64
|
| -void InstructionSelector::VisitS16x8Select(Node* node) { UNIMPLEMENTED(); }
|
| -#endif // !V8_TARGET_ARCH_X64 && !V8_TARGET_ARCH_ARM && !V8_TARGET_ARCH_MIPS &&
|
| - // !V8_TARGET_ARCH_MIPS64
|
| -
|
| #if !V8_TARGET_ARCH_ARM
|
| void InstructionSelector::VisitS8x16Shuffle(Node* node) { UNIMPLEMENTED(); }
|
| -
|
| #endif // !V8_TARGET_ARCH_ARM
|
|
|
| -#if !V8_TARGET_ARCH_X64 && !V8_TARGET_ARCH_ARM && !V8_TARGET_ARCH_MIPS && \
|
| - !V8_TARGET_ARCH_MIPS64
|
| -void InstructionSelector::VisitS8x16Select(Node* node) { UNIMPLEMENTED(); }
|
| -#endif // !V8_TARGET_ARCH_X64 && !V8_TARGET_ARCH_ARM && !V8_TARGET_ARCH_MIPS &&
|
| - // !V8_TARGET_ARCH_MIPS64
|
| -
|
| #if !V8_TARGET_ARCH_ARM && !V8_TARGET_ARCH_MIPS && !V8_TARGET_ARCH_MIPS64
|
| -void InstructionSelector::VisitS1x4And(Node* node) { UNIMPLEMENTED(); }
|
| -
|
| -void InstructionSelector::VisitS1x4Or(Node* node) { UNIMPLEMENTED(); }
|
| -
|
| -void InstructionSelector::VisitS1x4Xor(Node* node) { UNIMPLEMENTED(); }
|
| -
|
| -void InstructionSelector::VisitS1x4Not(Node* node) { UNIMPLEMENTED(); }
|
| -
|
| void InstructionSelector::VisitS1x4AnyTrue(Node* node) { UNIMPLEMENTED(); }
|
|
|
| void InstructionSelector::VisitS1x4AllTrue(Node* node) { UNIMPLEMENTED(); }
|
|
|
| -void InstructionSelector::VisitS1x8And(Node* node) { UNIMPLEMENTED(); }
|
| -
|
| -void InstructionSelector::VisitS1x8Or(Node* node) { UNIMPLEMENTED(); }
|
| -
|
| -void InstructionSelector::VisitS1x8Xor(Node* node) { UNIMPLEMENTED(); }
|
| -
|
| -void InstructionSelector::VisitS1x8Not(Node* node) { UNIMPLEMENTED(); }
|
| -
|
| void InstructionSelector::VisitS1x8AnyTrue(Node* node) { UNIMPLEMENTED(); }
|
|
|
| void InstructionSelector::VisitS1x8AllTrue(Node* node) { UNIMPLEMENTED(); }
|
|
|
| -void InstructionSelector::VisitS1x16And(Node* node) { UNIMPLEMENTED(); }
|
| -
|
| -void InstructionSelector::VisitS1x16Or(Node* node) { UNIMPLEMENTED(); }
|
| -
|
| -void InstructionSelector::VisitS1x16Xor(Node* node) { UNIMPLEMENTED(); }
|
| -
|
| -void InstructionSelector::VisitS1x16Not(Node* node) { UNIMPLEMENTED(); }
|
| -
|
| void InstructionSelector::VisitS1x16AnyTrue(Node* node) { UNIMPLEMENTED(); }
|
|
|
| void InstructionSelector::VisitS1x16AllTrue(Node* node) { UNIMPLEMENTED(); }
|
|
|