diff --git a/bolt/include/bolt/Core/BinaryBasicBlock.h b/bolt/include/bolt/Core/BinaryBasicBlock.h --- a/bolt/include/bolt/Core/BinaryBasicBlock.h +++ b/bolt/include/bolt/Core/BinaryBasicBlock.h @@ -634,14 +634,12 @@ /// Test if BB is a predecessor of this block. bool isPredecessor(const BinaryBasicBlock *BB) const { - auto Itr = std::find(Predecessors.begin(), Predecessors.end(), BB); - return Itr != Predecessors.end(); + return is_contained(Predecessors, BB); } /// Test if BB is a successor of this block. bool isSuccessor(const BinaryBasicBlock *BB) const { - auto Itr = std::find(Successors.begin(), Successors.end(), BB); - return Itr != Successors.end(); + return is_contained(Successors, BB); } /// Test if this BB has a valid execution count. diff --git a/bolt/include/bolt/Core/BinaryData.h b/bolt/include/bolt/Core/BinaryData.h --- a/bolt/include/bolt/Core/BinaryData.h +++ b/bolt/include/bolt/Core/BinaryData.h @@ -112,7 +112,7 @@ bool nameStartsWith(StringRef Prefix) const; bool hasSymbol(const MCSymbol *Symbol) const { - return std::find(Symbols.begin(), Symbols.end(), Symbol) != Symbols.end(); + return is_contained(Symbols, Symbol); } bool isAbsolute() const; diff --git a/bolt/include/bolt/Core/BinaryFunction.h b/bolt/include/bolt/Core/BinaryFunction.h --- a/bolt/include/bolt/Core/BinaryFunction.h +++ b/bolt/include/bolt/Core/BinaryFunction.h @@ -716,9 +716,8 @@ BB->setOffset(Offset); BasicBlockOffsets.emplace_back(Offset, BB); - assert(std::is_sorted(BasicBlockOffsets.begin(), BasicBlockOffsets.end(), - CompareBasicBlockOffsets()) && - std::is_sorted(begin(), end())); + assert(is_sorted(BasicBlockOffsets, CompareBasicBlockOffsets()) && + is_sorted(blocks())); return BB; } diff --git a/bolt/lib/Core/BinaryBasicBlock.cpp b/bolt/lib/Core/BinaryBasicBlock.cpp --- a/bolt/lib/Core/BinaryBasicBlock.cpp +++ b/bolt/lib/Core/BinaryBasicBlock.cpp @@ -544,7 +544,7 @@ } if (TotalCount > 0) { - auto Itr = std::find(Successors.begin(), Successors.end(), Succ); + auto Itr = find(Successors, Succ); assert(Itr != Successors.end()); const BinaryBranchInfo &BI = BranchInfo[Itr - Successors.begin()]; if (BI.Count && BI.Count != COUNT_NO_PROFILE) { diff --git a/bolt/lib/Core/BinaryContext.cpp b/bolt/lib/Core/BinaryContext.cpp --- a/bolt/lib/Core/BinaryContext.cpp +++ b/bolt/lib/Core/BinaryContext.cpp @@ -718,9 +718,8 @@ BF->setSimple(false); BF->setHasSplitJumpTable(true); - std::for_each(BF->Fragments.begin(), BF->Fragments.end(), addToWorklist); - std::for_each(BF->ParentFragments.begin(), BF->ParentFragments.end(), - addToWorklist); + for_each(BF->Fragments, addToWorklist); + for_each(BF->ParentFragments, addToWorklist); } if (!FragmentsToSkip.empty()) errs() << "BOLT-WARNING: skipped " << FragmentsToSkip.size() << " function" @@ -1059,10 +1058,9 @@ // First check if a non-anonymous alias exists and move it to the front. if (BD.getSymbols().size() > 1) { - auto Itr = std::find_if(BD.getSymbols().begin(), BD.getSymbols().end(), - [&](const MCSymbol *Symbol) { - return !isInternalSymbolName(Symbol->getName()); - }); + auto Itr = find_if(BD.getSymbols(), [&](const MCSymbol *Symbol) { + return !isInternalSymbolName(Symbol->getName()); + }); if (Itr != BD.getSymbols().end()) { size_t Idx = std::distance(BD.getSymbols().begin(), Itr); std::swap(BD.getSymbols()[0], BD.getSymbols()[Idx]); @@ -1224,8 +1222,7 @@ ChildBF.getSymbols().clear(); // Move other names the child function is known under. - std::move(ChildBF.Aliases.begin(), ChildBF.Aliases.end(), - std::back_inserter(ParentBF.Aliases)); + move(ChildBF.Aliases, std::back_inserter(ParentBF.Aliases)); ChildBF.Aliases.clear(); if (HasRelocations) { @@ -1392,32 +1389,29 @@ std::vector BinaryContext::getSortedFunctions() { std::vector SortedFunctions(BinaryFunctions.size()); - std::transform(BinaryFunctions.begin(), BinaryFunctions.end(), - SortedFunctions.begin(), - [](std::pair &BFI) { - return &BFI.second; - }); - - std::stable_sort(SortedFunctions.begin(), SortedFunctions.end(), - [](const BinaryFunction *A, const BinaryFunction *B) { - if (A->hasValidIndex() && B->hasValidIndex()) { - return A->getIndex() < B->getIndex(); - } - return A->hasValidIndex(); - }); + transform(BinaryFunctions, SortedFunctions.begin(), + [](std::pair &BFI) { + return &BFI.second; + }); + + stable_sort(SortedFunctions, + [](const BinaryFunction *A, const BinaryFunction *B) { + if (A->hasValidIndex() && B->hasValidIndex()) { + return A->getIndex() < B->getIndex(); + } + return A->hasValidIndex(); + }); return SortedFunctions; } std::vector BinaryContext::getAllBinaryFunctions() { std::vector AllFunctions; AllFunctions.reserve(BinaryFunctions.size() + InjectedBinaryFunctions.size()); - std::transform(BinaryFunctions.begin(), BinaryFunctions.end(), - std::back_inserter(AllFunctions), - [](std::pair &BFI) { - return &BFI.second; - }); - std::copy(InjectedBinaryFunctions.begin(), InjectedBinaryFunctions.end(), - std::back_inserter(AllFunctions)); + transform(BinaryFunctions, std::back_inserter(AllFunctions), + [](std::pair &BFI) { + return &BFI.second; + }); + copy(InjectedBinaryFunctions, std::back_inserter(AllFunctions)); return AllFunctions; } @@ -1494,17 +1488,15 @@ llvm::errs() << "BOLT-WARNING: BOLT does not support mix mode binary with " "DWARF5 and DWARF{2,3,4}.\n"; - std::sort(AllRanges.begin(), AllRanges.end()); + sort(AllRanges); for (auto &KV : BinaryFunctions) { const uint64_t FunctionAddress = KV.first; BinaryFunction &Function = KV.second; - auto It = std::partition_point( - AllRanges.begin(), AllRanges.end(), - [=](CURange R) { return R.HighPC <= FunctionAddress; }); - if (It != AllRanges.end() && It->LowPC <= FunctionAddress) { + auto It = partition_point( + AllRanges, [=](CURange R) { return R.HighPC <= FunctionAddress; }); + if (It != AllRanges.end() && It->LowPC <= FunctionAddress) Function.setDWARFUnit(It->Unit); - } } // Discover units with debug info that needs to be updated. @@ -2218,8 +2210,7 @@ break; const DebugAddressRangesVector FunctionRanges = Function.getOutputAddressRanges(); - std::move(std::begin(FunctionRanges), std::end(FunctionRanges), - std::back_inserter(OutputRanges)); + move(FunctionRanges, std::back_inserter(OutputRanges)); std::advance(BFI, 1); } } diff --git a/bolt/lib/Core/BinaryEmitter.cpp b/bolt/lib/Core/BinaryEmitter.cpp --- a/bolt/lib/Core/BinaryEmitter.cpp +++ b/bolt/lib/Core/BinaryEmitter.cpp @@ -333,8 +333,7 @@ // Only write CIE CFI insns that LLVM will not already emit const std::vector &FrameInstrs = MAI->getInitialFrameState(); - if (std::find(FrameInstrs.begin(), FrameInstrs.end(), CFIInstr) == - FrameInstrs.end()) + if (!is_contained(FrameInstrs, CFIInstr)) emitCFIInstruction(CFIInstr); } } @@ -1089,7 +1088,7 @@ StmtListOffsets.push_back(*StmtList); } - std::sort(StmtListOffsets.begin(), StmtListOffsets.end()); + sort(StmtListOffsets); // For each CU that was not processed, emit its line info as a binary blob. for (const std::unique_ptr &CU : BC.DwCtx->compile_units()) { @@ -1107,8 +1106,7 @@ // Statement list ends where the next unit contribution begins, or at the // end of the section. - auto It = - std::upper_bound(StmtListOffsets.begin(), StmtListOffsets.end(), Begin); + auto It = upper_bound(StmtListOffsets, Begin); const uint64_t End = It == StmtListOffsets.end() ? DebugLineContents.size() : *It; diff --git a/bolt/lib/Core/BinaryFunction.cpp b/bolt/lib/Core/BinaryFunction.cpp --- a/bolt/lib/Core/BinaryFunction.cpp +++ b/bolt/lib/Core/BinaryFunction.cpp @@ -281,9 +281,8 @@ * BasicBlockOffsets.end(), * CompareBasicBlockOffsets()))); */ - auto I = std::upper_bound(BasicBlockOffsets.begin(), BasicBlockOffsets.end(), - BasicBlockOffset(Offset, nullptr), - CompareBasicBlockOffsets()); + auto I = upper_bound(BasicBlockOffsets, BasicBlockOffset(Offset, nullptr), + CompareBasicBlockOffsets()); assert(I != BasicBlockOffsets.begin() && "first basic block not at offset 0"); --I; BinaryBasicBlock *BB = I->second; @@ -561,10 +560,9 @@ std::vector Indices(BB->succ_size()); std::iota(Indices.begin(), Indices.end(), 0); if (BB->succ_size() > 2 && BB->getKnownExecutionCount()) { - std::stable_sort(Indices.begin(), Indices.end(), - [&](const uint64_t A, const uint64_t B) { - return BB->BranchInfo[B] < BB->BranchInfo[A]; - }); + stable_sort(Indices, [&](const uint64_t A, const uint64_t B) { + return BB->BranchInfo[B] < BB->BranchInfo[A]; + }); } ListSeparator LS; for (unsigned I = 0; I < Indices.size(); ++I) { @@ -1718,7 +1716,7 @@ // Remove duplicates branches. We can get a bunch of them from jump tables. // Without doing jump table value profiling we don't have use for extra // (duplicate) branches. - std::sort(TakenBranches.begin(), TakenBranches.end()); + sort(TakenBranches); auto NewEnd = std::unique(TakenBranches.begin(), TakenBranches.end()); TakenBranches.erase(NewEnd, TakenBranches.end()); } @@ -3003,8 +3001,7 @@ << "node [fontname=courier, shape=box, style=filled, colorscheme=brbg9]\n"; uint64_t Offset = Address; for (BinaryBasicBlock *BB : BasicBlocks) { - auto LayoutPos = - std::find(BasicBlocksLayout.begin(), BasicBlocksLayout.end(), BB); + auto LayoutPos = find(BasicBlocksLayout, BB); unsigned Layout = LayoutPos - BasicBlocksLayout.begin(); const char *ColdStr = BB->isCold() ? " (cold)" : ""; std::vector Attrs; @@ -3187,8 +3184,7 @@ } for (const BinaryBasicBlock *LPBlock : BB->landing_pads()) { - if (std::find(LPBlock->throw_begin(), LPBlock->throw_end(), BB) == - LPBlock->throw_end()) { + if (!is_contained(LPBlock->throwers(), BB)) { errs() << "BOLT-ERROR: inconsistent landing pad detected in " << *this << ": " << BB->getName() << " is in LandingPads but not in " << LPBlock->getName() << " Throwers\n"; @@ -3196,8 +3192,7 @@ } } for (const BinaryBasicBlock *Thrower : BB->throwers()) { - if (std::find(Thrower->lp_begin(), Thrower->lp_end(), BB) == - Thrower->lp_end()) { + if (!is_contained(Thrower->landing_pads(), BB)) { errs() << "BOLT-ERROR: inconsistent thrower detected in " << *this << ": " << BB->getName() << " is in Throwers list but not in " << Thrower->getName() << " LandingPads\n"; @@ -3670,7 +3665,7 @@ } // Insert new blocks in the layout immediately after Start. - auto Pos = std::find(layout_begin(), layout_end(), Start); + auto Pos = find(layout(), Start); assert(Pos != layout_end()); BasicBlockListType::iterator Begin = std::next(BasicBlocks.begin(), getIndex(Start) + 1); @@ -4184,10 +4179,10 @@ // If the function hasn't changed return the same ranges. if (!isEmitted()) { OutputRanges.resize(InputRanges.size()); - std::transform(InputRanges.begin(), InputRanges.end(), OutputRanges.begin(), - [](const DWARFAddressRange &Range) { - return DebugAddressRange(Range.LowPC, Range.HighPC); - }); + transform(InputRanges, OutputRanges.begin(), + [](const DWARFAddressRange &Range) { + return DebugAddressRange(Range.LowPC, Range.HighPC); + }); return OutputRanges; } @@ -4207,9 +4202,9 @@ const uint64_t InputEndOffset = std::min(Range.HighPC - getAddress(), getSize()); - auto BBI = std::upper_bound( - BasicBlockOffsets.begin(), BasicBlockOffsets.end(), - BasicBlockOffset(InputOffset, nullptr), CompareBasicBlockOffsets()); + auto BBI = + upper_bound(BasicBlockOffsets, BasicBlockOffset(InputOffset, nullptr), + CompareBasicBlockOffsets()); --BBI; do { const BinaryBasicBlock *BB = BBI->second; @@ -4246,7 +4241,7 @@ } // Post-processing pass to sort and merge ranges. - std::sort(OutputRanges.begin(), OutputRanges.end()); + sort(OutputRanges); DebugAddressRangesVector MergedRanges; PrevEndAddress = 0; for (const DebugAddressRange &Range : OutputRanges) { @@ -4315,9 +4310,9 @@ } uint64_t InputOffset = Start - getAddress(); const uint64_t InputEndOffset = std::min(End - getAddress(), getSize()); - auto BBI = std::upper_bound( - BasicBlockOffsets.begin(), BasicBlockOffsets.end(), - BasicBlockOffset(InputOffset, nullptr), CompareBasicBlockOffsets()); + auto BBI = + upper_bound(BasicBlockOffsets, BasicBlockOffset(InputOffset, nullptr), + CompareBasicBlockOffsets()); --BBI; do { const BinaryBasicBlock *BB = BBI->second; @@ -4354,11 +4349,10 @@ } // Sort and merge adjacent entries with identical location. - std::stable_sort( - OutputLL.begin(), OutputLL.end(), - [](const DebugLocationEntry &A, const DebugLocationEntry &B) { - return A.LowPC < B.LowPC; - }); + stable_sort(OutputLL, + [](const DebugLocationEntry &A, const DebugLocationEntry &B) { + return A.LowPC < B.LowPC; + }); DebugLocationsVector MergedLL; PrevEndAddress = 0; PrevExpr = nullptr; diff --git a/bolt/lib/Core/DebugData.cpp b/bolt/lib/Core/DebugData.cpp --- a/bolt/lib/Core/DebugData.cpp +++ b/bolt/lib/Core/DebugData.cpp @@ -313,10 +313,9 @@ std::vector SortedMap(indexToAddressBegin(), indexToAdddessEnd()); // Sorting address in increasing order of indices. - std::sort(SortedMap.begin(), SortedMap.end(), - [](const IndexAddressPair &A, const IndexAddressPair &B) { - return A.first < B.first; - }); + sort(SortedMap, [](const IndexAddressPair &A, const IndexAddressPair &B) { + return A.first < B.first; + }); for (auto &Pair : SortedMap) dbgs() << Twine::utohexstr(Pair.second) << "\t" << Pair.first << "\n"; } @@ -375,10 +374,9 @@ std::vector SortedMap(AM->second.indexToAddressBegin(), AM->second.indexToAdddessEnd()); // Sorting address in increasing order of indices. - std::sort(SortedMap.begin(), SortedMap.end(), - [](const IndexAddressPair &A, const IndexAddressPair &B) { - return A.first < B.first; - }); + sort(SortedMap, [](const IndexAddressPair &A, const IndexAddressPair &B) { + return A.first < B.first; + }); uint8_t AddrSize = CU->getAddressByteSize(); uint32_t Counter = 0; @@ -449,10 +447,9 @@ AMIter->second.indexToAddressBegin(), AMIter->second.indexToAdddessEnd()); // Sorting address in increasing order of indices. - std::sort(SortedMap.begin(), SortedMap.end(), - [](const IndexAddressPair &A, const IndexAddressPair &B) { - return A.first < B.first; - }); + sort(SortedMap, [](const IndexAddressPair &A, const IndexAddressPair &B) { + return A.first < B.first; + }); // Writing out Header const uint32_t Length = SortedMap.size() * AddrSize + 4; support::endian::write(AddressStream, Length, Endian); @@ -841,22 +838,20 @@ CUOffsetMap DebugInfoBinaryPatcher::computeNewOffsets(DWARFContext &DWCtx, bool IsDWOContext) { CUOffsetMap CUMap; - std::sort(DebugPatches.begin(), DebugPatches.end(), - [](const UniquePatchPtrType &V1, const UniquePatchPtrType &V2) { - if (V1.get()->Offset == V2.get()->Offset) { - if (V1->Kind == DebugPatchKind::NewDebugEntry && - V2->Kind == DebugPatchKind::NewDebugEntry) - return reinterpret_cast(V1.get()) - ->CurrentOrder < - reinterpret_cast(V2.get()) - ->CurrentOrder; - - // This is a case where we are modifying first entry of next - // DIE, and adding a new one. - return V1->Kind == DebugPatchKind::NewDebugEntry; - } - return V1.get()->Offset < V2.get()->Offset; - }); + sort(DebugPatches, [](const UniquePatchPtrType &V1, + const UniquePatchPtrType &V2) { + if (V1.get()->Offset == V2.get()->Offset) { + if (V1->Kind == DebugPatchKind::NewDebugEntry && + V2->Kind == DebugPatchKind::NewDebugEntry) + return reinterpret_cast(V1.get())->CurrentOrder < + reinterpret_cast(V2.get())->CurrentOrder; + + // This is a case where we are modifying first entry of next + // DIE, and adding a new one. + return V1->Kind == DebugPatchKind::NewDebugEntry; + } + return V1.get()->Offset < V2.get()->Offset; + }); DWARFUnitVector::compile_unit_range CompileUnits = IsDWOContext ? DWCtx.dwo_compile_units() : DWCtx.compile_units(); diff --git a/bolt/lib/Core/DynoStats.cpp b/bolt/lib/Core/DynoStats.cpp --- a/bolt/lib/Core/DynoStats.cpp +++ b/bolt/lib/Core/DynoStats.cpp @@ -107,7 +107,7 @@ SortedHistogram.emplace_back(Stat.second.first, Stat.first); // Sort using lexicographic ordering - std::sort(SortedHistogram.begin(), SortedHistogram.end()); + sort(SortedHistogram); // Dump in ascending order: Start with Opcode with Highest execution // count. diff --git a/bolt/lib/Core/Exceptions.cpp b/bolt/lib/Core/Exceptions.cpp --- a/bolt/lib/Core/Exceptions.cpp +++ b/bolt/lib/Core/Exceptions.cpp @@ -657,7 +657,7 @@ std::map PCToFDE; // Presort array for binary search. - std::sort(FailedAddresses.begin(), FailedAddresses.end()); + sort(FailedAddresses); // Initialize PCToFDE using NewEHFrame. for (dwarf::FrameEntry &Entry : NewEHFrame.entries()) { @@ -683,9 +683,7 @@ }; LLVM_DEBUG(dbgs() << "BOLT-DEBUG: new .eh_frame contains " - << std::distance(NewEHFrame.entries().begin(), - NewEHFrame.entries().end()) - << " entries\n"); + << size(NewEHFrame.entries()) << " entries\n"); // Add entries from the original .eh_frame corresponding to the functions // that we did not update. @@ -707,9 +705,7 @@ }; LLVM_DEBUG(dbgs() << "BOLT-DEBUG: old .eh_frame contains " - << std::distance(OldEHFrame.entries().begin(), - OldEHFrame.entries().end()) - << " entries\n"); + << size(OldEHFrame.entries()) << " entries\n"); // Generate a new .eh_frame_hdr based on the new map. diff --git a/bolt/lib/Passes/BinaryPasses.cpp b/bolt/lib/Passes/BinaryPasses.cpp --- a/bolt/lib/Passes/BinaryPasses.cpp +++ b/bolt/lib/Passes/BinaryPasses.cpp @@ -1420,10 +1420,10 @@ if (ProfiledFunctions.size() > 10) { if (opts::Verbosity >= 1) { outs() << "BOLT-INFO: top called functions are:\n"; - std::sort(ProfiledFunctions.begin(), ProfiledFunctions.end(), - [](const BinaryFunction *A, const BinaryFunction *B) { - return B->getExecutionCount() < A->getExecutionCount(); - }); + sort(ProfiledFunctions, + [](const BinaryFunction *A, const BinaryFunction *B) { + return B->getExecutionCount() < A->getExecutionCount(); + }); auto SFI = ProfiledFunctions.begin(); auto SFIend = ProfiledFunctions.end(); for (unsigned I = 0u; I < opts::TopCalledLimit && SFI != SFIend; @@ -1433,8 +1433,7 @@ } if (!opts::PrintSortedBy.empty() && - std::find(opts::PrintSortedBy.begin(), opts::PrintSortedBy.end(), - DynoStats::FIRST_DYNO_STAT) == opts::PrintSortedBy.end()) { + !is_contained(opts::PrintSortedBy, DynoStats::FIRST_DYNO_STAT)) { std::vector Functions; std::map Stats; @@ -1448,29 +1447,25 @@ } const bool SortAll = - std::find(opts::PrintSortedBy.begin(), opts::PrintSortedBy.end(), - DynoStats::LAST_DYNO_STAT) != opts::PrintSortedBy.end(); + is_contained(opts::PrintSortedBy, DynoStats::LAST_DYNO_STAT); const bool Ascending = opts::DynoStatsSortOrderOpt == opts::DynoStatsSortOrder::Ascending; if (SortAll) { - std::stable_sort(Functions.begin(), Functions.end(), - [Ascending, &Stats](const BinaryFunction *A, - const BinaryFunction *B) { - return Ascending ? Stats.at(A) < Stats.at(B) - : Stats.at(B) < Stats.at(A); - }); + stable_sort(Functions, [Ascending, &Stats](const BinaryFunction *A, + const BinaryFunction *B) { + return Ascending ? Stats.at(A) < Stats.at(B) + : Stats.at(B) < Stats.at(A); + }); } else { - std::stable_sort( - Functions.begin(), Functions.end(), - [Ascending, &Stats](const BinaryFunction *A, - const BinaryFunction *B) { - const DynoStats &StatsA = Stats.at(A); - const DynoStats &StatsB = Stats.at(B); - return Ascending ? StatsA.lessThan(StatsB, opts::PrintSortedBy) - : StatsB.lessThan(StatsA, opts::PrintSortedBy); - }); + stable_sort(Functions, [Ascending, &Stats](const BinaryFunction *A, + const BinaryFunction *B) { + const DynoStats &StatsA = Stats.at(A); + const DynoStats &StatsB = Stats.at(B); + return Ascending ? StatsA.lessThan(StatsB, opts::PrintSortedBy) + : StatsB.lessThan(StatsA, opts::PrintSortedBy); + }); } outs() << "BOLT-INFO: top functions sorted by "; @@ -1564,11 +1559,11 @@ } if (!SuboptimalFuncs.empty()) { - std::sort(SuboptimalFuncs.begin(), SuboptimalFuncs.end(), - [](const BinaryFunction *A, const BinaryFunction *B) { - return A->getKnownExecutionCount() / A->getSize() > - B->getKnownExecutionCount() / B->getSize(); - }); + sort(SuboptimalFuncs, + [](const BinaryFunction *A, const BinaryFunction *B) { + return A->getKnownExecutionCount() / A->getSize() > + B->getKnownExecutionCount() / B->getSize(); + }); outs() << "BOLT-INFO: " << SuboptimalFuncs.size() << " functions have " diff --git a/bolt/lib/Passes/ExtTSPReorderAlgorithm.cpp b/bolt/lib/Passes/ExtTSPReorderAlgorithm.cpp --- a/bolt/lib/Passes/ExtTSPReorderAlgorithm.cpp +++ b/bolt/lib/Passes/ExtTSPReorderAlgorithm.cpp @@ -801,8 +801,7 @@ } // Remove chain From from the list of active chains - auto Iter = std::remove(HotChains.begin(), HotChains.end(), From); - HotChains.erase(Iter, HotChains.end()); + erase_value(HotChains, From); // Invalidate caches for (std::pair EdgeIter : Into->edges()) @@ -818,26 +817,23 @@ SortedChains.push_back(&Chain); // Sorting chains by density in decreasing order - std::stable_sort( - SortedChains.begin(), SortedChains.end(), - [](const Chain *C1, const Chain *C2) { - // Original entry point to the front - if (C1->isEntryPoint() != C2->isEntryPoint()) { - if (C1->isEntryPoint()) - return true; - if (C2->isEntryPoint()) - return false; - } + stable_sort(SortedChains, [](const Chain *C1, const Chain *C2) { + // Original entry point to the front + if (C1->isEntryPoint() != C2->isEntryPoint()) { + if (C1->isEntryPoint()) + return true; + if (C2->isEntryPoint()) + return false; + } - const double D1 = C1->density(); - const double D2 = C2->density(); - if (D1 != D2) - return D1 > D2; + const double D1 = C1->density(); + const double D2 = C2->density(); + if (D1 != D2) + return D1 > D2; - // Making the order deterministic - return C1->id() < C2->id(); - } - ); + // Making the order deterministic + return C1->id() < C2->id(); + }); // Collect the basic blocks in the order specified by their chains Order.reserve(BF.layout_size()); diff --git a/bolt/lib/Passes/HFSort.cpp b/bolt/lib/Passes/HFSort.cpp --- a/bolt/lib/Passes/HFSort.cpp +++ b/bolt/lib/Passes/HFSort.cpp @@ -86,7 +86,7 @@ void freezeClusters(const CallGraph &Cg, std::vector &Clusters) { uint32_t TotalSize = 0; - std::sort(Clusters.begin(), Clusters.end(), compareClustersDensity); + sort(Clusters, compareClustersDensity); for (Cluster &C : Clusters) { uint32_t NewSize = TotalSize + C.size(); if (NewSize > FrozenPages * HugePageSize) @@ -150,13 +150,12 @@ for (Cluster &Cluster : Clusters) FuncCluster[Cluster.targets().front()] = &Cluster; - std::sort(SortedFuncs.begin(), SortedFuncs.end(), - [&](const NodeId F1, const NodeId F2) { - const CallGraph::Node &Func1 = Cg.getNode(F1); - const CallGraph::Node &Func2 = Cg.getNode(F2); - return Func1.samples() * Func2.size() > // TODO: is this correct? - Func2.samples() * Func1.size(); - }); + sort(SortedFuncs, [&](const NodeId F1, const NodeId F2) { + const CallGraph::Node &Func1 = Cg.getNode(F1); + const CallGraph::Node &Func2 = Cg.getNode(F2); + return Func1.samples() * Func2.size() > // TODO: is this correct? + Func2.samples() * Func1.size(); + }); // Process each function, and consider merging its cluster with the // one containing its most likely predecessor. @@ -234,8 +233,7 @@ Visited.insert(Cluster); } - std::sort(SortedClusters.begin(), SortedClusters.end(), - compareClustersDensity); + sort(SortedClusters, compareClustersDensity); return SortedClusters; } @@ -251,9 +249,8 @@ Clusters.emplace_back(F, Cg.getNode(F)); } - std::sort( - Clusters.begin(), Clusters.end(), - [](const Cluster &A, const Cluster &B) { return A.size() < B.size(); }); + sort(Clusters, + [](const Cluster &A, const Cluster &B) { return A.size() < B.size(); }); auto pickMergeCluster = [&Clusters](const size_t Idx) { size_t MaxIdx = Idx + 1; diff --git a/bolt/lib/Passes/HFSortPlus.cpp b/bolt/lib/Passes/HFSortPlus.cpp --- a/bolt/lib/Passes/HFSortPlus.cpp +++ b/bolt/lib/Passes/HFSortPlus.cpp @@ -245,7 +245,7 @@ // Making sure the comparison is deterministic return L->Id < R->Id; }; - std::stable_sort(HotChains.begin(), HotChains.end(), DensityComparator); + stable_sort(HotChains, DensityComparator); // Return the set of clusters that are left, which are the ones that // didn't get merged (so their first func is its original func) @@ -453,9 +453,8 @@ } // Sort the pairs by the weight in reverse order - std::sort( - ArcsToMerge.begin(), ArcsToMerge.end(), - [](const Arc *L, const Arc *R) { return L->weight() > R->weight(); }); + sort(ArcsToMerge, + [](const Arc *L, const Arc *R) { return L->weight() > R->weight(); }); // Merge the pairs of chains for (const Arc *Arc : ArcsToMerge) { @@ -567,8 +566,7 @@ Into->Score = score(Into); // Remove chain From From the list of active chains - auto it = std::remove(HotChains.begin(), HotChains.end(), From); - HotChains.erase(it, HotChains.end()); + erase_value(HotChains, From); } private: diff --git a/bolt/lib/Passes/IdenticalCodeFolding.cpp b/bolt/lib/Passes/IdenticalCodeFolding.cpp --- a/bolt/lib/Passes/IdenticalCodeFolding.cpp +++ b/bolt/lib/Passes/IdenticalCodeFolding.cpp @@ -479,11 +479,10 @@ // Fold functions. Keep the order consistent across invocations with // different options. - std::stable_sort(Twins.begin(), Twins.end(), - [](const BinaryFunction *A, const BinaryFunction *B) { - return A->getFunctionNumber() < - B->getFunctionNumber(); - }); + stable_sort(Twins, + [](const BinaryFunction *A, const BinaryFunction *B) { + return A->getFunctionNumber() < B->getFunctionNumber(); + }); BinaryFunction *ParentBF = Twins[0]; for (unsigned I = 1; I < Twins.size(); ++I) { diff --git a/bolt/lib/Passes/IndirectCallPromotion.cpp b/bolt/lib/Passes/IndirectCallPromotion.cpp --- a/bolt/lib/Passes/IndirectCallPromotion.cpp +++ b/bolt/lib/Passes/IndirectCallPromotion.cpp @@ -238,17 +238,16 @@ } // Sort by symbol then addr. - std::sort(Targets.begin(), Targets.end(), - [](const Callsite &A, const Callsite &B) { - if (A.To.Sym && B.To.Sym) - return A.To.Sym < B.To.Sym; - else if (A.To.Sym && !B.To.Sym) - return true; - else if (!A.To.Sym && B.To.Sym) - return false; - else - return A.To.Addr < B.To.Addr; - }); + sort(Targets, [](const Callsite &A, const Callsite &B) { + if (A.To.Sym && B.To.Sym) + return A.To.Sym < B.To.Sym; + else if (A.To.Sym && !B.To.Sym) + return true; + else if (!A.To.Sym && B.To.Sym) + return false; + else + return A.To.Addr < B.To.Addr; + }); // Targets may contain multiple entries to the same target, but using // different indices. Their profile will report the same number of branches @@ -294,21 +293,18 @@ // Sort by target count, number of indices in case of jump table, and // mispredicts. We prioritize targets with high count, small number of indices // and high mispredicts. Break ties by selecting targets with lower addresses. - std::stable_sort(Targets.begin(), Targets.end(), - [](const Callsite &A, const Callsite &B) { - if (A.Branches != B.Branches) - return A.Branches > B.Branches; - if (A.JTIndices.size() != B.JTIndices.size()) - return A.JTIndices.size() < B.JTIndices.size(); - if (A.Mispreds != B.Mispreds) - return A.Mispreds > B.Mispreds; - return A.To.Addr < B.To.Addr; - }); + stable_sort(Targets, [](const Callsite &A, const Callsite &B) { + if (A.Branches != B.Branches) + return A.Branches > B.Branches; + if (A.JTIndices.size() != B.JTIndices.size()) + return A.JTIndices.size() < B.JTIndices.size(); + if (A.Mispreds != B.Mispreds) + return A.Mispreds > B.Mispreds; + return A.To.Addr < B.To.Addr; + }); // Remove non-symbol targets - auto Last = std::remove_if(Targets.begin(), Targets.end(), - [](const Callsite &CS) { return !CS.To.Sym; }); - Targets.erase(Last, Targets.end()); + erase_if(Targets, [](const Callsite &CS) { return !CS.To.Sym; }); LLVM_DEBUG(if (BF.getJumpTable(Inst)) { uint64_t TotalCount = 0; @@ -471,14 +467,13 @@ HotTarget.second = Index; } - std::transform( - HotTargetMap.begin(), HotTargetMap.end(), std::back_inserter(HotTargets), - [](const std::pair> &A) { - return A.second; - }); + transform(HotTargetMap, std::back_inserter(HotTargets), + [](const std::pair> &A) { + return A.second; + }); // Sort with highest counts first. - std::sort(HotTargets.rbegin(), HotTargets.rend()); + sort(reverse(HotTargets)); LLVM_DEBUG({ dbgs() << "BOLT-INFO: ICP jump table hot targets:\n"; @@ -566,9 +561,7 @@ NewTargets.push_back(Target); std::vector({JTIndex}).swap(NewTargets.back().JTIndices); - Target.JTIndices.erase(std::remove(Target.JTIndices.begin(), - Target.JTIndices.end(), JTIndex), - Target.JTIndices.end()); + erase_value(Target.JTIndices, JTIndex); // Keep fixCFG counts sane if more indices use this same target later assert(IndicesPerTarget[Target.To.Sym] > 0 && "wrong map"); @@ -581,7 +574,7 @@ Target.Branches -= NewTargets.back().Branches; Target.Mispreds -= NewTargets.back().Mispreds; } - std::copy(Targets.begin(), Targets.end(), std::back_inserter(NewTargets)); + copy(Targets, std::back_inserter(NewTargets)); std::swap(NewTargets, Targets); N = I; @@ -1168,7 +1161,7 @@ } // Sort callsites by execution count. - std::sort(IndirectCalls.rbegin(), IndirectCalls.rend()); + sort(reverse(IndirectCalls)); // Find callsites that contribute to the top "opts::ICPTopCallsites"% // number of calls. diff --git a/bolt/lib/Passes/Inliner.cpp b/bolt/lib/Passes/Inliner.cpp --- a/bolt/lib/Passes/Inliner.cpp +++ b/bolt/lib/Passes/Inliner.cpp @@ -353,10 +353,10 @@ // Add CFG edges to the basic blocks of the inlined instance. std::vector Successors(BB.succ_size()); - std::transform(BB.succ_begin(), BB.succ_end(), Successors.begin(), - [&InlinedBBMap](const BinaryBasicBlock *BB) { - return InlinedBBMap.at(BB); - }); + transform(BB.successors(), Successors.begin(), + [&InlinedBBMap](const BinaryBasicBlock *BB) { + return InlinedBBMap.at(BB); + }); if (CallerFunction.hasValidProfile() && Callee.hasValidProfile()) InlinedBB->addSuccessors(Successors.begin(), Successors.end(), @@ -397,11 +397,9 @@ BinaryContext &BC = Function.getBinaryContext(); std::vector Blocks(Function.layout().begin(), Function.layout().end()); - std::sort(Blocks.begin(), Blocks.end(), - [](const BinaryBasicBlock *BB1, const BinaryBasicBlock *BB2) { - return BB1->getKnownExecutionCount() > - BB2->getKnownExecutionCount(); - }); + sort(Blocks, [](const BinaryBasicBlock *BB1, const BinaryBasicBlock *BB2) { + return BB1->getKnownExecutionCount() > BB2->getKnownExecutionCount(); + }); bool DidInlining = false; for (BinaryBasicBlock *BB : Blocks) { @@ -520,11 +518,10 @@ continue; ConsideredFunctions.push_back(&Function); } - std::sort(ConsideredFunctions.begin(), ConsideredFunctions.end(), - [](const BinaryFunction *A, const BinaryFunction *B) { - return B->getKnownExecutionCount() < - A->getKnownExecutionCount(); - }); + sort(ConsideredFunctions, + [](const BinaryFunction *A, const BinaryFunction *B) { + return B->getKnownExecutionCount() < A->getKnownExecutionCount(); + }); for (BinaryFunction *Function : ConsideredFunctions) { if (opts::InlineLimit && NumInlinedCallSites >= opts::InlineLimit) break; diff --git a/bolt/lib/Passes/Instrumentation.cpp b/bolt/lib/Passes/Instrumentation.cpp --- a/bolt/lib/Passes/Instrumentation.cpp +++ b/bolt/lib/Passes/Instrumentation.cpp @@ -578,9 +578,8 @@ MCSymbol *Target = BC.registerNameAtAddress( "__bolt_instr_fini", FiniSection->getAddress(), 0, 0); auto IsLEA = [&BC](const MCInst &Inst) { return BC.MIB->isLEA64r(Inst); }; - const auto LEA = - std::find_if(std::next(std::find_if(BB.rbegin(), BB.rend(), IsLEA)), - BB.rend(), IsLEA); + const auto LEA = std::find_if(std::next(find_if(reverse(BB), IsLEA)), + BB.rend(), IsLEA); LEA->getOperand(4).setExpr( MCSymbolRefExpr::create(Target, MCSymbolRefExpr::VK_None, *BC.Ctx)); } else { diff --git a/bolt/lib/Passes/LongJmp.cpp b/bolt/lib/Passes/LongJmp.cpp --- a/bolt/lib/Passes/LongJmp.cpp +++ b/bolt/lib/Passes/LongJmp.cpp @@ -89,13 +89,11 @@ auto registerInMap = [&](StubGroupsTy &Map) { StubGroupTy &StubGroup = Map[TgtSym]; StubGroup.insert( - std::lower_bound( - StubGroup.begin(), StubGroup.end(), - std::make_pair(AtAddress, nullptr), - [&](const std::pair &LHS, - const std::pair &RHS) { - return LHS.first < RHS.first; - }), + lower_bound(StubGroup, std::make_pair(AtAddress, nullptr), + [&](const std::pair &LHS, + const std::pair &RHS) { + return LHS.first < RHS.first; + }), std::make_pair(AtAddress, StubBB.get())); }; @@ -126,12 +124,12 @@ const StubGroupTy &Candidates = CandidatesIter->second; if (Candidates.empty()) return nullptr; - auto Cand = std::lower_bound( - Candidates.begin(), Candidates.end(), std::make_pair(DotAddress, nullptr), - [&](const std::pair &LHS, - const std::pair &RHS) { - return LHS.first < RHS.first; - }); + auto Cand = + lower_bound(Candidates, std::make_pair(DotAddress, nullptr), + [&](const std::pair &LHS, + const std::pair &RHS) { + return LHS.first < RHS.first; + }); if (Cand == Candidates.end()) return nullptr; if (Cand != Candidates.begin()) { @@ -256,11 +254,11 @@ for (auto &KeyVal : StubGroups) { for (StubTy &Elem : KeyVal.second) Elem.first = BBAddresses[Elem.second]; - std::sort(KeyVal.second.begin(), KeyVal.second.end(), - [&](const std::pair &LHS, - const std::pair &RHS) { - return LHS.first < RHS.first; - }); + sort(KeyVal.second, + [&](const std::pair &LHS, + const std::pair &RHS) { + return LHS.first < RHS.first; + }); } }; diff --git a/bolt/lib/Passes/LoopInversionPass.cpp b/bolt/lib/Passes/LoopInversionPass.cpp --- a/bolt/lib/Passes/LoopInversionPass.cpp +++ b/bolt/lib/Passes/LoopInversionPass.cpp @@ -73,10 +73,9 @@ if (IsChanged) { BinaryFunction::BasicBlockOrderType NewOrder = BF.getLayout(); - std::sort(NewOrder.begin(), NewOrder.end(), - [&](BinaryBasicBlock *BB1, BinaryBasicBlock *BB2) { - return BB1->getLayoutIndex() < BB2->getLayoutIndex(); - }); + sort(NewOrder, [&](BinaryBasicBlock *BB1, BinaryBasicBlock *BB2) { + return BB1->getLayoutIndex() < BB2->getLayoutIndex(); + }); BF.updateBasicBlockLayout(NewOrder); } diff --git a/bolt/lib/Passes/PettisAndHansen.cpp b/bolt/lib/Passes/PettisAndHansen.cpp --- a/bolt/lib/Passes/PettisAndHansen.cpp +++ b/bolt/lib/Passes/PettisAndHansen.cpp @@ -207,7 +207,7 @@ for (Cluster *C : LiveClusters) OutClusters.push_back(std::move(*C)); - std::sort(OutClusters.begin(), OutClusters.end(), compareClustersDensity); + sort(OutClusters, compareClustersDensity); return OutClusters; } diff --git a/bolt/lib/Passes/RegReAssign.cpp b/bolt/lib/Passes/RegReAssign.cpp --- a/bolt/lib/Passes/RegReAssign.cpp +++ b/bolt/lib/Passes/RegReAssign.cpp @@ -197,8 +197,8 @@ } } std::iota(RankedRegs.begin(), RankedRegs.end(), 0); // 0, 1, 2, 3... - std::sort(RankedRegs.begin(), RankedRegs.end(), - [&](size_t A, size_t B) { return RegScore[A] > RegScore[B]; }); + sort(RankedRegs, + [&](size_t A, size_t B) { return RegScore[A] > RegScore[B]; }); LLVM_DEBUG({ for (size_t Reg : RankedRegs) { diff --git a/bolt/lib/Passes/ReorderAlgorithm.cpp b/bolt/lib/Passes/ReorderAlgorithm.cpp --- a/bolt/lib/Passes/ReorderAlgorithm.cpp +++ b/bolt/lib/Passes/ReorderAlgorithm.cpp @@ -244,7 +244,7 @@ }; // Sort edges in increasing profile count order. - std::sort(Queue.begin(), Queue.end(), Comp); + sort(Queue, Comp); } void PHGreedyClusterAlgorithm::adjustQueue(std::vector &Queue, @@ -385,7 +385,7 @@ // Sort remaining edges in increasing weight order. Queue.swap(NewQueue); - std::sort(Queue.begin(), Queue.end(), Comp); + sort(Queue, Comp); } bool MinBranchGreedyClusterAlgorithm::areClustersCompatible( diff --git a/bolt/lib/Passes/ReorderData.cpp b/bolt/lib/Passes/ReorderData.cpp --- a/bolt/lib/Passes/ReorderData.cpp +++ b/bolt/lib/Passes/ReorderData.cpp @@ -275,8 +275,8 @@ DataOrder Order = baseOrder(BC, Section); unsigned SplitPoint = Order.size(); - std::sort( - Order.begin(), Order.end(), + sort( + Order, [&](const DataOrder::value_type &A, const DataOrder::value_type &B) { // Total execution counts of functions referencing BD. const uint64_t ACount = BDtoFuncCount[A.first]; @@ -307,17 +307,17 @@ DataOrder Order = baseOrder(BC, Section); unsigned SplitPoint = Order.size(); - std::sort(Order.begin(), Order.end(), - [](const DataOrder::value_type &A, const DataOrder::value_type &B) { - // Weight by number of loads/data size. - const double AWeight = double(A.second) / A.first->getSize(); - const double BWeight = double(B.second) / B.first->getSize(); - return (AWeight > BWeight || - (AWeight == BWeight && - (A.first->getSize() < B.first->getSize() || - (A.first->getSize() == B.first->getSize() && - A.first->getAddress() < B.first->getAddress())))); - }); + sort(Order, + [](const DataOrder::value_type &A, const DataOrder::value_type &B) { + // Weight by number of loads/data size. + const double AWeight = double(A.second) / A.first->getSize(); + const double BWeight = double(B.second) / B.first->getSize(); + return (AWeight > BWeight || + (AWeight == BWeight && + (A.first->getSize() < B.first->getSize() || + (A.first->getSize() == B.first->getSize() && + A.first->getAddress() < B.first->getAddress())))); + }); for (unsigned Idx = 0; Idx < Order.size(); ++Idx) { if (!Order[Idx].second) { diff --git a/bolt/lib/Passes/ReorderFunctions.cpp b/bolt/lib/Passes/ReorderFunctions.cpp --- a/bolt/lib/Passes/ReorderFunctions.cpp +++ b/bolt/lib/Passes/ReorderFunctions.cpp @@ -292,28 +292,26 @@ { std::vector SortedFunctions(BFs.size()); uint32_t Index = 0; - std::transform(BFs.begin(), - BFs.end(), - SortedFunctions.begin(), - [](std::pair &BFI) { - return &BFI.second; - }); - std::stable_sort(SortedFunctions.begin(), SortedFunctions.end(), - [&](const BinaryFunction *A, const BinaryFunction *B) { - if (A->isIgnored()) - return false; - const size_t PadA = opts::padFunction(*A); - const size_t PadB = opts::padFunction(*B); - if (!PadA || !PadB) { - if (PadA) - return true; - if (PadB) - return false; - } - return !A->hasProfile() && + transform(BFs, SortedFunctions.begin(), + [](std::pair &BFI) { + return &BFI.second; + }); + stable_sort(SortedFunctions, + [&](const BinaryFunction *A, const BinaryFunction *B) { + if (A->isIgnored()) + return false; + const size_t PadA = opts::padFunction(*A); + const size_t PadB = opts::padFunction(*B); + if (!PadA || !PadB) { + if (PadA) + return true; + if (PadB) + return false; + } + return !A->hasProfile() && (B->hasProfile() || (A->getExecutionCount() > B->getExecutionCount())); - }); + }); for (BinaryFunction *BF : SortedFunctions) if (BF->hasProfile()) BF->setIndex(Index++); @@ -409,24 +407,22 @@ if (FuncsFile || LinkSectionsFile) { std::vector SortedFunctions(BFs.size()); - std::transform(BFs.begin(), BFs.end(), SortedFunctions.begin(), - [](std::pair &BFI) { - return &BFI.second; - }); + transform(BFs, SortedFunctions.begin(), + [](std::pair &BFI) { + return &BFI.second; + }); // Sort functions by index. - std::stable_sort( - SortedFunctions.begin(), - SortedFunctions.end(), - [](const BinaryFunction *A, const BinaryFunction *B) { - if (A->hasValidIndex() && B->hasValidIndex()) - return A->getIndex() < B->getIndex(); - if (A->hasValidIndex() && !B->hasValidIndex()) - return true; - if (!A->hasValidIndex() && B->hasValidIndex()) - return false; - return A->getAddress() < B->getAddress(); - }); + stable_sort(SortedFunctions, + [](const BinaryFunction *A, const BinaryFunction *B) { + if (A->hasValidIndex() && B->hasValidIndex()) + return A->getIndex() < B->getIndex(); + if (A->hasValidIndex() && !B->hasValidIndex()) + return true; + if (!A->hasValidIndex() && B->hasValidIndex()) + return false; + return A->getAddress() < B->getAddress(); + }); for (const BinaryFunction *Func : SortedFunctions) { if (!Func->hasValidIndex()) @@ -440,7 +436,7 @@ if (LinkSectionsFile) { const char *Indent = ""; std::vector AllNames = Func->getNames(); - std::sort(AllNames.begin(), AllNames.end()); + sort(AllNames); for (StringRef Name : AllNames) { const size_t SlashPos = Name.find('/'); if (SlashPos != std::string::npos) { diff --git a/bolt/lib/Passes/ShrinkWrapping.cpp b/bolt/lib/Passes/ShrinkWrapping.cpp --- a/bolt/lib/Passes/ShrinkWrapping.cpp +++ b/bolt/lib/Passes/ShrinkWrapping.cpp @@ -853,24 +853,21 @@ DominatorAnalysis &DA = Info.getDominatorAnalysis(); auto &InsnToBB = Info.getInsnToBBMap(); - std::sort(Order.begin(), Order.end(), - [&](const MCPhysReg &A, const MCPhysReg &B) { - BinaryBasicBlock *BBA = - BestSavePos[A] ? InsnToBB[BestSavePos[A]] : nullptr; - BinaryBasicBlock *BBB = - BestSavePos[B] ? InsnToBB[BestSavePos[B]] : nullptr; - if (BBA == BBB) - return A < B; - if (!BBA && BBB) - return false; - if (BBA && !BBB) - return true; - if (DA.doesADominateB(*BestSavePos[A], *BestSavePos[B])) - return true; - if (DA.doesADominateB(*BestSavePos[B], *BestSavePos[A])) - return false; - return A < B; - }); + sort(Order, [&](const MCPhysReg &A, const MCPhysReg &B) { + BinaryBasicBlock *BBA = BestSavePos[A] ? InsnToBB[BestSavePos[A]] : nullptr; + BinaryBasicBlock *BBB = BestSavePos[B] ? InsnToBB[BestSavePos[B]] : nullptr; + if (BBA == BBB) + return A < B; + if (!BBA && BBB) + return false; + if (BBA && !BBB) + return true; + if (DA.doesADominateB(*BestSavePos[A], *BestSavePos[B])) + return true; + if (DA.doesADominateB(*BestSavePos[B], *BestSavePos[A])) + return false; + return A < B; + }); for (MCPhysReg I = 0, E = BC.MRI->getNumRegs(); I != E; ++I) DomOrder[Order[I]] = I; @@ -1821,21 +1818,16 @@ } // Reorder POPs to obey the correct dominance relation between them - std::stable_sort(TodoList.begin(), TodoList.end(), - [&](const WorklistItem &A, const WorklistItem &B) { - if ((A.Action != WorklistItem::InsertPushOrPop || - !A.FIEToInsert.IsLoad) && - (B.Action != WorklistItem::InsertPushOrPop || - !B.FIEToInsert.IsLoad)) - return false; - if ((A.Action != WorklistItem::InsertPushOrPop || - !A.FIEToInsert.IsLoad)) - return true; - if ((B.Action != WorklistItem::InsertPushOrPop || - !B.FIEToInsert.IsLoad)) - return false; - return DomOrder[B.AffectedReg] < DomOrder[A.AffectedReg]; - }); + stable_sort(TodoList, [&](const WorklistItem &A, const WorklistItem &B) { + if ((A.Action != WorklistItem::InsertPushOrPop || !A.FIEToInsert.IsLoad) && + (B.Action != WorklistItem::InsertPushOrPop || !B.FIEToInsert.IsLoad)) + return false; + if ((A.Action != WorklistItem::InsertPushOrPop || !A.FIEToInsert.IsLoad)) + return true; + if ((B.Action != WorklistItem::InsertPushOrPop || !B.FIEToInsert.IsLoad)) + return false; + return DomOrder[B.AffectedReg] < DomOrder[A.AffectedReg]; + }); // Process insertions for (WorklistItem &Item : TodoList) { diff --git a/bolt/lib/Passes/SplitFunctions.cpp b/bolt/lib/Passes/SplitFunctions.cpp --- a/bolt/lib/Passes/SplitFunctions.cpp +++ b/bolt/lib/Passes/SplitFunctions.cpp @@ -188,10 +188,9 @@ // All blocks with 0 count that we can move go to the end of the function. // Even if they were natural to cluster formation and were seen in-between // hot basic blocks. - std::stable_sort(BF.layout_begin(), BF.layout_end(), - [&](BinaryBasicBlock *A, BinaryBasicBlock *B) { - return A->canOutline() < B->canOutline(); - }); + stable_sort(BF.layout(), [&](BinaryBasicBlock *A, BinaryBasicBlock *B) { + return A->canOutline() < B->canOutline(); + }); } else if (BF.hasEHRanges() && !opts::SplitEH) { // Typically functions with exception handling have landing pads at the end. // We cannot move beginning of landing pads, but we can move 0-count blocks diff --git a/bolt/lib/Passes/ThreeWayBranch.cpp b/bolt/lib/Passes/ThreeWayBranch.cpp --- a/bolt/lib/Passes/ThreeWayBranch.cpp +++ b/bolt/lib/Passes/ThreeWayBranch.cpp @@ -101,12 +101,10 @@ Blocks.push_back(std::make_pair(SecondEndpoint, SecondCC)); Blocks.push_back(std::make_pair(ThirdEndpoint, ThirdCC)); - std::sort(Blocks.begin(), Blocks.end(), - [&](const std::pair A, - const std::pair B) { - return A.first->getExecutionCount() < - B.first->getExecutionCount(); - }); + sort(Blocks, [&](const std::pair A, + const std::pair B) { + return A.first->getExecutionCount() < B.first->getExecutionCount(); + }); uint64_t NewSecondBranchCount = Blocks[1].first->getExecutionCount() + Blocks[0].first->getExecutionCount(); diff --git a/bolt/lib/Profile/DataAggregator.cpp b/bolt/lib/Profile/DataAggregator.cpp --- a/bolt/lib/Profile/DataAggregator.cpp +++ b/bolt/lib/Profile/DataAggregator.cpp @@ -114,10 +114,10 @@ sections.push_back( {Section.getName(), Section.getAddress(), Section.getEndAddress()}); } - std::sort(sections.begin(), sections.end(), - [](const SectionNameAndRange &A, const SectionNameAndRange &B) { - return A.BeginAddress < B.BeginAddress; - }); + sort(sections, + [](const SectionNameAndRange &A, const SectionNameAndRange &B) { + return A.BeginAddress < B.BeginAddress; + }); return sections; } } diff --git a/bolt/lib/Profile/DataReader.cpp b/bolt/lib/Profile/DataReader.cpp --- a/bolt/lib/Profile/DataReader.cpp +++ b/bolt/lib/Profile/DataReader.cpp @@ -95,7 +95,7 @@ I->To.Offset += Offset; } } - std::stable_sort(Data.begin(), Data.end()); + stable_sort(Data); ExecutionCount += FBD.ExecutionCount; for (auto I = FBD.EntryData.begin(), E = FBD.EntryData.end(); I != E; ++I) { assert(I->To.Name == FBD.Name); @@ -123,7 +123,7 @@ } uint64_t FuncSampleData::getSamples(uint64_t Start, uint64_t End) const { - assert(std::is_sorted(Data.begin(), Data.end())); + assert(is_sorted(Data)); struct Compare { bool operator()(const SampleInfo &SI, const uint64_t Val) const { return SI.Loc.Offset < Val; @@ -133,8 +133,8 @@ } }; uint64_t Result = 0; - for (auto I = std::lower_bound(Data.begin(), Data.end(), Start, Compare()), - E = std::lower_bound(Data.begin(), Data.end(), End, Compare()); + for (auto I = lower_bound(Data, Start, Compare()), + E = lower_bound(Data, End, Compare()); I != E; ++I) Result += I->Hits; return Result; @@ -1146,12 +1146,10 @@ } for (StringMapEntry &FuncSamples : NamesToSamples) - std::stable_sort(FuncSamples.second.Data.begin(), - FuncSamples.second.Data.end()); + stable_sort(FuncSamples.second.Data); for (StringMapEntry &MemEvents : NamesToMemEvents) - std::stable_sort(MemEvents.second.Data.begin(), - MemEvents.second.Data.end()); + stable_sort(MemEvents.second.Data); return std::error_code(); } @@ -1247,12 +1245,10 @@ } for (StringMapEntry &FuncBranches : NamesToBranches) - std::stable_sort(FuncBranches.second.Data.begin(), - FuncBranches.second.Data.end()); + stable_sort(FuncBranches.second.Data); for (StringMapEntry &MemEvents : NamesToMemEvents) - std::stable_sort(MemEvents.second.Data.begin(), - MemEvents.second.Data.end()); + stable_sort(MemEvents.second.Data); return std::error_code(); } diff --git a/bolt/lib/Profile/Heatmap.cpp b/bolt/lib/Profile/Heatmap.cpp --- a/bolt/lib/Profile/Heatmap.cpp +++ b/bolt/lib/Profile/Heatmap.cpp @@ -233,7 +233,7 @@ NumTotalCounts += KV.second; } - std::sort(Counts.begin(), Counts.end(), std::greater()); + sort(Counts, std::greater()); double RatioLeftInKB = (1.0 * BucketSize) / 1024; assert(NumTotalCounts > 0 && diff --git a/bolt/lib/Profile/YAMLProfileWriter.cpp b/bolt/lib/Profile/YAMLProfileWriter.cpp --- a/bolt/lib/Profile/YAMLProfileWriter.cpp +++ b/bolt/lib/Profile/YAMLProfileWriter.cpp @@ -106,7 +106,7 @@ } } - std::sort(YamlBB.CallSites.begin(), YamlBB.CallSites.end()); + sort(YamlBB.CallSites); // Skip printing if there's no profile data for non-entry basic block. // Include landing pads with non-zero execution count. diff --git a/bolt/lib/Rewrite/BoltDiff.cpp b/bolt/lib/Rewrite/BoltDiff.cpp --- a/bolt/lib/Rewrite/BoltDiff.cpp +++ b/bolt/lib/Rewrite/BoltDiff.cpp @@ -302,10 +302,9 @@ continue; Unmapped.emplace_back(&Function); } - std::sort(Unmapped.begin(), Unmapped.end(), - [&](const BinaryFunction *A, const BinaryFunction *B) { - return A->getFunctionScore() > B->getFunctionScore(); - }); + sort(Unmapped, [&](const BinaryFunction *A, const BinaryFunction *B) { + return A->getFunctionScore() > B->getFunctionScore(); + }); for (const BinaryFunction *Function : Unmapped) { outs() << Function->getPrintName() << " : "; outs() << Function->getFunctionScore() << "\n"; diff --git a/bolt/lib/Rewrite/DWARFRewriter.cpp b/bolt/lib/Rewrite/DWARFRewriter.cpp --- a/bolt/lib/Rewrite/DWARFRewriter.cpp +++ b/bolt/lib/Rewrite/DWARFRewriter.cpp @@ -1243,10 +1243,9 @@ // Sorting so it's easy to compare output. // They should be sharing the same Abbrev. - std::sort(TUContributions.begin(), TUContributions.end(), - [](const TUEntry &V1, const TUEntry &V2) -> bool { - return V1.second->Offset < V2.second->Offset; - }); + sort(TUContributions, [](const TUEntry &V1, const TUEntry &V2) -> bool { + return V1.second->Offset < V2.second->Offset; + }); for (auto &PairEntry : TUContributions) { const DWARFUnitIndex::Entry::SectionContribution *C = PairEntry.second; @@ -1289,11 +1288,11 @@ } // Sorting so it's easy to compare output. // They should be sharing the same Abbrev. - std::sort(TUContributions.begin(), TUContributions.end(), - [](const DWARFUnitIndex::Entry::SectionContribution *V1, - const DWARFUnitIndex::Entry::SectionContribution *V2) -> bool { - return V1->Offset < V2->Offset; - }); + sort(TUContributions, + [](const DWARFUnitIndex::Entry::SectionContribution *V1, + const DWARFUnitIndex::Entry::SectionContribution *V2) -> bool { + return V1->Offset < V2->Offset; + }); Streamer.switchSection(MCOFI.getDwarfInfoDWOSection()); for (const auto *C : TUContributions) Streamer.emitBytes(Contents.slice(C->Offset, C->Offset + C->Length)); diff --git a/bolt/lib/Rewrite/MachORewriteInstance.cpp b/bolt/lib/Rewrite/MachORewriteInstance.cpp --- a/bolt/lib/Rewrite/MachORewriteInstance.cpp +++ b/bolt/lib/Rewrite/MachORewriteInstance.cpp @@ -191,10 +191,9 @@ DataInCode.reserve(NumberOfEntries); for (auto I = O.begin_dices(), E = O.end_dices(); I != E; ++I) DataInCode.emplace_back(*I); - std::stable_sort(DataInCode.begin(), DataInCode.end(), - [](DataInCodeRegion LHS, DataInCodeRegion RHS) { - return LHS.Offset < RHS.Offset; - }); + stable_sort(DataInCode, [](DataInCodeRegion LHS, DataInCodeRegion RHS) { + return LHS.Offset < RHS.Offset; + }); return DataInCode; } @@ -244,10 +243,9 @@ } if (FunctionSymbols.empty()) return; - std::stable_sort(FunctionSymbols.begin(), FunctionSymbols.end(), - [](const SymbolRef &LHS, const SymbolRef &RHS) { - return cantFail(LHS.getValue()) < cantFail(RHS.getValue()); - }); + stable_sort(FunctionSymbols, [](const SymbolRef &LHS, const SymbolRef &RHS) { + return cantFail(LHS.getValue()) < cantFail(RHS.getValue()); + }); for (size_t Index = 0; Index < FunctionSymbols.size(); ++Index) { const uint64_t Address = cantFail(FunctionSymbols[Index].getValue()); ErrorOr Section = BC->getSectionForAddress(Address); diff --git a/bolt/lib/Rewrite/RewriteInstance.cpp b/bolt/lib/Rewrite/RewriteInstance.cpp --- a/bolt/lib/Rewrite/RewriteInstance.cpp +++ b/bolt/lib/Rewrite/RewriteInstance.cpp @@ -307,11 +307,9 @@ namespace { bool refersToReorderedSection(ErrorOr Section) { - auto Itr = - std::find_if(opts::ReorderData.begin(), opts::ReorderData.end(), - [&](const std::string &SectionName) { - return (Section && Section->getName() == SectionName); - }); + auto Itr = find_if(opts::ReorderData, [&](const std::string &SectionName) { + return (Section && Section->getName() == SectionName); + }); return Itr != opts::ReorderData.end(); } @@ -839,8 +837,8 @@ return Section.isAllocatable(); }; std::vector SortedFileSymbols; - std::copy_if(InputFile->symbol_begin(), InputFile->symbol_end(), - std::back_inserter(SortedFileSymbols), isSymbolInMemory); + copy_if(InputFile->symbols(), std::back_inserter(SortedFileSymbols), + isSymbolInMemory); auto CompareSymbols = [this](const SymbolRef &A, const SymbolRef &B) { // Marker symbols have the highest precedence, while // SECTIONs have the lowest. @@ -865,8 +863,7 @@ return false; }; - std::stable_sort(SortedFileSymbols.begin(), SortedFileSymbols.end(), - CompareSymbols); + stable_sort(SortedFileSymbols, CompareSymbols); auto LastSymbol = SortedFileSymbols.end() - 1; @@ -2707,11 +2704,9 @@ if (ProfileReader->mayHaveProfileData(Function)) TopFunctions.push_back(&Function); } - std::sort(TopFunctions.begin(), TopFunctions.end(), - [](const BinaryFunction *A, const BinaryFunction *B) { - return - A->getKnownExecutionCount() < B->getKnownExecutionCount(); - }); + sort(TopFunctions, [](const BinaryFunction *A, const BinaryFunction *B) { + return A->getKnownExecutionCount() < B->getKnownExecutionCount(); + }); size_t Index = TopFunctions.size() * opts::LiteThresholdPct / 100; if (Index) @@ -3300,7 +3295,7 @@ std::vector Addresses; for (auto &Entry : Address2ProbesMap) Addresses.push_back(Entry.first); - std::sort(Addresses.begin(), Addresses.end()); + sort(Addresses); for (uint64_t Key : Addresses) { for (MCDecodedPseudoProbe &Probe : Address2ProbesMap[Key]) { if (Probe.getAddress() == INT64_MAX) @@ -3574,7 +3569,7 @@ }; // Determine the order of sections. - std::stable_sort(CodeSections.begin(), CodeSections.end(), compareSections); + stable_sort(CodeSections, compareSections); return CodeSections; } @@ -3606,12 +3601,9 @@ std::vector CodeSections = getCodeSections(); // Remove sections that were pre-allocated (patch sections). - CodeSections.erase( - std::remove_if(CodeSections.begin(), CodeSections.end(), - [](BinarySection *Section) { - return Section->getOutputAddress(); - }), - CodeSections.end()); + erase_if(CodeSections, [](BinarySection *Section) { + return Section->getOutputAddress(); + }); LLVM_DEBUG(dbgs() << "Code sections in the order of output:\n"; for (const BinarySection *Section : CodeSections) dbgs() << Section->getName() << '\n'; @@ -4268,11 +4260,10 @@ } // Sort all allocatable sections by their offset. - std::stable_sort(OutputSections.begin(), OutputSections.end(), - [] (const std::pair &A, - const std::pair &B) { - return A.second.sh_offset < B.second.sh_offset; - }); + stable_sort(OutputSections, [](const std::pair &A, + const std::pair &B) { + return A.second.sh_offset < B.second.sh_offset; + }); // Fix section sizes to prevent overlapping. ELFShdrTy *PrevSection = nullptr; @@ -4381,11 +4372,10 @@ } std::vector SectionsOnly(OutputSections.size()); - std::transform(OutputSections.begin(), OutputSections.end(), - SectionsOnly.begin(), - [](std::pair &SectionInfo) { - return SectionInfo.second; - }); + transform(OutputSections, SectionsOnly.begin(), + [](std::pair &SectionInfo) { + return SectionInfo.second; + }); return SectionsOnly; } @@ -4782,13 +4772,11 @@ } // Put local symbols at the beginning. - std::stable_sort(Symbols.begin(), Symbols.end(), - [](const ELFSymTy &A, const ELFSymTy &B) { - if (A.getBinding() == ELF::STB_LOCAL && - B.getBinding() != ELF::STB_LOCAL) - return true; - return false; - }); + stable_sort(Symbols, [](const ELFSymTy &A, const ELFSymTy &B) { + if (A.getBinding() == ELF::STB_LOCAL && B.getBinding() != ELF::STB_LOCAL) + return true; + return false; + }); for (const ELFSymTy &Symbol : Symbols) Write(0, Symbol); diff --git a/bolt/lib/RuntimeLibs/InstrumentationRuntimeLibrary.cpp b/bolt/lib/RuntimeLibs/InstrumentationRuntimeLibrary.cpp --- a/bolt/lib/RuntimeLibs/InstrumentationRuntimeLibrary.cpp +++ b/bolt/lib/RuntimeLibs/InstrumentationRuntimeLibrary.cpp @@ -243,13 +243,12 @@ }; // Indirect targets need to be sorted for fast lookup during runtime - std::sort(Summary->IndCallTargetDescriptions.begin(), - Summary->IndCallTargetDescriptions.end(), - [&](const IndCallTargetDescription &A, - const IndCallTargetDescription &B) { - return getOutputAddress(*A.Target, A.ToLoc.Offset) < - getOutputAddress(*B.Target, B.ToLoc.Offset); - }); + sort(Summary->IndCallTargetDescriptions, + [&](const IndCallTargetDescription &A, + const IndCallTargetDescription &B) { + return getOutputAddress(*A.Target, A.ToLoc.Offset) < + getOutputAddress(*B.Target, B.ToLoc.Offset); + }); // Start of the vector with descriptions (one CounterDescription for each // counter), vector size is Counters.size() CounterDescription-sized elmts diff --git a/bolt/tools/merge-fdata/merge-fdata.cpp b/bolt/tools/merge-fdata/merge-fdata.cpp --- a/bolt/tools/merge-fdata/merge-fdata.cpp +++ b/bolt/tools/merge-fdata/merge-fdata.cpp @@ -398,14 +398,15 @@ BinaryProfile MergedProfile; MergedProfile.Header = MergedHeader; MergedProfile.Functions.resize(MergedBFs.size()); - std::transform( - MergedBFs.begin(), MergedBFs.end(), MergedProfile.Functions.begin(), + transform( + MergedBFs, MergedProfile.Functions.begin(), [](StringMapEntry &V) { return V.second; }); // For consistency, sort functions by their IDs. - std::sort(MergedProfile.Functions.begin(), MergedProfile.Functions.end(), - [](const BinaryFunctionProfile &A, - const BinaryFunctionProfile &B) { return A.Id < B.Id; }); + sort(MergedProfile.Functions, + [](const BinaryFunctionProfile &A, const BinaryFunctionProfile &B) { + return A.Id < B.Id; + }); YamlOut << MergedProfile; } @@ -435,9 +436,8 @@ CountFuncType CountFunc = (opts::PrintFunctionList == opts::ST_EXEC_COUNT) ? ExecCountFunc : BranchCountFunc; - std::transform(MergedBFs.begin(), MergedBFs.end(), FunctionList.begin(), - CountFunc); - std::stable_sort(FunctionList.rbegin(), FunctionList.rend()); + transform(MergedBFs, FunctionList.begin(), CountFunc); + stable_sort(reverse(FunctionList)); errs() << "Functions sorted by " << (opts::PrintFunctionList == opts::ST_EXEC_COUNT ? "execution" : "total branch")