summaryrefslogtreecommitdiffstats
path: root/llvm/lib/Transforms/IPO/SimplifyLibCalls.cpp
diff options
context:
space:
mode:
authorReid Spencer <rspencer@reidspencer.com>2005-06-18 17:46:28 +0000
committerReid Spencer <rspencer@reidspencer.com>2005-06-18 17:46:28 +0000
commita7828baa3ca5c95f63c577b12302d699f51ed286 (patch)
tree560a9431e0b36054d389108bd004e152b5b4ec0e /llvm/lib/Transforms/IPO/SimplifyLibCalls.cpp
parent4fdd96c4e0a8e9d3d9d8167bfe750aee941a7b98 (diff)
downloadbcm5719-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.cpp29
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:
//
OpenPOWER on IntegriCloud