Commit 75198b9a authored by Josh Bleecher Snyder's avatar Josh Bleecher Snyder

cmd/compile: simplify postorder

Use a bool instead of markKind;
it doesn't save space, but the semantics are more obvious.
Move type markKind closer to its only remaining use.

Change-Id: I9945a7baaeb764295a2709f83120ce3a82fa3beb
Reviewed-on: https://go-review.googlesource.com/c/go/+/177880
Run-TryBot: Josh Bleecher Snyder <josharian@gmail.com>
TryBot-Result: Gobot Gobot <gobot@golang.org>
Reviewed-by: default avatarDavid Chase <drchase@google.com>
parent b8cbcaca
...@@ -4,16 +4,6 @@ ...@@ -4,16 +4,6 @@
package ssa package ssa
// mark values
type markKind uint8
const (
notFound markKind = 0 // block has not been discovered yet
notExplored markKind = 1 // discovered and in queue, outedges not processed yet
explored markKind = 2 // discovered and in queue, outedges processed
done markKind = 3 // all done, in output ordering
)
// This file contains code to compute the dominator tree // This file contains code to compute the dominator tree
// of a control-flow graph. // of a control-flow graph.
...@@ -31,7 +21,7 @@ type blockAndIndex struct { ...@@ -31,7 +21,7 @@ type blockAndIndex struct {
// postorderWithNumbering provides a DFS postordering. // postorderWithNumbering provides a DFS postordering.
// This seems to make loop-finding more robust. // This seems to make loop-finding more robust.
func postorderWithNumbering(f *Func, ponums []int32) []*Block { func postorderWithNumbering(f *Func, ponums []int32) []*Block {
mark := make([]markKind, f.NumBlocks()) seen := make([]bool, f.NumBlocks())
// result ordering // result ordering
order := make([]*Block, 0, len(f.Blocks)) order := make([]*Block, 0, len(f.Blocks))
...@@ -41,26 +31,25 @@ func postorderWithNumbering(f *Func, ponums []int32) []*Block { ...@@ -41,26 +31,25 @@ func postorderWithNumbering(f *Func, ponums []int32) []*Block {
// enough to cover almost every postorderWithNumbering call. // enough to cover almost every postorderWithNumbering call.
s := make([]blockAndIndex, 0, 32) s := make([]blockAndIndex, 0, 32)
s = append(s, blockAndIndex{b: f.Entry}) s = append(s, blockAndIndex{b: f.Entry})
mark[f.Entry.ID] = explored seen[f.Entry.ID] = true
for len(s) > 0 { for len(s) > 0 {
tos := len(s) - 1 tos := len(s) - 1
x := s[tos] x := s[tos]
b := x.b b := x.b
i := x.index if i := x.index; i < len(b.Succs) {
if i < len(b.Succs) {
s[tos].index++ s[tos].index++
bb := b.Succs[i].Block() bb := b.Succs[i].Block()
if mark[bb.ID] == notFound { if !seen[bb.ID] {
mark[bb.ID] = explored seen[bb.ID] = true
s = append(s, blockAndIndex{b: bb}) s = append(s, blockAndIndex{b: bb})
} }
} else { continue
s = s[:tos] }
if len(ponums) > 0 { s = s[:tos]
ponums[b.ID] = int32(len(order)) if ponums != nil {
} ponums[b.ID] = int32(len(order))
order = append(order, b)
} }
order = append(order, b)
} }
return order return order
} }
......
...@@ -452,6 +452,16 @@ func findLastMems(f *Func) []*Value { ...@@ -452,6 +452,16 @@ func findLastMems(f *Func) []*Value {
return lastMems return lastMems
} }
// mark values
type markKind uint8
const (
notFound markKind = iota // block has not been discovered yet
notExplored // discovered and in queue, outedges not processed yet
explored // discovered and in queue, outedges processed
done // all done, in output ordering
)
type backedgesState struct { type backedgesState struct {
b *Block b *Block
i int i int
......
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