81 lines
		
	
	
		
			2.0 KiB
		
	
	
	
		
			LLVM
		
	
	
	
			
		
		
	
	
			81 lines
		
	
	
		
			2.0 KiB
		
	
	
	
		
			LLVM
		
	
	
	
; RUN: llc -verify-machineinstrs < %s -mtriple=powerpc64le-unknown-linux-gnu -march=ppc64le \
 | 
						|
; RUN:          -mattr=+altivec -mattr=+vsx |  FileCheck %s
 | 
						|
; RUN: llc -verify-machineinstrs < %s -mtriple=powerpc64le-unknown-linux-gnu -march=ppc64le \
 | 
						|
; RUN:          -mattr=+altivec -mattr=-vsx |  FileCheck %s \
 | 
						|
; RUN:          -check-prefix=CHECK-NOVSX
 | 
						|
 | 
						|
define <4 x float> @test_float(<4 x float> %aa) #0 {
 | 
						|
 | 
						|
; CHECK-LABEL: test_float
 | 
						|
; CHECK-NOVSX-LABEL: test_float
 | 
						|
; CHECK-NOVSX-LABEL: test_float
 | 
						|
 | 
						|
  entry:
 | 
						|
    %0 = tail call <4 x float> @llvm.fabs.v4f32(<4 x float> %aa) #2
 | 
						|
    ret <4 x float> %0
 | 
						|
}
 | 
						|
; Function Attrs: nounwind readnone
 | 
						|
declare <4 x float> @llvm.fabs.v4f32(<4 x float>) #1
 | 
						|
 | 
						|
; CHECK: xvabssp
 | 
						|
; CHECK: blr
 | 
						|
; CHECK-NOVSX: fabs
 | 
						|
; CHECK-NOVSX: fabs
 | 
						|
; CHECK-NOVSX: fabs
 | 
						|
; CHECK-NOVSX: fabs
 | 
						|
; CHECK-NOVSX: blr
 | 
						|
 | 
						|
define <4 x float> @test2_float(<4 x float> %aa) #0 {
 | 
						|
 | 
						|
; CHECK-LABEL: test2_float
 | 
						|
; CHECK-NOVSX-LABEL: test2_float
 | 
						|
 | 
						|
  entry:
 | 
						|
    %0 = tail call <4 x float> @llvm.fabs.v4f32(<4 x float> %aa) #2
 | 
						|
    %sub = fsub <4 x float> <float -0.000000e+00, float -0.000000e+00,
 | 
						|
                             float -0.000000e+00, float -0.000000e+00>, %0
 | 
						|
    ret <4 x float> %sub
 | 
						|
}
 | 
						|
 | 
						|
; CHECK: xvnabssp
 | 
						|
; CHECK: blr
 | 
						|
; CHECK-NOVSX: vspltisb
 | 
						|
; CHECK-NOVSX: fabs
 | 
						|
; CHECK-NOVSX: fabs
 | 
						|
; CHECK-NOVSX: fabs
 | 
						|
; CHECK-NOVSX: fabs
 | 
						|
; CHECK-NOVSX: vsubfp
 | 
						|
; CHECK-NOVSX: blr
 | 
						|
 | 
						|
define <2 x double> @test_double(<2 x double> %aa) #0 {
 | 
						|
 | 
						|
; CHECK-LABEL: test_double
 | 
						|
; CHECK-NOVSX-LABEL: test_double
 | 
						|
 | 
						|
  entry:
 | 
						|
    %0 = tail call <2 x double> @llvm.fabs.v2f64(<2 x double> %aa) #2
 | 
						|
    ret <2 x double> %0
 | 
						|
}
 | 
						|
 | 
						|
; Function Attrs: nounwind readnone
 | 
						|
declare <2 x double> @llvm.fabs.v2f64(<2 x double>) #1
 | 
						|
 | 
						|
; CHECK: xvabsdp
 | 
						|
; CHECK: blr
 | 
						|
; CHECK-NOVSX: fabs
 | 
						|
; CHECK-NOVSX: fabs
 | 
						|
; CHECK-NOVSX: blr
 | 
						|
 | 
						|
define <2 x double> @foo(<2 x double> %aa) #0 {
 | 
						|
  entry:
 | 
						|
    %0 = tail call <2 x double> @llvm.fabs.v2f64(<2 x double> %aa) #2
 | 
						|
    %sub = fsub <2 x double> <double -0.000000e+00, double -0.000000e+00>, %0
 | 
						|
    ret <2 x double> %sub
 | 
						|
}
 | 
						|
 | 
						|
; CHECK: xvnabsdp
 | 
						|
; CHECK: blr
 | 
						|
; CHECK-NOVSX: fnabs
 | 
						|
; CHECK-NOVSX: fnabs
 | 
						|
; CHECK-NOVSX: blr
 |