OLD | NEW |
1 // Copyright 2014 the V8 project authors. All rights reserved. | 1 // Copyright 2014 the V8 project authors. All rights reserved. |
2 // Use of this source code is governed by a BSD-style license that can be | 2 // Use of this source code is governed by a BSD-style license that can be |
3 // found in the LICENSE file. | 3 // found in the LICENSE file. |
4 | 4 |
5 #include "src/compiler/js-operator.h" | 5 #include "src/compiler/js-operator.h" |
6 #include "src/compiler/opcodes.h" | 6 #include "src/compiler/opcodes.h" |
7 #include "src/compiler/operator.h" | 7 #include "src/compiler/operator.h" |
8 #include "src/compiler/operator-properties.h" | 8 #include "src/compiler/operator-properties.h" |
9 #include "test/unittests/test-utils.h" | 9 #include "test/unittests/test-utils.h" |
10 | 10 |
(...skipping 10 matching lines...) Expand all Loading... |
21 struct SharedOperator { | 21 struct SharedOperator { |
22 const Operator* (JSOperatorBuilder::*constructor)(); | 22 const Operator* (JSOperatorBuilder::*constructor)(); |
23 IrOpcode::Value opcode; | 23 IrOpcode::Value opcode; |
24 Operator::Properties properties; | 24 Operator::Properties properties; |
25 int value_input_count; | 25 int value_input_count; |
26 int frame_state_input_count; | 26 int frame_state_input_count; |
27 int effect_input_count; | 27 int effect_input_count; |
28 int control_input_count; | 28 int control_input_count; |
29 int value_output_count; | 29 int value_output_count; |
30 int effect_output_count; | 30 int effect_output_count; |
| 31 int control_output_count; |
31 }; | 32 }; |
32 | 33 |
33 | 34 |
34 std::ostream& operator<<(std::ostream& os, const SharedOperator& sop) { | 35 std::ostream& operator<<(std::ostream& os, const SharedOperator& sop) { |
35 return os << IrOpcode::Mnemonic(sop.opcode); | 36 return os << IrOpcode::Mnemonic(sop.opcode); |
36 } | 37 } |
37 | 38 |
38 | 39 |
39 const SharedOperator kSharedOperators[] = { | 40 const SharedOperator kSharedOperators[] = { |
40 #define SHARED(Name, properties, value_input_count, frame_state_input_count, \ | 41 #define SHARED(Name, properties, value_input_count, frame_state_input_count, \ |
41 effect_input_count, control_input_count, value_output_count, \ | 42 effect_input_count, control_input_count, value_output_count, \ |
42 effect_output_count) \ | 43 effect_output_count, control_output_count) \ |
43 { \ | 44 { \ |
44 &JSOperatorBuilder::Name, IrOpcode::kJS##Name, properties, \ | 45 &JSOperatorBuilder::Name, IrOpcode::kJS##Name, properties, \ |
45 value_input_count, frame_state_input_count, effect_input_count, \ | 46 value_input_count, frame_state_input_count, effect_input_count, \ |
46 control_input_count, value_output_count, effect_output_count \ | 47 control_input_count, value_output_count, effect_output_count, \ |
| 48 control_output_count \ |
47 } | 49 } |
48 SHARED(Equal, Operator::kNoProperties, 2, 1, 1, 1, 1, 1), | 50 SHARED(Equal, Operator::kNoProperties, 2, 1, 1, 1, 1, 1, 2), |
49 SHARED(NotEqual, Operator::kNoProperties, 2, 1, 1, 1, 1, 1), | 51 SHARED(NotEqual, Operator::kNoProperties, 2, 1, 1, 1, 1, 1, 2), |
50 SHARED(StrictEqual, Operator::kPure, 2, 0, 0, 0, 1, 0), | 52 SHARED(StrictEqual, Operator::kPure, 2, 0, 0, 0, 1, 0, 0), |
51 SHARED(StrictNotEqual, Operator::kPure, 2, 0, 0, 0, 1, 0), | 53 SHARED(StrictNotEqual, Operator::kPure, 2, 0, 0, 0, 1, 0, 0), |
52 SHARED(LessThan, Operator::kNoProperties, 2, 1, 1, 1, 1, 1), | 54 SHARED(LessThan, Operator::kNoProperties, 2, 1, 1, 1, 1, 1, 2), |
53 SHARED(GreaterThan, Operator::kNoProperties, 2, 1, 1, 1, 1, 1), | 55 SHARED(GreaterThan, Operator::kNoProperties, 2, 1, 1, 1, 1, 1, 2), |
54 SHARED(LessThanOrEqual, Operator::kNoProperties, 2, 1, 1, 1, 1, 1), | 56 SHARED(LessThanOrEqual, Operator::kNoProperties, 2, 1, 1, 1, 1, 1, 2), |
55 SHARED(GreaterThanOrEqual, Operator::kNoProperties, 2, 1, 1, 1, 1, 1), | 57 SHARED(GreaterThanOrEqual, Operator::kNoProperties, 2, 1, 1, 1, 1, 1, 2), |
56 SHARED(BitwiseOr, Operator::kNoProperties, 2, 1, 1, 1, 1, 1), | 58 SHARED(BitwiseOr, Operator::kNoProperties, 2, 1, 1, 1, 1, 1, 2), |
57 SHARED(BitwiseXor, Operator::kNoProperties, 2, 1, 1, 1, 1, 1), | 59 SHARED(BitwiseXor, Operator::kNoProperties, 2, 1, 1, 1, 1, 1, 2), |
58 SHARED(BitwiseAnd, Operator::kNoProperties, 2, 1, 1, 1, 1, 1), | 60 SHARED(BitwiseAnd, Operator::kNoProperties, 2, 1, 1, 1, 1, 1, 2), |
59 SHARED(ShiftLeft, Operator::kNoProperties, 2, 1, 1, 1, 1, 1), | 61 SHARED(ShiftLeft, Operator::kNoProperties, 2, 1, 1, 1, 1, 1, 2), |
60 SHARED(ShiftRight, Operator::kNoProperties, 2, 1, 1, 1, 1, 1), | 62 SHARED(ShiftRight, Operator::kNoProperties, 2, 1, 1, 1, 1, 1, 2), |
61 SHARED(ShiftRightLogical, Operator::kNoProperties, 2, 1, 1, 1, 1, 1), | 63 SHARED(ShiftRightLogical, Operator::kNoProperties, 2, 1, 1, 1, 1, 1, 2), |
62 SHARED(Add, Operator::kNoProperties, 2, 1, 1, 1, 1, 1), | 64 SHARED(Add, Operator::kNoProperties, 2, 1, 1, 1, 1, 1, 2), |
63 SHARED(Subtract, Operator::kNoProperties, 2, 1, 1, 1, 1, 1), | 65 SHARED(Subtract, Operator::kNoProperties, 2, 1, 1, 1, 1, 1, 2), |
64 SHARED(Multiply, Operator::kNoProperties, 2, 1, 1, 1, 1, 1), | 66 SHARED(Multiply, Operator::kNoProperties, 2, 1, 1, 1, 1, 1, 2), |
65 SHARED(Divide, Operator::kNoProperties, 2, 1, 1, 1, 1, 1), | 67 SHARED(Divide, Operator::kNoProperties, 2, 1, 1, 1, 1, 1, 2), |
66 SHARED(Modulus, Operator::kNoProperties, 2, 1, 1, 1, 1, 1), | 68 SHARED(Modulus, Operator::kNoProperties, 2, 1, 1, 1, 1, 1, 2), |
67 SHARED(UnaryNot, Operator::kPure, 1, 0, 0, 0, 1, 0), | 69 SHARED(UnaryNot, Operator::kPure, 1, 0, 0, 0, 1, 0, 0), |
68 SHARED(ToBoolean, Operator::kPure, 1, 0, 0, 0, 1, 0), | 70 SHARED(ToBoolean, Operator::kPure, 1, 0, 0, 0, 1, 0, 0), |
69 SHARED(ToNumber, Operator::kNoProperties, 1, 1, 1, 1, 1, 1), | 71 SHARED(ToNumber, Operator::kNoProperties, 1, 1, 1, 1, 1, 1, 2), |
70 SHARED(ToString, Operator::kNoProperties, 1, 0, 1, 1, 1, 1), | 72 SHARED(ToString, Operator::kNoProperties, 1, 0, 1, 1, 1, 1, 2), |
71 SHARED(ToName, Operator::kNoProperties, 1, 1, 1, 1, 1, 1), | 73 SHARED(ToName, Operator::kNoProperties, 1, 1, 1, 1, 1, 1, 2), |
72 SHARED(ToObject, Operator::kNoProperties, 1, 1, 1, 1, 1, 1), | 74 SHARED(ToObject, Operator::kNoProperties, 1, 1, 1, 1, 1, 1, 2), |
73 SHARED(Yield, Operator::kNoProperties, 1, 0, 1, 1, 1, 1), | 75 SHARED(Yield, Operator::kNoProperties, 1, 0, 1, 1, 1, 1, 2), |
74 SHARED(Create, Operator::kEliminatable, 0, 0, 1, 1, 1, 1), | 76 SHARED(Create, Operator::kEliminatable, 0, 0, 1, 1, 1, 1, 0), |
75 SHARED(HasProperty, Operator::kNoProperties, 2, 1, 1, 1, 1, 1), | 77 SHARED(HasProperty, Operator::kNoProperties, 2, 1, 1, 1, 1, 1, 2), |
76 SHARED(TypeOf, Operator::kPure, 1, 0, 0, 0, 1, 0), | 78 SHARED(TypeOf, Operator::kPure, 1, 0, 0, 0, 1, 0, 0), |
77 SHARED(InstanceOf, Operator::kNoProperties, 2, 1, 1, 1, 1, 1), | 79 SHARED(InstanceOf, Operator::kNoProperties, 2, 1, 1, 1, 1, 1, 2), |
78 SHARED(Debugger, Operator::kNoProperties, 0, 0, 1, 1, 0, 1), | 80 SHARED(Debugger, Operator::kNoProperties, 0, 0, 1, 1, 0, 1, 2), |
79 SHARED(CreateFunctionContext, Operator::kNoProperties, 1, 0, 1, 1, 1, 1), | 81 SHARED(CreateFunctionContext, Operator::kNoProperties, 1, 0, 1, 1, 1, 1, 2), |
80 SHARED(CreateWithContext, Operator::kNoProperties, 2, 1, 1, 1, 1, 1), | 82 SHARED(CreateWithContext, Operator::kNoProperties, 2, 1, 1, 1, 1, 1, 2), |
81 SHARED(CreateBlockContext, Operator::kNoProperties, 2, 0, 1, 1, 1, 1), | 83 SHARED(CreateBlockContext, Operator::kNoProperties, 2, 0, 1, 1, 1, 1, 2), |
82 SHARED(CreateModuleContext, Operator::kNoProperties, 2, 0, 1, 1, 1, 1), | 84 SHARED(CreateModuleContext, Operator::kNoProperties, 2, 0, 1, 1, 1, 1, 2), |
83 SHARED(CreateScriptContext, Operator::kNoProperties, 2, 0, 1, 1, 1, 1) | 85 SHARED(CreateScriptContext, Operator::kNoProperties, 2, 0, 1, 1, 1, 1, 2) |
84 #undef SHARED | 86 #undef SHARED |
85 }; | 87 }; |
86 | 88 |
87 } // namespace | 89 } // namespace |
88 | 90 |
89 | 91 |
90 class JSSharedOperatorTest | 92 class JSSharedOperatorTest |
91 : public TestWithZone, | 93 : public TestWithZone, |
92 public ::testing::WithParamInterface<SharedOperator> {}; | 94 public ::testing::WithParamInterface<SharedOperator> {}; |
93 | 95 |
(...skipping 21 matching lines...) Expand all Loading... |
115 OperatorProperties::GetFrameStateInputCount(op)); | 117 OperatorProperties::GetFrameStateInputCount(op)); |
116 EXPECT_EQ(sop.effect_input_count, op->EffectInputCount()); | 118 EXPECT_EQ(sop.effect_input_count, op->EffectInputCount()); |
117 EXPECT_EQ(sop.control_input_count, op->ControlInputCount()); | 119 EXPECT_EQ(sop.control_input_count, op->ControlInputCount()); |
118 EXPECT_EQ(sop.value_input_count + context_input_count + | 120 EXPECT_EQ(sop.value_input_count + context_input_count + |
119 frame_state_input_count + sop.effect_input_count + | 121 frame_state_input_count + sop.effect_input_count + |
120 sop.control_input_count, | 122 sop.control_input_count, |
121 OperatorProperties::GetTotalInputCount(op)); | 123 OperatorProperties::GetTotalInputCount(op)); |
122 | 124 |
123 EXPECT_EQ(sop.value_output_count, op->ValueOutputCount()); | 125 EXPECT_EQ(sop.value_output_count, op->ValueOutputCount()); |
124 EXPECT_EQ(sop.effect_output_count, op->EffectOutputCount()); | 126 EXPECT_EQ(sop.effect_output_count, op->EffectOutputCount()); |
125 EXPECT_EQ(0, op->ControlOutputCount()); | 127 EXPECT_EQ(sop.control_output_count, op->ControlOutputCount()); |
126 } | 128 } |
127 | 129 |
128 | 130 |
129 TEST_P(JSSharedOperatorTest, OpcodeIsCorrect) { | 131 TEST_P(JSSharedOperatorTest, OpcodeIsCorrect) { |
130 JSOperatorBuilder javascript(zone()); | 132 JSOperatorBuilder javascript(zone()); |
131 const SharedOperator& sop = GetParam(); | 133 const SharedOperator& sop = GetParam(); |
132 const Operator* op = (javascript.*sop.constructor)(); | 134 const Operator* op = (javascript.*sop.constructor)(); |
133 EXPECT_EQ(sop.opcode, op->opcode()); | 135 EXPECT_EQ(sop.opcode, op->opcode()); |
134 } | 136 } |
135 | 137 |
(...skipping 38 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
174 EXPECT_EQ(1, OperatorProperties::GetContextInputCount(op)); | 176 EXPECT_EQ(1, OperatorProperties::GetContextInputCount(op)); |
175 EXPECT_EQ(frame_state_input_count, | 177 EXPECT_EQ(frame_state_input_count, |
176 OperatorProperties::GetFrameStateInputCount(op)); | 178 OperatorProperties::GetFrameStateInputCount(op)); |
177 EXPECT_EQ(1, op->EffectInputCount()); | 179 EXPECT_EQ(1, op->EffectInputCount()); |
178 EXPECT_EQ(1, op->ControlInputCount()); | 180 EXPECT_EQ(1, op->ControlInputCount()); |
179 EXPECT_EQ(6 + frame_state_input_count, | 181 EXPECT_EQ(6 + frame_state_input_count, |
180 OperatorProperties::GetTotalInputCount(op)); | 182 OperatorProperties::GetTotalInputCount(op)); |
181 | 183 |
182 EXPECT_EQ(0, op->ValueOutputCount()); | 184 EXPECT_EQ(0, op->ValueOutputCount()); |
183 EXPECT_EQ(1, op->EffectOutputCount()); | 185 EXPECT_EQ(1, op->EffectOutputCount()); |
184 EXPECT_EQ(0, op->ControlOutputCount()); | 186 EXPECT_EQ(2, op->ControlOutputCount()); |
185 } | 187 } |
186 | 188 |
187 | 189 |
188 TEST_P(JSStorePropertyOperatorTest, OpcodeIsCorrect) { | 190 TEST_P(JSStorePropertyOperatorTest, OpcodeIsCorrect) { |
189 JSOperatorBuilder javascript(zone()); | 191 JSOperatorBuilder javascript(zone()); |
190 const LanguageMode mode = GetParam(); | 192 const LanguageMode mode = GetParam(); |
191 const Operator* op = javascript.StoreProperty(mode); | 193 const Operator* op = javascript.StoreProperty(mode); |
192 EXPECT_EQ(IrOpcode::kJSStoreProperty, op->opcode()); | 194 EXPECT_EQ(IrOpcode::kJSStoreProperty, op->opcode()); |
193 } | 195 } |
194 | 196 |
(...skipping 13 matching lines...) Expand all Loading... |
208 EXPECT_EQ(Operator::kNoProperties, op->properties()); | 210 EXPECT_EQ(Operator::kNoProperties, op->properties()); |
209 } | 211 } |
210 | 212 |
211 | 213 |
212 INSTANTIATE_TEST_CASE_P(JSOperatorTest, JSStorePropertyOperatorTest, | 214 INSTANTIATE_TEST_CASE_P(JSOperatorTest, JSStorePropertyOperatorTest, |
213 ::testing::Values(SLOPPY, STRICT)); | 215 ::testing::Values(SLOPPY, STRICT)); |
214 | 216 |
215 } // namespace compiler | 217 } // namespace compiler |
216 } // namespace internal | 218 } // namespace internal |
217 } // namespace v8 | 219 } // namespace v8 |
OLD | NEW |