diff options
Diffstat (limited to 'lib/Transforms')
-rw-r--r-- | lib/Transforms/IPO/MutateStructTypes.cpp | 5 | ||||
-rw-r--r-- | lib/Transforms/IPO/OldPoolAllocate.cpp | 20 | ||||
-rw-r--r-- | lib/Transforms/Scalar/ADCE.cpp | 1 | ||||
-rw-r--r-- | lib/Transforms/Scalar/DecomposeMultiDimRefs.cpp | 13 | ||||
-rw-r--r-- | lib/Transforms/Scalar/GCSE.cpp | 3 | ||||
-rw-r--r-- | lib/Transforms/Scalar/IndVarSimplify.cpp | 5 | ||||
-rw-r--r-- | lib/Transforms/Scalar/LICM.cpp | 1 |
7 files changed, 34 insertions, 14 deletions
diff --git a/lib/Transforms/IPO/MutateStructTypes.cpp b/lib/Transforms/IPO/MutateStructTypes.cpp index 31692f8..4058a3d 100644 --- a/lib/Transforms/IPO/MutateStructTypes.cpp +++ b/lib/Transforms/IPO/MutateStructTypes.cpp @@ -27,6 +27,7 @@ #include "Support/STLExtras.h" #include "Support/StatisticReporter.h" #include <algorithm> +#include <iostream> using std::map; using std::vector; @@ -168,7 +169,7 @@ Value *MutateStructTypes::ConvertValue(const Value *V) { return LocalValueMap[V] = new BasicBlock(BB->getName()); } - DEBUG(cerr << "NPH: " << V << "\n"); + DEBUG(std::cerr << "NPH: " << V << "\n"); // Otherwise make a constant to represent it return LocalValueMap[V] = new ValuePlaceHolder(ConvertType(V->getType())); @@ -227,7 +228,7 @@ void MutateStructTypes::setTransforms(const TransformsType &XForm) { Transforms.insert(std::make_pair(OldTy, std::make_pair(cast<StructType>(NSTy.get()), InVec))); - DEBUG(cerr << "Mutate " << OldTy << "\nTo " << NSTy << "\n"); + DEBUG(std::cerr << "Mutate " << OldTy << "\nTo " << NSTy << "\n"); } } diff --git a/lib/Transforms/IPO/OldPoolAllocate.cpp b/lib/Transforms/IPO/OldPoolAllocate.cpp index 5182df4..ded2c22 100644 --- a/lib/Transforms/IPO/OldPoolAllocate.cpp +++ b/lib/Transforms/IPO/OldPoolAllocate.cpp @@ -24,6 +24,12 @@ #include "Support/DepthFirstIterator.h" #include "Support/STLExtras.h" #include <algorithm> +#include <iostream> +using std::vector; +using std::cerr; +using std::map; +using std::string; +using std::set; // DEBUG_CREATE_POOLS - Enable this to turn on debug output for the pool // creation phase in the top level function of a transformed data structure. @@ -171,7 +177,7 @@ namespace { // argument records, in order. Note that this must be a stable sort so // that the entries with the same sorting criteria (ie they are multiple // pool entries for the same argument) are kept in depth first order. - stable_sort(ArgInfo.begin(), ArgInfo.end()); + std::stable_sort(ArgInfo.begin(), ArgInfo.end()); } // addCallInfo - For a specified function call CI, figure out which pool @@ -335,7 +341,7 @@ bool PoolAllocate::processFunction(Function *F) { // variable sized array allocations and alloca's (which we do not want to // pool allocate) // - Allocs.erase(remove_if(Allocs.begin(), Allocs.end(), isNotPoolableAlloc), + Allocs.erase(std::remove_if(Allocs.begin(), Allocs.end(), isNotPoolableAlloc), Allocs.end()); @@ -771,7 +777,7 @@ public: LI.getOperand(3) == Constant::getNullValue(Type::UByteTy)); // If it is a load of a pool base, keep track of it for future reference - PoolDescMap.insert(make_pair(LoadAddr, &LI)); + PoolDescMap.insert(std::make_pair(LoadAddr, &LI)); ++Remaining; } } @@ -1256,7 +1262,7 @@ void PoolAllocate::transformFunctionBody(Function *F, FunctionDSGraph &IPFGraph, // we can safely delete Arguments whose types have changed... // for_each(InstToFix.begin(), InstToFix.end(), - mem_fun(&Instruction::dropAllReferences)); + std::mem_fun(&Instruction::dropAllReferences)); // Loop through all of the pointer arguments coming into the function, // replacing them with arguments of POINTERTYPE to match the function type of @@ -1475,7 +1481,7 @@ void PoolAllocate::transformFunction(TransformFunctionInfo &TFI, // Add the descriptor. We already know everything about it by now, much // of it is the same as the caller info. // - PoolDescs.insert(make_pair(CalleeNode, + PoolDescs.insert(std::make_pair(CalleeNode, PoolInfo(CalleeNode, CalleeValue, CallerPI.NewType, CallerPI.PoolType))); @@ -1542,7 +1548,7 @@ void PoolAllocate::CreatePools(Function *F, const vector<AllocDSNode*> &Allocs, // except the node & NewType fields. // map<DSNode*, PoolInfo>::iterator PI = - PoolDescs.insert(make_pair(Allocs[i], PoolInfo(Allocs[i]))).first; + PoolDescs.insert(std::make_pair(Allocs[i], PoolInfo(Allocs[i]))).first; // Add a symbol table entry for the new type if there was one for the old // type... @@ -1573,7 +1579,7 @@ void PoolAllocate::CreatePools(Function *F, const vector<AllocDSNode*> &Allocs, CurModule->addTypeName(OldName+".pool", PoolType); // Create the pool type, with opaque values for pointers... - AbsPoolTyMap.insert(make_pair(Allocs[i], PoolType)); + AbsPoolTyMap.insert(std::make_pair(Allocs[i], PoolType)); #ifdef DEBUG_CREATE_POOLS cerr << "POOL TY: " << AbsPoolTyMap.find(Allocs[i])->second.get() << "\n"; #endif diff --git a/lib/Transforms/Scalar/ADCE.cpp b/lib/Transforms/Scalar/ADCE.cpp index 237c458..35189e3 100644 --- a/lib/Transforms/Scalar/ADCE.cpp +++ b/lib/Transforms/Scalar/ADCE.cpp @@ -21,6 +21,7 @@ #include <algorithm> #include <iostream> using std::cerr; +using std::vector; static Statistic<> NumBlockRemoved("adce\t\t- Number of basic blocks removed"); static Statistic<> NumInstRemoved ("adce\t\t- Number of instructions removed"); diff --git a/lib/Transforms/Scalar/DecomposeMultiDimRefs.cpp b/lib/Transforms/Scalar/DecomposeMultiDimRefs.cpp index ab6059a..b180950 100644 --- a/lib/Transforms/Scalar/DecomposeMultiDimRefs.cpp +++ b/lib/Transforms/Scalar/DecomposeMultiDimRefs.cpp @@ -66,6 +66,7 @@ bool DecomposePass::runOnBasicBlock(BasicBlock &BB) { // uses the last ptr2 generated in the loop and a single index. // If any index is (uint) 0, we omit the getElementPtr instruction. // + void DecomposePass::decomposeArrayRef(BasicBlock::iterator &BBI) { MemAccessInst &MAI = cast<MemAccessInst>(*BBI); BasicBlock *BB = MAI.getParent(); @@ -74,10 +75,11 @@ void DecomposePass::decomposeArrayRef(BasicBlock::iterator &BBI) { // Remove the instruction from the stream BB->getInstList().remove(BBI); - vector<Instruction*> NewInsts; + std::vector<Instruction*> NewInsts; // Process each index except the last one. // + User::const_op_iterator OI = MAI.idx_begin(), OE = MAI.idx_end(); for (; OI+1 != OE; ++OI) { assert(isa<PointerType>(LastPtr->getType())); @@ -92,8 +94,10 @@ void DecomposePass::decomposeArrayRef(BasicBlock::iterator &BBI) { // and the next index is a structure offset (i.e., not an array offset), // we need to include an initial [0] to index into the pointer. // - vector<Value*> Indices; + + std::vector<Value*> Indices; const PointerType *PtrTy = cast<PointerType>(LastPtr->getType()); + if (isa<StructType>(PtrTy->getElementType()) && !PtrTy->indexValid(*OI)) Indices.push_back(Constant::getNullValue(Type::UIntTy)); @@ -117,6 +121,7 @@ void DecomposePass::decomposeArrayRef(BasicBlock::iterator &BBI) { NewInsts.push_back(cast<Instruction>(LastPtr)); ++NumAdded; } + // Instruction 2: nextPtr2 = cast nextPtr1 to NextPtrTy // This is not needed if the two types are identical. @@ -134,7 +139,8 @@ void DecomposePass::decomposeArrayRef(BasicBlock::iterator &BBI) { const PointerType *PtrTy = cast<PointerType>(LastPtr->getType()); // First, get the final index vector. As above, we may need an initial [0]. - vector<Value*> Indices; + + std::vector<Value*> Indices; if (isa<StructType>(PtrTy->getElementType()) && !PtrTy->indexValid(*OI)) Indices.push_back(Constant::getNullValue(Type::UIntTy)); @@ -156,6 +162,7 @@ void DecomposePass::decomposeArrayRef(BasicBlock::iterator &BBI) { assert(0 && "Unrecognized memory access instruction"); } NewInsts.push_back(NewI); + // Replace all uses of the old instruction with the new MAI.replaceAllUsesWith(NewI); diff --git a/lib/Transforms/Scalar/GCSE.cpp b/lib/Transforms/Scalar/GCSE.cpp index 850e65a..56bb191 100644 --- a/lib/Transforms/Scalar/GCSE.cpp +++ b/lib/Transforms/Scalar/GCSE.cpp @@ -23,6 +23,9 @@ #include "llvm/Support/CFG.h" #include "Support/StatisticReporter.h" #include <algorithm> +using std::set; +using std::map; + static Statistic<> NumInstRemoved("gcse\t\t- Number of instructions removed"); static Statistic<> NumLoadRemoved("gcse\t\t- Number of loads removed"); diff --git a/lib/Transforms/Scalar/IndVarSimplify.cpp b/lib/Transforms/Scalar/IndVarSimplify.cpp index 7a32315..4913a89 100644 --- a/lib/Transforms/Scalar/IndVarSimplify.cpp +++ b/lib/Transforms/Scalar/IndVarSimplify.cpp @@ -16,6 +16,7 @@ #include "llvm/Support/CFG.h" #include "Support/STLExtras.h" #include "Support/StatisticReporter.h" +#include <iostream> static Statistic<> NumRemoved ("indvars\t\t- Number of aux indvars removed"); static Statistic<> NumInserted("indvars\t\t- Number of cannonical indvars added"); @@ -114,7 +115,7 @@ static bool TransformLoop(LoopInfo *Loops, Loop *Loop) { Changed = true; } - DEBUG(cerr << "Induction variables:\n"); + DEBUG(std::cerr << "Induction variables:\n"); // Get the current loop iteration count, which is always the value of the // cannonical phi node... @@ -127,7 +128,7 @@ static bool TransformLoop(LoopInfo *Loops, Loop *Loop) { for (unsigned i = 0; i < IndVars.size(); ++i) { InductionVariable *IV = &IndVars[i]; - DEBUG(cerr << IV); + DEBUG(std::cerr << IV); // Don't modify the cannonical indvar or unrecognized indvars... if (IV != Cannonical && IV->InductionType != InductionVariable::Unknown) { diff --git a/lib/Transforms/Scalar/LICM.cpp b/lib/Transforms/Scalar/LICM.cpp index 98de447..99ee45e 100644 --- a/lib/Transforms/Scalar/LICM.cpp +++ b/lib/Transforms/Scalar/LICM.cpp @@ -25,6 +25,7 @@ #include "Support/STLExtras.h" #include "Support/StatisticReporter.h" #include <algorithm> +using std::string; static Statistic<> NumHoistedNPH("licm\t\t- Number of insts hoisted to multiple" " loop preds (bad, no loop pre-header)"); |