[llvm-commits] [llvm] r58995 - in /llvm/trunk: lib/Transforms/Scalar/LoopIndexSplit.cpp test/Transforms/LoopIndexSplit/2008-11-10-Sign.ll

Devang Patel dpatel at apple.com
Mon Nov 10 11:48:36 PST 2008


Author: dpatel
Date: Mon Nov 10 13:48:34 2008
New Revision: 58995

URL: http://llvm.org/viewvc/llvm-project?rev=58995&view=rev
Log:
If the sign of exit condition and split condition does not match
then do not split loop index.

Added:
    llvm/trunk/test/Transforms/LoopIndexSplit/2008-11-10-Sign.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=58995&r1=58994&r2=58995&view=diff

==============================================================================
--- llvm/trunk/lib/Transforms/Scalar/LoopIndexSplit.cpp (original)
+++ llvm/trunk/lib/Transforms/Scalar/LoopIndexSplit.cpp Mon Nov 10 13:48:34 2008
@@ -1437,7 +1437,12 @@
     if (ICMP->getPredicate() == ICmpInst::ICMP_EQ)
       return false;
   }
-  
+
+  // If the predicate sign does not match then skip.
+  ICmpInst *CI = dyn_cast<ICmpInst>(SD.SplitCondition);
+  if (CI && (ExitCondition->isSignedPredicate() != CI->isSignedPredicate()))
+    return false;
+
   BasicBlock *SplitCondBlock = SD.SplitCondition->getParent();
   
   // Unable to handle triangle loops at the moment.

Added: llvm/trunk/test/Transforms/LoopIndexSplit/2008-11-10-Sign.ll
URL: http://llvm.org/viewvc/llvm-project/llvm/trunk/test/Transforms/LoopIndexSplit/2008-11-10-Sign.ll?rev=58995&view=auto

==============================================================================
--- llvm/trunk/test/Transforms/LoopIndexSplit/2008-11-10-Sign.ll (added)
+++ llvm/trunk/test/Transforms/LoopIndexSplit/2008-11-10-Sign.ll Mon Nov 10 13:48:34 2008
@@ -0,0 +1,69 @@
+; RUN: llvm-as < %s | opt -loop-index-split -stats | not grep "loop-index-split"
+; PR3029
+
+ at g_138 = common global i32 0		; <i32*> [#uses=3]
+ at g_188 = common global i32 0		; <i32*> [#uses=4]
+ at g_207 = common global i32 0		; <i32*> [#uses=3]
+@"\01LC" = internal constant [4 x i8] c"%d\0A\00"		; <[4 x i8]*> [#uses=1]
+ at g_102 = common global i32 0		; <i32*> [#uses=0]
+
+define i32 @func_119() nounwind {
+entry:
+	%0 = volatile load i32* @g_138, align 4		; <i32> [#uses=1]
+	ret i32 %0
+}
+
+define void @func_110(i32 %p_111) nounwind {
+entry:
+	%0 = load i32* @g_188, align 4		; <i32> [#uses=1]
+	%1 = icmp ugt i32 %0, -1572397472		; <i1> [#uses=1]
+	br i1 %1, label %bb, label %bb1
+
+bb:		; preds = %entry
+	%2 = volatile load i32* @g_138, align 4		; <i32> [#uses=0]
+	ret void
+
+bb1:		; preds = %entry
+	store i32 1, i32* @g_207, align 4
+	ret void
+}
+
+define void @func_34() nounwind {
+entry:
+	store i32 0, i32* @g_188
+	%g_188.promoted = load i32* @g_188		; <i32> [#uses=1]
+	br label %bb
+
+bb:		; preds = %func_110.exit, %entry
+	%g_188.tmp.0 = phi i32 [ %g_188.promoted, %entry ], [ %2, %func_110.exit ]		; <i32> [#uses=2]
+	%0 = icmp ugt i32 %g_188.tmp.0, -1572397472		; <i1> [#uses=1]
+	br i1 %0, label %bb.i, label %bb1.i
+
+bb.i:		; preds = %bb
+	%1 = volatile load i32* @g_138, align 4		; <i32> [#uses=0]
+	br label %func_110.exit
+
+bb1.i:		; preds = %bb
+	store i32 1, i32* @g_207, align 4
+	br label %func_110.exit
+
+func_110.exit:		; preds = %bb.i, %bb1.i
+	%2 = add i32 %g_188.tmp.0, 1		; <i32> [#uses=3]
+	%3 = icmp sgt i32 %2, 1		; <i1> [#uses=1]
+	br i1 %3, label %return, label %bb
+
+return:		; preds = %func_110.exit
+	%.lcssa = phi i32 [ %2, %func_110.exit ]		; <i32> [#uses=1]
+	store i32 %.lcssa, i32* @g_188
+	ret void
+}
+
+define i32 @main() nounwind {
+entry:
+	call void @func_34() nounwind
+	%0 = load i32* @g_207, align 4		; <i32> [#uses=1]
+	%1 = call i32 (i8*, ...)* @printf(i8* getelementptr ([4 x i8]* @"\01LC", i32 0, i32 0), i32 %0) nounwind		; <i32> [#uses=0]
+	ret i32 0
+}
+
+declare i32 @printf(i8*, ...) nounwind





More information about the llvm-commits mailing list