correct suffix matching to search for s/l/t suffixes on
[oota-llvm.git] / test / Feature / calltest.ll
index 8adbe4937180312c716cfd77705d0a542dbf9c5c..feafd3cd208486f8616c49375545c91bc37d32ad 100644 (file)
@@ -1,35 +1,32 @@
-; RUN: llvm-as %s -o - | llvm-dis > %t1.ll
+; RUN: llvm-as < %s | llvm-dis > %t1.ll
 ; RUN: llvm-as %t1.ll -o - | llvm-dis > %t2.ll
 ; RUN: diff %t1.ll %t2.ll
 
-%FunTy = type int(int)
+%FunTy = type i32 (i32)
 
-declare int "test"(...)   ; Test differences of prototype
-declare int "test"()      ; Differ only by vararg
+declare i32 @test(i32)   ; Test forward declaration merging
 
-implementation
+define void @invoke(%FunTy* %x) {
+        %foo = call i32 %x( i32 123 )           ; <i32> [#uses=0]
+        %foo2 = tail call i32 %x( i32 123 )             ; <i32> [#uses=0]
+        ret void
+}
 
-void "invoke"(%FunTy *%x)
-begin
-       %foo = call %FunTy* %x(int 123)
-       ret void
-end
+define i32 @main(i32 %argc) {
+        %retval = call i32 @test( i32 %argc )           ; <i32> [#uses=2]
+        %two = add i32 %retval, %retval         ; <i32> [#uses=1]
+        %retval2 = invoke i32 @test( i32 %argc )
+                        to label %Next unwind label %Error              ; <i32> [#uses=1]
 
-int "main"(int %argc)   ; TODO: , sbyte **argv, sbyte **envp)
-begin
-        %retval = call int (int) *%test(int %argc)
-        %two    = add int %retval, %retval
-       %retval2 = invoke int %test(int %argc)
-                  to label %Next except label %Error
-Next:
-       %two2 = add int %two, %retval2
-       call void %invoke (%FunTy* %test)
-        ret int %two2
-Error:
-       ret int -1
-end
+Next:           ; preds = %0
+        %two2 = add i32 %two, %retval2          ; <i32> [#uses=1]
+        call void @invoke( %FunTy* @test )
+        ret i32 %two2
 
-int "test"(int %i0)
-begin
-    ret int %i0
-end
+Error:          ; preds = %0
+        ret i32 -1
+}
+
+define i32 @test(i32 %i0) {
+        ret i32 %i0
+}