forked from OSchip/llvm-project
37 lines
1.5 KiB
LLVM
37 lines
1.5 KiB
LLVM
; Test that the SPrintFOptimizer works correctly
|
|
; RUN: llvm-upgrade < %s | llvm-as | opt -simplify-libcalls | llvm-dis | \
|
|
; 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"
|
|
|
|
implementation ; Functions:
|
|
|
|
int %foo (sbyte* %p) {
|
|
%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)
|
|
%r4.1 = call int (sbyte*,sbyte*,...)* %sprintf(sbyte* %target_p, sbyte* %fmt1_p, sbyte* %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
|
|
%r9 = add int %r8, %r4
|
|
%r10 = add int %r9, %r4.1
|
|
ret int %r10
|
|
}
|