From: Marianne Mailhot-Sarrasin Date: Wed, 4 May 2016 17:45:40 +0000 (+0000) Subject: Adding test cases showing the behavior of LoopUnrollPass according to optnone and... X-Git-Url: https://granicus.if.org/sourcecode?a=commitdiff_plain;h=51b20e881241dd6f61ee0f579a4c9d6cc08fc605;p=llvm Adding test cases showing the behavior of LoopUnrollPass according to optnone and optsize attributes The unroll pass was disabled by clang in /Os. Those new test cases shows that the pass will behave correctly even if it is not fully disabled. This patch is related in some way to the clang commit (http://reviews.llvm.org/D19827), which re-enables the pass in /Os. Differential Revision: http://reviews.llvm.org/D19870 git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@268524 91177308-0d34-0410-b5e6-96231b3b80d8 --- diff --git a/test/Transforms/LoopUnroll/unroll-opt-attribute.ll b/test/Transforms/LoopUnroll/unroll-opt-attribute.ll new file mode 100644 index 00000000000..334162f5605 --- /dev/null +++ b/test/Transforms/LoopUnroll/unroll-opt-attribute.ll @@ -0,0 +1,160 @@ +; RUN: opt < %s -S -loop-unroll -unroll-count=4 | FileCheck -check-prefix=CHECK_COUNT4 %s +; RUN: opt < %s -S -loop-unroll | FileCheck -check-prefix=CHECK_NOCOUNT %s + + +;///////////////////// TEST 1 ////////////////////////////// + +; This test shows that with optsize attribute, the loop is unrolled +; according to the specified unroll factor. + +define void @Test1() nounwind optsize { +entry: + br label %loop + +loop: + %iv = phi i32 [ 0, %entry ], [ %inc, %loop ] + %inc = add i32 %iv, 1 + %exitcnd = icmp uge i32 %inc, 1024 + br i1 %exitcnd, label %exit, label %loop + +exit: + ret void +} + +; CHECK_COUNT4-LABEL: @Test1 +; CHECK_COUNT4: phi +; CHECK_COUNT4-NEXT: add +; CHECK_COUNT4-NEXT: add +; CHECK_COUNT4-NEXT: add +; CHECK_COUNT4-NEXT: add +; CHECK_COUNT4-NEXT: icmp + + +;///////////////////// TEST 2 ////////////////////////////// + +; This test shows that with minsize attribute, the loop is unrolled +; according to the specified unroll factor. + +define void @Test2() nounwind minsize { +entry: + br label %loop + +loop: + %iv = phi i32 [ 0, %entry ], [ %inc, %loop ] + %inc = add i32 %iv, 1 + %exitcnd = icmp uge i32 %inc, 1024 + br i1 %exitcnd, label %exit, label %loop + +exit: + ret void +} + +; CHECK_COUNT4-LABEL: @Test2 +; CHECK_COUNT4: phi +; CHECK_COUNT4-NEXT: add +; CHECK_COUNT4-NEXT: add +; CHECK_COUNT4-NEXT: add +; CHECK_COUNT4-NEXT: add +; CHECK_COUNT4-NEXT: icmp + + +;///////////////////// TEST 3 ////////////////////////////// + +; This test shows that with optnone attribute, the loop is not unrolled +; even if an unroll factor was specified. + +define void @Test3() nounwind optnone noinline { +entry: + br label %loop + +loop: + %iv = phi i32 [ 0, %entry ], [ %inc, %loop ] + %inc = add i32 %iv, 1 + %exitcnd = icmp uge i32 %inc, 1024 + br i1 %exitcnd, label %exit, label %loop + +exit: + ret void +} + +; CHECK_COUNT4-LABEL: @Test3 +; CHECK_COUNT4: phi +; CHECK_COUNT4-NEXT: add +; CHECK_COUNT4-NEXT: icmp + + +;///////////////////// TEST 4 ////////////////////////////// + +; This test shows that without any attribute, this loop is fully unrolled +; by default. + +@tab = common global [24 x i32] zeroinitializer, align 4 + +define i32 @Test4() { +entry: + br label %for.body + +for.body: ; preds = %for.body, %entry + %i.05 = phi i32 [ 0, %entry ], [ %inc, %for.body ] + %arrayidx = getelementptr inbounds [24 x i32], [24 x i32]* @tab, i32 0, i32 %i.05 + store i32 %i.05, i32* %arrayidx, align 4 + %inc = add nuw nsw i32 %i.05, 1 + %exitcond = icmp eq i32 %inc, 24 + br i1 %exitcond, label %for.end, label %for.body + +for.end: ; preds = %for.body + ret i32 42 +} + +; CHECK_NOCOUNT-LABEL: @Test4 +; CHECK_NOCOUNT: store +; CHECK_NOCOUNT-NEXT: store +; CHECK_NOCOUNT-NEXT: store +; CHECK_NOCOUNT-NEXT: store +; CHECK_NOCOUNT-NEXT: store +; CHECK_NOCOUNT-NEXT: store +; CHECK_NOCOUNT-NEXT: store +; CHECK_NOCOUNT-NEXT: store +; CHECK_NOCOUNT-NEXT: store +; CHECK_NOCOUNT-NEXT: store +; CHECK_NOCOUNT-NEXT: store +; CHECK_NOCOUNT-NEXT: store +; CHECK_NOCOUNT-NEXT: store +; CHECK_NOCOUNT-NEXT: store +; CHECK_NOCOUNT-NEXT: store +; CHECK_NOCOUNT-NEXT: store +; CHECK_NOCOUNT-NEXT: store +; CHECK_NOCOUNT-NEXT: store +; CHECK_NOCOUNT-NEXT: store +; CHECK_NOCOUNT-NEXT: store +; CHECK_NOCOUNT-NEXT: store +; CHECK_NOCOUNT-NEXT: store +; CHECK_NOCOUNT-NEXT: store +; CHECK_NOCOUNT-NEXT: store +; CHECK_NOCOUNT-NEXT: ret + + +;///////////////////// TEST 5 ////////////////////////////// + +; This test shows that with optsize attribute, this loop is not unrolled +; by default. + +define i32 @Test5() optsize { +entry: + br label %for.body + +for.body: ; preds = %for.body, %entry + %i.05 = phi i32 [ 0, %entry ], [ %inc, %for.body ] + %arrayidx = getelementptr inbounds [24 x i32], [24 x i32]* @tab, i32 0, i32 %i.05 + store i32 %i.05, i32* %arrayidx, align 4 + %inc = add nuw nsw i32 %i.05, 1 + %exitcond = icmp eq i32 %inc, 24 + br i1 %exitcond, label %for.end, label %for.body + +for.end: ; preds = %for.body + ret i32 42 +} + +; CHECK_NOCOUNT-LABEL: @Test5 +; CHECK_NOCOUNT: phi +; CHECK_NOCOUNT: icmp