[llvm-commits] [llvm] r153833 - /llvm/trunk/test/Transforms/Inline/always-inline.ll

Chandler Carruth chandlerc at gmail.com
Sun Apr 1 03:36:17 PDT 2012


Author: chandlerc
Date: Sun Apr  1 05:36:17 2012
New Revision: 153833

URL: http://llvm.org/viewvc/llvm-project?rev=153833&view=rev
Log:
Add some more testing to cover the remaining two cases where
always-inlining is disabled: recursive functions and indirectbr.

Modified:
    llvm/trunk/test/Transforms/Inline/always-inline.ll

Modified: llvm/trunk/test/Transforms/Inline/always-inline.ll
URL: http://llvm.org/viewvc/llvm-project/llvm/trunk/test/Transforms/Inline/always-inline.ll?rev=153833&r1=153832&r2=153833&view=diff
==============================================================================
--- llvm/trunk/test/Transforms/Inline/always-inline.ll (original)
+++ llvm/trunk/test/Transforms/Inline/always-inline.ll Sun Apr  1 05:36:17 2012
@@ -78,3 +78,48 @@
   %add = add nsw i32 1, %call
   ret i32 %add
 }
+
+define i32 @inner5(i8* %addr) alwaysinline {
+entry:
+  indirectbr i8* %addr, [ label %one, label %two ]
+
+one:
+  ret i32 42
+
+two:
+  ret i32 44
+}
+define i32 @outer5(i32 %x) {
+; CHECK: @outer5
+; CHECK: call i32 @inner5
+; CHECK: ret
+
+  %cmp = icmp slt i32 %x, 42
+  %addr = select i1 %cmp, i8* blockaddress(@inner5, %one), i8* blockaddress(@inner5, %two)
+  %call = call i32 @inner5(i8* %addr)
+  ret i32 %call
+}
+
+define void @inner6(i32 %x) alwaysinline {
+entry:
+  %icmp = icmp slt i32 %x, 0
+  br i1 %icmp, label %return, label %bb
+
+bb:
+  %sub = sub nsw i32 %x, 1
+  call void @inner6(i32 %sub)
+  ret void
+
+return:
+  ret void
+}
+define void @outer6() {
+; CHECK: @outer6
+; CHECK: call void @inner6(i32 42)
+; CHECK: ret
+
+entry:
+  call void @inner6(i32 42)
+  ret void
+}
+





More information about the llvm-commits mailing list