[llvm-commits] [llvm] r51280 - in /llvm/trunk: lib/Transforms/Scalar/LoopIndexSplit.cpp test/Transforms/LoopIndexSplit/2008-05-19-IndVar.ll
Devang Patel
dpatel at apple.com
Mon May 19 15:23:56 PDT 2008
Author: dpatel
Date: Mon May 19 17:23:55 2008
New Revision: 51280
URL: http://llvm.org/viewvc/llvm-project?rev=51280&view=rev
Log:
Do not erase induction variable increment if it is used outside the loop.
Added:
llvm/trunk/test/Transforms/LoopIndexSplit/2008-05-19-IndVar.ll
Modified:
llvm/trunk/lib/Transforms/Scalar/LoopIndexSplit.cpp
Modified: llvm/trunk/lib/Transforms/Scalar/LoopIndexSplit.cpp
URL: http://llvm.org/viewvc/llvm-project/llvm/trunk/lib/Transforms/Scalar/LoopIndexSplit.cpp?rev=51280&r1=51279&r2=51280&view=diff
==============================================================================
--- llvm/trunk/lib/Transforms/Scalar/LoopIndexSplit.cpp (original)
+++ llvm/trunk/lib/Transforms/Scalar/LoopIndexSplit.cpp Mon May 19 17:23:55 2008
@@ -596,11 +596,27 @@
if (isa<PHINode>(I) || I == LTerminator)
continue;
- if (I == IndVarIncrement)
- I->replaceAllUsesWith(ExitValue);
- else
+ if (I == IndVarIncrement) {
+ // Replace induction variable increment if it is not used outside
+ // the loop.
+ bool UsedOutsideLoop = false;
+ for (Value::use_iterator UI = I->use_begin(), E = I->use_end();
+ UI != E; ++UI) {
+ if (Instruction *Use = dyn_cast<Instruction>(UI))
+ if (!L->contains(Use->getParent())) {
+ UsedOutsideLoop = true;
+ break;
+ }
+ }
+ if (!UsedOutsideLoop) {
+ I->replaceAllUsesWith(ExitValue);
+ I->eraseFromParent();
+ }
+ }
+ else {
I->replaceAllUsesWith(UndefValue::get(I->getType()));
- I->eraseFromParent();
+ I->eraseFromParent();
+ }
}
LPM->deleteLoopFromQueue(L);
Added: llvm/trunk/test/Transforms/LoopIndexSplit/2008-05-19-IndVar.ll
URL: http://llvm.org/viewvc/llvm-project/llvm/trunk/test/Transforms/LoopIndexSplit/2008-05-19-IndVar.ll?rev=51280&view=auto
==============================================================================
--- llvm/trunk/test/Transforms/LoopIndexSplit/2008-05-19-IndVar.ll (added)
+++ llvm/trunk/test/Transforms/LoopIndexSplit/2008-05-19-IndVar.ll Mon May 19 17:23:55 2008
@@ -0,0 +1,41 @@
+; RUN: llvm-as < %s | opt -loop-index-split | llvm-dis | grep tmp8 | count 3
+; count 3 = increment + phi + store
+;PR2294
+ at g_2 = external global i16 ; <i16*> [#uses=4]
+ at g_5 = external global i32 ; <i32*> [#uses=1]
+ at .str = external constant [4 x i8] ; <[4 x i8]*> [#uses=1]
+
+declare void @func_1() nounwind
+
+define i32 @main() nounwind {
+entry:
+ %tmp101.i = load i16* @g_2, align 2 ; <i16> [#uses=1]
+ %tmp112.i = icmp sgt i16 %tmp101.i, 0 ; <i1> [#uses=1]
+ br i1 %tmp112.i, label %bb.preheader.i, label %func_1.exit
+bb.preheader.i: ; preds = %entry
+ %g_2.promoted.i = load i16* @g_2 ; <i16> [#uses=1]
+ br label %bb.i
+bb.i: ; preds = %bb6.i, %bb.preheader.i
+ %g_2.tmp.0.i = phi i16 [ %g_2.promoted.i, %bb.preheader.i ], [ %tmp8.i, %bb6.i ] ; <i16> [#uses=2]
+ %tmp2.i = icmp eq i16 %g_2.tmp.0.i, 0 ; <i1> [#uses=1]
+ br i1 %tmp2.i, label %bb4.i, label %bb6.i
+bb4.i: ; preds = %bb.i
+ %tmp5.i = volatile load i32* @g_5, align 4 ; <i32> [#uses=0]
+ br label %bb6.i
+bb6.i: ; preds = %bb4.i, %bb.i
+ %tmp8.i = add i16 %g_2.tmp.0.i, 1 ; <i16> [#uses=3]
+ %tmp11.i = icmp sgt i16 %tmp8.i, 0 ; <i1> [#uses=1]
+ br i1 %tmp11.i, label %bb.i, label %return.loopexit.i
+return.loopexit.i: ; preds = %bb6.i
+ %tmp8.i.lcssa = phi i16 [ %tmp8.i, %bb6.i ] ; <i16> [#uses=1]
+ store i16 %tmp8.i.lcssa, i16* @g_2
+ br label %func_1.exit
+func_1.exit: ; preds = %return.loopexit.i, %entry
+ %tmp1 = load i16* @g_2, align 2 ; <i16> [#uses=1]
+ %tmp12 = sext i16 %tmp1 to i32 ; <i32> [#uses=1]
+ %tmp3 = tail call i32 (i8*, ...)* @printf( i8* getelementptr ([4 x i8]* @.str, i32 0, i32 0), i32 %tmp12 ) nounwind ; <i32> [#uses=0]
+ ret i32 0
+}
+
+declare i32 @printf(i8*, ...) nounwind
+
More information about the llvm-commits
mailing list