From 45bb4afc7992d3b69d683a54d7379d8767914f6c Mon Sep 17 00:00:00 2001 From: Reid Spencer Date: Sat, 21 May 2005 00:39:30 +0000 Subject: Make sure ... arguments are casted to sbyte* where needed. llvm-svn: 22162 --- llvm/lib/Transforms/IPO/SimplifyLibCalls.cpp | 25 ++++++++++++------------- 1 file changed, 12 insertions(+), 13 deletions(-) (limited to 'llvm/lib/Transforms') diff --git a/llvm/lib/Transforms/IPO/SimplifyLibCalls.cpp b/llvm/lib/Transforms/IPO/SimplifyLibCalls.cpp index cb5194fea16..5c99a025f0b 100644 --- a/llvm/lib/Transforms/IPO/SimplifyLibCalls.cpp +++ b/llvm/lib/Transforms/IPO/SimplifyLibCalls.cpp @@ -1237,6 +1237,16 @@ 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. @@ -1292,7 +1302,7 @@ public: return false; } - // fprintf(file,fmt) -> fwrite(fmt,strlen(fmt),1file) + // fprintf(file,fmt) -> fwrite(fmt,strlen(fmt),file) const Type* FILEptr_type = ci->getOperand(1)->getType(); Function* fwrite_func = SLC.get_fwrite(FILEptr_type); if (!fwrite_func) @@ -1335,7 +1345,7 @@ public: if (!fwrite_func) return false; std::vector args; - args.push_back(ci->getOperand(3)); + args.push_back(CastToCStr(ci->getOperand(3), *ci)); args.push_back(ConstantUInt::get(SLC.getIntPtrType(),len)); args.push_back(ConstantUInt::get(SLC.getIntPtrType(),1)); args.push_back(ci->getOperand(1)); @@ -1366,17 +1376,6 @@ public: } } FPrintFOptimizer; -/// 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 "sprintf" library /// function. It looks for cases where the result of sprintf is not used and the /// operation can be reduced to something simpler. -- cgit v1.2.3