mirror of
				https://github.com/c64scene-ar/llvm-6502.git
				synced 2025-10-26 18:20:39 +00:00 
			
		
		
		
	InstCombine: Clean up foldLogOpOfMaskedICmps
No functional change intended. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@222229 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
		| @@ -665,8 +665,8 @@ static unsigned foldLogOpOfMaskedICmpsHelper(Value*& A, | |||||||
| /// foldLogOpOfMaskedICmps: | /// foldLogOpOfMaskedICmps: | ||||||
| /// try to fold (icmp(A & B) ==/!= C) &/| (icmp(A & D) ==/!= E) | /// try to fold (icmp(A & B) ==/!= C) &/| (icmp(A & D) ==/!= E) | ||||||
| /// into a single (icmp(A & X) ==/!= Y) | /// into a single (icmp(A & X) ==/!= Y) | ||||||
| static Value* foldLogOpOfMaskedICmps(ICmpInst *LHS, ICmpInst *RHS, bool IsAnd, | static Value *foldLogOpOfMaskedICmps(ICmpInst *LHS, ICmpInst *RHS, bool IsAnd, | ||||||
|                                      llvm::InstCombiner::BuilderTy* Builder) { |                                      llvm::InstCombiner::BuilderTy *Builder) { | ||||||
|   Value *A = nullptr, *B = nullptr, *C = nullptr, *D = nullptr, *E = nullptr; |   Value *A = nullptr, *B = nullptr, *C = nullptr, *D = nullptr, *E = nullptr; | ||||||
|   ICmpInst::Predicate LHSCC = LHS->getPredicate(), RHSCC = RHS->getPredicate(); |   ICmpInst::Predicate LHSCC = LHS->getPredicate(), RHSCC = RHS->getPredicate(); | ||||||
|   unsigned mask = foldLogOpOfMaskedICmpsHelper(A, B, C, D, E, LHS, RHS, |   unsigned mask = foldLogOpOfMaskedICmpsHelper(A, B, C, D, E, LHS, RHS, | ||||||
| @@ -697,26 +697,26 @@ static Value* foldLogOpOfMaskedICmps(ICmpInst *LHS, ICmpInst *RHS, bool IsAnd, | |||||||
|   if (mask & FoldMskICmp_Mask_AllZeroes) { |   if (mask & FoldMskICmp_Mask_AllZeroes) { | ||||||
|     // (icmp eq (A & B), 0) & (icmp eq (A & D), 0) |     // (icmp eq (A & B), 0) & (icmp eq (A & D), 0) | ||||||
|     // -> (icmp eq (A & (B|D)), 0) |     // -> (icmp eq (A & (B|D)), 0) | ||||||
|     Value* newOr = Builder->CreateOr(B, D); |     Value *newOr = Builder->CreateOr(B, D); | ||||||
|     Value* newAnd = Builder->CreateAnd(A, newOr); |     Value *newAnd = Builder->CreateAnd(A, newOr); | ||||||
|     // we can't use C as zero, because we might actually handle |     // we can't use C as zero, because we might actually handle | ||||||
|     //   (icmp ne (A & B), B) & (icmp ne (A & D), D) |     //   (icmp ne (A & B), B) & (icmp ne (A & D), D) | ||||||
|     // with B and D, having a single bit set |     // with B and D, having a single bit set | ||||||
|     Value* zero = Constant::getNullValue(A->getType()); |     Value *zero = Constant::getNullValue(A->getType()); | ||||||
|     return Builder->CreateICmp(NEWCC, newAnd, zero); |     return Builder->CreateICmp(NEWCC, newAnd, zero); | ||||||
|   } |   } | ||||||
|   if (mask & FoldMskICmp_BMask_AllOnes) { |   if (mask & FoldMskICmp_BMask_AllOnes) { | ||||||
|     // (icmp eq (A & B), B) & (icmp eq (A & D), D) |     // (icmp eq (A & B), B) & (icmp eq (A & D), D) | ||||||
|     // -> (icmp eq (A & (B|D)), (B|D)) |     // -> (icmp eq (A & (B|D)), (B|D)) | ||||||
|     Value* newOr = Builder->CreateOr(B, D); |     Value *newOr = Builder->CreateOr(B, D); | ||||||
|     Value* newAnd = Builder->CreateAnd(A, newOr); |     Value *newAnd = Builder->CreateAnd(A, newOr); | ||||||
|     return Builder->CreateICmp(NEWCC, newAnd, newOr); |     return Builder->CreateICmp(NEWCC, newAnd, newOr); | ||||||
|   } |   } | ||||||
|   if (mask & FoldMskICmp_AMask_AllOnes) { |   if (mask & FoldMskICmp_AMask_AllOnes) { | ||||||
|     // (icmp eq (A & B), A) & (icmp eq (A & D), A) |     // (icmp eq (A & B), A) & (icmp eq (A & D), A) | ||||||
|     // -> (icmp eq (A & (B&D)), A) |     // -> (icmp eq (A & (B&D)), A) | ||||||
|     Value* newAnd1 = Builder->CreateAnd(B, D); |     Value *newAnd1 = Builder->CreateAnd(B, D); | ||||||
|     Value* newAnd = Builder->CreateAnd(A, newAnd1); |     Value *newAnd = Builder->CreateAnd(A, newAnd1); | ||||||
|     return Builder->CreateICmp(NEWCC, newAnd, A); |     return Builder->CreateICmp(NEWCC, newAnd, A); | ||||||
|   } |   } | ||||||
|  |  | ||||||
| @@ -766,18 +766,16 @@ static Value* foldLogOpOfMaskedICmps(ICmpInst *LHS, ICmpInst *RHS, bool IsAnd, | |||||||
|     // with B and D, having a single bit set |     // with B and D, having a single bit set | ||||||
|     ConstantInt *CCst = dyn_cast<ConstantInt>(C); |     ConstantInt *CCst = dyn_cast<ConstantInt>(C); | ||||||
|     if (!CCst) return nullptr; |     if (!CCst) return nullptr; | ||||||
|     if (LHSCC != NEWCC) |  | ||||||
|       CCst = dyn_cast<ConstantInt>( ConstantExpr::getXor(BCst, CCst) ); |  | ||||||
|     ConstantInt *ECst = dyn_cast<ConstantInt>(E); |     ConstantInt *ECst = dyn_cast<ConstantInt>(E); | ||||||
|     if (!ECst) return nullptr; |     if (!ECst) return nullptr; | ||||||
|  |     if (LHSCC != NEWCC) | ||||||
|  |       CCst = cast<ConstantInt>(ConstantExpr::getXor(BCst, CCst)); | ||||||
|     if (RHSCC != NEWCC) |     if (RHSCC != NEWCC) | ||||||
|       ECst = dyn_cast<ConstantInt>( ConstantExpr::getXor(DCst, ECst) ); |       ECst = cast<ConstantInt>(ConstantExpr::getXor(DCst, ECst)); | ||||||
|     ConstantInt* MCst = dyn_cast<ConstantInt>( |  | ||||||
|       ConstantExpr::getAnd(ConstantExpr::getAnd(BCst, DCst), |  | ||||||
|                            ConstantExpr::getXor(CCst, ECst)) ); |  | ||||||
|     // if there is a conflict we should actually return a false for the |     // if there is a conflict we should actually return a false for the | ||||||
|     // whole construct |     // whole construct | ||||||
|     if (!MCst->isZero()) |     if (((BCst->getValue() & DCst->getValue()) & | ||||||
|  |          (CCst->getValue() ^ ECst->getValue())) != 0) | ||||||
|       return nullptr; |       return nullptr; | ||||||
|     Value *newOr1 = Builder->CreateOr(B, D); |     Value *newOr1 = Builder->CreateOr(B, D); | ||||||
|     Value *newOr2 = ConstantExpr::getOr(CCst, ECst); |     Value *newOr2 = ConstantExpr::getOr(CCst, ECst); | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user