; RUN: llc -verify-machineinstrs -mcpu=corei7-avx %s -o - | FileCheck %s --check-prefix=CHECK --check-prefix=NO-FLAGS target datalayout = "e-p:64:64:64-i1:8:8-i8:8:8-i16:16:16-i32:32:32-i64:64:64-f32:32:32-f64:64:64-v64:64:64-v128:128:128-a0:0:64-s0:64:64-f80:128:128-n8:16:32:64-S128" target triple = "x86_64-apple-macosx10.9.0" %struct.__va_list_tag = type { i32, i32, ptr, ptr } ; Check that vastart gets the right thing. define i32 @sum(i32 %count, ...) nounwind optsize ssp uwtable { ; CHECK: testb %al, %al ; CHECK-NEXT: je ; CHECK-NEXT: ## %bb.{{[0-9]+}}: ; CHECK-NEXT: vmovaps %xmm0, 48(%rsp) ; CHECK-NEXT: vmovaps %xmm1, 64(%rsp) ; CHECK-NEXT: vmovaps %xmm2, 80(%rsp) ; CHECK-NEXT: vmovaps %xmm3, 96(%rsp) ; CHECK-NEXT: vmovaps %xmm4, 112(%rsp) ; CHECK-NEXT: vmovaps %xmm5, 128(%rsp) ; CHECK-NEXT: vmovaps %xmm6, 144(%rsp) ; CHECK-NEXT: vmovaps %xmm7, 160(%rsp) ; Check that [EFLAGS] hasn't been pulled in. ; NO-FLAGS-NOT: %flags %ap = alloca [1 x %struct.__va_list_tag], align 16 call void @llvm.va_start(ptr %ap) %1 = icmp sgt i32 %count, 0 br i1 %1, label %.lr.ph, label %._crit_edge .lr.ph: ; preds = %0 %2 = getelementptr inbounds [1 x %struct.__va_list_tag], ptr %ap, i64 0, i64 0, i32 2 %.pre = load i32, ptr %ap, align 16 br label %3 ;