[llvm] [InstCombine] Remove shl if we only demand known signbits of shift source (PR #79014)

via llvm-commits llvm-commits at lists.llvm.org
Mon Jan 22 22:15:08 PST 2024


================
@@ -640,25 +640,31 @@ Value *InstCombinerImpl::SimplifyDemandedUseBits(Value *V, APInt DemandedMask,
                                                     DemandedMask, Known))
             return R;
 
-      // TODO: If we only want bits that already match the signbit then we don't
+      uint64_t ShiftAmt = SA->getLimitedValue(BitWidth - 1);
+      // If we only want bits that already match the signbit then we don't
       // need to shift.
+      if (DemandedMask.countr_zero() >= ShiftAmt) {
+        unsigned NumLowDemandedBits = BitWidth - DemandedMask.countr_zero();
----------------
ParkHanbum wrote:

my bad.. I'll fix it!

https://github.com/llvm/llvm-project/pull/79014


More information about the llvm-commits mailing list