mirror of
				https://github.com/c64scene-ar/llvm-6502.git
				synced 2025-10-26 02:22:29 +00:00 
			
		
		
		
	pass after isel instead of being interlaced with it, we can trust that all the code for a function has been isel'd before it is run. The practical impact of this is that we can scan for machine instr phis instead of doing a fuzzy match on the LLVM BB for phi nodes. Doing the fuzzy match required knowing when isel would produce an fp reg stack phi which was gross. It was also wrong in cases where select got lowered to a branch tree because cmovs aren't available (PR6828). Just do the scan on machine phis which is simpler, faster and more correct. This fixes PR6828. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@104333 91177308-0d34-0410-b5e6-96231b3b80d8
		
			
				
	
	
		
			26 lines
		
	
	
		
			1.0 KiB
		
	
	
	
		
			LLVM
		
	
	
	
	
	
			
		
		
	
	
			26 lines
		
	
	
		
			1.0 KiB
		
	
	
	
		
			LLVM
		
	
	
	
	
	
| ; RUN: llc %s -o - -mcpu=pentium
 | |
| ; PR6828
 | |
| target datalayout = "e-p:32:32:32-i1:8:8-i8:8:8-i16:16:16-i32:32:32-i64:32:64-f32:32:32-f64:32:64-v64:64:64-v128:128:128-a0:0:64-f80:32:32-n8:16:32"
 | |
| target triple = "i386-pc-linux-gnu"
 | |
| 
 | |
| define void @foo() nounwind {
 | |
| entry:
 | |
|   %tmp6 = load x86_fp80* undef                       ; <x86_fp80> [#uses=2]
 | |
|   %tmp15 = load x86_fp80* undef                      ; <x86_fp80> [#uses=2]
 | |
|   %tmp24 = load x86_fp80* undef                      ; <x86_fp80> [#uses=1]
 | |
|   br i1 undef, label %return, label %bb.nph
 | |
| 
 | |
| bb.nph:                                           ; preds = %entry
 | |
|   %cmp139 = fcmp ogt x86_fp80 %tmp15, %tmp6          ; <i1> [#uses=1]
 | |
|   %maxdiag.0 = select i1 %cmp139, x86_fp80 %tmp15, x86_fp80 %tmp6 ; <x86_fp80> [#uses=1]
 | |
|   %cmp139.1 = fcmp ogt x86_fp80 %tmp24, %maxdiag.0   ; <i1> [#uses=1]
 | |
|   br i1 %cmp139.1, label %sw.bb372, label %return
 | |
| 
 | |
| sw.bb372:                                         ; preds = %for.end
 | |
|   ret void
 | |
| 
 | |
| return:                                           ; preds = %for.end
 | |
|   ret void
 | |
| }
 | |
| 
 |