diff options
author | Chris Lattner <sabre@nondot.org> | 2010-08-29 17:21:35 +0000 |
---|---|---|
committer | Chris Lattner <sabre@nondot.org> | 2010-08-29 17:21:35 +0000 |
commit | d6f46b8af8825be5287a41d9103ba290f34858f5 (patch) | |
tree | cea3d6a2cefe79cdae3749d304254c80e9653ba9 /llvm/lib/Transforms/Scalar/LoopUnrollPass.cpp | |
parent | 161848a0309087cc8ed8fda2362bc10f0c7e20c1 (diff) | |
download | bcm5719-llvm-d6f46b8af8825be5287a41d9103ba290f34858f5.tar.gz bcm5719-llvm-d6f46b8af8825be5287a41d9103ba290f34858f5.zip |
now that loop passes don't use DomFrontier, there is no reason
for the unroller to pretend it supports updating it. It still
has a horrible hack for DomTree.
llvm-svn: 112444
Diffstat (limited to 'llvm/lib/Transforms/Scalar/LoopUnrollPass.cpp')
-rw-r--r-- | llvm/lib/Transforms/Scalar/LoopUnrollPass.cpp | 10 |
1 files changed, 2 insertions, 8 deletions
diff --git a/llvm/lib/Transforms/Scalar/LoopUnrollPass.cpp b/llvm/lib/Transforms/Scalar/LoopUnrollPass.cpp index 4ed2d456872..d0edfa22005 100644 --- a/llvm/lib/Transforms/Scalar/LoopUnrollPass.cpp +++ b/llvm/lib/Transforms/Scalar/LoopUnrollPass.cpp @@ -62,13 +62,12 @@ namespace { AU.addPreservedID(LoopSimplifyID); AU.addRequiredID(LCSSAID); AU.addPreservedID(LCSSAID); + AU.addPreserved<ScalarEvolution>(); // FIXME: Loop unroll requires LCSSA. And LCSSA requires dom info. // If loop unroll does not preserve dom info then LCSSA pass on next // loop will receive invalid dom info. // For now, recreate dom info, if loop is unrolled. AU.addPreserved<DominatorTree>(); - AU.addPreserved<DominanceFrontier>(); - AU.addPreserved<ScalarEvolution>(); } }; } @@ -148,12 +147,7 @@ bool LoopUnroll::runOnLoop(Loop *L, LPPassManager &LPM) { return false; // FIXME: Reconstruct dom info, because it is not preserved properly. - DominatorTree *DT = getAnalysisIfAvailable<DominatorTree>(); - if (DT) { + if (DominatorTree *DT = getAnalysisIfAvailable<DominatorTree>()) DT->runOnFunction(*F); - DominanceFrontier *DF = getAnalysisIfAvailable<DominanceFrontier>(); - if (DF) - DF->runOnFunction(*F); - } return true; } |