diff options
Diffstat (limited to 'contrib/llvm/lib/Transforms/IPO/MergeFunctions.cpp')
-rw-r--r-- | contrib/llvm/lib/Transforms/IPO/MergeFunctions.cpp | 77 |
1 files changed, 38 insertions, 39 deletions
diff --git a/contrib/llvm/lib/Transforms/IPO/MergeFunctions.cpp b/contrib/llvm/lib/Transforms/IPO/MergeFunctions.cpp index 2fb0ddb..b91ebf2 100644 --- a/contrib/llvm/lib/Transforms/IPO/MergeFunctions.cpp +++ b/contrib/llvm/lib/Transforms/IPO/MergeFunctions.cpp @@ -286,7 +286,7 @@ private: /// 6.4.Load: range metadata (as integer numbers) /// On this stage its better to see the code, since its not more than 10-15 /// strings for particular instruction, and could change sometimes. - int cmpOperation(const Instruction *L, const Instruction *R) const; + int cmpOperations(const Instruction *L, const Instruction *R) const; /// Compare two GEPs for equivalent pointer arithmetic. /// Parts to be compared for each comparison stage, @@ -297,9 +297,9 @@ private: /// 3. Pointer operand type (using cmpType method). /// 4. Number of operands. /// 5. Compare operands, using cmpValues method. - int cmpGEP(const GEPOperator *GEPL, const GEPOperator *GEPR); - int cmpGEP(const GetElementPtrInst *GEPL, const GetElementPtrInst *GEPR) { - return cmpGEP(cast<GEPOperator>(GEPL), cast<GEPOperator>(GEPR)); + int cmpGEPs(const GEPOperator *GEPL, const GEPOperator *GEPR); + int cmpGEPs(const GetElementPtrInst *GEPL, const GetElementPtrInst *GEPR) { + return cmpGEPs(cast<GEPOperator>(GEPL), cast<GEPOperator>(GEPR)); } /// cmpType - compares two types, @@ -342,12 +342,12 @@ private: /// be checked with the same way. If we get Res != 0 on some stage, return it. /// Otherwise return 0. /// 6. For all other cases put llvm_unreachable. - int cmpType(Type *TyL, Type *TyR) const; + int cmpTypes(Type *TyL, Type *TyR) const; int cmpNumbers(uint64_t L, uint64_t R) const; - int cmpAPInt(const APInt &L, const APInt &R) const; - int cmpAPFloat(const APFloat &L, const APFloat &R) const; + int cmpAPInts(const APInt &L, const APInt &R) const; + int cmpAPFloats(const APFloat &L, const APFloat &R) const; int cmpStrings(StringRef L, StringRef R) const; int cmpAttrs(const AttributeSet L, const AttributeSet R) const; @@ -392,15 +392,15 @@ private: DenseMap<const Value*, int> sn_mapL, sn_mapR; }; -class FunctionPtr { +class FunctionNode { AssertingVH<Function> F; const DataLayout *DL; public: - FunctionPtr(Function *F, const DataLayout *DL) : F(F), DL(DL) {} + FunctionNode(Function *F, const DataLayout *DL) : F(F), DL(DL) {} Function *getFunc() const { return F; } void release() { F = 0; } - bool operator<(const FunctionPtr &RHS) const { + bool operator<(const FunctionNode &RHS) const { return (FunctionComparator(DL, F, RHS.getFunc()).compare()) == -1; } }; @@ -412,7 +412,7 @@ int FunctionComparator::cmpNumbers(uint64_t L, uint64_t R) const { return 0; } -int FunctionComparator::cmpAPInt(const APInt &L, const APInt &R) const { +int FunctionComparator::cmpAPInts(const APInt &L, const APInt &R) const { if (int Res = cmpNumbers(L.getBitWidth(), R.getBitWidth())) return Res; if (L.ugt(R)) return 1; @@ -420,11 +420,11 @@ int FunctionComparator::cmpAPInt(const APInt &L, const APInt &R) const { return 0; } -int FunctionComparator::cmpAPFloat(const APFloat &L, const APFloat &R) const { +int FunctionComparator::cmpAPFloats(const APFloat &L, const APFloat &R) const { if (int Res = cmpNumbers((uint64_t)&L.getSemantics(), (uint64_t)&R.getSemantics())) return Res; - return cmpAPInt(L.bitcastToAPInt(), R.bitcastToAPInt()); + return cmpAPInts(L.bitcastToAPInt(), R.bitcastToAPInt()); } int FunctionComparator::cmpStrings(StringRef L, StringRef R) const { @@ -474,7 +474,7 @@ int FunctionComparator::cmpConstants(const Constant *L, const Constant *R) { // Check whether types are bitcastable. This part is just re-factored // Type::canLosslesslyBitCastTo method, but instead of returning true/false, // we also pack into result which type is "less" for us. - int TypesRes = cmpType(TyL, TyR); + int TypesRes = cmpTypes(TyL, TyR); if (TypesRes != 0) { // Types are different, but check whether we can bitcast them. if (!TyL->isFirstClassType()) { @@ -541,12 +541,12 @@ int FunctionComparator::cmpConstants(const Constant *L, const Constant *R) { case Value::ConstantIntVal: { const APInt &LInt = cast<ConstantInt>(L)->getValue(); const APInt &RInt = cast<ConstantInt>(R)->getValue(); - return cmpAPInt(LInt, RInt); + return cmpAPInts(LInt, RInt); } case Value::ConstantFPVal: { const APFloat &LAPF = cast<ConstantFP>(L)->getValueAPF(); const APFloat &RAPF = cast<ConstantFP>(R)->getValueAPF(); - return cmpAPFloat(LAPF, RAPF); + return cmpAPFloats(LAPF, RAPF); } case Value::ConstantArrayVal: { const ConstantArray *LA = cast<ConstantArray>(L); @@ -615,7 +615,7 @@ int FunctionComparator::cmpConstants(const Constant *L, const Constant *R) { /// cmpType - compares two types, /// defines total ordering among the types set. /// See method declaration comments for more details. -int FunctionComparator::cmpType(Type *TyL, Type *TyR) const { +int FunctionComparator::cmpTypes(Type *TyL, Type *TyR) const { PointerType *PTyL = dyn_cast<PointerType>(TyL); PointerType *PTyR = dyn_cast<PointerType>(TyR); @@ -665,8 +665,7 @@ int FunctionComparator::cmpType(Type *TyL, Type *TyR) const { return cmpNumbers(STyL->isPacked(), STyR->isPacked()); for (unsigned i = 0, e = STyL->getNumElements(); i != e; ++i) { - if (int Res = cmpType(STyL->getElementType(i), - STyR->getElementType(i))) + if (int Res = cmpTypes(STyL->getElementType(i), STyR->getElementType(i))) return Res; } return 0; @@ -681,11 +680,11 @@ int FunctionComparator::cmpType(Type *TyL, Type *TyR) const { if (FTyL->isVarArg() != FTyR->isVarArg()) return cmpNumbers(FTyL->isVarArg(), FTyR->isVarArg()); - if (int Res = cmpType(FTyL->getReturnType(), FTyR->getReturnType())) + if (int Res = cmpTypes(FTyL->getReturnType(), FTyR->getReturnType())) return Res; for (unsigned i = 0, e = FTyL->getNumParams(); i != e; ++i) { - if (int Res = cmpType(FTyL->getParamType(i), FTyR->getParamType(i))) + if (int Res = cmpTypes(FTyL->getParamType(i), FTyR->getParamType(i))) return Res; } return 0; @@ -696,7 +695,7 @@ int FunctionComparator::cmpType(Type *TyL, Type *TyR) const { ArrayType *ATyR = cast<ArrayType>(TyR); if (ATyL->getNumElements() != ATyR->getNumElements()) return cmpNumbers(ATyL->getNumElements(), ATyR->getNumElements()); - return cmpType(ATyL->getElementType(), ATyR->getElementType()); + return cmpTypes(ATyL->getElementType(), ATyR->getElementType()); } } } @@ -705,8 +704,8 @@ int FunctionComparator::cmpType(Type *TyL, Type *TyR) const { // and pointer-to-B are equivalent. This should be kept in sync with // Instruction::isSameOperationAs. // Read method declaration comments for more details. -int FunctionComparator::cmpOperation(const Instruction *L, - const Instruction *R) const { +int FunctionComparator::cmpOperations(const Instruction *L, + const Instruction *R) const { // Differences from Instruction::isSameOperationAs: // * replace type comparison with calls to isEquivalentType. // * we test for I->hasSameSubclassOptionalData (nuw/nsw/tail) at the top @@ -717,7 +716,7 @@ int FunctionComparator::cmpOperation(const Instruction *L, if (int Res = cmpNumbers(L->getNumOperands(), R->getNumOperands())) return Res; - if (int Res = cmpType(L->getType(), R->getType())) + if (int Res = cmpTypes(L->getType(), R->getType())) return Res; if (int Res = cmpNumbers(L->getRawSubclassOptionalData(), @@ -728,7 +727,7 @@ int FunctionComparator::cmpOperation(const Instruction *L, // if all operands are the same type for (unsigned i = 0, e = L->getNumOperands(); i != e; ++i) { if (int Res = - cmpType(L->getOperand(i)->getType(), R->getOperand(i)->getType())) + cmpTypes(L->getOperand(i)->getType(), R->getOperand(i)->getType())) return Res; } @@ -845,7 +844,7 @@ int FunctionComparator::cmpOperation(const Instruction *L, // Determine whether two GEP operations perform the same underlying arithmetic. // Read method declaration comments for more details. -int FunctionComparator::cmpGEP(const GEPOperator *GEPL, +int FunctionComparator::cmpGEPs(const GEPOperator *GEPL, const GEPOperator *GEPR) { unsigned int ASL = GEPL->getPointerAddressSpace(); @@ -861,7 +860,7 @@ int FunctionComparator::cmpGEP(const GEPOperator *GEPL, APInt OffsetL(BitWidth, 0), OffsetR(BitWidth, 0); if (GEPL->accumulateConstantOffset(*DL, OffsetL) && GEPR->accumulateConstantOffset(*DL, OffsetR)) - return cmpAPInt(OffsetL, OffsetR); + return cmpAPInts(OffsetL, OffsetR); } if (int Res = cmpNumbers((uint64_t)GEPL->getPointerOperand()->getType(), @@ -945,10 +944,10 @@ int FunctionComparator::compare(const BasicBlock *BBL, const BasicBlock *BBR) { if (int Res = cmpValues(GEPL->getPointerOperand(), GEPR->getPointerOperand())) return Res; - if (int Res = cmpGEP(GEPL, GEPR)) + if (int Res = cmpGEPs(GEPL, GEPR)) return Res; } else { - if (int Res = cmpOperation(InstL, InstR)) + if (int Res = cmpOperations(InstL, InstR)) return Res; assert(InstL->getNumOperands() == InstR->getNumOperands()); @@ -960,7 +959,7 @@ int FunctionComparator::compare(const BasicBlock *BBL, const BasicBlock *BBR) { if (int Res = cmpNumbers(OpL->getValueID(), OpR->getValueID())) return Res; // TODO: Already checked in cmpOperation - if (int Res = cmpType(OpL->getType(), OpR->getType())) + if (int Res = cmpTypes(OpL->getType(), OpR->getType())) return Res; } } @@ -1008,7 +1007,7 @@ int FunctionComparator::compare() { if (int Res = cmpNumbers(FnL->getCallingConv(), FnR->getCallingConv())) return Res; - if (int Res = cmpType(FnL->getFunctionType(), FnR->getFunctionType())) + if (int Res = cmpTypes(FnL->getFunctionType(), FnR->getFunctionType())) return Res; assert(FnL->arg_size() == FnR->arg_size() && @@ -1050,7 +1049,7 @@ int FunctionComparator::compare() { assert(TermL->getNumSuccessors() == TermR->getNumSuccessors()); for (unsigned i = 0, e = TermL->getNumSuccessors(); i != e; ++i) { - if (!VisitedBBs.insert(TermL->getSuccessor(i))) + if (!VisitedBBs.insert(TermL->getSuccessor(i)).second) continue; FnLBBs.push_back(TermL->getSuccessor(i)); @@ -1078,7 +1077,7 @@ public: bool runOnModule(Module &M) override; private: - typedef std::set<FunctionPtr> FnTreeType; + typedef std::set<FunctionNode> FnTreeType; /// A work queue of functions that may have been modified and should be /// analyzed again. @@ -1301,11 +1300,11 @@ static Value *createCast(IRBuilder<false> &Builder, Value *V, Type *DestTy) { Value *Result = UndefValue::get(DestTy); for (unsigned int I = 0, E = SrcTy->getStructNumElements(); I < E; ++I) { Value *Element = createCast( - Builder, Builder.CreateExtractValue(V, ArrayRef<unsigned int>(I)), + Builder, Builder.CreateExtractValue(V, makeArrayRef(I)), DestTy->getStructElementType(I)); Result = - Builder.CreateInsertValue(Result, Element, ArrayRef<unsigned int>(I)); + Builder.CreateInsertValue(Result, Element, makeArrayRef(I)); } return Result; } @@ -1421,14 +1420,14 @@ void MergeFunctions::mergeTwoFunctions(Function *F, Function *G) { // that was already inserted. bool MergeFunctions::insert(Function *NewFunction) { std::pair<FnTreeType::iterator, bool> Result = - FnTree.insert(FunctionPtr(NewFunction, DL)); + FnTree.insert(FunctionNode(NewFunction, DL)); if (Result.second) { DEBUG(dbgs() << "Inserting as unique: " << NewFunction->getName() << '\n'); return false; } - const FunctionPtr &OldF = *Result.first; + const FunctionNode &OldF = *Result.first; // Don't merge tiny functions, since it can just end up making the function // larger. @@ -1458,7 +1457,7 @@ bool MergeFunctions::insert(Function *NewFunction) { void MergeFunctions::remove(Function *F) { // We need to make sure we remove F, not a function "equal" to F per the // function equality comparator. - FnTreeType::iterator found = FnTree.find(FunctionPtr(F, DL)); + FnTreeType::iterator found = FnTree.find(FunctionNode(F, DL)); size_t Erased = 0; if (found != FnTree.end() && found->getFunc() == F) { Erased = 1; |