mirror of
				https://github.com/c64scene-ar/llvm-6502.git
				synced 2025-11-03 14:21:30 +00:00 
			
		
		
		
	git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@24582 91177308-0d34-0410-b5e6-96231b3b80d8
		
			
				
	
	
		
			66 lines
		
	
	
		
			1.8 KiB
		
	
	
	
		
			LLVM
		
	
	
	
	
	
			
		
		
	
	
			66 lines
		
	
	
		
			1.8 KiB
		
	
	
	
		
			LLVM
		
	
	
	
	
	
; Test a bunch of cases where the cfg simplification code should
 | 
						|
; be able to fold PHI nodes into computation in common cases.  Folding the PHI
 | 
						|
; nodes away allows the branches to be eliminated, performing a simple form of
 | 
						|
; 'if conversion'.
 | 
						|
 | 
						|
; RUN: llvm-as < %s | opt -simplifycfg | llvm-dis > %t.xform
 | 
						|
; RUN: not grep phi %t.xform && grep ret %t.xform
 | 
						|
 | 
						|
declare void %use(bool)
 | 
						|
declare void %use(int)
 | 
						|
 | 
						|
 | 
						|
void %test2(bool %c, bool %d, int %V, int %V2) {
 | 
						|
	br bool %d, label %X, label %F
 | 
						|
X:
 | 
						|
	br bool %c, label %T, label %F
 | 
						|
T:
 | 
						|
	br label %F
 | 
						|
F:
 | 
						|
	%B1 = phi bool [true, %0], [false, %T], [false, %X]
 | 
						|
	%B2 = phi bool [true, %T], [false, %0], [false, %X]
 | 
						|
	%I1 = phi int  [1, %T], [0, %0], [2, %X]
 | 
						|
	%I2 = phi int  [1, %0], [0, %T], [3, %X]
 | 
						|
	%I3 = phi int  [17, %T], [0, %0], [4, %X]
 | 
						|
	%I4 = phi int  [17, %T], [5, %0], [44, %X]
 | 
						|
	%I5 = phi int  [%V, %T], [0, %0], [%V, %X]
 | 
						|
	%I6 = phi int  [%V, %0], [0, %T], [%V, %X]
 | 
						|
	%I7 = phi int  [%V, %0], [%V2, %T], [%V2, %X]
 | 
						|
	call void %use(bool %B1)
 | 
						|
	call void %use(bool %B2)
 | 
						|
	call void %use(int  %I1)
 | 
						|
	call void %use(int  %I2)
 | 
						|
	call void %use(int  %I3)
 | 
						|
	call void %use(int  %I4)
 | 
						|
	call void %use(int  %I5)
 | 
						|
	call void %use(int  %I6)
 | 
						|
	call void %use(int  %I7)
 | 
						|
	ret void
 | 
						|
}
 | 
						|
 | 
						|
void %test(bool %c, int %V, int %V2) {
 | 
						|
	br bool %c, label %T, label %F
 | 
						|
T:
 | 
						|
	br label %F
 | 
						|
F:
 | 
						|
	%B1 = phi bool [true, %0], [false, %T]
 | 
						|
	%B2 = phi bool [true, %T], [false, %0]
 | 
						|
	%I1 = phi int  [1, %T], [0, %0]
 | 
						|
	%I2 = phi int  [1, %0], [0, %T]
 | 
						|
	%I3 = phi int  [17, %T], [0, %0]
 | 
						|
	%I4 = phi int  [17, %T], [5, %0]
 | 
						|
	%I5 = phi int  [%V, %T], [0, %0]
 | 
						|
	%I6 = phi int  [%V, %0], [0, %T]
 | 
						|
	%I7 = phi int  [%V, %0], [%V2, %T]
 | 
						|
	call void %use(bool %B1)
 | 
						|
	call void %use(bool %B2)
 | 
						|
	call void %use(int  %I1)
 | 
						|
	call void %use(int  %I2)
 | 
						|
	call void %use(int  %I3)
 | 
						|
	call void %use(int  %I4)
 | 
						|
	call void %use(int  %I5)
 | 
						|
	call void %use(int  %I6)
 | 
						|
	call void %use(int  %I7)
 | 
						|
	ret void
 | 
						|
}
 |