mirror of
				https://github.com/c64scene-ar/llvm-6502.git
				synced 2025-10-25 10:27:04 +00:00 
			
		
		
		
	PR19753: Optimize comparisons with "ashr exact" of a constanst.
Patch by suyog sarda. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@209903 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
		| @@ -2439,6 +2439,23 @@ Instruction *InstCombiner::visitICmpInst(ICmpInst &I) { | ||||
|       return new ICmpInst(I.getPredicate(), A, B); | ||||
|     } | ||||
|  | ||||
|     // PR19753: | ||||
|     // (icmp (ashr exact const2, A), const1) -> icmp A, Log2(const2/const1) | ||||
|     // Cases where const1 doesn't divide const2 exactly or Quotient is not | ||||
|     // exact of log2 are handled by SimplifyICmpInst call above where we | ||||
|     // return false. | ||||
|     // TODO: Handle this for lshr exact with udiv. | ||||
|     { | ||||
|       ConstantInt *CI2; | ||||
|       if (match(Op0, m_AShr(m_ConstantInt(CI2), m_Value(A))) && | ||||
|           (cast<BinaryOperator>(Op0)->isExact())) { | ||||
|         APInt Quotient = CI2->getValue().sdiv(CI->getValue()); | ||||
|         unsigned shift = Quotient.logBase2(); | ||||
|         return new ICmpInst(I.getPredicate(), A, | ||||
|                             ConstantInt::get(A->getType(), shift)); | ||||
|       } | ||||
|     } | ||||
|  | ||||
|     // If we have an icmp le or icmp ge instruction, turn it into the | ||||
|     // appropriate icmp lt or icmp gt instruction.  This allows us to rely on | ||||
|     // them being folded in the code below.  The SimplifyICmpInst code has | ||||
|   | ||||
| @@ -1365,3 +1365,11 @@ define i1 @icmp_neg_cst_slt(i32 %a) { | ||||
|   %2 = icmp slt i32 %1, -10 | ||||
|   ret i1 %2 | ||||
| } | ||||
|  | ||||
| ; CHECK-LABEL: @exact_ashr_eq_false | ||||
| ; CHECK-NEXT: icmp eq i32 %a, 1 | ||||
| define i1 @exact_ashr_eq_false(i32 %a) { | ||||
|   %shr = ashr exact i32 -30, %a | ||||
|   %cmp = icmp eq i32 %shr, -15 | ||||
|   ret i1 %cmp | ||||
| } | ||||
|   | ||||
		Reference in New Issue
	
	Block a user