Commit 8de41133 authored by Michael Starzinger's avatar Michael Starzinger Committed by Commit Bot

[turbofan] Avoid costly predicate during graph building.

This avoids usage of the costly {NodeProperties::IsExceptionalCall}
predicate during graph building. The result of this predicate is no
longer needed.

R=leszeks@chromium.org

Change-Id: Ief0c37b598ca51ea5d604f47d964bcbfb89a5206
Reviewed-on: https://chromium-review.googlesource.com/555517Reviewed-by: 's avatarLeszek Swirski <leszeks@chromium.org>
Commit-Queue: Michael Starzinger <mstarzinger@chromium.org>
Cr-Commit-Position: refs/heads/master@{#46327}
parent 26186702
...@@ -57,7 +57,6 @@ class BytecodeGraphBuilder::Environment : public ZoneObject { ...@@ -57,7 +57,6 @@ class BytecodeGraphBuilder::Environment : public ZoneObject {
// Preserve a checkpoint of the environment for the IR graph. Any // Preserve a checkpoint of the environment for the IR graph. Any
// further mutation of the environment will not affect checkpoints. // further mutation of the environment will not affect checkpoints.
Node* Checkpoint(BailoutId bytecode_offset, OutputFrameStateCombine combine, Node* Checkpoint(BailoutId bytecode_offset, OutputFrameStateCombine combine,
bool owner_has_exception,
const BytecodeLivenessState* liveness); const BytecodeLivenessState* liveness);
// Control dependency tracked by this environment. // Control dependency tracked by this environment.
...@@ -406,7 +405,7 @@ Node* BytecodeGraphBuilder::Environment::GetStateValuesFromCache( ...@@ -406,7 +405,7 @@ Node* BytecodeGraphBuilder::Environment::GetStateValuesFromCache(
Node* BytecodeGraphBuilder::Environment::Checkpoint( Node* BytecodeGraphBuilder::Environment::Checkpoint(
BailoutId bailout_id, OutputFrameStateCombine combine, BailoutId bailout_id, OutputFrameStateCombine combine,
bool owner_has_exception, const BytecodeLivenessState* liveness) { const BytecodeLivenessState* liveness) {
if (parameter_count() == register_count()) { if (parameter_count() == register_count()) {
// Re-use the state-value cache if the number of local registers happens // Re-use the state-value cache if the number of local registers happens
// to match the parameter count. // to match the parameter count.
...@@ -562,7 +561,7 @@ void BytecodeGraphBuilder::PrepareEagerCheckpoint() { ...@@ -562,7 +561,7 @@ void BytecodeGraphBuilder::PrepareEagerCheckpoint() {
bytecode_iterator().current_offset()); bytecode_iterator().current_offset());
Node* frame_state_before = environment()->Checkpoint( Node* frame_state_before = environment()->Checkpoint(
bailout_id, OutputFrameStateCombine::Ignore(), false, liveness_before); bailout_id, OutputFrameStateCombine::Ignore(), liveness_before);
NodeProperties::ReplaceFrameStateInput(node, frame_state_before); NodeProperties::ReplaceFrameStateInput(node, frame_state_before);
#ifdef DEBUG #ifdef DEBUG
} else { } else {
...@@ -590,14 +589,13 @@ void BytecodeGraphBuilder::PrepareFrameState(Node* node, ...@@ -590,14 +589,13 @@ void BytecodeGraphBuilder::PrepareFrameState(Node* node,
DCHECK_EQ(IrOpcode::kDead, DCHECK_EQ(IrOpcode::kDead,
NodeProperties::GetFrameStateInput(node)->opcode()); NodeProperties::GetFrameStateInput(node)->opcode());
BailoutId bailout_id(bytecode_iterator().current_offset()); BailoutId bailout_id(bytecode_iterator().current_offset());
bool has_exception = NodeProperties::IsExceptionalCall(node);
const BytecodeLivenessState* liveness_after = const BytecodeLivenessState* liveness_after =
bytecode_analysis()->GetOutLivenessFor( bytecode_analysis()->GetOutLivenessFor(
bytecode_iterator().current_offset()); bytecode_iterator().current_offset());
Node* frame_state_after = environment()->Checkpoint( Node* frame_state_after =
bailout_id, combine, has_exception, liveness_after); environment()->Checkpoint(bailout_id, combine, liveness_after);
NodeProperties::ReplaceFrameStateInput(node, frame_state_after); NodeProperties::ReplaceFrameStateInput(node, frame_state_after);
} }
} }
......
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