mirror of
				https://github.com/c64scene-ar/llvm-6502.git
				synced 2025-10-25 10:27:04 +00:00 
			
		
		
		
	Patch by Bill Seurer; committed on his behalf. These test cases generate slightly different code sequences when VSX is activated and thus fail. The update turns off VSX explicitly for the existing checks and then adds a second set of checks for most of them that test the VSX instruction output. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@220019 91177308-0d34-0410-b5e6-96231b3b80d8
		
			
				
	
	
		
			31 lines
		
	
	
		
			1.4 KiB
		
	
	
	
		
			LLVM
		
	
	
	
	
	
			
		
		
	
	
			31 lines
		
	
	
		
			1.4 KiB
		
	
	
	
		
			LLVM
		
	
	
	
	
	
| ; RUN: llc < %s -mattr=-vsx -march=ppc32 -mattr=+altivec --enable-unsafe-fp-math | FileCheck %s
 | |
| ; RUN: llc < %s -mattr=+vsx -march=ppc32 -mattr=+altivec --enable-unsafe-fp-math | FileCheck -check-prefix=CHECK-VSX %s
 | |
| 
 | |
| define void @VXOR(<4 x float>* %P1, <4 x i32>* %P2, <4 x float>* %P3) {
 | |
|         %tmp = load <4 x float>* %P3            ; <<4 x float>> [#uses=1]
 | |
|         %tmp3 = load <4 x float>* %P1           ; <<4 x float>> [#uses=1]
 | |
|         %tmp4 = fmul <4 x float> %tmp, %tmp3             ; <<4 x float>> [#uses=1]
 | |
|         store <4 x float> %tmp4, <4 x float>* %P3
 | |
|         store <4 x float> zeroinitializer, <4 x float>* %P1
 | |
|         store <4 x i32> zeroinitializer, <4 x i32>* %P2
 | |
|         ret void
 | |
| }
 | |
| ; The fmul will spill a vspltisw to create a -0.0 vector used as the addend
 | |
| ; to vmaddfp (so it would IEEE compliant with zero sign propagation).
 | |
| ; CHECK: @VXOR
 | |
| ; CHECK: vsplti
 | |
| ; CHECK: vxor
 | |
| ; CHECK-VSX: @VXOR
 | |
| ; CHECK-VSX: vxor
 | |
| ; CHECK-VSX: xvmulsp
 | |
| 
 | |
| define void @VSPLTI(<4 x i32>* %P2, <8 x i16>* %P3) {
 | |
|         store <4 x i32> bitcast (<16 x i8> < i8 -1, i8 -1, i8 -1, i8 -1, i8 -1, i8 -1, i8 -1, i8 -1, i8 -1, i8 -1, i8 -1, i8 -1, i8 -1, i8 -1, i8 -1, i8 -1 > to <4 x i32>), <4 x i32>* %P2
 | |
|         store <8 x i16> < i16 -1, i16 -1, i16 -1, i16 -1, i16 -1, i16 -1, i16 -1, i16 -1 >, <8 x i16>* %P3
 | |
|         ret void
 | |
| }
 | |
| ; CHECK: @VSPLTI
 | |
| ; CHECK: vsplti
 | |
| ; CHECK-VSX: @VSPLTI
 | |
| ; CHECK-VSX: vsplti
 |