[wasm] Int64Lowering: changing to DFS.

R=titzer@chromium.org

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

Cr-Commit-Position: refs/heads/master@{#34767}
This commit is contained in:
ahaas 2016-03-14 23:26:23 -07:00 committed by Commit bot
parent 8d7399f9f8
commit c4c34eba30
4 changed files with 38 additions and 17 deletions

View File

@ -24,7 +24,7 @@ Int64Lowering::Int64Lowering(Graph* graph, MachineOperatorBuilder* machine,
graph_(graph),
machine_(machine),
common_(common),
state_(graph, 4),
state_(graph, 3),
stack_(zone),
replacements_(zone->NewArray<Replacement>(graph->NodeCount())),
signature_(signature) {
@ -35,25 +35,23 @@ void Int64Lowering::LowerGraph() {
if (!machine()->Is32()) {
return;
}
stack_.push(graph()->end());
stack_.push({graph()->end(), 0});
state_.Set(graph()->end(), State::kOnStack);
while (!stack_.empty()) {
Node* top = stack_.top();
if (state_.Get(top) == State::kInputsPushed) {
NodeState& top = stack_.top();
if (top.input_index == top.node->InputCount()) {
// All inputs of top have already been lowered, now lower top.
stack_.pop();
state_.Set(top, State::kVisited);
// All inputs of top have already been reduced, now reduce top.
LowerNode(top);
state_.Set(top.node, State::kVisited);
LowerNode(top.node);
} else {
// Push all children onto the stack.
for (Node* input : top->inputs()) {
if (state_.Get(input) == State::kUnvisited) {
stack_.push(input);
state_.Set(input, State::kOnStack);
}
// Push the next input onto the stack.
Node* input = top.node->InputAt(top.input_index++);
if (state_.Get(input) == State::kUnvisited) {
stack_.push({input, 0});
state_.Set(input, State::kOnStack);
}
state_.Set(top, State::kInputsPushed);
}
}
}

View File

@ -24,7 +24,7 @@ class Int64Lowering {
void LowerGraph();
private:
enum class State : uint8_t { kUnvisited, kOnStack, kInputsPushed, kVisited };
enum class State : uint8_t { kUnvisited, kOnStack, kVisited };
struct Replacement {
Node* low;
@ -48,12 +48,17 @@ class Int64Lowering {
bool HasReplacementHigh(Node* node);
Node* GetReplacementHigh(Node* node);
struct NodeState {
Node* node;
int input_index;
};
Zone* zone_;
Graph* const graph_;
MachineOperatorBuilder* machine_;
CommonOperatorBuilder* common_;
NodeMarker<State> state_;
ZoneStack<Node*> stack_;
ZoneStack<NodeState> stack_;
Replacement* replacements_;
Signature<MachineRepresentation>* signature_;
};

View File

@ -30,7 +30,7 @@
#endif
#define FOREACH_I64_OPERATOR(V) \
V(DepthFirst, false) \
V(DepthFirst, true) \
V(I64Const, true) \
V(I64Return, true) \
V(I64Param, true) \

View File

@ -494,6 +494,24 @@ TEST_F(Int64LoweringTest, I64UConvertI32_2) {
// kExprI64Clz:
// kExprI64Ctz:
// kExprI64Popcnt:
TEST_F(Int64LoweringTest, Dfs) {
Node* common = Int64Constant(value(0));
LowerGraph(graph()->NewNode(machine()->Word64And(), common,
graph()->NewNode(machine()->Word64And(), common,
Int64Constant(value(1)))),
MachineRepresentation::kWord64);
EXPECT_THAT(
graph()->end()->InputAt(1),
IsReturn2(IsWord32And(IsInt32Constant(low_word_value(0)),
IsWord32And(IsInt32Constant(low_word_value(0)),
IsInt32Constant(low_word_value(1)))),
IsWord32And(IsInt32Constant(high_word_value(0)),
IsWord32And(IsInt32Constant(high_word_value(0)),
IsInt32Constant(high_word_value(1)))),
start(), start()));
}
} // namespace compiler
} // namespace internal
} // namespace v8