mirror of
				https://github.com/c64scene-ar/llvm-6502.git
				synced 2025-10-25 10:27:04 +00:00 
			
		
		
		
	Changed tests which assumed that vectors are legalized by widening them. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@142152 91177308-0d34-0410-b5e6-96231b3b80d8
		
			
				
	
	
		
			36 lines
		
	
	
		
			1.0 KiB
		
	
	
	
		
			LLVM
		
	
	
	
	
	
			
		
		
	
	
			36 lines
		
	
	
		
			1.0 KiB
		
	
	
	
		
			LLVM
		
	
	
	
	
	
| ; RUN: llc < %s -march=x86 -mattr=+sse2 -mattr=+mmx | not grep unpcklpd
 | |
| ; RUN: llc < %s -march=x86 -mattr=+sse2 -mattr=+mmx | not grep unpckhpd
 | |
| ; RUN: llc < %s -march=x86 -mattr=+sse2 | grep cvttpd2pi | count 1
 | |
| ; RUN: llc < %s -march=x86 -mattr=+sse2 | grep cvtpi2pd | count 1
 | |
| ; originally from PR2687, but things don't work that way any more.
 | |
| ; there are no MMX instructions here; we use XMM.
 | |
| 
 | |
| define <2 x double> @a(<2 x i32> %x) nounwind {
 | |
| entry:
 | |
|   %y = sitofp <2 x i32> %x to <2 x double>
 | |
|   ret <2 x double> %y
 | |
| }
 | |
| 
 | |
| define <2 x i32> @b(<2 x double> %x) nounwind {
 | |
| entry:
 | |
|   %y = fptosi <2 x double> %x to <2 x i32>
 | |
|   ret <2 x i32> %y
 | |
| }
 | |
| 
 | |
| ; This is how to get MMX instructions.
 | |
| 
 | |
| define <2 x double> @a2(x86_mmx %x) nounwind {
 | |
| entry:
 | |
|   %y = tail call <2 x double> @llvm.x86.sse.cvtpi2pd(x86_mmx %x)
 | |
|   ret <2 x double> %y
 | |
| }
 | |
| 
 | |
| define x86_mmx @b2(<2 x double> %x) nounwind {
 | |
| entry:
 | |
|   %y = tail call x86_mmx @llvm.x86.sse.cvttpd2pi (<2 x double> %x)
 | |
|   ret x86_mmx %y
 | |
| }
 | |
| 
 | |
| declare <2 x double> @llvm.x86.sse.cvtpi2pd(x86_mmx)
 | |
| declare x86_mmx @llvm.x86.sse.cvttpd2pi(<2 x double>)
 |