diff options
| author | Bill Wendling <isanbard@gmail.com> | 2009-01-30 02:52:17 +0000 | 
|---|---|---|
| committer | Bill Wendling <isanbard@gmail.com> | 2009-01-30 02:52:17 +0000 | 
| commit | 5b663e7b53fc1e1ef7a18f0fb9fbbe16b3597c6c (patch) | |
| tree | 43f6ce94134a0f7fe28bc96ecc64f4fd39935de6 /llvm/lib/CodeGen | |
| parent | b48dcf67e5d5973dfe59b875c9467c64f2b8fcca (diff) | |
| download | bcm5719-llvm-5b663e7b53fc1e1ef7a18f0fb9fbbe16b3597c6c.tar.gz bcm5719-llvm-5b663e7b53fc1e1ef7a18f0fb9fbbe16b3597c6c.zip | |
Propagate debug loc info for SDIV.
llvm-svn: 63372
Diffstat (limited to 'llvm/lib/CodeGen')
| -rw-r--r-- | llvm/lib/CodeGen/SelectionDAG/DAGCombiner.cpp | 33 | 
1 files changed, 21 insertions, 12 deletions
| diff --git a/llvm/lib/CodeGen/SelectionDAG/DAGCombiner.cpp b/llvm/lib/CodeGen/SelectionDAG/DAGCombiner.cpp index 1340ec5435a..2b59fe57917 100644 --- a/llvm/lib/CodeGen/SelectionDAG/DAGCombiner.cpp +++ b/llvm/lib/CodeGen/SelectionDAG/DAGCombiner.cpp @@ -1379,12 +1379,14 @@ SDValue DAGCombiner::visitSDIV(SDNode *N) {      return N0;    // fold (sdiv X, -1) -> 0-X    if (N1C && N1C->isAllOnesValue()) -    return DAG.getNode(ISD::SUB, VT, DAG.getConstant(0, VT), N0); +    return DAG.getNode(ISD::SUB, N->getDebugLoc(), VT, +                       DAG.getConstant(0, VT), N0);    // If we know the sign bits of both operands are zero, strength reduce to a    // udiv instead.  Handles (X&15) /s 4 -> X&15 >> 2    if (!VT.isVector()) {      if (DAG.SignBitIsZero(N1) && DAG.SignBitIsZero(N0)) -      return DAG.getNode(ISD::UDIV, N1.getValueType(), N0, N1); +      return DAG.getNode(ISD::UDIV, N->getDebugLoc(), N1.getValueType(), +                         N0, N1);    }    // fold (sdiv X, pow2) -> simple ops after legalize    if (N1C && !N1C->isNullValue() && !TLI.isIntDivCheap() && @@ -1394,30 +1396,37 @@ SDValue DAGCombiner::visitSDIV(SDNode *N) {      // fold.      if (TLI.isPow2DivCheap())        return SDValue(); +      int64_t pow2 = N1C->getSExtValue();      int64_t abs2 = pow2 > 0 ? pow2 : -pow2;      unsigned lg2 = Log2_64(abs2); +      // Splat the sign bit into the register -    SDValue SGN = DAG.getNode(ISD::SRA, VT, N0, -                                DAG.getConstant(VT.getSizeInBits()-1, -                                                TLI.getShiftAmountTy())); +    SDValue SGN = DAG.getNode(ISD::SRA, N->getDebugLoc(), VT, N0, +                              DAG.getConstant(VT.getSizeInBits()-1, +                                              TLI.getShiftAmountTy()));      AddToWorkList(SGN.getNode()); +      // Add (N0 < 0) ? abs2 - 1 : 0; -    SDValue SRL = DAG.getNode(ISD::SRL, VT, SGN, -                                DAG.getConstant(VT.getSizeInBits()-lg2, -                                                TLI.getShiftAmountTy())); -    SDValue ADD = DAG.getNode(ISD::ADD, VT, N0, SRL); +    SDValue SRL = DAG.getNode(ISD::SRL, N->getDebugLoc(), VT, SGN, +                              DAG.getConstant(VT.getSizeInBits() - lg2, +                                              TLI.getShiftAmountTy())); +    SDValue ADD = DAG.getNode(ISD::ADD, N->getDebugLoc(), VT, N0, SRL);      AddToWorkList(SRL.getNode());      AddToWorkList(ADD.getNode());    // Divide by pow2 -    SDValue SRA = DAG.getNode(ISD::SRA, VT, ADD, -                                DAG.getConstant(lg2, TLI.getShiftAmountTy())); +    SDValue SRA = DAG.getNode(ISD::SRA, N->getDebugLoc(), VT, ADD, +                              DAG.getConstant(lg2, TLI.getShiftAmountTy())); +      // If we're dividing by a positive value, we're done.  Otherwise, we must      // negate the result.      if (pow2 > 0)        return SRA; +      AddToWorkList(SRA.getNode()); -    return DAG.getNode(ISD::SUB, VT, DAG.getConstant(0, VT), SRA); +    return DAG.getNode(ISD::SUB, N->getDebugLoc(), VT, +                       DAG.getConstant(0, VT), SRA);    } +    // if integer divide is expensive and we satisfy the requirements, emit an    // alternate sequence.    if (N1C && (N1C->getSExtValue() < -1 || N1C->getSExtValue() > 1) &&  | 

