mirror of
				https://github.com/c64scene-ar/llvm-6502.git
				synced 2025-10-26 02:22:29 +00:00 
			
		
		
		
	If a conditional branch jumps to the same target, remove the condition
Given that large parts of inst combine is restricted to instructions which have one use, getting rid of a use on the condition can help the effectiveness of the optimizer. Also, it allows the condition to potentially be deleted by instcombine rather than waiting for another pass. I noticed this completely by accident in another test case. It's not anything that actually came from a real workload. p.s. We should probably do the same thing for switch instructions. Differential Revision: http://reviews.llvm.org/D8220 git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@231881 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
		| @@ -2002,6 +2002,15 @@ Instruction *InstCombiner::visitBranchInst(BranchInst &BI) { | ||||
|     return &BI; | ||||
|   } | ||||
|  | ||||
|   // If the condition is irrelevant, remove the use so that other | ||||
|   // transforms on the condition become more effective. | ||||
|   if (BI.isConditional() && | ||||
|       BI.getSuccessor(0) == BI.getSuccessor(1) && | ||||
|       !isa<UndefValue>(BI.getCondition())) { | ||||
|     BI.setCondition(UndefValue::get(BI.getCondition()->getType())); | ||||
|     return &BI; | ||||
|   } | ||||
|  | ||||
|   // Canonicalize fcmp_one -> fcmp_oeq | ||||
|   FCmpInst::Predicate FPred; Value *Y; | ||||
|   if (match(&BI, m_Br(m_FCmp(FPred, m_Value(X), m_Value(Y)), | ||||
|   | ||||
							
								
								
									
										16
									
								
								test/Transforms/InstCombine/branch.ll
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										16
									
								
								test/Transforms/InstCombine/branch.ll
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,16 @@ | ||||
| ; RUN: opt -instcombine -S < %s | FileCheck %s | ||||
|  | ||||
| define i32 @test(i32 %x) { | ||||
| ; CHECK-LABEL: @test | ||||
| entry: | ||||
| ; CHECK-NOT: icmp | ||||
| ; CHECK: br i1 undef,  | ||||
|   %cmp = icmp ult i32 %x, 7 | ||||
|   br i1 %cmp, label %merge, label %merge | ||||
| merge: | ||||
| ; CHECK-LABEL: merge: | ||||
| ; CHECK: ret i32 %x | ||||
|   ret i32 %x | ||||
| } | ||||
|  | ||||
|  | ||||
		Reference in New Issue
	
	Block a user