diff options
| author | Reid Spencer <rspencer@reidspencer.com> | 2005-06-18 17:46:28 +0000 | 
|---|---|---|
| committer | Reid Spencer <rspencer@reidspencer.com> | 2005-06-18 17:46:28 +0000 | 
| commit | a7828baa3ca5c95f63c577b12302d699f51ed286 (patch) | |
| tree | 560a9431e0b36054d389108bd004e152b5b4ec0e /llvm/lib/Transforms/IPO/SimplifyLibCalls.cpp | |
| parent | 4fdd96c4e0a8e9d3d9d8167bfe750aee941a7b98 (diff) | |
| download | bcm5719-llvm-a7828baa3ca5c95f63c577b12302d699f51ed286.tar.gz bcm5719-llvm-a7828baa3ca5c95f63c577b12302d699f51ed286.zip | |
Fix a problem with the strcmp optimization checking the wrong string and
not casting to the correct type.
llvm-svn: 22250
Diffstat (limited to 'llvm/lib/Transforms/IPO/SimplifyLibCalls.cpp')
| -rw-r--r-- | llvm/lib/Transforms/IPO/SimplifyLibCalls.cpp | 29 | 
1 files changed, 16 insertions, 13 deletions
| diff --git a/llvm/lib/Transforms/IPO/SimplifyLibCalls.cpp b/llvm/lib/Transforms/IPO/SimplifyLibCalls.cpp index 382bbb879e7..a2ca6921476 100644 --- a/llvm/lib/Transforms/IPO/SimplifyLibCalls.cpp +++ b/llvm/lib/Transforms/IPO/SimplifyLibCalls.cpp @@ -367,8 +367,9 @@ ModulePass *llvm::createSimplifyLibCallsPass()  // auto registers it into the "optlist" global above.   namespace { -// Forward declare a utility function. +// Forward declare utility functions.  bool getConstantStringLength(Value* V, uint64_t& len, ConstantArray** A = 0 ); +Value *CastToCStr(Value *V, Instruction &IP);  /// This LibCallOptimization will find instances of a call to "exit" that occurs  /// within the "main" function and change it to a simple "ret" instruction with @@ -663,7 +664,8 @@ public:        if (len_1 == 0)        {          // strcmp("",x) -> *x -        LoadInst* load = new LoadInst(s1,ci->getName()+".load",ci); +        LoadInst* load =  +          new LoadInst(CastToCStr(s2,*ci), ci->getName()+".load",ci);          CastInst* cast =             new CastInst(load,Type::IntTy,ci->getName()+".int",ci);          ci->replaceAllUsesWith(cast); @@ -681,7 +683,8 @@ public:        if (len_2 == 0)        {          // strcmp(x,"") -> *x -        LoadInst* load = new LoadInst(s2,ci->getName()+".val",ci); +        LoadInst* load =  +          new LoadInst(CastToCStr(s1,*ci),ci->getName()+".val",ci);          CastInst* cast =             new CastInst(load,Type::IntTy,ci->getName()+".int",ci);          ci->replaceAllUsesWith(cast); @@ -1242,16 +1245,6 @@ public:    }  } PowOptimizer; -/// CastToCStr - Return V if it is an sbyte*, otherwise cast it to sbyte*, -/// inserting the cast before IP, and return the cast. -/// @brief Cast a value to a "C" string. -static Value *CastToCStr(Value *V, Instruction &IP) { -  const Type *SBPTy = PointerType::get(Type::SByteTy); -  if (V->getType() != SBPTy) -    return new CastInst(V, SBPTy, V->getName(), &IP); -  return V; -} -  /// This LibCallOptimization will simplify calls to the "fprintf" library   /// function. It looks for cases where the result of fprintf is not used and the  /// operation can be reduced to something simpler. @@ -1889,6 +1882,16 @@ bool getConstantStringLength(Value* V, uint64_t& len, ConstantArray** CA )    return true; // success!  } +/// CastToCStr - Return V if it is an sbyte*, otherwise cast it to sbyte*, +/// inserting the cast before IP, and return the cast. +/// @brief Cast a value to a "C" string. +Value *CastToCStr(Value *V, Instruction &IP) { +  const Type *SBPTy = PointerType::get(Type::SByteTy); +  if (V->getType() != SBPTy) +    return new CastInst(V, SBPTy, V->getName(), &IP); +  return V; +} +  // TODO:   //   Additional cases that we need to add to this file:  // | 

