You've already forked linux-packaging-mono
							
							
		
			
	
	
		
			25 lines
		
	
	
		
			734 B
		
	
	
	
		
			LLVM
		
	
	
	
	
	
		
		
			
		
	
	
			25 lines
		
	
	
		
			734 B
		
	
	
	
		
			LLVM
		
	
	
	
	
	
|   | ; RUN: llc -verify-machineinstrs -mcpu=pwr8 -mtriple=powerpc64le-unknown-linux-gnu -O3 < %s | FileCheck %s
 | ||
|  | 
 | ||
|  | ; This test verifies that VSX swap optimization works for the
 | ||
|  | ; doubleword splat idiom.
 | ||
|  | 
 | ||
|  | @a = external global <2 x double>, align 16 | ||
|  | @b = external global <2 x double>, align 16 | ||
|  | 
 | ||
|  | define void @test(double %s) { | ||
|  | entry: | ||
|  |   %0 = insertelement <2 x double> undef, double %s, i32 0 | ||
|  |   %1 = shufflevector <2 x double> %0, <2 x double> undef, <2 x i32> zeroinitializer | ||
|  |   %2 = load <2 x double>, <2 x double>* @a, align 16 | ||
|  |   %3 = fadd <2 x double> %0, %2 | ||
|  |   store <2 x double> %3, <2 x double>* @b, align 16 | ||
|  |   ret void | ||
|  | } | ||
|  | 
 | ||
|  | ; CHECK-LABEL: @test
 | ||
|  | ; CHECK-DAG: xxspltd
 | ||
|  | ; CHECK-DAG: lxvd2x
 | ||
|  | ; CHECK: xvadddp
 | ||
|  | ; CHECK: stxvd2x
 | ||
|  | ; CHECK-NOT: xxswapd
 |