Fix the remaining TCL-style quotes found in the testsuite. This is
[oota-llvm.git] / test / Transforms / SimplifyLibCalls / SPrintF.ll
index d17b038732770426c470e418ce3b4c2d95a8cd1f..514a7d9f6eeef7e91d4afff221ac16bc8c7b7228 100644 (file)
@@ -1,32 +1,40 @@
 ; Test that the SPrintFOptimizer works correctly
-; RUN: llvm-as < %s | opt -simplify-libcalls | llvm-dis | not grep 'call.*sprintf'
+; RUN: opt < %s -simplify-libcalls -S | \
+; RUN:   not grep "call.*sprintf"
 
-declare int %sprintf(sbyte*,sbyte*,...)
-declare int %puts(sbyte*)
-%hello = constant [6 x sbyte] c"hello\00"
-%null = constant [1 x sbyte] c"\00"
-%null_hello = constant [7 x sbyte] c"\00hello\00"
-%fmt1 = constant [3 x sbyte] c"%s\00"
-%fmt2 = constant [3 x sbyte] c"%c\00"
+; This transformation requires the pointer size, as it assumes that size_t is
+; the size of a pointer.
+target datalayout = "-p:64:64:64"
 
-implementation   ; Functions:
+@hello = constant [6 x i8] c"hello\00"         ; <[6 x i8]*> [#uses=1]
+@null = constant [1 x i8] zeroinitializer              ; <[1 x i8]*> [#uses=1]
+@null_hello = constant [7 x i8] c"\00hello\00"         ; <[7 x i8]*> [#uses=1]
+@fmt1 = constant [3 x i8] c"%s\00"             ; <[3 x i8]*> [#uses=1]
+@fmt2 = constant [3 x i8] c"%c\00"             ; <[3 x i8]*> [#uses=1]
 
-int %main () {
-  %target = alloca [1024 x sbyte]
-  %target_p = getelementptr [1024 x sbyte]* %target, int 0, int 0
-  %hello_p = getelementptr [6 x sbyte]* %hello, int 0, int 0
-  %null_p = getelementptr [1 x sbyte]* %null, int 0, int 0
-  %nh_p = getelementptr [7 x sbyte]* %null_hello, int 0, int 0
-  %fmt1_p = getelementptr [3 x sbyte]* %fmt1, int 0, int 0
-  %fmt2_p = getelementptr [3 x sbyte]* %fmt2, int 0, int 0
-  store sbyte 0, sbyte* %target_p
-  %r1 = call int (sbyte*,sbyte*,...)* %sprintf(sbyte* %target_p, sbyte* %hello_p)
-  %r2 = call int (sbyte*,sbyte*,...)* %sprintf(sbyte* %target_p, sbyte* %null_p)
-  %r3 = call int (sbyte*,sbyte*,...)* %sprintf(sbyte* %target_p, sbyte* %nh_p)
-  %r4 = call int (sbyte*,sbyte*,...)* %sprintf(sbyte* %target_p, sbyte* %fmt1_p, sbyte* %hello_p)
-  %r5 = call int (sbyte*,sbyte*,...)* %sprintf(sbyte* %target_p, sbyte* %fmt2_p, int 82)
-  %r6 = add int %r1, %r2
-  %r7 = add int %r3, %r6
-  %r8 = add int %r5, %r7
-  ret int %r8
+declare i32 @sprintf(i8*, i8*, ...)
+
+declare i32 @puts(i8*)
+
+define i32 @foo(i8* %p) {
+       %target = alloca [1024 x i8]            ; <[1024 x i8]*> [#uses=1]
+       %target_p = getelementptr [1024 x i8]* %target, i32 0, i32 0            ; <i8*> [#uses=7]
+       %hello_p = getelementptr [6 x i8]* @hello, i32 0, i32 0         ; <i8*> [#uses=2]
+       %null_p = getelementptr [1 x i8]* @null, i32 0, i32 0           ; <i8*> [#uses=1]
+       %nh_p = getelementptr [7 x i8]* @null_hello, i32 0, i32 0               ; <i8*> [#uses=1]
+       %fmt1_p = getelementptr [3 x i8]* @fmt1, i32 0, i32 0           ; <i8*> [#uses=2]
+       %fmt2_p = getelementptr [3 x i8]* @fmt2, i32 0, i32 0           ; <i8*> [#uses=1]
+       store i8 0, i8* %target_p
+       %r1 = call i32 (i8*, i8*, ...)* @sprintf( i8* %target_p, i8* %hello_p )         ; <i32> [#uses=1]
+       %r2 = call i32 (i8*, i8*, ...)* @sprintf( i8* %target_p, i8* %null_p )          ; <i32> [#uses=1]
+       %r3 = call i32 (i8*, i8*, ...)* @sprintf( i8* %target_p, i8* %nh_p )            ; <i32> [#uses=1]
+       %r4 = call i32 (i8*, i8*, ...)* @sprintf( i8* %target_p, i8* %fmt1_p, i8* %hello_p )            ; <i32> [#uses=1]
+       %r4.1 = call i32 (i8*, i8*, ...)* @sprintf( i8* %target_p, i8* %fmt1_p, i8* %p )                ; <i32> [#uses=1]
+       %r5 = call i32 (i8*, i8*, ...)* @sprintf( i8* %target_p, i8* %fmt2_p, i32 82 )          ; <i32> [#uses=1]
+       %r6 = add i32 %r1, %r2          ; <i32> [#uses=1]
+       %r7 = add i32 %r3, %r6          ; <i32> [#uses=1]
+       %r8 = add i32 %r5, %r7          ; <i32> [#uses=1]
+       %r9 = add i32 %r8, %r4          ; <i32> [#uses=1]
+       %r10 = add i32 %r9, %r4.1               ; <i32> [#uses=1]
+       ret i32 %r10
 }