Fixed some bugs in register stack pass.
[llvm/zpu.git] / test / Feature / varargs.ll
blobb9317df491afb04afde8443098f01c879226e1ae
1 ; RUN: llvm-as < %s | llvm-dis > %t1.ll
2 ; RUN: llvm-as %t1.ll -o - | llvm-dis > %t2.ll
3 ; RUN: diff %t1.ll %t2.ll
5 ; Demonstrate all of the variable argument handling intrinsic functions plus 
6 ; the va_arg instruction.
8 declare void @llvm.va_start(i8*)
10 declare void @llvm.va_copy(i8*, i8*)
12 declare void @llvm.va_end(i8*)
14 define i32 @test(i32 %X, ...) {
15         %ap = alloca i8*                ; <i8**> [#uses=4]
16         %va.upgrd.1 = bitcast i8** %ap to i8*           ; <i8*> [#uses=1]
17         call void @llvm.va_start( i8* %va.upgrd.1 )
18         %tmp = va_arg i8** %ap, i32             ; <i32> [#uses=1]
19         %aq = alloca i8*                ; <i8**> [#uses=2]
20         %va0.upgrd.2 = bitcast i8** %aq to i8*          ; <i8*> [#uses=1]
21         %va1.upgrd.3 = bitcast i8** %ap to i8*          ; <i8*> [#uses=1]
22         call void @llvm.va_copy( i8* %va0.upgrd.2, i8* %va1.upgrd.3 )
23         %va.upgrd.4 = bitcast i8** %aq to i8*           ; <i8*> [#uses=1]
24         call void @llvm.va_end( i8* %va.upgrd.4 )
25         %va.upgrd.5 = bitcast i8** %ap to i8*           ; <i8*> [#uses=1]
26         call void @llvm.va_end( i8* %va.upgrd.5 )
27         ret i32 %tmp