summary refs log tree commit diff
diff options
context:
space:
mode:
authorQuentin Carbonneaux <quentin.carbonneaux@yale.edu>2015-08-20 13:49:49 -0400
committerQuentin Carbonneaux <quentin.carbonneaux@yale.edu>2015-09-15 23:01:32 -0400
commit3b708f506f5b5b45b5cc22493595a31e7183b620 (patch)
tree2610d4a59826bec2b62b088e0e7c5796c6090e53
parent7d36a71a2287e28312403ab12a6ca5b49c7a73b0 (diff)
downloadroux-3b708f506f5b5b45b5cc22493595a31e7183b620.tar.gz
use loop frequency in ties of rpo
-rw-r--r--lisc/ssa.c16
1 files changed, 11 insertions, 5 deletions
diff --git a/lisc/ssa.c b/lisc/ssa.c
index 4bf6c46..cd9e1a7 100644
--- a/lisc/ssa.c
+++ b/lisc/ssa.c
@@ -44,13 +44,19 @@ fillpreds(Fn *f)
 static int
 rporec(Blk *b, int x)
 {
-	if (b->id >= 0)
+	Blk *s1, *s2;
+
+	if (!b || b->id >= 0)
 		return x;
 	b->id = 1;
-	if (b->s2)
-		x = rporec(b->s2, x);
-	if (b->s1)
-		x = rporec(b->s1, x);
+	s1 = b->s1;
+	s2 = b->s2;
+	if (s1 && s2 && s1->loop > s2->loop) {
+		s1 = b->s2;
+		s2 = b->s1;
+	}
+	x = rporec(s1, x);
+	x = rporec(s2, x);
 	b->id = x;
 	assert(x >= 0);
 	return x - 1;