Commit 4c79f55c authored by jarin's avatar jarin Committed by Commit bot

[turbofan] Handle cyclic dependencies in context typing.

BUG=chromium:451012
LOG=n
R=bmeurer@chromium.org

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

Cr-Commit-Position: refs/heads/master@{#26281}
parent 3937dd67
...@@ -316,14 +316,7 @@ class Typer::Visitor : public Reducer { ...@@ -316,14 +316,7 @@ class Typer::Visitor : public Reducer {
return BoundsOrNone(operand_node); return BoundsOrNone(operand_node);
} }
Bounds ContextOperand(Node* node) { Bounds WrapContextBoundsForInput(Node* node);
Bounds result = BoundsOrNone(NodeProperties::GetContextInput(node));
DCHECK(result.upper->Maybe(Type::Internal()));
// TODO(rossberg): More precisely, instead of the above assertion, we should
// back-propagate the constraint that it has to be a subtype of Internal.
return result;
}
Type* Weaken(Type* current_type, Type* previous_type); Type* Weaken(Type* current_type, Type* previous_type);
Zone* zone() { return typer_->zone(); } Zone* zone() { return typer_->zone(); }
...@@ -1387,40 +1380,45 @@ Bounds Typer::Visitor::TypeJSStoreContext(Node* node) { ...@@ -1387,40 +1380,45 @@ Bounds Typer::Visitor::TypeJSStoreContext(Node* node) {
} }
Bounds Typer::Visitor::WrapContextBoundsForInput(Node* node) {
Bounds outer = BoundsOrNone(NodeProperties::GetContextInput(node));
if (outer.upper->Is(Type::None())) {
return Bounds(Type::None());
} else {
DCHECK(outer.upper->Maybe(Type::Internal()));
return Bounds(Type::Context(outer.upper, zone()));
}
}
Bounds Typer::Visitor::TypeJSCreateFunctionContext(Node* node) { Bounds Typer::Visitor::TypeJSCreateFunctionContext(Node* node) {
Bounds outer = ContextOperand(node); return WrapContextBoundsForInput(node);
return Bounds(Type::Context(outer.upper, zone()));
} }
Bounds Typer::Visitor::TypeJSCreateCatchContext(Node* node) { Bounds Typer::Visitor::TypeJSCreateCatchContext(Node* node) {
Bounds outer = ContextOperand(node); return WrapContextBoundsForInput(node);
return Bounds(Type::Context(outer.upper, zone()));
} }
Bounds Typer::Visitor::TypeJSCreateWithContext(Node* node) { Bounds Typer::Visitor::TypeJSCreateWithContext(Node* node) {
Bounds outer = ContextOperand(node); return WrapContextBoundsForInput(node);
return Bounds(Type::Context(outer.upper, zone()));
} }
Bounds Typer::Visitor::TypeJSCreateBlockContext(Node* node) { Bounds Typer::Visitor::TypeJSCreateBlockContext(Node* node) {
Bounds outer = ContextOperand(node); return WrapContextBoundsForInput(node);
return Bounds(Type::Context(outer.upper, zone()));
} }
Bounds Typer::Visitor::TypeJSCreateModuleContext(Node* node) { Bounds Typer::Visitor::TypeJSCreateModuleContext(Node* node) {
// TODO(rossberg): this is probably incorrect // TODO(rossberg): this is probably incorrect
Bounds outer = ContextOperand(node); return WrapContextBoundsForInput(node);
return Bounds(Type::Context(outer.upper, zone()));
} }
Bounds Typer::Visitor::TypeJSCreateScriptContext(Node* node) { Bounds Typer::Visitor::TypeJSCreateScriptContext(Node* node) {
Bounds outer = ContextOperand(node); return WrapContextBoundsForInput(node);
return Bounds(Type::Context(outer.upper, zone()));
} }
......
// 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.
"use strict";
function f() {
for (let v; v; ) {
let x;
}
}
f();
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