Commit e3f40478 authored by mstarzinger's avatar mstarzinger Committed by Commit bot

[turbofan] Deprecate RawMachineAssembler::CallFunctionStub0.

This deprecates the ability of the raw machine assembler to utilize the
CallFunctionStub in preparation of the stub itself being deprecated. We
only used this to test instruction selection of calls to stubs that can
deoptimize, the test has been adapted.

R=verwaest@chromium.org
TEST=unittests/InstructionSelectorTest

Review URL: https://codereview.chromium.org/1408193006

Cr-Commit-Position: refs/heads/master@{#31799}
parent f687c4f4
...@@ -174,19 +174,6 @@ Node* RawMachineAssembler::TailCallN(CallDescriptor* desc, Node* function, ...@@ -174,19 +174,6 @@ Node* RawMachineAssembler::TailCallN(CallDescriptor* desc, Node* function,
} }
Node* RawMachineAssembler::CallFunctionStub0(Node* function, Node* receiver,
Node* context, Node* frame_state,
CallFunctionFlags flags) {
Callable callable = CodeFactory::CallFunction(isolate(), 0, flags);
CallDescriptor* desc = Linkage::GetStubCallDescriptor(
isolate(), zone(), callable.descriptor(), 1,
CallDescriptor::kNeedsFrameState, Operator::kNoProperties);
Node* stub_code = HeapConstant(callable.code());
return AddNode(common()->Call(desc), stub_code, function, receiver, context,
frame_state, graph()->start(), graph()->start());
}
Node* RawMachineAssembler::CallRuntime1(Runtime::FunctionId function, Node* RawMachineAssembler::CallRuntime1(Runtime::FunctionId function,
Node* arg1, Node* context) { Node* arg1, Node* context) {
CallDescriptor* descriptor = Linkage::GetRuntimeCallDescriptor( CallDescriptor* descriptor = Linkage::GetRuntimeCallDescriptor(
......
...@@ -521,9 +521,6 @@ class RawMachineAssembler { ...@@ -521,9 +521,6 @@ class RawMachineAssembler {
Node* frame_state); Node* frame_state);
// Tail call the given call descriptor and the given arguments. // Tail call the given call descriptor and the given arguments.
Node* TailCallN(CallDescriptor* call_descriptor, Node* function, Node** args); Node* TailCallN(CallDescriptor* call_descriptor, Node* function, Node** args);
// Call through CallFunctionStub with lazy deopt and frame-state.
Node* CallFunctionStub0(Node* function, Node* receiver, Node* context,
Node* frame_state, CallFunctionFlags flags);
// Call to a runtime function with one arguments. // Call to a runtime function with one arguments.
Node* CallRuntime1(Runtime::FunctionId function, Node* arg0, Node* context); Node* CallRuntime1(Runtime::FunctionId function, Node* arg0, Node* context);
// Call to a runtime function with two arguments. // Call to a runtime function with two arguments.
......
...@@ -4,6 +4,7 @@ ...@@ -4,6 +4,7 @@
#include "test/unittests/compiler/instruction-selector-unittest.h" #include "test/unittests/compiler/instruction-selector-unittest.h"
#include "src/code-factory.h"
#include "src/compiler/graph.h" #include "src/compiler/graph.h"
#include "src/compiler/schedule.h" #include "src/compiler/schedule.h"
#include "src/flags.h" #include "src/flags.h"
...@@ -371,17 +372,19 @@ TARGET_TEST_F(InstructionSelectorTest, CallJSFunctionWithDeopt) { ...@@ -371,17 +372,19 @@ TARGET_TEST_F(InstructionSelectorTest, CallJSFunctionWithDeopt) {
CallDescriptor* descriptor = Linkage::GetJSCallDescriptor( CallDescriptor* descriptor = Linkage::GetJSCallDescriptor(
zone(), false, 1, CallDescriptor::kNeedsFrameState); zone(), false, 1, CallDescriptor::kNeedsFrameState);
// Build frame state for the state before the call.
Node* parameters = Node* parameters =
m.AddNode(m.common()->TypedStateValues(&int32_type), m.Int32Constant(1)); m.AddNode(m.common()->TypedStateValues(&int32_type), m.Int32Constant(1));
Node* locals = m.AddNode(m.common()->TypedStateValues(&empty_types)); Node* locals = m.AddNode(m.common()->TypedStateValues(&empty_types));
Node* stack = m.AddNode(m.common()->TypedStateValues(&empty_types)); Node* stack = m.AddNode(m.common()->TypedStateValues(&empty_types));
Node* context_dummy = m.Int32Constant(0); Node* context_sentinel = m.Int32Constant(0);
Node* state_node = m.AddNode( Node* state_node = m.AddNode(
m.common()->FrameState(bailout_id, OutputFrameStateCombine::Push(), m.common()->FrameState(bailout_id, OutputFrameStateCombine::Push(),
m.GetFrameStateFunctionInfo(1, 0)), m.GetFrameStateFunctionInfo(1, 0)),
parameters, locals, stack, context_dummy, function_node, parameters, locals, stack, context_sentinel, function_node,
m.UndefinedConstant()); m.UndefinedConstant());
// Build the call.
Node* args[] = {receiver, m.Int32Constant(1), context}; Node* args[] = {receiver, m.Int32Constant(1), context};
Node* call = Node* call =
m.CallNWithFrameState(descriptor, function_node, args, state_node); m.CallNWithFrameState(descriptor, function_node, args, state_node);
...@@ -404,7 +407,7 @@ TARGET_TEST_F(InstructionSelectorTest, CallJSFunctionWithDeopt) { ...@@ -404,7 +407,7 @@ TARGET_TEST_F(InstructionSelectorTest, CallJSFunctionWithDeopt) {
} }
TARGET_TEST_F(InstructionSelectorTest, CallFunctionStubWithDeopt) { TARGET_TEST_F(InstructionSelectorTest, CallStubWithDeopt) {
StreamBuilder m(this, kMachAnyTagged, kMachAnyTagged, kMachAnyTagged, StreamBuilder m(this, kMachAnyTagged, kMachAnyTagged, kMachAnyTagged,
kMachAnyTagged); kMachAnyTagged);
...@@ -419,6 +422,11 @@ TARGET_TEST_F(InstructionSelectorTest, CallFunctionStubWithDeopt) { ...@@ -419,6 +422,11 @@ TARGET_TEST_F(InstructionSelectorTest, CallFunctionStubWithDeopt) {
ZoneVector<MachineType> float64_type(1, kMachFloat64, zone()); ZoneVector<MachineType> float64_type(1, kMachFloat64, zone());
ZoneVector<MachineType> tagged_type(1, kMachAnyTagged, zone()); ZoneVector<MachineType> tagged_type(1, kMachAnyTagged, zone());
Callable callable = CodeFactory::ToObject(isolate());
CallDescriptor* descriptor = Linkage::GetStubCallDescriptor(
isolate(), zone(), callable.descriptor(), 1,
CallDescriptor::kNeedsFrameState, Operator::kNoProperties);
// Build frame state for the state before the call. // Build frame state for the state before the call.
Node* parameters = Node* parameters =
m.AddNode(m.common()->TypedStateValues(&int32_type), m.Int32Constant(43)); m.AddNode(m.common()->TypedStateValues(&int32_type), m.Int32Constant(43));
...@@ -426,18 +434,17 @@ TARGET_TEST_F(InstructionSelectorTest, CallFunctionStubWithDeopt) { ...@@ -426,18 +434,17 @@ TARGET_TEST_F(InstructionSelectorTest, CallFunctionStubWithDeopt) {
m.Float64Constant(0.5)); m.Float64Constant(0.5));
Node* stack = m.AddNode(m.common()->TypedStateValues(&tagged_type), Node* stack = m.AddNode(m.common()->TypedStateValues(&tagged_type),
m.UndefinedConstant()); m.UndefinedConstant());
Node* context_sentinel = m.Int32Constant(0); Node* context_sentinel = m.Int32Constant(0);
Node* frame_state_before = m.AddNode( Node* state_node = m.AddNode(
m.common()->FrameState(bailout_id_before, OutputFrameStateCombine::Push(), m.common()->FrameState(bailout_id_before, OutputFrameStateCombine::Push(),
m.GetFrameStateFunctionInfo(1, 1)), m.GetFrameStateFunctionInfo(1, 1)),
parameters, locals, stack, context_sentinel, function_node, parameters, locals, stack, context_sentinel, function_node,
m.UndefinedConstant()); m.UndefinedConstant());
// Build the call. // Build the call.
Node* call = m.CallFunctionStub0(function_node, receiver, context, Node* args[] = {function_node, receiver, context};
frame_state_before, CALL_AS_METHOD); Node* stub_code = m.HeapConstant(callable.code());
Node* call = m.CallNWithFrameState(descriptor, stub_code, args, state_node);
m.Return(call); m.Return(call);
Stream s = m.Build(kAllExceptNopInstructions); Stream s = m.Build(kAllExceptNopInstructions);
...@@ -498,8 +505,7 @@ TARGET_TEST_F(InstructionSelectorTest, CallFunctionStubWithDeopt) { ...@@ -498,8 +505,7 @@ TARGET_TEST_F(InstructionSelectorTest, CallFunctionStubWithDeopt) {
} }
TARGET_TEST_F(InstructionSelectorTest, TARGET_TEST_F(InstructionSelectorTest, CallStubWithDeoptRecursiveFrameState) {
CallFunctionStubDeoptRecursiveFrameState) {
StreamBuilder m(this, kMachAnyTagged, kMachAnyTagged, kMachAnyTagged, StreamBuilder m(this, kMachAnyTagged, kMachAnyTagged, kMachAnyTagged,
kMachAnyTagged); kMachAnyTagged);
...@@ -510,11 +516,17 @@ TARGET_TEST_F(InstructionSelectorTest, ...@@ -510,11 +516,17 @@ TARGET_TEST_F(InstructionSelectorTest,
Node* function_node = m.Parameter(0); Node* function_node = m.Parameter(0);
Node* receiver = m.Parameter(1); Node* receiver = m.Parameter(1);
Node* context = m.Int32Constant(66); Node* context = m.Int32Constant(66);
Node* context2 = m.Int32Constant(46);
ZoneVector<MachineType> int32_type(1, kMachInt32, zone()); ZoneVector<MachineType> int32_type(1, kMachInt32, zone());
ZoneVector<MachineType> int32x2_type(2, kMachInt32, zone()); ZoneVector<MachineType> int32x2_type(2, kMachInt32, zone());
ZoneVector<MachineType> float64_type(1, kMachFloat64, zone()); ZoneVector<MachineType> float64_type(1, kMachFloat64, zone());
Callable callable = CodeFactory::ToObject(isolate());
CallDescriptor* descriptor = Linkage::GetStubCallDescriptor(
isolate(), zone(), callable.descriptor(), 1,
CallDescriptor::kNeedsFrameState, Operator::kNoProperties);
// Build frame state for the state before the call. // Build frame state for the state before the call.
Node* parameters = Node* parameters =
m.AddNode(m.common()->TypedStateValues(&int32_type), m.Int32Constant(63)); m.AddNode(m.common()->TypedStateValues(&int32_type), m.Int32Constant(63));
...@@ -528,23 +540,22 @@ TARGET_TEST_F(InstructionSelectorTest, ...@@ -528,23 +540,22 @@ TARGET_TEST_F(InstructionSelectorTest,
m.GetFrameStateFunctionInfo(1, 1)), m.GetFrameStateFunctionInfo(1, 1)),
parameters, locals, stack, context, function_node, m.UndefinedConstant()); parameters, locals, stack, context, function_node, m.UndefinedConstant());
Node* context2 = m.Int32Constant(46);
Node* parameters2 = Node* parameters2 =
m.AddNode(m.common()->TypedStateValues(&int32_type), m.Int32Constant(43)); m.AddNode(m.common()->TypedStateValues(&int32_type), m.Int32Constant(43));
Node* locals2 = m.AddNode(m.common()->TypedStateValues(&float64_type), Node* locals2 = m.AddNode(m.common()->TypedStateValues(&float64_type),
m.Float64Constant(0.25)); m.Float64Constant(0.25));
Node* stack2 = m.AddNode(m.common()->TypedStateValues(&int32x2_type), Node* stack2 = m.AddNode(m.common()->TypedStateValues(&int32x2_type),
m.Int32Constant(44), m.Int32Constant(45)); m.Int32Constant(44), m.Int32Constant(45));
Node* frame_state_before = m.AddNode( Node* state_node = m.AddNode(
m.common()->FrameState(bailout_id_before, OutputFrameStateCombine::Push(), m.common()->FrameState(bailout_id_before, OutputFrameStateCombine::Push(),
m.GetFrameStateFunctionInfo(1, 1)), m.GetFrameStateFunctionInfo(1, 1)),
parameters2, locals2, stack2, context2, function_node, parameters2, locals2, stack2, context2, function_node,
frame_state_parent); frame_state_parent);
// Build the call. // Build the call.
Node* call = m.CallFunctionStub0(function_node, receiver, context2, Node* args[] = {function_node, receiver, context2};
frame_state_before, CALL_AS_METHOD); Node* stub_code = m.HeapConstant(callable.code());
Node* call = m.CallNWithFrameState(descriptor, stub_code, args, state_node);
m.Return(call); m.Return(call);
Stream s = m.Build(kAllExceptNopInstructions); Stream s = m.Build(kAllExceptNopInstructions);
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment