From d92b3434a0eae214ecd06c66cab56b4da9522666 Mon Sep 17 00:00:00 2001 From: whitequark Date: Mon, 23 Nov 2015 21:44:38 +0800 Subject: [PATCH] compiler.ir: print basic blocks in reverse postorder for readability. --- artiq/compiler/ir.py | 13 ++++++++++++- 1 file changed, 12 insertions(+), 1 deletion(-) diff --git a/artiq/compiler/ir.py b/artiq/compiler/ir.py index 1c41ca5c1..055d0f2ed 100644 --- a/artiq/compiler/ir.py +++ b/artiq/compiler/ir.py @@ -463,12 +463,23 @@ class Function: yield from iter(basic_block.instructions) def as_entity(self, type_printer): + postorder = [] + visited = set() + def visit(block): + visited.add(block) + for next_block in block.successors(): + if next_block not in visited: + visit(next_block) + postorder.append(block) + + visit(self.entry()) + lines = [] lines.append("{} {}({}) {{ ; type: {}".format( type_printer.name(self.type.ret), self.name, ", ".join([arg.as_operand(type_printer) for arg in self.arguments]), type_printer.name(self.type))) - for block in self.basic_blocks: + for block in reversed(postorder): lines.append(block.as_entity(type_printer)) lines.append("}") return "\n".join(lines)