Commit a601eccb authored by bmeurer's avatar bmeurer Committed by Commit bot

Revert of [turbofan] Enable super constructor inlining. (patchset #1 id:1 of...

Revert of [turbofan] Enable super constructor inlining. (patchset #1 id:1 of https://codereview.chromium.org/2409423006/ )

Reason for revert:
As adamk@ pointed out, this is not correct. Some more changes required instead

Original issue's description:
> [turbofan] Enable super constructor inlining.
>
> When we inlined a [[Construct]] call to a subclass constructor, we can
> also inline the super constructor call (either explicit or implicit),
> since we have a concrete JSFunction constant for the subclass and we
> can thus constant-fold the %_GetSuperConstructor intrinsic. We don't
> need any guards here since the prototype of subclass constructors is
> non-writable, non-configurable in ES6.
>
> BUG=v8:5517
> R=jarin@chromium.org
>
> Committed: https://crrev.com/74158b00b3f6a1fc8676dd1f7af4d96131eb5ebe
> Cr-Commit-Position: refs/heads/master@{#40261}

TBR=jarin@chromium.org,adamk@chromium.org
# Skipping CQ checks because original CL landed less than 1 days ago.
NOPRESUBMIT=true
NOTREECHECKS=true
NOTRY=true
BUG=v8:5517

Review-Url: https://codereview.chromium.org/2413883003
Cr-Commit-Position: refs/heads/master@{#40285}
parent 0ee8eea2
...@@ -314,27 +314,14 @@ Reduction JSIntrinsicLowering::ReduceNewObject(Node* node) { ...@@ -314,27 +314,14 @@ Reduction JSIntrinsicLowering::ReduceNewObject(Node* node) {
} }
Reduction JSIntrinsicLowering::ReduceGetSuperConstructor(Node* node) { Reduction JSIntrinsicLowering::ReduceGetSuperConstructor(Node* node) {
Node* target = NodeProperties::GetValueInput(node, 0); Node* active_function = NodeProperties::GetValueInput(node, 0);
// The prototype of subclass constructors is non-writable, non-configurable Node* effect = NodeProperties::GetEffectInput(node);
// in ES6, so we don't need to do any checking, but we can just load (or even Node* control = NodeProperties::GetControlInput(node);
// constant-fold) the prototype from the {target}. Node* active_function_map = effect =
HeapObjectMatcher m(target); graph()->NewNode(simplified()->LoadField(AccessBuilder::ForMap()),
if (m.HasValue()) { active_function, effect, control);
Handle<JSFunction> target_function = Handle<JSFunction>::cast(m.Value()); return Change(node, simplified()->LoadField(AccessBuilder::ForMapPrototype()),
Node* value = jsgraph()->HeapConstant(handle( active_function_map, effect, control);
JSFunction::cast(target_function->map()->prototype()), isolate()));
ReplaceWithValue(node, value);
return Replace(value);
} else {
Node* effect = NodeProperties::GetEffectInput(node);
Node* control = NodeProperties::GetControlInput(node);
Node* target_map = effect =
graph()->NewNode(simplified()->LoadField(AccessBuilder::ForMap()),
target, effect, control);
return Change(node,
simplified()->LoadField(AccessBuilder::ForMapPrototype()),
target_map, effect, control);
}
} }
Reduction JSIntrinsicLowering::Change(Node* node, const Operator* op, Node* a, Reduction JSIntrinsicLowering::Change(Node* node, const Operator* op, Node* a,
......
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