From c6bf37d56d73d8ab1c1da86ce4cfd21afb0ab43a Mon Sep 17 00:00:00 2001 From: Rui Ueyama Date: Tue, 3 Apr 2018 20:08:45 +0000 Subject: [PATCH] Instead of using std::copy, clear the vector first and add new elements. NFC. Differential Revision: https://reviews.llvm.org/D45227 llvm-svn: 329107 --- lld/ELF/Writer.cpp | 19 +++++++++---------- 1 file changed, 9 insertions(+), 10 deletions(-) diff --git a/lld/ELF/Writer.cpp b/lld/ELF/Writer.cpp index 610e2656e7a7..68dda6f06cf3 100644 --- a/lld/ELF/Writer.cpp +++ b/lld/ELF/Writer.cpp @@ -1137,24 +1137,23 @@ sortISDBySectionOrder(InputSectionDescription *ISD, // of the second block of cold code can call the hot code without a thunk. So // we effectively double the amount of code that could potentially call into // the hot code without a thunk. - size_t UnorderedInsPt = 0; + size_t InsPt = 0; if (Target->ThunkSectionSpacing && !OrderedSections.empty()) { uint64_t UnorderedPos = 0; - for (; UnorderedInsPt != UnorderedSections.size(); ++UnorderedInsPt) { - UnorderedPos += UnorderedSections[UnorderedInsPt]->getSize(); + for (; InsPt != UnorderedSections.size(); ++InsPt) { + UnorderedPos += UnorderedSections[InsPt]->getSize(); if (UnorderedPos > UnorderedSize / 2) break; } } - std::copy(UnorderedSections.begin(), - UnorderedSections.begin() + UnorderedInsPt, ISD->Sections.begin()); - std::vector::iterator SectionsPos = - ISD->Sections.begin() + UnorderedInsPt; + ISD->Sections.clear(); + for (InputSection *IS : makeArrayRef(UnorderedSections).slice(0, InsPt)) + ISD->Sections.push_back(IS); for (std::pair P : OrderedSections) - *SectionsPos++ = P.first; - std::copy(UnorderedSections.begin() + UnorderedInsPt, UnorderedSections.end(), - SectionsPos); + ISD->Sections.push_back(P.first); + for (InputSection *IS : makeArrayRef(UnorderedSections).slice(InsPt)) + ISD->Sections.push_back(IS); } static void sortSection(OutputSection *Sec,