[llvm-commits] CVS: llvm/lib/Transforms/IPO/SimplifyLibCalls.cpp
Reid Spencer
reid at x10sys.com
Sat Jun 18 10:46:40 PDT 2005
Changes in directory llvm/lib/Transforms/IPO:
SimplifyLibCalls.cpp updated: 1.42 -> 1.43
---
Log message:
Fix a problem with the strcmp optimization checking the wrong string and
not casting to the correct type.
---
Diffs of the changes: (+16 -13)
SimplifyLibCalls.cpp | 29 ++++++++++++++++-------------
1 files changed, 16 insertions(+), 13 deletions(-)
Index: llvm/lib/Transforms/IPO/SimplifyLibCalls.cpp
diff -u llvm/lib/Transforms/IPO/SimplifyLibCalls.cpp:1.42 llvm/lib/Transforms/IPO/SimplifyLibCalls.cpp:1.43
--- llvm/lib/Transforms/IPO/SimplifyLibCalls.cpp:1.42 Fri May 20 20:27:04 2005
+++ llvm/lib/Transforms/IPO/SimplifyLibCalls.cpp Sat Jun 18 12:46:28 2005
@@ -367,8 +367,9 @@
// 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 @@
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 @@
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 @@
}
} 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 @@
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:
//
More information about the llvm-commits
mailing list