diff options
| author | Evan Cheng <evan.cheng@apple.com> | 2010-04-01 18:19:11 +0000 | 
|---|---|---|
| committer | Evan Cheng <evan.cheng@apple.com> | 2010-04-01 18:19:11 +0000 | 
| commit | 94107ba9ceaa199f8e5c03912511b0619c84226d (patch) | |
| tree | cffe293c8930b7236aea0e0c79efbbaf7da3b2f9 /lib/CodeGen/SelectionDAG/SelectionDAG.cpp | |
| parent | 58c7aa61d49f155a1d36b9c14273de5a630de8e1 (diff) | |
| download | external_llvm-94107ba9ceaa199f8e5c03912511b0619c84226d.zip external_llvm-94107ba9ceaa199f8e5c03912511b0619c84226d.tar.gz external_llvm-94107ba9ceaa199f8e5c03912511b0619c84226d.tar.bz2 | |
- Avoid using floating point stores to implement memset unless the value is zero.
- Do not try to infer GV alignment unless its type is sized. It's not possible to infer alignment if it has opaque type.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@100118 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'lib/CodeGen/SelectionDAG/SelectionDAG.cpp')
| -rw-r--r-- | lib/CodeGen/SelectionDAG/SelectionDAG.cpp | 24 | 
1 files changed, 14 insertions, 10 deletions
| diff --git a/lib/CodeGen/SelectionDAG/SelectionDAG.cpp b/lib/CodeGen/SelectionDAG/SelectionDAG.cpp index 25bf861..4fcfeec 100644 --- a/lib/CodeGen/SelectionDAG/SelectionDAG.cpp +++ b/lib/CodeGen/SelectionDAG/SelectionDAG.cpp @@ -3195,9 +3195,9 @@ static bool isMemSrcFromString(SDValue Src, std::string &Str) {  /// is below the threshold. It returns the types of the sequence of  /// memory ops to perform memset / memcpy by reference.  static bool FindOptimalMemOpLowering(std::vector<EVT> &MemOps, -                                     SDValue Dst, SDValue Src,                                       unsigned Limit, uint64_t Size,                                       unsigned DstAlign, unsigned SrcAlign, +                                     bool SafeToUseFP,                                       SelectionDAG &DAG,                                       const TargetLowering &TLI) {    assert((SrcAlign == 0 || SrcAlign >= DstAlign) && @@ -3207,7 +3207,7 @@ static bool FindOptimalMemOpLowering(std::vector<EVT> &MemOps,    // the inferred alignment of the source. 'DstAlign', on the other hand, is the    // specified alignment of the memory operation. If it is zero, that means    // it's possible to change the alignment of the destination. -  EVT VT = TLI.getOptimalMemOpType(Size, DstAlign, SrcAlign, DAG); +  EVT VT = TLI.getOptimalMemOpType(Size, DstAlign, SrcAlign, SafeToUseFP, DAG);    if (VT == MVT::Other) {      VT = TLI.getPointerTy(); @@ -3285,9 +3285,9 @@ static SDValue getMemcpyLoadsAndStores(SelectionDAG &DAG, DebugLoc dl,    std::string Str;    bool CopyFromStr = isMemSrcFromString(Src, Str);    bool isZeroStr = CopyFromStr && Str.empty(); -  if (!FindOptimalMemOpLowering(MemOps, Dst, Src, Limit, Size, +  if (!FindOptimalMemOpLowering(MemOps, Limit, Size,                                  (DstAlignCanChange ? 0 : Align), -                                (isZeroStr ? 0 : SrcAlign), DAG, TLI)) +                                (isZeroStr ? 0 : SrcAlign), true, DAG, TLI))      return SDValue();    if (DstAlignCanChange) { @@ -3369,9 +3369,9 @@ static SDValue getMemmoveLoadsAndStores(SelectionDAG &DAG, DebugLoc dl,    if (Align > SrcAlign)      SrcAlign = Align; -  if (!FindOptimalMemOpLowering(MemOps, Dst, Src, Limit, Size, +  if (!FindOptimalMemOpLowering(MemOps, Limit, Size,                                  (DstAlignCanChange ? 0 : Align), -                                SrcAlign, DAG, TLI)) +                                SrcAlign, true, DAG, TLI))      return SDValue();    if (DstAlignCanChange) { @@ -3436,9 +3436,11 @@ static SDValue getMemsetStores(SelectionDAG &DAG, DebugLoc dl,    FrameIndexSDNode *FI = dyn_cast<FrameIndexSDNode>(Dst);    if (FI && !MFI->isFixedObjectIndex(FI->getIndex()))      DstAlignCanChange = true; -  if (!FindOptimalMemOpLowering(MemOps, Dst, Src, TLI.getMaxStoresPerMemset(), +  bool IsZero = isa<ConstantSDNode>(Src) && +    cast<ConstantSDNode>(Src)->isNullValue(); +  if (!FindOptimalMemOpLowering(MemOps, TLI.getMaxStoresPerMemset(),                                  Size, (DstAlignCanChange ? 0 : Align), 0, -                                DAG, TLI)) +                                IsZero, DAG, TLI))      return SDValue();    if (DstAlignCanChange) { @@ -6150,8 +6152,10 @@ unsigned SelectionDAG::InferPtrAlignment(SDValue Ptr) const {      unsigned Align = GV->getAlignment();      if (!Align) {        if (GlobalVariable *GVar = dyn_cast<GlobalVariable>(GV)) { -        const TargetData *TD = TLI.getTargetData(); -        Align = TD->getPreferredAlignment(GVar); +        if (GV->getType()->getElementType()->isSized()) { +          const TargetData *TD = TLI.getTargetData(); +          Align = TD->getPreferredAlignment(GVar); +        }        }      }      return MinAlign(Align, GVOffset); | 
