Index: src/compiler/escape-analysis-reducer.cc |
diff --git a/src/compiler/escape-analysis-reducer.cc b/src/compiler/escape-analysis-reducer.cc |
index 2e2f6781ebfe3f8b8e6f7ea17c273779cd83e4aa..6d0b602fa386ea4880e644bfbff7feac8e1d53ff 100644 |
--- a/src/compiler/escape-analysis-reducer.cc |
+++ b/src/compiler/escape-analysis-reducer.cc |
@@ -34,7 +34,7 @@ Reduction EscapeAnalysisReducer::Reduce(Node* node) { |
return ReduceReferenceEqual(node); |
case IrOpcode::kStateValues: |
case IrOpcode::kFrameState: |
- return ReplaceWithDeoptDummy(node); |
+ return ReduceStateValueInputs(node); |
default: |
break; |
} |
@@ -140,31 +140,32 @@ Reduction EscapeAnalysisReducer::ReduceReferenceEqual(Node* node) { |
} |
-// TODO(sigurds): This is a temporary solution until escape analysis |
-// supports deoptimization. |
-Reduction EscapeAnalysisReducer::ReplaceWithDeoptDummy(Node* node) { |
+Reduction EscapeAnalysisReducer::ReduceStateValueInputs(Node* node) { |
DCHECK(node->opcode() == IrOpcode::kStateValues || |
node->opcode() == IrOpcode::kFrameState); |
+ Node* effect = escape_analysis()->GetEffect(node); |
+ DCHECK_NOT_NULL(effect); |
Reduction r = NoChange(); |
for (int i = 0; i < node->op()->ValueInputCount(); ++i) { |
Node* input = NodeProperties::GetValueInput(node, i); |
if (input->opcode() == IrOpcode::kFinishRegion || |
- input->opcode() == IrOpcode::kAllocate || |
- input->opcode() == IrOpcode::kPhi) { |
+ input->opcode() == IrOpcode::kAllocate) { |
if (escape_analysis()->IsVirtual(input)) { |
- NodeProperties::ReplaceValueInput(node, jsgraph()->UndefinedConstant(), |
- i); |
- if (FLAG_trace_turbo_escape) { |
- PrintF("Replaced state value (#%d) input with dummy\n", node->id()); |
+ if (Node* object_state = |
+ escape_analysis()->GetOrCreateObjectState(effect, input)) { |
+ NodeProperties::ReplaceValueInput(node, object_state, i); |
+ if (FLAG_trace_turbo_escape) { |
+ PrintF("Replaced state value (#%d) input with object state #%d\n", |
+ node->id(), object_state->id()); |
+ } |
+ r = Changed(node); |
} |
- r = Changed(node); |
} |
} |
} |
return r; |
} |
- |
} // namespace compiler |
} // namespace internal |
} // namespace v8 |