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

llvm-svn: 268524
diff --git a/llvm/test/Transforms/LoopUnroll/unroll-opt-attribute.ll b/llvm/test/Transforms/LoopUnroll/unroll-opt-attribute.ll
new file mode 100644
index 0000000..334162f
--- /dev/null
+++ b/llvm/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