33 lines
		
	
	
		
			1.4 KiB
		
	
	
	
		
			LLVM
		
	
	
	
			
		
		
	
	
			33 lines
		
	
	
		
			1.4 KiB
		
	
	
	
		
			LLVM
		
	
	
	
; RUN: llc %s -mattr=+avx -o - | FileCheck %s
 | 
						|
; Originally from http://llvm.org/PR21743.
 | 
						|
 | 
						|
target triple = "x86_64-pc-win32-elf"
 | 
						|
 | 
						|
; Copy propagation may remove COPYs if the result is only used by undef
 | 
						|
; operands.
 | 
						|
;
 | 
						|
; CHECK-LABEL: foo:
 | 
						|
; CHECK: movl	$339752784, %e[[INDIRECT_CALL1:[a-z]+]]
 | 
						|
; CHECK: callq *%r[[INDIRECT_CALL1]]
 | 
						|
; Copy the result in a temporary.
 | 
						|
; Note: Technically the regalloc could have been smarter and this move not
 | 
						|
; required, which would have hidden the bug.
 | 
						|
; CHECK: vmovapd	%xmm0, [[TMP:%xmm[0-9]+]]
 | 
						|
; CHECK-NOT: vxorps  %xmm0, %xmm0, %xmm0
 | 
						|
; CHECK-NEXT: vcvtsi2sdq      %rsi, %xmm0, %xmm6
 | 
						|
; CHECK: movl	$339772768, %e[[INDIRECT_CALL2:[a-z]+]]
 | 
						|
; CHECK-NOT: vmovapd %xmm7, %xmm0
 | 
						|
; CHECK-NEXT: vmovapd %xmm6, %xmm1
 | 
						|
; Set TMP in the first argument of the second call.
 | 
						|
; CHECK_NEXT: callq *%r[[INDIRECT_CALL2]]
 | 
						|
; CHECK: retq
 | 
						|
define double @foo(i64 %arg) {
 | 
						|
top:
 | 
						|
  %tmp = call double inttoptr (i64 339752784 to double (double, double)*)(double 1.000000e+00, double 0.000000e+00)
 | 
						|
  tail call void asm sideeffect "", "x,~{xmm1},~{xmm2},~{xmm3},~{xmm4},~{xmm5},~{xmm6},~{xmm7},~{xmm8},~{xmm9},~{xmm10},~{xmm11},~{xmm12},~{xmm13},~{xmm14},~{xmm15},~{dirflag},~{fpsr},~{flags}"(double %tmp)
 | 
						|
  %tmp1 = sitofp i64 %arg to double
 | 
						|
  call void inttoptr (i64 339772768 to void (double, double)*)(double %tmp, double %tmp1)
 | 
						|
  %tmp3 = fadd double %tmp1, %tmp
 | 
						|
  ret double %tmp3
 | 
						|
}
 |