diff options
author | Chris Lattner <sabre@nondot.org> | 2010-04-03 06:16:22 +0000 |
---|---|---|
committer | Chris Lattner <sabre@nondot.org> | 2010-04-03 06:16:22 +0000 |
commit | 70c0d4f7eb9c14bccc8a585be4086712e46bfbdb (patch) | |
tree | c39d1d7382ef4c63e98502c73ec87ba64b2fe106 /lib/Transforms/Scalar/IndVarSimplify.cpp | |
parent | 9698c1985f8b4f461a01a908be60f9fd14a342ec (diff) | |
download | external_llvm-70c0d4f7eb9c14bccc8a585be4086712e46bfbdb.tar.gz external_llvm-70c0d4f7eb9c14bccc8a585be4086712e46bfbdb.tar.bz2 external_llvm-70c0d4f7eb9c14bccc8a585be4086712e46bfbdb.zip |
improve comment and drop a dead check. If PH had
no uses, it would have been deleted by
RecursivelyDeleteTriviallyDeadInstructions
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@100275 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'lib/Transforms/Scalar/IndVarSimplify.cpp')
-rw-r--r-- | lib/Transforms/Scalar/IndVarSimplify.cpp | 12 |
1 files changed, 8 insertions, 4 deletions
diff --git a/lib/Transforms/Scalar/IndVarSimplify.cpp b/lib/Transforms/Scalar/IndVarSimplify.cpp index b5fdd0c4a1..650231b8e5 100644 --- a/lib/Transforms/Scalar/IndVarSimplify.cpp +++ b/lib/Transforms/Scalar/IndVarSimplify.cpp @@ -759,10 +759,14 @@ void IndVarSimplify::HandleFloatingPointIV(Loop *L, PHINode *PH) { Incr->replaceAllUsesWith(UndefValue::get(Incr->getType())); RecursivelyDeleteTriviallyDeadInstructions(Incr); - // Replace floating induction variable, if it isn't already deleted. - // Give SIToFPInst preference over UIToFPInst because it is faster on - // platforms that are widely used. - if (WeakPH && !PH->use_empty()) { + // If the FP induction variable still has uses, this is because something else + // in the loop uses its value. In order to canonicalize the induction + // variable, we chose to eliminate the IV and rewrite it in terms of an + // int->fp cast. + // + // We give preference to sitofp over uitofp because it is faster on most + // platforms. + if (WeakPH) { if (CanUseSIToFP(InitValueVal, ExitValueVal, InitValue, ExitValue)) { SIToFPInst *Conv = new SIToFPInst(NewPHI, PH->getType(), "indvar.conv", PH->getParent()->getFirstNonPHI()); |