diff options
| author | Dimitry Andric <dim@FreeBSD.org> | 2017-07-19 07:02:10 +0000 | 
|---|---|---|
| committer | Dimitry Andric <dim@FreeBSD.org> | 2017-07-19 07:02:10 +0000 | 
| commit | 93c91e39b29142dec1d03a30df9f6e757f56c193 (patch) | |
| tree | 33a9b014a327e64450b3c9ed46d8c5bdb78ad345 /lib/Transforms/InstCombine/InstCombineSimplifyDemanded.cpp | |
| parent | ca089b24d48ef6fa8da2d0bb8c25bb802c4a95c0 (diff) | |
Notes
Diffstat (limited to 'lib/Transforms/InstCombine/InstCombineSimplifyDemanded.cpp')
| -rw-r--r-- | lib/Transforms/InstCombine/InstCombineSimplifyDemanded.cpp | 6 | 
1 files changed, 4 insertions, 2 deletions
| diff --git a/lib/Transforms/InstCombine/InstCombineSimplifyDemanded.cpp b/lib/Transforms/InstCombine/InstCombineSimplifyDemanded.cpp index 5689c06042391..a20f474cbf40d 100644 --- a/lib/Transforms/InstCombine/InstCombineSimplifyDemanded.cpp +++ b/lib/Transforms/InstCombine/InstCombineSimplifyDemanded.cpp @@ -417,8 +417,10 @@ Value *InstCombiner::SimplifyDemandedUseBits(Value *V, APInt DemandedMask,        // the highest demanded bit, we just return the other side.        if (DemandedFromOps.isSubsetOf(RHSKnown.Zero))          return I->getOperand(0); -      // We can't do this with the LHS for subtraction. -      if (I->getOpcode() == Instruction::Add && +      // We can't do this with the LHS for subtraction, unless we are only +      // demanding the LSB. +      if ((I->getOpcode() == Instruction::Add || +           DemandedFromOps.isOneValue()) &&            DemandedFromOps.isSubsetOf(LHSKnown.Zero))          return I->getOperand(1);      } | 
