| Index: test/unittests/compiler/js-context-relaxation-unittest.cc
|
| diff --git a/test/unittests/compiler/js-context-relaxation-unittest.cc b/test/unittests/compiler/js-context-relaxation-unittest.cc
|
| deleted file mode 100644
|
| index 5621e4604aa2805dabb42a5e665c3b17f85dcb0b..0000000000000000000000000000000000000000
|
| --- a/test/unittests/compiler/js-context-relaxation-unittest.cc
|
| +++ /dev/null
|
| @@ -1,285 +0,0 @@
|
| -// Copyright 2015 the V8 project authors. All rights reserved.
|
| -// Use of this source code is governed by a BSD-style license that can be
|
| -// found in the LICENSE file.
|
| -
|
| -#include "src/compiler/js-context-relaxation.h"
|
| -#include "src/compiler/js-graph.h"
|
| -#include "test/unittests/compiler/graph-unittest.h"
|
| -#include "test/unittests/compiler/node-test-utils.h"
|
| -
|
| -namespace v8 {
|
| -namespace internal {
|
| -namespace compiler {
|
| -
|
| -class JSContextRelaxationTest : public GraphTest {
|
| - public:
|
| - JSContextRelaxationTest() : GraphTest(3), javascript_(zone()) {}
|
| - ~JSContextRelaxationTest() override {}
|
| -
|
| - protected:
|
| - Reduction Reduce(Node* node, MachineOperatorBuilder::Flags flags =
|
| - MachineOperatorBuilder::kNoFlags) {
|
| - MachineOperatorBuilder machine(zone(), MachineType::PointerRepresentation(),
|
| - flags);
|
| - JSGraph jsgraph(isolate(), graph(), common(), javascript(), nullptr,
|
| - &machine);
|
| - // TODO(titzer): mock the GraphReducer here for better unit testing.
|
| - GraphReducer graph_reducer(zone(), graph());
|
| - JSContextRelaxation reducer;
|
| - return reducer.Reduce(node);
|
| - }
|
| -
|
| - Node* EmptyFrameState() {
|
| - MachineOperatorBuilder machine(zone());
|
| - JSGraph jsgraph(isolate(), graph(), common(), javascript(), nullptr,
|
| - &machine);
|
| - return jsgraph.EmptyFrameState();
|
| - }
|
| -
|
| - Node* ShallowFrameStateChain(Node* outer_context,
|
| - ContextCallingMode context_calling_mode) {
|
| - const FrameStateFunctionInfo* const frame_state_function_info =
|
| - common()->CreateFrameStateFunctionInfo(
|
| - FrameStateType::kJavaScriptFunction, 3, 0,
|
| - Handle<SharedFunctionInfo>(), context_calling_mode);
|
| - const Operator* op = common()->FrameState(BailoutId::None(),
|
| - OutputFrameStateCombine::Ignore(),
|
| - frame_state_function_info);
|
| - return graph()->NewNode(op, graph()->start(), graph()->start(),
|
| - graph()->start(), outer_context, graph()->start(),
|
| - graph()->start());
|
| - }
|
| -
|
| - Node* DeepFrameStateChain(Node* outer_context,
|
| - ContextCallingMode context_calling_mode) {
|
| - const FrameStateFunctionInfo* const frame_state_function_info =
|
| - common()->CreateFrameStateFunctionInfo(
|
| - FrameStateType::kJavaScriptFunction, 3, 0,
|
| - Handle<SharedFunctionInfo>(), context_calling_mode);
|
| - const Operator* op = common()->FrameState(BailoutId::None(),
|
| - OutputFrameStateCombine::Ignore(),
|
| - frame_state_function_info);
|
| - Node* shallow_frame_state =
|
| - ShallowFrameStateChain(outer_context, CALL_MAINTAINS_NATIVE_CONTEXT);
|
| - return graph()->NewNode(op, graph()->start(), graph()->start(),
|
| - graph()->start(), graph()->start(),
|
| - graph()->start(), shallow_frame_state);
|
| - }
|
| -
|
| - JSOperatorBuilder* javascript() { return &javascript_; }
|
| -
|
| - private:
|
| - JSOperatorBuilder javascript_;
|
| -};
|
| -
|
| -
|
| -TEST_F(JSContextRelaxationTest,
|
| - RelaxJSCallFunctionShallowFrameStateChainNoCrossCtx) {
|
| - Node* const input0 = Parameter(0);
|
| - Node* const input1 = Parameter(1);
|
| - Node* const context = Parameter(2);
|
| - Node* const outer_context = Parameter(3);
|
| - Node* const frame_state =
|
| - ShallowFrameStateChain(outer_context, CALL_MAINTAINS_NATIVE_CONTEXT);
|
| - Node* const effect = graph()->start();
|
| - Node* const control = graph()->start();
|
| - Node* node = graph()->NewNode(javascript()->CallFunction(2, VectorSlotPair()),
|
| - input0, input1, context, frame_state,
|
| - frame_state, effect, control);
|
| - Reduction const r = Reduce(node);
|
| - EXPECT_TRUE(r.Changed());
|
| - EXPECT_EQ(outer_context, NodeProperties::GetContextInput(node));
|
| -}
|
| -
|
| -TEST_F(JSContextRelaxationTest,
|
| - RelaxJSCallFunctionShallowFrameStateChainCrossCtx) {
|
| - Node* const input0 = Parameter(0);
|
| - Node* const input1 = Parameter(1);
|
| - Node* const context = Parameter(2);
|
| - Node* const outer_context = Parameter(3);
|
| - Node* const frame_state =
|
| - ShallowFrameStateChain(outer_context, CALL_CHANGES_NATIVE_CONTEXT);
|
| - Node* const effect = graph()->start();
|
| - Node* const control = graph()->start();
|
| - Node* node = graph()->NewNode(javascript()->CallFunction(2, VectorSlotPair()),
|
| - input0, input1, context, frame_state,
|
| - frame_state, effect, control);
|
| - Reduction const r = Reduce(node);
|
| - EXPECT_FALSE(r.Changed());
|
| - EXPECT_EQ(context, NodeProperties::GetContextInput(node));
|
| -}
|
| -
|
| -TEST_F(JSContextRelaxationTest,
|
| - RelaxJSCallFunctionDeepFrameStateChainNoCrossCtx) {
|
| - Node* const input0 = Parameter(0);
|
| - Node* const input1 = Parameter(1);
|
| - Node* const context = Parameter(2);
|
| - Node* const outer_context = Parameter(3);
|
| - Node* const frame_state =
|
| - DeepFrameStateChain(outer_context, CALL_MAINTAINS_NATIVE_CONTEXT);
|
| - Node* const effect = graph()->start();
|
| - Node* const control = graph()->start();
|
| - Node* node = graph()->NewNode(javascript()->CallFunction(2, VectorSlotPair()),
|
| - input0, input1, context, frame_state,
|
| - frame_state, effect, control);
|
| - Reduction const r = Reduce(node);
|
| - EXPECT_TRUE(r.Changed());
|
| - EXPECT_EQ(outer_context, NodeProperties::GetContextInput(node));
|
| -}
|
| -
|
| -TEST_F(JSContextRelaxationTest,
|
| - RelaxJSCallFunctionDeepFrameStateChainCrossCtx) {
|
| - Node* const input0 = Parameter(0);
|
| - Node* const input1 = Parameter(1);
|
| - Node* const context = Parameter(2);
|
| - Node* const outer_context = Parameter(3);
|
| - Node* const frame_state =
|
| - DeepFrameStateChain(outer_context, CALL_CHANGES_NATIVE_CONTEXT);
|
| - Node* const effect = graph()->start();
|
| - Node* const control = graph()->start();
|
| - Node* node = graph()->NewNode(javascript()->CallFunction(2, VectorSlotPair()),
|
| - input0, input1, context, frame_state,
|
| - frame_state, effect, control);
|
| - Reduction const r = Reduce(node);
|
| - EXPECT_FALSE(r.Changed());
|
| - EXPECT_EQ(context, NodeProperties::GetContextInput(node));
|
| -}
|
| -
|
| -TEST_F(JSContextRelaxationTest,
|
| - RelaxJSCallFunctionDeepContextChainFullRelaxForCatch) {
|
| - Node* const input0 = Parameter(0);
|
| - Node* const input1 = Parameter(1);
|
| - Node* const context = Parameter(2);
|
| - Node* const outer_context = Parameter(3);
|
| - const Operator* op = javascript()->CreateCatchContext(Handle<String>());
|
| - Node* const effect = graph()->start();
|
| - Node* const control = graph()->start();
|
| - Node* nested_context = graph()->NewNode(
|
| - op, graph()->start(), graph()->start(), outer_context, effect, control);
|
| - Node* const frame_state_2 =
|
| - ShallowFrameStateChain(nested_context, CALL_MAINTAINS_NATIVE_CONTEXT);
|
| - Node* node = graph()->NewNode(javascript()->CallFunction(2, VectorSlotPair()),
|
| - input0, input1, context, frame_state_2,
|
| - frame_state_2, effect, control);
|
| - Reduction const r = Reduce(node);
|
| - EXPECT_TRUE(r.Changed());
|
| - EXPECT_EQ(outer_context, NodeProperties::GetContextInput(node));
|
| -}
|
| -
|
| -
|
| -TEST_F(JSContextRelaxationTest,
|
| - RelaxJSCallFunctionDeepContextChainFullRelaxForWith) {
|
| - Node* const input0 = Parameter(0);
|
| - Node* const input1 = Parameter(1);
|
| - Node* const context = Parameter(2);
|
| - Node* const outer_context = Parameter(3);
|
| - const Operator* op = javascript()->CreateWithContext();
|
| - Node* const effect = graph()->start();
|
| - Node* const control = graph()->start();
|
| - Node* nested_context = graph()->NewNode(
|
| - op, graph()->start(), graph()->start(), outer_context, effect, control);
|
| - Node* const frame_state_2 =
|
| - ShallowFrameStateChain(nested_context, CALL_MAINTAINS_NATIVE_CONTEXT);
|
| - Node* node = graph()->NewNode(javascript()->CallFunction(2, VectorSlotPair()),
|
| - input0, input1, context, frame_state_2,
|
| - frame_state_2, effect, control);
|
| - Reduction const r = Reduce(node);
|
| - EXPECT_TRUE(r.Changed());
|
| - EXPECT_EQ(outer_context, NodeProperties::GetContextInput(node));
|
| -}
|
| -
|
| -
|
| -TEST_F(JSContextRelaxationTest,
|
| - RelaxJSCallFunctionDeepContextChainFullRelaxForBlock) {
|
| - Node* const input0 = Parameter(0);
|
| - Node* const input1 = Parameter(1);
|
| - Node* const context = Parameter(2);
|
| - Node* const outer_context = Parameter(3);
|
| - Handle<ScopeInfo> scope_info = Handle<ScopeInfo>::null();
|
| - const Operator* op = javascript()->CreateBlockContext(scope_info);
|
| - Node* const effect = graph()->start();
|
| - Node* const control = graph()->start();
|
| - Node* nested_context =
|
| - graph()->NewNode(op, graph()->start(), outer_context, effect, control);
|
| - Node* const frame_state_2 =
|
| - ShallowFrameStateChain(nested_context, CALL_MAINTAINS_NATIVE_CONTEXT);
|
| - Node* node = graph()->NewNode(javascript()->CallFunction(2, VectorSlotPair()),
|
| - input0, input1, context, frame_state_2,
|
| - frame_state_2, effect, control);
|
| - Reduction const r = Reduce(node);
|
| - EXPECT_TRUE(r.Changed());
|
| - EXPECT_EQ(outer_context, NodeProperties::GetContextInput(node));
|
| -}
|
| -
|
| -
|
| -TEST_F(JSContextRelaxationTest,
|
| - RelaxJSCallFunctionDeepContextChainPartialRelaxForScript) {
|
| - Node* const input0 = Parameter(0);
|
| - Node* const input1 = Parameter(1);
|
| - Node* const context = Parameter(2);
|
| - Node* const outer_context = Parameter(3);
|
| - Handle<ScopeInfo> scope_info = Handle<ScopeInfo>::null();
|
| - const Operator* op = javascript()->CreateScriptContext(scope_info);
|
| - Node* const frame_state_1 =
|
| - ShallowFrameStateChain(outer_context, CALL_MAINTAINS_NATIVE_CONTEXT);
|
| - Node* const effect = graph()->start();
|
| - Node* const control = graph()->start();
|
| - Node* nested_context = graph()->NewNode(op, graph()->start(), outer_context,
|
| - frame_state_1, effect, control);
|
| - Node* const frame_state_2 =
|
| - ShallowFrameStateChain(nested_context, CALL_MAINTAINS_NATIVE_CONTEXT);
|
| - Node* node = graph()->NewNode(javascript()->CallFunction(2, VectorSlotPair()),
|
| - input0, input1, context, frame_state_2,
|
| - frame_state_2, effect, control);
|
| - Reduction const r = Reduce(node);
|
| - EXPECT_TRUE(r.Changed());
|
| - EXPECT_EQ(nested_context, NodeProperties::GetContextInput(node));
|
| -}
|
| -
|
| -
|
| -TEST_F(JSContextRelaxationTest,
|
| - RelaxJSCallFunctionDeepContextChainPartialRelaxForModule) {
|
| - Node* const input0 = Parameter(0);
|
| - Node* const input1 = Parameter(1);
|
| - Node* const context = Parameter(2);
|
| - Node* const outer_context = Parameter(3);
|
| - const Operator* op = javascript()->CreateModuleContext();
|
| - Node* const effect = graph()->start();
|
| - Node* const control = graph()->start();
|
| - Node* nested_context = graph()->NewNode(
|
| - op, graph()->start(), graph()->start(), outer_context, effect, control);
|
| - Node* const frame_state_2 =
|
| - ShallowFrameStateChain(nested_context, CALL_MAINTAINS_NATIVE_CONTEXT);
|
| - Node* node = graph()->NewNode(javascript()->CallFunction(2, VectorSlotPair()),
|
| - input0, input1, context, frame_state_2,
|
| - frame_state_2, effect, control);
|
| - Reduction const r = Reduce(node);
|
| - EXPECT_TRUE(r.Changed());
|
| - EXPECT_EQ(nested_context, NodeProperties::GetContextInput(node));
|
| -}
|
| -
|
| -
|
| -TEST_F(JSContextRelaxationTest,
|
| - RelaxJSCallFunctionDeepContextChainPartialNoRelax) {
|
| - Node* const input0 = Parameter(0);
|
| - Node* const input1 = Parameter(1);
|
| - Node* const context = Parameter(2);
|
| - Node* const outer_context = Parameter(3);
|
| - const Operator* op = javascript()->CreateFunctionContext(0);
|
| - Node* const effect = graph()->start();
|
| - Node* const control = graph()->start();
|
| - Node* nested_context =
|
| - graph()->NewNode(op, graph()->start(), outer_context, effect, control);
|
| - Node* const frame_state_2 =
|
| - ShallowFrameStateChain(nested_context, CALL_MAINTAINS_NATIVE_CONTEXT);
|
| - Node* node = graph()->NewNode(javascript()->CallFunction(2, VectorSlotPair()),
|
| - input0, input1, context, frame_state_2,
|
| - frame_state_2, effect, control);
|
| - Reduction const r = Reduce(node);
|
| - EXPECT_FALSE(r.Changed());
|
| - EXPECT_EQ(context, NodeProperties::GetContextInput(node));
|
| -}
|
| -
|
| -} // namespace compiler
|
| -} // namespace internal
|
| -} // namespace v8
|
|
|