40 lines
		
	
	
		
			1.4 KiB
		
	
	
	
		
			LLVM
		
	
	
	
			
		
		
	
	
			40 lines
		
	
	
		
			1.4 KiB
		
	
	
	
		
			LLVM
		
	
	
	
; NOTE: Assertions have been autogenerated by utils/update_llc_test_checks.py
 | 
						|
; RUN: llc < %s -mtriple=i686-- -mcpu=yonah | FileCheck %s
 | 
						|
 | 
						|
	%struct.S = type { <2 x i64>, <2 x i64>, <2 x i64>, <2 x i64>,
 | 
						|
                           <2 x i64>, <2 x i64>, <2 x i64>, <2 x i64>,
 | 
						|
                           <2 x i64> }
 | 
						|
 | 
						|
define i32 @main() nounwind  {
 | 
						|
; CHECK-LABEL: main:
 | 
						|
; CHECK:       # %bb.0: # %entry
 | 
						|
; CHECK-NEXT:    pushl %ebp
 | 
						|
; CHECK-NEXT:    movl %esp, %ebp
 | 
						|
; CHECK-NEXT:    pushl %edi
 | 
						|
; CHECK-NEXT:    pushl %esi
 | 
						|
; CHECK-NEXT:    andl $-16, %esp
 | 
						|
; CHECK-NEXT:    subl $304, %esp # imm = 0x130
 | 
						|
; CHECK-NEXT:    movaps {{.*#+}} xmm0 = [3,2,1,0]
 | 
						|
; CHECK-NEXT:    movaps %xmm0, {{[0-9]+}}(%esp)
 | 
						|
; CHECK-NEXT:    leal {{[0-9]+}}(%esp), %edi
 | 
						|
; CHECK-NEXT:    leal {{[0-9]+}}(%esp), %esi
 | 
						|
; CHECK-NEXT:    movl $36, %ecx
 | 
						|
; CHECK-NEXT:    rep;movsl (%esi), %es:(%edi)
 | 
						|
; CHECK-NEXT:    movl $1, (%esp)
 | 
						|
; CHECK-NEXT:    calll t
 | 
						|
; CHECK-NEXT:    xorl %eax, %eax
 | 
						|
; CHECK-NEXT:    leal -8(%ebp), %esp
 | 
						|
; CHECK-NEXT:    popl %esi
 | 
						|
; CHECK-NEXT:    popl %edi
 | 
						|
; CHECK-NEXT:    popl %ebp
 | 
						|
; CHECK-NEXT:    retl
 | 
						|
entry:
 | 
						|
	%s = alloca %struct.S		; <%struct.S*> [#uses=2]
 | 
						|
	%tmp15 = getelementptr %struct.S, %struct.S* %s, i32 0, i32 0		; <<2 x i64>*> [#uses=1]
 | 
						|
	store <2 x i64> < i64 8589934595, i64 1 >, <2 x i64>* %tmp15, align 16
 | 
						|
	call void @t( i32 1, %struct.S* byval(%struct.S) %s) nounwind
 | 
						|
	ret i32 0
 | 
						|
}
 | 
						|
 | 
						|
declare void @t(i32, %struct.S* byval(%struct.S))
 |