diff --git a/llvm/lib/CodeGen/GlobalISel/CombinerHelper.cpp b/llvm/lib/CodeGen/GlobalISel/CombinerHelper.cpp --- a/llvm/lib/CodeGen/GlobalISel/CombinerHelper.cpp +++ b/llvm/lib/CodeGen/GlobalISel/CombinerHelper.cpp @@ -4962,16 +4962,12 @@ Magic = std::move(magics.Magic); - if (!magics.IsAdd) { - assert(magics.ShiftAmount < Divisor.getBitWidth() && - "We shouldn't generate an undefined shift!"); - PostShift = magics.ShiftAmount; - PreShift = magics.PreShift; - } else { - assert(magics.PreShift == 0 && "Unexpected pre-shift"); - PostShift = magics.ShiftAmount - 1; - SelNPQ = true; - } + assert(magics.ShiftAmount < Divisor.getBitWidth() && + "We shouldn't generate an undefined shift!"); + assert((!magics.IsAdd || magics.PreShift == 0) && "Unexpected pre-shift"); + PostShift = magics.ShiftAmount; + PreShift = magics.PreShift; + SelNPQ = magics.IsAdd; } PreShifts.push_back( diff --git a/llvm/lib/CodeGen/SelectionDAG/TargetLowering.cpp b/llvm/lib/CodeGen/SelectionDAG/TargetLowering.cpp --- a/llvm/lib/CodeGen/SelectionDAG/TargetLowering.cpp +++ b/llvm/lib/CodeGen/SelectionDAG/TargetLowering.cpp @@ -6056,16 +6056,13 @@ Magic = std::move(magics.Magic); - if (!magics.IsAdd) { - assert(magics.ShiftAmount < Divisor.getBitWidth() && - "We shouldn't generate an undefined shift!"); - PostShift = magics.ShiftAmount; - PreShift = magics.PreShift; - } else { - assert(magics.PreShift == 0 && "Unexpected pre-shift"); - PostShift = magics.ShiftAmount - 1; - SelNPQ = true; - } + assert(magics.ShiftAmount < Divisor.getBitWidth() && + "We shouldn't generate an undefined shift!"); + assert((!magics.IsAdd || magics.PreShift == 0) && + "Unexpected pre-shift"); + PostShift = magics.ShiftAmount; + PreShift = magics.PreShift; + SelNPQ = magics.IsAdd; } PreShifts.push_back(DAG.getConstant(PreShift, dl, ShSVT)); diff --git a/llvm/lib/Support/DivisionByConstantInfo.cpp b/llvm/lib/Support/DivisionByConstantInfo.cpp --- a/llvm/lib/Support/DivisionByConstantInfo.cpp +++ b/llvm/lib/Support/DivisionByConstantInfo.cpp @@ -144,6 +144,11 @@ Retval.Magic = std::move(Q2); // resulting magic number ++Retval.Magic; Retval.ShiftAmount = P - D.getBitWidth(); // resulting shift + // Reduce shift amount for IsAdd. + if (Retval.IsAdd) { + assert(Retval.ShiftAmount > 0 && "Unexpected shift"); + Retval.ShiftAmount -= 1; + } Retval.PreShift = 0; return Retval; } diff --git a/llvm/unittests/Support/DivisionByConstantTest.cpp b/llvm/unittests/Support/DivisionByConstantTest.cpp --- a/llvm/unittests/Support/DivisionByConstantTest.cpp +++ b/llvm/unittests/Support/DivisionByConstantTest.cpp @@ -116,22 +116,12 @@ } } - unsigned PreShift = 0; - unsigned PostShift = 0; - bool UseNPQ = false; - if (!Magics.IsAdd) { - assert(Magics.ShiftAmount < Divisor.getBitWidth() && - "We shouldn't generate an undefined shift!"); - PreShift = Magics.PreShift; - PostShift = Magics.ShiftAmount; - UseNPQ = false; - } else { - assert(Magics.PreShift == 0 && "Unexpected pre-shift"); - PostShift = Magics.ShiftAmount - 1; - assert(PostShift < Divisor.getBitWidth() && - "We shouldn't generate an undefined shift!"); - UseNPQ = true; - } + assert(Magics.ShiftAmount < Divisor.getBitWidth() && + "We shouldn't generate an undefined shift!"); + assert((!Magics.IsAdd || Magics.PreShift == 0) && "Unexpected pre-shift"); + unsigned PreShift = Magics.PreShift; + unsigned PostShift = Magics.ShiftAmount;; + bool UseNPQ = Magics.IsAdd; APInt NPQFactor = UseNPQ ? APInt::getSignedMinValue(Bits) : APInt::getZero(Bits);