Commit a6394f06 authored by Santiago Aboy Solanes's avatar Santiago Aboy Solanes Committed by Commit Bot

[compiler] SimplifiedLowering cleanups pt. 2/2

Clenaups:
 * Encapsulated same code in methods
 * Inlined trace prints
 * Don't set as queued, we are going to visit it anyway
 * Moved the phi check updwards

Bug: v8:10424
Change-Id: I82534399617d97d717c5c0dd1ca4bfef9df91e97
Reviewed-on: https://chromium-review.googlesource.com/c/v8/v8/+/2218037
Commit-Queue: Santiago Aboy Solanes <solanes@chromium.org>
Reviewed-by: 's avatarNico Hartmann <nicohartmann@chromium.org>
Cr-Commit-Position: refs/heads/master@{#68393}
parent c4c28952
...@@ -341,10 +341,6 @@ class RepresentationSelector { ...@@ -341,10 +341,6 @@ class RepresentationSelector {
bool UpdateFeedbackType(Node* node) { bool UpdateFeedbackType(Node* node) {
if (node->op()->ValueOutputCount() == 0) return false; if (node->op()->ValueOutputCount() == 0) return false;
NodeInfo* info = GetInfo(node);
Type type = info->feedback_type();
Type new_type = type;
// For any non-phi node just wait until we get all inputs typed. We only // For any non-phi node just wait until we get all inputs typed. We only
// allow untyped inputs for phi nodes because phis are the only places // allow untyped inputs for phi nodes because phis are the only places
// where cycles need to be broken. // where cycles need to be broken.
...@@ -356,6 +352,10 @@ class RepresentationSelector { ...@@ -356,6 +352,10 @@ class RepresentationSelector {
} }
} }
NodeInfo* info = GetInfo(node);
Type type = info->feedback_type();
Type new_type = NodeProperties::GetType(node);
// We preload these values here to avoid increasing the binary size too // We preload these values here to avoid increasing the binary size too
// much, which happens if we inline the calls into the macros below. // much, which happens if we inline the calls into the macros below.
Type input0_type; Type input0_type;
...@@ -566,6 +566,40 @@ class RepresentationSelector { ...@@ -566,6 +566,40 @@ class RepresentationSelector {
} }
} }
void PushNodeToRevisitIfVisited(Node* node) {
NodeInfo* info = GetInfo(node);
if (info->visited()) {
TRACE(" QUEUEING #%d: %s\n", node->id(), node->op()->mnemonic());
info->set_queued();
revisit_queue_.push(node);
}
}
// Tries to update the feedback type of the node, as well as setting its
// machine representation (in VisitNode). Returns true iff updating the
// feedback type is successful.
bool RetypeNode(Node* node) {
NodeInfo* info = GetInfo(node);
info->set_visited();
bool updated = UpdateFeedbackType(node);
TRACE(" visit #%d: %s\n", node->id(), node->op()->mnemonic());
VisitNode<RETYPE>(node, info->truncation(), nullptr);
TRACE(" ==> output %s\n", MachineReprToString(info->representation()));
return updated;
}
// Visits the node and marks it as visited. Inside of VisitNode, we might
// change the truncation of one of our inputs (see EnqueueInput<PROPAGATE> for
// this). If we change the truncation of an already visited node, we will add
// it to the revisit queue.
void PropagateTruncation(Node* node) {
NodeInfo* info = GetInfo(node);
info->set_visited();
TRACE(" visit #%d: %s (trunc: %s)\n", node->id(), node->op()->mnemonic(),
info->truncation().description());
VisitNode<PROPAGATE>(node, info->truncation(), nullptr);
}
// Backward propagation of truncations to a fixpoint. // Backward propagation of truncations to a fixpoint.
void RunPropagatePhase() { void RunPropagatePhase() {
TRACE("--{Propagate phase}--\n"); TRACE("--{Propagate phase}--\n");
...@@ -575,23 +609,12 @@ class RepresentationSelector { ...@@ -575,23 +609,12 @@ class RepresentationSelector {
// Process nodes in reverse post order, with End as the root. // Process nodes in reverse post order, with End as the root.
for (auto it = traversal_nodes_.crbegin(); it != traversal_nodes_.crend(); for (auto it = traversal_nodes_.crbegin(); it != traversal_nodes_.crend();
++it) { ++it) {
Node* node = *it; PropagateTruncation(*it);
NodeInfo* info = GetInfo(node);
info->set_visited();
TRACE(" visit #%d: %s (trunc: %s)\n", node->id(), node->op()->mnemonic(),
info->truncation().description());
VisitNode<PROPAGATE>(node, info->truncation(), nullptr);
// Revisit queue
while (!revisit_queue_.empty()) { while (!revisit_queue_.empty()) {
Node* revisit_node = revisit_queue_.front(); Node* node = revisit_queue_.front();
NodeInfo* revisit_info = GetInfo(revisit_node);
revisit_queue_.pop(); revisit_queue_.pop();
revisit_info->set_visited(); PropagateTruncation(node);
TRACE(" visit #%d: %s (trunc: %s)\n", revisit_node->id(),
revisit_node->op()->mnemonic(),
revisit_info->truncation().description());
VisitNode<PROPAGATE>(revisit_node, revisit_info->truncation(), nullptr);
} }
} }
} }
...@@ -605,52 +628,25 @@ class RepresentationSelector { ...@@ -605,52 +628,25 @@ class RepresentationSelector {
for (auto it = traversal_nodes_.cbegin(); it != traversal_nodes_.cend(); for (auto it = traversal_nodes_.cbegin(); it != traversal_nodes_.cend();
++it) { ++it) {
Node* node = *it; Node* node = *it;
NodeInfo* info = GetInfo(node); if (!RetypeNode(node)) continue;
info->set_visited();
bool updated = UpdateFeedbackType(node);
TRACE(" visit #%d: %s\n", node->id(), node->op()->mnemonic());
VisitNode<RETYPE>(node, info->truncation(), nullptr);
TRACE(" ==> output ");
PrintOutputInfo(info);
TRACE("\n");
if (updated) {
auto revisit_it = might_need_revisit_.find(node);
if (revisit_it == might_need_revisit_.end()) continue;
for (Node* const user : revisit_it->second) {
if (GetInfo(user)->visited()) {
TRACE(" QUEUEING #%d: %s\n", user->id(), user->op()->mnemonic());
GetInfo(user)->set_queued();
revisit_queue_.push(user);
}
}
// Process the revisit queue. auto revisit_it = might_need_revisit_.find(node);
while (!revisit_queue_.empty()) { if (revisit_it == might_need_revisit_.end()) continue;
Node* revisit_node = revisit_queue_.front();
revisit_queue_.pop(); for (Node* const user : revisit_it->second) {
NodeInfo* revisit_info = GetInfo(revisit_node); PushNodeToRevisitIfVisited(user);
revisit_info->set_visited(); }
bool updated = UpdateFeedbackType(revisit_node);
TRACE(" revisit #%d: %s\n", revisit_node->id(), // Process the revisit queue.
revisit_node->op()->mnemonic()); while (!revisit_queue_.empty()) {
VisitNode<RETYPE>(revisit_node, revisit_info->truncation(), nullptr); Node* revisit_node = revisit_queue_.front();
TRACE(" ==> output "); revisit_queue_.pop();
PrintOutputInfo(revisit_info); if (!RetypeNode(revisit_node)) continue;
TRACE("\n"); // Here we need to check all uses since we can't easily know which
if (updated) { // nodes will need to be revisited due to having an input which was
// Here we need to check all uses since we can't easily know which // a revisited node.
// nodes will need to be revisited due to having an input which was for (Node* const user : revisit_node->uses()) {
// a revisited node. PushNodeToRevisitIfVisited(user);
for (Node* const user : revisit_node->uses()) {
if (GetInfo(user)->visited()) {
TRACE(" QUEUEING #%d: %s\n", user->id(),
user->op()->mnemonic());
GetInfo(user)->set_queued();
revisit_queue_.push(user);
}
}
}
} }
} }
} }
...@@ -836,11 +832,10 @@ class RepresentationSelector { ...@@ -836,11 +832,10 @@ class RepresentationSelector {
// Output representation doesn't match usage. // Output representation doesn't match usage.
TRACE(" change: #%d:%s(@%d #%d:%s) ", node->id(), node->op()->mnemonic(), TRACE(" change: #%d:%s(@%d #%d:%s) ", node->id(), node->op()->mnemonic(),
index, input->id(), input->op()->mnemonic()); index, input->id(), input->op()->mnemonic());
TRACE(" from "); TRACE("from %s to %s:%s\n",
PrintOutputInfo(input_info); MachineReprToString(input_info->representation()),
TRACE(" to "); MachineReprToString(use.representation()),
PrintUseInfo(use); use.truncation().description());
TRACE("\n");
if (input_type.IsInvalid()) { if (input_type.IsInvalid()) {
input_type = TypeOf(input); input_type = TypeOf(input);
} }
...@@ -3799,25 +3794,6 @@ class RepresentationSelector { ...@@ -3799,25 +3794,6 @@ class RepresentationSelector {
node->NullAllInputs(); // The {node} is now dead. node->NullAllInputs(); // The {node} is now dead.
} }
void PrintOutputInfo(NodeInfo* info) {
if (FLAG_trace_representation) {
StdoutStream{} << info->representation();
}
}
void PrintTruncation(Truncation truncation) {
if (FLAG_trace_representation) {
StdoutStream{} << truncation.description() << std::endl;
}
}
void PrintUseInfo(UseInfo info) {
if (FLAG_trace_representation) {
StdoutStream{} << info.representation() << ":"
<< info.truncation().description();
}
}
private: private:
JSGraph* jsgraph_; JSGraph* jsgraph_;
Zone* zone_; // Temporary zone. Zone* zone_; // Temporary zone.
...@@ -3872,26 +3848,21 @@ void RepresentationSelector::EnqueueInput<PROPAGATE>(Node* use_node, int index, ...@@ -3872,26 +3848,21 @@ void RepresentationSelector::EnqueueInput<PROPAGATE>(Node* use_node, int index,
use_info); use_info);
#endif // DEBUG #endif // DEBUG
if (info->unvisited()) { if (info->unvisited()) {
// First visit of this node.
info->set_queued();
TRACE(" initial #%i: ", node->id());
info->AddUse(use_info); info->AddUse(use_info);
PrintTruncation(info->truncation()); TRACE(" initial #%i: %s\n", node->id(), info->truncation().description());
return; return;
} }
TRACE(" queue #%i?: ", node->id()); TRACE(" queue #%i?: %s\n", node->id(), info->truncation().description());
PrintTruncation(info->truncation());
if (info->AddUse(use_info)) { if (info->AddUse(use_info)) {
// New usage information for the node is available. // New usage information for the node is available.
if (!info->queued()) { if (!info->queued()) {
DCHECK(info->visited()); DCHECK(info->visited());
revisit_queue_.push(node); revisit_queue_.push(node);
info->set_queued(); info->set_queued();
TRACE(" added: "); TRACE(" added: %s\n", info->truncation().description());
} else { } else {
TRACE(" inqueue: "); TRACE(" inqueue: %s\n", info->truncation().description());
} }
PrintTruncation(info->truncation());
} }
} }
......
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