Commit 904c3a1f authored by Tobias Tebbi's avatar Tobias Tebbi Committed by Commit Bot

[turbofan] fix dead code elimination: propagate DeadValue along FrameState inputs

Bug: chromium:788539
Change-Id: I75b6ef7e486b578f123747d79f52c9eb45a0370e
Reviewed-on: https://chromium-review.googlesource.com/792050Reviewed-by: 's avatarJaroslav Sevcik <jarin@chromium.org>
Commit-Queue: Tobias Tebbi <tebbi@chromium.org>
Cr-Commit-Position: refs/heads/master@{#49654}
parent aa7d1438
...@@ -218,12 +218,8 @@ Reduction DeadCodeElimination::ReducePhi(Node* node) { ...@@ -218,12 +218,8 @@ Reduction DeadCodeElimination::ReducePhi(Node* node) {
Reduction DeadCodeElimination::ReducePureNode(Node* node) { Reduction DeadCodeElimination::ReducePureNode(Node* node) {
DCHECK_EQ(0, node->op()->EffectInputCount()); DCHECK_EQ(0, node->op()->EffectInputCount());
int input_count = node->op()->ValueInputCount(); if (HasDeadInput(node)) {
for (int i = 0; i < input_count; ++i) { return Replace(dead_value());
Node* input = NodeProperties::GetValueInput(node, i);
if (NoReturn(input)) {
return Replace(dead_value());
}
} }
return NoChange(); return NoChange();
} }
......
// Copyright 2017 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.
// Flags: --allow-natives-syntax --turbo-verify
// This test creates a FrameState node with a DeadValue parent framestate.
// Ensure that deadness is propagated along FrameState edges.
function f1() {
return this;
}
function f2(x, value, type) {
x instanceof type
}
function f3(a) {
a.x = 0;
if (a.x === 0) {
a[1] = 0.1;
}
class B {
}
class C extends B {
bar() {
return super.foo()
}
}
B.prototype.foo = f1;
f2(new C().bar.call(), Object(), String);
}
f3(new Array(1));
f3(new Array(1));
%OptimizeFunctionOnNextCall(f3);
f3(new Array(1));
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