Chromium Code Reviews| Index: test/unittests/interpreter/interpreter-assembler-unittest.cc |
| diff --git a/test/unittests/interpreter/interpreter-assembler-unittest.cc b/test/unittests/interpreter/interpreter-assembler-unittest.cc |
| index b8eb64c8844261c26f72f6962731f9e3ed069aa0..ad49b798f660033aeff25cdebb92d9062ad2ba84 100644 |
| --- a/test/unittests/interpreter/interpreter-assembler-unittest.cc |
| +++ b/test/unittests/interpreter/interpreter-assembler-unittest.cc |
| @@ -5,7 +5,6 @@ |
| #include "test/unittests/interpreter/interpreter-assembler-unittest.h" |
| #include "src/code-factory.h" |
| -#include "src/compiler/graph.h" |
| #include "src/compiler/node.h" |
| #include "src/interface-descriptors.h" |
| #include "src/isolate.h" |
| @@ -21,6 +20,14 @@ using namespace compiler; |
| namespace interpreter { |
| +InterpreterAssemblerTestState::InterpreterAssemblerTestState( |
| + InterpreterAssemblerTest* test, Bytecode bytecode) |
| + : compiler::CodeAssemblerState( |
| + test->isolate(), test->zone(), |
| + InterpreterDispatchDescriptor(test->isolate()), |
| + Code::ComputeFlags(Code::BYTECODE_HANDLER), |
| + Bytecodes::ToString(bytecode), Bytecodes::ReturnCount(bytecode)) {} |
| + |
| const interpreter::Bytecode kBytecodes[] = { |
| #define DEFINE_BYTECODE(Name, ...) interpreter::Bytecode::k##Name, |
| BYTECODE_LIST(DEFINE_BYTECODE) |
| @@ -298,7 +305,8 @@ InterpreterAssemblerTest::InterpreterAssemblerForTest::IsUnsignedOperand( |
| TARGET_TEST_F(InterpreterAssemblerTest, Dispatch) { |
| TRACED_FOREACH(interpreter::Bytecode, bytecode, kBytecodes) { |
| - InterpreterAssemblerForTest m(this, bytecode); |
| + InterpreterAssemblerTestState state(this, bytecode); |
| + InterpreterAssemblerForTest m(&state, bytecode); |
|
Igor Sheludko
2016/11/15 13:06:35
... constructor function that creates an Interpret
|
| Node* tail_call_node = m.Dispatch(); |
| OperandScale operand_scale = OperandScale::kSingle; |
| @@ -364,7 +372,8 @@ TARGET_TEST_F(InterpreterAssemblerTest, Jump) { |
| TRACED_FOREACH(interpreter::Bytecode, bytecode, kBytecodes) { |
| if (!interpreter::Bytecodes::IsJump(bytecode)) return; |
| - InterpreterAssemblerForTest m(this, bytecode); |
| + InterpreterAssemblerTestState state(this, bytecode); |
| + InterpreterAssemblerForTest m(&state, bytecode); |
| Node* tail_call_node = m.Jump(m.IntPtrConstant(jump_offset)); |
| Matcher<Node*> next_bytecode_offset_matcher = IsIntPtrAdd( |
| @@ -398,7 +407,8 @@ TARGET_TEST_F(InterpreterAssemblerTest, BytecodeOperand) { |
| OperandScale::kSingle, OperandScale::kDouble, OperandScale::kQuadruple}; |
| TRACED_FOREACH(interpreter::Bytecode, bytecode, kBytecodes) { |
| TRACED_FOREACH(interpreter::OperandScale, operand_scale, kOperandScales) { |
| - InterpreterAssemblerForTest m(this, bytecode, operand_scale); |
| + InterpreterAssemblerTestState state(this, bytecode); |
| + InterpreterAssemblerForTest m(&state, bytecode, operand_scale); |
| int number_of_operands = |
| interpreter::Bytecodes::NumberOfOperands(bytecode); |
| for (int i = 0; i < number_of_operands; i++) { |
| @@ -463,7 +473,8 @@ TARGET_TEST_F(InterpreterAssemblerTest, GetSetAccumulator) { |
| continue; |
| } |
| - InterpreterAssemblerForTest m(this, bytecode); |
| + InterpreterAssemblerTestState state(this, bytecode); |
| + InterpreterAssemblerForTest m(&state, bytecode); |
| // Should be incoming accumulator if not set. |
| EXPECT_THAT(m.GetAccumulator(), |
| IsParameter(InterpreterDispatchDescriptor::kAccumulator)); |
| @@ -485,7 +496,8 @@ TARGET_TEST_F(InterpreterAssemblerTest, GetSetAccumulator) { |
| TARGET_TEST_F(InterpreterAssemblerTest, GetContext) { |
| TRACED_FOREACH(interpreter::Bytecode, bytecode, kBytecodes) { |
| - InterpreterAssemblerForTest m(this, bytecode); |
| + InterpreterAssemblerTestState state(this, bytecode); |
| + InterpreterAssemblerForTest m(&state, bytecode); |
| EXPECT_THAT( |
| m.GetContext(), |
| m.IsLoad(MachineType::AnyTagged(), IsLoadParentFramePointer(), |
| @@ -496,7 +508,8 @@ TARGET_TEST_F(InterpreterAssemblerTest, GetContext) { |
| TARGET_TEST_F(InterpreterAssemblerTest, RegisterLocation) { |
| TRACED_FOREACH(interpreter::Bytecode, bytecode, kBytecodes) { |
| - InterpreterAssemblerForTest m(this, bytecode); |
| + InterpreterAssemblerTestState state(this, bytecode); |
| + InterpreterAssemblerForTest m(&state, bytecode); |
| Node* reg_index_node = m.IntPtrConstant(44); |
| Node* reg_location_node = m.RegisterLocation(reg_index_node); |
| EXPECT_THAT(reg_location_node, |
| @@ -508,7 +521,8 @@ TARGET_TEST_F(InterpreterAssemblerTest, RegisterLocation) { |
| TARGET_TEST_F(InterpreterAssemblerTest, LoadRegister) { |
| TRACED_FOREACH(interpreter::Bytecode, bytecode, kBytecodes) { |
| - InterpreterAssemblerForTest m(this, bytecode); |
| + InterpreterAssemblerTestState state(this, bytecode); |
| + InterpreterAssemblerForTest m(&state, bytecode); |
| Node* reg_index_node = m.IntPtrConstant(44); |
| Node* load_reg_node = m.LoadRegister(reg_index_node); |
| EXPECT_THAT(load_reg_node, |
| @@ -520,7 +534,8 @@ TARGET_TEST_F(InterpreterAssemblerTest, LoadRegister) { |
| TARGET_TEST_F(InterpreterAssemblerTest, StoreRegister) { |
| TRACED_FOREACH(interpreter::Bytecode, bytecode, kBytecodes) { |
| - InterpreterAssemblerForTest m(this, bytecode); |
| + InterpreterAssemblerTestState state(this, bytecode); |
| + InterpreterAssemblerForTest m(&state, bytecode); |
| Node* store_value = m.Int32Constant(0xdeadbeef); |
| Node* reg_index_node = m.IntPtrConstant(44); |
| Node* store_reg_node = m.StoreRegister(store_value, reg_index_node); |
| @@ -536,7 +551,8 @@ TARGET_TEST_F(InterpreterAssemblerTest, StoreRegister) { |
| TARGET_TEST_F(InterpreterAssemblerTest, SmiTag) { |
| TRACED_FOREACH(interpreter::Bytecode, bytecode, kBytecodes) { |
| - InterpreterAssemblerForTest m(this, bytecode); |
| + InterpreterAssemblerTestState state(this, bytecode); |
| + InterpreterAssemblerForTest m(&state, bytecode); |
| Node* value = m.Int32Constant(44); |
| EXPECT_THAT(m.SmiTag(value), IsBitcastWordToTaggedSigned(IsIntPtrConstant( |
| static_cast<intptr_t>(44) |
| @@ -549,7 +565,8 @@ TARGET_TEST_F(InterpreterAssemblerTest, SmiTag) { |
| TARGET_TEST_F(InterpreterAssemblerTest, IntPtrAdd) { |
| TRACED_FOREACH(interpreter::Bytecode, bytecode, kBytecodes) { |
| - InterpreterAssemblerForTest m(this, bytecode); |
| + InterpreterAssemblerTestState state(this, bytecode); |
| + InterpreterAssemblerForTest m(&state, bytecode); |
| Node* a = m.Int32Constant(0); |
| Node* b = m.Int32Constant(1); |
| Node* add = m.IntPtrAdd(a, b); |
| @@ -559,7 +576,8 @@ TARGET_TEST_F(InterpreterAssemblerTest, IntPtrAdd) { |
| TARGET_TEST_F(InterpreterAssemblerTest, IntPtrSub) { |
| TRACED_FOREACH(interpreter::Bytecode, bytecode, kBytecodes) { |
| - InterpreterAssemblerForTest m(this, bytecode); |
| + InterpreterAssemblerTestState state(this, bytecode); |
| + InterpreterAssemblerForTest m(&state, bytecode); |
| Node* a = m.Int32Constant(0); |
| Node* b = m.Int32Constant(1); |
| Node* add = m.IntPtrSub(a, b); |
| @@ -569,7 +587,8 @@ TARGET_TEST_F(InterpreterAssemblerTest, IntPtrSub) { |
| TARGET_TEST_F(InterpreterAssemblerTest, WordShl) { |
| TRACED_FOREACH(interpreter::Bytecode, bytecode, kBytecodes) { |
| - InterpreterAssemblerForTest m(this, bytecode); |
| + InterpreterAssemblerTestState state(this, bytecode); |
| + InterpreterAssemblerForTest m(&state, bytecode); |
| Node* a = m.IntPtrConstant(0); |
| Node* add = m.WordShl(a, 10); |
| EXPECT_THAT(add, IsWordShl(a, IsIntPtrConstant(10))); |
| @@ -578,7 +597,8 @@ TARGET_TEST_F(InterpreterAssemblerTest, WordShl) { |
| TARGET_TEST_F(InterpreterAssemblerTest, LoadConstantPoolEntry) { |
| TRACED_FOREACH(interpreter::Bytecode, bytecode, kBytecodes) { |
| - InterpreterAssemblerForTest m(this, bytecode); |
| + InterpreterAssemblerTestState state(this, bytecode); |
| + InterpreterAssemblerForTest m(&state, bytecode); |
| Node* index = m.IntPtrConstant(2); |
| Node* load_constant = m.LoadConstantPoolEntry(index); |
| Matcher<Node*> constant_pool_matcher = m.IsLoad( |
| @@ -596,7 +616,8 @@ TARGET_TEST_F(InterpreterAssemblerTest, LoadConstantPoolEntry) { |
| TARGET_TEST_F(InterpreterAssemblerTest, LoadObjectField) { |
| TRACED_FOREACH(interpreter::Bytecode, bytecode, kBytecodes) { |
| - InterpreterAssemblerForTest m(this, bytecode); |
| + InterpreterAssemblerTestState state(this, bytecode); |
| + InterpreterAssemblerForTest m(&state, bytecode); |
| Node* object = m.IntPtrConstant(0xdeadbeef); |
| int offset = 16; |
| Node* load_field = m.LoadObjectField(object, offset); |
| @@ -608,7 +629,8 @@ TARGET_TEST_F(InterpreterAssemblerTest, LoadObjectField) { |
| TARGET_TEST_F(InterpreterAssemblerTest, CallRuntime2) { |
| TRACED_FOREACH(interpreter::Bytecode, bytecode, kBytecodes) { |
| - InterpreterAssemblerForTest m(this, bytecode); |
| + InterpreterAssemblerTestState state(this, bytecode); |
| + InterpreterAssemblerForTest m(&state, bytecode); |
| Node* arg1 = m.Int32Constant(2); |
| Node* arg2 = m.Int32Constant(3); |
| Node* context = m.Int32Constant(4); |
| @@ -622,7 +644,8 @@ TARGET_TEST_F(InterpreterAssemblerTest, CallRuntime) { |
| const int kResultSizes[] = {1, 2}; |
| TRACED_FOREACH(interpreter::Bytecode, bytecode, kBytecodes) { |
| TRACED_FOREACH(int, result_size, kResultSizes) { |
| - InterpreterAssemblerForTest m(this, bytecode); |
| + InterpreterAssemblerTestState state(this, bytecode); |
| + InterpreterAssemblerForTest m(&state, bytecode); |
| Callable builtin = CodeFactory::InterpreterCEntry(isolate(), result_size); |
| Node* function_id = m.Int32Constant(0); |
| @@ -653,7 +676,8 @@ TARGET_TEST_F(InterpreterAssemblerTest, CallJS) { |
| TailCallMode::kAllow}; |
| TRACED_FOREACH(TailCallMode, tail_call_mode, tail_call_modes) { |
| TRACED_FOREACH(interpreter::Bytecode, bytecode, kBytecodes) { |
| - InterpreterAssemblerForTest m(this, bytecode); |
| + InterpreterAssemblerTestState state(this, bytecode); |
| + InterpreterAssemblerForTest m(&state, bytecode); |
| Callable builtin = |
| CodeFactory::InterpreterPushArgsAndCall(isolate(), tail_call_mode); |
| Node* function = m.Int32Constant(0); |
| @@ -670,7 +694,8 @@ TARGET_TEST_F(InterpreterAssemblerTest, CallJS) { |
| TARGET_TEST_F(InterpreterAssemblerTest, LoadTypeFeedbackVector) { |
| TRACED_FOREACH(interpreter::Bytecode, bytecode, kBytecodes) { |
| - InterpreterAssemblerForTest m(this, bytecode); |
| + InterpreterAssemblerTestState state(this, bytecode); |
| + InterpreterAssemblerForTest m(&state, bytecode); |
| Node* feedback_vector = m.LoadTypeFeedbackVector(); |
| Matcher<Node*> load_function_matcher = |