Commit aea68b5a authored by bmeurer's avatar bmeurer Committed by Commit Bot

[turbofan] Inline ReturnReceiver builtin into TurboFan.

Builtins::kReturnReceiver is used for the Symbol.iterator function on
iterators, and just returns the iterator itself. For example, for-of
or yield* with a generator will first call generator[Symbol.iterator](),
which simply returns the generator itself. Inlining this particular
builtin into TurboFan is trivial and avoids that call completely,
enabling more possibilities for LoadElimination and EscapeAnalysis
to get rid of even more checks in common generator code.

BUG=v8:6344,v8:6351,v8:6354
R=jgruber@chromium.org

Review-Url: https://codereview.chromium.org/2938683002
Cr-Commit-Position: refs/heads/master@{#45927}
parent 223a6f63
...@@ -779,6 +779,8 @@ Reduction JSCallReducer::ReduceJSCall(Node* node) { ...@@ -779,6 +779,8 @@ Reduction JSCallReducer::ReduceJSCall(Node* node) {
return ReduceReflectGetPrototypeOf(node); return ReduceReflectGetPrototypeOf(node);
case Builtins::kArrayForEach: case Builtins::kArrayForEach:
return ReduceArrayForEach(function, node); return ReduceArrayForEach(function, node);
case Builtins::kReturnReceiver:
return ReduceReturnReceiver(node);
default: default:
break; break;
} }
...@@ -1036,6 +1038,13 @@ Reduction JSCallReducer::ReduceJSConstructWithSpread(Node* node) { ...@@ -1036,6 +1038,13 @@ Reduction JSCallReducer::ReduceJSConstructWithSpread(Node* node) {
return ReduceSpreadCall(node, arity); return ReduceSpreadCall(node, arity);
} }
Reduction JSCallReducer::ReduceReturnReceiver(Node* node) {
DCHECK_EQ(IrOpcode::kJSCall, node->opcode());
Node* receiver = NodeProperties::GetValueInput(node, 1);
ReplaceWithValue(node, receiver);
return Replace(receiver);
}
Graph* JSCallReducer::graph() const { return jsgraph()->graph(); } Graph* JSCallReducer::graph() const { return jsgraph()->graph(); }
Isolate* JSCallReducer::isolate() const { return jsgraph()->isolate(); } Isolate* JSCallReducer::isolate() const { return jsgraph()->isolate(); }
......
...@@ -57,6 +57,7 @@ class JSCallReducer final : public AdvancedReducer { ...@@ -57,6 +57,7 @@ class JSCallReducer final : public AdvancedReducer {
Reduction ReduceJSConstructWithSpread(Node* node); Reduction ReduceJSConstructWithSpread(Node* node);
Reduction ReduceJSCall(Node* node); Reduction ReduceJSCall(Node* node);
Reduction ReduceJSCallWithSpread(Node* node); Reduction ReduceJSCallWithSpread(Node* node);
Reduction ReduceReturnReceiver(Node* node);
Graph* graph() const; Graph* graph() const;
JSGraph* jsgraph() const { return jsgraph_; } JSGraph* jsgraph() const { return jsgraph_; }
......
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