| Index: src/compiler/ast-graph-builder.h
|
| diff --git a/src/compiler/ast-graph-builder.h b/src/compiler/ast-graph-builder.h
|
| index c9ed8d648eb0c09db1514b34f5a8345b53094112..861bd5baa36e8320be889c47e1135e32c6b9f23e 100644
|
| --- a/src/compiler/ast-graph-builder.h
|
| +++ b/src/compiler/ast-graph-builder.h
|
| @@ -171,18 +171,8 @@ class AstGraphBuilder : public StructuredGraphBuilder, public AstVisitor {
|
| // Dispatched from VisitForInStatement.
|
| void VisitForInAssignment(Expression* expr, Node* value);
|
|
|
| - // Flag that describes how to combine the current environment with
|
| - // the output of a node to obtain a framestate for lazy bailout.
|
| - enum OutputFrameStateCombine {
|
| - PUSH_OUTPUT, // Push the output on the expression stack.
|
| - IGNORE_OUTPUT // Use the frame state as-is.
|
| - };
|
| -
|
| - // Builds deoptimization for a given node.
|
| - void PrepareFrameState(Node* node, BailoutId ast_id,
|
| - OutputFrameStateCombine combine = IGNORE_OUTPUT);
|
| -
|
| - OutputFrameStateCombine StateCombineFromAstContext();
|
| + void BuildLazyBailout(Node* node, BailoutId ast_id);
|
| + void BuildLazyBailoutWithPushedNode(Node* node, BailoutId ast_id);
|
|
|
| DEFINE_AST_VISITOR_SUBCLASS_MEMBERS();
|
| DISALLOW_COPY_AND_ASSIGN(AstGraphBuilder);
|
| @@ -292,15 +282,10 @@ class AstGraphBuilder::AstContext BASE_EMBEDDED {
|
| bool IsValue() const { return kind_ == Expression::kValue; }
|
| bool IsTest() const { return kind_ == Expression::kTest; }
|
|
|
| - // Determines how to combine the frame state with the value
|
| - // that is about to be plugged into this AstContext.
|
| - AstGraphBuilder::OutputFrameStateCombine GetStateCombine() {
|
| - return IsEffect() ? IGNORE_OUTPUT : PUSH_OUTPUT;
|
| - }
|
| -
|
| // Plug a node into this expression context. Call this function in tail
|
| // position in the Visit functions for expressions.
|
| virtual void ProduceValue(Node* value) = 0;
|
| + virtual void ProduceValueWithLazyBailout(Node* value) = 0;
|
|
|
| // Unplugs a node from this expression context. Call this to retrieve the
|
| // result of another Visit function that already plugged the context.
|
| @@ -310,7 +295,8 @@ class AstGraphBuilder::AstContext BASE_EMBEDDED {
|
| void ReplaceValue() { ProduceValue(ConsumeValue()); }
|
|
|
| protected:
|
| - AstContext(AstGraphBuilder* owner, Expression::Context kind);
|
| + AstContext(AstGraphBuilder* owner, Expression::Context kind,
|
| + BailoutId bailout_id);
|
| virtual ~AstContext();
|
|
|
| AstGraphBuilder* owner() const { return owner_; }
|
| @@ -322,6 +308,8 @@ class AstGraphBuilder::AstContext BASE_EMBEDDED {
|
| int original_height_;
|
| #endif
|
|
|
| + BailoutId bailout_id_;
|
| +
|
| private:
|
| Expression::Context kind_;
|
| AstGraphBuilder* owner_;
|
| @@ -332,10 +320,11 @@ class AstGraphBuilder::AstContext BASE_EMBEDDED {
|
| // Context to evaluate expression for its side effects only.
|
| class AstGraphBuilder::AstEffectContext V8_FINAL : public AstContext {
|
| public:
|
| - explicit AstEffectContext(AstGraphBuilder* owner)
|
| - : AstContext(owner, Expression::kEffect) {}
|
| + explicit AstEffectContext(AstGraphBuilder* owner, BailoutId bailout_id)
|
| + : AstContext(owner, Expression::kEffect, bailout_id) {}
|
| virtual ~AstEffectContext();
|
| virtual void ProduceValue(Node* value) V8_OVERRIDE;
|
| + virtual void ProduceValueWithLazyBailout(Node* value) V8_OVERRIDE;
|
| virtual Node* ConsumeValue() V8_OVERRIDE;
|
| };
|
|
|
| @@ -343,10 +332,11 @@ class AstGraphBuilder::AstEffectContext V8_FINAL : public AstContext {
|
| // Context to evaluate expression for its value (and side effects).
|
| class AstGraphBuilder::AstValueContext V8_FINAL : public AstContext {
|
| public:
|
| - explicit AstValueContext(AstGraphBuilder* owner)
|
| - : AstContext(owner, Expression::kValue) {}
|
| + explicit AstValueContext(AstGraphBuilder* owner, BailoutId bailout_id)
|
| + : AstContext(owner, Expression::kValue, bailout_id) {}
|
| virtual ~AstValueContext();
|
| virtual void ProduceValue(Node* value) V8_OVERRIDE;
|
| + virtual void ProduceValueWithLazyBailout(Node* value) V8_OVERRIDE;
|
| virtual Node* ConsumeValue() V8_OVERRIDE;
|
| };
|
|
|
| @@ -354,10 +344,11 @@ class AstGraphBuilder::AstValueContext V8_FINAL : public AstContext {
|
| // Context to evaluate expression for a condition value (and side effects).
|
| class AstGraphBuilder::AstTestContext V8_FINAL : public AstContext {
|
| public:
|
| - explicit AstTestContext(AstGraphBuilder* owner)
|
| - : AstContext(owner, Expression::kTest) {}
|
| + explicit AstTestContext(AstGraphBuilder* owner, BailoutId bailout_id)
|
| + : AstContext(owner, Expression::kTest, bailout_id) {}
|
| virtual ~AstTestContext();
|
| virtual void ProduceValue(Node* value) V8_OVERRIDE;
|
| + virtual void ProduceValueWithLazyBailout(Node* value) V8_OVERRIDE;
|
| virtual Node* ConsumeValue() V8_OVERRIDE;
|
| };
|
|
|
|
|