mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-01-18 13:34:04 +00:00
teach MaskedValueIsZero how to analyze ADDE. This is
enough to teach it that ADDE(0,0) is known 0 except the low bit, for example. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@122191 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
459f4f8c25
commit
da60588402
@ -1956,7 +1956,8 @@ void SelectionDAG::ComputeMaskedBits(SDValue Op, const APInt &Mask,
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
// fall through
|
// fall through
|
||||||
case ISD::ADD: {
|
case ISD::ADD:
|
||||||
|
case ISD::ADDE: {
|
||||||
// Output known-0 bits are known if clear or set in both the low clear bits
|
// Output known-0 bits are known if clear or set in both the low clear bits
|
||||||
// common to both LHS & RHS. For example, 8+(X<<3) is known to have the
|
// common to both LHS & RHS. For example, 8+(X<<3) is known to have the
|
||||||
// low 3 bits clear.
|
// low 3 bits clear.
|
||||||
@ -1971,7 +1972,17 @@ void SelectionDAG::ComputeMaskedBits(SDValue Op, const APInt &Mask,
|
|||||||
KnownZeroOut = std::min(KnownZeroOut,
|
KnownZeroOut = std::min(KnownZeroOut,
|
||||||
KnownZero2.countTrailingOnes());
|
KnownZero2.countTrailingOnes());
|
||||||
|
|
||||||
KnownZero |= APInt::getLowBitsSet(BitWidth, KnownZeroOut);
|
if (Op.getOpcode() == ISD::ADD) {
|
||||||
|
KnownZero |= APInt::getLowBitsSet(BitWidth, KnownZeroOut);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
// With ADDE, a carry bit may be added in, so we can only use this
|
||||||
|
// information if we know (at least) that the low two bits are clear. We
|
||||||
|
// then return to the caller that the low bit is unknown but that other bits
|
||||||
|
// are known zero.
|
||||||
|
if (KnownZeroOut >= 2) // ADDE
|
||||||
|
KnownZero |= APInt::getBitsSet(BitWidth, 1, KnownZeroOut);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
case ISD::SREM:
|
case ISD::SREM:
|
||||||
|
Loading…
x
Reference in New Issue
Block a user