diff options
| author | Chris Lattner <sabre@nondot.org> | 2005-09-24 22:17:06 +0000 | 
|---|---|---|
| committer | Chris Lattner <sabre@nondot.org> | 2005-09-24 22:17:06 +0000 | 
| commit | 175463a165419b5c553384674139faf600fe5ea5 (patch) | |
| tree | 9f2329a9b9dc996829ae2282d24b04c8c63dce9f /llvm/lib/Transforms | |
| parent | 906d70564492a854a5c8fd14b23e2477a7c6f549 (diff) | |
| download | bcm5719-llvm-175463a165419b5c553384674139faf600fe5ea5.tar.gz bcm5719-llvm-175463a165419b5c553384674139faf600fe5ea5.zip | |
Simplify this code a bit by relying on recursive simplification.  Support
sprintf("%s", P)'s that have uses.
s/hasNUses(0)/use_empty()/
llvm-svn: 23425
Diffstat (limited to 'llvm/lib/Transforms')
| -rw-r--r-- | llvm/lib/Transforms/IPO/SimplifyLibCalls.cpp | 94 | 
1 files changed, 43 insertions, 51 deletions
| diff --git a/llvm/lib/Transforms/IPO/SimplifyLibCalls.cpp b/llvm/lib/Transforms/IPO/SimplifyLibCalls.cpp index 19e2f6c820a..a11bde10a6b 100644 --- a/llvm/lib/Transforms/IPO/SimplifyLibCalls.cpp +++ b/llvm/lib/Transforms/IPO/SimplifyLibCalls.cpp @@ -1282,7 +1282,7 @@ public:      // If the result of the fprintf call is used, none of these optimizations      // can be made. -    if (!ci->hasNUses(0)) +    if (!ci->use_empty())        return false;      // All the optimizations depend on the length of the second argument and the @@ -1477,57 +1477,49 @@ public:      // Get the second character and switch on its value      ConstantInt* CI = dyn_cast<ConstantInt>(CA->getOperand(1)); -    switch (CI->getRawValue()) -    { -      case 's': -      { -        uint64_t len = 0; -        if (ci->hasNUses(0)) -        { -          // sprintf(dest,"%s",str) -> strcpy(dest,str) -          Function* strcpy_func = SLC.get_strcpy(); -          if (!strcpy_func) -            return false; -          std::vector<Value*> args; -          args.push_back(CastToCStr(ci->getOperand(1), *ci)); -          args.push_back(CastToCStr(ci->getOperand(3), *ci)); -          new CallInst(strcpy_func,args,"",ci); -        } -        else if (getConstantStringLength(ci->getOperand(3),len)) -        { -          // sprintf(dest,"%s",cstr) -> llvm.memcpy(dest,str,strlen(str),1) -          len++; // get the null-terminator -          Function* memcpy_func = SLC.get_memcpy(); -          if (!memcpy_func) -            return false; -          std::vector<Value*> args; -          args.push_back(CastToCStr(ci->getOperand(1), *ci)); -          args.push_back(CastToCStr(ci->getOperand(3), *ci)); -          args.push_back(ConstantUInt::get(Type::UIntTy,len)); -          args.push_back(ConstantUInt::get(Type::UIntTy,1)); -          new CallInst(memcpy_func,args,"",ci); -          ci->replaceAllUsesWith(ConstantSInt::get(Type::IntTy,len)); -        } -        break; -      } -      case 'c': -      { -        // sprintf(dest,"%c",chr) -> store chr, dest -        CastInst* cast = -          new CastInst(ci->getOperand(3),Type::SByteTy,"char",ci); -        new StoreInst(cast, ci->getOperand(1), ci); -        GetElementPtrInst* gep = new GetElementPtrInst(ci->getOperand(1), -          ConstantUInt::get(Type::UIntTy,1),ci->getOperand(1)->getName()+".end", -          ci); -        new StoreInst(ConstantInt::get(Type::SByteTy,0),gep,ci); -        ci->replaceAllUsesWith(ConstantSInt::get(Type::IntTy,1)); -        break; -      } -      default: +    switch (CI->getRawValue()) { +    case 's': { +      // sprintf(dest,"%s",str) -> llvm.memcpy(dest, str, strlen(str)+1, 1) +      Function* strlen_func = SLC.get_strlen(); +      Function* memcpy_func = SLC.get_memcpy(); +      if (!strlen_func || !memcpy_func)          return false; +       +      Value *Len = new CallInst(strlen_func, CastToCStr(ci->getOperand(3), *ci), +                                ci->getOperand(3)->getName()+".len", ci); +      Value *Len1 = BinaryOperator::createAdd(Len, +                                            ConstantInt::get(Len->getType(), 1), +                                              Len->getName()+"1", ci); +      if (Len1->getType() != Type::UIntTy) +        Len1 = new CastInst(Len1, Type::UIntTy, Len1->getName(), ci); +      std::vector<Value*> args; +      args.push_back(CastToCStr(ci->getOperand(1), *ci)); +      args.push_back(CastToCStr(ci->getOperand(3), *ci)); +      args.push_back(Len1); +      args.push_back(ConstantUInt::get(Type::UIntTy,1)); +      new CallInst(memcpy_func, args, "", ci); +       +      // The strlen result is the unincremented number of bytes in the string. +      if (!ci->use_empty() && Len->getType() != ci->getType()) +        Len = new CastInst(Len, ci->getType(), Len->getName(), ci); +      ci->replaceAllUsesWith(Len); +      ci->eraseFromParent(); +      return true;      } -    ci->eraseFromParent(); -    return true; +    case 'c': { +      // sprintf(dest,"%c",chr) -> store chr, dest +      CastInst* cast = new CastInst(ci->getOperand(3),Type::SByteTy,"char",ci); +      new StoreInst(cast, ci->getOperand(1), ci); +      GetElementPtrInst* gep = new GetElementPtrInst(ci->getOperand(1), +        ConstantUInt::get(Type::UIntTy,1),ci->getOperand(1)->getName()+".end", +        ci); +      new StoreInst(ConstantInt::get(Type::SByteTy,0),gep,ci); +      ci->replaceAllUsesWith(ConstantSInt::get(Type::IntTy,1)); +      ci->eraseFromParent(); +      return true; +    } +    } +    return false;    }  } SPrintFOptimizer; @@ -1556,7 +1548,7 @@ public:    virtual bool OptimizeCall(CallInst* ci, SimplifyLibCalls& SLC)    {      // If the result is used, none of these optimizations work -    if (!ci->hasNUses(0)) +    if (!ci->use_empty())        return false;      // All the optimizations depend on the length of the first argument and the | 

