From 247bdbde16c9024f5e591571063fe252b09b19b4 Mon Sep 17 00:00:00 2001 From: Owen Anderson Date: Fri, 12 Jun 2009 21:50:22 +0000 Subject: [PATCH] This is supposed to be a preorder numbering of the dominator tree, not the CFG. llvm-svn: 73257 --- lib/CodeGen/LazyLiveness.cpp | 9 +++++---- 1 file changed, 5 insertions(+), 4 deletions(-) diff --git a/lib/CodeGen/LazyLiveness.cpp b/lib/CodeGen/LazyLiveness.cpp index 85817da2e4f..4b2d737e6d3 100644 --- a/lib/CodeGen/LazyLiveness.cpp +++ b/lib/CodeGen/LazyLiveness.cpp @@ -62,13 +62,14 @@ bool LazyLiveness::runOnMachineFunction(MachineFunction &mf) { preorder.clear(); MRI = &mf.getRegInfo(); + MachineDominatorTree& MDT = getAnalysis(); // Step 0: Compute preorder numbering for all MBBs. unsigned num = 0; - for (df_iterator DI = df_begin(&*mf.begin()); - DI != df_end(&*mf.begin()); ++DI) { - preorder[*DI] = num++; - rev_preorder.push_back(*DI); + for (df_iterator DI = df_begin(MDT.getRootNode()); + DI != df_end(MDT.getRootNode()); ++DI) { + preorder[(*DI)->getBlock()] = num++; + rev_preorder.push_back((*DI)->getBlock()); } // Step 1: Compute the transitive closure of the CFG, ignoring backedges.