[ARM] Cortex-M4 schedule additions
[llvm-complete.git] / test / CodeGen / X86 / stdarg.ll
blob96d2f49cbbb004e56cfc156dfbceccb962a94b45
1 ; RUN: llc -stack-symbol-ordering=0 < %s -mtriple=x86_64-linux | FileCheck %s
3 %struct.__va_list_tag = type { i32, i32, i8*, i8* }
5 define void @foo(i32 %x, ...) nounwind {
6 entry:
7   %ap = alloca [1 x %struct.__va_list_tag], align 8; <[1 x %struct.__va_list_tag]*> [#uses=2]
8   %ap12 = bitcast [1 x %struct.__va_list_tag]* %ap to i8*; <i8*> [#uses=2]
9   call void @llvm.va_start(i8* %ap12)
10 ; CHECK: testb %al, %al
12 ; These test for specific offsets, which is very fragile. Still, the test needs
13 ; to ensure that va_list has the correct element types.
15 ; CHECK-DAG: movq {{.*}}, 192(%rsp)
16 ; CHECK-DAG: movq {{.*}}, 184(%rsp)
17 ; CHECK-DAG: movq {{.*}}, 176(%rsp)
18   %ap3 = getelementptr inbounds [1 x %struct.__va_list_tag], [1 x %struct.__va_list_tag]* %ap, i64 0, i64 0; <%struct.__va_list_tag*> [#uses=1]
19   call void @bar(%struct.__va_list_tag* %ap3) nounwind
20   call void @llvm.va_end(i8* %ap12)
21   ret void
24 declare void @llvm.va_start(i8*) nounwind
26 declare void @bar(%struct.__va_list_tag*)
28 declare void @llvm.va_end(i8*) nounwind