diff options
Diffstat (limited to 'llvm/lib')
| -rw-r--r-- | llvm/lib/CodeGen/SelectionDAG/TargetLowering.cpp | 66 | ||||
| -rw-r--r-- | llvm/lib/Target/AArch64/AArch64ISelLowering.cpp | 141 | ||||
| -rw-r--r-- | llvm/lib/Target/AArch64/AArch64ISelLowering.h | 3 | ||||
| -rw-r--r-- | llvm/lib/Target/AMDGPU/AMDGPUISelLowering.cpp | 5 | ||||
| -rw-r--r-- | llvm/lib/Target/AMDGPU/SIISelLowering.cpp | 2 | ||||
| -rw-r--r-- | llvm/lib/Target/X86/X86ISelLowering.cpp | 4 | ||||
| -rw-r--r-- | llvm/lib/Target/XCore/XCoreISelLowering.cpp | 4 | 
7 files changed, 188 insertions, 37 deletions
| diff --git a/llvm/lib/CodeGen/SelectionDAG/TargetLowering.cpp b/llvm/lib/CodeGen/SelectionDAG/TargetLowering.cpp index 93c6738f650..069fb5b9c09 100644 --- a/llvm/lib/CodeGen/SelectionDAG/TargetLowering.cpp +++ b/llvm/lib/CodeGen/SelectionDAG/TargetLowering.cpp @@ -342,11 +342,16 @@ TargetLowering::isOffsetFoldingLegal(const GlobalAddressSDNode *GA) const {  /// If the specified instruction has a constant integer operand and there are  /// bits set in that constant that are not demanded, then clear those bits and  /// return true. -bool TargetLowering::TargetLoweringOpt::ShrinkDemandedConstant( -    SDValue Op, const APInt &Demanded) { +bool TargetLowering::ShrinkDemandedConstant(SDValue Op, const APInt &Demanded, +                                            TargetLoweringOpt &TLO) const { +  SelectionDAG &DAG = TLO.DAG;    SDLoc DL(Op);    unsigned Opcode = Op.getOpcode(); +  // Do target-specific constant optimization. +  if (targetShrinkDemandedConstant(Op, Demanded, TLO)) +    return TLO.New.getNode(); +    // FIXME: ISD::SELECT, ISD::SELECT_CC    switch (Opcode) {    default: @@ -367,7 +372,7 @@ bool TargetLowering::TargetLoweringOpt::ShrinkDemandedConstant(        EVT VT = Op.getValueType();        SDValue NewC = DAG.getConstant(Demanded & C, DL, VT);        SDValue NewOp = DAG.getNode(Opcode, DL, VT, Op.getOperand(0), NewC); -      return CombineTo(Op, NewOp); +      return TLO.CombineTo(Op, NewOp);      }      break; @@ -380,15 +385,17 @@ bool TargetLowering::TargetLoweringOpt::ShrinkDemandedConstant(  /// Convert x+y to (VT)((SmallVT)x+(SmallVT)y) if the casts are free.  /// This uses isZExtFree and ZERO_EXTEND for the widening cast, but it could be  /// generalized for targets with other types of implicit widening casts. -bool TargetLowering::TargetLoweringOpt::ShrinkDemandedOp(SDValue Op, -                                                         unsigned BitWidth, -                                                         const APInt &Demanded, -                                                         const SDLoc &dl) { +bool TargetLowering::ShrinkDemandedOp(SDValue Op, unsigned BitWidth, +                                      const APInt &Demanded, +                                      TargetLoweringOpt &TLO) const {    assert(Op.getNumOperands() == 2 &&           "ShrinkDemandedOp only supports binary operators!");    assert(Op.getNode()->getNumValues() == 1 &&           "ShrinkDemandedOp only supports nodes with one result!"); +  SelectionDAG &DAG = TLO.DAG; +  SDLoc dl(Op); +    // Early return, as this function cannot handle vector types.    if (Op.getValueType().isVector())      return false; @@ -418,23 +425,22 @@ bool TargetLowering::TargetLoweringOpt::ShrinkDemandedOp(SDValue Op,        bool NeedZext = DemandedSize > SmallVTBits;        SDValue Z = DAG.getNode(NeedZext ? ISD::ZERO_EXTEND : ISD::ANY_EXTEND,                                dl, Op.getValueType(), X); -      return CombineTo(Op, Z); +      return TLO.CombineTo(Op, Z);      }    }    return false;  }  bool -TargetLowering::TargetLoweringOpt::SimplifyDemandedBits(SDNode *User, -                                                        unsigned OpIdx, -                                                        const APInt &Demanded, -                                                        DAGCombinerInfo &DCI) { -  const TargetLowering &TLI = DAG.getTargetLoweringInfo(); +TargetLowering::SimplifyDemandedBits(SDNode *User, unsigned OpIdx, +                                     const APInt &Demanded, +                                     DAGCombinerInfo &DCI, +                                     TargetLoweringOpt &TLO) const {    SDValue Op = User->getOperand(OpIdx);    APInt KnownZero, KnownOne; -  if (!TLI.SimplifyDemandedBits(Op, Demanded, KnownZero, KnownOne, -                                *this, 0, true)) +  if (!SimplifyDemandedBits(Op, Demanded, KnownZero, KnownOne, +                            TLO, 0, true))      return false; @@ -446,9 +452,9 @@ TargetLowering::TargetLoweringOpt::SimplifyDemandedBits(SDNode *User,    // with the value 'x', which will give us:    // Old = i32 and x, 0xffffff    // New = x -  if (Old.hasOneUse()) { +  if (TLO.Old.hasOneUse()) {      // For the one use case, we just commit the change. -    DCI.CommitTargetLoweringOpt(*this); +    DCI.CommitTargetLoweringOpt(TLO);      return true;    } @@ -456,17 +462,17 @@ TargetLowering::TargetLoweringOpt::SimplifyDemandedBits(SDNode *User,    // AssumeSingleUse flag is not propogated to recursive calls of    // SimplifyDemanded bits, so the only node with multiple use that    // it will attempt to combine will be opt. -  assert(Old == Op); +  assert(TLO.Old == Op);    SmallVector <SDValue, 4> NewOps;    for (unsigned i = 0, e = User->getNumOperands(); i != e; ++i) {      if (i == OpIdx) { -      NewOps.push_back(New); +      NewOps.push_back(TLO.New);        continue;      }      NewOps.push_back(User->getOperand(i));    } -  DAG.UpdateNodeOperands(User, NewOps); +  TLO.DAG.UpdateNodeOperands(User, NewOps);    // Op has less users now, so we may be able to perform additional combines    // with it.    DCI.AddToWorklist(Op.getNode()); @@ -585,7 +591,7 @@ bool TargetLowering::SimplifyDemandedBits(SDValue Op,        // If any of the set bits in the RHS are known zero on the LHS, shrink        // the constant. -      if (TLO.ShrinkDemandedConstant(Op, ~LHSZero & NewMask)) +      if (ShrinkDemandedConstant(Op, ~LHSZero & NewMask, TLO))          return true;        // Bitwise-not (xor X, -1) is a special case: we don't usually shrink its @@ -620,10 +626,10 @@ bool TargetLowering::SimplifyDemandedBits(SDValue Op,      if ((NewMask & (KnownZero|KnownZero2)) == NewMask)        return TLO.CombineTo(Op, TLO.DAG.getConstant(0, dl, Op.getValueType()));      // If the RHS is a constant, see if we can simplify it. -    if (TLO.ShrinkDemandedConstant(Op, ~KnownZero2 & NewMask)) +    if (ShrinkDemandedConstant(Op, ~KnownZero2 & NewMask, TLO))        return true;      // If the operation can be done in a smaller type, do so. -    if (TLO.ShrinkDemandedOp(Op, BitWidth, NewMask, dl)) +    if (ShrinkDemandedOp(Op, BitWidth, NewMask, TLO))        return true;      // Output known-1 bits are only known if set in both the LHS & RHS. @@ -654,10 +660,10 @@ bool TargetLowering::SimplifyDemandedBits(SDValue Op,      if ((NewMask & ~KnownZero2 & KnownOne) == (~KnownZero2 & NewMask))        return TLO.CombineTo(Op, Op.getOperand(1));      // If the RHS is a constant, see if we can simplify it. -    if (TLO.ShrinkDemandedConstant(Op, NewMask)) +    if (ShrinkDemandedConstant(Op, NewMask, TLO))        return true;      // If the operation can be done in a smaller type, do so. -    if (TLO.ShrinkDemandedOp(Op, BitWidth, NewMask, dl)) +    if (ShrinkDemandedOp(Op, BitWidth, NewMask, TLO))        return true;      // Output known-0 bits are only known if clear in both the LHS & RHS. @@ -682,7 +688,7 @@ bool TargetLowering::SimplifyDemandedBits(SDValue Op,      if ((KnownZero2 & NewMask) == NewMask)        return TLO.CombineTo(Op, Op.getOperand(1));      // If the operation can be done in a smaller type, do so. -    if (TLO.ShrinkDemandedOp(Op, BitWidth, NewMask, dl)) +    if (ShrinkDemandedOp(Op, BitWidth, NewMask, TLO))        return true;      // If all of the unknown bits are known to be zero on one side or the other @@ -727,7 +733,7 @@ bool TargetLowering::SimplifyDemandedBits(SDValue Op,          }          // If it already has all the bits set, nothing to change          // but don't shrink either! -      } else if (TLO.ShrinkDemandedConstant(Op, NewMask)) { +      } else if (ShrinkDemandedConstant(Op, NewMask, TLO)) {          return true;        }      } @@ -746,7 +752,7 @@ bool TargetLowering::SimplifyDemandedBits(SDValue Op,      assert((KnownZero2 & KnownOne2) == 0 && "Bits known to be one AND zero?");      // If the operands are constants, see if we can simplify them. -    if (TLO.ShrinkDemandedConstant(Op, NewMask)) +    if (ShrinkDemandedConstant(Op, NewMask, TLO))        return true;      // Only known if known in both the LHS and RHS. @@ -764,7 +770,7 @@ bool TargetLowering::SimplifyDemandedBits(SDValue Op,      assert((KnownZero2 & KnownOne2) == 0 && "Bits known to be one AND zero?");      // If the operands are constants, see if we can simplify them. -    if (TLO.ShrinkDemandedConstant(Op, NewMask)) +    if (ShrinkDemandedConstant(Op, NewMask, TLO))        return true;      // Only known if known in both the LHS and RHS. @@ -1284,7 +1290,7 @@ bool TargetLowering::SimplifyDemandedBits(SDValue Op,          SimplifyDemandedBits(Op.getOperand(1), LoMask, KnownZero2,                               KnownOne2, TLO, Depth+1) ||          // See if the operation should be performed at a smaller bit width. -        TLO.ShrinkDemandedOp(Op, BitWidth, NewMask, dl)) { +        ShrinkDemandedOp(Op, BitWidth, NewMask, TLO)) {        const SDNodeFlags *Flags = Op.getNode()->getFlags();        if (Flags->hasNoSignedWrap() || Flags->hasNoUnsignedWrap()) {          // Disable the nsw and nuw flags. We can no longer guarantee that we diff --git a/llvm/lib/Target/AArch64/AArch64ISelLowering.cpp b/llvm/lib/Target/AArch64/AArch64ISelLowering.cpp index 7796c44d666..a7c98fbb425 100644 --- a/llvm/lib/Target/AArch64/AArch64ISelLowering.cpp +++ b/llvm/lib/Target/AArch64/AArch64ISelLowering.cpp @@ -91,6 +91,7 @@ using namespace llvm;  STATISTIC(NumTailCalls, "Number of tail calls");  STATISTIC(NumShiftInserts, "Number of vector shift inserts"); +STATISTIC(NumOptimizedImms, "Number of times immediates were optimized");  static cl::opt<bool>  EnableAArch64SlrGeneration("aarch64-shift-insert-generation", cl::Hidden, @@ -105,6 +106,12 @@ cl::opt<bool> EnableAArch64ELFLocalDynamicTLSGeneration(      cl::desc("Allow AArch64 Local Dynamic TLS code generation"),      cl::init(false)); +static cl::opt<bool> +EnableOptimizeLogicalImm("aarch64-enable-logical-imm", cl::Hidden, +                         cl::desc("Enable AArch64 logical imm instruction " +                                  "optimization"), +                         cl::init(true)); +  /// Value type used for condition codes.  static const MVT MVT_CC = MVT::i32; @@ -787,6 +794,140 @@ EVT AArch64TargetLowering::getSetCCResultType(const DataLayout &, LLVMContext &,    return VT.changeVectorElementTypeToInteger();  } +static bool optimizeLogicalImm(SDValue Op, unsigned Size, uint64_t Imm, +                               const APInt &Demanded, +                               TargetLowering::TargetLoweringOpt &TLO, +                               unsigned NewOpc) { +  uint64_t OldImm = Imm, NewImm, Enc; +  uint64_t Mask = ((uint64_t)(-1LL) >> (64 - Size)), OrigMask = Mask; + +  // Return if the immediate is already all zeros, all ones, a bimm32 or a +  // bimm64. +  if (Imm == 0 || Imm == Mask || +      AArch64_AM::isLogicalImmediate(Imm & Mask, Size)) +    return false; + +  unsigned EltSize = Size; +  uint64_t DemandedBits = Demanded.getZExtValue(); + +  // Clear bits that are not demanded. +  Imm &= DemandedBits; + +  while (true) { +    // The goal here is to set the non-demanded bits in a way that minimizes +    // the number of switching between 0 and 1. In order to achieve this goal, +    // we set the non-demanded bits to the value of the preceding demanded bits. +    // For example, if we have an immediate 0bx10xx0x1 ('x' indicates a +    // non-demanded bit), we copy bit0 (1) to the least significant 'x', +    // bit2 (0) to 'xx', and bit6 (1) to the most significant 'x'. +    // The final result is 0b11000011. +    uint64_t NonDemandedBits = ~DemandedBits; +    uint64_t InvertedImm = ~Imm & DemandedBits; +    uint64_t RotatedImm = +        ((InvertedImm << 1) | (InvertedImm >> (EltSize - 1) & 1)) & +        NonDemandedBits; +    uint64_t Sum = RotatedImm + NonDemandedBits; +    bool Carry = NonDemandedBits & ~Sum & (1ULL << (EltSize - 1)); +    uint64_t Ones = (Sum + Carry) & NonDemandedBits; +    NewImm = (Imm | Ones) & Mask; + +    // If NewImm or its bitwise NOT is a shifted mask, it is a bitmask immediate +    // or all-ones or all-zeros, in which case we can stop searching. Otherwise, +    // we halve the element size and continue the search. +    if (isShiftedMask_64(NewImm) || isShiftedMask_64(~(NewImm | ~Mask))) +      break; + +    // We cannot shrink the element size any further if it is 2-bits. +    if (EltSize == 2) +      return false; + +    EltSize /= 2; +    Mask >>= EltSize; +    uint64_t Hi = Imm >> EltSize, DemandedBitsHi = DemandedBits >> EltSize; + +    // Return if there is mismatch in any of the demanded bits of Imm and Hi. +    if (((Imm ^ Hi) & (DemandedBits & DemandedBitsHi) & Mask) != 0) +      return false; + +    // Merge the upper and lower halves of Imm and DemandedBits. +    Imm |= Hi; +    DemandedBits |= DemandedBitsHi; +  } + +  ++NumOptimizedImms; + +  // Replicate the element across the register width. +  while (EltSize < Size) { +    NewImm |= NewImm << EltSize; +    EltSize *= 2; +  } + +  (void)OldImm; +  assert(((OldImm ^ NewImm) & Demanded.getZExtValue()) == 0 && +         "demanded bits should never be altered"); +  assert(OldImm != NewImm && "the new imm shouldn't be equal to the old imm"); + +  // Create the new constant immediate node. +  EVT VT = Op.getValueType(); +  SDLoc DL(Op); + +  // If the new constant immediate is all-zeros or all-ones, let the target +  // independent DAG combine optimize this node. +  if (NewImm == 0 || NewImm == OrigMask) +    return TLO.CombineTo(Op.getOperand(1), TLO.DAG.getConstant(NewImm, DL, VT)); + +  // Otherwise, create a machine node so that target independent DAG combine +  // doesn't undo this optimization. +  Enc = AArch64_AM::encodeLogicalImmediate(NewImm, Size); +  SDValue EncConst = TLO.DAG.getTargetConstant(Enc, DL, VT); +  SDValue New( +      TLO.DAG.getMachineNode(NewOpc, DL, VT, Op.getOperand(0), EncConst), 0); + +  return TLO.CombineTo(Op, New); +} + +bool AArch64TargetLowering::targetShrinkDemandedConstant( +    SDValue Op, const APInt &Demanded, TargetLoweringOpt &TLO) const { +  // Delay this optimization to as late as possible. +  if (!TLO.LegalOps) +    return false; + +  if (!EnableOptimizeLogicalImm) +    return false; + +  EVT VT = Op.getValueType(); +  if (VT.isVector()) +    return false; + +  unsigned Size = VT.getSizeInBits(); +  assert((Size == 32 || Size == 64) && +         "i32 or i64 is expected after legalization."); + +  // Exit early if we demand all bits. +  if (Demanded.countPopulation() == Size) +    return false; + +  unsigned NewOpc; +  switch (Op.getOpcode()) { +  default: +    return false; +  case ISD::AND: +    NewOpc = Size == 32 ? AArch64::ANDWri : AArch64::ANDXri; +    break; +  case ISD::OR: +    NewOpc = Size == 32 ? AArch64::ORRWri : AArch64::ORRXri; +    break; +  case ISD::XOR: +    NewOpc = Size == 32 ? AArch64::EORWri : AArch64::EORXri; +    break; +  } +  ConstantSDNode *C = dyn_cast<ConstantSDNode>(Op.getOperand(1)); +  if (!C) +    return false; +  uint64_t Imm = C->getZExtValue(); +  return optimizeLogicalImm(Op, Size, Imm, Demanded, TLO, NewOpc); +} +  /// computeKnownBitsForTargetNode - Determine which of the bits specified in  /// Mask are known to be either zero or one and return them in the  /// KnownZero/KnownOne bitsets. diff --git a/llvm/lib/Target/AArch64/AArch64ISelLowering.h b/llvm/lib/Target/AArch64/AArch64ISelLowering.h index 8e1720f3d52..6081b07479b 100644 --- a/llvm/lib/Target/AArch64/AArch64ISelLowering.h +++ b/llvm/lib/Target/AArch64/AArch64ISelLowering.h @@ -255,6 +255,9 @@ public:                                       const SelectionDAG &DAG,                                       unsigned Depth = 0) const override; +  bool targetShrinkDemandedConstant(SDValue Op, const APInt &Demanded, +                                    TargetLoweringOpt &TLO) const override; +    MVT getScalarShiftAmountTy(const DataLayout &DL, EVT) const override;    /// Returns true if the target allows unaligned memory accesses of the diff --git a/llvm/lib/Target/AMDGPU/AMDGPUISelLowering.cpp b/llvm/lib/Target/AMDGPU/AMDGPUISelLowering.cpp index c0f336e082b..7276d3c85fb 100644 --- a/llvm/lib/Target/AMDGPU/AMDGPUISelLowering.cpp +++ b/llvm/lib/Target/AMDGPU/AMDGPUISelLowering.cpp @@ -2315,12 +2315,13 @@ static bool simplifyI24(SDNode *Node24, unsigned OpIdx,    SelectionDAG &DAG = DCI.DAG;    SDValue Op = Node24->getOperand(OpIdx); +  const TargetLowering &TLI = DAG.getTargetLoweringInfo();    EVT VT = Op.getValueType();    APInt Demanded = APInt::getLowBitsSet(VT.getSizeInBits(), 24);    APInt KnownZero, KnownOne;    TargetLowering::TargetLoweringOpt TLO(DAG, true, true); -  if (TLO.SimplifyDemandedBits(Node24, OpIdx, Demanded, DCI)) +  if (TLI.SimplifyDemandedBits(Node24, OpIdx, Demanded, DCI, TLO))      return true;    return false; @@ -3361,7 +3362,7 @@ SDValue AMDGPUTargetLowering::PerformDAGCombine(SDNode *N,        TargetLowering::TargetLoweringOpt TLO(DAG, !DCI.isBeforeLegalize(),                                              !DCI.isBeforeLegalizeOps());        const TargetLowering &TLI = DAG.getTargetLoweringInfo(); -      if (TLO.ShrinkDemandedConstant(BitsFrom, Demanded) || +      if (TLI.ShrinkDemandedConstant(BitsFrom, Demanded, TLO) ||            TLI.SimplifyDemandedBits(BitsFrom, Demanded,                                     KnownZero, KnownOne, TLO)) {          DCI.CommitTargetLoweringOpt(TLO); diff --git a/llvm/lib/Target/AMDGPU/SIISelLowering.cpp b/llvm/lib/Target/AMDGPU/SIISelLowering.cpp index dd867b15b4c..fb166d7c7cd 100644 --- a/llvm/lib/Target/AMDGPU/SIISelLowering.cpp +++ b/llvm/lib/Target/AMDGPU/SIISelLowering.cpp @@ -4696,7 +4696,7 @@ SDValue SITargetLowering::performCvtF32UByteNCombine(SDNode *N,    TargetLowering::TargetLoweringOpt TLO(DAG, !DCI.isBeforeLegalize(),                                          !DCI.isBeforeLegalizeOps());    const TargetLowering &TLI = DAG.getTargetLoweringInfo(); -  if (TLO.ShrinkDemandedConstant(Src, Demanded) || +  if (TLI.ShrinkDemandedConstant(Src, Demanded, TLO) ||        TLI.SimplifyDemandedBits(Src, Demanded, KnownZero, KnownOne, TLO)) {      DCI.CommitTargetLoweringOpt(TLO);    } diff --git a/llvm/lib/Target/X86/X86ISelLowering.cpp b/llvm/lib/Target/X86/X86ISelLowering.cpp index b5f29fb400e..e3de30417b0 100644 --- a/llvm/lib/Target/X86/X86ISelLowering.cpp +++ b/llvm/lib/Target/X86/X86ISelLowering.cpp @@ -30207,7 +30207,7 @@ static SDValue combineSelect(SDNode *N, SelectionDAG &DAG,      APInt KnownZero, KnownOne;      TargetLowering::TargetLoweringOpt TLO(DAG, DCI.isBeforeLegalize(),                                            DCI.isBeforeLegalizeOps()); -    if (TLO.ShrinkDemandedConstant(Cond, DemandedMask) || +    if (TLI.ShrinkDemandedConstant(Cond, DemandedMask, TLO) ||          TLI.SimplifyDemandedBits(Cond, DemandedMask, KnownZero, KnownOne,                                   TLO)) {        // If we changed the computation somewhere in the DAG, this change will @@ -33777,7 +33777,7 @@ static SDValue combineBT(SDNode *N, SelectionDAG &DAG,      TargetLowering::TargetLoweringOpt TLO(DAG, !DCI.isBeforeLegalize(),                                            !DCI.isBeforeLegalizeOps());      const TargetLowering &TLI = DAG.getTargetLoweringInfo(); -    if (TLO.ShrinkDemandedConstant(Op1, DemandedMask) || +    if (TLI.ShrinkDemandedConstant(Op1, DemandedMask, TLO) ||          TLI.SimplifyDemandedBits(Op1, DemandedMask, KnownZero, KnownOne, TLO))        DCI.CommitTargetLoweringOpt(TLO);    } diff --git a/llvm/lib/Target/XCore/XCoreISelLowering.cpp b/llvm/lib/Target/XCore/XCoreISelLowering.cpp index 45437815fa3..2efcd46cd8d 100644 --- a/llvm/lib/Target/XCore/XCoreISelLowering.cpp +++ b/llvm/lib/Target/XCore/XCoreISelLowering.cpp @@ -1605,7 +1605,7 @@ SDValue XCoreTargetLowering::PerformDAGCombine(SDNode *N,          TargetLowering::TargetLoweringOpt TLO(DAG, !DCI.isBeforeLegalize(),                                                !DCI.isBeforeLegalizeOps());          const TargetLowering &TLI = DAG.getTargetLoweringInfo(); -        if (TLO.ShrinkDemandedConstant(OutVal, DemandedMask) || +        if (TLI.ShrinkDemandedConstant(OutVal, DemandedMask, TLO) ||              TLI.SimplifyDemandedBits(OutVal, DemandedMask, KnownZero, KnownOne,                                       TLO))            DCI.CommitTargetLoweringOpt(TLO); @@ -1622,7 +1622,7 @@ SDValue XCoreTargetLowering::PerformDAGCombine(SDNode *N,          TargetLowering::TargetLoweringOpt TLO(DAG, !DCI.isBeforeLegalize(),                                                !DCI.isBeforeLegalizeOps());          const TargetLowering &TLI = DAG.getTargetLoweringInfo(); -        if (TLO.ShrinkDemandedConstant(Time, DemandedMask) || +        if (TLI.ShrinkDemandedConstant(Time, DemandedMask, TLO) ||              TLI.SimplifyDemandedBits(Time, DemandedMask, KnownZero, KnownOne,                                       TLO))            DCI.CommitTargetLoweringOpt(TLO); | 

