llvm/llvm/test/CodeGen/X86/byval6.ll

; NOTE: Assertions have been autogenerated by utils/update_llc_test_checks.py
; RUN: llc < %s -mcpu=generic -mtriple=i686-- | FileCheck %s

	%struct.W = type { x86_fp80, x86_fp80 }
@B = global %struct.W { x86_fp80 0xK4001A000000000000000, x86_fp80 0xK4001C000000000000000 }, align 32
@.cpx = internal constant %struct.W { x86_fp80 0xK4001E000000000000000, x86_fp80 0xK40028000000000000000 }

define i32 @main() nounwind  {
; CHECK-LABEL: main:
; CHECK:       # %bb.0: # %entry
; CHECK-NEXT:    pushl %ebx
; CHECK-NEXT:    pushl %edi
; CHECK-NEXT:    pushl %esi
; CHECK-NEXT:    movl .cpx+20, %eax
; CHECK-NEXT:    movl .cpx+16, %ecx
; CHECK-NEXT:    movl .cpx+12, %edx
; CHECK-NEXT:    movl .cpx+8, %esi
; CHECK-NEXT:    movl .cpx+4, %edi
; CHECK-NEXT:    movl .cpx, %ebx
; CHECK-NEXT:    pushl %eax
; CHECK-NEXT:    pushl %ecx
; CHECK-NEXT:    pushl %edx
; CHECK-NEXT:    pushl %esi
; CHECK-NEXT:    pushl %edi
; CHECK-NEXT:    pushl %ebx
; CHECK-NEXT:    pushl $3
; CHECK-NEXT:    calll bar@PLT
; CHECK-NEXT:    addl $28, %esp
; CHECK-NEXT:    movl B+20, %eax
; CHECK-NEXT:    movl B+16, %ecx
; CHECK-NEXT:    movl B+12, %edx
; CHECK-NEXT:    movl B+8, %esi
; CHECK-NEXT:    movl B+4, %edi
; CHECK-NEXT:    movl B, %ebx
; CHECK-NEXT:    pushl %eax
; CHECK-NEXT:    pushl %ecx
; CHECK-NEXT:    pushl %edx
; CHECK-NEXT:    pushl %esi
; CHECK-NEXT:    pushl %edi
; CHECK-NEXT:    pushl %ebx
; CHECK-NEXT:    pushl $3
; CHECK-NEXT:    calll baz@PLT
; CHECK-NEXT:    addl $28, %esp
; CHECK-NEXT:    popl %esi
; CHECK-NEXT:    popl %edi
; CHECK-NEXT:    popl %ebx
; CHECK-NEXT:    retl
entry:
	tail call void (i32, ...) @bar( i32 3, ptr byval(%struct.W) @.cpx ) nounwind
	tail call void (i32, ...) @baz( i32 3, ptr byval(%struct.W)  @B ) nounwind
	ret i32 undef
}

declare void @bar(i32, ...)

declare void @baz(i32, ...)