mirror of
				https://github.com/c64scene-ar/llvm-6502.git
				synced 2025-10-31 08:16:47 +00:00 
			
		
		
		
	On cores without fpcvt support, we cannot promote int_to_fp i1 operations, because there is nothing to promote them to. The most straightforward implementation of this uses a select to choose between the two possible resulting floating-point values (and that's what is done here). git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@203015 91177308-0d34-0410-b5e6-96231b3b80d8
		
			
				
	
	
		
			22 lines
		
	
	
		
			473 B
		
	
	
	
		
			LLVM
		
	
	
	
	
	
			
		
		
	
	
			22 lines
		
	
	
		
			473 B
		
	
	
	
		
			LLVM
		
	
	
	
	
	
| ; RUN: llc -march=ppc32 -mcpu=ppc32 -mtriple=powerpc-unknown-linux-gnu < %s | FileCheck %s
 | |
| define double @test(i1 %X) {
 | |
|         %Y = uitofp i1 %X to double
 | |
|         ret double %Y
 | |
| }
 | |
| 
 | |
| ; CHECK-LABEL: @test
 | |
| 
 | |
| ; CHECK: andi. {{[0-9]+}}, 3, 1
 | |
| ; CHECK: bc 12, 1,
 | |
| 
 | |
| ; CHECK: li 3, .LCP[[L1:[A-Z0-9_]+]]@l
 | |
| ; CHECK: addis 3, 3, .LCP[[L1]]@ha
 | |
| ; CHECK: lfs 1, 0(3)
 | |
| ; CHECK: blr
 | |
| 
 | |
| ; CHECK: li 3, .LCP[[L2:[A-Z0-9_]+]]@l
 | |
| ; CHECK: addis 3, 3, .LCP[[L2]]@ha
 | |
| ; CHECK: lfs 1, 0(3)
 | |
| ; CHECK: blr
 | |
| 
 |