forked from OSchip/llvm-project
[InstCombine] Use ConstantExpr::getBinOpIdentity to implement getIdentityValue.
This removes a TODO in getIdentityValue and may allow some transforms to occur earlier. But I was unable to find any transforms we didn't already handle. llvm-svn: 299966
This commit is contained in:
parent
b34ec829be
commit
271b2245f4
|
@ -455,16 +455,11 @@ static bool RightDistributesOverLeft(Instruction::BinaryOps LOp,
|
|||
|
||||
/// This function returns identity value for given opcode, which can be used to
|
||||
/// factor patterns like (X * 2) + X ==> (X * 2) + (X * 1) ==> X * (2 + 1).
|
||||
static Value *getIdentityValue(Instruction::BinaryOps OpCode, Value *V) {
|
||||
static Value *getIdentityValue(Instruction::BinaryOps Opcode, Value *V) {
|
||||
if (isa<Constant>(V))
|
||||
return nullptr;
|
||||
|
||||
if (OpCode == Instruction::Mul)
|
||||
return ConstantInt::get(V->getType(), 1);
|
||||
|
||||
// TODO: We can handle other cases e.g. Instruction::And, Instruction::Or etc.
|
||||
|
||||
return nullptr;
|
||||
return ConstantExpr::getBinOpIdentity(Opcode, V->getType());
|
||||
}
|
||||
|
||||
/// This function factors binary ops which can be combined using distributive
|
||||
|
|
Loading…
Reference in New Issue