Index: test/unittests/compiler/machine-operator-unittest.cc |
diff --git a/test/unittests/compiler/machine-operator-unittest.cc b/test/unittests/compiler/machine-operator-unittest.cc |
index 31f55793c3f881f8c6d4c4ffc473a4431cf2def5..f49a6988f7d9b69f17760d1216d531e1d060cf08 100644 |
--- a/test/unittests/compiler/machine-operator-unittest.cc |
+++ b/test/unittests/compiler/machine-operator-unittest.cc |
@@ -149,130 +149,199 @@ INSTANTIATE_TEST_CASE_P( |
::testing::Combine(::testing::ValuesIn(kMachineTypes), |
::testing::Values(kNoWriteBarrier, |
kFullWriteBarrier)))); |
- |
+#endif |
// ----------------------------------------------------------------------------- |
// Pure operators. |
- |
namespace { |
struct PureOperator { |
const Operator* (MachineOperatorBuilder::*constructor)(); |
- IrOpcode::Value opcode; |
+ char const* const constructor_name; |
int value_input_count; |
int control_input_count; |
int value_output_count; |
}; |
-std::ostream& operator<<(std::ostream& os, const PureOperator& pop) { |
- return os << IrOpcode::Mnemonic(pop.opcode); |
+std::ostream& operator<<(std::ostream& os, PureOperator const& pop) { |
+ return os << pop.constructor_name; |
} |
- |
const PureOperator kPureOperators[] = { |
#define PURE(Name, value_input_count, control_input_count, value_output_count) \ |
{ \ |
- &MachineOperatorBuilder::Name, IrOpcode::k##Name, value_input_count, \ |
+ &MachineOperatorBuilder::Name, #Name, value_input_count, \ |
control_input_count, value_output_count \ |
} |
- PURE(Word32And, 2, 0, 1), PURE(Word32Or, 2, 0, 1), PURE(Word32Xor, 2, 0, 1), |
- PURE(Word32Shl, 2, 0, 1), PURE(Word32Shr, 2, 0, 1), |
- PURE(Word32Sar, 2, 0, 1), PURE(Word32Ror, 2, 0, 1), |
- PURE(Word32Equal, 2, 0, 1), PURE(Word32Clz, 1, 0, 1), |
- PURE(Word64And, 2, 0, 1), PURE(Word64Or, 2, 0, 1), PURE(Word64Xor, 2, 0, 1), |
- PURE(Word64Shl, 2, 0, 1), PURE(Word64Shr, 2, 0, 1), |
- PURE(Word64Sar, 2, 0, 1), PURE(Word64Ror, 2, 0, 1), |
- PURE(Word64Equal, 2, 0, 1), PURE(Int32Add, 2, 0, 1), |
- PURE(Int32AddWithOverflow, 2, 0, 2), PURE(Int32Sub, 2, 0, 1), |
- PURE(Int32SubWithOverflow, 2, 0, 2), PURE(Int32Mul, 2, 0, 1), |
- PURE(Int32MulHigh, 2, 0, 1), PURE(Int32Div, 2, 1, 1), |
- PURE(Uint32Div, 2, 1, 1), PURE(Int32Mod, 2, 1, 1), PURE(Uint32Mod, 2, 1, 1), |
- PURE(Int32LessThan, 2, 0, 1), PURE(Int32LessThanOrEqual, 2, 0, 1), |
- PURE(Uint32LessThan, 2, 0, 1), PURE(Uint32LessThanOrEqual, 2, 0, 1), |
- PURE(Int64Add, 2, 0, 1), PURE(Int64Sub, 2, 0, 1), PURE(Int64Mul, 2, 0, 1), |
- PURE(Int64Div, 2, 0, 1), PURE(Uint64Div, 2, 0, 1), PURE(Int64Mod, 2, 0, 1), |
- PURE(Uint64Mod, 2, 0, 1), PURE(Int64LessThan, 2, 0, 1), |
- PURE(Int64LessThanOrEqual, 2, 0, 1), PURE(Uint64LessThan, 2, 0, 1), |
- PURE(ChangeFloat32ToFloat64, 1, 0, 1), PURE(ChangeFloat64ToInt32, 1, 0, 1), |
- PURE(ChangeFloat64ToUint32, 1, 0, 1), PURE(ChangeInt32ToInt64, 1, 0, 1), |
- PURE(ChangeUint32ToFloat64, 1, 0, 1), PURE(ChangeUint32ToUint64, 1, 0, 1), |
- PURE(TruncateFloat64ToFloat32, 1, 0, 1), |
- PURE(TruncateFloat64ToInt32, 1, 0, 1), PURE(TruncateInt64ToInt32, 1, 0, 1), |
- PURE(Float32Add, 2, 0, 1), PURE(Float32Sub, 2, 0, 1), |
- PURE(Float32Mul, 2, 0, 1), PURE(Float32Div, 2, 0, 1), |
- PURE(Float32Abs, 1, 0, 1), PURE(Float32Sqrt, 1, 0, 1), |
- PURE(Float32Equal, 2, 0, 1), PURE(Float32LessThan, 2, 0, 1), |
- PURE(Float32LessThanOrEqual, 2, 0, 1), PURE(Float32Max, 2, 0, 1), |
- PURE(Float32Min, 2, 0, 1), PURE(Float64Add, 2, 0, 1), |
- PURE(Float64Sub, 2, 0, 1), PURE(Float64Mul, 2, 0, 1), |
- PURE(Float64Div, 2, 0, 1), PURE(Float64Mod, 2, 0, 1), |
- PURE(Float64Abs, 1, 0, 1), PURE(Float64Sqrt, 1, 0, 1), |
- PURE(Float64Equal, 2, 0, 1), PURE(Float64LessThan, 2, 0, 1), |
- PURE(Float64LessThanOrEqual, 2, 0, 1), PURE(Float64Max, 2, 0, 1), |
- PURE(Float64Min, 2, 0, 1), PURE(LoadStackPointer, 0, 0, 1), |
- PURE(Float64RoundDown, 1, 0, 1), PURE(Float64RoundTruncate, 1, 0, 1), |
- PURE(Float64RoundTiesAway, 1, 0, 1), PURE(Float64ExtractLowWord32, 1, 0, 1), |
- PURE(Float64ExtractHighWord32, 1, 0, 1), |
- PURE(Float64InsertLowWord32, 2, 0, 1), |
- PURE(Float64InsertHighWord32, 2, 0, 1) |
+ PURE(Word32And, 2, 0, 1), // -- |
+ PURE(Word32Or, 2, 0, 1), // -- |
+ PURE(Word32Xor, 2, 0, 1), // -- |
+ PURE(Word32Shl, 2, 0, 1), // -- |
+ PURE(Word32Shr, 2, 0, 1), // -- |
+ PURE(Word32Sar, 2, 0, 1), // -- |
+ PURE(Word32Ror, 2, 0, 1), // -- |
+ PURE(Word32Equal, 2, 0, 1), // -- |
+ PURE(Word32Clz, 1, 0, 1), // -- |
+ PURE(Word64And, 2, 0, 1), // -- |
+ PURE(Word64Or, 2, 0, 1), // -- |
+ PURE(Word64Xor, 2, 0, 1), // -- |
+ PURE(Word64Shl, 2, 0, 1), // -- |
+ PURE(Word64Shr, 2, 0, 1), // -- |
+ PURE(Word64Sar, 2, 0, 1), // -- |
+ PURE(Word64Ror, 2, 0, 1), // -- |
+ PURE(Word64Equal, 2, 0, 1), // -- |
+ PURE(Int32Add, 2, 0, 1), // -- |
+ PURE(Int32AddWithOverflow, 2, 0, 2), // -- |
+ PURE(Int32Sub, 2, 0, 1), // -- |
+ PURE(Int32SubWithOverflow, 2, 0, 2), // -- |
+ PURE(Int32Mul, 2, 0, 1), // -- |
+ PURE(Int32MulHigh, 2, 0, 1), // -- |
+ PURE(Int32Div, 2, 1, 1), // -- |
+ PURE(Uint32Div, 2, 1, 1), // -- |
+ PURE(Int32Mod, 2, 1, 1), // -- |
+ PURE(Uint32Mod, 2, 1, 1), // -- |
+ PURE(Int32LessThan, 2, 0, 1), // -- |
+ PURE(Int32LessThanOrEqual, 2, 0, 1), // -- |
+ PURE(Uint32LessThan, 2, 0, 1), // -- |
+ PURE(Uint32LessThanOrEqual, 2, 0, 1), // -- |
+ PURE(Int64Add, 2, 0, 1), // -- |
+ PURE(Int64Sub, 2, 0, 1), // -- |
+ PURE(Int64Mul, 2, 0, 1), // -- |
+ PURE(Int64Div, 2, 0, 1), // -- |
+ PURE(Uint64Div, 2, 0, 1), // -- |
+ PURE(Int64Mod, 2, 0, 1), // -- |
+ PURE(Uint64Mod, 2, 0, 1), // -- |
+ PURE(Int64LessThan, 2, 0, 1), // -- |
+ PURE(Int64LessThanOrEqual, 2, 0, 1), // -- |
+ PURE(Uint64LessThan, 2, 0, 1), // -- |
+ PURE(ChangeFloat32ToFloat64, 1, 0, 1), // -- |
+ PURE(ChangeFloat64ToInt32, 1, 0, 1), // -- |
+ PURE(ChangeFloat64ToUint32, 1, 0, 1), // -- |
+ PURE(ChangeInt32ToInt64, 1, 0, 1), // -- |
+ PURE(ChangeUint32ToFloat64, 1, 0, 1), // -- |
+ PURE(ChangeUint32ToUint64, 1, 0, 1), // -- |
+ PURE(TruncateFloat64ToFloat32, 1, 0, 1), // -- |
+ PURE(TruncateFloat64ToInt32, 1, 0, 1), // -- |
+ PURE(TruncateInt64ToInt32, 1, 0, 1), // -- |
+ PURE(Float32Abs, 1, 0, 1), // -- |
+ PURE(Float32Add, 2, 0, 1), // -- |
+ PURE(Float32Sub, 2, 0, 1), // -- |
+ PURE(Float32Mul, 2, 0, 1), // -- |
+ PURE(Float32Div, 2, 0, 1), // -- |
+ PURE(Float32Sqrt, 1, 0, 1), // -- |
+ PURE(Float32Equal, 2, 0, 1), // -- |
+ PURE(Float32LessThan, 2, 0, 1), // -- |
+ PURE(Float32LessThanOrEqual, 2, 0, 1), // -- |
+ PURE(Float64Abs, 1, 0, 1), // -- |
+ PURE(Float64Add, 2, 0, 1), // -- |
+ PURE(Float64Sub, 2, 0, 1), // -- |
+ PURE(Float64Mul, 2, 0, 1), // -- |
+ PURE(Float64Div, 2, 0, 1), // -- |
+ PURE(Float64Mod, 2, 0, 1), // -- |
+ PURE(Float64Sqrt, 1, 0, 1), // -- |
+ PURE(Float64Equal, 2, 0, 1), // -- |
+ PURE(Float64LessThan, 2, 0, 1), // -- |
+ PURE(Float64LessThanOrEqual, 2, 0, 1), // -- |
+ PURE(LoadStackPointer, 0, 0, 1), // -- |
+ PURE(Float64ExtractLowWord32, 1, 0, 1), // -- |
+ PURE(Float64ExtractHighWord32, 1, 0, 1), // -- |
+ PURE(Float64InsertLowWord32, 2, 0, 1), // -- |
+ PURE(Float64InsertHighWord32, 2, 0, 1), // -- |
#undef PURE |
}; |
- |
-typedef MachineOperatorTestWithParam<PureOperator> MachinePureOperatorTest; |
- |
} // namespace |
+class MachinePureOperatorTest : public TestWithZone { |
+ protected: |
+ MachineType word_type() { return kMachPtr; } |
+}; |
-TEST_P(MachinePureOperatorTest, InstancesAreGloballyShared) { |
- const PureOperator& pop = GetParam(); |
- MachineOperatorBuilder machine1(zone(), type()); |
- MachineOperatorBuilder machine2(zone(), type()); |
- EXPECT_EQ((machine1.*pop.constructor)(), (machine2.*pop.constructor)()); |
+ |
+TEST_F(MachinePureOperatorTest, PureOperators) { |
+ TRACED_FOREACH(MachineType, machine_rep1, kMachineReps) { |
+ MachineOperatorBuilder machine1(zone(), machine_rep1); |
+ TRACED_FOREACH(MachineType, machine_rep2, kMachineReps) { |
+ MachineOperatorBuilder machine2(zone(), machine_rep2); |
+ TRACED_FOREACH(PureOperator, pop, kPureOperators) { |
+ const Operator* op1 = (machine1.*pop.constructor)(); |
+ const Operator* op2 = (machine2.*pop.constructor)(); |
+ EXPECT_EQ(op1, op2); |
+ EXPECT_EQ(pop.value_input_count, op1->ValueInputCount()); |
+ EXPECT_EQ(pop.control_input_count, op1->ControlInputCount()); |
+ EXPECT_EQ(pop.value_output_count, op1->ValueOutputCount()); |
+ } |
+ } |
+ } |
} |
-TEST_P(MachinePureOperatorTest, NumberOfInputsAndOutputs) { |
- MachineOperatorBuilder machine(zone(), type()); |
- const PureOperator& pop = GetParam(); |
- const Operator* op = (machine.*pop.constructor)(); |
+// Optional operators. |
- EXPECT_EQ(pop.value_input_count, op->ValueInputCount()); |
- EXPECT_EQ(0, op->EffectInputCount()); |
- EXPECT_EQ(pop.control_input_count, op->ControlInputCount()); |
- EXPECT_EQ(pop.value_input_count + pop.control_input_count, |
- OperatorProperties::GetTotalInputCount(op)); |
+namespace { |
- EXPECT_EQ(pop.value_output_count, op->ValueOutputCount()); |
- EXPECT_EQ(0, op->EffectOutputCount()); |
- EXPECT_EQ(0, op->ControlOutputCount()); |
-} |
+struct OptionalOperatorEntry { |
+ const OptionalOperator (MachineOperatorBuilder::*constructor)(); |
+ MachineOperatorBuilder::Flag enabling_flag; |
+ char const* const constructor_name; |
+ int value_input_count; |
+ int control_input_count; |
+ int value_output_count; |
+}; |
-TEST_P(MachinePureOperatorTest, MarkedAsPure) { |
- MachineOperatorBuilder machine(zone(), type()); |
- const PureOperator& pop = GetParam(); |
- const Operator* op = (machine.*pop.constructor)(); |
- EXPECT_TRUE(op->HasProperty(Operator::kPure)); |
+std::ostream& operator<<(std::ostream& os, OptionalOperatorEntry const& pop) { |
+ return os << pop.constructor_name; |
} |
+const OptionalOperatorEntry kOptionalOperators[] = { |
+#define OPTIONAL_ENTRY(Name, value_input_count, control_input_count, \ |
+ value_output_count) \ |
+ { \ |
+ &MachineOperatorBuilder::Name, MachineOperatorBuilder::k##Name, #Name, \ |
+ value_input_count, control_input_count, value_output_count \ |
+ } |
+ OPTIONAL_ENTRY(Float32Max, 2, 0, 1), // -- |
+ OPTIONAL_ENTRY(Float32Min, 2, 0, 1), // -- |
+ OPTIONAL_ENTRY(Float64Max, 2, 0, 1), // -- |
+ OPTIONAL_ENTRY(Float64Min, 2, 0, 1), // -- |
+ OPTIONAL_ENTRY(Float64RoundDown, 1, 0, 1), // -- |
+ OPTIONAL_ENTRY(Float64RoundTruncate, 1, 0, 1), // -- |
+ OPTIONAL_ENTRY(Float64RoundTiesAway, 1, 0, 1), // -- |
+#undef OPTIONAL_ENTRY |
+}; |
+} // namespace |
-TEST_P(MachinePureOperatorTest, OpcodeIsCorrect) { |
- MachineOperatorBuilder machine(zone(), type()); |
- const PureOperator& pop = GetParam(); |
- const Operator* op = (machine.*pop.constructor)(); |
- EXPECT_EQ(pop.opcode, op->opcode()); |
-} |
+class MachineOptionalOperatorTest : public TestWithZone { |
+ protected: |
+ MachineType word_type() { return kMachPtr; } |
+}; |
-INSTANTIATE_TEST_CASE_P( |
- MachineOperatorTest, MachinePureOperatorTest, |
- ::testing::Combine(::testing::ValuesIn(kMachineReps), |
- ::testing::ValuesIn(kPureOperators))); |
-#endif // GTEST_HAS_COMBINE |
+TEST_F(MachineOptionalOperatorTest, OptionalOperators) { |
+ TRACED_FOREACH(OptionalOperatorEntry, pop, kOptionalOperators) { |
+ TRACED_FOREACH(MachineType, machine_rep1, kMachineReps) { |
+ MachineOperatorBuilder machine1(zone(), machine_rep1, pop.enabling_flag); |
+ TRACED_FOREACH(MachineType, machine_rep2, kMachineReps) { |
+ MachineOperatorBuilder machine2(zone(), machine_rep2, |
+ pop.enabling_flag); |
+ const Operator* op1 = (machine1.*pop.constructor)().op(); |
+ const Operator* op2 = (machine2.*pop.constructor)().op(); |
+ EXPECT_EQ(op1, op2); |
+ EXPECT_EQ(pop.value_input_count, op1->ValueInputCount()); |
+ EXPECT_EQ(pop.control_input_count, op1->ControlInputCount()); |
+ EXPECT_EQ(pop.value_output_count, op1->ValueOutputCount()); |
+ |
+ MachineOperatorBuilder machine3(zone(), word_type()); |
+ EXPECT_TRUE((machine1.*pop.constructor)().IsSupported()); |
+ EXPECT_FALSE((machine3.*pop.constructor)().IsSupported()); |
+ } |
+ } |
+ } |
+} |
// ----------------------------------------------------------------------------- |