mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-02-21 06:30:16 +00:00
Remove trailing whitespace
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@170990 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
037435d114
commit
8a8413d75c
@ -21,11 +21,11 @@
|
||||
using namespace llvm;
|
||||
using namespace llvm::PatternMatch;
|
||||
|
||||
/// ShrinkDemandedConstant - Check to see if the specified operand of the
|
||||
/// ShrinkDemandedConstant - Check to see if the specified operand of the
|
||||
/// specified instruction is a constant integer. If so, check to see if there
|
||||
/// are any bits set in the constant that are not demanded. If so, shrink the
|
||||
/// constant and return true.
|
||||
static bool ShrinkDemandedConstant(Instruction *I, unsigned OpNo,
|
||||
static bool ShrinkDemandedConstant(Instruction *I, unsigned OpNo,
|
||||
APInt Demanded) {
|
||||
assert(I && "No instruction?");
|
||||
assert(OpNo < I->getNumOperands() && "Operand index too large");
|
||||
@ -54,8 +54,8 @@ bool InstCombiner::SimplifyDemandedInstructionBits(Instruction &Inst) {
|
||||
unsigned BitWidth = Inst.getType()->getScalarSizeInBits();
|
||||
APInt KnownZero(BitWidth, 0), KnownOne(BitWidth, 0);
|
||||
APInt DemandedMask(APInt::getAllOnesValue(BitWidth));
|
||||
|
||||
Value *V = SimplifyDemandedUseBits(&Inst, DemandedMask,
|
||||
|
||||
Value *V = SimplifyDemandedUseBits(&Inst, DemandedMask,
|
||||
KnownZero, KnownOne, 0);
|
||||
if (V == 0) return false;
|
||||
if (V == &Inst) return true;
|
||||
@ -66,7 +66,7 @@ bool InstCombiner::SimplifyDemandedInstructionBits(Instruction &Inst) {
|
||||
/// SimplifyDemandedBits - This form of SimplifyDemandedBits simplifies the
|
||||
/// specified instruction operand if possible, updating it in place. It returns
|
||||
/// true if it made any change and false otherwise.
|
||||
bool InstCombiner::SimplifyDemandedBits(Use &U, APInt DemandedMask,
|
||||
bool InstCombiner::SimplifyDemandedBits(Use &U, APInt DemandedMask,
|
||||
APInt &KnownZero, APInt &KnownOne,
|
||||
unsigned Depth) {
|
||||
Value *NewVal = SimplifyDemandedUseBits(U.get(), DemandedMask,
|
||||
@ -87,7 +87,7 @@ bool InstCombiner::SimplifyDemandedBits(Use &U, APInt DemandedMask,
|
||||
/// to be one in the expression. KnownZero contains all the bits that are known
|
||||
/// to be zero in the expression. These are provided to potentially allow the
|
||||
/// caller (which might recursively be SimplifyDemandedBits itself) to simplify
|
||||
/// the expression. KnownOne and KnownZero always follow the invariant that
|
||||
/// the expression. KnownOne and KnownZero always follow the invariant that
|
||||
/// KnownOne & KnownZero == 0. That is, a bit can't be both 1 and 0. Note that
|
||||
/// the bits in KnownOne and KnownZero may only be accurate for those bits set
|
||||
/// in DemandedMask. Note also that the bitwidth of V, DemandedMask, KnownZero
|
||||
@ -134,10 +134,10 @@ Value *InstCombiner::SimplifyDemandedUseBits(Value *V, APInt DemandedMask,
|
||||
return 0;
|
||||
return UndefValue::get(VTy);
|
||||
}
|
||||
|
||||
|
||||
if (Depth == 6) // Limit search depth.
|
||||
return 0;
|
||||
|
||||
|
||||
APInt LHSKnownZero(BitWidth, 0), LHSKnownOne(BitWidth, 0);
|
||||
APInt RHSKnownZero(BitWidth, 0), RHSKnownOne(BitWidth, 0);
|
||||
|
||||
@ -159,56 +159,56 @@ Value *InstCombiner::SimplifyDemandedUseBits(Value *V, APInt DemandedMask,
|
||||
// If either the LHS or the RHS are Zero, the result is zero.
|
||||
ComputeMaskedBits(I->getOperand(1), RHSKnownZero, RHSKnownOne, Depth+1);
|
||||
ComputeMaskedBits(I->getOperand(0), LHSKnownZero, LHSKnownOne, Depth+1);
|
||||
|
||||
|
||||
// If all of the demanded bits are known 1 on one side, return the other.
|
||||
// These bits cannot contribute to the result of the 'and' in this
|
||||
// context.
|
||||
if ((DemandedMask & ~LHSKnownZero & RHSKnownOne) ==
|
||||
if ((DemandedMask & ~LHSKnownZero & RHSKnownOne) ==
|
||||
(DemandedMask & ~LHSKnownZero))
|
||||
return I->getOperand(0);
|
||||
if ((DemandedMask & ~RHSKnownZero & LHSKnownOne) ==
|
||||
if ((DemandedMask & ~RHSKnownZero & LHSKnownOne) ==
|
||||
(DemandedMask & ~RHSKnownZero))
|
||||
return I->getOperand(1);
|
||||
|
||||
|
||||
// If all of the demanded bits in the inputs are known zeros, return zero.
|
||||
if ((DemandedMask & (RHSKnownZero|LHSKnownZero)) == DemandedMask)
|
||||
return Constant::getNullValue(VTy);
|
||||
|
||||
|
||||
} else if (I->getOpcode() == Instruction::Or) {
|
||||
// We can simplify (X|Y) -> X or Y in the user's context if we know that
|
||||
// only bits from X or Y are demanded.
|
||||
|
||||
|
||||
// If either the LHS or the RHS are One, the result is One.
|
||||
ComputeMaskedBits(I->getOperand(1), RHSKnownZero, RHSKnownOne, Depth+1);
|
||||
ComputeMaskedBits(I->getOperand(0), LHSKnownZero, LHSKnownOne, Depth+1);
|
||||
|
||||
|
||||
// If all of the demanded bits are known zero on one side, return the
|
||||
// other. These bits cannot contribute to the result of the 'or' in this
|
||||
// context.
|
||||
if ((DemandedMask & ~LHSKnownOne & RHSKnownZero) ==
|
||||
if ((DemandedMask & ~LHSKnownOne & RHSKnownZero) ==
|
||||
(DemandedMask & ~LHSKnownOne))
|
||||
return I->getOperand(0);
|
||||
if ((DemandedMask & ~RHSKnownOne & LHSKnownZero) ==
|
||||
if ((DemandedMask & ~RHSKnownOne & LHSKnownZero) ==
|
||||
(DemandedMask & ~RHSKnownOne))
|
||||
return I->getOperand(1);
|
||||
|
||||
|
||||
// If all of the potentially set bits on one side are known to be set on
|
||||
// the other side, just use the 'other' side.
|
||||
if ((DemandedMask & (~RHSKnownZero) & LHSKnownOne) ==
|
||||
if ((DemandedMask & (~RHSKnownZero) & LHSKnownOne) ==
|
||||
(DemandedMask & (~RHSKnownZero)))
|
||||
return I->getOperand(0);
|
||||
if ((DemandedMask & (~LHSKnownZero) & RHSKnownOne) ==
|
||||
if ((DemandedMask & (~LHSKnownZero) & RHSKnownOne) ==
|
||||
(DemandedMask & (~LHSKnownZero)))
|
||||
return I->getOperand(1);
|
||||
} else if (I->getOpcode() == Instruction::Xor) {
|
||||
// We can simplify (X^Y) -> X or Y in the user's context if we know that
|
||||
// only bits from X or Y are demanded.
|
||||
|
||||
|
||||
ComputeMaskedBits(I->getOperand(1), RHSKnownZero, RHSKnownOne, Depth+1);
|
||||
ComputeMaskedBits(I->getOperand(0), LHSKnownZero, LHSKnownOne, Depth+1);
|
||||
|
||||
|
||||
// If all of the demanded bits are known zero on one side, return the
|
||||
// other.
|
||||
// other.
|
||||
if ((DemandedMask & RHSKnownZero) == DemandedMask)
|
||||
return I->getOperand(0);
|
||||
if ((DemandedMask & LHSKnownZero) == DemandedMask)
|
||||
@ -219,14 +219,14 @@ Value *InstCombiner::SimplifyDemandedUseBits(Value *V, APInt DemandedMask,
|
||||
ComputeMaskedBits(I, KnownZero, KnownOne, Depth);
|
||||
return 0;
|
||||
}
|
||||
|
||||
|
||||
// If this is the root being simplified, allow it to have multiple uses,
|
||||
// just set the DemandedMask to all bits so that we can try to simplify the
|
||||
// operands. This allows visitTruncInst (for example) to simplify the
|
||||
// operand of a trunc without duplicating all the logic below.
|
||||
if (Depth == 0 && !V->hasOneUse())
|
||||
DemandedMask = APInt::getAllOnesValue(BitWidth);
|
||||
|
||||
|
||||
switch (I->getOpcode()) {
|
||||
default:
|
||||
ComputeMaskedBits(I, KnownZero, KnownOne, Depth);
|
||||
@ -238,26 +238,26 @@ Value *InstCombiner::SimplifyDemandedUseBits(Value *V, APInt DemandedMask,
|
||||
SimplifyDemandedBits(I->getOperandUse(0), DemandedMask & ~RHSKnownZero,
|
||||
LHSKnownZero, LHSKnownOne, Depth+1))
|
||||
return I;
|
||||
assert(!(RHSKnownZero & RHSKnownOne) && "Bits known to be one AND zero?");
|
||||
assert(!(LHSKnownZero & LHSKnownOne) && "Bits known to be one AND zero?");
|
||||
assert(!(RHSKnownZero & RHSKnownOne) && "Bits known to be one AND zero?");
|
||||
assert(!(LHSKnownZero & LHSKnownOne) && "Bits known to be one AND zero?");
|
||||
|
||||
// If all of the demanded bits are known 1 on one side, return the other.
|
||||
// These bits cannot contribute to the result of the 'and'.
|
||||
if ((DemandedMask & ~LHSKnownZero & RHSKnownOne) ==
|
||||
if ((DemandedMask & ~LHSKnownZero & RHSKnownOne) ==
|
||||
(DemandedMask & ~LHSKnownZero))
|
||||
return I->getOperand(0);
|
||||
if ((DemandedMask & ~RHSKnownZero & LHSKnownOne) ==
|
||||
if ((DemandedMask & ~RHSKnownZero & LHSKnownOne) ==
|
||||
(DemandedMask & ~RHSKnownZero))
|
||||
return I->getOperand(1);
|
||||
|
||||
|
||||
// If all of the demanded bits in the inputs are known zeros, return zero.
|
||||
if ((DemandedMask & (RHSKnownZero|LHSKnownZero)) == DemandedMask)
|
||||
return Constant::getNullValue(VTy);
|
||||
|
||||
|
||||
// If the RHS is a constant, see if we can simplify it.
|
||||
if (ShrinkDemandedConstant(I, 1, DemandedMask & ~LHSKnownZero))
|
||||
return I;
|
||||
|
||||
|
||||
// Output known-1 bits are only known if set in both the LHS & RHS.
|
||||
KnownOne = RHSKnownOne & LHSKnownOne;
|
||||
// Output known-0 are known to be clear if zero in either the LHS | RHS.
|
||||
@ -265,36 +265,36 @@ Value *InstCombiner::SimplifyDemandedUseBits(Value *V, APInt DemandedMask,
|
||||
break;
|
||||
case Instruction::Or:
|
||||
// If either the LHS or the RHS are One, the result is One.
|
||||
if (SimplifyDemandedBits(I->getOperandUse(1), DemandedMask,
|
||||
if (SimplifyDemandedBits(I->getOperandUse(1), DemandedMask,
|
||||
RHSKnownZero, RHSKnownOne, Depth+1) ||
|
||||
SimplifyDemandedBits(I->getOperandUse(0), DemandedMask & ~RHSKnownOne,
|
||||
SimplifyDemandedBits(I->getOperandUse(0), DemandedMask & ~RHSKnownOne,
|
||||
LHSKnownZero, LHSKnownOne, Depth+1))
|
||||
return I;
|
||||
assert(!(RHSKnownZero & RHSKnownOne) && "Bits known to be one AND zero?");
|
||||
assert(!(LHSKnownZero & LHSKnownOne) && "Bits known to be one AND zero?");
|
||||
|
||||
assert(!(RHSKnownZero & RHSKnownOne) && "Bits known to be one AND zero?");
|
||||
assert(!(LHSKnownZero & LHSKnownOne) && "Bits known to be one AND zero?");
|
||||
|
||||
// If all of the demanded bits are known zero on one side, return the other.
|
||||
// These bits cannot contribute to the result of the 'or'.
|
||||
if ((DemandedMask & ~LHSKnownOne & RHSKnownZero) ==
|
||||
if ((DemandedMask & ~LHSKnownOne & RHSKnownZero) ==
|
||||
(DemandedMask & ~LHSKnownOne))
|
||||
return I->getOperand(0);
|
||||
if ((DemandedMask & ~RHSKnownOne & LHSKnownZero) ==
|
||||
if ((DemandedMask & ~RHSKnownOne & LHSKnownZero) ==
|
||||
(DemandedMask & ~RHSKnownOne))
|
||||
return I->getOperand(1);
|
||||
|
||||
// If all of the potentially set bits on one side are known to be set on
|
||||
// the other side, just use the 'other' side.
|
||||
if ((DemandedMask & (~RHSKnownZero) & LHSKnownOne) ==
|
||||
if ((DemandedMask & (~RHSKnownZero) & LHSKnownOne) ==
|
||||
(DemandedMask & (~RHSKnownZero)))
|
||||
return I->getOperand(0);
|
||||
if ((DemandedMask & (~LHSKnownZero) & RHSKnownOne) ==
|
||||
if ((DemandedMask & (~LHSKnownZero) & RHSKnownOne) ==
|
||||
(DemandedMask & (~LHSKnownZero)))
|
||||
return I->getOperand(1);
|
||||
|
||||
|
||||
// If the RHS is a constant, see if we can simplify it.
|
||||
if (ShrinkDemandedConstant(I, 1, DemandedMask))
|
||||
return I;
|
||||
|
||||
|
||||
// Output known-0 bits are only known if clear in both the LHS & RHS.
|
||||
KnownZero = RHSKnownZero & LHSKnownZero;
|
||||
// Output known-1 are known to be set if set in either the LHS | RHS.
|
||||
@ -303,34 +303,34 @@ Value *InstCombiner::SimplifyDemandedUseBits(Value *V, APInt DemandedMask,
|
||||
case Instruction::Xor: {
|
||||
if (SimplifyDemandedBits(I->getOperandUse(1), DemandedMask,
|
||||
RHSKnownZero, RHSKnownOne, Depth+1) ||
|
||||
SimplifyDemandedBits(I->getOperandUse(0), DemandedMask,
|
||||
SimplifyDemandedBits(I->getOperandUse(0), DemandedMask,
|
||||
LHSKnownZero, LHSKnownOne, Depth+1))
|
||||
return I;
|
||||
assert(!(RHSKnownZero & RHSKnownOne) && "Bits known to be one AND zero?");
|
||||
assert(!(LHSKnownZero & LHSKnownOne) && "Bits known to be one AND zero?");
|
||||
|
||||
assert(!(RHSKnownZero & RHSKnownOne) && "Bits known to be one AND zero?");
|
||||
assert(!(LHSKnownZero & LHSKnownOne) && "Bits known to be one AND zero?");
|
||||
|
||||
// If all of the demanded bits are known zero on one side, return the other.
|
||||
// These bits cannot contribute to the result of the 'xor'.
|
||||
if ((DemandedMask & RHSKnownZero) == DemandedMask)
|
||||
return I->getOperand(0);
|
||||
if ((DemandedMask & LHSKnownZero) == DemandedMask)
|
||||
return I->getOperand(1);
|
||||
|
||||
|
||||
// If all of the demanded bits are known to be zero on one side or the
|
||||
// other, turn this into an *inclusive* or.
|
||||
// e.g. (A & C1)^(B & C2) -> (A & C1)|(B & C2) iff C1&C2 == 0
|
||||
if ((DemandedMask & ~RHSKnownZero & ~LHSKnownZero) == 0) {
|
||||
Instruction *Or =
|
||||
Instruction *Or =
|
||||
BinaryOperator::CreateOr(I->getOperand(0), I->getOperand(1),
|
||||
I->getName());
|
||||
return InsertNewInstWith(Or, *I);
|
||||
}
|
||||
|
||||
|
||||
// If all of the demanded bits on one side are known, and all of the set
|
||||
// bits on that side are also known to be set on the other side, turn this
|
||||
// into an AND, as we know the bits will be cleared.
|
||||
// e.g. (X | C1) ^ C2 --> (X | C1) & ~C2 iff (C1&C2) == C2
|
||||
if ((DemandedMask & (RHSKnownZero|RHSKnownOne)) == DemandedMask) {
|
||||
if ((DemandedMask & (RHSKnownZero|RHSKnownOne)) == DemandedMask) {
|
||||
// all known
|
||||
if ((RHSKnownOne & LHSKnownOne) == RHSKnownOne) {
|
||||
Constant *AndC = Constant::getIntegerValue(VTy,
|
||||
@ -339,12 +339,12 @@ Value *InstCombiner::SimplifyDemandedUseBits(Value *V, APInt DemandedMask,
|
||||
return InsertNewInstWith(And, *I);
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
// If the RHS is a constant, see if we can simplify it.
|
||||
// FIXME: for XOR, we prefer to force bits to 1 if they will make a -1.
|
||||
if (ShrinkDemandedConstant(I, 1, DemandedMask))
|
||||
return I;
|
||||
|
||||
|
||||
// If our LHS is an 'and' and if it has one use, and if any of the bits we
|
||||
// are flipping are known to be set, then the xor is just resetting those
|
||||
// bits to zero. We can just knock out bits from the 'and' and the 'xor',
|
||||
@ -357,12 +357,12 @@ Value *InstCombiner::SimplifyDemandedUseBits(Value *V, APInt DemandedMask,
|
||||
ConstantInt *AndRHS = cast<ConstantInt>(LHSInst->getOperand(1));
|
||||
ConstantInt *XorRHS = cast<ConstantInt>(I->getOperand(1));
|
||||
APInt NewMask = ~(LHSKnownOne & RHSKnownOne & DemandedMask);
|
||||
|
||||
|
||||
Constant *AndC =
|
||||
ConstantInt::get(I->getType(), NewMask & AndRHS->getValue());
|
||||
Instruction *NewAnd = BinaryOperator::CreateAnd(I->getOperand(0), AndC);
|
||||
InsertNewInstWith(NewAnd, *I);
|
||||
|
||||
|
||||
Constant *XorC =
|
||||
ConstantInt::get(I->getType(), NewMask & XorRHS->getValue());
|
||||
Instruction *NewXor = BinaryOperator::CreateXor(NewAnd, XorC);
|
||||
@ -378,17 +378,17 @@ Value *InstCombiner::SimplifyDemandedUseBits(Value *V, APInt DemandedMask,
|
||||
case Instruction::Select:
|
||||
if (SimplifyDemandedBits(I->getOperandUse(2), DemandedMask,
|
||||
RHSKnownZero, RHSKnownOne, Depth+1) ||
|
||||
SimplifyDemandedBits(I->getOperandUse(1), DemandedMask,
|
||||
SimplifyDemandedBits(I->getOperandUse(1), DemandedMask,
|
||||
LHSKnownZero, LHSKnownOne, Depth+1))
|
||||
return I;
|
||||
assert(!(RHSKnownZero & RHSKnownOne) && "Bits known to be one AND zero?");
|
||||
assert(!(LHSKnownZero & LHSKnownOne) && "Bits known to be one AND zero?");
|
||||
|
||||
assert(!(RHSKnownZero & RHSKnownOne) && "Bits known to be one AND zero?");
|
||||
assert(!(LHSKnownZero & LHSKnownOne) && "Bits known to be one AND zero?");
|
||||
|
||||
// If the operands are constants, see if we can simplify them.
|
||||
if (ShrinkDemandedConstant(I, 1, DemandedMask) ||
|
||||
ShrinkDemandedConstant(I, 2, DemandedMask))
|
||||
return I;
|
||||
|
||||
|
||||
// Only known if known in both the LHS and RHS.
|
||||
KnownOne = RHSKnownOne & LHSKnownOne;
|
||||
KnownZero = RHSKnownZero & LHSKnownZero;
|
||||
@ -398,13 +398,13 @@ Value *InstCombiner::SimplifyDemandedUseBits(Value *V, APInt DemandedMask,
|
||||
DemandedMask = DemandedMask.zext(truncBf);
|
||||
KnownZero = KnownZero.zext(truncBf);
|
||||
KnownOne = KnownOne.zext(truncBf);
|
||||
if (SimplifyDemandedBits(I->getOperandUse(0), DemandedMask,
|
||||
if (SimplifyDemandedBits(I->getOperandUse(0), DemandedMask,
|
||||
KnownZero, KnownOne, Depth+1))
|
||||
return I;
|
||||
DemandedMask = DemandedMask.trunc(BitWidth);
|
||||
KnownZero = KnownZero.trunc(BitWidth);
|
||||
KnownOne = KnownOne.trunc(BitWidth);
|
||||
assert(!(KnownZero & KnownOne) && "Bits known to be one AND zero?");
|
||||
assert(!(KnownZero & KnownOne) && "Bits known to be one AND zero?");
|
||||
break;
|
||||
}
|
||||
case Instruction::BitCast:
|
||||
@ -427,12 +427,12 @@ Value *InstCombiner::SimplifyDemandedUseBits(Value *V, APInt DemandedMask,
|
||||
if (SimplifyDemandedBits(I->getOperandUse(0), DemandedMask,
|
||||
KnownZero, KnownOne, Depth+1))
|
||||
return I;
|
||||
assert(!(KnownZero & KnownOne) && "Bits known to be one AND zero?");
|
||||
assert(!(KnownZero & KnownOne) && "Bits known to be one AND zero?");
|
||||
break;
|
||||
case Instruction::ZExt: {
|
||||
// Compute the bits in the result that are not present in the input.
|
||||
unsigned SrcBitWidth =I->getOperand(0)->getType()->getScalarSizeInBits();
|
||||
|
||||
|
||||
DemandedMask = DemandedMask.trunc(SrcBitWidth);
|
||||
KnownZero = KnownZero.trunc(SrcBitWidth);
|
||||
KnownOne = KnownOne.trunc(SrcBitWidth);
|
||||
@ -442,7 +442,7 @@ Value *InstCombiner::SimplifyDemandedUseBits(Value *V, APInt DemandedMask,
|
||||
DemandedMask = DemandedMask.zext(BitWidth);
|
||||
KnownZero = KnownZero.zext(BitWidth);
|
||||
KnownOne = KnownOne.zext(BitWidth);
|
||||
assert(!(KnownZero & KnownOne) && "Bits known to be one AND zero?");
|
||||
assert(!(KnownZero & KnownOne) && "Bits known to be one AND zero?");
|
||||
// The top bits are known to be zero.
|
||||
KnownZero |= APInt::getHighBitsSet(BitWidth, BitWidth - SrcBitWidth);
|
||||
break;
|
||||
@ -450,8 +450,8 @@ Value *InstCombiner::SimplifyDemandedUseBits(Value *V, APInt DemandedMask,
|
||||
case Instruction::SExt: {
|
||||
// Compute the bits in the result that are not present in the input.
|
||||
unsigned SrcBitWidth =I->getOperand(0)->getType()->getScalarSizeInBits();
|
||||
|
||||
APInt InputDemandedBits = DemandedMask &
|
||||
|
||||
APInt InputDemandedBits = DemandedMask &
|
||||
APInt::getLowBitsSet(BitWidth, SrcBitWidth);
|
||||
|
||||
APInt NewBits(APInt::getHighBitsSet(BitWidth, BitWidth - SrcBitWidth));
|
||||
@ -459,7 +459,7 @@ Value *InstCombiner::SimplifyDemandedUseBits(Value *V, APInt DemandedMask,
|
||||
// bit is demanded.
|
||||
if ((NewBits & DemandedMask) != 0)
|
||||
InputDemandedBits.setBit(SrcBitWidth-1);
|
||||
|
||||
|
||||
InputDemandedBits = InputDemandedBits.trunc(SrcBitWidth);
|
||||
KnownZero = KnownZero.trunc(SrcBitWidth);
|
||||
KnownOne = KnownOne.trunc(SrcBitWidth);
|
||||
@ -469,8 +469,8 @@ Value *InstCombiner::SimplifyDemandedUseBits(Value *V, APInt DemandedMask,
|
||||
InputDemandedBits = InputDemandedBits.zext(BitWidth);
|
||||
KnownZero = KnownZero.zext(BitWidth);
|
||||
KnownOne = KnownOne.zext(BitWidth);
|
||||
assert(!(KnownZero & KnownOne) && "Bits known to be one AND zero?");
|
||||
|
||||
assert(!(KnownZero & KnownOne) && "Bits known to be one AND zero?");
|
||||
|
||||
// If the sign bit of the input is known set or clear, then we know the
|
||||
// top bits of the result.
|
||||
|
||||
@ -490,7 +490,7 @@ Value *InstCombiner::SimplifyDemandedUseBits(Value *V, APInt DemandedMask,
|
||||
// are not demanded, then the add doesn't demand them from its input
|
||||
// either.
|
||||
unsigned NLZ = DemandedMask.countLeadingZeros();
|
||||
|
||||
|
||||
// If there is a constant on the RHS, there are a variety of xformations
|
||||
// we can do.
|
||||
if (ConstantInt *RHS = dyn_cast<ConstantInt>(I->getOperand(1))) {
|
||||
@ -498,13 +498,13 @@ Value *InstCombiner::SimplifyDemandedUseBits(Value *V, APInt DemandedMask,
|
||||
// won't work if the RHS is zero.
|
||||
if (RHS->isZero())
|
||||
break;
|
||||
|
||||
|
||||
// If the top bit of the output is demanded, demand everything from the
|
||||
// input. Otherwise, we demand all the input bits except NLZ top bits.
|
||||
APInt InDemandedBits(APInt::getLowBitsSet(BitWidth, BitWidth - NLZ));
|
||||
|
||||
// Find information about known zero/one bits in the input.
|
||||
if (SimplifyDemandedBits(I->getOperandUse(0), InDemandedBits,
|
||||
if (SimplifyDemandedBits(I->getOperandUse(0), InDemandedBits,
|
||||
LHSKnownZero, LHSKnownOne, Depth+1))
|
||||
return I;
|
||||
|
||||
@ -512,11 +512,11 @@ Value *InstCombiner::SimplifyDemandedUseBits(Value *V, APInt DemandedMask,
|
||||
// the constant.
|
||||
if (ShrinkDemandedConstant(I, 1, InDemandedBits))
|
||||
return I;
|
||||
|
||||
|
||||
// Avoid excess work.
|
||||
if (LHSKnownZero == 0 && LHSKnownOne == 0)
|
||||
break;
|
||||
|
||||
|
||||
// Turn it into OR if input bits are zero.
|
||||
if ((LHSKnownZero & RHS->getValue()) == RHS->getValue()) {
|
||||
Instruction *Or =
|
||||
@ -524,26 +524,26 @@ Value *InstCombiner::SimplifyDemandedUseBits(Value *V, APInt DemandedMask,
|
||||
I->getName());
|
||||
return InsertNewInstWith(Or, *I);
|
||||
}
|
||||
|
||||
|
||||
// We can say something about the output known-zero and known-one bits,
|
||||
// depending on potential carries from the input constant and the
|
||||
// unknowns. For example if the LHS is known to have at most the 0x0F0F0
|
||||
// bits set and the RHS constant is 0x01001, then we know we have a known
|
||||
// one mask of 0x00001 and a known zero mask of 0xE0F0E.
|
||||
|
||||
|
||||
// To compute this, we first compute the potential carry bits. These are
|
||||
// the bits which may be modified. I'm not aware of a better way to do
|
||||
// this scan.
|
||||
const APInt &RHSVal = RHS->getValue();
|
||||
APInt CarryBits((~LHSKnownZero + RHSVal) ^ (~LHSKnownZero ^ RHSVal));
|
||||
|
||||
|
||||
// Now that we know which bits have carries, compute the known-1/0 sets.
|
||||
|
||||
|
||||
// Bits are known one if they are known zero in one operand and one in the
|
||||
// other, and there is no input carry.
|
||||
KnownOne = ((LHSKnownZero & RHSVal) |
|
||||
KnownOne = ((LHSKnownZero & RHSVal) |
|
||||
(LHSKnownOne & ~RHSVal)) & ~CarryBits;
|
||||
|
||||
|
||||
// Bits are known zero if they are known zero in both operands and there
|
||||
// is no input carry.
|
||||
KnownZero = LHSKnownZero & ~RHSVal & ~CarryBits;
|
||||
@ -607,15 +607,15 @@ Value *InstCombiner::SimplifyDemandedUseBits(Value *V, APInt DemandedMask,
|
||||
|
||||
uint64_t ShiftAmt = SA->getLimitedValue(BitWidth-1);
|
||||
APInt DemandedMaskIn(DemandedMask.lshr(ShiftAmt));
|
||||
|
||||
|
||||
// If the shift is NUW/NSW, then it does demand the high bits.
|
||||
ShlOperator *IOp = cast<ShlOperator>(I);
|
||||
if (IOp->hasNoSignedWrap())
|
||||
DemandedMaskIn |= APInt::getHighBitsSet(BitWidth, ShiftAmt+1);
|
||||
else if (IOp->hasNoUnsignedWrap())
|
||||
DemandedMaskIn |= APInt::getHighBitsSet(BitWidth, ShiftAmt);
|
||||
|
||||
if (SimplifyDemandedBits(I->getOperandUse(0), DemandedMaskIn,
|
||||
|
||||
if (SimplifyDemandedBits(I->getOperandUse(0), DemandedMaskIn,
|
||||
KnownZero, KnownOne, Depth+1))
|
||||
return I;
|
||||
assert(!(KnownZero & KnownOne) && "Bits known to be one AND zero?");
|
||||
@ -630,15 +630,15 @@ Value *InstCombiner::SimplifyDemandedUseBits(Value *V, APInt DemandedMask,
|
||||
// For a logical shift right
|
||||
if (ConstantInt *SA = dyn_cast<ConstantInt>(I->getOperand(1))) {
|
||||
uint64_t ShiftAmt = SA->getLimitedValue(BitWidth-1);
|
||||
|
||||
|
||||
// Unsigned shift right.
|
||||
APInt DemandedMaskIn(DemandedMask.shl(ShiftAmt));
|
||||
|
||||
|
||||
// If the shift is exact, then it does demand the low bits (and knows that
|
||||
// they are zero).
|
||||
if (cast<LShrOperator>(I)->isExact())
|
||||
DemandedMaskIn |= APInt::getLowBitsSet(BitWidth, ShiftAmt);
|
||||
|
||||
|
||||
if (SimplifyDemandedBits(I->getOperandUse(0), DemandedMaskIn,
|
||||
KnownZero, KnownOne, Depth+1))
|
||||
return I;
|
||||
@ -662,28 +662,28 @@ Value *InstCombiner::SimplifyDemandedUseBits(Value *V, APInt DemandedMask,
|
||||
Instruction *NewVal = BinaryOperator::CreateLShr(
|
||||
I->getOperand(0), I->getOperand(1), I->getName());
|
||||
return InsertNewInstWith(NewVal, *I);
|
||||
}
|
||||
}
|
||||
|
||||
// If the sign bit is the only bit demanded by this ashr, then there is no
|
||||
// need to do it, the shift doesn't change the high bit.
|
||||
if (DemandedMask.isSignBit())
|
||||
return I->getOperand(0);
|
||||
|
||||
|
||||
if (ConstantInt *SA = dyn_cast<ConstantInt>(I->getOperand(1))) {
|
||||
uint32_t ShiftAmt = SA->getLimitedValue(BitWidth-1);
|
||||
|
||||
|
||||
// Signed shift right.
|
||||
APInt DemandedMaskIn(DemandedMask.shl(ShiftAmt));
|
||||
// If any of the "high bits" are demanded, we should set the sign bit as
|
||||
// demanded.
|
||||
if (DemandedMask.countLeadingZeros() <= ShiftAmt)
|
||||
DemandedMaskIn.setBit(BitWidth-1);
|
||||
|
||||
|
||||
// If the shift is exact, then it does demand the low bits (and knows that
|
||||
// they are zero).
|
||||
if (cast<AShrOperator>(I)->isExact())
|
||||
DemandedMaskIn |= APInt::getLowBitsSet(BitWidth, ShiftAmt);
|
||||
|
||||
|
||||
if (SimplifyDemandedBits(I->getOperandUse(0), DemandedMaskIn,
|
||||
KnownZero, KnownOne, Depth+1))
|
||||
return I;
|
||||
@ -692,15 +692,15 @@ Value *InstCombiner::SimplifyDemandedUseBits(Value *V, APInt DemandedMask,
|
||||
APInt HighBits(APInt::getHighBitsSet(BitWidth, ShiftAmt));
|
||||
KnownZero = APIntOps::lshr(KnownZero, ShiftAmt);
|
||||
KnownOne = APIntOps::lshr(KnownOne, ShiftAmt);
|
||||
|
||||
|
||||
// Handle the sign bits.
|
||||
APInt SignBit(APInt::getSignBit(BitWidth));
|
||||
// Adjust to where it is now in the mask.
|
||||
SignBit = APIntOps::lshr(SignBit, ShiftAmt);
|
||||
|
||||
SignBit = APIntOps::lshr(SignBit, ShiftAmt);
|
||||
|
||||
// If the input sign bit is known to be zero, or if none of the top bits
|
||||
// are demanded, turn this into an unsigned shift right.
|
||||
if (BitWidth <= ShiftAmt || KnownZero[BitWidth-ShiftAmt-1] ||
|
||||
if (BitWidth <= ShiftAmt || KnownZero[BitWidth-ShiftAmt-1] ||
|
||||
(HighBits & ~DemandedMask) == HighBits) {
|
||||
// Perform the logical shift right.
|
||||
BinaryOperator *NewVal = BinaryOperator::CreateLShr(I->getOperand(0),
|
||||
@ -743,7 +743,7 @@ Value *InstCombiner::SimplifyDemandedUseBits(Value *V, APInt DemandedMask,
|
||||
if (LHSKnownOne[BitWidth-1] && ((LHSKnownOne & LowBits) != 0))
|
||||
KnownOne |= ~LowBits;
|
||||
|
||||
assert(!(KnownZero & KnownOne) && "Bits known to be one AND zero?");
|
||||
assert(!(KnownZero & KnownOne) && "Bits known to be one AND zero?");
|
||||
}
|
||||
}
|
||||
|
||||
@ -781,7 +781,7 @@ Value *InstCombiner::SimplifyDemandedUseBits(Value *V, APInt DemandedMask,
|
||||
// just shift the input byte into position to eliminate the bswap.
|
||||
unsigned NLZ = DemandedMask.countLeadingZeros();
|
||||
unsigned NTZ = DemandedMask.countTrailingZeros();
|
||||
|
||||
|
||||
// Round NTZ down to the next byte. If we have 11 trailing zeros, then
|
||||
// we need all the bits down to bit 8. Likewise, round NLZ. If we
|
||||
// have 14 leading zeros, round to 8.
|
||||
@ -791,7 +791,7 @@ Value *InstCombiner::SimplifyDemandedUseBits(Value *V, APInt DemandedMask,
|
||||
if (BitWidth-NLZ-NTZ == 8) {
|
||||
unsigned ResultBit = NTZ;
|
||||
unsigned InputBit = BitWidth-NTZ-8;
|
||||
|
||||
|
||||
// Replace this with either a left or right shift to get the byte into
|
||||
// the right place.
|
||||
Instruction *NewVal;
|
||||
@ -804,7 +804,7 @@ Value *InstCombiner::SimplifyDemandedUseBits(Value *V, APInt DemandedMask,
|
||||
NewVal->takeName(I);
|
||||
return InsertNewInstWith(NewVal, *I);
|
||||
}
|
||||
|
||||
|
||||
// TODO: Could compute known zero/one bits based on the input.
|
||||
break;
|
||||
}
|
||||
@ -817,7 +817,7 @@ Value *InstCombiner::SimplifyDemandedUseBits(Value *V, APInt DemandedMask,
|
||||
ComputeMaskedBits(V, KnownZero, KnownOne, Depth);
|
||||
break;
|
||||
}
|
||||
|
||||
|
||||
// If the client is only demanding bits that we know, return the known
|
||||
// constant.
|
||||
if ((DemandedMask & (KnownZero|KnownOne)) == DemandedMask)
|
||||
@ -921,14 +921,14 @@ Value *InstCombiner::SimplifyDemandedVectorElts(Value *V, APInt DemandedElts,
|
||||
UndefElts = EltMask;
|
||||
return 0;
|
||||
}
|
||||
|
||||
|
||||
if (DemandedElts == 0) { // If nothing is demanded, provide undef.
|
||||
UndefElts = EltMask;
|
||||
return UndefValue::get(V->getType());
|
||||
}
|
||||
|
||||
UndefElts = 0;
|
||||
|
||||
|
||||
// Handle ConstantAggregateZero, ConstantVector, ConstantDataSequential.
|
||||
if (Constant *C = dyn_cast<Constant>(V)) {
|
||||
// Check if this is identity. If so, return 0 since we are not simplifying
|
||||
@ -938,7 +938,7 @@ Value *InstCombiner::SimplifyDemandedVectorElts(Value *V, APInt DemandedElts,
|
||||
|
||||
Type *EltTy = cast<VectorType>(V->getType())->getElementType();
|
||||
Constant *Undef = UndefValue::get(EltTy);
|
||||
|
||||
|
||||
SmallVector<Constant*, 16> Elts;
|
||||
for (unsigned i = 0; i != VWidth; ++i) {
|
||||
if (!DemandedElts[i]) { // If not demanded, set to undef.
|
||||
@ -946,10 +946,10 @@ Value *InstCombiner::SimplifyDemandedVectorElts(Value *V, APInt DemandedElts,
|
||||
UndefElts.setBit(i);
|
||||
continue;
|
||||
}
|
||||
|
||||
|
||||
Constant *Elt = C->getAggregateElement(i);
|
||||
if (Elt == 0) return 0;
|
||||
|
||||
|
||||
if (isa<UndefValue>(Elt)) { // Already undef.
|
||||
Elts.push_back(Undef);
|
||||
UndefElts.setBit(i);
|
||||
@ -957,12 +957,12 @@ Value *InstCombiner::SimplifyDemandedVectorElts(Value *V, APInt DemandedElts,
|
||||
Elts.push_back(Elt);
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
// If we changed the constant, return it.
|
||||
Constant *NewCV = ConstantVector::get(Elts);
|
||||
return NewCV != C ? NewCV : 0;
|
||||
}
|
||||
|
||||
|
||||
// Limit search depth.
|
||||
if (Depth == 10)
|
||||
return 0;
|
||||
@ -981,16 +981,16 @@ Value *InstCombiner::SimplifyDemandedVectorElts(Value *V, APInt DemandedElts,
|
||||
// Conservatively assume that all elements are needed.
|
||||
DemandedElts = EltMask;
|
||||
}
|
||||
|
||||
|
||||
Instruction *I = dyn_cast<Instruction>(V);
|
||||
if (!I) return 0; // Only analyze instructions.
|
||||
|
||||
|
||||
bool MadeChange = false;
|
||||
APInt UndefElts2(VWidth, 0);
|
||||
Value *TmpV;
|
||||
switch (I->getOpcode()) {
|
||||
default: break;
|
||||
|
||||
|
||||
case Instruction::InsertElement: {
|
||||
// If this is a variable index, we don't know which element it overwrites.
|
||||
// demand exactly the same input as we produce.
|
||||
@ -1003,7 +1003,7 @@ Value *InstCombiner::SimplifyDemandedVectorElts(Value *V, APInt DemandedElts,
|
||||
if (TmpV) { I->setOperand(0, TmpV); MadeChange = true; }
|
||||
break;
|
||||
}
|
||||
|
||||
|
||||
// If this is inserting an element that isn't demanded, remove this
|
||||
// insertelement.
|
||||
unsigned IdxNo = Idx->getZExtValue();
|
||||
@ -1011,7 +1011,7 @@ Value *InstCombiner::SimplifyDemandedVectorElts(Value *V, APInt DemandedElts,
|
||||
Worklist.Add(I);
|
||||
return I->getOperand(0);
|
||||
}
|
||||
|
||||
|
||||
// Otherwise, the element inserted overwrites whatever was there, so the
|
||||
// input demanded set is simpler than the output set.
|
||||
APInt DemandedElts2 = DemandedElts;
|
||||
@ -1107,7 +1107,7 @@ Value *InstCombiner::SimplifyDemandedVectorElts(Value *V, APInt DemandedElts,
|
||||
TmpV = SimplifyDemandedVectorElts(I->getOperand(2), RightDemanded,
|
||||
UndefElts2, Depth+1);
|
||||
if (TmpV) { I->setOperand(2, TmpV); MadeChange = true; }
|
||||
|
||||
|
||||
// Output elements are undefined if both are undefined.
|
||||
UndefElts &= UndefElts2;
|
||||
break;
|
||||
@ -1128,7 +1128,7 @@ Value *InstCombiner::SimplifyDemandedVectorElts(Value *V, APInt DemandedElts,
|
||||
} else if (VWidth > InVWidth) {
|
||||
// Untested so far.
|
||||
break;
|
||||
|
||||
|
||||
// If there are more elements in the result than there are in the source,
|
||||
// then an input element is live if any of the corresponding output
|
||||
// elements are live.
|
||||
@ -1140,7 +1140,7 @@ Value *InstCombiner::SimplifyDemandedVectorElts(Value *V, APInt DemandedElts,
|
||||
} else {
|
||||
// Untested so far.
|
||||
break;
|
||||
|
||||
|
||||
// If there are more elements in the source than there are in the result,
|
||||
// then an input element is live if the corresponding output element is
|
||||
// live.
|
||||
@ -1149,7 +1149,7 @@ Value *InstCombiner::SimplifyDemandedVectorElts(Value *V, APInt DemandedElts,
|
||||
if (DemandedElts[InIdx/Ratio])
|
||||
InputDemandedElts.setBit(InIdx);
|
||||
}
|
||||
|
||||
|
||||
// div/rem demand all inputs, because they don't want divide by zero.
|
||||
TmpV = SimplifyDemandedVectorElts(I->getOperand(0), InputDemandedElts,
|
||||
UndefElts2, Depth+1);
|
||||
@ -1157,7 +1157,7 @@ Value *InstCombiner::SimplifyDemandedVectorElts(Value *V, APInt DemandedElts,
|
||||
I->setOperand(0, TmpV);
|
||||
MadeChange = true;
|
||||
}
|
||||
|
||||
|
||||
UndefElts = UndefElts2;
|
||||
if (VWidth > InVWidth) {
|
||||
llvm_unreachable("Unimp");
|
||||
@ -1192,7 +1192,7 @@ Value *InstCombiner::SimplifyDemandedVectorElts(Value *V, APInt DemandedElts,
|
||||
TmpV = SimplifyDemandedVectorElts(I->getOperand(1), DemandedElts,
|
||||
UndefElts2, Depth+1);
|
||||
if (TmpV) { I->setOperand(1, TmpV); MadeChange = true; }
|
||||
|
||||
|
||||
// Output elements are undefined if both are undefined. Consider things
|
||||
// like undef&0. The result is known zero, not undef.
|
||||
UndefElts &= UndefElts2;
|
||||
@ -1203,13 +1203,13 @@ Value *InstCombiner::SimplifyDemandedVectorElts(Value *V, APInt DemandedElts,
|
||||
UndefElts, Depth+1);
|
||||
if (TmpV) { I->setOperand(0, TmpV); MadeChange = true; }
|
||||
break;
|
||||
|
||||
|
||||
case Instruction::Call: {
|
||||
IntrinsicInst *II = dyn_cast<IntrinsicInst>(I);
|
||||
if (!II) break;
|
||||
switch (II->getIntrinsicID()) {
|
||||
default: break;
|
||||
|
||||
|
||||
// Binary vector operations that work column-wise. A dest element is a
|
||||
// function of the corresponding input elements from the two inputs.
|
||||
case Intrinsic::x86_sse_sub_ss:
|
||||
@ -1240,11 +1240,11 @@ Value *InstCombiner::SimplifyDemandedVectorElts(Value *V, APInt DemandedElts,
|
||||
Value *LHS = II->getArgOperand(0);
|
||||
Value *RHS = II->getArgOperand(1);
|
||||
// Extract the element as scalars.
|
||||
LHS = InsertNewInstWith(ExtractElementInst::Create(LHS,
|
||||
LHS = InsertNewInstWith(ExtractElementInst::Create(LHS,
|
||||
ConstantInt::get(Type::getInt32Ty(I->getContext()), 0U)), *II);
|
||||
RHS = InsertNewInstWith(ExtractElementInst::Create(RHS,
|
||||
ConstantInt::get(Type::getInt32Ty(I->getContext()), 0U)), *II);
|
||||
|
||||
|
||||
switch (II->getIntrinsicID()) {
|
||||
default: llvm_unreachable("Case stmts out of sync!");
|
||||
case Intrinsic::x86_sse_sub_ss:
|
||||
@ -1258,7 +1258,7 @@ Value *InstCombiner::SimplifyDemandedVectorElts(Value *V, APInt DemandedElts,
|
||||
II->getName()), *II);
|
||||
break;
|
||||
}
|
||||
|
||||
|
||||
Instruction *New =
|
||||
InsertElementInst::Create(
|
||||
UndefValue::get(II->getType()), TmpV,
|
||||
@ -1266,9 +1266,9 @@ Value *InstCombiner::SimplifyDemandedVectorElts(Value *V, APInt DemandedElts,
|
||||
II->getName());
|
||||
InsertNewInstWith(New, *II);
|
||||
return New;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
// Output elements are undefined if both are undefined. Consider things
|
||||
// like undef&0. The result is known zero, not undef.
|
||||
UndefElts &= UndefElts2;
|
||||
|
Loading…
x
Reference in New Issue
Block a user