diff options
Diffstat (limited to 'llvm/lib/CodeGen/SelectionDAG/TargetLowering.cpp')
| -rw-r--r-- | llvm/lib/CodeGen/SelectionDAG/TargetLowering.cpp | 5 | 
1 files changed, 3 insertions, 2 deletions
| diff --git a/llvm/lib/CodeGen/SelectionDAG/TargetLowering.cpp b/llvm/lib/CodeGen/SelectionDAG/TargetLowering.cpp index 09a2b1f3d7a..e341e15e41a 100644 --- a/llvm/lib/CodeGen/SelectionDAG/TargetLowering.cpp +++ b/llvm/lib/CodeGen/SelectionDAG/TargetLowering.cpp @@ -1367,8 +1367,9 @@ bool TargetLowering::SimplifyDemandedBits(SDValue Op,      // 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 ((NewMask & (KnownZero|KnownOne)) == NewMask) { // all known -      if ((KnownOne & KnownOne2) == KnownOne) { +    // NB: it is okay if more bits are known than are requested +    if ((NewMask & (KnownZero|KnownOne)) == NewMask) { // all known on one side  +      if (KnownOne == KnownOne2) { // set bits are the same on both sides          EVT VT = Op.getValueType();          SDValue ANDC = TLO.DAG.getConstant(~KnownOne & NewMask, VT);          return TLO.CombineTo(Op, TLO.DAG.getNode(ISD::AND, dl, VT, | 

